﻿:root {
  --ink: #18333a;
  --deep: #062a34;
  --deep-2: #0a3b44;
  --green: #198a62;
  --mint: #77d7ae;
  --paper: #f4f7f3;
  --white: #fff;
  --muted: #6c8081;
  --line: #d7e2df;
  --amber: #d79b35;
  --coral: #d96d55;
  --shadow: 0 18px 40px rgba(18, 61, 67, .1);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: hidden; color: var(--ink); background: var(--paper); font-family: "DM Sans", Arial, sans-serif; }
button, select, input { font: inherit; }
.band { width: min(1420px, calc(100% - 56px)); margin: 0 auto; }
.site-header { display: flex; justify-content: space-between; align-items: center; padding: 15px 28px; color: white; background: var(--deep); }
.brand { display: flex; align-items: center; gap: 10px; color: white; text-decoration: none; font-weight: 700; }
.brand-mark { display: grid; place-items: center; width: 34px; height: 34px; border: 1px solid rgba(255,255,255,.55); color: var(--mint); font-size: 12px; }
.header-meta, .period-picker { display: flex; gap: 9px; align-items: center; color: #c8dddc; font-size: 12px; }
.period-picker select { min-width: 132px; padding: 7px 28px 7px 10px; border-color: rgba(255,255,255,.28); color: white; background: var(--deep); font-size: 12px; }
.period-picker option { color: var(--ink); background: white; }
.top-nav { display: flex; gap: 18px; }
.top-nav a { color: #c8dddc; font-size: 11px; font-weight: 700; text-decoration: none; text-transform: uppercase; }
.top-nav a:hover { color: var(--mint); }
.mobile-menu-toggle { display: none; min-height: 36px; padding: 0 12px; border: 1px solid rgba(255,255,255,.32); color: white; background: transparent; cursor: pointer; font-size: 11px; font-weight: 700; text-transform: uppercase; }
.mobile-menu-toggle[aria-expanded="true"] { color: var(--deep); background: var(--mint); border-color: var(--mint); }
body.menu-open { overflow: hidden; }
.mobile-menu-panel { position: fixed; inset: 0; z-index: 40; display: none; }
.mobile-menu-panel.open { display: block; }
.mobile-menu-backdrop { position: absolute; inset: 0; background: rgba(6,42,52,.58); }
.mobile-menu-sheet { position: absolute; left: 12px; right: 12px; top: 12px; display: grid; overflow: hidden; border: 1px solid rgba(255,255,255,.18); background: white; box-shadow: 0 28px 70px rgba(6,42,52,.34); }
.mobile-menu-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 14px 14px; color: white; background: var(--deep); }
.mobile-menu-head span { color: var(--mint); font-size: 11px; font-weight: 700; text-transform: uppercase; }
.mobile-menu-head button { border: 1px solid rgba(255,255,255,.24); color: white; background: transparent; cursor: pointer; padding: 7px 9px; font-size: 10px; font-weight: 700; text-transform: uppercase; }
.mobile-menu-sheet a { display: flex; justify-content: space-between; align-items: center; min-height: 52px; padding: 0 16px; border-bottom: 1px solid var(--line); color: var(--deep); font-size: 15px; font-weight: 700; text-decoration: none; }
.mobile-menu-sheet a:last-child { border-bottom: 0; }
.mobile-menu-sheet a::after { content: ">"; color: var(--green); font-size: 14px; }
.mobile-menu-sheet a:hover { color: var(--green); background: #f4fbf7; }
.status-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); }
.hero { position: relative; min-height: 610px; overflow: hidden; color: white; background: var(--deep); }
.hero-photo { position: absolute; inset: 0; background: url("assets/canarias-energy-hero.png") center / cover no-repeat; }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(4,34,42,.96), rgba(4,34,42,.76) 55%, rgba(4,34,42,.22)); }
.hero-inner { position: relative; width: min(1420px, calc(100% - 56px)); margin: auto; padding: 95px 0 92px; }
.eyebrow { margin: 0 0 10px; color: var(--mint); font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.eyebrow.green { color: var(--green); }
.eyebrow.mint { color: var(--mint); }
h1, h2 { margin: 0; font-family: "Fraunces", Georgia, serif; letter-spacing: 0; }
h1 { max-width: 920px; font-size: clamp(55px, 7vw, 98px); line-height: .93; }
h2 { font-size: clamp(34px, 4vw, 56px); line-height: 1; }
h3 { margin: 0; font-size: 25px; letter-spacing: 0; }
.hero-copy { max-width: 690px; margin: 24px 0 34px; overflow-wrap: anywhere; color: #d7e7e5; font-size: 17px; line-height: 1.65; }
.hero-numbers { display: flex; gap: 42px; flex-wrap: wrap; }
.hero-numbers div { min-width: 220px; padding-left: 15px; border-left: 3px solid var(--mint); }
.hero-numbers span, .hero-numbers small { display: block; color: #bed4d2; font-size: 12px; }
.hero-numbers strong { display: block; margin: 5px 0; font-size: 29px; }
.hero-scroll { position: absolute; right: 28px; bottom: 24px; color: white; text-decoration: none; font-size: 12px; font-weight: 700; }
.hero-scroll span { display: inline-grid; place-items: center; width: 29px; height: 29px; margin-left: 9px; border: 1px solid rgba(255,255,255,.5); border-radius: 50%; }
.intro { display: grid; grid-template-columns: .85fr 1.15fr; gap: 70px; padding: 76px 0; }
.overview { padding: 68px 0 46px; }
.overview-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 10px; }
.overview-grid article, .self-kpis article { min-width: 0; padding: 17px; border-top: 3px solid var(--green); background: white; }
.overview-grid span, .self-kpis span, .overview-grid small, .self-kpis small { display: block; color: var(--muted); font-size: 11px; }
.overview-grid strong, .self-kpis strong { display: block; margin: 13px 0 7px; overflow-wrap: anywhere; font-size: 25px; }
.overview-grid .solar-card, .self-kpis article { border-top-color: var(--amber); background: #fffaf0; }
.overview-grid .erni-card { border-top-color: var(--coral); }
.view-control { display: flex; align-items: center; gap: 10px; color: var(--muted); font-size: 11px; font-weight: 700; text-transform: uppercase; }
.segments.light { display: flex; margin: 0; }
.segments.light button { min-height: 34px; padding: 0 10px; border-color: var(--line); color: var(--muted); }
.segments.light button.active { color: white; background: var(--deep); border-color: var(--deep); }
.legend-row { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 14px; color: var(--muted); font-size: 11px; }
.legend-row i { display: inline-block; width: 8px; height: 8px; margin-right: 5px; border-radius: 50%; }
.official-dot { background: var(--green); }.calculated-dot { background: var(--deep); }.estimated-dot { background: var(--amber); }
.readings-section { padding: 18px 0 74px; }
.readings-hero { display: grid; grid-template-columns: .85fr 1.15fr; gap: 12px; }
.reading-main { min-width: 0; padding: 24px; color: white; background: var(--deep); box-shadow: var(--shadow); }
.reading-main span { display: block; color: var(--mint); font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.reading-main strong { display: block; margin-top: 14px; font-family: "DM Sans", Arial, sans-serif; font-size: clamp(19px, 2vw, 28px); font-weight: 700; line-height: 1.22; overflow-wrap: anywhere; }
.reading-main p { margin: 18px 0 0; color: #c9dddd; font-size: 13px; line-height: 1.55; }
.reading-grid { display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap: 9px; }
.reading-grid article { min-width: 0; min-height: 205px; padding: 16px; border-top: 3px solid var(--deep); background: white; box-shadow: var(--shadow); }
.reading-grid article.good { border-top-color: var(--green); background: #f4fbf7; }
.reading-grid article.warn { border-top-color: var(--amber); background: #fff8e9; }
.reading-grid article.opportunity { border-top-color: var(--coral); background: #fff6f3; }
.reading-grid article.solar { border-top-color: var(--amber); background: #fffaf0; }
.reading-grid article.cost { border-top-color: var(--deep); }
.reading-grid span { display: block; color: var(--green); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.reading-grid strong { display: block; margin-top: 12px; overflow-wrap: anywhere; font-size: 24px; line-height: 1; }
.reading-grid em { display: block; min-height: 34px; margin-top: 10px; color: var(--deep); font-size: 13px; font-style: normal; font-weight: 700; line-height: 1.25; }
.reading-grid p { margin: 10px 0 0; color: var(--muted); font-size: 12px; line-height: 1.48; }
.cost-section { padding: 54px 0 70px; }
.cost-context { display: inline-flex; align-items: center; min-height: 32px; margin: 0 0 14px; padding: 7px 10px; border: 1px solid var(--line); color: var(--green); background: white; font-size: 12px; font-weight: 700; }
.cost-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 9px; }
.cost-grid article { min-width: 0; min-height: 132px; padding: 17px; border-top: 3px solid var(--deep); background: white; box-shadow: var(--shadow); }
.cost-grid article.accent { border-top-color: var(--amber); background: #fff8e9; }
.cost-grid span, .cost-grid small { display: block; color: var(--muted); font-size: 11px; }
.cost-grid strong { display: block; margin: 15px 0 7px; overflow-wrap: anywhere; font-size: 25px; line-height: 1; }
.cost-method-grid { display: grid; grid-template-columns: .9fr .9fr 1.2fr; gap: 9px; margin-top: 9px; }
.cost-method-grid article { min-width: 0; padding: 15px 16px; border: 1px solid var(--line); background: rgba(255,255,255,.72); }
.cost-method-grid span { display: block; color: var(--green); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.cost-method-grid p { margin: 8px 0 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
.cost-group-list { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 7px; margin-top: 10px; }
.cost-group-list div { min-width: 0; padding: 9px; background: white; border-left: 3px solid var(--deep); }
.cost-group-list div:nth-child(2) { border-left-color: var(--green); }
.cost-group-list div:nth-child(3) { border-left-color: var(--amber); }
.cost-group-list strong { display: block; margin-top: 4px; overflow-wrap: anywhere; color: var(--ink); font-size: 16px; }
.cost-group-list small { display: block; margin-top: 2px; color: var(--muted); font-size: 10px; }
.cost-trace-card { grid-column: 1 / -1; border-left: 4px solid var(--green) !important; background: white !important; }
.cost-trace-list { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 8px; margin-top: 12px; }
.cost-trace-list div { min-width: 0; padding: 11px; background: #f4faf7; border: 1px solid #d9ebe4; }
.cost-trace-list span { color: var(--green); }
.cost-trace-list strong { display: block; margin-top: 5px; color: var(--ink); font-size: 12px; line-height: 1.35; overflow-wrap: anywhere; }
.cost-component-list { display: grid; gap: 6px; margin-top: 10px; }
.cost-component-list div { display: flex; justify-content: space-between; gap: 10px; padding: 7px 8px; background: white; font-size: 11px; }
.cost-component-list span { color: var(--muted); }
.cost-component-list strong { color: var(--ink); }
.cost-tech-panel { margin-top: 10px; padding: 18px; border: 1px solid var(--line); background: white; }
.cost-tech-bars { display: grid; gap: 12px; margin-top: 18px; }
.cost-tech-row { display: grid; grid-template-columns: 220px minmax(0,1fr) 130px; gap: 14px; align-items: center; font-size: 12px; }
.cost-tech-row strong, .cost-tech-row span { display: block; }
.cost-tech-row span { margin-top: 3px; color: var(--muted); font-size: 11px; }
.cost-tech-row > div:last-child { text-align: right; }
.cost-bar-track { height: 9px; overflow: hidden; background: #e7eeec; }
.cost-bar-fill { height: 100%; background: var(--coral); }
.cost-bar-fill.renewable { background: var(--green); }
.cost-bar-fill.storage { background: var(--amber); }
.evolution-section { padding: 20px 0 76px; }
.evolution-kpis { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 9px; }
.evolution-kpis article { min-width: 0; min-height: 122px; padding: 16px; border-top: 3px solid var(--green); background: white; box-shadow: var(--shadow); }
.evolution-kpis article:nth-child(2), .evolution-kpis article:nth-child(3) { border-top-color: var(--amber); }
.evolution-kpis span, .evolution-kpis small { display: block; color: var(--muted); font-size: 11px; }
.evolution-kpis strong { display: block; margin: 14px 0 7px; overflow-wrap: anywhere; font-size: 24px; line-height: 1; }
.evolution-panel { margin-top: 10px; padding: 18px; border: 1px solid var(--line); background: white; box-shadow: var(--shadow); }
#monthlyEvolutionChart { position: relative; min-height: 310px; margin-top: 12px; }
#monthlyEvolutionChart svg { display: block; width: 100%; height: 310px; overflow: visible; }
#monthlyEvolutionChart text { fill: #6c8081; font-size: 10px; }
.evolution-demand-bar { fill: rgba(25,138,98,.18); }
.evolution-cost-dot { fill: var(--deep); }
.evolution-gap-dot { fill: var(--amber); }
.evolution-demand-dot { fill: var(--green); }
.evolution-table { margin-top: 10px; overflow-x: auto; border: 1px solid var(--line); background: white; }
.evolution-row { display: grid; grid-template-columns: 1.2fr repeat(5,1fr); min-width: 860px; width: 100%; padding: 11px 12px; border: 0; border-top: 1px solid var(--line); color: var(--ink); background: white; cursor: pointer; font-size: 12px; text-align: left; }
.evolution-row:not(.evolution-head):hover, .evolution-row.active { background: #f2f8f5; }
.evolution-row.active { box-shadow: inset 4px 0 0 var(--green); }
.evolution-head { border-top: 0; color: var(--muted); cursor: default; font-size: 10px; font-weight: 700; text-transform: uppercase; }
.comparison-section { padding: 18px 0 78px; }
.comparison-kpis { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 9px; }
.comparison-kpis article { min-width: 0; min-height: 118px; padding: 16px; border-top: 3px solid var(--deep); background: white; box-shadow: var(--shadow); }
.comparison-kpis article:first-child { border-top-color: var(--amber); background: #fff8e9; }
.comparison-kpis span, .comparison-kpis small { display: block; color: var(--muted); font-size: 11px; }
.comparison-kpis strong { display: block; margin: 14px 0 7px; overflow-wrap: anywhere; font-size: 24px; line-height: 1; }
.comparison-panel { margin-top: 10px; padding: 18px; border: 1px solid var(--line); background: white; box-shadow: var(--shadow); }
.comparison-bars { display: grid; gap: 8px; margin-top: 16px; }
.comparison-row { display: grid; grid-template-columns: 34px 170px minmax(0,1fr) 110px 140px; gap: 12px; align-items: center; width: 100%; padding: 10px; border: 1px solid var(--line); color: var(--ink); background: white; cursor: pointer; font-size: 12px; text-align: left; }
.comparison-row:hover, .comparison-row.active { border-color: rgba(25,138,98,.45); background: #f2f8f5; }
.comparison-row.active { box-shadow: inset 4px 0 0 var(--green); }
.comparison-rank { display: grid; place-items: center; width: 26px; height: 26px; color: white; background: var(--deep); font-size: 11px; font-weight: 700; }
.comparison-row strong { overflow-wrap: anywhere; }
.comparison-row small { color: var(--muted); text-align: right; }
.comparison-track { height: 9px; overflow: hidden; background: #e7eeec; }
.comparison-fill { height: 100%; background: var(--green); }
.diagnosis-section { padding: 18px 0 76px; }
.diagnosis-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; }
.diagnosis-grid article { min-width: 0; min-height: 188px; padding: 18px; border-top: 3px solid var(--deep); background: white; box-shadow: var(--shadow); }
.diagnosis-grid article.good { border-top-color: var(--green); background: #f4fbf7; }
.diagnosis-grid article.warn { border-top-color: var(--amber); background: #fff8e9; }
.diagnosis-grid article.stable { border-top-color: var(--deep); }
.diagnosis-grid span { display: block; color: var(--green); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.diagnosis-grid strong { display: block; margin-top: 12px; font-size: 22px; line-height: 1.05; }
.diagnosis-grid em { display: block; margin-top: 10px; color: var(--deep); font-size: 24px; font-style: normal; font-weight: 700; line-height: 1; }
.diagnosis-grid p { margin: 12px 0 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
.intro-copy { max-width: 760px; color: #536d70; font-size: 16px; line-height: 1.75; }
.section-heading { display: flex; justify-content: space-between; align-items: end; gap: 30px; margin-bottom: 22px; }
.section-copy { max-width: 590px; color: var(--muted); line-height: 1.6; font-size: 14px; }
.period-chip { display: inline-flex; align-items: center; min-height: 27px; margin-top: 10px; padding: 5px 8px; border: 1px solid var(--line); color: var(--green); background: rgba(255,255,255,.55); font-size: 11px; font-weight: 700; text-transform: uppercase; }
.period-chip.amber { color: #a36e16; border-color: rgba(215,155,53,.4); background: rgba(255,250,240,.78); }
.select-label { display: grid; gap: 7px; color: var(--muted); font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
select { min-width: 240px; padding: 11px 12px; border: 1px solid var(--line); border-radius: 4px; color: var(--ink); background: white; font-size: 13px; font-weight: 700; }
.explorer { padding: 20px 0 80px; }
.map-layout { display: grid; grid-template-columns: minmax(0,1fr) 310px; gap: 16px; }
.map-panel { position: relative; min-height: 440px; overflow: hidden; border: 1px solid #b7d0cc; background: #dcebe8; }
.map-ocean { position: absolute; inset: 0; opacity: .6; background: linear-gradient(145deg, transparent 0 45%, rgba(255,255,255,.55) 45.3% 46%, transparent 46.3%), linear-gradient(15deg, rgba(255,255,255,.33), transparent); }
.island-node { position: absolute; border: 0; color: var(--deep); background: transparent; cursor: pointer; font-size: 12px; font-weight: 700; text-align: left; }
.island-node i { display: block; width: 20px; height: 9px; margin-bottom: 5px; border-radius: 50%; background: var(--deep-2); box-shadow: 0 4px 0 rgba(6,42,52,.15); transform: rotate(-12deg); transition: .2s ease; }
.island-node:hover i, .island-node.active i { background: var(--amber); transform: scale(1.22) rotate(-12deg); }
.island-node span { display: block; }
.island-node.canarias { top: 19px; left: 18px; padding: 9px 11px; color: white; background: var(--deep); }
.island-node.canarias strong, .oriental-system strong { display: block; margin-top: 2px; color: var(--mint); font-size: 10px; }
.hierro { left: 7%; top: 66%; }.palma { left: 18%; top: 39%; }.gomera { left: 31%; top: 61%; }.tenerife { left: 40%; top: 39%; }.grancanaria { left: 59%; top: 59%; }.lanzarote { left: 85%; top: 24%; }.fuerteventura { left: 77%; top: 49%; }
.oriental-system { right: 17px; bottom: 17px; padding: 8px 10px; color: white; background: var(--deep); text-align: right; }
.map-note { position: absolute; left: 18px; bottom: 16px; color: #55797b; font-size: 11px; }
.system-summary { padding: 23px; color: white; background: var(--deep); }
.system-summary h3 { margin-bottom: 5px; font-size: 31px; }
.summary-period { display: inline-flex; margin: 0 0 9px; padding: 5px 8px; border: 1px solid rgba(255,255,255,.18); color: var(--mint); font-size: 11px; font-weight: 700; text-transform: uppercase; }
.system-summary p { min-height: 45px; color: #bfd3d2; font-size: 12px; line-height: 1.55; }
.system-summary .shared-oriental-note { min-height: auto; margin: 5px 0 13px; padding: 9px 10px; border-left: 3px solid var(--amber); color: #fff2cd; background: rgba(221,167,57,.13); }
.summary-stat { padding: 15px 0; border-top: 1px solid rgba(255,255,255,.16); }
.summary-stat span { display: block; color: #bcd1d0; font-size: 11px; }
.summary-stat strong { display: block; margin-top: 5px; font-size: 22px; }
.summary-stat.emphasis strong { color: #ffd17e; }
.summary-stat.solar strong { color: #ffd17e; }
.system-page-link { display: inline-flex; justify-content: center; width: 100%; margin-top: 12px; padding: 10px 12px; border: 1px solid rgba(255,255,255,.28); color: white; text-decoration: none; font-size: 12px; font-weight: 700; }
.system-page-link:hover { color: var(--deep); background: var(--mint); border-color: var(--mint); }
.ranking-panel { margin-top: 16px; padding: 18px; border: 1px solid var(--line); background: white; }
.ranking-table { margin-top: 16px; overflow-x: auto; }
.ranking-row { display: grid; grid-template-columns: 1.35fr repeat(5,1fr); min-width: 810px; width: 100%; padding: 11px 8px; border: 0; border-top: 1px solid var(--line); color: var(--ink); background: white; cursor: pointer; font-size: 12px; text-align: left; }
.ranking-row:not(.ranking-head):hover { background: #f2f8f5; }
.ranking-head { border-top: 0; color: var(--muted); cursor: default; font-size: 10px; font-weight: 700; text-transform: uppercase; }
.estimated-cell { color: #a36e16; }
.oriental-views { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-top: 15px; padding-top: 13px; border-top: 1px solid var(--line); color: var(--muted); font-size: 11px; }
.oriental-views button { padding: 7px 9px; border: 1px solid var(--line); color: var(--deep); background: #f6faf8; cursor: pointer; font-size: 11px; font-weight: 700; }
.oriental-views button:hover { border-color: var(--green); color: var(--green); }
.oriental-views small { flex: 1 1 360px; }
.self-section { padding: 72px 0; background: #f3ecdc; }
.eyebrow.sun { color: #a36e16; }
.self-layout { display: grid; grid-template-columns: 270px minmax(0,1fr); gap: 14px; }
.self-kpis { display: grid; gap: 9px; }
.profile-panel { padding: 17px; background: white; }
.estimated-label { color: #a36e16; font-size: 11px; font-weight: 700; text-transform: uppercase; }
.chart-context { margin: 6px 0 0; color: var(--muted); font-size: 12px; font-weight: 700; }
#selfChart { position: relative; min-height: 250px; }
#selfChart svg { display: block; width: 100%; height: 250px; }
#selfChart text, #dailyChart text { fill: #6c8081; font-size: 10px; }
.grid-line { stroke: #dce6e3; stroke-width: 1; }
.axis-label { fill: #7c8e8e; font-size: 9px; }
.axis-right { fill: #a36e16; }
.chart-guide { display: none; stroke: #8ca09e; stroke-dasharray: 4 4; stroke-width: 1; }
.chart-dot { display: none; stroke: white; stroke-width: 2; }
.self-dot, .daily-self-dot { fill: var(--amber); }
.demand-dot { fill: var(--deep); }
.generation-dot { fill: var(--green); }
.chart-hover .chart-guide, .chart-hover .chart-dot { display: block; }
.chart-tooltip { position: absolute; z-index: 3; display: none; width: 188px; padding: 10px; color: white; background: rgba(6,42,52,.96); box-shadow: 0 8px 22px rgba(6,42,52,.18); pointer-events: none; font-size: 11px; line-height: 1.45; }
.chart-hover .chart-tooltip { display: grid; gap: 4px; }
.chart-tooltip strong { color: var(--mint); font-size: 12px; }
.chart-tooltip span { display: flex; align-items: center; gap: 5px; }
.chart-tooltip b { margin-left: auto; color: white; }
.chart-tooltip i { width: 7px; height: 7px; border-radius: 50%; }
.demand-key { background: var(--deep-2); border: 1px solid white; }
.generation-key { background: var(--green); }
.amber-key { background: var(--amber); }
.coral-key { background: var(--coral); }
.simulator { color: white; background: var(--deep); }
.simulator-inner { padding: 72px 0 76px; }
.simulator h2 { max-width: 850px; }
.simulator .section-copy { color: #bcd0d0; }
.model-tag { align-self: start; padding: 8px 10px; border: 1px solid rgba(255,255,255,.27); color: #c8dddc; font-size: 11px; font-weight: 700; }
.sim-grid { display: grid; grid-template-columns: 290px minmax(0,1fr); gap: 18px; }
.sim-system-label { display: inline-flex; align-items: center; min-height: 34px; margin: 0 0 14px; padding: 8px 11px; border: 1px solid rgba(255,255,255,.24); color: var(--mint); font-size: 12px; font-weight: 700; }
.controls { padding: 18px; background: rgba(255,255,255,.07); }
.control-block { display: block; padding: 16px 0; border-bottom: 1px solid rgba(255,255,255,.15); }
.control-label { color: #c5d9d8; font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.control-line { display: flex; justify-content: space-between; gap: 10px; }
.segments { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 4px; margin-top: 10px; }
.segments button { min-height: 36px; border: 1px solid rgba(255,255,255,.22); color: #c8dada; background: transparent; cursor: pointer; font-size: 10px; font-weight: 700; }
.segments button.active, .segments button:hover { color: var(--deep); background: var(--mint); border-color: var(--mint); }
input[type=range] { width: 100%; margin-top: 16px; accent-color: var(--mint); }
.method-note { padding-top: 17px; color: #bcd0d0; font-size: 12px; line-height: 1.55; }
.method-note strong { color: white; }
.result-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 9px; }
.result-grid article { min-width: 0; min-height: 132px; padding: 16px; color: var(--ink); background: white; border-top: 3px solid var(--mint); }
.result-grid article.accent { border-top-color: var(--amber); background: #fff8e9; }
.result-grid span, .result-grid small { display: block; color: var(--muted); font-size: 11px; }
.result-grid strong { display: block; margin: 16px 0 7px; overflow-wrap: anywhere; font-size: 25px; line-height: 1; }
.tech-panel { margin-top: 9px; padding: 17px; color: var(--ink); background: white; }
.panel-heading { display: flex; justify-content: space-between; gap: 18px; align-items: start; }
.panel-heading span { color: var(--green); font-weight: 700; }
.tech-bars { display: grid; gap: 12px; margin-top: 17px; }
.tech-row { display: grid; grid-template-columns: 145px minmax(0,1fr) 105px; gap: 12px; align-items: center; font-size: 12px; }
.bar-track { height: 8px; overflow: hidden; background: #e9efed; }
.bar-fill { height: 100%; background: var(--green); }
.tech-row strong { text-align: right; }
.charts { padding: 76px 0; }
.chart-panel { padding: 18px; border: 1px solid var(--line); background: white; box-shadow: var(--shadow); }
.chart-panel-meta { display: flex; justify-content: space-between; gap: 16px; margin: 0 0 8px; color: var(--muted); font-size: 12px; font-weight: 700; }
.chart-panel-meta strong { color: var(--green); font-size: 11px; text-transform: uppercase; }
#dailyChart { position: relative; min-height: 300px; }
#dailyChart svg { display: block; width: 100%; height: 300px; overflow: visible; }
.sources { padding: 38px 0 84px; }
.method-flow { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 10px; margin-top: 20px; }
.method-flow article { min-width: 0; min-height: 178px; padding: 18px; border-top: 3px solid var(--green); background: white; box-shadow: var(--shadow); }
.method-flow article:nth-child(2) { border-top-color: var(--deep); }
.method-flow article:nth-child(3) { border-top-color: var(--amber); }
.method-flow article:nth-child(4) { border-top-color: var(--coral); }
.method-flow span { color: var(--amber); font-family: "Fraunces"; font-size: 30px; }
.method-flow strong { display: block; margin: 11px 0 7px; font-size: 18px; }
.method-flow p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
.method-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 10px; margin-top: 10px; }
.method-card { min-width: 0; padding: 16px; border: 1px solid var(--line); background: rgba(255,255,255,.78); }
.method-card.strong { border-left: 4px solid var(--green); background: #f4faf7; }
.method-card span, .assumption-panel .panel-heading span { display: block; color: var(--green); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.method-card strong { display: block; margin-top: 9px; color: var(--ink); font-size: 19px; line-height: 1.05; overflow-wrap: anywhere; }
.method-card p { margin: 9px 0 0; color: var(--muted); font-size: 12px; line-height: 1.45; overflow-wrap: anywhere; }
.assumption-panel { margin-top: 10px; padding: 18px; border: 1px solid var(--line); background: white; }
.assumption-table { display: grid; gap: 7px; margin-top: 15px; }
.assumption-row { display: grid; grid-template-columns: minmax(170px,1fr) 120px 110px 120px; gap: 10px; align-items: center; padding: 10px 12px; background: #f8fbfa; font-size: 12px; }
.assumption-row span, .assumption-row strong, .assumption-row em, .assumption-row small { min-width: 0; overflow-wrap: anywhere; }
.assumption-row strong { color: var(--ink); text-align: right; }
.assumption-row em { color: var(--green); font-style: normal; font-weight: 700; }
.assumption-row small { color: var(--muted); text-align: right; }
.method-limits { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; margin-top: 10px; }
.method-limits article { padding: 15px 16px; border-left: 3px solid var(--deep); background: #f4faf7; }
.method-limits article:nth-child(2) { border-left-color: var(--amber); background: #fff8e9; }
.method-limits article:nth-child(3) { border-left-color: var(--green); }
.method-limits strong { display: block; margin-bottom: 6px; }
.method-limits p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
.method-page .site-header { position: sticky; top: 0; z-index: 5; }
.method-hero { padding: 78px 0 58px; color: white; background: var(--deep); }
.method-hero-grid { display: grid; grid-template-columns: minmax(0,1fr) 330px; gap: 34px; align-items: end; }
.method-hero h1 { max-width: 940px; font-size: clamp(46px, 6vw, 82px); }
.method-hero .section-copy { max-width: 760px; color: #c8dddc; }
.method-status-card { min-width: 0; padding: 22px; border-top: 3px solid var(--mint); background: rgba(255,255,255,.08); }
.method-status-card span { display: block; color: var(--mint); font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.method-status-card strong { display: block; margin: 12px 0 10px; overflow-wrap: anywhere; font-size: 25px; line-height: 1.05; }
.method-status-card p { margin: 0; color: #c8dddc; font-size: 13px; line-height: 1.55; }
.method-jump { position: sticky; top: 64px; z-index: 4; display: flex; gap: 8px; overflow-x: auto; margin-top: -18px; padding: 10px; border: 1px solid var(--line); background: rgba(244,247,243,.97); box-shadow: 0 10px 24px rgba(18,61,67,.08); }
.method-jump a { flex: 0 0 auto; padding: 8px 10px; border: 1px solid var(--line); color: var(--deep); background: white; font-size: 10px; font-weight: 700; text-decoration: none; text-transform: uppercase; }
.method-jump a:hover { color: white; background: var(--deep); border-color: var(--deep); }
.method-section { padding: 62px 0 0; }
.method-source-grid, .method-process, .formula-grid, .method-kpis, .method-explain-grid { display: grid; gap: 10px; }
.method-source-grid { grid-template-columns: repeat(4,minmax(0,1fr)); }
.method-process, .formula-grid { grid-template-columns: repeat(4,minmax(0,1fr)); }
.method-kpis, .method-explain-grid { grid-template-columns: repeat(4,minmax(0,1fr)); }
.method-explain-grid { grid-template-columns: repeat(3,minmax(0,1fr)); }
.method-source-grid article, .method-process article, .formula-grid article, .method-kpis article, .method-explain-grid article { min-width: 0; padding: 17px; border-top: 3px solid var(--green); background: white; box-shadow: var(--shadow); }
.method-source-grid article:nth-child(2), .method-process article:nth-child(2), .formula-grid article:nth-child(2), .method-kpis article:nth-child(2) { border-top-color: var(--deep); }
.method-source-grid article:nth-child(3), .method-process article:nth-child(3), .formula-grid article:nth-child(3), .method-kpis article:nth-child(3) { border-top-color: var(--amber); background: #fff8e9; }
.method-source-grid article:nth-child(4), .method-process article:nth-child(4), .formula-grid article:nth-child(4), .method-kpis article:nth-child(4) { border-top-color: var(--coral); background: #fff7f4; }
.method-source-grid span, .method-kpis span, .method-process span, .formula-grid span { display: block; color: var(--green); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.method-process span { color: var(--amber); font-family: "Fraunces", Georgia, serif; font-size: 30px; letter-spacing: 0; }
.method-source-grid strong, .method-process strong, .method-kpis strong, .method-explain-grid strong { display: block; margin: 10px 0 8px; overflow-wrap: anywhere; font-size: 20px; line-height: 1.08; }
.method-source-grid p, .method-process p, .formula-grid p, .method-kpis small, .method-explain-grid p { display: block; margin: 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
.formula-grid code { display: block; min-height: 58px; margin: 10px 0; padding: 11px; color: var(--deep); background: #f4faf7; border-left: 3px solid var(--green); font-size: 12px; line-height: 1.45; white-space: normal; }
.method-cost-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 12px; }
.method-panel { margin-top: 12px; padding: 18px; border: 1px solid var(--line); background: white; box-shadow: var(--shadow); }
.method-component-bars, .method-assumption-cards { display: grid; gap: 9px; margin-top: 14px; }
.method-component-row { display: grid; grid-template-columns: 185px minmax(0,1fr) 115px; gap: 12px; align-items: center; font-size: 12px; }
.method-component-row span, .method-component-row strong { overflow-wrap: anywhere; font-weight: 700; }
.method-component-row small { display: block; margin-top: 3px; color: var(--muted); font-size: 10px; font-weight: 500; }
.method-component-row div { height: 10px; overflow: hidden; background: #e7eeec; }
.method-component-row i { display: block; height: 100%; background: var(--deep); }
.method-component-row .fuel { background: var(--coral); }
.method-component-row .co2 { background: #8d5d50; }
.method-component-row .om { background: var(--green); }
.method-component-row .fixed { background: var(--amber); }
.method-assumption-cards { grid-template-columns: repeat(2,minmax(0,1fr)); }
.method-assumption-cards article { min-width: 0; padding: 13px; border-left: 3px solid var(--green); background: #f8fbfa; }
.method-assumption-cards article:nth-child(2), .method-assumption-cards article:nth-child(5) { border-left-color: var(--amber); background: #fff8e9; }
.method-assumption-cards span { color: var(--green); font-size: 10px; font-weight: 700; text-transform: uppercase; }
.method-assumption-cards strong { display: block; margin-top: 7px; overflow-wrap: anywhere; font-size: 18px; }
.method-assumption-cards p { margin: 6px 0 0; color: var(--muted); font-size: 11px; line-height: 1.45; }
.method-tech-table { margin-top: 14px; overflow-x: auto; border: 1px solid var(--line); }
.method-tech-row { display: grid; grid-template-columns: 1.35fr .8fr repeat(4,1fr); min-width: 920px; padding: 10px 12px; border-top: 1px solid var(--line); font-size: 12px; }
.method-tech-row:first-child { border-top: 0; }
.method-tech-head { color: var(--muted); background: #f6faf8; font-size: 10px; font-weight: 700; text-transform: uppercase; }
.method-tech-row strong, .method-tech-row span { overflow-wrap: anywhere; }
.method-tech-summary { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; min-width: 920px; padding: 10px; border-top: 1px solid var(--line); background: #f8fbfa; }
.method-tech-summary article { min-width: 0; padding: 11px; border-left: 3px solid var(--green); background: white; }
.method-tech-summary span { display: block; color: var(--muted); font-size: 10px; text-transform: uppercase; }
.method-tech-summary strong { display: block; margin-top: 5px; overflow-wrap: anywhere; font-size: 17px; }
.method-limits.large { margin-top: 0; }
.site-section-page .site-header { position: sticky; top: 0; z-index: 5; }
.section-hero { padding: 78px 0 58px; color: white; background: var(--deep); }
.section-hero-grid { display: grid; grid-template-columns: minmax(0,1fr) 330px; gap: 34px; align-items: end; }
.section-hero h1 { max-width: 880px; font-size: clamp(46px, 6vw, 82px); }
.section-hero .section-copy { max-width: 720px; color: #c8dddc; }
.section-hero-card { min-width: 0; padding: 22px; border-top: 3px solid var(--mint); background: rgba(255,255,255,.08); }
.section-hero-card span { display: block; color: var(--mint); font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.section-hero-card strong { display: block; margin: 12px 0 10px; overflow-wrap: anywhere; font-size: 29px; line-height: 1; }
.section-hero-card p { margin: 0; color: #c8dddc; font-size: 13px; line-height: 1.55; }
.site-directory-section { padding: 62px 0 0; }
.systems-directory-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; }
.system-directory-card { min-width: 0; padding: 18px; border-top: 3px solid var(--green); color: var(--ink); background: white; text-decoration: none; box-shadow: var(--shadow); }
.system-directory-card:nth-child(3n+2) { border-top-color: var(--amber); background: #fff8e9; }
.system-directory-card:nth-child(3n) { border-top-color: var(--deep); background: #f8fbfa; }
.system-directory-card:hover { transform: translateY(-2px); transition: transform .16s ease; }
.system-directory-card span { display: block; color: var(--green); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.system-directory-card strong { display: block; margin: 9px 0 8px; overflow-wrap: anywhere; font-size: 25px; line-height: 1; }
.system-directory-card p { min-height: 44px; margin: 0 0 13px; color: var(--muted); font-size: 12px; line-height: 1.48; }
.system-directory-card div { display: grid; grid-template-columns: 86px 1fr; gap: 8px; padding: 8px 0; border-top: 1px solid var(--line); font-size: 12px; }
.system-directory-card small { color: var(--muted); }
.system-directory-card b { text-align: right; overflow-wrap: anywhere; }
.systems-index-ranking { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; }
.systems-index-ranking article { min-width: 0; padding: 17px; border: 1px solid var(--line); background: white; box-shadow: var(--shadow); }
.systems-index-ranking article > span { display: block; color: var(--green); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.systems-index-ranking a { display: grid; grid-template-columns: 28px minmax(0,1fr) 110px; gap: 9px; align-items: center; margin-top: 10px; padding: 9px; color: var(--ink); background: #f8fbfa; text-decoration: none; font-size: 12px; }
.systems-index-ranking a:hover { background: #f2f8f5; }
.systems-index-ranking b { display: grid; place-items: center; width: 24px; height: 24px; color: white; background: var(--deep); }
.systems-index-ranking strong { overflow-wrap: anywhere; }
.systems-index-ranking small { color: var(--muted); text-align: right; }
.reports-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
.report-card { min-width: 0; padding: 20px; border-top: 3px solid var(--green); background: white; box-shadow: var(--shadow); }
.report-card:nth-child(2n) { border-top-color: var(--amber); background: #fff8e9; }
.report-card > span { display: block; color: var(--green); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.report-card > strong { display: block; margin: 10px 0 14px; font-size: 28px; line-height: 1; }
.report-card-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 8px; }
.report-card-grid div { min-width: 0; padding: 10px; background: rgba(255,255,255,.72); border: 1px solid var(--line); }
.report-card-grid small { display: block; color: var(--muted); font-size: 10px; }
.report-card-grid b { display: block; margin-top: 5px; overflow-wrap: anywhere; font-size: 14px; }
.report-card p { margin: 14px 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
.report-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.report-actions a { padding: 8px 10px; border: 1px solid var(--line); color: var(--deep); background: white; font-size: 11px; font-weight: 700; text-decoration: none; }
.report-actions a:hover { color: white; background: var(--deep); border-color: var(--deep); }
.report-publishing-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 10px; }
.report-publishing-grid article { min-width: 0; padding: 17px; border-top: 3px solid var(--green); background: white; box-shadow: var(--shadow); }
.report-publishing-grid article:nth-child(2) { border-top-color: var(--deep); }
.report-publishing-grid article:nth-child(3) { border-top-color: var(--amber); background: #fff8e9; }
.report-publishing-grid article:nth-child(4) { border-top-color: var(--coral); background: #fff7f4; }
.report-publishing-grid span { color: var(--amber); font-family: "Fraunces", Georgia, serif; font-size: 30px; }
.report-publishing-grid strong { display: block; margin: 10px 0 7px; font-size: 18px; }
.report-publishing-grid p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
footer { display: flex; justify-content: space-between; gap: 15px; padding: 18px 28px; color: #bad0cf; background: var(--deep); font-size: 12px; }
.official-view .estimated, .official-view .self-section, .official-view .summary-stat.solar, .official-view .estimated-cell { display: none; }
.system-page .site-header { position: sticky; top: 0; z-index: 4; }
.system-hero { padding: 64px 0 34px; color: white; background: var(--deep); }
.system-hero-grid { display: grid; grid-template-columns: minmax(0,1fr) 300px; gap: 26px; align-items: end; }
.system-hero h1 { max-width: 900px; font-size: clamp(48px, 6vw, 86px); }
.system-hero p { max-width: 700px; color: #c8dddc; line-height: 1.6; }
.system-controls { display: grid; gap: 12px; padding: 18px; background: rgba(255,255,255,.08); }
.system-nav-band { padding: 14px 0; background: #edf4f1; border-bottom: 1px solid var(--line); }
.system-nav { display: flex; flex-wrap: wrap; gap: 8px; }
.system-nav a { padding: 8px 10px; border: 1px solid var(--line); color: var(--deep); background: white; text-decoration: none; font-size: 11px; font-weight: 700; }
.system-nav a.active, .system-nav a:hover { color: white; background: var(--deep); border-color: var(--deep); }
.system-detail { padding: 46px 0 70px; }
.system-jump-nav { position: sticky; top: 64px; z-index: 3; display: flex; gap: 7px; overflow-x: auto; margin: -22px 0 18px; padding: 10px; border: 1px solid var(--line); background: rgba(244,247,243,.96); box-shadow: 0 10px 24px rgba(18,61,67,.08); scrollbar-width: thin; }
.system-jump-nav a { flex: 0 0 auto; padding: 8px 10px; border: 1px solid transparent; color: var(--muted); background: white; font-size: 10px; font-weight: 700; text-decoration: none; text-transform: uppercase; }
.system-jump-nav a:hover, .system-jump-nav a.active { color: white; background: var(--deep); border-color: var(--deep); }
.system-kpis { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 9px; }
.system-kpis article, .system-cost-card { min-width: 0; padding: 17px; border-top: 3px solid var(--green); background: white; box-shadow: var(--shadow); }
.system-kpis article:nth-child(4), .system-cost-card.accent { border-top-color: var(--amber); background: #fff8e9; }
.system-kpis span, .system-kpis small, .system-cost-card span, .system-cost-card small { display: block; color: var(--muted); font-size: 11px; }
.system-kpis strong, .system-cost-card strong { display: block; margin: 12px 0 7px; font-size: 25px; line-height: 1; overflow-wrap: anywhere; }
.system-portrait-panel { margin-top: 12px; }
.system-portrait-grid { display: grid; grid-template-columns: repeat(6,minmax(0,1fr)); gap: 8px; margin-top: 15px; }
.system-portrait-grid article { min-width: 0; min-height: 116px; padding: 14px; border-top: 3px solid var(--deep); background: #f8fbfa; }
.system-portrait-grid article:nth-child(2), .system-portrait-grid article:nth-child(5) { border-top-color: var(--green); background: #f4fbf7; }
.system-portrait-grid article:nth-child(3), .system-portrait-grid article:nth-child(6) { border-top-color: var(--amber); background: #fff8e9; }
.system-portrait-grid article:nth-child(4) { border-top-color: var(--coral); background: #fff7f4; }
.system-portrait-grid span, .system-portrait-grid small { display: block; color: var(--muted); font-size: 11px; }
.system-portrait-grid strong { display: block; margin: 12px 0 7px; overflow-wrap: anywhere; font-size: 22px; line-height: 1; }
.system-radiography-panel { margin-top: 12px; }
.radiography-main { margin-top: 14px; padding: 19px 20px; color: white; background: var(--deep); }
.radiography-main span { display: block; color: var(--mint); font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.radiography-main strong { display: block; margin-top: 10px; max-width: 980px; font-size: 23px; line-height: 1.22; overflow-wrap: anywhere; }
.radiography-main p { margin: 12px 0 0; max-width: 860px; color: #c9dddd; font-size: 13px; line-height: 1.55; }
.radiography-grid { display: grid; grid-template-columns: repeat(6,minmax(0,1fr)); gap: 8px; margin-top: 10px; }
.radiography-grid article { min-width: 0; min-height: 190px; padding: 15px; border-top: 3px solid var(--deep); background: white; }
.radiography-grid article.good { border-top-color: var(--green); background: #f4fbf7; }
.radiography-grid article.warn { border-top-color: var(--amber); background: #fff8e9; }
.radiography-grid article.opportunity { border-top-color: var(--coral); background: #fff6f3; }
.radiography-grid article.stable { border-top-color: var(--deep); background: #f8fbfa; }
.radiography-grid span { display: block; color: var(--green); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.radiography-grid strong { display: block; margin-top: 11px; overflow-wrap: anywhere; font-size: 21px; line-height: 1.02; }
.radiography-grid em { display: block; min-height: 32px; margin-top: 9px; color: var(--deep); font-size: 12px; font-style: normal; font-weight: 700; line-height: 1.25; }
.radiography-grid p { margin: 9px 0 0; color: var(--muted); font-size: 12px; line-height: 1.45; }
.system-deep-dive-panel { margin-top: 12px; }
.deep-dive-layout { display: grid; grid-template-columns: 1.05fr .95fr; gap: 10px; margin-top: 15px; }
.deep-dive-story { min-width: 0; padding: 20px; color: white; background: var(--deep); }
.deep-dive-story span { display: block; color: var(--mint); font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.deep-dive-story strong { display: block; margin-top: 10px; max-width: 780px; font-size: 24px; line-height: 1.18; overflow-wrap: anywhere; }
.deep-dive-story p { margin: 13px 0 0; color: #c9dddd; font-size: 13px; line-height: 1.58; }
.deep-dive-scoreboard { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; }
.deep-dive-scoreboard article { min-width: 0; padding: 14px; border-top: 3px solid var(--green); background: #f4fbf7; }
.deep-dive-scoreboard article:nth-child(2) { border-top-color: var(--amber); background: #fff8e9; }
.deep-dive-scoreboard article:nth-child(3) { border-top-color: var(--coral); background: #fff7f4; }
.deep-dive-scoreboard span, .deep-dive-scoreboard small { display: block; color: var(--muted); font-size: 11px; }
.deep-dive-scoreboard strong { display: block; margin: 10px 0 6px; overflow-wrap: anywhere; font-size: 23px; line-height: 1; }
.deep-dive-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 16px; }
.cost-breakdown-bars, .critical-tech-list { display: grid; gap: 9px; margin-top: 13px; }
.cost-breakdown-row, .critical-tech-row { display: grid; grid-template-columns: 175px minmax(0,1fr) 115px; gap: 12px; align-items: center; font-size: 12px; }
.cost-breakdown-row span, .critical-tech-row span { display: block; overflow-wrap: anywhere; font-weight: 700; }
.cost-breakdown-row small, .critical-tech-row small { display: block; margin-top: 3px; color: var(--muted); font-size: 10px; font-weight: 500; }
.cost-breakdown-row strong, .critical-tech-row strong { text-align: right; }
.cost-breakdown-track, .critical-tech-track { height: 9px; overflow: hidden; background: #e7eeec; }
.cost-breakdown-fill, .critical-tech-fill { height: 100%; background: var(--deep); }
.cost-breakdown-fill.fuel { background: var(--coral); }
.cost-breakdown-fill.co2 { background: #8d5d50; }
.cost-breakdown-fill.om { background: var(--green); }
.cost-breakdown-fill.fixed { background: var(--amber); }
.critical-tech-fill.renewable { background: var(--green); }
.critical-tech-fill.storage { background: var(--amber); }
.deep-dive-table { margin-top: 16px; overflow-x: auto; border: 1px solid var(--line); background: white; }
.deep-table-row { display: grid; grid-template-columns: 1.35fr .8fr repeat(4,1fr); min-width: 920px; padding: 10px 12px; border-top: 1px solid var(--line); font-size: 12px; }
.deep-table-row:first-child { border-top: 0; }
.deep-table-head { color: var(--muted); background: #f6faf8; font-size: 10px; font-weight: 700; text-transform: uppercase; }
.deep-table-row strong, .deep-table-row span { overflow-wrap: anywhere; }
.deep-table-notes { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; min-width: 920px; padding: 10px; border-top: 1px solid var(--line); background: #f8fbfa; }
.deep-table-notes article { min-width: 0; padding: 11px; border-left: 3px solid var(--green); background: white; }
.deep-table-notes article:nth-child(2) { border-left-color: var(--amber); }
.deep-table-notes article:nth-child(3) { border-left-color: var(--deep); }
.deep-table-notes span, .deep-table-notes small { display: block; color: var(--muted); font-size: 10px; }
.deep-table-notes strong { display: block; margin: 6px 0 4px; overflow-wrap: anywhere; font-size: 15px; }
.system-balance-grid { display: grid; grid-template-columns: .95fr 1.05fr; gap: 12px; margin-top: 12px; }
.balance-flow { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 8px; margin-top: 15px; }
.balance-flow article { min-width: 0; padding: 13px; border-top: 3px solid var(--deep); background: #f8fbfa; }
.balance-flow article:nth-child(4) { border-top-color: var(--amber); background: #fff8e9; }
.balance-flow span, .mix-group-grid span { display: block; color: var(--muted); font-size: 11px; }
.balance-flow strong, .mix-group-grid strong { display: block; margin-top: 10px; overflow-wrap: anywhere; font-size: 21px; line-height: 1; }
.balance-stack { display: grid; gap: 10px; margin-top: 18px; }
.balance-stack-row { display: grid; grid-template-columns: 120px minmax(0,1fr) 62px; gap: 10px; align-items: center; font-size: 12px; }
.balance-stack-track, .mix-tech-track { height: 10px; overflow: hidden; background: #e7eeec; }
.balance-stack-fill, .mix-tech-fill { height: 100%; background: var(--coral); }
.balance-stack-fill.renewable, .mix-tech-fill.renewable { background: var(--green); }
.balance-stack-fill.storage, .mix-tech-fill.storage { background: var(--amber); }
.balance-stack-row strong { text-align: right; }
.mix-group-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; margin-top: 15px; }
.mix-group-grid article { min-width: 0; padding: 13px; border-top: 3px solid var(--deep); background: #f8fbfa; }
.mix-group-grid article:nth-child(2) { border-top-color: var(--green); }
.mix-group-grid article:nth-child(3) { border-top-color: var(--amber); }
.mix-group-grid small { display: block; margin-top: 6px; color: var(--muted); font-size: 11px; }
.mix-tech-bars { display: grid; gap: 10px; margin-top: 16px; }
.mix-tech-row { display: grid; grid-template-columns: 165px minmax(0,1fr) 112px; gap: 12px; align-items: center; font-size: 12px; }
.mix-tech-row span, .mix-tech-row small { display: block; }
.mix-tech-row small { margin-top: 2px; color: var(--muted); font-size: 10px; }
.mix-tech-row strong { text-align: right; }
.system-emissions-panel { margin-top: 12px; }
.emissions-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 8px; margin-top: 15px; }
.emissions-grid article { min-width: 0; padding: 13px; border-top: 3px solid var(--coral); background: #fff7f4; }
.emissions-grid article:nth-child(3) { border-top-color: var(--amber); background: #fff8e9; }
.emissions-grid span, .emissions-grid small { display: block; color: var(--muted); font-size: 11px; }
.emissions-grid strong { display: block; margin: 10px 0 6px; overflow-wrap: anywhere; font-size: 21px; line-height: 1; }
.emissions-chart { min-height: 250px; margin-top: 15px; }
.emissions-chart { position: relative; }
.emissions-chart svg { display: block; width: 100%; height: 250px; }
.emissions-chart text { fill: #6c8081; font-size: 10px; }
.emissions-note { margin-top: 12px; padding: 12px 14px; border-left: 3px solid var(--coral); color: var(--muted); background: #fff7f4; font-size: 12px; line-height: 1.55; }
.system-curtailment-panel { margin-top: 12px; }
.curtailment-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 8px; margin-top: 15px; }
.curtailment-grid article { min-width: 0; padding: 13px; border-top: 3px solid var(--amber); background: #fff8e9; }
.curtailment-grid article:nth-child(2), .curtailment-grid article:nth-child(3) { border-top-color: var(--deep); background: #f8fbfa; }
.curtailment-grid span, .curtailment-grid small { display: block; color: var(--muted); font-size: 11px; }
.curtailment-grid strong { display: block; margin: 10px 0 6px; overflow-wrap: anywhere; font-size: 21px; line-height: 1; }
.curtailment-layout { display: grid; grid-template-columns: 1.05fr .95fr; gap: 14px; margin-top: 16px; }
.curtailment-layout.lower { align-items: start; }
.panel-heading.compact { margin-bottom: 10px; }
.curtailment-chart { min-height: 230px; }
.curtailment-chart { position: relative; }
.curtailment-chart svg { display: block; width: 100%; height: 230px; }
.curtailment-chart text { fill: #6c8081; font-size: 10px; }
.curtailment-bar { fill: rgba(215,155,53,.55); }
.curtailment-months, .v2a-scenario-list, .v2a-tech-list, .curtailment-diagnosis { display: grid; gap: 8px; }
.curtailment-months div, .v2a-scenario-list article { padding: 10px 11px; border: 1px solid var(--line); background: white; font-size: 12px; }
.curtailment-months div { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; align-items: center; }
.curtailment-months div.active { border-color: rgba(215,155,53,.55); background: #fff8e9; box-shadow: inset 4px 0 0 var(--amber); }
.v2a-scenario-list span { display: block; color: var(--green); font-size: 10px; font-weight: 700; text-transform: uppercase; }
.v2a-scenario-list strong { display: block; margin-top: 7px; font-size: 20px; }
.v2a-scenario-list small { display: block; margin-top: 5px; color: var(--muted); line-height: 1.45; }
.v2a-tech-row { display: grid; grid-template-columns: 150px minmax(0,1fr) 105px; gap: 12px; align-items: center; font-size: 12px; }
.v2a-tech-track { height: 9px; overflow: hidden; background: #e7eeec; }
.v2a-tech-fill { height: 100%; background: var(--green); }
.v2a-tech-row strong { text-align: right; }
.curtailment-diagnosis article { padding: 13px 14px; border-left: 3px solid var(--amber); color: var(--ink); background: #fff8e9; font-size: 13px; line-height: 1.5; }
.system-two-col { display: grid; grid-template-columns: 1.05fr .95fr; gap: 12px; margin-top: 12px; }
.system-panel { padding: 18px; border: 1px solid var(--line); background: white; box-shadow: var(--shadow); }
.system-cost-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 9px; }
.system-chart { min-height: 250px; margin-top: 14px; }
.system-chart { position: relative; }
.system-chart svg { display: block; width: 100%; height: 250px; }
.system-chart text { fill: #6c8081; font-size: 10px; }
.system-cost-dot { fill: var(--deep); }
.system-gap-dot, .system-curtailment-dot { fill: var(--amber); }
.system-emissions-dot { fill: var(--coral); }
.system-evolution-rows, .system-diagnosis { display: grid; gap: 8px; margin-top: 14px; }
.system-evolution-rows div { display: grid; grid-template-columns: 1.1fr repeat(3,1fr); gap: 8px; padding: 9px 10px; border: 1px solid var(--line); font-size: 12px; }
.system-evolution-rows div.active { border-color: rgba(25,138,98,.45); background: #f2f8f5; box-shadow: inset 4px 0 0 var(--green); }
.system-tech-list { display: grid; gap: 10px; margin-top: 14px; }
.system-tech-row { display: grid; grid-template-columns: 150px minmax(0,1fr) 110px; gap: 12px; align-items: center; font-size: 12px; }
.system-tech-track { height: 9px; overflow: hidden; background: #e7eeec; }
.system-tech-fill { height: 100%; background: var(--coral); }
.system-tech-fill.renewable { background: var(--green); }
.system-tech-fill.storage { background: var(--amber); }
.system-tech-row strong { text-align: right; }
.system-diagnosis article { padding: 13px 14px; border-left: 3px solid var(--green); background: #f4fbf7; color: var(--ink); font-size: 13px; line-height: 1.5; }
.system-operation-panel { margin-top: 12px; border-color: #b9d5cf; background: #fbfdfc; }
.operation-controls { display: grid; grid-template-columns: 220px minmax(0,1fr); gap: 14px; margin-top: 16px; align-items: end; }
.operation-clock { display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap: 8px; }
.operation-clock article, .operation-kpis article { min-width: 0; padding: 12px; border-top: 3px solid var(--deep); background: white; }
.operation-clock span, .operation-kpis span, .operation-kpis small { display: block; color: var(--muted); font-size: 11px; }
.operation-clock strong { display: block; margin-top: 7px; font-size: 22px; line-height: 1; }
.operation-stepper { grid-column: 1 / -1; display: grid; grid-template-columns: 78px 86px minmax(0,1fr) 86px 78px 104px 210px; gap: 8px; align-items: center; padding: 10px 12px; border: 1px solid var(--line); background: white; }
.operation-stepper button { min-height: 36px; border: 1px solid var(--deep); color: white; background: var(--deep); cursor: pointer; font-size: 11px; font-weight: 700; }
.operation-stepper button:hover { color: var(--deep); background: var(--mint); border-color: var(--mint); }
.operation-stepper button.operation-play { background: var(--green); border-color: var(--green); }
.operation-stepper button.operation-play.active { color: var(--deep); background: var(--amber); border-color: var(--amber); }
.operation-stepper input[type=range] { margin: 0; }
.operation-speed { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 4px; }
.operation-speed button { min-height: 32px; color: var(--deep); background: white; border-color: var(--line); font-size: 10px; }
.operation-speed button.active, .operation-speed button:hover { color: var(--deep); background: var(--mint); border-color: var(--mint); }
.operation-kpis { display: grid; grid-template-columns: repeat(6,minmax(0,1fr)); gap: 8px; margin-top: 12px; }
.operation-kpis article:nth-child(3), .operation-kpis article:nth-child(4) { border-top-color: var(--green); }
.operation-kpis article:nth-child(5) { border-top-color: var(--coral); background: #fff7f4; }
.operation-kpis article:nth-child(6) { border-top-color: var(--amber); background: #fff8e9; }
.operation-kpis strong { display: block; margin: 10px 0 6px; overflow-wrap: anywhere; font-size: 21px; line-height: 1; }
.operation-visual { display: grid; grid-template-columns: minmax(0,1.25fr) minmax(320px,.75fr); gap: 18px; margin-top: 16px; }
.operation-bar-chart { display: grid; align-content: start; gap: 13px; padding: 16px; border: 1px solid var(--line); background: white; }
.operation-chart-head { display: flex; justify-content: space-between; gap: 14px; align-items: center; color: var(--muted); font-size: 11px; font-weight: 700; text-transform: uppercase; }
.operation-chart-head strong { color: var(--green); font-size: 11px; }
.operation-bars { display: grid; gap: 10px; }
.operation-chart-row { display: grid; grid-template-columns: 170px minmax(0,1fr) 92px; gap: 12px; align-items: center; font-size: 12px; }
.operation-chart-row span, .operation-chart-row small { display: block; }
.operation-chart-row small { margin-top: 2px; color: var(--muted); font-size: 10px; }
.operation-chart-track { height: 20px; overflow: hidden; background: #e7eeec; }
.operation-chart-fill { height: 100%; background: var(--coral); }
.operation-chart-fill.demand { background: var(--deep); }
.operation-chart-fill.generation { background: var(--green); }
.operation-chart-fill.self, .operation-chart-fill.storage { background: var(--amber); }
.operation-chart-fill.renewable { background: var(--green); }
.operation-chart-fill.fossil { background: var(--coral); }
.operation-chart-row strong { text-align: right; }
.operation-tech-list { display: grid; gap: 9px; padding: 16px; border: 1px solid var(--line); background: white; }
.operation-tech-row { display: grid; grid-template-columns: 150px minmax(0,1fr) 86px; gap: 10px; align-items: center; font-size: 12px; }
.operation-tech-row span, .operation-tech-row small { display: block; }
.operation-tech-row small { margin-top: 2px; color: var(--muted); font-size: 10px; }
.operation-tech-track { height: 9px; overflow: hidden; background: #e7eeec; }
.operation-tech-fill { height: 100%; background: var(--coral); }
.operation-tech-fill.renewable { background: var(--green); }
.operation-tech-fill.storage { background: var(--amber); }
.operation-tech-row strong { text-align: right; }
.operation-alerts { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 8px; margin-top: 12px; }
.operation-alerts article { min-width: 0; padding: 13px 14px; border-left: 4px solid var(--deep); background: white; font-size: 12px; line-height: 1.45; }
.operation-alerts article.good { border-left-color: var(--green); background: #f4fbf7; }
.operation-alerts article.warn, .operation-alerts article.sun { border-left-color: var(--amber); background: #fff8e9; }
.operation-alerts article.coral { border-left-color: var(--coral); background: #fff7f4; }
.operation-alerts strong, .operation-alerts span { display: block; }
.operation-alerts span { margin-top: 5px; color: var(--muted); }
.compare-hero { padding: 76px 0 52px; color: white; background: var(--deep); }
.compare-hero-grid { display: grid; grid-template-columns: minmax(0,1fr) 330px; gap: 34px; align-items: end; }
.compare-hero h1 { max-width: 880px; font-size: clamp(48px, 6vw, 86px); }
.compare-hero .section-copy { max-width: 690px; margin-top: 20px; color: #c8dddc; }
.compare-hero-note { max-width: 760px; margin: 14px 0 0; color: #b8d2d0; font-size: 12px; line-height: 1.55; }
.compare-control-card { display: grid; gap: 14px; padding: 18px; background: rgba(255,255,255,.08); }
.compare-overview { padding: 34px 0 10px; }
.compare-kpis { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 9px; }
.compare-kpis article { min-width: 0; min-height: 122px; padding: 16px; border-top: 3px solid var(--green); background: white; box-shadow: var(--shadow); }
.compare-kpis article:nth-child(2) { border-top-color: var(--amber); background: #fff8e9; }
.compare-kpis article:nth-child(4) { border-top-color: var(--coral); background: #fff7f4; }
.compare-kpis span, .compare-kpis small { display: block; color: var(--muted); font-size: 11px; }
.compare-kpis strong { display: block; margin: 13px 0 7px; overflow-wrap: anywhere; font-size: 23px; line-height: 1.05; }
.compare-jump { position: sticky; top: 64px; z-index: 4; display: flex; gap: 8px; overflow-x: auto; margin-top: 10px; padding: 10px; border: 1px solid var(--line); background: rgba(244,247,243,.97); box-shadow: 0 10px 24px rgba(18,61,67,.08); }
.compare-jump a { flex: 0 0 auto; padding: 8px 10px; border: 1px solid var(--line); color: var(--deep); background: white; font-size: 10px; font-weight: 700; text-decoration: none; text-transform: uppercase; }
.compare-jump a:hover { color: white; background: var(--deep); border-color: var(--deep); }
.compare-section { padding: 36px 0; }
.compare-insight-layout { display: grid; grid-template-columns: .95fr 1.05fr; gap: 10px; }
.compare-main-insight { min-width: 0; padding: 21px; color: white; background: var(--deep); box-shadow: var(--shadow); }
.compare-main-insight span { display: block; color: var(--mint); font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.compare-main-insight strong { display: block; margin-top: 11px; overflow-wrap: anywhere; font-size: 25px; line-height: 1.18; }
.compare-main-insight p { margin: 14px 0 0; color: #c9dddd; font-size: 13px; line-height: 1.55; }
.compare-insight-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; }
.compare-insight-grid article { min-width: 0; padding: 15px; border-top: 3px solid var(--deep); background: white; box-shadow: var(--shadow); }
.compare-insight-grid article.good { border-top-color: var(--green); background: #f4fbf7; }
.compare-insight-grid article.stable { border-top-color: var(--amber); background: #fff8e9; }
.compare-insight-grid article.warn { border-top-color: var(--coral); background: #fff7f4; }
.compare-insight-grid span, .compare-insight-grid small { display: block; color: var(--muted); font-size: 11px; }
.compare-insight-grid strong { display: block; margin: 11px 0 7px; overflow-wrap: anywhere; font-size: 22px; line-height: 1.03; }
.compare-ranking { display: grid; gap: 8px; }
.compare-rank-row { display: grid; grid-template-columns: 36px 190px minmax(0,1fr) 132px; gap: 12px; align-items: center; min-height: 48px; padding: 10px 12px; border: 1px solid var(--line); color: var(--ink); background: white; text-decoration: none; font-size: 12px; }
.compare-rank-row:hover { border-color: rgba(25,138,98,.5); background: #f4fbf7; }
.compare-rank-row.good { box-shadow: inset 4px 0 0 var(--green); }
.compare-rank-row.mid { box-shadow: inset 4px 0 0 var(--amber); }
.compare-rank-row.warn { box-shadow: inset 4px 0 0 var(--coral); }
.compare-rank-index { display: grid; place-items: center; width: 26px; height: 26px; color: white; background: var(--deep); font-weight: 700; }
.compare-rank-track { height: 10px; overflow: hidden; background: #e7eeec; }
.compare-rank-track div { height: 100%; background: var(--green); }
.compare-rank-row.mid .compare-rank-track div { background: var(--amber); }
.compare-rank-row.warn .compare-rank-track div { background: var(--coral); }
.compare-rank-row > span:last-child { text-align: right; font-weight: 700; }
.compare-rank-row > span:last-child small { display: block; margin-top: 3px; color: var(--muted); font-size: 9px; font-weight: 500; line-height: 1.25; }
.compare-matrix { overflow-x: auto; border: 1px solid var(--line); background: white; }
.matrix-row { display: grid; grid-template-columns: 190px repeat(7,130px); min-width: 1100px; border-top: 1px solid var(--line); }
.matrix-row:first-child { border-top: 0; }
.matrix-row > * { min-width: 0; padding: 11px 10px; border-left: 1px solid var(--line); font-size: 12px; }
.matrix-row > *:first-child { border-left: 0; }
.matrix-row a { color: var(--deep); font-weight: 700; text-decoration: none; }
.matrix-head { color: var(--muted); background: #f8fbfa; font-size: 10px; font-weight: 700; text-transform: uppercase; }
.matrix-row span.good { background: #f4fbf7; color: var(--green); font-weight: 700; }
.matrix-row span.mid { background: #fff8e9; color: #a36e16; font-weight: 700; }
.matrix-row span.warn { background: #fff7f4; color: #b65342; font-weight: 700; }
.matrix-row span.neutral { background: #f8fbfa; color: var(--deep); font-weight: 700; }
.compare-duel-controls { display: flex; gap: 10px; align-items: end; flex-wrap: wrap; }
.duel-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 10px; }
.duel-card { min-width: 0; padding: 15px; border: 1px solid var(--line); background: white; box-shadow: var(--shadow); }
.duel-card > span { display: block; color: var(--green); font-size: 10px; font-weight: 700; text-transform: uppercase; }
.duel-bars { display: grid; gap: 11px; margin-top: 13px; }
.duel-bars > div { display: grid; grid-template-columns: 145px minmax(0,1fr) 112px; gap: 10px; align-items: center; font-size: 12px; }
.duel-bars strong { overflow-wrap: anywhere; }
.duel-bars div div { height: 10px; overflow: hidden; background: #e7eeec; }
.duel-bars i { display: block; height: 100%; background: var(--coral); }
.duel-bars .better i { background: var(--green); }
.duel-bars em { color: var(--muted); font-style: normal; text-align: right; }
.duel-diagnosis { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; margin-top: 10px; }
.duel-diagnosis article { padding: 13px 14px; border-left: 4px solid var(--green); background: #f4fbf7; font-size: 13px; line-height: 1.5; }
.compare-evolution { display: grid; gap: 8px; }
.compare-evolution-row { display: grid; grid-template-columns: 190px minmax(0,1fr) 135px; gap: 12px; align-items: center; padding: 11px 12px; border: 1px solid var(--line); background: white; font-size: 12px; }
.compare-evolution-row a { color: var(--deep); font-weight: 700; text-decoration: none; }
.spark-bars { display: flex; align-items: end; gap: 5px; height: 46px; padding: 4px 0; }
.spark-bars span { display: block; flex: 1; min-width: 10px; background: var(--green); }
.compare-evolution-row strong { text-align: right; }
.compare-evolution-row strong small { display: block; margin-top: 3px; color: var(--muted); font-size: 10px; font-weight: 500; }
.system-hourly-panel, .system-extremes-panel { margin-top: 12px; }
.hourly-kpis { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; margin-top: 15px; }
.hourly-kpis article, .extremes-grid article { min-width: 0; padding: 13px 14px; border-top: 3px solid var(--green); background: #f4fbf7; }
.hourly-kpis article:nth-child(2), .extremes-grid article:nth-child(3), .extremes-grid article:nth-child(5) { border-top-color: var(--amber); background: #fff8e9; }
.hourly-kpis article:nth-child(3), .extremes-grid article:nth-child(4) { border-top-color: var(--coral); background: #fff7f4; }
.hourly-kpis span, .hourly-kpis small, .extremes-grid span, .extremes-grid small { display: block; color: var(--muted); font-size: 11px; }
.hourly-kpis strong, .extremes-grid strong { display: block; margin: 9px 0 6px; overflow-wrap: anywhere; font-size: 21px; line-height: 1; }
.hourly-chart { position: relative; min-height: 270px; margin-top: 15px; }
.hourly-chart svg { display: block; width: 100%; height: 270px; }
.hourly-chart text { fill: #6c8081; font-size: 10px; }
.hourly-demand-dot { fill: var(--deep); }
.hourly-generation-dot, .hourly-renewable-dot { fill: var(--green); }
.hourly-fossil-dot { fill: var(--coral); }
.extremes-grid { display: grid; grid-template-columns: repeat(6,minmax(0,1fr)); gap: 8px; margin-top: 15px; }
.daily-depth-table { margin-top: 14px; overflow-x: auto; border: 1px solid var(--line); background: white; }
.daily-depth-row { display: grid; grid-template-columns: 70px repeat(4,1fr); gap: 12px; min-width: 760px; padding: 10px 12px; border-top: 1px solid var(--line); font-size: 12px; align-items: center; }
.daily-depth-row:first-child { border-top: 0; }
.daily-depth-head { color: var(--muted); background: #f8fbfa; font-size: 10px; font-weight: 700; text-transform: uppercase; }
@media (max-width: 940px) {
  .intro { grid-template-columns: 1fr; gap: 22px; }
  .map-layout { grid-template-columns: 1fr; }
  .system-summary { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
  .system-summary .eyebrow, .system-summary h3, .system-summary p { grid-column: 1 / -1; }
  .summary-stat { padding-bottom: 0; }
  .sim-grid { grid-template-columns: 1fr; }
  .controls { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
  .control-block { padding: 0; border-bottom: 0; }
  .method-note { grid-column: 1 / -1; }
  .site-header { gap: 10px; flex-wrap: wrap; }
  .top-nav { display: none; }
  .mobile-menu-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .overview-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .readings-hero { grid-template-columns: 1fr; }
  .reading-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .cost-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .evolution-kpis { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .comparison-kpis { grid-template-columns: 1fr; }
  .diagnosis-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .comparison-row { grid-template-columns: 30px 150px minmax(0,1fr) 100px; }
  .comparison-row small { grid-column: 3 / 5; text-align: left; }
  .cost-method-grid { grid-template-columns: 1fr; }
  .cost-trace-list { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .cost-tech-row { grid-template-columns: 180px minmax(0,1fr) 115px; }
  .self-layout { grid-template-columns: 1fr; }
  .self-kpis { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .method-flow, .method-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .method-hero-grid, .method-cost-layout { grid-template-columns: 1fr; }
  .section-hero-grid { grid-template-columns: 1fr; }
  .systems-directory-grid, .systems-index-ranking { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .reports-grid, .report-publishing-grid { grid-template-columns: 1fr; }
  .method-source-grid, .method-process, .formula-grid, .method-kpis { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .method-explain-grid { grid-template-columns: 1fr; }
  .method-assumption-cards { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .assumption-row { grid-template-columns: minmax(150px,1fr) 110px 90px; }
  .assumption-row small { grid-column: 1 / -1; text-align: left; }
  .method-limits { grid-template-columns: 1fr; }
  .system-hero-grid, .system-two-col, .system-balance-grid { grid-template-columns: 1fr; }
  .system-kpis, .system-cost-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .system-portrait-grid, .radiography-grid, .extremes-grid { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .hourly-kpis { grid-template-columns: 1fr; }
  .balance-flow, .mix-group-grid, .emissions-grid, .curtailment-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .curtailment-layout, .deep-dive-layout, .deep-dive-columns { grid-template-columns: 1fr; }
  .deep-dive-scoreboard { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .operation-controls, .operation-visual { grid-template-columns: 1fr; }
  .operation-kpis { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .operation-stepper { grid-template-columns: repeat(2,1fr); }
  .operation-stepper input[type=range], .operation-speed { grid-column: 1 / -1; }
  .operation-alerts { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .compare-hero-grid { grid-template-columns: 1fr; }
  .compare-kpis { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .compare-insight-layout, .duel-grid, .duel-diagnosis { grid-template-columns: 1fr; }
  .compare-insight-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 680px) {
  .band, .hero-inner { width: min(100% - 30px, 1420px); }
  .site-header { padding: 13px 15px; }.header-meta span:not(.status-dot) { display: none; }
  .hero { min-height: auto; }.hero-inner { padding: 68px 0 42px; }
  h1 { max-width: 100%; font-size: 43px; line-height: .98; overflow-wrap: anywhere; }.hero-copy { max-width: 100%; margin-bottom: 0; font-size: 14px; }.hero-scroll, .hero-numbers { display: none; }
  .intro { padding: 55px 0; }.section-heading { display: block; }.select-label { margin-top: 16px; } select { width: 100%; }
  .map-panel { min-height: 365px; }.island-node { font-size: 10px; }.lanzarote { left: 82%; }.fuerteventura { left: 71%; }
  .system-summary { grid-template-columns: 1fr; }.system-summary .eyebrow, .system-summary h3, .system-summary p { grid-column: auto; }
  .controls { grid-template-columns: 1fr; }.control-block { padding-bottom: 13px; border-bottom: 1px solid rgba(255,255,255,.15); }
  .result-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .result-grid article { min-height: 125px; padding: 13px; }.result-grid strong { font-size: 20px; }
  .tech-row { grid-template-columns: 105px minmax(0,1fr) 76px; gap: 8px; }
  .overview-grid, .self-kpis { grid-template-columns: 1fr; }
  .reading-grid { grid-template-columns: 1fr; }
  .reading-grid article { min-height: 0; }
  .cost-grid { grid-template-columns: 1fr; }
  .evolution-kpis { grid-template-columns: 1fr; }
  .comparison-row { grid-template-columns: 28px minmax(0,1fr); gap: 8px; }
  .diagnosis-grid { grid-template-columns: 1fr; }
  .comparison-track, .comparison-row > span:not(.comparison-rank), .comparison-row small { grid-column: 2; }
  .comparison-row small { text-align: left; }
  .cost-group-list { grid-template-columns: 1fr; }
  .cost-trace-list { grid-template-columns: 1fr; }
  .cost-tech-row { grid-template-columns: 1fr; gap: 7px; }
  .cost-tech-row > div:last-child { text-align: left; }
  .view-control { display: block; margin-top: 15px; }.segments.light { margin-top: 7px; }
  .method-flow, .method-grid { grid-template-columns: 1fr; }
  .method-source-grid, .method-process, .formula-grid, .method-kpis, .method-assumption-cards { grid-template-columns: 1fr; }
  .systems-directory-grid, .systems-index-ranking, .report-card-grid { grid-template-columns: 1fr; }
  .systems-index-ranking a { grid-template-columns: 28px minmax(0,1fr); }
  .systems-index-ranking small { grid-column: 2; text-align: left; }
  .method-component-row { grid-template-columns: 1fr; }
  .section-hero { padding: 52px 0 38px; }
  .method-hero { padding: 52px 0 38px; }
  .assumption-row { grid-template-columns: 1fr; gap: 5px; }
  .assumption-row strong, .assumption-row small { text-align: left; }
  footer { flex-direction: column; padding: 16px; }
  .system-hero { padding: 44px 0 24px; }
  .system-kpis, .system-cost-grid, .balance-flow, .mix-group-grid, .emissions-grid, .curtailment-grid { grid-template-columns: 1fr; }
  .system-portrait-grid, .radiography-grid, .extremes-grid, .deep-dive-scoreboard { grid-template-columns: 1fr; }
  .radiography-grid article { min-height: 0; }
  .radiography-main strong { font-size: 20px; }
  .operation-clock, .operation-kpis { grid-template-columns: 1fr; }
  .operation-stepper { grid-template-columns: 1fr; }
  .operation-alerts { grid-template-columns: 1fr; }
  .compare-kpis { grid-template-columns: 1fr; }
  .compare-insight-grid { grid-template-columns: 1fr; }
  .compare-rank-row, .compare-evolution-row, .duel-bars > div { grid-template-columns: 1fr; }
  .compare-rank-row > span:last-child, .compare-evolution-row strong, .duel-bars em { text-align: left; }
  .system-evolution-rows div, .system-tech-row, .balance-stack-row, .mix-tech-row, .curtailment-months div, .v2a-tech-row, .operation-tech-row, .operation-chart-row, .cost-breakdown-row, .critical-tech-row { grid-template-columns: 1fr; }
  .cost-breakdown-row strong, .critical-tech-row strong { text-align: left; }
  .system-tech-row strong, .balance-stack-row strong, .mix-tech-row strong, .v2a-tech-row strong, .operation-tech-row strong, .operation-chart-row strong { text-align: left; }
}


