/* ====================================================================
 * QNOA — apothecary edition.
 * Paleta: cream warm, ink forest, sage, gold. Tipografie minimalistă.
 * ==================================================================== */

:root{
  /* surfaces */
  --bg-0:#FAFAF7;          /* alb cald, aproape neutru */
  --bg-1:#F0EDE6;          /* crem discret, secțiuni alternative */
  --paper:#FFFFFF;         /* card surface */
  --paper-edge:#E8E4DC;
  --hairline:rgba(26,26,46,.06);
  --hairline-2:rgba(26,26,46,.12);

  /* typography */
  --ink:#1A1A2E;           /* aproape negru cu tentă albastră caldă */
  --ink-soft:#3D405B;      /* gri-violet body */
  --ink-mute:#6B7280;      /* gri neutru */
  --ink-faint:#9CA3AF;

  /* greens — autoritate clinică */
  --green-900:#1B4332;
  --sage-deep:#2D6A4F;     /* dominant */
  --sage:#52B788;          /* accent / hover */
  --sage-tint:#D8F3DC;     /* chip / badge bg */
  --sage-tint-2:#EDFAF1;   /* ultra light */

  /* gold premium */
  --gold:#C9A84C;
  --gold-soft:#D8BD6E;
  --gold-tint:#FDF6E3;

  /* mineral / element labels */
  --mineral-blue:#5E8B9E;
  --mineral-warm:#A0785A;
  --mineral-green:#8FB4A8;

  /* warning / contraindicații (păstrăm un plum cald) */
  --plum:#8a5a6b;
  --plum-tint:#efe3e6;

  /* heatmap simptome — gradient cald spre alarmă pastel */
  --warn-1:#BCA362;
  --warn-2:#B88A52;
  --warn-3:#A6755C;
  --warn-4:#925462;

  /* radii */
  --r-xs:6px;
  --r-sm:10px;
  --r-md:14px;
  --r-lg:22px;
  --r-pill:999px;

  /* shadow — soft, paper-like */
  --shadow-1:0 1px 3px rgba(26,26,46,.06), 0 4px 12px rgba(26,26,46,.08);
  --shadow-2:0 8px 32px rgba(26,26,46,.10);
  --shadow-press:0 1px 0 rgba(26,26,46,.06), inset 0 1px 0 rgba(255,255,255,.6);

  /* motion */
  --t-xs:.12s;
  --t-fast:.22s;
  --t-med:.4s;
  --t-slow:.7s;
  --ease:cubic-bezier(.22,.8,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;background:var(--bg-0);color:var(--ink);}
html{-webkit-text-size-adjust:100%;}
body{
  font:400 16px/1.55 "DM Sans","Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-feature-settings:"ss01","ss02";
  letter-spacing:-.005em;
  color:var(--ink-soft);
  overflow-x:hidden;
  min-height:100vh;
  min-height:100dvh;
  background:
    radial-gradient(1100px 700px at 82% -8%, rgba(82,183,136,.10), transparent 60%),
    radial-gradient(900px 600px at -10% 110%, rgba(201,168,76,.06), transparent 65%),
    var(--bg-0);
}

img,svg{max-width:100%;display:block}
input,button,select,textarea{font:inherit;color:inherit}
button{cursor:pointer}

/* hidden attribute trumps any flex/grid display */
[hidden]{display:none !important}

::selection{background:var(--sage-tint);color:var(--ink)}

/* ── 3D STAGE ───────────────────────────── */
#stage{
  position:fixed;inset:0;
  width:100%;height:100%;
  z-index:0;
  pointer-events:none;
  opacity:.78;
  filter: blur(.3px);
  mask-image:
    radial-gradient(circle at 50% 50%, #000 60%, transparent 92%);
  -webkit-mask-image:
    radial-gradient(circle at 50% 50%, #000 60%, transparent 92%);
}

/* ── TOPBAR ─────────────────────────────── */
.topbar{
  position:fixed;top:0;left:0;right:0;
  z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:calc(20px + var(--safe-top)) 28px 16px;
  pointer-events:none;
}
.topbar > *{pointer-events:auto}

.brand{display:flex;align-items:center;gap:12px;}
.brand-mark{
  width:22px;height:22px;border-radius:50%;
  background:
    radial-gradient(circle at 32% 30%, #fff 0%, var(--sage-tint) 28%, var(--sage) 65%, var(--sage-deep) 100%);
  box-shadow:
    inset 0 0 6px rgba(255,255,255,.55),
    0 0 0 1px rgba(45,106,79,.18),
    0 4px 12px rgba(45,106,79,.16);
  position:relative;
  animation:breathe 4.8s var(--ease) infinite;
}
.brand-mark::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.7),transparent 32%);
}
@keyframes breathe{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.04)}
}
.brand-word{
  font:500 14px/1 "DM Sans","Inter",sans-serif;
  letter-spacing:.34em;
  color:var(--ink);
  text-transform:uppercase;
}
.brand-tag{
  font:500 10px/1 "DM Sans","Inter",sans-serif;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
  padding-left:14px;border-left:1px solid var(--hairline);
}
@media (max-width:520px){ .brand-tag{display:none} }

.ghost-btn{
  background:rgba(255,255,255,.55);
  border:1px solid var(--hairline-2);
  color:var(--ink-soft);
  width:38px;height:38px;
  border-radius:var(--r-pill);
  display:inline-flex;align-items:center;justify-content:center;
  transition:all var(--t-fast) var(--ease);
  backdrop-filter:blur(8px);
}
.ghost-btn:hover{color:var(--sage-deep);border-color:var(--sage);background:#fff}

/* ── APP CONTAINER ───────────────────────── */
.app{
  position:relative;
  z-index:2;
  min-height:100vh;
  min-height:100dvh;
  padding:calc(120px + var(--safe-top)) 56px calc(56px + var(--safe-bot));
  display:flex;align-items:center;justify-content:center;
}
@media (max-width:880px){
  .app{ padding:calc(96px + var(--safe-top)) 24px calc(48px + var(--safe-bot)); }
}
.screen{
  width:100%;
  max-width:780px;
  display:none;
  animation:screenIn .6s var(--ease-out) both;
}
.screen[aria-hidden="false"]{display:block}
@keyframes screenIn{
  from{opacity:0;transform:translateY(14px);filter:blur(4px)}
  to{opacity:1;transform:none;filter:blur(0)}
}

/* ── SPLASH ─────────────────────────────── */
.screen--splash{max-width:780px;text-align:left;padding-top:4vh}
.display{
  font:400 clamp(48px,8.2vw,92px)/.98 "Cormorant Garamond","Cormorant",serif;
  letter-spacing:-.025em;
  margin:0 0 30px;
  color:var(--ink);
}
.display-soft{
  display:block;color:var(--ink-mute);font-style:italic;font-weight:300;
  font-size:.72em;
  margin-bottom:.05em;
}
.display-strong{
  display:block;color:var(--ink);
  font-weight:500;
}
.lede{
  font-size:clamp(15.5px,1.6vw,18px);
  color:var(--ink-soft);
  max-width:520px;margin:0 0 38px;
  line-height:1.6;
  font-weight:400;
}
.trust{
  list-style:none;padding:14px 16px;margin:36px 0 0;
  display:inline-flex;flex-wrap:wrap;gap:0;
  background:var(--bg-1);
  border-radius:var(--r-pill);
}
.trust li{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-mute);font-weight:500;
  padding:0 18px;
  position:relative;
}
.trust li + li::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:3px;border-radius:50%;background:var(--ink-faint);
}
@media (max-width:680px){
  .trust{display:flex;flex-direction:column;gap:6px;border-radius:var(--r-md);padding:14px 18px}
  .trust li{padding:0}
  .trust li + li::before{display:none}
}

/* ── BUTTONS ─────────────────────────────── */
.cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--sage-deep);
  color:#fff;
  border:1px solid var(--sage-deep);
  padding:14px 26px;
  border-radius:var(--r-pill);
  font-weight:500;font-size:14px;letter-spacing:.005em;
  box-shadow:var(--shadow-1);
  transition:transform var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease),background var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.cta:hover{
  transform:translateY(-1px);
  background:var(--green-900);
  border-color:var(--green-900);
  box-shadow:var(--shadow-2);
}
.cta:active{transform:translateY(0) scale(.98)}
.cta--gold{
  background:var(--gold);
  border-color:var(--gold);
  color:#fff;
}
.cta--gold:hover{
  background:#947638;
  border-color:#947638;
}
.cta--ghost{
  background:transparent;color:var(--ink-soft);
  border:1px solid var(--hairline-2);
  box-shadow:none;
}
.cta--ghost:hover{
  color:var(--ink);
  border-color:var(--sage);
  background:rgba(255,255,255,.6);
  transform:none;
  box-shadow:none;
}
.cta--link{
  background:transparent;color:var(--ink-mute);border:0;
  text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:1px;
  padding:14px 12px;box-shadow:none;
  font-weight:400;
}
.cta--link:hover{color:var(--ink);transform:none;background:transparent;box-shadow:none}

/* ── SCREEN HEAD ─────────────────────────── */
.screen-head{margin-bottom:30px}
.screen-head--wide{margin-bottom:40px}
.step{
  font:600 11px/1 "DM Sans","Inter",sans-serif;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--sage-deep);
}
.screen-head h2{
  font:400 clamp(30px,4.4vw,44px)/1.05 "Cormorant Garamond","Cormorant",serif;
  margin:12px 0 8px;letter-spacing:-.02em;
  color:var(--ink);
}
.screen-head em{font-style:italic;color:var(--sage-deep);font-weight:400}
.muted{color:var(--ink-mute);font-size:13.5px;margin:0;font-weight:400}

/* ── FORMS ──────────────────────────────── */
.form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:var(--r-lg);
  padding:26px;
  box-shadow:var(--shadow-1);
}
.form--wide{grid-template-columns:1fr}
.form-actions{
  grid-column:1/-1;
  display:flex;justify-content:flex-end;gap:10px;margin-top:10px;
}
.form-actions--split{justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.form-actions--analyze{
  grid-column:1/-1;
  display:flex;flex-direction:column;gap:10px;align-items:stretch;
}

.field{
  position:relative;
  display:flex;flex-direction:column;gap:6px;
  padding:14px 16px;
  background:#fff;
  border:1px solid var(--hairline-2);
  border-radius:var(--r-md);
  transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease);
}
.field:focus-within{
  border-color:var(--sage);
  box-shadow:0 0 0 4px rgba(125,155,136,.12);
}
.field-label{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-mute);font-weight:600;
}
.field input[type="text"],
.field input[type="number"],
.field input[type="email"],
textarea{
  background:transparent;border:0;outline:0;
  color:var(--ink);
  padding:2px 0;
  font-size:16px;
  font-weight:420;
  width:100%;
}
.field input::placeholder,textarea::placeholder{color:var(--ink-faint);font-weight:380}
textarea{
  resize:vertical;min-height:72px;line-height:1.45;font-size:14px;font-weight:400;
  padding:10px 12px;background:#fff;
  border:1px solid var(--hairline-2);border-radius:var(--r-md);
  margin-top:10px;
}

.field--inline{flex-direction:column}

/* mini capsule slot inside field — fills when value present */
.field-cap{
  position:absolute;top:12px;right:12px;
  width:26px;height:26px;border-radius:50%;
  background:var(--bg-1);
  border:1px dashed var(--hairline-2);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t-med) var(--ease);
  overflow:visible;
}
.field-cap.filled{
  background:radial-gradient(circle at 32% 30%,#fff,var(--sage) 55%,var(--sage-deep) 100%);
  border:0;
  box-shadow:0 0 0 1px rgba(45,106,79,.18),0 4px 10px -2px rgba(45,106,79,.35);
  animation:capDrop .55s var(--ease-out);
}
@keyframes capDrop{
  0%{transform:translateY(-32px) scale(.4) rotate(-12deg);opacity:0}
  60%{transform:translateY(4px) scale(1.08) rotate(2deg);opacity:1}
  100%{transform:translateY(0) scale(1) rotate(0);opacity:1}
}

/* segmented controls */
.seg{
  display:flex;gap:4px;
  background:var(--bg-1);
  border:1px solid var(--hairline);
  border-radius:var(--r-pill);
  padding:3px;
}
.seg label{flex:1;position:relative;cursor:pointer}
.seg input{position:absolute;opacity:0;inset:0}
.seg span{
  display:block;text-align:center;
  padding:8px 10px;
  font-size:13px;font-weight:480;
  color:var(--ink-soft);
  border-radius:var(--r-pill);
  transition:all var(--t-fast) var(--ease);
}
.seg input:checked + span{
  background:#fff;
  color:var(--ink);
  font-weight:520;
  box-shadow:0 1px 2px rgba(29,42,36,.06),0 1px 0 rgba(255,255,255,.8) inset;
}
.seg--4 span{font-size:12.5px;padding:8px 6px}

/* chips — selectable */
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{position:relative;cursor:pointer}
.chip input{position:absolute;opacity:0;inset:0}
.chip span{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 14px 8px 11px;
  background:#fff;
  border:1px solid var(--hairline-2);
  border-radius:var(--r-pill);
  color:var(--ink-soft);
  font-size:13px;font-weight:460;
  transition:background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease),color var(--t-fast) var(--ease),transform var(--t-fast) var(--ease);
  white-space:nowrap;
}
.chip svg{width:14px;height:14px;flex-shrink:0;color:var(--ink-mute);transition:color var(--t-fast)}
.chip:hover span{border-color:var(--sage);color:var(--ink);transform:translateY(-1px)}
.chip:hover svg{color:var(--sage-deep)}
.chip input:checked + span{
  background:var(--sage-deep);
  border-color:var(--sage-deep);
  color:#fff;
  font-weight:500;
  box-shadow:0 4px 10px -3px rgba(45,106,79,.32);
}
.chip input:checked + span svg{color:var(--sage-tint)}

/* heatmap — symptom group only. JS sets data-load 0..6 */
.chips[data-group="symptoms"][data-load="2"] .chip input:checked + span{ background:var(--warn-1);border-color:var(--warn-1) }
.chips[data-group="symptoms"][data-load="2"] .chip input:checked + span svg{color:#fff}
.chips[data-group="symptoms"][data-load="3"] .chip input:checked + span{ background:var(--warn-2);border-color:var(--warn-2) }
.chips[data-group="symptoms"][data-load="3"] .chip input:checked + span svg{color:#fff}
.chips[data-group="symptoms"][data-load="4"] .chip input:checked + span{ background:var(--warn-3);border-color:var(--warn-3) }
.chips[data-group="symptoms"][data-load="4"] .chip input:checked + span svg{color:#fff}
.chips[data-group="symptoms"][data-load="5"] .chip input:checked + span,
.chips[data-group="symptoms"][data-load="6"] .chip input:checked + span{
  background:var(--warn-4);border-color:var(--warn-4);
  box-shadow:0 4px 14px -4px rgba(142,83,100,.45);
}
.chips[data-group="symptoms"][data-load="5"] .chip input:checked + span svg,
.chips[data-group="symptoms"][data-load="6"] .chip input:checked + span svg{color:#fff}

.chips--toggle .chip span{padding:8px 12px}

/* blocks */
.block{
  border:0;padding:0;margin:0 0 12px;
  background:transparent;
}
.block legend{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-mute);font-weight:600;
  padding:0;margin-bottom:12px;
}
.block--row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.block--row .field{padding:14px 16px}
.block--reveal textarea[hidden]{display:none}

input[type="range"]{
  -webkit-appearance:none;appearance:none;
  width:100%;height:3px;
  background:linear-gradient(to right,var(--sage),var(--sage-deep));
  border-radius:var(--r-pill);
  outline:0;
  margin:14px 0 8px;
}
input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:20px;height:20px;border-radius:50%;
  background:#fff;
  border:1px solid var(--sage);
  box-shadow:0 1px 3px rgba(29,42,36,.18),0 0 0 3px rgba(125,155,136,.1);
  cursor:grab;
}
input[type="range"]::-moz-range-thumb{
  width:20px;height:20px;border-radius:50%;
  background:#fff;border:1px solid var(--sage);
  box-shadow:0 1px 3px rgba(29,42,36,.18),0 0 0 3px rgba(125,155,136,.1);
}
output{
  display:inline-block;
  font-weight:550;color:var(--sage-deep);font-size:13px;
}

/* ── LAB UPLOAD ─────────────────────────── */
.lab-zone{
  background:var(--paper);
  border:1px dashed var(--hairline-2);
  border-radius:var(--r-lg);
  padding:32px 24px;
  text-align:center;
  margin-bottom:18px;
}
.lab-drop{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  cursor:pointer;
  color:var(--ink-soft);
  padding:24px;
  border-radius:var(--r-md);
  transition:background var(--t-fast) var(--ease);
}
.lab-drop:hover{background:#fff;color:var(--ink)}
.lab-drop strong{font-size:15px;font-weight:520}

.lab-thumbs{
  display:flex;flex-wrap:wrap;gap:10px;
  margin-top:18px;
}
.lab-thumb{
  position:relative;
  width:84px;height:84px;
  border-radius:var(--r-sm);
  overflow:hidden;
  border:1px solid var(--hairline-2);
  background:#fff;
  box-shadow:var(--shadow-1);
}
.lab-thumb img{width:100%;height:100%;object-fit:cover}
.lab-thumb button{
  position:absolute;top:4px;right:4px;
  width:22px;height:22px;border-radius:50%;
  background:rgba(255,255,255,.95);color:var(--ink);
  border:1px solid var(--hairline-2);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;line-height:1;
}

/* analyze depth picker */
.depth-picker{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
  background:var(--bg-1);
  padding:5px;border-radius:var(--r-md);
  border:1px solid var(--hairline);
  margin-bottom:14px;
}
.depth-picker label{position:relative;cursor:pointer}
.depth-picker input{position:absolute;opacity:0;inset:0}
.depth-picker .depth-card{
  display:block;padding:14px 16px;
  border-radius:var(--r-sm);
  background:transparent;
  transition:all var(--t-fast) var(--ease);
}
.depth-picker .depth-card strong{
  display:block;font-weight:540;color:var(--ink-soft);
  font-size:14px;letter-spacing:-.005em;
}
.depth-picker .depth-card span{
  display:block;font-size:11.5px;color:var(--ink-mute);margin-top:3px;line-height:1.3;
}
.depth-picker input:checked + .depth-card{
  background:#fff;
  box-shadow:0 1px 2px rgba(29,42,36,.06);
}
.depth-picker input:checked + .depth-card strong{color:var(--ink)}
.depth-picker input:checked + .depth-card span{color:var(--ink-soft)}

/* ── LOADING ─────────────────────────────── */
.screen--loading{text-align:center;max-width:540px}
.loader-core{
  position:relative;width:120px;height:120px;
  margin:14px auto 32px;
  display:flex;align-items:center;justify-content:center;
}
.loader-ring{
  position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg, var(--sage) 0%, var(--gold-soft) 50%, transparent 70%, transparent 100%);
  -webkit-mask:radial-gradient(circle, transparent 56%, #000 58%);
          mask:radial-gradient(circle, transparent 56%, #000 58%);
  animation:spin 2.4s linear infinite;
  filter:drop-shadow(0 0 6px rgba(125,155,136,.3));
}
.loader-core::before{
  content:"";position:absolute;inset:14px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#fff,var(--sage-tint) 50%,var(--sage) 100%);
  box-shadow:inset 0 0 14px rgba(255,255,255,.5),0 4px 14px rgba(80,107,90,.18);
  animation:breathe 2.6s var(--ease) infinite;
}
.loader-pct{
  position:relative;z-index:2;
  font:400 13px/1 "Inter",sans-serif;letter-spacing:.05em;
  color:var(--sage-deep);
}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-title{
  font:300 24px/1.15 "Cormorant Garamond",serif;margin:6px 0;color:var(--ink);
}
.loader-sub{margin-bottom:30px;font-size:13.5px}
.curio{
  position:relative;
  background:#FFFFFF;
  border:1px solid var(--paper-edge);
  border-radius:var(--r-lg);
  padding:24px 26px;
  text-align:left;
  min-height:120px;
  display:flex;flex-direction:column;gap:12px;
  box-shadow:var(--shadow-1);
  isolation:isolate;
}
.curio::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--sage),var(--gold));
  border-radius:var(--r-lg) 0 0 var(--r-lg);
}
.curio-label{
  font:600 10px/1 "DM Sans","Inter",sans-serif;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--sage-deep);
  display:inline-flex;align-items:center;gap:7px;
}
.curio-label::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 3px rgba(201,168,76,.18);
}
.curio-text{
  margin:0;
  font:500 16px/1.55 "Montserrat","DM Sans","Inter",sans-serif;
  color:var(--ink);
  letter-spacing:-.005em;
  animation:curioFade .55s var(--ease);
}
@keyframes curioFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ── RESULTS ─────────────────────────────── */
.screen--results{max-width:920px}
.results-summary{
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:var(--r-lg);
  padding:22px;
  margin-bottom:24px;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:14px;
  box-shadow:var(--shadow-1);
}
.summary-cell{padding:6px 4px}
.summary-cell .label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);display:block;font-weight:600}
.summary-cell .val{font:300 26px/1 "Cormorant Garamond",serif;color:var(--ink);margin-top:6px;display:block}

/* clinical narrative — looks like a doctor's note */
.narrative{
  background:#fff;
  border:1px solid var(--paper-edge);
  border-left:3px solid var(--sage-deep);
  border-radius:var(--r-lg);
  padding:26px 28px;
  margin-bottom:24px;
  box-shadow:var(--shadow-1);
  position:relative;
}
.narrative-tag{
  display:inline-flex;align-items:center;gap:7px;
  font:600 10px/1 "DM Sans","Inter",sans-serif;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--sage-deep);
  margin-bottom:14px;
}
.narrative-tag::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--sage);
  box-shadow:0 0 0 3px rgba(82,183,136,.22);
}
.narrative h3{
  font:400 22px/1.2 "Cormorant Garamond",serif;
  margin:0 0 12px;color:var(--ink);
}
.narrative p{
  margin:0 0 12px;
  font-size:14.5px;line-height:1.65;
  color:var(--ink-soft);
}
.narrative p:last-child{margin-bottom:0}
.narrative p strong{color:var(--ink);font-weight:540}
.narrative .lab-flags{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-top:14px;padding-top:14px;
  border-top:1px solid var(--hairline);
}
.narrative .lab-flag{
  font-size:12px;font-weight:480;
  padding:5px 12px;border-radius:var(--r-pill);
  background:var(--sage-tint);color:var(--sage-deep);
  border:1px solid rgba(45,106,79,.18);
}
.narrative .lab-flag b{font-weight:600;color:var(--ink)}

.results-list{display:grid;gap:14px;margin-bottom:30px}
.product{
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:var(--r-lg);
  padding:22px 24px;
  display:grid;
  grid-template-columns:auto 1fr;
  gap:20px;
  align-items:start;
  position:relative;overflow:hidden;
  transition:transform var(--t-med) var(--ease),box-shadow var(--t-med) var(--ease);
  box-shadow:var(--shadow-1);
}
.product::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--sage);
  opacity:.7;
}
.product:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}

.product-cap{
  width:56px;height:56px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%,#fff,var(--sage-tint) 35%,var(--sage) 90%);
  box-shadow:inset 0 0 8px rgba(255,255,255,.5),0 4px 14px rgba(80,107,90,.22);
  position:relative;
  flex-shrink:0;
}
.product-cap[data-hue="amber"]{background:radial-gradient(circle at 32% 30%,#fff,var(--gold-tint) 35%,var(--gold) 100%);box-shadow:inset 0 0 8px rgba(255,255,255,.5),0 4px 14px rgba(168,136,72,.25)}
.product-cap[data-hue="rose"]{background:radial-gradient(circle at 32% 30%,#fff,var(--plum-tint) 35%,var(--plum) 100%);box-shadow:inset 0 0 8px rgba(255,255,255,.5),0 4px 14px rgba(138,90,107,.25)}
.product-cap[data-hue="violet"]{background:radial-gradient(circle at 32% 30%,#fff,#ece5ee 35%,#7e6585 100%);box-shadow:inset 0 0 8px rgba(255,255,255,.5),0 4px 14px rgba(126,101,133,.25)}
.product-cap[data-hue="ocean"]{background:radial-gradient(circle at 32% 30%,#fff,#dde9eb 35%,#5e8590 100%);box-shadow:inset 0 0 8px rgba(255,255,255,.5),0 4px 14px rgba(94,133,144,.25)}
.product-cap[data-hue="gold"]{background:radial-gradient(circle at 32% 30%,#fff,var(--gold-tint) 35%,var(--gold) 100%);box-shadow:inset 0 0 8px rgba(255,255,255,.5),0 4px 14px rgba(168,136,72,.25)}
.product-cap[data-hue="mint"]{background:radial-gradient(circle at 32% 30%,#fff,var(--sage-tint) 35%,var(--sage) 100%);box-shadow:inset 0 0 8px rgba(255,255,255,.5),0 4px 14px rgba(125,155,136,.25)}

.product h3{
  font:400 19px/1.2 "Cormorant Garamond",serif;margin:0 0 5px;
  color:var(--ink);
  letter-spacing:-.01em;
}
.product .ingredient{
  font-size:11.5px;color:var(--ink-mute);
  letter-spacing:.04em;margin-bottom:12px;
  font-weight:500;
}
.product .ingredient strong{color:var(--ink-soft);font-weight:600}
.product .why{margin:0 0 10px;font-size:14.5px;line-height:1.55;color:var(--ink-soft);font-weight:400}
.product .meta{
  display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;
  font-size:11.5px;
}
.meta-tag{
  padding:4px 10px;border-radius:var(--r-pill);
  background:var(--bg-1);
  color:var(--ink-soft);
  border:1px solid var(--hairline);
  font-weight:480;
}
.meta-tag--good{color:var(--gold);border-color:var(--gold-tint);background:var(--gold-tint)}
.product .reason{
  margin-top:10px;
  font-size:13px;color:var(--ink-soft);
  border-top:1px solid var(--hairline);
  padding-top:10px;
  line-height:1.5;
}
.product .reason b{font-weight:600;color:var(--sage-deep);letter-spacing:.04em;text-transform:uppercase;font-size:9.5px;display:block;margin-bottom:4px;font-style:normal}

/* ── SCHEDULE ───────────────────────────── */
.schedule{
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:var(--r-lg);
  padding:24px;
  margin-bottom:26px;
  box-shadow:var(--shadow-1);
}
.schedule h3{
  font:400 20px/1.2 "Cormorant Garamond",serif;
  margin:0 0 14px;color:var(--ink);
}
.schedule-grid{display:grid;gap:6px}
.slot{
  display:grid;grid-template-columns:130px 1fr;gap:14px;align-items:start;
  padding:12px 0;border-bottom:1px solid var(--hairline);
}
.slot:last-child{border-bottom:0}
.slot-when{
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);font-weight:600;
  padding-top:3px;
}
.slot-items{display:flex;flex-wrap:wrap;gap:6px}
.slot-pill{
  padding:6px 12px;border-radius:var(--r-pill);
  background:var(--bg-1);
  border:1px solid var(--hairline);
  font-size:13px;color:var(--ink-soft);
  font-weight:460;
}

.results-actions{
  display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;
}

/* ── CHAT DRAWER ────────────────────────── */
.chat{
  position:fixed;
  right:20px;bottom:20px;
  width:min(380px,calc(100vw - 32px));
  max-height:min(620px,calc(100dvh - 40px));
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-2);
  display:flex;flex-direction:column;
  z-index:80;
  transform:translateY(20px) scale(.96);opacity:0;pointer-events:none;
  transition:transform var(--t-med) var(--ease),opacity var(--t-med) var(--ease);
}
.chat[aria-hidden="false"]{transform:none;opacity:1;pointer-events:auto}
.chat-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;border-bottom:1px solid var(--hairline);
}
.chat-head strong{font-weight:540;font-size:14px;display:block;color:var(--ink)}
.chat-head .muted{font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:500}
.chat-log{
  flex:1;overflow-y:auto;
  padding:16px 18px;
  display:flex;flex-direction:column;gap:10px;
  min-height:140px;max-height:380px;
}
.msg{
  max-width:88%;
  padding:10px 14px;
  border-radius:var(--r-md);
  font-size:14px;line-height:1.45;
  animation:msgIn .35s var(--ease);
}
@keyframes msgIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.msg--bot{
  align-self:flex-start;
  background:var(--bg-1);
  color:var(--ink);
}
.msg--user{
  align-self:flex-end;
  background:var(--ink);
  color:#fff;
  font-weight:480;
}
.msg.typing{display:inline-flex;gap:4px;padding:14px 16px;align-self:flex-start;background:var(--bg-1);border-radius:var(--r-md)}
.msg.typing span{width:5px;height:5px;border-radius:50%;background:var(--ink-mute);animation:typing 1.2s var(--ease) infinite}
.msg.typing span:nth-child(2){animation-delay:.15s}
.msg.typing span:nth-child(3){animation-delay:.3s}
@keyframes typing{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}

.chat-reeval{
  padding:14px 18px;
  background:var(--gold-tint);
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
  font-size:13px;color:var(--ink);
  display:flex;flex-direction:column;gap:8px;
}
.chat-reeval p{margin:0}
#btn-reeval{
  align-self:flex-start;
  background:var(--gold);color:#fff;font-weight:540;
  border:0;padding:8px 16px;border-radius:var(--r-pill);
  font-size:13px;
}

.chat-form{
  display:flex;gap:8px;padding:14px;border-top:1px solid var(--hairline);
}
.chat-form input{
  flex:1;background:#fff;
  border:1px solid var(--hairline-2);border-radius:var(--r-pill);
  padding:10px 16px;color:var(--ink);font-size:14px;
  outline:0;
}
.chat-form input:focus{border-color:var(--sage)}
.chat-form button{
  width:38px;height:38px;border-radius:50%;
  background:var(--ink);color:#fff;border:0;
  display:flex;align-items:center;justify-content:center;
}

/* ── MODAL ──────────────────────────────── */
.modal{
  border:0;padding:0;background:transparent;
  inset:0;width:100vw;height:100vh;max-width:none;max-height:none;
}
.modal[open]{
  display:flex;align-items:center;justify-content:center;
  background:rgba(29,42,36,.32);
  backdrop-filter:blur(4px);
  z-index:90;
}
.modal::backdrop{background:rgba(29,42,36,.32);backdrop-filter:blur(4px)}
.modal-card{
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:var(--r-lg);
  padding:30px;
  width:min(440px,calc(100vw - 32px));
  display:flex;flex-direction:column;gap:14px;
  box-shadow:var(--shadow-2);
}
.modal-card h3{font:400 22px/1.1 "Cormorant Garamond",serif;margin:0;color:var(--ink)}
.modal-card input{
  background:#fff;
  border:1px solid var(--hairline-2);
  border-radius:var(--r-md);
  padding:12px 16px;color:var(--ink);font-size:15px;
  outline:0;
}
.modal-card input:focus{border-color:var(--sage)}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}

/* ── TOAST ──────────────────────────────── */
.toast{
  position:fixed;bottom:max(20px,calc(var(--safe-bot) + 20px));
  left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);
  color:#fff;
  border:0;
  padding:12px 22px;border-radius:var(--r-pill);
  font-size:13.5px;
  z-index:100;
  opacity:0;pointer-events:none;
  transition:transform var(--t-med) var(--ease),opacity var(--t-med) var(--ease);
  max-width:90vw;
  box-shadow:var(--shadow-2);
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast--err{background:var(--plum)}

/* ── DIAG ──────────────────────────────── */
.diag{
  position:fixed;top:max(64px,calc(var(--safe-top) + 64px));right:18px;
  z-index:55;
  background:var(--paper);border:1px solid var(--hairline-2);
  border-radius:var(--r-pill);
  padding:5px 11px;
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-mute);font-weight:600;
  opacity:0;transform:translateY(-6px);
  transition:opacity var(--t-fast),transform var(--t-fast);
  pointer-events:none;
}
.diag.show{opacity:1;transform:none}
.diag.ok{color:var(--sage-deep);border-color:var(--sage)}
.diag.err{color:var(--plum);border-color:var(--plum);pointer-events:auto}

/* AI status pill — discrete, jos-stânga, fără input */
.ai-status{
  position:fixed;left:20px;bottom:max(20px,calc(var(--safe-bot) + 14px));
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 13px;border-radius:var(--r-pill);
  background:var(--paper);
  border:1px solid var(--paper-edge);
  color:var(--ink-mute);
  font-size:11px;font-weight:500;letter-spacing:.04em;
  z-index:60;
  box-shadow:var(--shadow-1);
}
.ai-status::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--ink-faint);
}
.ai-status.ok{color:var(--sage-deep)}
.ai-status.ok::before{background:var(--sage);box-shadow:0 0 0 3px rgba(82,183,136,.22)}
.ai-status.err{color:var(--plum)}
.ai-status.err::before{background:var(--plum);box-shadow:0 0 0 3px rgba(138,90,107,.18)}

/* ── RESPONSIVE ─────────────────────────── */
@media (max-width:680px){
  .form{grid-template-columns:1fr;padding:20px}
  .block--row{grid-template-columns:1fr}
  .product{grid-template-columns:1fr;padding:20px;gap:14px}
  .product-cap{width:44px;height:44px}
  .slot{grid-template-columns:1fr}
  .slot-when{padding-bottom:4px}
  .form-actions{justify-content:stretch;flex-direction:column-reverse}
  .form-actions .cta{width:100%;justify-content:center}
  .form-actions--split{flex-direction:column-reverse;gap:8px}
  .form-actions--split .cta{width:100%;justify-content:center}
  .chat{
    right:0;left:0;bottom:0;
    width:100%;max-height:78dvh;
    border-radius:var(--r-lg) var(--r-lg) 0 0;
    border-bottom:0;
  }
  .apikey{left:8px;right:8px;max-width:none}
  .results-actions .cta{flex:1;justify-content:center}
  .app{padding:calc(86px + var(--safe-top)) 18px calc(110px + var(--safe-bot))}
  .depth-picker{grid-template-columns:1fr}
}

@media (max-width:420px){
  .display{font-size:44px}
  .lede{font-size:14.5px}
  .seg--4{flex-wrap:wrap}
  .seg--4 label{flex:1 1 calc(50% - 4px)}
  .summary-cell .val{font-size:20px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;transition-duration:.001ms !important}
}

/* ── PRINT (download PDF via browser save-as-PDF) ───────────────────────── */
@media print{
  @page { margin: 16mm; size: A4; }
  body{ background:#fff !important; }
  #stage,.topbar,.chat,.modal,.toast,.diag,.ai-status,.results-actions,#btn-restart{ display:none !important; }
  .app{ padding:0 !important; display:block !important; }
  .screen[aria-hidden="true"]{ display:none !important; }
  .screen[aria-hidden="false"]{ display:block !important; max-width:none !important; }
  .product, .narrative, .schedule, .results-summary{
    box-shadow:none !important; break-inside:avoid; page-break-inside:avoid;
    border-color:#ddd !important;
  }
  .product:hover, .product{ transform:none !important; }
  h2,h3{ page-break-after:avoid; }
  .results-list{ gap:10px !important; }
  .product{ padding:14px 16px !important; }
}

