*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#0d0d0d;--surface:#141414;--surface-el:#1a1a1a;
  --border:#2a2a2a;--text-pri:#f0ede8;--text-sec:#bbb7b2;
  --accent:#c4a882;--accent-hov:#d4b892;
}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text-pri);font-family:'Inter',sans-serif;font-weight:300;font-size:15px;line-height:1.7;min-height:100vh;}

.loading-overlay{display:none;position:fixed;inset:0;background:rgba(13,13,13,0.93);z-index:9999;align-items:center;justify-content:center;flex-direction:column;gap:20px;}
.loading-overlay.active{display:flex;}
.spinner{width:44px;height:44px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.loading-text{font-size:13px;letter-spacing:0.15em;color:var(--text-sec);}

.site-header{display:flex;align-items:center;justify-content:center;gap:14px;padding:22px 32px 18px;border-bottom:1px solid var(--border);}
.site-logo{height:30px;width:auto;}
.site-logo-text{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:13px;letter-spacing:0.35em;text-transform:uppercase;color:var(--accent);}

.progress-wrapper{max-width:680px;margin:28px auto 0;padding:0 24px;}
.progress-meta{display:flex;justify-content:space-between;margin-bottom:8px;}
.progress-label{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent);}
.progress-count{font-size:11px;color:var(--text-sec);}
.progress-track{height:2px;background:var(--border);border-radius:2px;overflow:hidden;}
.progress-fill{height:100%;background:var(--accent);transition:width 0.4s ease;}

.assessment-container{max-width:680px;margin:0 auto;padding:40px 24px 80px;}

.step{display:none;animation:fadeIn 0.3s ease;}
.step.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

.step-header{margin-bottom:36px;}
.step-eyebrow{display:block;font-size:10px;letter-spacing:0.35em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;}
.step-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:36px;line-height:1.2;color:var(--text-pri);margin-bottom:14px;}
.step-instructions{font-size:14px;color:var(--text-sec);line-height:1.75;}

.error-msg{display:none;background:rgba(180,60,60,0.12);border:1px solid rgba(180,60,60,0.3);color:#e08080;padding:12px 16px;border-radius:4px;font-size:13px;margin-bottom:20px;}
.error-msg.visible{display:block;}

.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;}
.field-row.single{grid-template-columns:1fr;}
.field-group{display:flex;flex-direction:column;gap:7px;}
label{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-sec);}
input[type=text],input[type=email],input[type=tel],textarea{background:var(--surface-el);border:1px solid var(--border);color:var(--text-pri);padding:12px 14px;border-radius:3px;font-family:'Inter',sans-serif;font-size:14px;font-weight:300;outline:none;transition:border-color 0.2s;width:100%;resize:vertical;}
input:focus,textarea:focus{border-color:var(--accent);}
input::placeholder,textarea::placeholder{color:#444;}

.ranking-container{margin-bottom:32px;}
.rank-item{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:12px 14px;margin-bottom:8px;cursor:grab;user-select:none;transition:border-color 0.2s,background 0.2s;}
.rank-item:active{cursor:grabbing;}
.rank-item.sortable-ghost{opacity:0.35;}
.rank-item.sortable-drag{background:var(--surface-el);border-color:var(--accent);box-shadow:0 4px 20px rgba(0,0,0,0.5);}
.rank-number{min-width:24px;text-align:center;font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--accent);font-weight:300;}
.rank-text{flex:1;font-size:14px;color:var(--text-pri);}
.rank-drag-handle{color:var(--border);font-size:18px;cursor:grab;line-height:1;}
.rank-arrows{display:none;flex-direction:column;gap:3px;}
.rank-arrow{background:none;border:1px solid var(--border);color:var(--text-sec);width:28px;height:24px;border-radius:3px;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;transition:border-color 0.2s,color 0.2s;}
.rank-arrow:hover{border-color:var(--accent);color:var(--accent);}

.sub-step{display:none;}
.sub-step.active{display:block;}
.sub-step-instruction{font-size:13px;color:var(--accent);letter-spacing:0.06em;margin-bottom:20px;padding:12px 16px;border-left:2px solid var(--accent);background:rgba(196,168,130,0.05);line-height:1.6;}
.cluster-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px;}
.cluster-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:16px;cursor:pointer;transition:border-color 0.2s,background 0.2s;position:relative;}
.cluster-card:hover{border-color:rgba(196,168,130,0.4);}
.cluster-card.selected{border-color:var(--accent);background:rgba(196,168,130,0.07);}
.cluster-card.dimmed{opacity:0.4;pointer-events:none;}
.cluster-letter{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--accent);font-weight:300;margin-bottom:4px;}
.cluster-name{font-size:13px;font-weight:400;color:var(--text-pri);margin-bottom:6px;}
.cluster-desc{font-size:12px;color:var(--text-sec);line-height:1.6;}
.cluster-check{position:absolute;top:10px;right:12px;font-size:16px;color:var(--accent);display:none;}
.cluster-card.selected .cluster-check{display:block;}

.q-group{margin-bottom:32px;}
.q-group-title{font-size:11px;letter-spacing:0.3em;text-transform:uppercase;color:var(--accent);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border);}
.q-item{margin-bottom:22px;}
.q-text{font-size:14px;color:var(--text-pri);margin-bottom:10px;line-height:1.65;}
.q-pills{display:flex;gap:8px;flex-wrap:wrap;}
.q-pill{background:var(--surface);border:1px solid var(--border);color:var(--text-sec);padding:8px 14px;border-radius:3px;cursor:pointer;font-size:13px;min-width:40px;text-align:center;transition:all 0.15s;font-family:'Inter',sans-serif;}
.q-pill:hover{border-color:var(--accent);color:var(--text-pri);}
.q-pill.selected{background:var(--accent);border-color:var(--accent);color:#0d0d0d;font-weight:400;}
.q-scale-labels{display:flex;justify-content:space-between;margin-top:5px;font-size:10px;color:var(--text-sec);letter-spacing:0.1em;}

.scenario{margin-bottom:40px;}
.scenario-num{font-size:10px;letter-spacing:0.3em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;}
.scenario-text{font-size:14px;color:var(--text-pri);line-height:1.75;margin-bottom:20px;padding:16px;background:var(--surface);border-left:2px solid var(--border);border-radius:0 4px 4px 0;}
.scenario-choices{margin-bottom:20px;}
.scenario-choice{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;margin-bottom:8px;border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:border-color 0.2s,background 0.2s;font-size:14px;color:var(--text-sec);}
.scenario-choice:hover{border-color:rgba(196,168,130,0.4);color:var(--text-pri);}
.scenario-choice.selected{border-color:var(--accent);background:rgba(196,168,130,0.07);color:var(--text-pri);}
.choice-letter{min-width:18px;font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--accent);line-height:1.3;}
.scenario-reflection-label{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-sec);margin-bottom:8px;font-style:italic;}
.scenario-divider{border:none;border-top:1px solid var(--border);margin:32px 0;}

.step-nav{display:flex;justify-content:space-between;align-items:center;margin-top:48px;padding-top:24px;border-top:1px solid var(--border);}
.btn{padding:13px 32px;border-radius:3px;font-size:12px;letter-spacing:0.2em;text-transform:uppercase;cursor:pointer;transition:all 0.2s;border:1px solid transparent;font-family:'Inter',sans-serif;font-weight:400;}
.btn-primary{background:var(--accent);color:#0d0d0d;border-color:var(--accent);}
.btn-primary:hover{background:var(--accent-hov);border-color:var(--accent-hov);}
.btn-secondary{background:transparent;color:var(--text-sec);border-color:var(--border);}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);}
.btn-submit{background:var(--accent);color:#0d0d0d;border:none;padding:13px 40px;font-size:12px;letter-spacing:0.2em;text-transform:uppercase;border-radius:3px;cursor:pointer;font-family:'Inter',sans-serif;font-weight:400;transition:background 0.2s;}
.btn-submit:hover{background:var(--accent-hov);}

.site-footer{text-align:center;padding:32px;font-size:12px;color:var(--text-sec);border-top:1px solid var(--border);letter-spacing:0.1em;}

@media(max-width:768px){
  .field-row{grid-template-columns:1fr;}
  .cluster-grid{grid-template-columns:1fr;}
  .step-title{font-size:26px;}
  .rank-arrows{display:flex;}
  .rank-drag-handle{display:none;}
  .rank-item{cursor:default;}
  .assessment-container{padding:24px 16px 60px;}
  .step-nav{flex-direction:column;gap:12px;}
  .step-nav .btn,.step-nav .btn-submit{width:100%;text-align:center;}
}
