/* =============================================================
   THE HANGAR — study viewer  (App / "Instrument" surface)
   V&V study record: result readouts, MDO formulation, decision
   log, analysis plots, model + provenance iframes. Shared by all
   studies/*/index.html. Tokens from ds/tokens.css; fonts from
   fonts/fonts.css. Embedded n2 / dag / plan-detail viewers keep
   their own (generated) styling inside bordered panels.
   ============================================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth}
body{font-family:var(--font-sans);background:var(--app-canvas);color:var(--ink-700);line-height:1.55;font-size:var(--fs-base);-webkit-font-smoothing:antialiased}

a{color:var(--blue-600);text-decoration:none}
a:hover{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
:focus{outline:none}
:focus-visible{outline:2px solid var(--blue-400);outline-offset:3px;border-radius:2px}
.section-desc a,.subtitle a{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}

.container{max-width:var(--container-site);margin:0 auto;padding:0 40px;position:relative}

.skip-link{position:absolute;top:-46px;left:8px;z-index:1000;background:var(--green-600);color:#fff;padding:10px 16px;font-family:var(--font-mono);font-size:var(--fs-xs);border-radius:var(--radius-sm);text-decoration:none}
.skip-link:focus{top:8px;text-decoration:none}

/* code accents inherit the green semantic alias (--accent) from tokens */
code{font-family:var(--font-mono)}

/* ---- NAV ---- */
nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--app-line);padding:13px 0}
nav .container{display:flex;align-items:center;justify-content:space-between}
nav .wordmark{font-family:var(--font-mono);font-size:var(--fs-sm);font-weight:var(--fw-semibold);letter-spacing:.13em;color:var(--ink-800);text-decoration:none;display:inline-flex;align-items:center;gap:.55em}
nav .wordmark:hover{text-decoration:none}
nav .wordmark span{color:var(--green-600)}
nav .links{display:flex;gap:22px;font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.02em}
nav .links a{color:var(--ink-500)}
nav .links a:hover{color:var(--ink-800);text-decoration:none}

.label{font-family:var(--font-mono);font-size:var(--fs-2xs);font-weight:var(--fw-medium);color:var(--blue-700);text-transform:uppercase;letter-spacing:var(--ls-kicker);margin-bottom:18px;display:block}

/* ---- STUDY HEADER ---- */
.study-header{padding:72px 0 40px;border-bottom:1px solid var(--app-line);background:var(--app-panel)}
.study-header h1{font-family:var(--font-sans);font-size:2.1rem;font-weight:var(--fw-semibold);letter-spacing:-.025em;line-height:1.12;margin-bottom:14px;color:var(--ink-800)}
.amber{color:var(--green-700)}
.study-header .subtitle{font-family:var(--font-sans);font-size:var(--fs-md);color:var(--ink-500);max-width:780px;margin-bottom:20px;line-height:1.65}
.study-header .run-meta{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--ink-400);letter-spacing:.04em}
.study-header .run-meta .k{color:var(--ink-400)}
.study-header .run-meta .v{color:var(--ink-600)}
.study-header .run-meta .sep{color:var(--green-600);margin:0 12px}

/* ---- RESULT CARDS ---- */
.result-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;background:var(--app-line);border:1px solid var(--app-line);border-radius:var(--radius-md);overflow:hidden;margin:40px 0 0}
.result-card{background:var(--app-panel);padding:22px 24px;text-align:left}
.result-card .value{font-family:var(--font-mono);font-size:1.5rem;font-weight:var(--fw-medium);color:var(--ink-800);margin-bottom:6px;letter-spacing:-.02em}
.result-card .value.converged{color:var(--green-600)}
.result-card .label-k{font-family:var(--font-mono);font-size:var(--fs-2xs);color:var(--ink-400);text-transform:lowercase;letter-spacing:.08em}

/* ---- SECTIONS ---- */
section{padding:64px 0;border-bottom:1px solid var(--app-line)}
section h2{font-family:var(--font-sans);font-size:1.5rem;font-weight:var(--fw-semibold);letter-spacing:-.02em;margin-bottom:10px;color:var(--ink-800)}
section .section-desc{color:var(--ink-500);margin-bottom:36px;font-size:var(--fs-base);max-width:720px;line-height:1.65;font-family:var(--font-sans)}

/* ---- FORMULATION CARDS ---- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}
.form-card{background:var(--app-panel);border:1px solid var(--app-line);border-radius:var(--radius-md);padding:22px 26px}
.form-card h3{font-family:var(--font-mono);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--green-700);margin-bottom:14px;letter-spacing:.02em;text-transform:lowercase}
.form-card h3::before{content:'## ';color:var(--green-600);opacity:.7}
.form-card table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:var(--fs-sm)}
.form-card td{padding:5px 0;border-bottom:1px solid var(--app-line-2);vertical-align:top}
.form-card td:first-child{color:var(--ink-400);width:55%}
.form-card td:last-child{color:var(--ink-800);text-align:right}
.form-card ul{list-style:none;padding:0;font-family:var(--font-mono);font-size:var(--fs-sm)}
.form-card li{padding:6px 0 6px 16px;border-bottom:1px solid var(--app-line-2);color:var(--ink-600);line-height:1.6;position:relative}
.form-card li:last-child{border-bottom:none}
.form-card li::before{content:'-';position:absolute;left:0;color:var(--green-600)}
.form-card li strong{color:var(--ink-800);font-weight:var(--fw-semibold)}
.form-card li .bounds{color:var(--ink-400);font-size:.92em}

/* ---- DECISIONS ---- */
.decisions{margin-top:16px}
.stage{background:var(--app-panel);border:1px solid var(--app-line);border-left:var(--bw-accent) solid var(--green-600);border-radius:0 var(--radius-md) var(--radius-md) 0;margin-bottom:10px}
.stage summary{padding:14px 20px;cursor:pointer;font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--ink-800);display:flex;justify-content:space-between;align-items:center;gap:12px;list-style:none;user-select:none}
.stage summary::-webkit-details-marker{display:none}
.stage summary::before{content:'+';color:var(--green-600);font-weight:var(--fw-semibold);margin-right:10px;font-family:var(--font-mono)}
.stage[open] summary::before{content:'-'}
.stage summary:hover{background:var(--app-subtle)}
.stage summary .stage-name{font-weight:var(--fw-medium);flex:1;text-transform:uppercase;letter-spacing:.06em;font-size:var(--fs-xs)}
.stage summary .stage-count{color:var(--ink-400);font-size:var(--fs-2xs);font-weight:var(--fw-regular);letter-spacing:.04em}
.stage-body{padding:4px 20px 18px;border-top:1px solid var(--app-line)}
.decision{border:none;border-left:1px solid var(--app-line);padding:10px 0 10px 16px;margin:14px 0 0}
.decision:first-child{margin-top:16px}
.decision .dec-head{display:flex;gap:16px;margin-bottom:6px;align-items:baseline;flex-wrap:wrap}
.decision .dec-id{font-family:var(--font-mono);font-size:var(--fs-2xs);color:var(--green-700);font-weight:var(--fw-semibold);letter-spacing:.08em}
.decision .dec-text{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--ink-800);font-weight:var(--fw-medium);margin-bottom:6px;line-height:1.5}
.decision .dec-reason{font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--ink-500);line-height:1.6}

/* ---- PLOTS ---- */
.plots-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.plot-item{background:var(--app-panel);border:1px solid var(--app-line);border-radius:var(--radius-md);overflow:hidden}
.plot-item img{width:100%;height:auto;display:block;background:#fff}
.plot-item .cap{padding:12px 18px;border-top:1px solid var(--app-line);font-family:var(--font-mono);font-size:var(--fs-2xs);color:var(--ink-400);line-height:1.6}
.plot-item .cap .tag{color:var(--green-700);margin-right:6px}

/* ---- HEADLINE FIGURE (brelje) ---- */
.headline-fig{background:var(--app-panel);border:1px solid var(--app-line);border-radius:var(--radius-md);overflow:hidden;margin-bottom:28px}
.headline-fig img{width:100%;height:auto;display:block;background:#fff}
.headline-fig .cap{padding:14px 22px;border-top:1px solid var(--app-line);font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--ink-500);line-height:1.6}

/* ---- FIGURE GROUPS (brelje) ---- */
.fig-group{margin-bottom:40px}
.fig-group h3{font-family:var(--font-sans);font-size:var(--fs-lg);font-weight:var(--fw-semibold);color:var(--ink-800);margin-bottom:14px}
.fig-group h3::before{content:'## ';color:var(--green-600);font-family:var(--font-mono);font-weight:var(--fw-regular)}
.fig-group .desc{font-family:var(--font-sans);font-size:var(--fs-base);color:var(--ink-500);margin-bottom:18px;max-width:760px;line-height:1.65}
.fig-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.fig-item{background:var(--app-panel);border:1px solid var(--app-line);border-radius:var(--radius-md);overflow:hidden}
.fig-item img{width:100%;height:auto;display:block;background:#fff}
.fig-item .cap{padding:12px 18px;border-top:1px solid var(--app-line);font-family:var(--font-mono);font-size:var(--fs-2xs);color:var(--ink-400);line-height:1.6}
.fig-item .cap .tag{color:var(--green-700);margin-right:6px}

/* ---- DIVERGENCES (amber callout, brelje) ---- */
.divergences{background:var(--amber-50);border:1px solid var(--amber-200);border-left:3px solid var(--amber-600);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:24px 28px;margin-top:20px;font-family:var(--font-sans)}
.divergences h3{font-family:var(--font-mono);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--amber-600);margin-bottom:14px;letter-spacing:.04em}
.divergences h3::before{content:'! ';color:var(--amber-600);font-family:var(--font-mono);font-weight:700}
.divergences ol{margin:0;padding-left:20px;color:var(--ink-600);font-size:var(--fs-base);line-height:1.7}
.divergences li{margin-bottom:10px}
.divergences li strong{color:var(--ink-800);font-family:var(--font-mono);font-size:.88em;font-weight:var(--fw-medium)}

/* ---- PIPELINE CODE BLOCK (dark console, brelje) ---- */
.pipeline{background:var(--ink-800);border:1px solid var(--ink-700);border-radius:var(--radius-md);padding:20px 26px;font-family:var(--font-mono);font-size:var(--fs-sm);color:#c5cdd6;line-height:1.9;overflow-x:auto;white-space:pre}
.pipeline .prompt{color:var(--green-500)}
.pipeline .comment{color:#6b7785}
.pipeline .cmd{color:#eef2f6}

/* ---- MODEL / PROVENANCE IFRAMES ---- */
.iframe-section{margin-bottom:24px}
.iframe-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px;gap:12px}
.iframe-head h3{font-family:var(--font-sans);font-size:var(--fs-md);font-weight:var(--fw-semibold);color:var(--ink-800)}
.iframe-head h3::before{content:'## ';color:var(--green-600);font-family:var(--font-mono);font-weight:var(--fw-regular)}
.iframe-head a{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--blue-600)}
.iframe-wrap{background:var(--app-panel);border:1px solid var(--app-line);border-radius:var(--radius-md);overflow:hidden}
.iframe-wrap.light{background:#fff}
.iframe-wrap iframe{width:100%;height:620px;border:none;display:block}
.iframe-missing{padding:22px 26px;font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--ink-400);line-height:1.7;border:1px dashed var(--app-line);border-radius:var(--radius-md);background:var(--app-subtle)}
.iframe-missing code{color:var(--blue-700);font-size:.9em;background:var(--app-panel);padding:1px 5px;border-radius:2px}

/* ---- FOOTER ---- */
footer{padding:36px 0;text-align:center;font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--ink-400);letter-spacing:.04em}
footer .container{display:flex;flex-direction:column;gap:14px;align-items:center}
footer a{color:var(--ink-500)}
footer a:hover{color:var(--green-700)}
footer .legal a{color:var(--ink-500)}
footer .legal a:hover{color:var(--green-700)}
footer .sep{margin:0 10px;color:var(--green-600)}

@media(max-width:860px){
  .study-header h1{font-size:1.6rem}
  .form-grid,.plots-grid,.fig-grid-2{grid-template-columns:1fr}
  nav .links{gap:14px}
}
@media(max-width:540px){
  .container{padding:0 20px}
  section{padding:48px 0}
}
