/* ── RESET ── */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%;height:-webkit-fill-available}
body{height:100%;height:-webkit-fill-available;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:#060d12;color:#fff;overflow:hidden;-webkit-font-smoothing:antialiased}

/* ── MAP ── */
#map{position:fixed;inset:0;z-index:1;background:#0a1520;pointer-events:none;}
.leaflet-container{pointer-events:none;}

/* ── HEADER ── */
.header{position:fixed;top:0;left:0;right:0;z-index:500;background:rgba(6,13,18,.98);border-bottom:1px solid rgba(255,255,255,.06)}
.logo-main{font-size:17px;font-weight:900;letter-spacing:-.3px}
.logo-main em{font-style:normal;color:#22c55e}
.logo-sub{font-size:9px;font-weight:600;color:#4b5563;letter-spacing:1.5px;text-transform:uppercase}
.header-actions{display:flex;gap:6px}

/* Stats chips */
.stat-chip{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:4px 12px;font-size:11px;font-weight:600;color:#d1d5db;display:flex;align-items:center;gap:4px}
.sc-num{color:#22c55e;font-weight:800;font-size:13px}

/* ── BOTTOM NAV ── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:500;background:rgba(6,13,18,.97);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.06);display:flex;padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom))}
.bottom-nav button{flex:1;background:none;border:none;color:#4b5563;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 0;transition:color .2s}
.bottom-nav button.active{color:#22c55e}
.nav-icon{font-size:18px;line-height:1;font-style:normal}

/* ── SCREENS ── */
.screen{position:fixed;inset:0;overflow-y:auto;overflow-x:hidden;padding-top:88px;padding-bottom:max(60px,calc(60px + env(safe-area-inset-bottom)));display:none !important;background:#060d12;z-index:10}
.screen.active{display:block !important}
#screen-map{background:transparent;padding:0;overflow:hidden;z-index:2;pointer-events:none}
#screen-cards.active{display:flex !important;flex-direction:column;align-items:center}

/* ── MAP ── */
.map-overlays{position:fixed;top:88px;left:0;right:0;z-index:10;pointer-events:none}
.map-overlays>*{pointer-events:all}

/* Map selbst muss klickbar sein */
.leaflet-marker-icon{pointer-events:none;cursor:pointer;}

/* Filter Pills */
.filter-row{display:flex;gap:6px;padding:6px 12px 8px;overflow-x:auto;scrollbar-width:none;background:rgba(6,13,18,.85);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.05)}
.filter-row::-webkit-scrollbar{display:none}
.filter-pill{padding:6px 16px;border-radius:999px;border:1.5px solid rgba(255,255,255,.12);background:rgba(6,13,18,.8);color:#6b7280;font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .2s}
.filter-pill.active{border-color:#22c55e;background:rgba(34,197,94,.15);color:#22c55e}

/* FAB */
.fab{position:fixed;bottom:max(72px,calc(72px + env(safe-area-inset-bottom)));right:14px;z-index:400;height:44px;border-radius:22px;padding:0 18px;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;color:#fff;font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 4px 20px rgba(34,197,94,.4);transition:transform .15s}
.fab:active{transform:scale(.92)}

/* ── CARDS ── */
.cards-header{width:100%;padding:60px 20px 8px;text-align:center}
.cards-header h2{font-size:20px;font-weight:900}
.cards-header p{font-size:12px;color:#4b5563;margin-top:4px}
.card-stack{position:fixed;top:124px;bottom:max(200px,calc(200px + env(safe-area-inset-bottom)));left:16px;right:16px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.energy-card{position:absolute;width:100%;max-width:360px;border-radius:24px;overflow:hidden;cursor:grab;user-select:none;touch-action:none;box-shadow:0 24px 64px rgba(0,0,0,.7);max-height:calc(100% - 0px)}
.energy-card:active{cursor:grabbing}
.card-img{height:230px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.card-emoji{font-size:80px;position:relative;z-index:1;opacity:0.3}
.card-grad{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(0deg,rgba(0,0,0,.9) 0%,transparent 100%)}
.card-badge{position:absolute;top:14px;right:14px;z-index:2;padding:4px 12px;border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;backdrop-filter:blur(8px)}
.badge-v{background:rgba(245,158,11,.85);color:#000}
.badge-k{background:rgba(59,130,246,.85);color:#fff}
.badge-s{background:rgba(139,92,246,.85);color:#fff}
.card-title-area{position:absolute;bottom:0;left:0;right:0;padding:14px 18px;z-index:2}
.cname{font-size:26px;font-weight:900;line-height:1;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.cort{font-size:13px;color:rgba(255,255,255,.7);margin-top:4px}
.card-body{background:linear-gradient(180deg,#111827,#0d1520);padding:16px 18px 18px;border-top:1px solid rgba(255,255,255,.05)}
.card-kwh{font-size:32px;font-weight:900;color:#22c55e;letter-spacing:-1px}
.card-kwh small{font-size:13px;color:#4b5563;font-weight:400}
.card-anlage{font-size:12px;color:#6b7280;margin-bottom:6px;display:inline-block;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);border-radius:999px;padding:3px 10px;color:#22c55e}
.card-desc{font-size:13px;color:#6b7280;line-height:1.5}
.swipe-hint{position:absolute;top:50%;transform:translateY(-50%);font-size:16px;font-weight:900;padding:8px 14px;border-radius:10px;opacity:0 !important;pointer-events:none;z-index:20;letter-spacing:1px;transition:opacity .1s}
.swipe-l{left:16px;border:2px solid #ef4444;color:#ef4444;background:rgba(239,68,68,.15)}
.swipe-r{right:16px;border:2px solid #22c55e;color:#22c55e;background:rgba(34,197,94,.15)}

/* Card Actions */
.card-actions{position:fixed;bottom:max(72px,calc(72px + env(safe-area-inset-bottom)));left:0;right:0;display:flex;gap:20px;align-items:center;justify-content:center;z-index:1000;pointer-events:all}
.cta{border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .12s;box-shadow:0 4px 16px rgba(0,0,0,.5);pointer-events:all !important;position:relative;z-index:1001}
.cta:active{transform:scale(.88)}
.cta-nope{width:56px;height:56px;font-size:20px;background:#1a2535;border:2px solid rgba(239,68,68,.4);color:#ef4444}
.cta-match{width:70px;height:70px;font-size:14px;font-weight:800;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 4px 24px rgba(34,197,94,.5)}
.no-cards{text-align:center;padding:40px 20px}
.no-cards-icon{font-size:52px;margin-bottom:12px;opacity:.5}

/* ── MATCHES ── */
.screen-title{padding:14px 16px;font-size:20px;font-weight:900}
.match-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;transition:background .1s}
.match-item:active{background:rgba(255,255,255,.03)}
.m-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;font-weight:700;color:#fff}
.av-v{background:rgba(245,158,11,.2);border:1px solid rgba(245,158,11,.2)}
.av-k{background:rgba(59,130,246,.2);border:1px solid rgba(59,130,246,.2)}
.av-s{background:rgba(139,92,246,.2);border:1px solid rgba(139,92,246,.2)}
.m-info{flex:1;min-width:0}
.m-name{font-weight:700;font-size:14px;margin-bottom:3px}
.m-meta{font-size:12px;color:#4b5563;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.m-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.dot-a{background:#f59e0b}.dot-b{background:#22c55e}.dot-x{background:#ef4444}

/* ── PROFIL/LANDING ── */
.landing{padding:24px 20px 32px;text-align:center}
.landing h1{font-size:24px;font-weight:900;line-height:1.2;margin-bottom:10px}
.landing h1 span{color:#22c55e}
.landing p{font-size:14px;color:#6b7280;margin-bottom:24px;line-height:1.6}
.feature-list{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;text-align:left}
.feature-item{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:13px 14px;display:flex;align-items:center;gap:12px}
.fi-icon{font-size:20px;width:32px;text-align:center;flex-shrink:0;color:#22c55e;font-weight:700}
.fi-text strong{display:block;font-size:13px;font-weight:700;margin-bottom:1px}
.fi-text span{font-size:11px;color:#4b5563}
.profil-section{padding:0 16px 12px}
.profil-section h3{font-size:10px;font-weight:700;color:#4b5563;text-transform:uppercase;letter-spacing:1.5px;margin:16px 0 10px}
.profil-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:14px;margin-bottom:10px}

/* ── MODALS ── */
.modal-overlay{position:fixed;inset:0;z-index:700;display:none;flex-direction:column;justify-content:flex-end}
.modal-overlay.open{display:flex}
.modal-bg{position:absolute;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px)}
.modal-sheet{position:relative;background:linear-gradient(180deg,#111827,#0d1520);border-radius:24px 24px 0 0;border-top:1px solid rgba(255,255,255,.08);width:100%;padding:20px 18px;padding-bottom:max(20px,env(safe-area-inset-bottom));max-height:92vh;overflow-y:auto;animation:slideUp .3s ease;pointer-events:all}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-handle{width:36px;height:4px;background:rgba(255,255,255,.15);border-radius:999px;margin:0 auto 20px}
.modal-sheet h2{font-size:20px;font-weight:900;margin-bottom:4px}
.modal-sub{font-size:12px;color:#4b5563;margin-bottom:20px}
.modal-close{position:absolute;top:14px;right:14px;background:rgba(255,255,255,.08);border:none;color:#6b7280;width:30px;height:30px;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;pointer-events:all}

/* ── FORMS ── */
.fg{margin-bottom:12px}
.fg label{font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;display:block}
.fi{width:100%;padding:13px 14px;border-radius:12px;border:1.5px solid rgba(255,255,255,.08);background:rgba(255,255,255,.05);color:#fff;font-size:15px;outline:none;transition:border .2s;-webkit-appearance:none;appearance:none}
.fi:focus{border-color:#22c55e;background:rgba(34,197,94,.05)}
.fi option{background:#111827}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fe{color:#ef4444;font-size:12px;margin-top:-6px;margin-bottom:8px;min-height:14px}

/* ── BUTTONS ── */
.btn{padding:14px 20px;border-radius:14px;border:none;cursor:pointer;font-weight:700;font-size:14px;transition:all .12s;display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:6px}
.btn:active{transform:scale(.97)}
.btn-green{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 3px 14px rgba(34,197,94,.3)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.15)}
.btn-sm{padding:7px 14px;font-size:12px;border-radius:10px;width:auto;margin-top:0}

/* TYP SELECTOR */
.typ-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px}
.typ-card{border:2px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 6px;text-align:center;cursor:pointer;transition:all .2s;background:rgba(255,255,255,.04)}
.typ-card input{display:none}
.typ-icon{font-size:12px;font-weight:700;margin-bottom:5px;color:#fff}
.typ-lbl{font-size:10px;font-weight:700;color:#4b5563;text-transform:uppercase;letter-spacing:.3px}
.typ-card.sel-v{border-color:#f59e0b;background:rgba(245,158,11,.1)}.typ-card.sel-v .typ-lbl{color:#f59e0b}
.typ-card.sel-k{border-color:#3b82f6;background:rgba(59,130,246,.1)}.typ-card.sel-k .typ-lbl{color:#3b82f6}
.typ-card.sel-s{border-color:#8b5cf6;background:rgba(139,92,246,.1)}.typ-card.sel-s .typ-lbl{color:#8b5cf6}

/* ── CHAT ── */
.chat-screen{position:fixed;inset:0;background:#060d12;z-index:700;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .28s ease}
.chat-screen.open{transform:translateX(0)}
.chat-head{padding:max(14px,env(safe-area-inset-top)) 14px 12px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px;background:rgba(6,13,18,.98);flex-shrink:0}
.chat-back{background:rgba(255,255,255,.08);border:none;color:#22c55e;width:36px;height:36px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.chat-head-name{font-weight:800;font-size:16px}
.chat-head-sub{font-size:11px;color:#22c55e;margin-top:2px}
.chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.msg-wrap{display:flex;flex-direction:column;max-width:78%}
.msg-wrap.me{align-self:flex-end;align-items:flex-end}
.msg-wrap.other{align-self:flex-start}
.msg-bbl{padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5}
.me .msg-bbl{background:linear-gradient(135deg,#22c55e,#16a34a);color:#000;border-bottom-right-radius:3px;font-weight:500}
.other .msg-bbl{background:rgba(255,255,255,.08);color:#fff;border-bottom-left-radius:3px}
.msg-t{font-size:10px;color:#374151;margin-top:3px;padding:0 4px}
.chat-inp{padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom));background:rgba(6,13,18,.98);border-top:1px solid rgba(255,255,255,.06);display:flex;gap:8px;flex-shrink:0}
.chat-inp input{flex:1;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:11px 16px;color:#fff;font-size:14px;outline:none}
.chat-inp input:focus{border-color:#22c55e}
.chat-send-btn{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;color:#000;font-size:18px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800}

/* ── MATCH BLAST ── */
.match-blast{position:fixed;inset:0;z-index:800;pointer-events:none;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.match-blast.show{opacity:1;pointer-events:all}
.match-blast-inner{background:linear-gradient(135deg,rgba(34,197,94,.95),rgba(16,185,129,.95));border-radius:24px;padding:40px 48px;text-align:center;transform:scale(.5);transition:transform .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 24px 64px rgba(34,197,94,.4)}
.match-blast.show .match-blast-inner{transform:scale(1)}
.match-blast h2{font-size:28px;font-weight:900;color:#000;margin-bottom:4px}
.match-blast p{font-size:14px;color:rgba(0,0,0,.7)}
.confetti-piece{position:fixed;width:8px;height:8px;border-radius:2px;top:-10px;pointer-events:none;z-index:801;animation:confettiFall 1.8s ease-in forwards}
@keyframes confettiFall{to{transform:translateY(110vh) rotate(720deg);opacity:0}}

/* ── LEAFLET CUSTOM ── */
.leaflet-popup-content-wrapper{background:rgba(13,21,32,.97) !important;border:1px solid rgba(255,255,255,.1) !important;border-radius:16px !important;color:#fff !important;box-shadow:0 8px 32px rgba(0,0,0,.5) !important}
.leaflet-popup-tip{background:rgba(13,21,32,.97) !important}
.leaflet-popup-content{margin:14px 16px !important}
.leaflet-control-zoom a{background:rgba(6,13,18,.9) !important;color:#22c55e !important;border-color:rgba(255,255,255,.1) !important}
.leaflet-control-attribution{background:rgba(6,13,18,.7) !important;color:#374151 !important;font-size:10px !important}

/* ── TOAST ── */
#toast{position:fixed;bottom:max(80px,calc(80px + env(safe-area-inset-bottom)));left:50%;transform:translateX(-50%) translateY(16px);background:rgba(17,24,39,.97);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);color:#fff;padding:11px 20px;border-radius:14px;font-weight:700;z-index:999;font-size:13px;opacity:0;transition:all .25s;max-width:88vw;text-align:center;pointer-events:none}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── EMPTY ── */
.empty{text-align:center;padding:40px 20px;color:#374151}
.empty .ei{font-size:48px;margin-bottom:14px;opacity:.5}
.empty h3{font-size:15px;color:#4b5563;margin-bottom:6px;font-weight:700}

/* ── RESPONSIVE ── */
@media(min-width:480px){
  .card-stack{max-width:380px;left:50%;transform:translateX(-50%)}
  .card-actions{bottom:80px}
}


/* Leaflet nur klickbar wenn Karten-Screen aktiv */
#screen-map.active + * .leaflet-container,
body.map-active .leaflet-container { pointer-events:all !important; }
body.map-active .leaflet-marker-icon { pointer-events:all !important; cursor:pointer !important; }
