*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --red:#C0392B;--red-dark:#7B1A0D;--red-light:#FAECE7;--red-mid:#E07060;
  --now:#2A7F7F;--now-light:#E6F1FB;
  --fut:#C0392B;--fut-light:#FAEEDA;
  --ink:#1a1a18;--ink2:#4a4a46;--ink3:#8a8a84;--ink4:#c2c0b6;
  --bg:#f7f6f2;--surface:#ffffff;
  --border:rgba(0,0,0,0.09);--border2:rgba(0,0,0,0.05);
  --r:12px;--rsm:8px;
  --btn-hover-orange: #fca83a;
  --btn-hover-blue: #3d9e9e;
}

html{font-size:16px}
body{font-family:'Nunito',sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;min-height:100vh}

.page{display:flex;flex-direction:column;max-width:820px;margin:0 auto;min-height:100vh}

header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;background:var(--surface);border-bottom:1px solid var(--border2);
  height:60px;flex-shrink:0;
}
.logo{display:flex;align-items:center;gap:9px;text-decoration:none}
.logo-img{height:36px;width:auto;display:block;object-fit:contain}
.logo-text{font-family:'Nunito',serif;font-size:20px;color:var(--ink);letter-spacing:-.02em}
.logo-text em{font-style:italic;color:var(--red)}
.hdr-meta{font-size:11px;color:var(--ink3);text-align:right;line-height:1.5}
.hdr-meta strong{color:var(--ink2);font-weight:500}

main{padding:24px 24px 80px}

.flow-steps{display:flex;align-items:center;margin-bottom:24px}
.flow-step{display:flex;flex-direction:column;align-items:center;gap:4px}
.fs-num{width:28px;height:28px;border-radius:7px;border:1.5px solid var(--red);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--red);background:var(--surface)}
.flow-step.active .fs-num{background:var(--red);color:#fff}
.flow-step.done .fs-num{background:var(--red);color:#fff;border-color:var(--red)}
.fs-lbl{font-size:10px;color:var(--ink3);text-align:center;line-height:1.3}
.flow-step.active .fs-lbl{color:var(--red);font-weight:500}
.flow-step.done .fs-lbl{color:var(--red-dark)}
.flow-line{flex:1;height:1px;background:#ddd;margin:0 8px;margin-bottom:14px}
.flow-line.active{background:var(--red)}

.intro{margin-bottom:20px}
.intro h1{font-family:'Nunito',serif;font-size:26px;font-weight:400;letter-spacing:-.02em;line-height:1.2;margin-bottom:7px}
.intro p{font-size:13px;color:var(--ink2);max-width: 100%;line-height:1.65}

.prog-row{display:flex;justify-content:space-between;font-size:11px;color:var(--ink3);margin-bottom:4px}
.prog-row strong{color:var(--ink2);font-weight:500}
.prog-track{height:3px;background:var(--border2);border-radius:99px;overflow:hidden;margin-bottom:16px}
.prog-fill{height:100%;background:var(--red);border-radius:99px;width:0%;transition:width .4s}

.steps{display:flex;gap:5px;margin-bottom:18px}
.step{flex:1;padding:8px 8px 7px;border:1px solid var(--border);border-radius:var(--rsm);background:var(--surface);font-family:'Nunito',sans-serif;font-size:11px;font-weight:500;color:var(--ink3);cursor:pointer;text-align:center;transition:all .18s;display:flex;flex-direction:column;align-items:center;gap:3px}
.step .ico{font-size:14px}
.step.active{border-color:var(--red);color:var(--red-dark);background:var(--red-light)}
.step.done{border-color:var(--red-mid);background:var(--bg);color:var(--red-dark)}

.card{background:var(--surface);border-radius:var(--r);border:1px solid var(--border2);box-shadow:0 1px 3px rgba(0,0,0,.05),0 4px 14px rgba(0,0,0,.03);display:none;margin-bottom:12px}
.card.on{display:block}
.card-head{display:flex;align-items:center;gap:12px;padding:16px 20px 12px;border-bottom:1px solid var(--border2)}
.theme-badge{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.theme-name{font-family:'Nunito',serif;font-size:18px;font-weight:400;letter-spacing:-.01em}
.theme-sub{font-size:11px;color:var(--ink3);margin-top:1px}
.tip-btn{margin-left:auto;font-family:'Nunito',sans-serif;font-size:11px;padding:3px 9px;border-radius:99px;border:1px solid var(--border);background:var(--bg);color:var(--ink3);cursor:pointer;flex-shrink:0;transition:all .15s;white-space:nowrap}
.tip-btn:hover{border-color:var(--ink3);color:var(--ink2)}
.def{margin:0 20px;padding:10px 12px;background:var(--bg);border-radius:var(--rsm);border-left:3px solid var(--border);font-family:Nunito;font-size:11px;color:var(--ink3);line-height:1.6;display:none}
.def.open{display:block}

.qs{padding:0 20px 20px}
.q{padding:14px 0;border-top:1px solid var(--border2)}
.q:first-child{border-top:none;padding-top:0}
.q-tag{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.q-text{font-size:13px;color:var(--ink);line-height:1.5;margin-bottom:12px}
.pair{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pcol-label{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px;display:flex;align-items:center;gap:4px}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}
.now-lbl{color:var(--now)}.fut-lbl{color:var(--fut)}
.srow{display:flex;align-items:center;gap:7px}
.sval{font-size:12px;font-weight:500;min-width:26px;text-align:right}
.now-sval{color:var(--now)}.fut-sval{color:var(--fut)}

input[type=range]{-webkit-appearance:none;appearance:none;flex:1;height:6px;border-radius:99px;cursor:pointer;outline:none;margin:0;border:none}
input[type=range].nr{background:linear-gradient(to right,var(--now) 50%,#dde4ed 50%)}
input[type=range].fr{background:linear-gradient(to right,var(--fut) 50%,#ede8dc 50%)}
input[type=range].nr::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--now);border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.2);cursor:pointer;transition:transform .1s}
input[type=range].fr::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--fut);border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.2);cursor:pointer;transition:transform .1s}
input[type=range].nr:hover::-webkit-slider-thumb,input[type=range].fr:hover::-webkit-slider-thumb{transform:scale(1.1)}
input[type=range]::-moz-range-track{height:6px;border-radius:99px;background:#e0ddd6}
input[type=range].nr::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--now);border:2px solid #fff}
input[type=range].fr::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--fut);border:2px solid #fff}

.submit-card{display:none;background:var(--surface);border-radius:var(--r);border:1px solid var(--border2);padding:28px;text-align:center;margin-bottom:14px}
.submit-card.on{display:block}
.submit-card h2{font-family:'Nunito',serif;font-size:22px;font-weight:400;margin-bottom:8px;letter-spacing:-.01em}
.submit-card p{font-size:13px;color:var(--ink2);margin-bottom:18px}

.fnav{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--border2)}
.btn-back{font-family:'Nunito',sans-serif;font-size:13px;padding:9px 18px;border-radius:var(--rsm);border:1px solid var(--border);background:var(--now);color:var(--surface);cursor:pointer;transition:all .15s;text-decoration:none;display:inline-flex;align-items:center}
.btn-back:hover{background:var(--btn-hover-blue);}
.btn-next{font-family:'Nunito',sans-serif;font-size:13px;font-weight:500;padding:9px 22px;border-radius:var(--rsm);border:none;background:var(--red);color:#fff;cursor:pointer;transition:all .15s}
.btn-next:hover{background:var(--btn-hover-orange)}
.btn-sub{font-family:'Nunito',sans-serif;font-size:14px;font-weight:500;padding:11px 28px;border-radius:var(--rsm);border:none;background:var(--red);color:#fff;cursor:pointer;transition:all .2s}
.btn-sub:hover{background:var(--btn-hover-orange);transform:translateY(-1px)}
.nav-hint{font-size:11px;color:var(--ink3)}

.survey-card{background:var(--surface);border-radius:var(--r);border:1px solid var(--border2);box-shadow:0 1px 3px rgba(0,0,0,.05),0 4px 14px rgba(0,0,0,.03);padding:24px}
.section-label{font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--red);margin:20px 0 10px}
.section-label:first-child{margin-top:0}
.field{margin-bottom:12px}
.field label{display:block;font-size:13px;color:var(--ink2);margin-bottom:4px}
.req{color:var(--red)}
.field input,.field textarea{width:100%;background:var(--surface);border:1px solid #ccc;border-radius:var(--rsm);padding:9px 12px;font-size:14px;color:var(--ink);outline:none;transition:border-color .15s;font-family:inherit}
.field input:focus,.field textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(192,57,43,.08)}
.field input.invalid,.field textarea.invalid{border-color:var(--red);background:#fff9f9}
.field textarea{resize:vertical;min-height:80px;line-height:1.5}
.field input, .field textarea, .field select {
  background: #fff3cd;
  color: #1a1a18;
  border-color: var(--red);
}
.hint{font-size:11px;color:var(--ink3);margin-top:3px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sdivider{border:none;border-top:1px solid var(--border2);margin:16px 0}
.error-box{background:#fff0ee;border:1px solid #f5c6c0;border-radius:var(--rsm);padding:12px 16px;margin-bottom:16px;font-size:13px;color:var(--red-dark)}

/* ── Results page ── */
.results-page{max-width:960px}
.results-main{padding:24px 24px 80px}

.result-banner{background:var(--red-light);border-radius:var(--r);padding:20px 24px;margin-bottom:16px;border:1px solid rgba(192,57,43,.15)}
.result-banner-inner{display:flex;align-items:center;gap:16px}
.result-emoji{font-size:36px}
.result-greeting{font-family:'Nunito',serif;font-size:22px;font-weight:400;color:var(--red-dark);letter-spacing:-.01em}
.result-subtitle{font-size:13px;color:var(--ink2);margin-top:2px}

.result-meta{font-size:12px;color:var(--ink3);margin-bottom:20px;display:flex;align-items:center;flex-wrap:wrap;gap:4px}
.meta-sep{color:var(--ink4)}

/* Two radars side by side */
.results-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-bottom:20px;
  align-items:start;
}
.results-diagram-col{min-width:0}

/* Scores panel full width below radars */
.results-scores-row{
  margin-bottom:20px;
}

.scores-inline{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin:10px 0;
}

.result-card{background:var(--surface);border-radius:var(--r);border:1px solid var(--border2);box-shadow:0 1px 3px rgba(0,0,0,.05);padding:20px}
.result-card-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:12px}

.highlight-card{background:var(--red-light);border-radius:var(--r);border:1px solid rgba(192,57,43,.2);padding:16px;margin-bottom:10px}
.highlight-label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.07em;color:var(--red-dark);margin-bottom:4px}
.highlight-value{font-family:'Nunito',serif;font-size:22px;color:var(--red-dark);letter-spacing:-.01em}
.highlight-delta{font-size:16px;color:var(--red)}
.highlight-sub{font-size:11px;color:var(--red-dark);margin-top:2px;opacity:.8}

.score-card{background:var(--surface);border-radius:var(--rsm);border:1px solid var(--border2);padding:12px 14px}
.score-card-head{display:flex;align-items:center;gap:7px;margin-bottom:8px}
.score-icon{font-size:14px}
.score-label{font-size:13px;font-weight:500;color:var(--ink);flex:1}
.score-delta{font-size:12px;font-weight:500;padding:2px 7px;border-radius:99px}
.score-delta.pos{background:#E1F5EE;color:#085041}
.score-delta.neg{background:#FCEBEB;color:#7B1A0D}
.score-bars{display:flex;flex-direction:column;gap:6px}
.score-bar-row{display:flex;align-items:center;gap:8px}
.score-bar-lbl{font-size:10px;font-weight:500;min-width:28px}
.score-bar-track{flex:1;height:6px;background:var(--border2);border-radius:99px;overflow:hidden}
.score-bar-fill{height:100%;border-radius:99px;transition:width .6s ease}
.score-bar-val{font-size:11px;font-weight:500;min-width:24px;text-align:right}

.diagram-legend{display:flex;gap:14px;font-size:11px;color:var(--ink3);margin-top:10px;align-items:center}
.leg-item{display:flex;align-items:center;gap:5px}

.result-actions{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.btn-print{font-family:'Nunito',sans-serif;font-size:13px;font-weight:500;padding:10px 18px;border-radius:var(--rsm);border:1px solid var(--border);background:var(--now);color:var(--surface);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px}
.btn-print:hover{background:var(--btn-hover-blue);}
.btn-restart{font-family:'Nunito',sans-serif;font-size:13px;padding:10px 18px;border-radius:var(--rsm);border:1px solid var(--border);background:var(--red);color:var(--surface);cursor:pointer;transition:all .15s;text-decoration:none;display:inline-flex;align-items:center}
.btn-restart:hover{background:var(--btn-hover-orange)}
.print-tip{font-size:11px;color:var(--ink4);margin-top:4px}

.daisy-wrap{width:100%}
.daisy-drow{display:grid;grid-template-columns:18px 1fr auto auto;align-items:center;gap:5px;font-size:11px;color:var(--ink2)}
.daisy-hdr{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--ink3);margin-bottom:3px}
.daisy-dnow{color:#185FA5;font-weight:600;min-width:24px;text-align:right}
.daisy-dfut{color:#B06D00;font-weight:600;min-width:24px;text-align:right}

.print-only{display:none}

.result-card-title-fancy {
  font-family: 'Nunito', serif;
  font-size: 20px;
  font-weight: 400;
  color: var(--ink);
  letter-spacing: -.02em;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--red-light);
}
.result-card-title-fancy em {
  font-style: italic;
  color: var(--red);
}

@media(max-width:640px){
  .pair{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
  .results-grid{grid-template-columns:1fr}
  .scores-inline{grid-template-columns:1fr}
  main{padding:16px 16px 60px}
}