:root{--rose:#B5294E;--gold:#C09228;--maroon:#7B1A35;--ivory:#FDFAF6;--ink:#1A0A10;--muted:#8B6070;--bd:rgba(176,146,40,.2);--grey:#F4F4F6;--green:#1A7A3A}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:linear-gradient(180deg,#FDFAF6 0%,#F4F4F6 100%);color:var(--ink);min-height:100vh}
nav{position:sticky;top:0;z-index:20;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;background:rgba(253,250,246,.96);border-bottom:1px solid var(--bd);backdrop-filter:blur(12px)}
.brand{font-family:'Playfair Display',serif;font-size:1.45rem;font-weight:900;color:var(--maroon);cursor:pointer}.brand span{color:var(--gold)}
.nav-actions{display:flex;gap:.7rem;align-items:center}.nav-actions a{color:var(--muted);text-decoration:none;font-weight:700;font-size:.84rem;padding:.45rem .8rem;border-radius:4px}.nav-actions a:hover{background:#fff;color:var(--rose)}
.page{max-width:1180px;margin:0 auto;padding:2rem 1.5rem 4rem}
.hero-panel{display:grid;grid-template-columns:1fr 170px;gap:1.5rem;align-items:center;background:linear-gradient(135deg,#1A0A10,var(--maroon));border-radius:8px;padding:2rem;color:#fff;box-shadow:0 14px 44px rgba(123,26,53,.18)}
.eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:800;color:var(--gold);margin-bottom:.6rem}
h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);line-height:1.05;margin-bottom:.8rem}
.hero-panel p{max-width:760px;line-height:1.75;color:rgba(255,255,255,.72);font-size:.96rem}
.score-orb{height:142px;width:142px;border-radius:50%;justify-self:end;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(255,255,255,.11);border:2px solid rgba(255,255,255,.18);text-align:center}.score-orb span{font-family:'Playfair Display',serif;font-size:3rem;color:var(--gold);font-weight:900}.score-orb small{max-width:90px;color:rgba(255,255,255,.75);font-size:.72rem;line-height:1.3}
.layout{display:grid;grid-template-columns:270px 1fr;gap:1.5rem;margin-top:1.5rem;align-items:start}
.side,.card{background:#fff;border:1px solid var(--bd);border-radius:8px;box-shadow:0 8px 30px rgba(123,26,53,.07)}
.side{position:sticky;top:82px;padding:1rem}.side-title{font-family:'Playfair Display',serif;color:var(--maroon);font-weight:800;margin-bottom:.8rem}.section-list{display:flex;flex-direction:column;gap:.45rem}.section-pill{border:1px solid #EAD9E4;background:var(--ivory);border-radius:5px;padding:.65rem .75rem;font-size:.8rem;color:var(--muted);font-weight:700}.section-pill.done{border-color:rgba(26,122,58,.28);background:#EDF7F1;color:var(--green)}.section-pill.active{border-color:var(--rose);background:#FCF0F3;color:var(--rose)}
.side-note{margin-top:1rem;border-top:1px solid var(--bd);padding-top:.9rem;font-size:.78rem;line-height:1.6;color:var(--muted)}
.card{min-height:420px;padding:1.5rem}.loading{text-align:center;color:var(--muted);padding:5rem 1rem}
.consent-title,.result-title,.quiz-title{font-family:'Playfair Display',serif;color:var(--maroon);font-size:1.75rem;font-weight:800;margin-bottom:.5rem}.consent-copy,.quiz-copy,.result-copy{color:var(--muted);line-height:1.75;font-size:.94rem;margin-bottom:1rem}
.consent-box{display:grid;gap:.8rem;margin:1.25rem 0}.consent-item{display:flex;gap:.75rem;align-items:flex-start;background:var(--ivory);border:1px solid var(--bd);padding:.9rem;border-radius:6px;color:var(--ink);line-height:1.55;font-size:.9rem}.consent-item span{color:var(--gold);font-weight:900}
.agree-line{display:flex;gap:.7rem;align-items:flex-start;margin:1rem 0;color:var(--ink);font-weight:700;font-size:.92rem}.agree-line input{margin-top:.18rem}
.btn-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.25rem}.btn{border:none;border-radius:4px;padding:.78rem 1.25rem;font-family:'DM Sans',sans-serif;font-weight:800;font-size:.88rem;cursor:pointer}.btn.primary{background:var(--maroon);color:#fff}.btn.primary:hover{background:var(--rose)}.btn.secondary{background:#fff;color:var(--maroon);border:1.5px solid var(--maroon)}.btn:disabled{opacity:.55;cursor:not-allowed}
.progress-wrap{margin:1rem 0 1.35rem}.progress-top{display:flex;justify-content:space-between;color:var(--muted);font-size:.78rem;font-weight:700;margin-bottom:.45rem}.progress{height:8px;border-radius:10px;background:#F0E3E9;overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--rose));width:0;transition:width .2s}
.question-list{display:grid;gap:1rem}.question{border:1px solid var(--bd);border-radius:7px;padding:1rem;background:var(--ivory)}.q-text{font-weight:700;color:var(--ink);line-height:1.55;margin-bottom:.85rem}.scale{display:grid;grid-template-columns:repeat(5,1fr);gap:.45rem}.scale button{min-height:46px;padding:.45rem;border:1px solid #EAD9E4;background:#fff;border-radius:5px;color:var(--muted);font-weight:800;font-size:.76rem;line-height:1.2;text-align:center;cursor:pointer;white-space:normal;word-break:break-word}.scale button.on{background:var(--rose);border-color:var(--rose);color:#fff}.scale button:hover{border-color:var(--rose)}
.result-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;margin-top:1rem}.result-item{background:var(--ivory);border:1px solid var(--bd);border-radius:6px;padding:.9rem}.result-item b{display:block;color:var(--maroon);margin-bottom:.3rem}.meter{height:7px;background:#F0E3E9;border-radius:8px;overflow:hidden;margin-top:.45rem}.meter span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--rose))}
.status{margin-top:1rem;padding:.8rem 1rem;border-radius:5px;font-size:.88rem;line-height:1.6}.status.ok{background:#EDF7F1;color:var(--green);border:1px solid rgba(26,122,58,.18)}.status.err{background:#FFF0F0;color:#9B1C1C;border:1px solid rgba(155,28,28,.18)}
@media(max-width:860px){nav{padding:0 1rem}.layout{grid-template-columns:1fr}.side{position:static}.hero-panel{grid-template-columns:1fr}.score-orb{justify-self:start}.scale{grid-template-columns:1fr}.scale-labels{display:none}.result-grid{grid-template-columns:1fr}}

@media(max-width:640px){
  html,body{overflow-x:hidden}
  nav{height:58px;padding:0 .9rem}
  .brand{font-size:1.18rem}
  .nav-actions{gap:.35rem}
  .nav-actions a{padding:.42rem .45rem;font-size:.74rem}
  .nav-actions a:nth-child(2){display:none}
  .page{padding:1rem .85rem 2.5rem}
  .hero-panel{padding:1rem;border-radius:8px;gap:1rem}
  h1{font-size:1.9rem}
  .hero-panel p{font-size:.86rem;line-height:1.6}
  .score-orb{width:106px;height:106px}
  .score-orb span{font-size:2.1rem}
  .layout{gap:1rem;margin-top:1rem}
  .side,.card{border-radius:8px}
  .side{padding:.85rem}
  .section-list{display:flex;flex-direction:row;overflow-x:auto;padding-bottom:.25rem}
  .section-pill{min-width:150px}
  .side-note{display:none}
  .card{min-height:auto;padding:1rem}
  .consent-title,.result-title,.quiz-title{font-size:1.35rem;line-height:1.2}
  .consent-copy,.quiz-copy,.result-copy{font-size:.86rem;line-height:1.6}
  .consent-item{padding:.8rem;font-size:.84rem}
  .btn-row{display:grid;grid-template-columns:1fr;gap:.55rem}
  .btn{width:100%;min-height:44px}
  .question{padding:.85rem}
  .q-text{font-size:.9rem}
  .scale{gap:.4rem}
  .scale button{min-height:42px}
}
