/* =====================================================================
   EVA MAISON — interactive presentation experience
   Real deck slides (images) + live question slides that average all
   answers, route to a recommendation, and hand off to a lead form.
   Plain CSS, no build step. cPanel-ready static files.
   ===================================================================== */
:root{
  --ink:#1a1611; --ink-2:#2b251d; --muted:#736a5d; --muted-2:#9a8f7e;
  --cream:#f6f1e8; --cream-2:#efe6d6; --paper:#fffdf8;
  --gold:#9a7b3c; --gold-2:#c4a45c; --gold-3:#e0ca99; --wine:#8c2c20;
  --line:rgba(26,22,17,.16); --line-soft:rgba(26,22,17,.08); --line-light:rgba(255,255,255,.18);
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Jost', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --ar:'Amiri','Cormorant Garamond',serif;
  --stage:#14110c;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;height:100%;}
body{
  font-family:var(--sans);font-weight:300;color:var(--ink);background:var(--stage);
  -webkit-font-smoothing:antialiased;overflow:hidden;
}
button{font-family:inherit;cursor:pointer;}
a{color:inherit;text-decoration:none;}
:focus-visible{outline:2px solid var(--gold-2);outline-offset:3px;}

/* ------------------------------ stage ----------------------------- */
.exp{position:fixed;inset:0;overflow:hidden;}
.stage{position:absolute;inset:0;}

.slide{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .6s var(--ease);
  padding:0;
}
.slide.is-active{opacity:1;visibility:visible;z-index:2;}
.slide.is-prev{z-index:1;}

/* media slides — fill the stage, letterboxed (works for <img> and <video>) */
.slide__img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block;}

/* placeholder when an image isn't present yet */
.slide--ph{background:
   radial-gradient(120% 90% at 80% 12%, rgba(196,164,92,.14), transparent 55%),
   linear-gradient(155deg,#211a12,#3a2e20 55%,#52412f);
}
.slide--ph .ph{color:rgba(255,253,248,.6);text-align:center;font-family:var(--serif);}
.slide--ph .ph b{display:block;font-size:clamp(3rem,9vw,7rem);color:rgba(255,253,248,.32);line-height:1;}
.slide--ph .ph span{font-size:.8rem;letter-spacing:.28em;text-transform:uppercase;font-family:var(--sans);color:rgba(255,253,248,.5);}

/* ---------------------------- question ---------------------------- */
.slide--q{background:var(--cream);}
.q{width:min(900px,90vw);text-align:center;padding:24px;}
.q__eyebrow{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4em;}
.q__ar{font-family:var(--ar);color:var(--muted-2);font-size:1.15rem;margin-bottom:.4em;}
.q__title{font-family:var(--serif);font-weight:400;line-height:1.1;color:var(--ink);
  font-size:clamp(1.7rem,4.4vw,3.1rem);max-width:18ch;margin:0 auto;}
.q__title em{font-style:italic;color:var(--gold);}

/* 1–5 scale */
.scale{display:flex;justify-content:center;gap:clamp(8px,2vw,26px);margin-top:clamp(34px,6vw,64px);}
.scale .opt{display:flex;flex-direction:column;align-items:center;gap:12px;background:none;border:0;padding:6px;width:clamp(56px,12vw,96px);}
.opt__n{display:grid;place-items:center;width:clamp(46px,6vw,60px);height:clamp(46px,6vw,60px);border-radius:50%;
  border:1px solid var(--line);font-family:var(--serif);font-size:1.35rem;color:var(--ink-2);
  transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease);}
.opt__l{font-size:.66rem;letter-spacing:.05em;color:var(--muted);line-height:1.3;min-height:2.4em;}
.opt:hover .opt__n,.opt:focus-visible .opt__n{border-color:var(--gold);transform:translateY(-2px);}
.opt.is-sel .opt__n{background:linear-gradient(150deg,var(--gold-2),var(--gold));color:#fff;border-color:transparent;transform:scale(1.07);}

/* Q6 choices */
.choices{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:clamp(30px,5vw,52px);}
.choices .opt{flex-direction:row;width:auto;background:none;border:0;padding:0;cursor:pointer;}
.choices .opt .opt__l{
  min-height:0;font-size:.92rem;letter-spacing:.06em;color:var(--ink-2);
  border:1px solid var(--line);border-radius:999px;padding:.85em 1.5em;transition:background .25s,color .25s,border-color .25s;}
.choices .opt:hover .opt__l{border-color:var(--gold);}
.choices .opt.is-sel .opt__l{background:var(--ink);color:var(--cream);border-color:var(--ink);}

.q__hint{margin-top:2.4em;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-2);}

/* progress dots for the quiz */
.q__dots{display:flex;justify-content:center;gap:8px;margin-top:1.8em;}
.q__dots i{width:7px;height:7px;border-radius:50%;background:var(--line);transition:background .3s;}
.q__dots i.on{background:var(--gold);}

/* --------------- recommendation notification (small glass toast) -------------- */
.rec-pop{position:fixed;top:16px;left:clamp(14px,3vw,24px);z-index:50;width:min(290px,82vw);
  pointer-events:none;opacity:0;visibility:hidden;transform:translateY(-12px);
  transition:opacity .45s var(--ease),transform .45s var(--ease),visibility .45s;}
.rec-pop[hidden]{display:none;}
.rec-pop.is-open{opacity:1;visibility:visible;transform:translateY(0);}
.rec-card{position:relative;pointer-events:auto;color:#fbf6ec;
  background:rgba(24,19,13,.5);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);backdrop-filter:blur(20px) saturate(1.4);
  border:1px solid rgba(255,255,255,.2);border-radius:14px;padding:14px 16px 15px;
  box-shadow:0 16px 44px -16px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,255,255,.22);}
.rec-x{position:absolute;top:8px;right:9px;width:22px;height:22px;border:0;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.1);color:rgba(255,253,248,.7);font-size:15px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;}
.rec-x:hover{background:rgba(255,255,255,.2);color:#fff;}
.rec-k{font-size:.52rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-3);margin-bottom:.5em;}
.rec-stars{color:var(--gold-2);letter-spacing:.1em;font-size:.72rem;margin-bottom:.1em;}
.rec-tier{font-family:var(--serif);font-weight:500;font-size:1.12rem;line-height:1.15;color:#fdfaf3;padding-right:18px;}
.rec-line{font-family:var(--serif);font-style:italic;color:var(--gold-3);font-size:.78rem;line-height:1.3;margin:.3em 0 .8em;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.rec-card .btn{min-width:0;width:100%;justify-content:center;padding:.7em 1em;font-size:.7rem;}
.rec-note{margin-top:.55em;font-size:.64rem;line-height:1.3;color:rgba(255,253,248,.6);}
.rec-note:empty{display:none;}
.rec-note[data-state="ok"]{color:#a7d3a0;}
.rec-note[data-state="err"]{color:#e7a99f;}

/* ----------------------------- buttons ---------------------------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  background:transparent;padding:.95em 1.9em;border:1px solid transparent;border-radius:999px;transition:background .35s var(--ease),color .35s,border-color .35s,transform .35s;}
.btn--solid{background:var(--gold);color:#1a1306;}
.btn--solid:hover{background:var(--gold-3);}
.btn--line{border-color:var(--line-light);color:var(--cream);}
.btn--line:hover{background:var(--cream);color:var(--ink);}
.btn--ink{background:var(--ink);color:var(--cream);}
.btn--ink:hover{background:var(--gold);color:#1a1306;}
.btn--block{width:100%;justify-content:center;}

/* ----------------------- form fields (shared) --------------------- */
.field{display:flex;flex-direction:column;gap:8px;}
.field--full{grid-column:1 / -1;}
.field label{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-3);}
.field input,.field select,.field textarea{font-family:var(--sans);font-weight:300;font-size:1rem;color:var(--cream);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.16);padding:13px 15px;border-radius:2px;transition:border-color .3s,background .3s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold-2);background:rgba(255,255,255,.07);}
.field select option{color:#1a1611;}
.field textarea{resize:vertical;min-height:90px;}
.form-note{margin-top:12px;font-size:.9rem;color:var(--gold-3);min-height:1.2em;text-align:center;}
.form-note[data-state="err"]{color:#e7a99f;}
.form-note[data-state="ok"]{color:#a7d3a0;}

/* ------------------------------- hud ------------------------------ */
.hud{position:absolute;left:0;right:0;bottom:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:28px clamp(16px,4vw,40px) 18px;pointer-events:none;
  background:linear-gradient(to top,rgba(15,11,7,.6),transparent);}
.exp.on-light .hud{background:none;}
.hud__btn{pointer-events:auto;display:inline-flex;align-items:center;gap:8px;background:rgba(20,17,12,.55);color:#fff;
  border:1px solid var(--line-light);border-radius:999px;padding:11px 18px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  backdrop-filter:blur(6px);transition:background .3s,opacity .3s,border-color .3s;}
.hud__btn:hover{background:rgba(154,123,60,.85);border-color:transparent;}
.hud__btn svg{width:18px;height:18px;}
.hud__btn[disabled]{opacity:.32;cursor:not-allowed;}
.hud__prev{padding:11px 13px;}
.hud__center{pointer-events:auto;flex:1;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:8px;}
.hud__progress{width:100%;height:2px;background:rgba(255,255,255,.16);overflow:hidden;border-radius:2px;}
.hud__progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-3));transition:width .5s var(--ease);}
.hud__count{font-size:.7rem;letter-spacing:.18em;color:rgba(255,253,248,.7);}
/* on cream slides, darken hud text for contrast */
.exp.on-light .hud__count{color:rgba(26,22,17,.6);}
.exp.on-light .hud__progress{background:rgba(26,22,17,.14);}
.exp.on-light .hud__btn{background:rgba(255,253,248,.7);color:var(--ink);border-color:var(--line);}
.exp.on-light .hud__btn:hover{background:var(--gold);color:#1a1306;}


/* ------------------------- opening gate --------------------------- */
.gate{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(120% 90% at 70% 12%,rgba(196,164,92,.16),transparent 55%),linear-gradient(155deg,#1a1610,#2b2118);
  transition:opacity .5s var(--ease),visibility .5s;}
.gate.is-hidden{opacity:0;visibility:hidden;}
.gate[hidden]{display:none;}
.gate__card{width:min(460px,92vw);text-align:center;color:var(--cream);}
.gate__k{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-3);margin-bottom:1.1em;}
.gate__title{font-family:var(--serif);font-weight:400;font-size:clamp(2rem,5vw,2.8rem);line-height:1.05;}
.gate__sub{color:rgba(255,253,248,.74);margin:.8em auto 0;max-width:40ch;font-size:.95rem;}
.gate__form{display:flex;flex-direction:column;gap:14px;margin-top:1.9em;text-align:left;}
.gate__form .btn{margin-top:.5em;}
.gate__form .form-note{text-align:center;}
.gate__skip{align-self:center;background:none;border:0;color:rgba(255,253,248,.6);font-family:var(--sans);font-size:.8rem;letter-spacing:.05em;text-decoration:underline;text-underline-offset:3px;transition:color .25s;}
.gate__skip:hover{color:var(--gold-3);}

/* ------------------------- full-screen ---------------------------- */
.fs-toggle{position:absolute;top:16px;right:clamp(16px,4vw,40px);z-index:25;display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;background:rgba(20,17,12,.55);color:#fff;border:1px solid var(--line-light);border-radius:999px;
  backdrop-filter:blur(6px);transition:background .3s,border-color .3s;}
.fs-toggle:hover{background:rgba(154,123,60,.85);border-color:transparent;}
.fs-toggle svg{width:18px;height:18px;}
.fs-toggle .fs-exit{display:none;}
.fs-toggle.is-on .fs-enter{display:none;}
.fs-toggle.is-on .fs-exit{display:block;}
.exp.on-light .fs-toggle{background:rgba(255,253,248,.7);color:var(--ink);border-color:var(--line);}
.exp.on-light .fs-toggle:hover{background:var(--gold);color:#1a1306;}

/* hide HUD nav text on small screens */
@media (max-width:560px){
  .hud__next span{display:none;}
  .hud__next{padding:11px 13px;}
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  .slide{transition:none;}
  .rec-pop,.rec-card{transition:opacity .2s;}
  .opt__n,.hud__progress span{transition:none;}
}
