/* loadcurve — közös design-tokenek + chrome stílusok (Phase 3 előtt index.html
   inline <style>-jéből kiemelve, szó szerint, vizuális változás nélkül), plusz a
   metodológia oldal hosszú-szöveges (article/ToC/footnote-kész) kiegészítései.
   Mindkét oldal (index.html, methodology.html) ugyanide linkel. */
:root{
  --bg:#0B0E14; --surface:#141923; --line:#232A38;
  --txt:#E6EBF2; --muted:#8A93A6; --faint:#5A6477;
  --teal:#3FD8B4; --amber:#F2B441; --green:#7ED957;
  --display:'Space Grotesk',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif; --mono:'IBM Plex Mono',monospace;
}
*{box-sizing:border-box} html,body{margin:0}
body{background:var(--bg);color:var(--txt);font-family:var(--body);min-height:100vh}
::selection{background:var(--teal);color:#04140f}
:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
h1,h2,h3{font-family:var(--display);font-weight:600;letter-spacing:-.01em}
button{font-family:var(--body);cursor:pointer}
.btn{background:var(--surface);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:.5rem .9rem;font-size:13px}
.btn:hover{border-color:var(--faint)}
.btn:disabled{opacity:.4;cursor:default}
/* a .muted a --faint helyett a --muted tokent használja (8A93A6, ~6.3:1 a --bg-hez
   képest) — mért WCAG AA-fix (polish brief): a --faint csak ~3.2:1-et ad, ami a
   tényleges OLVASANDÓ magyarázó szövegekhez (lábjegyzetek, captionök, bontás-kontextus)
   nem elég; a --faint marad a dekoratív CSAK-NAGYBETŰS label-eknél (.eyebrow,
   .heroColLabel, stb.), ahol a nagyméretű-szöveg AA-küszöb (3:1) is elég. */
.muted{color:var(--muted)}
.wrap{max-width:1040px;margin:0 auto;padding:0 1.5rem;width:100%}

header{border-bottom:1px solid var(--line)}
/* gap a "wordmark <-> bar-right" pár között: justify-content:space-between magában
   csak akkor ad helyet, ha van rá szabad szélesség — szűk (~380px) nézeten elfogyhat,
   és a wordmark + módszertan glued lesz; a gap minimumot garantál attól függetlenül */
.bar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1rem 0}
.wordmark{font-family:var(--mono);font-weight:500;font-size:15px}
.wordmark .tld{color:var(--teal)}
.bar a{color:var(--muted);font-size:13px;text-decoration:none;cursor:pointer}
.bar a:hover{color:var(--txt)}
.bar-right{display:flex;align-items:center;gap:1rem}

/* nyelv-választó: natív <details>/<summary> — állandó fejléc-méret függetlenül a
   nyelvek számától (lásd *.js#buildLangSwitcher()), a régi "egy pill soronkénti
   nyelv" elrendezés helyett, ami már 3 nyelvnél túlcsordul szűk nézeten. A <summary>
   a meglévő .seg/.seg.on pill-stílust használja (lásd lentebb), csak a natív
   lenyíló-háromszöget cseréljük saját ▾ jelre (cross-browser reset). */
#langSwitch{position:relative;display:block}
#langSwitch summary{list-style:none;display:inline-flex;align-items:center;gap:.3rem;cursor:pointer}
#langSwitch summary::-webkit-details-marker{display:none}
#langSwitch summary::marker{content:""}
#langSwitch .caret{font-size:9px}
#langSwitch .seg{padding:.3rem .6rem;font-size:12px}
#langSwitch .langPanel{position:absolute;top:calc(100% + .4rem);right:0;z-index:20;display:flex;flex-direction:column;gap:.15rem;min-width:130px;max-height:60vh;overflow-y:auto;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.35rem}
#langSwitch .langPanel a{display:block;padding:.4rem .6rem;border-radius:6px;color:var(--muted);font-size:13px;text-decoration:none}
#langSwitch .langPanel a:hover{background:var(--bg);color:var(--txt)}
#langSwitch .langPanel a[aria-current="true"]{color:var(--teal);font-weight:500}

.periodbar{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding:.85rem 0;border-bottom:1px solid var(--line)}
.periodbar .plabel{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-right:.25rem}
.periodbar select{background:var(--bg);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:.4rem .5rem;font-size:13px;font-family:var(--body)}
.periodbar select:disabled{opacity:.4}
.periodbar #periodNote{font-size:12px;margin-left:.5rem}
.periodsel{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.periodsel .plabel{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.periodsel select{background:var(--bg);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:.35rem .45rem;font-size:12px;font-family:var(--body)}
.periodsel select:disabled{opacity:.4}
.mapleft{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.depthright{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
section{padding:2rem 0}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}

/* HŐS: élő nap+szél-arány + szezonális sáv + esemény (UI brief: signature-first hero) */
/* egysoros értékajánlat (polish brief) — a korábbi redundáns .eyebrow helyén, de azzal
   szemben DOMINÁL: nagyobb, fehérebb (--txt, ~16:1), mint a heroTitle (--muted, ~6.3:1) alatta,
   hogy a két sor ne egy futószövegként olvasódjon, és a fő figyelem az értékajánlaton
   legyen, mielőtt a nagy szám jönne */
.heroValueProp{font-family:var(--display);font-size:1.05rem;font-weight:500;line-height:1.4;color:var(--txt);margin:.2rem 0 .3rem;max-width:46ch}
#hero h1{font-size:.95rem;font-weight:500;color:var(--muted);margin:0 0 .6rem;letter-spacing:0}
/* két szám egymás mellett (nap+szél teal | teljes megújuló zöld) — lásd app.js#renderHero()/
   #renderRenewableBreakdown(); a .heroColRenewable [hidden] a graceful-degradation ág, ha a
   zónának nincs friss bontás-pillanatképe (a böngésző natívan elrejti, nincs JS-display-csere) */
/* 2->4 csempe (low-carbon brief): grid, hogy a "4 oszlop széles nézeten, 2x2 mobilon"
   determinisztikus legyen — a korábbi flex-wrap a tartalom szélességétől függően
   máshogy törhetett volna sorba. [hidden] csempék grid-ben is kiesnek a flow-ból
   (ugyanúgy, mint korábban flex-ben), így a részleges degradáció (csak 2 csempe
   látható) továbbra is helyesen balra igazítva jelenik meg. */
.heroNums{display:grid;grid-template-columns:repeat(4,1fr);align-items:baseline;gap:2rem 2.5rem}
@media (max-width:680px){.heroNums{grid-template-columns:repeat(2,1fr)}}
.heroCol[hidden]{display:none}
.heroColLabel{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:.15rem}
.heroBig{font-family:var(--mono);font-weight:500;font-size:clamp(3rem,12vw,5.5rem);color:var(--teal);line-height:1;white-space:nowrap}
.heroBigRenewable,.heroBigLowCarbon{color:var(--green)}
.heroUnit{font-size:.36em;color:var(--muted);margin-left:.12em;font-weight:500}
.co2-low{color:var(--green)}
.co2-mid{color:var(--amber)}
.co2-high{color:#ef5350}
.heroGwLine{color:var(--muted);font-size:13px;margin-top:.3rem}
/* .heroSubNote (CO2-csempe) a .muted/.small utility osztályoktól kapja a színt/méretet
   (lásd index.html markup) — itt csak a heroGwLine-nal egyező felső térköz kell. */
.heroSubNote{margin-top:.3rem}
.heroRef{color:var(--muted);font-size:14px;margin-top:.5rem}
.small{font-size:12px}
/* lenyitható forrás-bontás — natív <details>/<summary>, ugyanaz a minta mint #langSwitch-nél
   (lásd app.js#buildLangSwitcher() megjegyzése): nincs egyedi JS toggle. A magyarázó
   lábjegyzetek (korábban a hős mindig-látható részén) ide költöztek (polish brief: declutter)
   — a <summary> a #langSwitch ▾-jelét (caret) használja újra, hogy lenyithatóként, ne
   navigációs gombként olvasódjon, és CSS-ben forog nyitáskor (nincs külön JS-állapot, a
   natív [open] attribútum vezérli). */
.renewableBreakdown{margin-top:1rem;max-width:640px}
.renewableBreakdown[hidden]{display:none}
.renewableBreakdown summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;width:fit-content}
.renewableBreakdown summary::-webkit-details-marker{display:none}
.renewableBreakdown summary::marker{content:""}
.renewableBreakdown .caret{font-size:9px;display:inline-block;transition:transform .15s ease}
.renewableBreakdown[open] .caret{transform:rotate(180deg)}
.renewableBreakdown .breakdownContext{margin:.6rem 0 .4rem}
.renewableBreakdown .breakdownHourNote{margin:0 0 .4rem;font-family:var(--mono)}
.renewableBreakdown .breakdownFootnote{margin:.2rem 0}
.breakdownRows{display:flex;flex-direction:column;gap:.45rem;margin-top:.5rem}
.breakdownRow{display:grid;grid-template-columns:6.5rem 1fr 5rem 3.5rem;align-items:center;gap:.6rem;font-size:13px}
.breakdownLabel{color:var(--txt)}
.breakdownBarTrack{position:relative;height:8px;border-radius:999px;background:var(--surface);border:1px solid var(--line);overflow:hidden}
.breakdownBar{display:block;height:100%;border-radius:999px}
.breakdownBar-teal{background:var(--teal)}
.breakdownBar-green{background:var(--green)}
.breakdownGw{font-family:var(--mono);text-align:right;color:var(--txt)}
.breakdownPct{text-align:right}
@media (max-width:480px){
  .breakdownRow{grid-template-columns:5rem 1fr 4.2rem;font-size:12px}
  .breakdownPct{display:none}
}
#historyBar{margin-top:1rem;max-width:420px}
.historyTrack{position:relative;height:6px;border-radius:999px;background:var(--surface);border:1px solid var(--line)}
/* a bal/jobb szél (border) a p05/p95 jelölő — lásd event-note fix brief Part 2: a sáv
   pereme MAGA a "tick", nem kell külön elem hozzá */
.historyBand{position:absolute;top:0;bottom:0;background:rgba(63,216,180,.35);border-radius:999px;border-left:1px solid rgba(63,216,180,.7);border-right:1px solid rgba(63,216,180,.7)}
.historyNow{position:absolute;top:-3px;width:2px;height:12px;background:var(--teal);transform:translateX(-1px)}
/* sávon-túli "most"-jelölő (a skála fix paddinggel a sáv köré tágul, lásd app.js
   renderHistoryBar() — ezért a pozíció magától "kilóg" a sávból); a szín az esemény-sáv
   meglévő amber/teal konvencióját követi (alacsony=amber, magas=teal, ami már az alap) */
.historyNow-low{background:var(--amber)}
/* a szezonális-sáv magyarázat OLVASANDÓ szöveg, nem label — --muted (AA-fix, lásd .muted
   megjegyzése fentebb), nem --faint */
.historyCaption{color:var(--muted);font-size:11px;margin-top:.4rem}
.eventBar{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--amber);border-radius:8px;padding:.85rem 1rem;margin-top:1rem;font-size:13px;color:var(--txt)}
.eventBar[hidden]{display:none}
.eventBar p{margin:0 0 .4rem}
.eventBar p:last-child{margin-bottom:0}
/* az "ez az óra a felfedezőben" link — nincs globális a{} reset az oldalon, ezért
   ez nélküle UA-kék lenne; szándékosan csak .eventBar-ra szűkítve, nem globálisan */
.eventBar a,.eventBar a:visited{color:var(--teal);text-decoration:none}
.eventBar a:hover{text-decoration:underline}
.heroFoot{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-top:1.25rem}
.zonePicker{display:flex;align-items:center;gap:.5rem;font-size:12px;color:var(--muted)}
.zonePicker label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;font-size:11px;color:var(--faint)}
.zonePicker select{background:var(--bg);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:.3rem .5rem;font-size:13px;font-family:var(--body)}
.exploreLink{color:var(--muted);font-size:13px;text-decoration:none}
.exploreLink:hover{color:var(--txt)}
@media (max-width:680px){
  .heroBig{font-size:clamp(2.4rem,16vw,3.2rem)}
}

/* KONTEXTUS: térkép (volt hős, lásd UI brief WU-4 — áthelyezve, nem újraépítve) */
#context{border-top:1px solid var(--line)}
#context h2{font-size:1.3rem;margin:.3rem 0 1rem}
.maptop{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:space-between;margin-bottom:1rem}
#mapLayers{display:flex;gap:.4rem;flex-wrap:wrap}
.seg{background:transparent;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:.4rem .9rem;font-size:13px}
.seg.on{background:var(--teal);color:#04140f;border-color:var(--teal);font-weight:500}
#mapTime{font-family:var(--mono);font-size:12px;color:var(--faint)}
#map{min-height:520px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:.5rem}
#map svg{max-width:100%;height:auto}

/* MOST + REKORDOK */
.statgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media (max-width:680px){.statgrid{grid-template-columns:1fr}}
.stat,.rec{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:1.25rem}
.stat .big,.rec .big{font-family:var(--mono);font-weight:500;font-size:1.9rem;color:var(--teal)}
.stat .lbl,.rec .lbl{color:var(--muted);font-size:13px;margin-top:.25rem}
.rec .sub{font-family:var(--mono);font-size:11px;color:var(--faint);margin-top:.4rem}
#records h3{font-size:1rem;color:var(--muted);font-weight:500;margin:0 0 1rem}
.recgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media (max-width:680px){.recgrid{grid-template-columns:1fr}}

/* MÉLYSÉG */
#depth{border-top:1px solid var(--line)}
.depthhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.depthhead h2{font-size:1.4rem;margin:0}
#storybar{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:1.1rem 1.25rem;margin-bottom:1.25rem}
#storybar.hidden,#controls.hidden{display:none}
#storyTitle{font-size:1.3rem;margin:0 0 .4rem}
#storyCaption{color:var(--muted);margin:0 0 .9rem;max-width:72ch}
.storynav{display:flex;gap:.5rem;align-items:center}
.storynav .spacer{flex:1}
#depthGrid{display:grid;grid-template-columns:1fr;gap:1.25rem;align-items:start}
#depthGrid.explore{grid-template-columns:260px 1fr}
@media (max-width:760px){#depthGrid.explore{grid-template-columns:1fr}}
#controls{display:flex;flex-direction:column;gap:1rem}
.ctl{display:flex;flex-direction:column;gap:.35rem}
.ctl.row{flex-direction:row;align-items:center}
.ctl label{font-size:12px;color:var(--muted);font-family:var(--mono);letter-spacing:.04em}
select{background:var(--bg);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:.45rem;font-size:13px;font-family:var(--body)}
select[multiple]{padding:.2rem}
#panel{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:1.25rem;min-height:540px}
#chart{width:100%;min-height:480px;overflow-x:auto}
#chart svg{max-width:100%;height:auto}
.loading,.stub{color:var(--muted);padding:2rem;text-align:center}

.waiting{max-width:520px;margin:5rem auto;text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:2.5rem}
.waiting h2{font-weight:500;margin:1rem 0 .5rem}
.waiting p{color:var(--muted);margin:0}
.led{width:11px;height:11px;border-radius:50%;display:inline-block;background:var(--faint)}
.led.wait{background:var(--amber);box-shadow:0 0 0 5px rgba(242,180,65,.12)}

footer{border-top:1px solid var(--line)}
.foot{padding:1.5rem 0;font-size:13px;color:var(--muted)}
.foot p{margin:0}
.foot p + p{margin-top:.4rem}
.foot a{color:var(--muted);text-decoration:underline}
.foot a:hover{color:var(--txt)}
.foot .meta{font-family:var(--mono);font-size:11px;color:var(--faint);margin-top:.5rem}

/* --- Hosszú-szöveges (metodológia) oldal — saját réteg, a fenti chrome-tokeneket
   használja, de a dashboard sűrű chrome-rácsától eltérő, olvasásra optimalizált
   elrendezés. --- */
.pageTitle{font-size:clamp(1.6rem,4vw,2.2rem);margin:.2rem 0 1.25rem}
.notice{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--amber);border-radius:8px;padding:.75rem 1rem;font-size:13px;color:var(--muted);margin-bottom:1.5rem}
.notice[hidden]{display:none}

.methGrid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start}
.methGrid.withToc{grid-template-columns:220px 1fr}
@media (max-width:760px){.methGrid.withToc{grid-template-columns:1fr}}

#toc{font-size:13px}
#toc .tocLabel{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:.6rem;display:block}
#toc ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.45rem}
#toc a{color:var(--muted);text-decoration:none;line-height:1.3}
#toc a:hover{color:var(--txt)}
@media (min-width:761px){#toc{position:sticky;top:1.5rem}}

.article{max-width:72ch;font-size:15px;line-height:1.7}
.article h2{font-size:1.5rem;margin:2.2rem 0 .9rem;scroll-margin-top:1rem}
.article h2:first-child{margin-top:0}
.article h3{font-size:1.15rem;margin:1.6rem 0 .7rem;scroll-margin-top:1rem}
.article h2 .h-anchor,.article h3 .h-anchor{opacity:0;margin-left:.4rem;color:var(--faint);text-decoration:none;font-size:.85em}
.article h2:hover .h-anchor,.article h3:hover .h-anchor{opacity:1}
.article p{margin:0 0 1rem}
.article ul,.article ol{margin:0 0 1rem;padding-left:1.4rem}
.article li{margin-bottom:.4rem}
.article strong{color:var(--txt);font-weight:600}
.article blockquote{border-left:3px solid var(--line);margin:0 0 1rem;padding:.2rem 0 .2rem 1rem;color:var(--muted)}
.article code{font-family:var(--mono);font-size:.85em;background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:.1em .35em}
.article pre{font-family:var(--mono);font-size:.85em;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.9rem 1rem;overflow-x:auto;margin:0 0 1rem}
.article pre code{background:none;border:none;padding:0}
.article table{width:100%;border-collapse:collapse;font-size:13px;margin:0 0 1.25rem}
.article th,.article td{border-bottom:1px solid var(--line);text-align:left;padding:.45rem .6rem}
.article th{color:var(--muted);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.article .chartLink{font-size:13px;margin:.5rem 0 1.5rem}
.article .footnotes{border-top:1px solid var(--line);margin-top:2.5rem;padding-top:1rem;font-size:13px;color:var(--muted)}

/* --- shared popover (hero tile explanations + map zone tap) --- */
/* Hero tiles are themselves the trigger (no separate "i" dot): the whole tile is
   hoverable/tappable/focusable and shows its explanation popover. */
.heroCol[role="button"]{cursor:help;border-radius:8px}
.heroCol[role="button"]:focus-visible{outline:2px solid var(--teal);outline-offset:4px}
/* a subtle hint the label is interactive, without adding chrome */
.heroCol[role="button"] .heroColLabel{text-decoration:underline dotted var(--faint);text-underline-offset:3px}
/* infoDot: reusable "i" circle primitive (makeInfoDot) — not used on the hero tiles,
   kept for other surfaces that may want a dedicated trigger */
.infoDot{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;border:1px solid var(--faint);background:transparent;color:var(--faint);font-size:9px;font-family:var(--body);cursor:pointer;padding:0;margin-left:.35em;vertical-align:middle;line-height:1;flex-shrink:0;transition:border-color .15s,color .15s}
.infoDot:hover,.infoDot:focus-visible{border-color:var(--muted);color:var(--muted);outline:none}
.infoDot[aria-expanded="true"]{border-color:var(--teal);color:var(--teal)}
/* shared popover bubble */
.popover{position:fixed;z-index:200;max-width:min(320px,90vw);background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:.75rem 1rem;font-size:13px;color:var(--txt);line-height:1.5;box-shadow:0 4px 20px rgba(0,0,0,.45);cursor:default}
.popover[hidden]{display:none}
.popover .pTitle{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin:0 0 .5rem}
.popover .pRow{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;padding:.18rem 0;border-bottom:1px solid var(--line)}
.popover .pRow:last-of-type{border-bottom:none}
.popover .pLbl{font-size:12px;color:var(--muted)}
.popover .pVal{font-family:var(--mono);font-weight:500;color:var(--teal);white-space:nowrap}
.popover .pNote{font-size:12px;color:var(--muted);margin:.5rem 0 0;line-height:1.45}
/* narrow viewport: bottom sheet instead of anchored bubble */
@media(max-width:480px){
  .popover{position:fixed;bottom:0;left:0;right:0;max-width:100%;border-radius:14px 14px 0 0;padding:1.25rem 1.5rem 2.5rem;box-shadow:0 -4px 28px rgba(0,0,0,.55)}
}
