/* EB Hypnose — Design System Quiz v2 · Forest + Cream + Vermillion */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&family=Manrope:wght@400;500;600;700&family=Caveat:wght@500&display=swap');

:root{
  /* Remap old tokens → new palette */
  --p:      #c93b1f;
  --pc:     #e87059;
  --pf:     rgba(201,59,31,.08);
  --pb:     rgba(201,59,31,.22);
  --s:      #f4ecdf;
  --sl:     #faf6ef;
  --sm:     #e6d9c4;
  --sw:     #fff;
  --os:     #1a1916;
  --osv:    #6a6155;
  --ov:     rgba(244,236,223,.6);
  --t:      #2a3a2c;
  --tc:     #3d4f3f;
  --serif:  'Cormorant Garamond', Georgia, serif;
  --sans:   'Manrope', system-ui, sans-serif;
  --hand:   'Caveat', cursive;
  --forest: #2a3a2c;
  --forest-dk: #1d2a1f;
  --vermil: #c93b1f;
  --cream:  #f4ecdf;
  --ink:    #1a1916;
  --mute:   #6a6155;
  --rule:   #bcb09c;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--s);color:var(--os);overflow-x:hidden;line-height:1.7;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
::selection{background:var(--vermil);color:#fff}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-thumb{background:var(--vermil)}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.015)}}
@keyframes radarDraw{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(244,236,223,.95);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(188,176,156,.35);
  transition:box-shadow .3s;
}
.nav-inner{
  max-width:1280px;margin:0 auto;padding:0 44px;height:68px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  font-family:var(--serif);font-size:1.2rem;font-style:italic;
  color:var(--forest);font-weight:500;letter-spacing:-.01em;
}
.nav-back{
  display:flex;align-items:center;gap:8px;
  font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--mute);transition:color .2s;
}
.nav-back:hover{color:var(--vermil)}
.nav-back i{font-size:.68rem}
@media(max-width:820px){.nav-inner{padding:0 20px}}

/* ── HERO ── */
.divider{width:100%;height:1px;background:linear-gradient(to right,transparent,rgba(188,176,156,.3),transparent)}

.hero{
  min-height:78vh;display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:120px 24px 72px;text-align:center;
  position:relative;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;top:-10%;left:50%;transform:translateX(-50%);
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(201,59,31,.05) 0%,transparent 65%);
  pointer-events:none;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid var(--pb);padding:7px 20px;
  font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--vermil);margin-bottom:44px;
  animation:fadeUp .8s ease both;
}
.hero-badge span{width:5px;height:5px;background:var(--vermil)}
.hero-eyebrow{
  font-family:var(--hand);font-size:20px;color:var(--mute);
  margin-bottom:12px;animation:fadeUp .85s .05s ease both;
  display:inline-flex;align-items:center;gap:10px;
}
.hero-eyebrow::before{content:'';display:inline-block;width:20px;height:1px;background:currentColor;opacity:.5}
.hero-title{
  font-family:var(--serif);font-size:clamp(2rem,5.5vw,4.2rem);
  font-weight:300;line-height:1.15;max-width:760px;
  margin-bottom:22px;animation:fadeUp .9s .1s ease both;
  color:var(--os);letter-spacing:-.03em;
}
.hero-title em{font-style:italic;color:var(--vermil)}
.hero-sub{
  font-size:.95rem;color:var(--osv);max-width:500px;
  margin-bottom:38px;animation:fadeUp 1s .15s ease both;
  font-style:italic;line-height:1.72;
}
.hero-instructions{display:flex;flex-direction:column;gap:9px;margin-bottom:52px;animation:fadeUp 1.1s .2s ease both}
.hero-instr-item{display:flex;align-items:center;gap:11px;font-size:.85rem;color:var(--osv)}
.hero-instr-item::before{content:"→";color:var(--vermil);font-size:.8rem}
.btn-start{
  display:inline-flex;align-items:center;gap:11px;
  background:var(--forest);color:var(--cream);
  font-family:var(--sans);font-size:.74rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:16px 40px;border:none;cursor:pointer;
  transition:opacity .2s;
  animation:fadeUp 1.2s .3s ease both;
  animation-fill-mode:both;
}
.btn-start:hover{opacity:.88}

/* ── PROGRESS ── */
.quiz-progress{
  position:sticky;top:68px;z-index:90;
  background:rgba(244,236,223,.96);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(188,176,156,.3);
  padding:12px 24px;display:none;
}
.quiz-progress.visible{display:block}
.progress-inner{max-width:760px;margin:0 auto;display:flex;align-items:center;gap:14px}
.progress-label{font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);white-space:nowrap}
.progress-track{flex:1;height:2px;background:var(--sm);overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--forest),var(--vermil));transition:width .5s ease;width:0%}
.progress-count{font-size:.72rem;color:var(--vermil);white-space:nowrap}

/* ── QUIZ SECTION ── */
.quiz-section{max-width:760px;margin:0 auto;padding:50px 24px 80px;display:none}
.quiz-section.visible{display:block}
.question-block{margin-bottom:50px;opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.question-block.revealed{opacity:1;transform:translateY(0)}
.question-header{display:flex;align-items:baseline;gap:14px;margin-bottom:22px}
.question-num{font-family:var(--serif);font-style:italic;font-size:.72rem;color:var(--vermil);min-width:22px;padding-top:2px;font-weight:500}
.question-text{font-family:var(--serif);font-size:clamp(1.05rem,2.2vw,1.35rem);font-style:italic;color:var(--os);line-height:1.45}
.choices{display:flex;flex-direction:column;gap:9px;padding-left:36px}
.choice-btn{
  display:flex;align-items:flex-start;gap:12px;padding:15px 20px;
  background:var(--sl);border:1.5px solid rgba(188,176,156,.35);
  color:var(--osv);font-family:var(--sans);font-size:.88rem;
  font-weight:400;text-align:left;cursor:pointer;
  transition:all .2s;line-height:1.55;width:100%;
}
.choice-btn:hover:not(.selected){background:var(--sm);border-color:var(--pb)}
.choice-dot{width:14px;height:14px;border:1.5px solid rgba(188,176,156,.5);flex-shrink:0;margin-top:4px;transition:all .2s}
.choice-btn.selected{background:var(--pf);border-color:var(--pb);color:var(--os)}
.choice-btn.selected .choice-dot{background:var(--vermil);border-color:var(--vermil);box-shadow:inset 0 0 0 3px var(--pf)}
.q-divider{width:100%;height:1px;background:linear-gradient(to right,transparent,rgba(188,176,156,.3),transparent);margin:0 0 50px}
.quiz-submit-wrap{text-align:center;padding:20px 0 60px;display:none}
.quiz-submit-wrap.visible{display:block;animation:fadeUp .5s ease both}
.btn-submit{
  display:inline-flex;align-items:center;gap:11px;
  background:var(--vermil);color:#fff;
  font-family:var(--sans);font-size:.74rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:18px 46px;border:none;cursor:pointer;
  transition:opacity .2s;animation:breathe 4s ease-in-out infinite;
}
.btn-submit:hover{opacity:.9}
.quiz-submit-note{margin-top:12px;font-size:.8rem;color:var(--osv);font-style:italic}

/* ── RESULT ── */
.result-section{display:none;padding:80px 24px;position:relative}
.result-section.visible{display:block;animation:fadeUp .7s ease both}
.result-inner{max-width:760px;margin:0 auto}
.result-eyebrow{
  font-family:var(--hand);font-size:22px;color:var(--vermil);
  display:flex;align-items:center;gap:14px;margin-bottom:18px;justify-content:center;
}
.result-eyebrow::before,.result-eyebrow::after{content:'';display:inline-block;width:28px;height:1px;background:var(--vermil)}
.result-title{
  font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);
  font-weight:300;line-height:1.2;text-align:center;
  margin-bottom:14px;color:var(--os);letter-spacing:-.02em;
}
.result-title em{font-style:italic;color:var(--vermil)}
.result-desc{font-size:.92rem;color:var(--osv);max-width:520px;margin:0 auto 40px;text-align:center;line-height:1.75;font-style:italic}
.radar-wrap{
  background:var(--sw);border:1px solid var(--pb);
  padding:36px 20px;margin:0 auto 32px;max-width:560px;
  box-shadow:0 4px 24px rgba(42,58,44,.06);position:relative;
}
.radar-wrap::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--vermil),transparent)}
.radar-svg{width:100%;height:auto;max-width:480px;margin:0 auto;display:block;animation:radarDraw .9s ease both}
.radar-legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:30px}
.legend-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--sl)}
.legend-dot{width:10px;height:10px;flex-shrink:0;background:var(--vermil)}
.legend-label{font-size:.82rem;color:var(--os);flex:1}
.legend-pct{font-family:var(--serif);font-style:italic;font-size:.95rem;color:var(--vermil)}
.dominant-card{
  background:var(--pf);border:1px solid var(--pb);
  padding:22px 26px;margin:24px 0;border-left:3px solid var(--vermil);
}
.dominant-label{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--osv);margin-bottom:6px}
.dominant-name{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--vermil);margin-bottom:10px}
.dominant-text{font-size:.9rem;color:var(--os);line-height:1.7}

/* ── FORM ── */
.form-section{display:none;padding:60px 24px 80px;position:relative}
.form-section.visible{display:block;animation:fadeUp .7s ease both}
.form-section::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--pb),transparent)}
.form-inner{max-width:540px;margin:0 auto;text-align:center}
.form-eyebrow{font-family:var(--hand);font-size:20px;color:var(--vermil);margin-bottom:18px;display:block}
.form-title{font-family:var(--serif);font-size:clamp(1.5rem,3.2vw,2.4rem);font-weight:300;line-height:1.25;margin-bottom:14px;color:var(--os)}
.form-title em{font-style:italic;color:var(--vermil)}
.form-desc{font-size:.9rem;color:var(--osv);margin-bottom:36px;line-height:1.75}
.form-fields-block{display:flex;flex-direction:column;gap:9px}
.form-input{
  background:transparent;border:none;
  border-bottom:1.5px solid rgba(188,176,156,.5);
  color:var(--os);font-family:var(--sans);font-size:.9rem;
  padding:11px 0;outline:none;width:100%;transition:border-color .2s;
}
.form-input:focus{border-color:var(--vermil)}
.form-input::placeholder{color:rgba(188,176,156,.8)}
.form-submit-block{
  width:100%;background:var(--forest);border:none;
  color:var(--cream);font-family:var(--sans);font-size:.74rem;
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:16px 28px;cursor:pointer;transition:opacity .2s;
  margin-top:14px;display:flex;align-items:center;justify-content:center;gap:9px;
}
.form-submit-block:hover{opacity:.88}
.form-submit-block:disabled{opacity:.45;cursor:not-allowed}
.form-note-block{font-size:.76rem;color:var(--osv);margin-top:12px;font-style:italic}
.form-error{color:#c93b1f;font-size:.82rem;margin-top:10px;display:none}
.form-error.show{display:block}

/* ── SUCCESS ── */
.success-section{display:none;padding:80px 24px;text-align:center;animation:fadeUp .6s ease both}
.success-section.visible{display:block}
.success-inner{max-width:560px;margin:0 auto}
.success-icon{
  width:64px;height:64px;background:var(--pf);border:1px solid var(--pb);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;color:var(--vermil);margin:0 auto 24px;
}
.success-eyebrow{font-family:var(--hand);font-size:20px;color:var(--vermil);margin-bottom:14px;display:block}
.success-title{font-family:var(--serif);font-size:clamp(1.8rem,3.8vw,2.8rem);font-weight:300;line-height:1.2;margin-bottom:18px;color:var(--os)}
.success-title em{font-style:italic;color:var(--vermil)}
.success-desc{font-size:.95rem;color:var(--osv);line-height:1.75;margin-bottom:30px}
.success-quote{border-left:2px solid var(--vermil);padding:20px 24px;background:var(--pf);text-align:left;margin:24px 0}
.success-quote p{font-family:var(--serif);font-style:italic;font-size:1rem;line-height:1.7;color:var(--os)}

/* ── FOOTER ── */
.footer{background:var(--forest-dk, #1d2a1f);padding:32px 24px;text-align:center;border-top:1px solid rgba(244,236,223,.08)}
.footer-brand{font-family:var(--serif);font-style:italic;font-size:.9rem;color:rgba(244,236,223,.85);margin-bottom:6px}
.footer-link{font-size:.76rem;color:var(--vermil);text-decoration:none;opacity:.8;transition:opacity .2s}
.footer-link:hover{opacity:1}

/* ── DESKTOP ── */
@media(min-width:821px){
  .hero{padding:140px 32px 90px}
  .hero-title{font-size:clamp(2.6rem,5.5vw,4.4rem)}
  .hero-sub{font-size:1.02rem;max-width:560px}
  .hero-instr-item{font-size:.92rem}

  .quiz-section{max-width:920px;padding:70px 32px 100px}
  .question-block{
    background:var(--sw);border:1.5px solid rgba(201,59,31,.18);
    padding:40px 46px;margin-bottom:28px;
    box-shadow:0 4px 20px rgba(42,58,44,.06);
    transition:opacity .6s ease,transform .6s ease,box-shadow .25s ease,border-color .25s ease;
  }
  .question-block::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg,transparent,var(--vermil),transparent);
  }
  .question-block{position:relative}
  .question-block:hover{border-color:rgba(201,59,31,.35);box-shadow:0 6px 28px rgba(42,58,44,.1)}
  .question-block .q-divider{display:none}
  .question-header{margin-bottom:28px}
  .question-text{font-size:1.4rem;line-height:1.4}
  .choices{padding-left:0;gap:11px}
  .choice-btn{border:1.5px solid rgba(201,59,31,.15);padding:17px 22px;font-size:.92rem;background:var(--s)}
  .choice-btn:hover:not(.selected){border-color:rgba(201,59,31,.4);background:var(--sl)}
  .choice-btn.selected{border-color:var(--vermil);border-width:2px;background:var(--pf)}
  .choice-dot{width:16px;height:16px;border-width:1.5px}

  .result-section{padding:100px 32px}
  .result-inner{max-width:900px}
  .result-title{font-size:clamp(2.2rem,4vw,3.4rem)}
  .result-desc{font-size:1rem;max-width:600px}
  .radar-wrap{max-width:720px;padding:52px 44px;border-width:1.5px}
  .radar-svg{max-width:600px}
  .radar-legend{gap:12px;margin-top:36px}
  .legend-item{padding:13px 16px;border:1px solid rgba(201,59,31,.15)}
  .legend-label{font-size:.88rem}
  .legend-pct{font-size:1.05rem}
  .dominant-card{padding:30px 34px;border-left:4px solid var(--vermil)}
  .dominant-name{font-size:1.4rem}
  .dominant-text{font-size:.95rem}

  .form-section{padding:80px 32px 100px}
  .form-inner{max-width:600px;background:var(--sw);border:1.5px solid rgba(201,59,31,.18);padding:50px 48px;box-shadow:0 4px 20px rgba(42,58,44,.06)}
  .form-title{font-size:clamp(1.8rem,3.2vw,2.7rem)}
  .form-desc{font-size:.95rem}
  .form-input{font-size:.95rem;padding:13px 0}
  .form-submit-block{padding:18px 32px;font-size:.78rem}

  .success-inner{max-width:640px}
  .success-quote{padding:24px 28px;border-left-width:3px}
}

/* ── MOBILE ── */
@media(max-width:820px){
  .nav-inner{padding:0 20px}
  .hero{padding:100px 20px 60px}
  .choices{padding-left:0}
  .question-header{flex-direction:column;gap:6px;margin-bottom:16px}
  .radar-wrap{padding:24px 12px}
}

@media(max-width:400px){
  .hero-title{font-size:1.6rem}
  .form-input{font-size:16px}
}
