/* idojarasbudapest.com – modern, lightweight CSS, mobile-first */
:root {
  --bg: #f4f7fb; --surface: #fff; --surface-alt: #f4f7fb;
  --text: #1a2632; --text-dark: #0a2540; --text-muted: #5a6b7c;
  --border: #e7edf3; --primary: #0a6bc1; --accent: #ffb74d;
  --shadow: 0 4px 14px rgba(10,37,64,.06);
}
:root[data-theme="dark"] {
  --bg: #0a1929; --surface: #102a40; --surface-alt: #0e2236;
  --text: #d6e3ed; --text-dark: #fff; --text-muted: #9aaab9;
  --border: #1c3956; --primary: #5fb1e8; --accent: #ffb74d;
  --shadow: 0 4px 14px rgba(0,0,0,.4);
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --bg: #0a1929; --surface: #102a40; --surface-alt: #0e2236;
    --text: #d6e3ed; --text-dark: #fff; --text-muted: #9aaab9;
    --border: #1c3956; --primary: #5fb1e8; --accent: #ffb74d;
    --shadow: 0 4px 14px rgba(0,0,0,.4);
  }
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font:16px/1.6 system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Inter",sans-serif;
  color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;
  transition:background .2s, color .2s;
}
:root[data-theme="dark"] section,
:root[data-theme="dark"] .qcard,
:root[data-theme="dark"] .prose,
:root[data-theme="dark"] .seo-text,
:root[data-theme="dark"] .daypart,
:root[data-theme="dark"] .frow,
:root[data-theme="dark"] .hour,
:root[data-theme="dark"] .cmp,
:root[data-theme="dark"] details.faq,
:root[data-theme="dark"] .chart-wrap {
  background:var(--surface); border-color:var(--border); color:var(--text);
}
:root[data-theme="dark"] h1, :root[data-theme="dark"] h2, :root[data-theme="dark"] h3, :root[data-theme="dark"] h4 { color:var(--text-dark); }
:root[data-theme="dark"] .qcard .val, :root[data-theme="dark"] .qcard .lbl, :root[data-theme="dark"] .cmp .v, :root[data-theme="dark"] .frow .day, :root[data-theme="dark"] .prose strong, :root[data-theme="dark"] .prose p { color:var(--text); }
:root[data-theme="dark"] .qcard .sub, :root[data-theme="dark"] .cmp .sub, :root[data-theme="dark"] .chart-note, :root[data-theme="dark"] .breadcrumbs ol { color:var(--text-muted); }
:root[data-theme="dark"] .ibp-chart rect[fill="#fafcfe"] { fill: var(--surface-alt); }
:root[data-theme="dark"] table.data th { background: var(--surface-alt); color: var(--text-dark); }
:root[data-theme="dark"] table.data td { color: var(--text); }
/* „Rövid válasz" és „Egy éve ma" sárgás blokkok sötétben */
:root[data-theme="dark"] section[style*="fff8e1"],
:root[data-theme="dark"] section[style*="fffaf0"] { background:linear-gradient(135deg,#3a2e0f 0%,#2a2008 100%) !important; }
:root[data-theme="dark"] section[style*="fff8e1"] h2,
:root[data-theme="dark"] section[style*="fffaf0"] h2 { color:#ffd980 !important; }
:root[data-theme="dark"] section[style*="fff8e1"] p,
:root[data-theme="dark"] section[style*="fffaf0"] p { color:#e0d4b8 !important; }
:root[data-theme="dark"] section[style*="fff8e1"] strong,
:root[data-theme="dark"] section[style*="fffaf0"] strong { color:#fff !important; }
/* „Egy éve ma" comparison kártya sötétben */
:root[data-theme="dark"] .cmp[style*="fff8e1"] { background: #3a2e0f !important; border-color:#ffb74d33 !important; }
:root[data-theme="dark"] .cmp[style*="fff8e1"] .v { color:#ffb74d !important; }
:root[data-theme="dark"] .cmp[style*="fff8e1"] .lbl { color:#ffd980 !important; }
:root[data-theme="dark"] .cmp[style*="fff8e1"] .sub { color:#e0d4b8 !important; }
:root[data-theme="dark"] .cmp[style*="fff8e1"] .d { color:#e0d4b8 !important; }
/* 14 napos lista – piros max és leírás láthatóságra */
:root[data-theme="dark"] .frow .temps .hi { color:#ff8e7d; }
:root[data-theme="dark"] .frow .temps .lo { color:#5fb1e8; }
:root[data-theme="dark"] .frow .desc { color:var(--text); }
:root[data-theme="dark"] .frow .rain { color:#5fb1e8; }
:root[data-theme="dark"] .frow .wind { color:var(--text-muted); }
:root[data-theme="dark"] .frow .day small { color:var(--text-muted); }
/* Daypart sötétben */
:root[data-theme="dark"] .daypart { background:var(--surface-alt); }
:root[data-theme="dark"] .daypart h3 { color:var(--text-muted); }
:root[data-theme="dark"] .daypart .t { color:var(--text); }
:root[data-theme="dark"] .daypart .desc { color:var(--text-muted); }
/* Hour sáv */
:root[data-theme="dark"] .hour { background:var(--surface-alt); }
:root[data-theme="dark"] .hour .h { color:var(--text-muted); }
:root[data-theme="dark"] .hour .t { color:var(--text); }
/* Notice + tip */
:root[data-theme="dark"] .notice { background:#3a2e0f; color:#ffe5b3; border-left-color:#ffb74d; }
:root[data-theme="dark"] .tip { background:var(--surface-alt); border-left-color:#5fb1e8; }
:root[data-theme="dark"] .tip h3 { color:var(--text); }
:root[data-theme="dark"] .tip p { color:var(--text-muted); }
/* Sister blokk */
:root[data-theme="dark"] .sister h3 { color:var(--text); }
:root[data-theme="dark"] .sister a { color:#5fb1e8; }
/* Map wrap dark bg */
:root[data-theme="dark"] .map-wrap { background:var(--surface-alt); }
/* Prose blockquote dark */
:root[data-theme="dark"] .prose blockquote { background:var(--surface-alt); color:var(--text-muted); }
/* Forecast14 row hover */
:root[data-theme="dark"] .frow:hover { border-color:#3a5b80; }
/* details/faq */
:root[data-theme="dark"] details.faq > summary { color:var(--text); }
:root[data-theme="dark"] details.faq > div { color:var(--text-muted); }
:root[data-theme="dark"] details.faq > summary::after { color:#5fb1e8; }
/* Hero text: az inline JS-szel set background-ok minden hero gradient marad, de kontraszt fix */
:root[data-theme="dark"] .hero { color:#fff; }
:root[data-theme="dark"] .hero h1, :root[data-theme="dark"] .hero .hero-state, :root[data-theme="dark"] .hero .hero-temp { color:#fff !important; }

.theme-toggle{background:none;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.85rem;display:inline-flex;align-items:center;gap:6px;margin-left:8px}
.theme-toggle:hover{background:rgba(255,255,255,.1)}
.geo-notice{background:#fff8e1;border-left:4px solid #ffb74d;color:#5d4a1f;padding:10px 14px;border-radius:8px;margin:0 0 12px;display:flex;align-items:center;gap:10px;font-size:.92rem}
.geo-notice a{font-weight:700;color:#0a2540}
.geo-notice .close{margin-left:auto;background:none;border:0;cursor:pointer;font-size:1.2rem;color:#5d4a1f}
:root[data-theme="dark"] .geo-notice{background:#3a2e0f;color:#ffe5b3}
img{max-width:100%;height:auto;display:block}
a{color:#0a6bc1;text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-weight:700;line-height:1.25;margin:0 0 .5em;color:#0a2540}
h1{font-size:clamp(1.6rem,3.5vw,2.25rem)}
h2{font-size:clamp(1.3rem,2.6vw,1.7rem);margin-top:1.5em}
h3{font-size:1.15rem;margin-top:1.25em}
p{margin:0 0 1em}
ul{padding-left:1.2em;margin:0 0 1em}
.container{max-width:1180px;margin:0 auto;padding:0 16px}
.skip{position:absolute;left:-9999px;top:0}
.skip:focus{left:0;top:0;background:#0a2540;color:#fff;padding:8px 14px;z-index:9999}

/* HEADER */
.site-header{background:linear-gradient(135deg,#0a2540 0%,#0e3d68 100%);color:#fff;position:sticky;top:0;z-index:50;box-shadow:0 2px 10px rgba(10,37,64,.18)}
.header-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;gap:12px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-size:1.25rem;text-decoration:none}
.brand:hover{text-decoration:none}
.brand-mark{font-size:1.6rem;line-height:1}
.brand-text strong{color:#fff;font-weight:800;letter-spacing:.2px}
.brand-dot{color:#ffb74d;font-weight:700;margin-left:6px}
.primary-nav{display:flex;flex-wrap:nowrap;gap:1px;align-items:center;white-space:nowrap}
.primary-nav a{color:#cfe2f5;padding:6px 9px;border-radius:6px;font-weight:500;font-size:.86rem;letter-spacing:-.1px;line-height:1.2;flex-shrink:0}
.primary-nav a:hover{background:rgba(255,255,255,.1);color:#fff;text-decoration:none}
.primary-nav .sister-link{background:rgba(255,183,77,.16);color:#ffb74d;font-weight:600;margin-left:6px;padding:6px 10px;border:1px solid rgba(255,183,77,.3)}
.primary-nav .sister-link:hover{background:rgba(255,183,77,.28);color:#fff}
.header-row{flex-wrap:nowrap;gap:8px}
.menu-toggle{display:none;background:none;border:0;color:#fff;width:42px;height:42px;cursor:pointer;flex-direction:column;justify-content:space-around;align-items:center;padding:10px}
.menu-toggle span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .2s}
@media (max-width:1100px){
  .primary-nav a{padding:6px 7px;font-size:.82rem}
}
@media (max-width:980px){
  .menu-toggle{display:flex}
  .primary-nav{display:none;width:100%;flex-direction:column;background:rgba(0,0,0,.25);border-radius:8px;padding:8px;margin-top:8px;white-space:normal}
  .primary-nav.open{display:flex}
  .primary-nav a{padding:10px 14px;font-size:.95rem}
  .primary-nav .sister-link{margin-left:0;margin-top:4px}
  .header-row{flex-wrap:wrap}
}

/* BREADCRUMBS */
.breadcrumbs{padding:14px 0 12px;background:linear-gradient(180deg, var(--surface-alt) 0%, transparent 100%);border-bottom:1px solid var(--border)}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:0;list-style:none;padding:0 16px;margin:0 auto;max-width:1180px;font-size:.95rem;font-weight:500}
.breadcrumbs li{display:flex;align-items:center;color:var(--text-muted)}
.breadcrumbs li:first-child a::before{content:"🏠 ";margin-right:4px}
.breadcrumbs li+li::before{content:"›";margin:0 10px;color:var(--text-muted);font-weight:700;opacity:.6}
.breadcrumbs a{color:var(--primary);text-decoration:none;font-weight:600;padding:3px 0;border-bottom:2px solid transparent;transition:border-color .15s}
.breadcrumbs a:hover{border-bottom-color:var(--primary);text-decoration:none}
.breadcrumbs li:last-child{color:var(--text-dark);font-weight:700}
:root[data-theme="dark"] .breadcrumbs{background:linear-gradient(180deg, #0e2236 0%, transparent 100%);border-bottom-color:#1c3956}
:root[data-theme="dark"] .breadcrumbs li:last-child{color:#fff}

/* MAIN */
main{padding:18px 0 40px}

/* HERO */
.hero{
  background:linear-gradient(135deg,#0e3d68 0%,#1976bd 60%,#3aa1e0 100%);
  color:#fff;border-radius:20px;padding:28px;margin-bottom:24px;position:relative;overflow:hidden;
  box-shadow:0 10px 30px rgba(14,61,104,.25)
}
.hero::after{content:"";position:absolute;right:-40px;top:-40px;width:280px;height:280px;background:radial-gradient(circle,rgba(255,255,255,.18) 0,transparent 70%);pointer-events:none}
.hero h1{color:#fff;margin:0 0 6px;text-shadow:0 2px 12px rgba(0,0,0,.15)}
.hero-sub{opacity:.92;margin:0 0 18px}
.hero-grid{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center;position:relative;z-index:1}
.hero-temp{font-size:clamp(3.8rem,11vw,6rem);font-weight:800;line-height:1;letter-spacing:-2px}
.hero-temp small{font-size:.4em;font-weight:600;opacity:.7;margin-left:6px}
.hero-state{font-size:1.2rem;margin:6px 0;font-weight:600}
.hero-icon{font-size:clamp(3.5rem,9vw,5.5rem);line-height:1}
.hero-icon img{width:clamp(3.6rem,9vw,5.6rem);height:auto;display:block;filter:drop-shadow(0 6px 14px rgba(0,0,0,.25))}
.hero-meta{display:flex;gap:14px;flex-wrap:wrap;font-size:.92rem;opacity:.92;margin-top:6px}
.hero-meta span{background:rgba(255,255,255,.16);padding:4px 10px;border-radius:999px;backdrop-filter:blur(4px)}
.updated{font-size:.82rem;opacity:.8;margin-top:10px}
@media (max-width:560px){
  .hero-grid{grid-template-columns:1fr}
  .hero{padding:22px 18px}
}

/* QUICK CARDS */
.quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:24px}
.qcard{background:#fff;border-radius:14px;padding:14px 16px;box-shadow:0 4px 14px rgba(10,37,64,.06);border:1px solid #e7edf3}
.qcard .lbl{font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;color:#5a6b7c;font-weight:600}
.qcard .val{font-size:1.5rem;font-weight:700;color:#0a2540;margin-top:4px}
.qcard .sub{font-size:.82rem;color:#5a6b7c;margin-top:2px}

/* SECTION */
section{background:#fff;border-radius:18px;padding:22px;margin:0 0 22px;box-shadow:0 4px 14px rgba(10,37,64,.05);border:1px solid #e7edf3}
section h2{margin-top:0}

/* DAYPARTS */
.dayparts{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.daypart{background:#f4f7fb;border-radius:12px;padding:14px;text-align:center}
.daypart h3{margin:0 0 4px;font-size:.95rem;color:#5a6b7c;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.daypart .icon{font-size:2.2rem;margin:4px 0}
.daypart .t{font-weight:700;color:#0a2540;font-size:1.1rem}
.daypart .desc{font-size:.88rem;color:#5a6b7c;margin-top:4px}

/* 14 DAYS TABLE */
.forecast14{display:grid;gap:10px}
.frow{
  display:grid;grid-template-columns:1.2fr 0.6fr 1fr 1.6fr 1fr 1fr;
  align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  background:#fff;border:1px solid #e7edf3;transition:transform .15s
}
.frow:hover{transform:translateX(2px);border-color:#cfe2f5}
.frow .day{font-weight:700;color:#0a2540}
.frow .day small{display:block;font-weight:400;color:#5a6b7c;font-size:.78rem}
.frow .ico{font-size:1.6rem;text-align:center}
.frow .desc{color:#1a2632;font-size:.92rem}
.frow .temps{font-weight:700;color:#0a2540;text-align:right}
.frow .temps .lo{color:#5a8bb8;font-weight:600;margin-right:8px}
.frow .rain{color:#0a6bc1;text-align:right;font-size:.9rem}
.frow .wind{color:#5a6b7c;text-align:right;font-size:.9rem}
@media (max-width:720px){
  .frow{grid-template-columns:1.3fr 0.5fr 1fr 1.2fr;font-size:.92rem}
  .frow .desc,.frow .rain{display:none}
}

/* HOURLY */
.hourly{display:flex;gap:8px;overflow-x:auto;padding:6px 2px 14px;scroll-snap-type:x mandatory}
.hour{flex:0 0 86px;text-align:center;background:#f4f7fb;border-radius:10px;padding:10px 6px;scroll-snap-align:start}
.hour .h{font-size:.82rem;color:#5a6b7c;font-weight:600}
.hour .ico{font-size:1.5rem;margin:3px 0}
.hour .t{font-weight:700;color:#0a2540}
.hour .p{font-size:.75rem;color:#0a6bc1}

/* DECISIONS PANEL — „Most dönteni akarok" */
.decisions{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;margin:14px 0}
.decision{background:var(--surface);border-radius:12px;padding:14px 16px;border-left:5px solid var(--border);box-shadow:var(--shadow);display:flex;gap:12px;align-items:flex-start;transition:transform .15s}
.decision:hover{transform:translateY(-2px)}
.decision .ic{font-size:2rem;line-height:1;flex-shrink:0}
.decision .tx h3{margin:0 0 4px;font-size:.78rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;font-weight:700}
.decision .tx p{margin:0;color:var(--text);font-size:.95rem;line-height:1.45;font-weight:500}
.decision.ok{border-left-color:#27ae60;background:linear-gradient(90deg,rgba(39,174,96,.06) 0%,var(--surface) 30%)}
.decision.warn{border-left-color:#f1c40f;background:linear-gradient(90deg,rgba(241,196,15,.08) 0%,var(--surface) 30%)}
.decision.bad{border-left-color:#e74c3c;background:linear-gradient(90deg,rgba(231,76,60,.08) 0%,var(--surface) 30%)}
:root[data-theme="dark"] .decision.ok{background:linear-gradient(90deg,rgba(39,174,96,.15) 0%,var(--surface) 30%)}
:root[data-theme="dark"] .decision.warn{background:linear-gradient(90deg,rgba(241,196,15,.15) 0%,var(--surface) 30%)}
:root[data-theme="dark"] .decision.bad{background:linear-gradient(90deg,rgba(231,76,60,.15) 0%,var(--surface) 30%)}

/* RAIN ARRIVAL — „Mikor érkezik az eső?" sáv */
.rain-arrival{background:linear-gradient(135deg,#0a6bc1 0%,#3aa1e0 100%);color:#fff;border-radius:14px;padding:18px 22px;margin:14px 0;display:flex;gap:16px;align-items:center;box-shadow:0 4px 14px rgba(10,107,193,.25)}
.rain-arrival .icon{font-size:2.8rem;line-height:1;flex-shrink:0}
.rain-arrival .main{flex:1}
.rain-arrival .main h3{margin:0 0 4px;color:#fff;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;font-weight:700;opacity:.9}
.rain-arrival .main p{margin:0;color:#fff;font-size:1.1rem;font-weight:600}
.rain-arrival .sub{font-size:.85rem;opacity:.9;margin-top:2px;font-weight:400}
:root[data-theme="dark"] .rain-arrival{background:linear-gradient(135deg,#0e3d68 0%,#1976bd 100%)}

/* AI / DINAMIKUS BEVEZETŐ — friss, időjárás-specifikus felvezetés */
.ai-intro{
  background:linear-gradient(135deg,var(--surface) 0%,var(--surface-alt) 100%);
  border:1px solid var(--border);border-left:4px solid var(--primary);
  border-radius:14px;padding:18px 22px;margin:0 0 22px;box-shadow:var(--shadow)
}
.ai-intro p{margin:0 0 .6em;font-size:1.06rem;line-height:1.72;color:var(--text)}
.ai-intro p:last-child{margin-bottom:0}
.ai-intro .ai-intro-meta{display:block;margin-top:10px;font-size:.8rem;color:var(--text-muted);font-weight:500}
:root[data-theme="dark"] .ai-intro{background:linear-gradient(135deg,var(--surface) 0%,var(--surface-alt) 100%);border-left-color:#5fb1e8}
:root[data-theme="dark"] .ai-intro p{color:var(--text)}

/* TRUST BAR — adatbizalom jelzés */
.trust-bar{display:flex;flex-wrap:wrap;gap:8px 16px;font-size:.82rem;color:var(--text-muted);padding:8px 14px;background:var(--surface-alt);border-radius:8px;margin:8px 0 16px;border-left:3px solid var(--primary)}
.trust-bar strong{color:var(--text);font-weight:600}
.trust-bar .sep{opacity:.4}

/* TIPS / ADVICE */
.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.tip{background:#f4f7fb;border-left:4px solid #1976bd;padding:14px 16px;border-radius:8px}
.tip h3{margin:0 0 6px;font-size:1rem;color:#0a2540}
.tip p{margin:0;color:#1a2632;font-size:.95rem}

/* SISTER LINKS */
.sister{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.sister h3{margin:0 0 8px;font-size:1rem;color:#0a2540}
.sister ul{list-style:none;padding:0;margin:0}
.sister li{margin:4px 0}
.sister a{color:#0a6bc1}

/* AD */
.ad-wrap{margin:18px 0;text-align:center;min-height:120px;background:#f7f9fc;border:1px dashed #d6deea;border-radius:10px;padding:8px;overflow:hidden}
.ad-wrap ins{margin:0 auto}

/* FOOTER */
.site-footer{background:#0a2540;color:#cfe2f5;padding:48px 0 18px;margin-top:40px}
.site-footer h3{color:#fff;font-size:.92rem;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.footer-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:32px 24px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:5px 0}
.site-footer a{color:#cfe2f5;font-size:.92rem;line-height:1.5;text-decoration:none;transition:color .15s}
.site-footer a:hover{color:#ffb74d;text-decoration:none}
.footer-legal{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 24px;margin:32px 0 18px;padding:18px 0 12px;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.footer-legal a{font-size:.88rem;color:#9aaab9;font-weight:500}
.footer-legal a:hover{color:#ffb74d}
.footer-disclaimer{font-size:.85rem;line-height:1.65;color:#9aaab9;max-width:1100px;margin:0 auto 18px;padding:0 8px}
.footer-disclaimer p{margin:0 0 8px}
.footer-disclaimer a{color:#ffb74d;font-weight:600}
.footer-bottom{margin-top:14px;padding-top:14px;text-align:center;color:#7d8a98;border-top:1px solid rgba(255,255,255,.06);font-size:.82rem}
@media (max-width:980px){.footer-grid{grid-template-columns:repeat(3,1fr);gap:28px 20px}}
@media (max-width:680px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:420px){.footer-grid{grid-template-columns:1fr}}

/* CHARTS */
.chart-wrap{margin:14px 0 4px;background:#fff;border-radius:12px;border:1px solid #e7edf3;padding:10px 8px;position:relative}
.ibp-chart{width:100%;height:auto;display:block;max-height:340px}
.ibp-chart .ibp-hit{cursor:crosshair}
.ibp-chart .ibp-cross{transition:opacity .1s}
.chart-tooltip{position:absolute;z-index:5;pointer-events:none;opacity:0;transform:translate(-50%,0);transition:opacity .12s;
  background:var(--text-dark);color:#fff;padding:7px 10px;border-radius:8px;font-size:.8rem;line-height:1.35;
  box-shadow:0 6px 18px rgba(10,37,64,.28);white-space:nowrap;max-width:220px}
.chart-tooltip.on{opacity:1}
.chart-tooltip .tt-title{font-weight:700;margin-bottom:2px;color:#ffd980}
.chart-tooltip .tt-row{opacity:.95}
:root[data-theme="dark"] .chart-tooltip{background:#06121f;border:1px solid #1c3956}
.chart-note{font-size:.85rem;color:#5a6b7c;margin-top:4px;text-align:center}
.comparison{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin:12px 0}
.cmp{background:#f4f7fb;border-radius:10px;padding:10px 12px;text-align:center}
.cmp .lbl{font-size:.78rem;text-transform:uppercase;color:#5a6b7c;letter-spacing:.4px;font-weight:600}
.cmp .v{font-size:1.3rem;font-weight:700;color:#0a2540}
.cmp .d{font-size:.85rem;font-weight:600;margin-top:2px}
.cmp .d.up{color:#c0392b}
.cmp .d.down{color:#1f78b4}
.cmp .d.same{color:#5a6b7c}

/* PROSE */
.prose{background:#fff;border-radius:14px;padding:24px;border:1px solid #e7edf3;color:#243447;margin:18px 0}
.prose p{font-size:1rem;line-height:1.75;margin:0 0 1.05em;color:#243447}
.prose h2{color:#0a2540;margin-top:1.2em}
.prose h3{color:#0a2540;margin-top:1em}
.prose strong{color:#0a2540}
.prose blockquote{border-left:4px solid #1976bd;padding:8px 16px;margin:12px 0;background:#f4f7fb;border-radius:0 8px 8px 0;color:#384a5e;font-style:italic}

/* FAQ */
details.faq{background:#fff;border:1px solid #e7edf3;border-radius:10px;padding:0;margin:8px 0;overflow:hidden}
details.faq>summary{padding:14px 18px;cursor:pointer;font-weight:600;color:#0a2540;list-style:none;display:flex;justify-content:space-between;align-items:center}
details.faq>summary::-webkit-details-marker{display:none}
details.faq>summary::after{content:"+";font-size:1.3rem;color:#0a6bc1;font-weight:700;margin-left:10px}
details.faq[open]>summary::after{content:"−"}
details.faq>div{padding:0 18px 16px;color:#384a5e;line-height:1.7}

/* MAP IFRAME WRAPPER */
.map-wrap{position:relative;border-radius:14px;overflow:hidden;box-shadow:0 4px 14px rgba(10,37,64,.08);aspect-ratio:16/9;background:#e7edf3}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* SEO BODY */
.seo-text{background:#fff;border-radius:14px;padding:22px;border:1px solid #e7edf3;color:#384a5e}
.seo-text h2{color:#0a2540}
.seo-text p{font-size:.96rem}

/* TABLE — climate */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table.data{width:100%;border-collapse:collapse;font-size:.92rem}
table.data th,table.data td{padding:8px 10px;border-bottom:1px solid #e7edf3;text-align:center}
table.data th{background:#f4f7fb;color:#0a2540;font-weight:700}

/* NOTICE */
.notice{background:#fff8e1;border-left:4px solid #ffb74d;color:#5d4a1f;padding:12px 14px;border-radius:8px;margin:10px 0}

/* PRINT */
@media print{
  .site-header,.site-footer,.ad-wrap,.menu-toggle{display:none!important}
  section{break-inside:avoid;box-shadow:none;border:1px solid #ccc}
}
