/* css/app.css — İDx Weather (music/t style) v3 */
:root{
  --bg:#08121f; --panel:rgba(9,18,34,0.92); --surface:rgba(255,255,255,0.05);
  --surface2:rgba(255,255,255,0.08); --border:rgba(79,195,247,0.25);
  --text:#e6edf3; --muted:#8ba7be; --accent:#4fc3f7;
  --gold:#ffd166;
  --ok:#22c55e; --err:#ef4444; --warn:#f59e0b;
}
*{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden;margin:0;padding:0}
body{
  font-family:"Segoe UI",Tahoma,Geneva,Verdana,sans-serif;color:var(--text);
  background:radial-gradient(circle at top right,#1b3e6d 0%,#08121f 60%);
  min-height:100vh;line-height:1.45;
}
.hidden{display:none !important}
.muted{color:var(--muted);font-size:.9em}
.error{color:var(--err);min-height:1.2em;font-size:.9em}

/* ── GOLD İ (global) ───────────────────────────────────────────── */
.logo-i,.footer-i{
  color:var(--gold) !important;
  font-style:italic;font-weight:900;font-size:1.12em;
  letter-spacing:-0.05em;text-shadow:0 1px 0 rgba(0,0,0,.35);
  display:inline-block;
}

/* ── BRAND BAR ─────────────────────────────────────────────────── */
.site-brand-bar{
  position:fixed;top:0;left:0;right:0;height:58px;
  background:rgba(9,18,34,0.92);backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(79,195,247,0.10);
  z-index:500;display:flex;align-items:center;padding:0 14px;
}
.site-brand-bar a{display:flex;align-items:center;gap:10px;text-decoration:none;
  padding:5px 10px;border-radius:10px;transition:background .2s}
.site-brand-bar a:hover{background:rgba(79,195,247,0.09)}
.site-brand-bar img{width:42px;height:42px;border-radius:8px;display:block;flex-shrink:0}
.site-brand-bar .logo-text{font-size:.95rem;font-weight:700;color:#c8d8e8;white-space:nowrap;line-height:1}
body.has-brand-bar{padding-top:58px}

/* ── PAGE / HEADER ─────────────────────────────────────────────── */
.page{width:min(1220px,100%);margin:0 auto;padding:16px;display:flex;flex-direction:column;gap:14px}
.header{
  background:var(--surface);border:1px solid rgba(255,255,255,0.10);
  border-radius:15px;padding:20px 24px 16px;backdrop-filter:blur(10px);
}
.header h1{
  text-align:center;color:var(--accent);font-size:1.5rem;font-weight:700;
  margin:0 0 6px;display:flex;align-items:center;justify-content:center;gap:4px;
}
.header p{text-align:center;color:#7a8fa8;font-size:.86rem;margin:0 0 14px}

/* ── NAV ───────────────────────────────────────────────────────── */
.site-nav{display:flex;flex-direction:column;align-items:center;margin-top:8px}
.nav-menu{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;align-items:center}
.nav-link{
  display:inline-flex;align-items:center;gap:8px;padding:8px 14px;
  background:rgba(79,195,247,0.12);color:#90d8f9;text-decoration:none;
  border:1px solid rgba(79,195,247,0.25);border-radius:8px;
  font-size:13px;font-weight:600;white-space:nowrap;cursor:pointer;
  user-select:none;transition:all .18s;
}
.nav-link:hover{background:rgba(79,195,247,0.24);border-color:rgba(79,195,247,0.45);
  color:#e0f7fe;transform:translateY(-1px)}
.nav-link.active{background:rgba(2,136,209,0.32);border-color:#0288d1;color:#fff}
.nav-link.nav-logout{background:rgba(244,67,54,0.10);border-color:rgba(244,67,54,0.28);color:#ff8a80}
.nav-link.nav-logout:hover{background:rgba(244,67,54,0.22);border-color:rgba(244,67,54,0.55);color:#ffcdd2}

/* ── PANELS / CARDS / TAB ─────────────────────────────────────── */
main{padding:0;width:100%}
.tab-panel{display:none;width:100%}
.tab-panel.active{display:flex;flex-direction:column;gap:14px;width:100%}
.panel,.card{
  background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:14px;
  width:100%;min-width:0;
}
.panel h3{margin:0 0 .6rem 0;font-size:.95rem;color:var(--muted);
  text-transform:uppercase;letter-spacing:.04em;font-weight:700}

/* ── PILLS ─────────────────────────────────────────────────────── */
.pills{display:flex;gap:.4rem;overflow-x:auto;padding:.2rem 0;
  scrollbar-width:thin;scrollbar-color:rgba(79,195,247,.3) transparent}
.pills::-webkit-scrollbar{height:6px}
.pills::-webkit-scrollbar-thumb{background:rgba(79,195,247,.3);border-radius:3px}
.pill{padding:.5rem .9rem;border-radius:999px;background:rgba(79,195,247,0.10);
  border:1px solid var(--border);cursor:pointer;white-space:nowrap;font-size:.88rem;
  color:#bfe7ff;transition:all .15s;flex-shrink:0}
.pill:hover{background:rgba(79,195,247,0.20)}
.pill.active{background:rgba(2,136,209,0.40);border-color:#0288d1;color:#fff;font-weight:700}

.alert-banner{background:rgba(245,158,11,.12);border:1px solid var(--warn);
  border-radius:10px;padding:.6rem .8rem;color:#fbbf24}

/* ── CURRENT WIDGET ────────────────────────────────────────────── */
.current-head{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.current-ico{font-size:3.4rem;line-height:1}
.current-temp .big{font-size:2.6rem;font-weight:800;color:#fff;line-height:1}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.7rem;margin-top:.8rem;width:100%}
.stat{background:rgba(2,8,18,.55);border:1px solid rgba(148,163,184,.18);
  padding:.6rem;border-radius:10px;text-align:center;min-width:0}
.stat .l{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}
.stat .v{font-size:1.05rem;font-weight:700;margin-top:.25rem;color:var(--text)}

/* ── HOURLY/DAILY ──────────────────────────────────────────────── */
.row-list{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.3rem;
  scrollbar-width:thin;scrollbar-color:rgba(79,195,247,.3) transparent}
.row-list::-webkit-scrollbar{height:6px}
.row-list::-webkit-scrollbar-thumb{background:rgba(79,195,247,.3);border-radius:3px}
.row-list .item{background:rgba(2,8,18,.55);border:1px solid rgba(148,163,184,.18);
  padding:.6rem;border-radius:10px;text-align:center;min-width:80px;font-size:.85rem;flex-shrink:0}
.row-list .item .h{color:var(--muted);font-size:.72rem}
.row-list .item .t{font-weight:700;font-size:1rem;margin:.25rem 0;color:#fff}
.row-list .item .p{color:var(--accent);font-size:.72rem}

.daily-row{display:flex;justify-content:space-between;align-items:center;
  padding:.55rem 0;border-bottom:1px solid rgba(148,163,184,.12);gap:.5rem}
.daily-row:last-child{border-bottom:none}
.daily-row .d{flex:0 0 90px;font-size:.88rem}
.daily-row .ico{font-size:1.4rem;flex:0 0 40px;text-align:center}
.daily-row .t{flex:0 0 auto;font-weight:700;color:#fff}
.daily-row .t .min{color:var(--muted);margin-right:.4rem;font-weight:500}

/* ── MAP ───────────────────────────────────────────────────────── */
.map-wrap{position:relative;width:100%}
.map{height:calc(100vh - 260px);min-height:460px;border-radius:14px;overflow:hidden;
  border:1px solid var(--border)}
.modal-map{height:240px;border-radius:8px;margin:.5rem 0;border:1px solid var(--border)}
.leaflet-container{background:#0a1828;font-family:inherit}
.leaflet-control-attribution{background:rgba(9,18,34,.85) !important;color:#8ba7be !important}
.leaflet-control-attribution a{color:var(--accent) !important}
.leaflet-control-zoom a{background:rgba(9,18,34,.92) !important;color:#bfe7ff !important;
  border:1px solid var(--border) !important}
.leaflet-control-zoom a:hover{background:rgba(79,195,247,.22) !important}
.leaflet-control-layers{background:rgba(9,18,34,.95) !important;color:var(--text) !important;
  border:1px solid var(--border) !important;border-radius:10px !important;padding:6px !important}
.leaflet-control-layers label{color:var(--text)}
.leaflet-control-scale-line{background:rgba(9,18,34,.85) !important;color:#bfe7ff !important;
  border-color:var(--border) !important}
.leaflet-popup-content-wrapper{background:#0d1b2a;color:var(--text);border:1px solid var(--border)}
.leaflet-popup-tip{background:#0d1b2a}

/* ── RADAR TIMELINE ────────────────────────────────────────────── */
.radar-bar{
  margin-top:.7rem;background:var(--panel);border:1px solid var(--border);border-radius:12px;
  padding:.8rem 1rem;display:flex;flex-direction:column;gap:.5rem;
}
.radar-bar .head{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.radar-bar .play{
  width:38px;height:38px;border-radius:50%;background:rgba(79,195,247,.22);
  border:1px solid var(--border);color:#fff;font-size:1rem;cursor:pointer;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
}
.radar-bar .play:hover{background:rgba(79,195,247,.36)}
.radar-bar .ts{font-size:.95rem;font-weight:700;color:#fff;min-width:140px}
.radar-bar .lbl{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.radar-bar input[type=range]{flex:1;min-width:0;accent-color:var(--accent);height:6px}
.radar-bar .legend{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted)}
.radar-bar .opacity{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--muted)}
.radar-bar .opacity input{width:90px}
.radar-bar .badge-future{background:rgba(245,158,11,.22);color:var(--warn);
  padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:700}

/* ── MODELS ────────────────────────────────────────────────────── */
.model-toolbar{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}
.model-checks{display:flex;flex-wrap:wrap;gap:.6rem}
.chart-panel{position:relative;height:280px;padding:.6rem .8rem}
.chart-panel canvas{width:100% !important;height:100% !important;display:block}
.model-checks label{display:flex;align-items:center;gap:.3rem;font-size:.88rem;color:#bfe7ff;
  text-transform:none;letter-spacing:0;margin:0}

/* ── LOCATIONS ─────────────────────────────────────────────────── */
.loc-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.7rem;margin-top:.7rem}
.loc-card{background:rgba(2,8,18,.55);border:1px solid rgba(148,163,184,.2);
  border-radius:12px;padding:.9rem}
.loc-card h4{margin:0 0 .3rem 0;color:#fff}
.loc-card .meta{color:var(--muted);font-size:.8rem;margin-bottom:.5rem}
.loc-card .acts{display:flex;gap:.4rem;flex-wrap:wrap}
.loc-card .acts button{flex:1;padding:.4rem;border-radius:6px;border:1px solid rgba(79,195,247,.25);
  background:rgba(79,195,247,.10);color:#bfe7ff;cursor:pointer;font-size:.82rem}
.loc-card .acts button:hover{background:rgba(79,195,247,.22)}
.loc-card .badge{display:inline-block;background:var(--accent);color:#0a1828;
  font-size:.68rem;padding:.1rem .45rem;border-radius:4px;margin-left:.3rem;font-weight:700}

/* ── FORMS ─────────────────────────────────────────────────────── */
form label{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.6rem;
  font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
input,select,textarea{
  font:inherit;padding:.6rem;border-radius:8px;border:1px solid rgba(148,163,184,.35);
  background:rgba(2,8,18,.84);color:var(--text);font-size:.95rem;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(79,195,247,.18)}
button{
  font:inherit;padding:.6rem 1rem;border-radius:8px;border:1px solid rgba(148,163,184,.35);
  background:rgba(2,8,18,.84);color:var(--text);cursor:pointer;font-weight:600;
  transition:all .15s;
}
button:hover{background:rgba(79,195,247,.15);border-color:var(--border)}
.btn-primary,.primary{background:rgba(79,195,247,.24);border-color:var(--border);
  color:#e0f7fe;font-weight:700}
.btn-primary:hover,.primary:hover{background:rgba(79,195,247,.36);color:#fff}
.row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:end}
.row > *{flex:1;min-width:120px}

/* Modern checkbox */
.check{flex-direction:row !important;align-items:center !important;gap:.55rem;
  text-transform:none !important;letter-spacing:0 !important;color:var(--text) !important;
  cursor:pointer;user-select:none;font-size:.9rem !important}
.check input[type=checkbox]{
  appearance:none;-webkit-appearance:none;
  width:20px;height:20px;border-radius:5px;
  border:1.5px solid rgba(148,163,184,.55);background:rgba(2,8,18,.84);
  cursor:pointer;flex:0 0 auto;position:relative;transition:all .15s;margin:0;padding:0;
}
.check input[type=checkbox]:hover{border-color:var(--accent)}
.check input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}
.check input[type=checkbox]:checked::after{
  content:'';position:absolute;left:5px;top:1px;width:6px;height:11px;
  border:solid #08121f;border-width:0 2.5px 2.5px 0;transform:rotate(45deg);
}
.check input[type=checkbox]:focus-visible{box-shadow:0 0 0 3px rgba(79,195,247,.3)}

/* ── ALERTS RULES ─────────────────────────────────────────────── */
.rule-row{display:flex;align-items:center;gap:.7rem;padding:.55rem 0;
  border-bottom:1px solid rgba(148,163,184,.12)}
.rule-row:last-child{border-bottom:none}
.rule-row .lbl{flex:1;color:var(--text);font-size:.92rem}
.rule-row input[type=number],.rule-row input[type=time]{width:110px;flex:0 0 auto}

/* ── MODAL ─────────────────────────────────────────────────────── */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:10000;
  display:flex;align-items:center;justify-content:center;padding:1rem;overflow-y:auto}
.modal-card{background:#0d1b2a;border:1px solid var(--border);border-radius:14px;
  padding:1.4rem;max-width:560px;width:100%;max-height:90vh;overflow-y:auto;
  box-shadow:0 16px 40px rgba(0,0,0,.65)}
.modal-card h3{margin:0 0 .8rem;color:var(--accent)}

/* ── USERS LIST ───────────────────────────────────────────────── */
#users-list .urow{display:flex;justify-content:space-between;align-items:center;
  padding:.5rem 0;border-bottom:1px solid rgba(148,163,184,.12)}
#users-list .urow:last-child{border-bottom:none}
#users-list .urow button{background:rgba(244,67,54,.18);border:1px solid rgba(244,67,54,.4);
  color:#ff8a80;padding:.25rem .6rem;border-radius:5px;cursor:pointer;font-size:.78rem;font-weight:600}
#users-list .urow button:hover{background:rgba(244,67,54,.32)}

/* ── LOGIN ─────────────────────────────────────────────────────── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}
.login-card{background:var(--panel);padding:2rem;border-radius:16px;
  width:100%;max-width:360px;display:flex;flex-direction:column;gap:.8rem;
  border:1px solid var(--border);box-shadow:0 16px 40px rgba(0,0,0,.55)}
.login-card h1{margin:0;text-align:center;color:var(--accent);font-size:1.4rem;
  display:flex;justify-content:center;align-items:center;gap:4px}
.login-card .login-logo{height:84px;width:84px;object-fit:contain;margin:0 auto;display:block}
.login-card input{width:100%}
.login-card button{background:rgba(79,195,247,.24);border-color:var(--border);
  color:#e0f7fe;font-weight:700}
.login-card button:hover{background:rgba(79,195,247,.36);color:#fff}

/* ── FOOTER ────────────────────────────────────────────────────── */
.site-footer{
  text-align:center;padding:18px;margin-top:24px;
  border-top:1px solid rgba(255,255,255,.18);background:#2e4358;
  color:#f5f7fa;font-size:14px;font-weight:600;letter-spacing:.2px;border-radius:14px;
}
.site-footer p{margin:0}
.site-footer a{color:#bfe7ff;text-decoration:none}
.site-footer a:hover{color:#fff;text-decoration:underline}

/* ── TOAST ─────────────────────────────────────────────────────── */
.toast-stack{
  position:fixed;top:74px;right:16px;z-index:11000;
  display:flex;flex-direction:column;gap:.5rem;pointer-events:none;
  max-width:calc(100vw - 32px);
}
.toast{
  pointer-events:auto;display:flex;align-items:center;gap:.7rem;
  background:rgba(13,27,42,.96);backdrop-filter:blur(14px);
  border:1px solid var(--border);border-radius:10px;padding:.7rem .9rem;
  min-width:240px;max-width:380px;box-shadow:0 10px 30px rgba(0,0,0,.5);
  color:var(--text);font-size:.92rem;
  opacity:0;transform:translateX(20px);transition:all .22s ease;
}
.toast.in{opacity:1;transform:translateX(0)}
.toast.out{opacity:0;transform:translateX(20px)}
.toast-ico{
  flex-shrink:0;width:26px;height:26px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:900;font-size:.92rem;
}
.toast-success{border-color:rgba(34,197,94,.5)}
.toast-success .toast-ico{background:rgba(34,197,94,.22);color:#86efac}
.toast-error{border-color:rgba(239,68,68,.5)}
.toast-error .toast-ico{background:rgba(239,68,68,.22);color:#fca5a5}
.toast-warn{border-color:rgba(245,158,11,.5)}
.toast-warn .toast-ico{background:rgba(245,158,11,.22);color:#fcd34d}
.toast-info .toast-ico{background:rgba(79,195,247,.22);color:#90d8f9}
.toast-msg{flex:1;min-width:0;line-height:1.35}
.toast-x{
  flex-shrink:0;background:none;border:none;color:var(--muted);
  font-size:1.3rem;line-height:1;padding:0 .2rem;cursor:pointer;font-weight:700;
}
.toast-x:hover{color:var(--text);background:none}

/* ── UI MODAL (confirm/alert) ─────────────────────────────────── */
.ui-modal{
  position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);
  z-index:11500;display:flex;align-items:center;justify-content:center;padding:1rem;
  opacity:0;transition:opacity .18s ease;
}
.ui-modal.in{opacity:1}
.ui-modal.out{opacity:0}
.ui-modal-card{
  background:#0d1b2a;border:1px solid var(--border);border-radius:14px;
  padding:1.4rem 1.6rem;max-width:440px;width:100%;
  box-shadow:0 24px 60px rgba(0,0,0,.7);
  transform:scale(.96);transition:transform .18s ease;
}
.ui-modal.in .ui-modal-card{transform:scale(1)}
.ui-modal-title{margin:0 0 .5rem;color:var(--accent);font-size:1.1rem;font-weight:700}
.ui-modal-msg{margin:0 0 1.2rem;color:var(--text);line-height:1.5;font-size:.95rem;white-space:pre-wrap}
.ui-modal-acts{display:flex;gap:.5rem;justify-content:flex-end;flex-wrap:wrap}
.ui-btn{
  padding:.55rem 1.1rem;border-radius:8px;border:1px solid var(--border);
  background:rgba(2,8,18,.84);color:var(--text);font-weight:600;cursor:pointer;
  font-size:.92rem;transition:all .15s;
}
.ui-btn:hover{background:rgba(79,195,247,.15)}
.ui-btn-ghost{background:transparent;border-color:rgba(148,163,184,.3);color:var(--muted)}
.ui-btn-ghost:hover{background:rgba(148,163,184,.12);color:var(--text)}
.ui-btn-primary{background:rgba(79,195,247,.28);color:#fff;border-color:var(--accent)}
.ui-btn-primary:hover{background:rgba(79,195,247,.45)}
.ui-btn-danger{background:rgba(239,68,68,.22);border-color:rgba(239,68,68,.55);color:#fca5a5}
.ui-btn-danger:hover{background:rgba(239,68,68,.4);color:#fff}
.ui-btn[data-act="cancel"]:empty{display:none}

/* ── RESPONSIVE ────────────────────────────────────────────────── */
@media (max-width:720px){
  .site-brand-bar img{width:36px;height:36px}
  .site-brand-bar .logo-text{font-size:.85rem}
  .header{padding:14px 14px 10px}
  .header h1{font-size:1.2rem}
  .nav-menu{gap:4px}
  .nav-link{padding:7px 11px;font-size:12px}
  .current-temp .big{font-size:2.1rem}
  .map{height:calc(100vh - 320px);min-height:380px}
  .toast-stack{top:68px;right:8px;left:8px;max-width:none}
  .toast{min-width:0}
}

/* ──────────────────────────────────────────────────────────────────
   Phase 3: Windy-benzeri model karşılaştırma + uyarı geçmişi (v4)
   ────────────────────────────────────────────────────────────────── */

/* ── Yer ayar modali: çoklu model tercihi ─────────────────────── */
.pref-models{
  display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.35rem;
}
.pref-models label{
  display:inline-flex;align-items:center;gap:.35rem;
  background:rgba(255,255,255,.05);border:1px solid var(--border);
  padding:.3rem .55rem;border-radius:8px;font-size:.85rem;cursor:pointer;
}
.pref-models label:hover{background:rgba(79,195,247,.10)}
.pref-models input{margin:0}

/* ── Uyarı kuralları modal başlıkları ─────────────────────────── */
h4.rule-section{
  margin:1.1rem 0 .35rem;padding-top:.55rem;
  border-top:1px solid rgba(148,163,184,.18);
  color:var(--accent);font-size:.78rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
}
.rule-row{
  display:flex;align-items:center;gap:.5rem;margin:.25rem 0;
  padding:.25rem .4rem;border-radius:6px;
}
.rule-row:hover{background:rgba(255,255,255,.03)}
.rule-row .lbl{flex:1;font-size:.88rem}
.rule-row input[type=number]{width:80px;padding:.3rem .4rem}
.rule-row input[type=time]{width:110px;padding:.3rem .4rem}

/* ── Ayarlar: Pushover/Telegram yardım linkleri ──────────────── */
.help-links{
  display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem;
}
.help-links a{
  font-size:.78rem;color:var(--accent);text-decoration:none;
  background:rgba(79,195,247,.08);padding:.25rem .55rem;border-radius:6px;
  border:1px solid rgba(79,195,247,.18);
}
.help-links a:hover{background:rgba(79,195,247,.16)}

/* ──────────────────────────────────────────────────────────────────
   WINDY-LIKE COMPARISON  (#tab-windy)
   ────────────────────────────────────────────────────────────────── */
.windy-toolbar{
  display:flex;flex-wrap:wrap;align-items:center;gap:.7rem;
  background:var(--surface);border:1px solid rgba(255,255,255,.08);
  border-radius:12px;padding:.7rem .9rem;margin-bottom:.7rem;
}
.windy-toolbar select,
.windy-toolbar button{
  padding:.45rem .8rem;border-radius:8px;border:1px solid var(--border);
  background:rgba(255,255,255,.04);color:var(--text);font-size:.9rem;
}
.windy-toolbar button{
  background:var(--accent);color:#03263c;border:none;font-weight:700;cursor:pointer;
}
.windy-toolbar button:hover{filter:brightness(1.1)}
#windy-models{
  display:flex;flex-wrap:wrap;gap:.4rem;flex:1;min-width:0;
}
#windy-models label{
  display:inline-flex;align-items:center;gap:.3rem;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  padding:.25rem .55rem;border-radius:6px;font-size:.8rem;cursor:pointer;
  white-space:nowrap;
}
#windy-models input{margin:0}

.windy-info{
  background:linear-gradient(135deg,rgba(79,195,247,.10),rgba(255,209,102,.05));
  border:1px solid rgba(79,195,247,.20);
  border-radius:12px;padding:.8rem 1rem;margin-bottom:.7rem;
}
.windy-info-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:.8rem;
}
.windy-info-l{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.windy-info-v{font-size:1rem;font-weight:600;margin-top:.2rem}

.windy-table-wrap{
  background:var(--surface);border:1px solid rgba(255,255,255,.08);
  border-radius:12px;overflow:hidden;
}
.windy-table{
  overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
}
.windy-table::-webkit-scrollbar{height:10px}
.windy-table::-webkit-scrollbar-thumb{background:rgba(79,195,247,.4);border-radius:6px}

.windy-row{
  display:flex;border-bottom:1px solid rgba(255,255,255,.05);
  min-width:max-content;
}
.windy-row.windy-header{
  background:rgba(255,255,255,.04);
  position:sticky;top:0;z-index:5;
}
.windy-row.windy-err{opacity:.65}

.windy-rowhead{
  flex:0 0 140px;position:sticky;left:0;z-index:4;
  background:rgba(9,18,34,0.96);backdrop-filter:blur(8px);
  padding:.45rem .55rem;border-left:4px solid var(--accent);
  border-right:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;justify-content:center;gap:.15rem;
}
.windy-rowhead .rh-name{font-weight:700;font-size:.88rem}
.windy-rowhead .rh-sub{font-size:.66rem;color:var(--muted);line-height:1.2}
.windy-rowhead .rh-rows{
  display:flex;flex-direction:column;font-size:.62rem;color:var(--muted);
  margin-top:.25rem;line-height:1.7;
}

.windy-cells{flex:1;display:flex;flex-direction:column}
.windy-line{display:flex;height:42px}
.windy-line.windy-days{height:24px;background:rgba(255,255,255,.03);border-bottom:1px solid rgba(255,255,255,.06)}

.windy-cell{
  flex:0 0 38px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:.7rem;line-height:1.1;border-right:1px solid rgba(255,255,255,.04);
  text-align:center;padding:.1rem 0;position:relative;
}
.windy-cell.windy-h{font-weight:600;color:var(--muted);font-size:.7rem;height:24px}
.windy-cell.h-major{color:var(--text)}
.windy-cell.h-day{color:var(--accent);font-weight:700;border-left:1px solid rgba(79,195,247,.3)}

.windy-day{
  display:flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:700;color:var(--accent);
  border-right:1px solid rgba(79,195,247,.18);
  text-transform:capitalize;
}

.windy-cell.windy-wx .wx-ico{font-size:1.1rem;line-height:1}
.windy-cell.windy-wx .wx-t{font-weight:700;font-size:.74rem;margin-top:.05rem}
.windy-cell.windy-p{font-weight:600;color:#bfe5ff;font-size:.7rem}
.windy-cell.windy-w{gap:.05rem}
.windy-cell.windy-w .w-v{font-weight:600;font-size:.68rem}
.windy-cell.windy-w .w-g{color:#fca5a5;font-size:.62rem;margin-left:1px}
.wind-arrow{
  display:inline-block;font-size:.85rem;line-height:1;
  color:#0f1c2e;font-weight:900;
  transform-origin:center;
}

@media(max-width:640px){
  .windy-rowhead{flex-basis:96px}
  .windy-rowhead .rh-sub{display:none}
  .windy-cell{flex-basis:32px;font-size:.65rem}
  .windy-cell.windy-wx .wx-ico{font-size:.95rem}
}

/* ──────────────────────────────────────────────────────────────────
   ALERTS LOG  (#tab-alerts-log)
   ────────────────────────────────────────────────────────────────── */
.alerts-log-toolbar{
  display:flex;gap:.5rem;justify-content:flex-end;margin-bottom:.7rem;
}
.alerts-log-toolbar button{
  padding:.45rem .8rem;border-radius:8px;border:1px solid var(--border);
  background:rgba(79,195,247,.08);color:var(--accent);font-weight:600;cursor:pointer;
}
.alerts-log-toolbar button:hover{background:rgba(79,195,247,.18)}

.alert-feed{display:flex;flex-direction:column;gap:.5rem}
.alert-item{
  display:flex;gap:.7rem;padding:.7rem .85rem;
  background:var(--surface);border:1px solid rgba(255,255,255,.08);
  border-left:4px solid var(--accent);border-radius:10px;
}
.alert-item.alert-err{border-left-color:var(--err);background:rgba(239,68,68,.06)}
.alert-ico{font-size:1.6rem;line-height:1;flex:0 0 auto}
.alert-body{flex:1;min-width:0}
.alert-head{
  display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.2rem;
}
.alert-head b{font-size:.95rem}
.alert-loc{font-size:.78rem;color:var(--muted)}
.alert-msg{font-size:.88rem;color:var(--text);margin:.1rem 0 .25rem;word-break:break-word}
.alert-ts{font-size:.7rem;color:var(--muted)}

.ch-badge{
  display:inline-block;padding:.1rem .45rem;border-radius:5px;
  font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
}
.ch-badge.ch-pushover{background:rgba(34,197,94,.18);color:#86efac}
.ch-badge.ch-telegram{background:rgba(59,130,246,.20);color:#93c5fd}
.ch-badge.ch-pwa{background:rgba(148,163,184,.18);color:#cbd5e1}

.st-badge{
  display:inline-block;padding:.1rem .45rem;border-radius:5px;
  font-size:.66rem;font-weight:700;
}
.st-badge.st-ok{background:rgba(34,197,94,.18);color:#86efac}
.st-badge.st-err{background:rgba(239,68,68,.20);color:#fca5a5}
.st-badge.st-warn{background:rgba(245,158,11,.18);color:#fcd34d}

/* Yer kartı badge */
.loc-card .badge{
  background:var(--gold);color:#3a2f00;font-size:.65rem;
  padding:.1rem .4rem;border-radius:4px;margin-left:.4rem;font-weight:700;
}

/* ──────────────── v5: kaynak çubuğu, info chip, info modal ──────────────── */
.source-bar{
  display:flex;align-items:center;gap:.55rem;padding:.45rem .75rem;
  border-left:4px solid var(--mc, #888);
  background:linear-gradient(90deg, color-mix(in srgb, var(--mc,#888) 14%, transparent), transparent);
  border-radius:6px;margin-bottom:.6rem;font-size:.86rem;flex-wrap:wrap;
}
.source-bar .src-dot{width:10px;height:10px;border-radius:50%;background:var(--mc,#888);box-shadow:0 0 6px var(--mc,#888)}
.source-bar .src-l{color:var(--muted,#9ca3af);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}
.source-bar .src-name{
  background:none;border:0;padding:0;color:var(--mc,#888);font-weight:700;cursor:pointer;
  text-decoration:underline dotted;font-size:.92rem;
}
.source-bar .src-name:hover{filter:brightness(1.2)}
.source-bar .src-meta{margin-left:auto;font-size:.78rem;color:var(--muted,#9ca3af)}

.info-chip,.info-chip-sm{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;
  background:rgba(99,102,241,.14);color:#a5b4fc;border:1px solid rgba(99,102,241,.32);
  font-size:.7rem;font-weight:700;cursor:pointer;padding:0;line-height:1;
  margin-left:.25rem;vertical-align:middle;font-family:serif;
}
.info-chip:hover{background:rgba(99,102,241,.28);color:#fff}
.info-chip-sm{width:14px;height:14px;font-size:.6rem;margin-left:.2rem}
.info-chip-host{display:inline}

.ui-info-modal .ui-modal-card.ui-info-card{max-width:560px;width:92vw}
.ui-info-body{line-height:1.55;font-size:.92rem;color:#cbd5e1}
.ui-info-body p{margin:.4rem 0}
.ui-info-body b{color:#e2e8f0}
.info-grid{display:grid;grid-template-columns:auto 1fr;gap:.35rem .8rem;margin:.5rem 0;font-size:.86rem}
.info-grid .k{color:#94a3b8}
.info-grid .v{color:#e2e8f0}
.info-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin:.4rem 0}
.info-tag{
  background:rgba(34,197,94,.12);color:#86efac;border:1px solid rgba(34,197,94,.28);
  border-radius:999px;padding:.12rem .55rem;font-size:.75rem;
}
.info-note{color:#fcd34d;border-left:3px solid #f59e0b;padding:.4rem .6rem;background:rgba(245,158,11,.06);border-radius:4px;margin-top:.5rem}
.info-link{color:#93c5fd;cursor:pointer;text-decoration:underline dotted;font-size:.78rem}
.info-link:hover{color:#dbeafe}

/* ──────────────── yağış rozetleri & tipler ──────────────── */
.precip-badge{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-weight:600;font-size:.85rem}
.precip-badge.bg-rain{background:rgba(59,130,246,.22);color:#bfdbfe}
.precip-badge.bg-snow{background:rgba(186,230,253,.32);color:#e0f2fe}
.precip-badge.bg-freezing{background:rgba(56,189,248,.30);color:#bae6fd;border:1px dashed #38bdf8}
.precip-badge.bg-hail{background:rgba(250,204,21,.30);color:#fde68a;border:1px solid #f59e0b}
.precip-badge.bg-storm{background:rgba(168,85,247,.22);color:#e9d5ff}
.precip-badge.bg-none{background:rgba(148,163,184,.12);color:#94a3b8}

.row-list .item.type-rain{border-left:3px solid #60a5fa}
.row-list .item.type-snow{border-left:3px solid #bae6fd}
.row-list .item.type-freezing{border-left:3px solid #38bdf8}
.row-list .item.type-hail{border-left:3px solid #f59e0b}
.row-list .item.type-storm{border-left:3px solid #a855f7}
.row-list .item.type-fog{border-left:3px solid #94a3b8}

.hp{font-size:.78rem;font-weight:600}
.hp small{font-size:.62rem;opacity:.7;margin-left:1px}
.hp-rain{color:#60a5fa}
.hp-snow{color:#bae6fd}
.hp-hail{color:#fcd34d}
.hp-prob{color:#a78bfa}
.hp-none{color:#475569;font-weight:400}

.daily-row.daily-type-snow{border-left:3px solid #bae6fd}
.daily-row.daily-type-hail{border-left:3px solid #f59e0b}
.daily-row.daily-type-storm{border-left:3px solid #a855f7}
.daily-row.daily-type-freezing{border-left:3px solid #38bdf8}

.hourly-legend,.windy-legend{
  display:flex;flex-wrap:wrap;gap:.4rem;margin:.4rem 0 .55rem;font-size:.74rem;align-items:center
}
.lg{padding:.12rem .5rem;border-radius:999px;background:rgba(148,163,184,.10);color:#cbd5e1}
.lg-rain{background:rgba(59,130,246,.20);color:#bfdbfe}
.lg-snow{background:rgba(186,230,253,.30);color:#e0f2fe}
.lg-hail{background:rgba(250,204,21,.25);color:#fde68a}
.lg-storm{background:rgba(168,85,247,.20);color:#e9d5ff}
.lg-sep{color:#475569;margin:0 .2rem}

/* windy cell tipleri */
.windy-cell.windy-p.p-snow{outline:1px solid rgba(186,230,253,.6) inset}
.windy-cell.windy-p.p-hail{outline:1px solid #f59e0b inset;font-weight:700}
.windy-cell.windy-p.p-prob{font-style:italic;opacity:.85}
.windy-cell.windy-wx.type-snow .wx-ico,
.windy-cell.windy-wx.type-hail .wx-ico,
.windy-cell.windy-wx.type-freezing .wx-ico{filter:drop-shadow(0 0 2px rgba(56,189,248,.6))}

/* ──────────────── tercihler formu ──────────────── */
.prefs-form{display:flex;flex-direction:column;gap:.7rem}
.prefs-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.86rem}
.prefs-form select,.prefs-form input[type=number]{
  background:#0b1220;color:#e2e8f0;border:1px solid #334155;border-radius:6px;padding:.45rem .55rem;font:inherit
}
.prefs-form .prefs-row{display:grid;grid-template-columns:1fr 140px;gap:.6rem}
.prefs-form small.muted{color:#94a3b8;font-size:.75rem}

.ch-pick{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.7rem}
.ch-pick-row{display:flex;align-items:center;gap:.5rem}

/* ──────────────── v6: mobil drawer menü + detay çubuğu ──────────────── */
.nav-toggle{display:none}
.nav-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9000;
  opacity:0;pointer-events:none;transition:opacity .25s;
}
.nav-backdrop.active{opacity:1;pointer-events:auto}
.nav-close-btn{display:none}

@media (max-width:768px), (pointer:coarse){
  .nav-toggle{
    display:flex !important;align-items:center;justify-content:center;gap:8px;
    width:100%;padding:10px 18px;background:rgba(79,195,247,.12);color:#4fc3f7;
    border:1px solid rgba(79,195,247,.32);border-radius:8px;cursor:pointer;
    font-weight:600;font-size:14px;letter-spacing:.4px;
  }
  .nav-toggle:hover{background:rgba(79,195,247,.24);color:#81d4fa}
  .nav-menu{
    position:fixed;top:0;right:0;height:100dvh;height:100vh;
    width:min(290px,85vw);background:#060f1a;
    border-left:1px solid rgba(79,195,247,.18);
    z-index:10001;display:flex;flex-direction:column;align-items:stretch;
    padding:0;gap:0;overflow-y:auto;
    box-shadow:-12px 0 40px rgba(0,0,0,.65);
    transform:translate3d(100%,0,0);visibility:hidden;
    transition:transform .28s cubic-bezier(.4,0,.2,1),visibility 0s linear .28s;
  }
  .nav-menu.open{
    transform:translate3d(0,0,0);visibility:visible;
    transition:transform .28s cubic-bezier(.4,0,.2,1),visibility 0s linear 0s;
  }
  .nav-close-btn{
    display:flex !important;align-items:center;gap:8px;width:100%;
    padding:14px 18px;border:none;border-bottom:1px solid rgba(79,195,247,.15);
    background:rgba(79,195,247,.06);color:#4fc3f7;cursor:pointer;
    font-size:13px;font-weight:700;letter-spacing:.5px;text-align:left;
  }
  .nav-close-btn:hover{background:rgba(79,195,247,.14)}
  .nav-menu .nav-link{
    width:100%;justify-content:flex-start;padding:12px 16px;font-size:14px;
    border-radius:0;border:none;border-bottom:1px solid rgba(255,255,255,.06);
    background:transparent;color:#f2f8ff;
  }
  .nav-menu .nav-link:hover{background:rgba(79,195,247,.18);color:#fff}
  .nav-menu .nav-link.active{background:rgba(79,195,247,.14);color:#4fc3f7}
  .nav-menu .nav-link.nav-logout{margin-top:auto;border-top:1px solid rgba(244,67,54,.2)}
  body.nav-drawer-open{overflow:hidden}
}

/* ──────────────── konum detay çubuğu (windy tarzı) ──────────────── */
.loc-details{
  display:flex;flex-direction:column;gap:.3rem;margin:.2rem 0 .8rem;
  padding:.55rem .75rem;border-radius:8px;
  background:linear-gradient(180deg,rgba(15,23,42,.55),rgba(15,23,42,.30));
  border:1px solid rgba(148,163,184,.16);
  font-size:.82rem;color:#cbd5e1;
}
.loc-details .ld-row{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}
.loc-details .ld-row-top{font-weight:600;color:#e2e8f0}
.loc-details .ld-coord,.loc-details .ld-elev,.loc-details .ld-tz,
.loc-details .ld-sun,.loc-details .ld-len{display:inline-flex;align-items:center;gap:.25rem}
.loc-details .ld-next{
  margin-left:auto;color:#fcd34d;font-weight:600;
  background:rgba(245,158,11,.12);padding:.15rem .55rem;border-radius:999px;font-size:.78rem;
}
.dn-chip{
  display:inline-flex;align-items:center;gap:.25rem;
  padding:.12rem .55rem;border-radius:999px;font-size:.74rem;font-weight:700;
}
.dn-chip.dn-day{background:rgba(250,204,21,.18);color:#fcd34d;border:1px solid rgba(245,158,11,.4)}
.dn-chip.dn-night{background:rgba(99,102,241,.18);color:#c7d2fe;border:1px solid rgba(99,102,241,.4)}
@media (max-width:480px){
  .loc-details{font-size:.78rem}
  .loc-details .ld-next{margin-left:0;width:100%;text-align:center}
}
