:root{
  --red:#ff3b5c; --orange:#ff9f1c; --green:#22e06b; --accent:#5b8cff;
  --txt:#eef2f8; --muted:#9aa7ba;
  --glass: rgba(18,23,33,.55);
  --glass-strong: rgba(16,21,30,.72);
  --stroke: rgba(255,255,255,.10);
  --stroke-soft: rgba(255,255,255,.06);
  --shadow: 0 10px 40px rgba(0,0,0,.45), 0 2px 8px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:#0b0f16;color:var(--txt);overflow:hidden;-webkit-font-smoothing:antialiased}
#map{position:fixed;inset:0}
.maplibregl-ctrl-attrib{font-size:10px}
.maplibregl-ctrl-attrib a{color:#1565a8}
/* Varsayılan kapalı: sadece ⓘ; tıklayınca (details açılınca) metin görünür */
.maplibregl-ctrl-attrib.maplibregl-compact .maplibregl-ctrl-attrib-inner{display:none!important}
.maplibregl-ctrl-attrib.maplibregl-compact[open] .maplibregl-ctrl-attrib-inner{display:block!important}

/* kenar vinyet */
.vignette{position:fixed;inset:0;pointer-events:none;z-index:1;
  box-shadow:inset 0 0 220px rgba(0,0,0,.65), inset 0 0 60px rgba(0,0,0,.35)}

/* cam yüzey */
.glass{background:var(--glass);backdrop-filter:blur(22px) saturate(165%);
  -webkit-backdrop-filter:blur(22px) saturate(165%);
  border:1px solid var(--stroke);border-radius:20px;box-shadow:var(--shadow);
  position:relative}
.glass::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,0) 40%)}

/* giriş animasyonu */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.card,.brand,.fabs{animation:fadeUp .6s cubic-bezier(.2,.8,.2,1) both}

/* Marka */
.brand{position:fixed;z-index:6;top:16px;left:16px;display:flex;gap:11px;align-items:center;
  padding:9px 15px 9px 11px;border-radius:16px}
.brand-logo{width:38px;height:38px;border-radius:50%;background:#fff;flex:none;
  box-shadow:0 0 0 1px rgba(255,255,255,.55), 0 3px 10px rgba(0,0,0,.45)}
.brand-txt{display:flex;flex-direction:column;line-height:1.2;max-width:205px}
.brand-txt b{font-size:12.5px;font-weight:700;letter-spacing:.2px}
.brand-txt i{font-size:10.5px;color:var(--muted);font-style:normal}

/* Bottom-sheet sarmalayıcı — masaüstünde etkisiz (kartlar yine fixed) */
#sheet{display:contents}
.sheet-handle{display:none}

/* Kartlar */
.card{position:fixed;z-index:6;width:330px;padding:16px}
.route-card{top:84px;left:16px}
.legend-card{top:16px;right:16px;width:290px}
.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.card-h h2{font-size:14px;margin:0;font-weight:700;letter-spacing:.2px}
.muted{color:var(--muted);font-size:12px}
.mini-link{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;font-weight:600;padding:2px 4px}

/* Alanlar */
.field{display:flex;align-items:center;gap:9px;margin-bottom:10px;position:relative}
.pin{width:26px;height:26px;min-width:26px;border-radius:9px;display:grid;place-items:center;
  font-weight:800;font-size:12px;color:#0b0f16}
.pin.a{background:linear-gradient(135deg,#7fa8ff,#5b8cff)}
.pin.b{background:linear-gradient(135deg,#9affc0,#22e06b)}
.geo{position:relative;flex:1}
input{width:100%;padding:11px 12px;background:rgba(255,255,255,.05);border:1px solid var(--stroke);
  border-radius:12px;color:var(--txt);font-size:13px;font-family:inherit;transition:.2s}
input::placeholder{color:#7c8aa0}
input:focus{outline:none;border-color:var(--accent);background:rgba(91,140,255,.10);
  box-shadow:0 0 0 4px rgba(91,140,255,.14)}
.icon-btn{width:34px;height:34px;min-width:34px;border-radius:11px;border:1px solid var(--stroke);
  background:rgba(255,255,255,.05);color:var(--txt);font-size:16px;cursor:pointer;transition:.18s}
.icon-btn:hover{background:rgba(91,140,255,.18);border-color:var(--accent);transform:translateY(-1px)}
.icon-btn.armed{background:var(--accent);border-color:var(--accent);animation:pulseBtn 1.1s infinite}
@keyframes pulseBtn{0%,100%{box-shadow:0 0 0 0 rgba(91,140,255,.5)}50%{box-shadow:0 0 0 7px rgba(91,140,255,0)}}

.suggestions{list-style:none;margin:6px 0 0;padding:5px;position:absolute;z-index:30;width:100%;
  background:var(--glass-strong);backdrop-filter:blur(20px);border:1px solid var(--stroke);
  border-radius:13px;max-height:210px;overflow:auto;box-shadow:var(--shadow);display:none}
.suggestions li{padding:9px 10px;font-size:12px;cursor:pointer;border-radius:9px;color:#d6deeb;transition:.12s}
.suggestions li:hover{background:rgba(91,140,255,.16)}

/* iOS switch */
.switch{position:relative;display:inline-block;width:40px;height:24px;min-width:40px}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch i{position:absolute;inset:0;border-radius:24px;background:rgba(255,255,255,.14);
  border:1px solid var(--stroke);transition:.25s cubic-bezier(.2,.8,.2,1)}
.switch i::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;
  background:#fff;transition:.25s cubic-bezier(.2,.8,.2,1);box-shadow:0 2px 5px rgba(0,0,0,.4)}
.switch input:checked + i{background:var(--accent);border-color:transparent}
.switch input:checked + i.red{background:var(--red)}
.switch input:checked + i.orange{background:var(--orange)}
.switch input:checked + i.green{background:var(--green)}
.switch input:checked + i::after{transform:translateX(16px)}
.switch-row,.legend-row{display:flex;align-items:center;gap:10px;font-size:12.5px;margin:11px 0;cursor:pointer;user-select:none}
.switch-row{justify-content:space-between}
.legend-row{color:#d6deeb}
.sw{width:16px;height:5px;border-radius:3px;display:inline-block}
.sw.red{background:var(--red);box-shadow:0 0 8px var(--red)}
.sw.orange{background:var(--orange);box-shadow:0 0 8px var(--orange)}
.sw.green{background:var(--green);box-shadow:0 0 8px var(--green)}

/* Butonlar */
.actions{display:flex;gap:9px;margin-top:6px}
button{font-family:inherit}
.primary{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:none;
  border-radius:13px;background:linear-gradient(135deg,#6f9bff,#5b8cff);color:#fff;font-weight:700;font-size:13.5px;
  cursor:pointer;transition:.2s;box-shadow:0 6px 18px rgba(91,140,255,.4)}
.primary:hover{transform:translateY(-1px);box-shadow:0 9px 26px rgba(91,140,255,.55)}
.primary:active{transform:translateY(0)}
.ghost{padding:12px 14px;border:1px solid var(--stroke);border-radius:13px;background:rgba(255,255,255,.05);
  color:var(--txt);font-size:13px;cursor:pointer;transition:.18s}
.ghost:hover{background:rgba(255,255,255,.1)}
.primary .spin-dot{width:13px;height:13px;border-radius:50%;border:2px solid rgba(255,255,255,.45);
  border-top-color:#fff;display:none}
.primary.loading .spin-dot{display:inline-block;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Rota bilgisi */
.route-info{font-size:12.5px;margin-top:12px;line-height:1.55;color:#cdd7e6}
.route-info:empty{display:none}
.route-info .ok{color:#7ef0a8;font-weight:600}
.route-info .err{color:#ff9bb0;font-weight:600}
.route-info b{color:#fff}
.route-info{animation:fadeIn .3s}

/* Yol listesi */
.roads-wrap{margin-top:13px;border-top:1px solid var(--stroke-soft);padding-top:13px;
  max-height:0;overflow:hidden;opacity:0;transition:.35s cubic-bezier(.2,.8,.2,1)}
.roads-wrap.open{max-height:50vh;opacity:1}
.filter{margin-bottom:9px}
.road-list{list-style:none;margin:0;padding:0;max-height:38vh;overflow:auto}
.road-list li{padding:9px 10px;border-radius:10px;font-size:12px;cursor:pointer;transition:.14s;
  display:flex;gap:9px;align-items:flex-start}
.road-list li:hover{background:rgba(91,140,255,.14)}
.road-list .dot{width:8px;height:8px;border-radius:50%;margin-top:4px;flex:none;box-shadow:0 0 7px currentColor}
.road-list .nm{font-weight:600;color:#e7edf6}
.road-list .nt{color:var(--muted);font-size:10.5px;margin-top:1px}
.count{font-size:10.5px;color:var(--muted);text-align:right;margin-top:6px}

/* FAB */
.fabs{position:fixed;z-index:6;right:16px;bottom:160px;display:flex;flex-direction:column;gap:10px}
.fab{width:46px;height:46px;border-radius:15px;display:grid;place-items:center;font-size:17px;cursor:pointer;
  color:var(--txt);border:1px solid var(--stroke);transition:.2s;font-weight:700}
.fab:hover{transform:translateY(-2px);background:rgba(91,140,255,.2)}
.fab.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* maplibre kontrol stili */
.maplibregl-ctrl-group{background:var(--glass-strong)!important;backdrop-filter:blur(18px);
  border:1px solid var(--stroke)!important;border-radius:14px!important;overflow:hidden;box-shadow:var(--shadow)!important}
.maplibregl-ctrl-group button{width:40px!important;height:40px!important}
.maplibregl-ctrl-group button+button{border-top:1px solid var(--stroke-soft)!important}
.maplibregl-ctrl button .maplibregl-ctrl-icon{filter:invert(1) hue-rotate(180deg) brightness(1.4)}
.maplibregl-ctrl-bottom-right{margin-bottom:8px}

/* Külliye işareti */
.kulliye{position:relative;width:18px;height:18px}
.kulliye .core{position:absolute;inset:0;border-radius:50%;background:#fff;
  border:3px solid var(--accent);box-shadow:0 0 14px var(--accent),0 2px 6px rgba(0,0,0,.5);z-index:2}
.kulliye .ring{position:absolute;inset:0;border-radius:50%;border:2px solid var(--accent);
  animation:pulseRing 2.4s ease-out infinite}
.kulliye .ring:nth-child(2){animation-delay:.8s}
@keyframes pulseRing{0%{transform:scale(1);opacity:.7}100%{transform:scale(4.4);opacity:0}}
.kulliye .label{position:absolute;left:24px;top:-3px;white-space:nowrap;font-size:11px;font-weight:700;
  color:#fff;background:rgba(11,15,22,.7);backdrop-filter:blur(8px);padding:3px 9px;border-radius:8px;
  border:1px solid var(--stroke)}

/* A/B işaretleri */
.ab-pin{width:30px;height:30px;border-radius:50% 50% 50% 2px;transform:rotate(45deg);
  display:grid;place-items:center;box-shadow:0 4px 12px rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.85);cursor:grab}
.ab-pin b{transform:rotate(-45deg);font-size:13px;font-weight:800;color:#0b0f16}
.ab-pin.a{background:linear-gradient(135deg,#7fa8ff,#5b8cff)}
.ab-pin.b{background:linear-gradient(135deg,#9affc0,#22e06b)}

/* Popup */
.maplibregl-popup-content{background:var(--glass-strong)!important;backdrop-filter:blur(20px);
  color:var(--txt)!important;border:1px solid var(--stroke);border-radius:14px!important;
  box-shadow:var(--shadow)!important;font-size:12.5px;padding:12px 14px!important;font-family:inherit}
.maplibregl-popup-content b{color:#fff}
.maplibregl-popup-tip{display:none}
.maplibregl-popup-close-button{color:var(--muted);font-size:17px;padding:2px 7px}
.pop-cat{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;margin-top:6px}
.pop-cat.closed{background:rgba(255,59,92,.2);color:#ff8aa0}
.pop-cat.convoy{background:rgba(255,159,28,.2);color:#ffc06b}

/* Yükleyici */
.loader{position:fixed;inset:0;z-index:50;display:flex;flex-direction:column;gap:16px;align-items:center;justify-content:center;
  background:#0b0f16;transition:opacity .6s,visibility .6s;font-size:13px;color:var(--muted)}
.loader.hidden{opacity:0;visibility:hidden}
.loader-ring{width:46px;height:46px;border-radius:50%;border:3px solid rgba(255,255,255,.12);
  border-top-color:var(--accent);animation:spin .9s linear infinite}
.loader-logo{width:84px;height:84px;border-radius:50%;background:#fff;
  box-shadow:0 0 0 1px rgba(255,255,255,.4), 0 6px 24px rgba(0,0,0,.5);
  animation:fadeIn .6s both}
.loader small{font-size:11px;letter-spacing:.4px;color:#7c8aa0;font-weight:600}

/* Admin modal */
.modal-bg{position:fixed;inset:0;z-index:40;background:rgba(5,8,13,.6);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;animation:fadeIn .25s}
.modal-bg.open{display:flex}
.modal{width:330px;padding:22px;border-radius:22px;animation:fadeUp .35s cubic-bezier(.2,.8,.2,1)}
.modal h3{margin:0 0 4px;font-size:16px}
.modal .sub{color:var(--muted);font-size:12px;margin:0 0 16px}
.modal input{margin-bottom:10px}
.modal .actions{margin-top:6px}
.adm-err{color:#ff9bb0;font-size:12px;min-height:16px;margin-bottom:4px}
.adm-ok{display:flex;align-items:center;gap:9px;font-size:13px;color:#7ef0a8;margin-bottom:14px}

/* Toast */
.toast{position:fixed;z-index:60;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);
  background:var(--glass-strong);backdrop-filter:blur(18px);border:1px solid var(--stroke);
  border-radius:13px;padding:11px 18px;font-size:13px;box-shadow:var(--shadow);opacity:0;
  transition:.35s cubic-bezier(.2,.8,.2,1);pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Admin şeridi */
.admin-bar{position:fixed;z-index:7;top:16px;left:50%;transform:translateX(-50%);display:none;
  align-items:center;gap:10px;padding:9px 16px;border-radius:14px;font-size:12.5px;color:#ffd9a8}
.admin-bar.show{display:flex;animation:fadeUp .4s}
.dot-live{width:9px;height:9px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 0 var(--orange);
  animation:pulseBtn 1.4s infinite}
.fab.admin-on{background:var(--orange);border-color:var(--orange);color:#0b0f16}

.bar-switch{display:flex;align-items:center;gap:7px;font-size:12px;cursor:pointer;color:#ffe6c4;
  padding-left:10px;margin-left:4px;border-left:1px solid var(--stroke)}
.bar-switch .switch{width:34px;height:20px;min-width:34px}
.bar-switch .switch i::after{width:14px;height:14px}
.bar-switch .switch input:checked + i::after{transform:translateX(14px)}
.bar-btn{background:rgba(255,255,255,.1);border:1px solid var(--stroke);color:#ffd9a8;
  border-radius:9px;padding:5px 10px;font-size:12px;cursor:pointer;font-weight:600;transition:.15s}
.bar-btn:hover{background:rgba(255,159,28,.25)}

/* Çizim paneli */
.draw-card{top:84px;left:16px;width:330px;display:none;z-index:8}
.draw-card.open{display:block;animation:fadeUp .35s cubic-bezier(.2,.8,.2,1)}
.seg{display:flex;gap:8px;margin:4px 0 12px}
.seg-opt{flex:1;display:flex;align-items:center;gap:7px;justify-content:center;padding:9px;border-radius:11px;
  border:1px solid var(--stroke);background:rgba(255,255,255,.04);font-size:12px;cursor:pointer;transition:.15s}
.seg-opt input{display:none}
.seg-opt:has(input:checked){background:rgba(91,140,255,.18);border-color:var(--accent)}

/* Popup admin butonları */
.pop-admin{margin-top:10px;display:flex;flex-direction:column;gap:6px}
.pop-admin button{padding:7px 10px;border-radius:9px;font-size:12px;cursor:pointer;border:1px solid var(--stroke);
  background:rgba(255,255,255,.06);color:var(--txt);transition:.15s;font-family:inherit}
.pop-admin button:hover{filter:brightness(1.2)}
.pop-admin .danger{background:rgba(255,59,92,.18);border-color:rgba(255,59,92,.4);color:#ff9bb0}
.pop-admin .go{background:rgba(34,224,107,.16);border-color:rgba(34,224,107,.4);color:#8af0b0}
.pop-disabled-tag{display:inline-block;margin-top:6px;font-size:10px;font-weight:700;padding:2px 8px;
  border-radius:20px;background:rgba(150,160,175,.25);color:#c2cbd8}

/* Çerez onay şeridi */
.cookie-banner{position:fixed;z-index:30;left:50%;bottom:18px;
  transform:translateX(-50%) translateY(160%);
  width:min(560px,calc(100vw - 24px));padding:13px 16px;border-radius:16px;
  display:flex;align-items:center;gap:14px;opacity:0;pointer-events:none;
  transition:transform .45s cubic-bezier(.2,.8,.2,1),opacity .45s}
.cookie-banner.show{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:auto}
.cb-text{font-size:12px;color:#cdd7e6;line-height:1.5}
.cb-text b{display:block;font-size:13px;color:#fff;margin-bottom:2px}
.cb-actions{display:flex;gap:8px;flex:none}
.cb-actions button{white-space:nowrap;padding:9px 15px}
@media (max-width:820px){
  .cookie-banner{left:12px;right:12px;width:auto;transform:translateY(180%);
    bottom:calc(12px + env(safe-area-inset-bottom));flex-direction:column;align-items:stretch;gap:10px}
  .cookie-banner.show{transform:translateY(0)}
  .cb-actions{justify-content:flex-end}
}

/* özel scrollbar */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.28)}

/* Mobil */
/* ====================== MOBİL ====================== */
@media (max-width:820px){
  :root{ --peek: 56px; }

  /* Marka — kompakt */
  .brand{top:calc(10px + env(safe-area-inset-top));left:10px;padding:7px 12px 7px 8px;gap:8px;max-width:62vw}
  .brand-logo{width:30px;height:30px}
  .brand-txt b{font-size:12px}
  .brand-txt i{display:none}

  /* Harita kontrolleri: zoom'u gizle (parmakla zoom), attribution'ı üste al */
  .maplibregl-ctrl-bottom-right .maplibregl-ctrl-group{display:none}
  .maplibregl-ctrl-bottom-right{top:calc(8px + env(safe-area-inset-top));bottom:auto;right:8px}

  /* FAB'lar — sağ, peek'in hemen üstünde, biraz küçük */
  .fabs{right:10px;left:auto;top:auto;flex-direction:column;
    bottom:calc(var(--peek) + 14px + env(safe-area-inset-bottom));gap:9px}
  .fab{width:44px;height:44px;border-radius:13px;font-size:16px}

  /* Bottom-sheet */
  #sheet{display:block;position:fixed;left:0;right:0;bottom:0;z-index:9;
    max-height:82vh;overflow-y:auto;-webkit-overflow-scrolling:touch;
    background:var(--glass-strong);backdrop-filter:blur(22px) saturate(165%);
    -webkit-backdrop-filter:blur(22px) saturate(165%);
    border-top:1px solid var(--stroke);border-radius:22px 22px 0 0;
    box-shadow:0 -10px 40px rgba(0,0,0,.5);
    padding-bottom:calc(16px + env(safe-area-inset-bottom));
    transition:transform .38s cubic-bezier(.2,.8,.2,1)}
  #sheet.peek{transform:translateY(calc(100% - var(--peek) - env(safe-area-inset-bottom)))}

  .sheet-handle{display:flex;flex-direction:column;align-items:center;gap:5px;
    position:sticky;top:0;z-index:2;padding:9px 0 7px;cursor:pointer;
    background:linear-gradient(180deg,rgba(16,21,30,.92),rgba(16,21,30,.5));
    backdrop-filter:blur(8px);border-radius:22px 22px 0 0}
  .sheet-handle .grip{width:42px;height:5px;border-radius:3px;background:rgba(255,255,255,.3)}
  .sheet-handle .sheet-label{font-size:11px;color:var(--muted);font-weight:600}

  /* Kartlar sheet içinde: cam yok, tam genişlik, yığılı */
  #sheet{overflow-x:hidden}
  #sheet .card{position:static;width:auto;padding:6px 16px 16px;animation:none}
  #sheet .switch-row,#sheet .legend-row{max-width:100%}
  #sheet .field{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:9px;align-items:center}
  #sheet .actions{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:9px}
  #sheet .geo,#sheet input{min-width:0;width:100%}
  #sheet .glass{background:none;backdrop-filter:none;-webkit-backdrop-filter:none;
    border:none;box-shadow:none;border-radius:0}
  #sheet .glass::before{display:none}
  .legend-card{border-top:1px solid var(--stroke-soft);padding-top:14px!important}
  .roads-wrap.open{max-height:42vh}
  .road-list{max-height:34vh}

  /* iOS odak zoom'unu engelle + dokunmatik hedefler */
  input{font-size:16px;padding:12px}
  .primary,.ghost{min-height:46px}
  .icon-btn{width:40px;height:40px;min-width:40px}
  .suggestions{max-height:38vh}

  /* Admin şeridi — markanın altında, sarmalı */
  .admin-bar{top:calc(54px + env(safe-area-inset-top));left:10px;right:10px;transform:none;
    justify-content:center;flex-wrap:wrap;gap:8px;font-size:12px}
  .bar-switch{border-left:none;padding-left:0;margin-left:0}

  /* Çizim paneli — bottom-sheet */
  .draw-card{top:auto;left:0;right:0;bottom:0;width:auto;border-radius:22px 22px 0 0;
    max-height:80vh;overflow-y:auto;padding-bottom:calc(16px + env(safe-area-inset-bottom));z-index:11}

  /* Modal — ekrana sığ */
  .modal{width:min(340px,92vw);padding:20px}

  /* Toast — sheet'in üstünde */
  .toast{bottom:calc(var(--peek) + 70px + env(safe-area-inset-bottom))}
}

/* Çok küçük ekranlar */
@media (max-width:380px){
  .brand-txt b{font-size:11px}
  .fab{width:42px;height:42px}
  .seg-opt{padding:8px;font-size:11px}
}

/* Yatay (landscape) telefon: sheet'i biraz kısalt */
@media (max-width:900px) and (orientation:landscape){
  #sheet{max-height:90vh}
}
