@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Inter:wght@300;400;500;600&family=DM+Mono:wght@300;400&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --navy:       #0B1120;
  --navy-mid:   #0F1829;
  --navy-card:  #131E33;
  --navy-light: #1A2640;
  --gold:       #C9A84C;
  --gold-hi:    #E8C96A;
  --gold-lo:    #9A7830;
  --gold-dim:   rgba(201,168,76,0.12);
  --gold-line:  rgba(201,168,76,0.3);
  --page-bg:    #F0F2F5;
  --surface:    #FFFFFF;
  --surface-2:  #F7F8FA;
  --border:     rgba(0,0,0,0.08);
  --border-md:  rgba(0,0,0,0.13);
  --text-1:     #0F1729;
  --text-2:     #3D4B63;
  --text-3:     #7A869A;
  --text-4:     #B0BAC8;
  --ht-1:       rgba(255,255,255,0.95);
  --ht-2:       rgba(255,255,255,0.6);
  --ht-3:       rgba(255,255,255,0.35);
  --ht-4:       rgba(255,255,255,0.15);
  --green:      #15803D;
  --green-bg:   rgba(21,128,61,0.07);
  --green-bd:   rgba(21,128,61,0.2);
  --amber:      #92400E;
  --amber-bg:   rgba(146,64,14,0.07);
  --amber-bd:   rgba(146,64,14,0.2);
  --blue-bg:    rgba(29,78,216,0.06);
  --blue-bd:    rgba(29,78,216,0.18);
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Inter', system-ui, sans-serif;
  --mono:  'DM Mono', monospace;
  --ease:  cubic-bezier(.4,0,.2,1);
  --r:     10px;
  --r-sm:  6px;
}

html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--page-bg);color:var(--text-1);min-height:100vh;-webkit-font-smoothing:antialiased}

/* ════════════════════════════
   INTRO SCREEN
════════════════════════════ */
.intro{
  position:fixed;inset:0;
  background:var(--navy);
  z-index:300;
  display:flex;flex-direction:column;
  transition:opacity .45s var(--ease),transform .45s var(--ease);
  overflow-y:auto;
}
.intro.out{opacity:0;pointer-events:none;transform:translateY(-10px)}

/* Topbar */
.intro-nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 48px;
  border-bottom:1px solid var(--ht-4);
}

.logo{display:flex;flex-direction:column;align-items:center;gap:0}
.logo-sck{
  font-family:var(--serif);
  font-size:36px;font-weight:600;
  color:var(--gold);
  letter-spacing:0.14em;
  line-height:1;
}
.logo-rule{
  width:100%;
  display:flex;align-items:center;justify-content:center;
  gap:6px;
  margin:2px 0;
}
.logo-rule-line{flex:1;height:1px;background:linear-gradient(to right,transparent,var(--gold-lo),var(--gold),var(--gold-lo),transparent)}
.logo-rule-text{
  font-family:var(--sans);
  font-size:8px;font-weight:400;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--ht-3);
  white-space:nowrap;
}
.nav-pill{
  border:1px solid var(--gold-line);
  background:var(--gold-dim);
  color:var(--gold);
  font-family:var(--sans);
  font-size:10px;font-weight:500;
  letter-spacing:0.1em;
  text-transform:uppercase;
  padding:7px 18px;
  border-radius:100px;
}

/* Hero */
.intro-hero{
  flex:1;
  display:flex;align-items:center;justify-content:center;
  padding:52px 48px;
  text-align:center;
  background:
    radial-gradient(ellipse 70% 55% at 50% -5%,rgba(201,168,76,0.11) 0%,transparent 65%),
    linear-gradient(180deg,var(--navy) 0%,var(--navy-mid) 100%);
}
.intro-hero-inner{max-width:720px;width:100%}

.intro-kicker{
  font-family:var(--mono);
  font-size:9px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gold);opacity:.85;
  margin-bottom:20px;
  display:flex;align-items:center;justify-content:center;gap:12px;
}
.intro-kicker::before,.intro-kicker::after{content:'';width:28px;height:1px;background:var(--gold);opacity:.45}

.intro-h1{
  font-family:var(--serif);
  font-size:clamp(40px,5.5vw,62px);
  font-weight:500;
  color:var(--ht-1);
  line-height:1.08;
  letter-spacing:-0.01em;
  margin-bottom:20px;
}
.intro-h1 .gw{color:var(--gold-hi);font-style:italic}

.intro-p{
  font-size:15px;font-weight:300;
  color:var(--ht-2);line-height:1.85;
  max-width:580px;margin:0 auto 32px;
}

.intro-tags{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
  margin-bottom:40px;
}
.itag{
  display:flex;align-items:center;gap:7px;
  padding:7px 16px;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:100px;
  font-size:12.5px;font-weight:400;
  color:var(--ht-2);
  background:rgba(255,255,255,0.04);
  letter-spacing:0.01em;
}
.itag-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0;opacity:.8}

.intro-sigilo{
  background:var(--blue-bg);
  border:1px solid var(--blue-bd);
  border-radius:var(--r);
  padding:16px 20px;
  display:flex;align-items:flex-start;gap:12px;
  text-align:left;
  margin-bottom:32px;
}
.is-icon{
  width:32px;height:32px;
  background:rgba(29,78,216,.12);
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.is-icon svg{width:16px;height:16px}
.is-title{font-size:11.5px;font-weight:600;color:rgba(147,197,253,.9);margin-bottom:4px;letter-spacing:.01em}
.is-text{font-size:12.5px;font-weight:300;color:var(--ht-2);line-height:1.7}
.is-text strong{color:var(--ht-1);font-weight:500}

.btn-start{
  width:100%;
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);
  font-size:13.5px;font-weight:600;
  letter-spacing:0.04em;
  color:var(--navy);
  background:linear-gradient(135deg,var(--gold-hi),var(--gold));
  border:none;border-radius:var(--r-sm);
  padding:15px 32px;
  cursor:pointer;
  box-shadow:0 4px 20px rgba(201,168,76,.35);
  transition:all .2s var(--ease);
}
.btn-start:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,168,76,.45);background:linear-gradient(135deg,#F0D080,var(--gold-hi))}
.btn-start svg{width:16px;height:16px}

.intro-fine{
  text-align:center;
  font-family:var(--mono);
  font-size:9px;letter-spacing:.08em;
  color:var(--ht-3);
  margin-top:14px;
}

/* Stats */
.intro-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--ht-4);
  border:1px solid var(--ht-4);
  border-radius:var(--r);
  overflow:hidden;
  margin-bottom:28px;
}
.stat{background:rgba(255,255,255,0.03);padding:14px 10px;text-align:center}
.stat-n{font-family:var(--mono);font-size:19px;font-weight:400;color:var(--gold);margin-bottom:3px}
.stat-l{font-size:10px;font-weight:300;color:var(--ht-3);letter-spacing:.03em}

/* ════════════════════════════
   HEADER (form view)
════════════════════════════ */
.site-header{
  background:var(--navy);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 40px;
  height:62px;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.sh-logo{display:flex;flex-direction:column;align-items:center;gap:0}
.sh-sck{font-family:var(--serif);font-size:26px;font-weight:600;color:var(--gold);letter-spacing:.12em;line-height:1}
.sh-rule{width:100%;display:flex;align-items:center;justify-content:center;gap:5px;margin:1px 0}
.sh-rule-line{flex:1;height:1px;background:linear-gradient(to right,transparent,var(--gold-lo),transparent)}
.sh-rule-text{font-size:7.5px;font-weight:400;letter-spacing:.28em;text-transform:uppercase;color:var(--ht-3);white-space:nowrap}
.sh-right{display:flex;align-items:center;gap:10px}
.sh-pill{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:5px 14px;border-radius:100px}
.sh-pill.g{color:var(--gold);border:1px solid var(--gold-line);background:var(--gold-dim)}
.sh-pill.w{color:var(--ht-3);border:1px solid var(--ht-4)}

/* ════════════════════════════
   HERO BANNER (form)
════════════════════════════ */
.form-banner{
  background:
    radial-gradient(ellipse 90% 180% at 50% -20%,rgba(201,168,76,0.1) 0%,transparent 60%),
    linear-gradient(180deg,var(--navy) 0%,var(--navy-mid) 100%);
  padding:48px 40px 56px;
  text-align:center;
  position:relative;overflow:hidden;
}
.form-banner::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:56px;
  background:linear-gradient(to bottom,transparent,var(--page-bg));
  pointer-events:none;
}
/* Gold accent line at top */
.form-banner::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 5%,var(--gold) 30%,var(--gold) 70%,transparent 95%);
  opacity:.35;
}
.fb-inner{max-width:860px;margin:0 auto;position:relative;z-index:1}

.fb-kicker{
  font-family:var(--mono);
  font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);opacity:.8;
  margin-bottom:14px;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.fb-kicker::before,.fb-kicker::after{content:'';width:24px;height:1px;background:var(--gold);opacity:.4}

.fb-title{
  font-family:var(--serif);
  font-size:clamp(30px,4vw,48px);
  font-weight:500;
  color:var(--ht-1);
  line-height:1.1;
  margin-bottom:12px;
  letter-spacing:-0.01em;
}
.fb-title .gw{color:var(--gold-hi);font-style:italic}

.fb-sub{
  font-size:14px;font-weight:300;
  color:var(--ht-2);line-height:1.75;
  max-width:560px;margin:0 auto 22px;
}

.fb-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.fbtag{
  display:flex;align-items:center;gap:7px;
  padding:7px 16px;
  border:1px solid rgba(255,255,255,0.1);
  border-radius:100px;
  font-size:12px;font-weight:400;
  color:var(--ht-2);
  background:rgba(255,255,255,0.04);
}
.fbtag::before{content:'✓';font-size:10px;color:var(--gold);font-weight:600}

/* ════════════════════════════
   PROGRESS
════════════════════════════ */
.progress-section{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:14px 40px 0;
  box-shadow:0 2px 10px rgba(0,0,0,.05);
}
.ps-top{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:8px;
}
.ps-label{font-size:12.5px;font-weight:500;color:var(--text-2)}
.ps-pct{font-family:var(--mono);font-size:11px;font-weight:400;color:var(--text-1)}
.ps-track{height:3px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:14px}
.ps-fill{height:100%;background:linear-gradient(90deg,var(--gold-lo),var(--gold),var(--gold-hi));border-radius:3px;transition:width .5s var(--ease)}

.sec-tabs{display:flex;overflow-x:auto;scrollbar-width:none;gap:2px}
.sec-tabs::-webkit-scrollbar{display:none}
.stab{
  font-family:var(--sans);
  font-size:12px;font-weight:400;
  color:var(--text-3);
  padding:8px 18px;
  border-radius:100px 100px 0 0;
  cursor:pointer;white-space:nowrap;
  border:1px solid transparent;
  border-bottom:none;
  transition:all .15s;
  user-select:none;
  letter-spacing:.01em;
}
.stab:hover{color:var(--text-1);background:rgba(0,0,0,.03)}
.stab.active{
  color:var(--text-1);
  background:var(--surface);
  border-color:var(--border);
  border-bottom:none;
  font-weight:600;
  position:relative;top:1px;
}
.stab.done{color:var(--green)}

/* ════════════════════════════
   FORM BODY
════════════════════════════ */
.form-body{
  max-width:860px;margin:0 auto;
  padding:28px 40px 120px;
  width:100%;
}

/* Section card — dark, like the original */
.sec-card{
  background:var(--navy-card);
  border-radius:var(--r);
  padding:20px 26px;
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:12px;
  box-shadow:0 4px 20px rgba(0,0,0,.18);
  position:relative;overflow:hidden;
}
.sec-card::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(to bottom,var(--gold-hi),var(--gold-lo));
}
.sec-card-left{}
.sec-card-title{
  font-family:var(--serif);
  font-size:19px;font-weight:600;
  color:var(--ht-1);
  line-height:1.2;margin-bottom:3px;
}
.sec-card-title em{font-style:italic;color:var(--gold-hi)}
.sec-card-desc{font-size:12px;font-weight:300;color:var(--ht-3);letter-spacing:.01em}
.sec-card-badge{
  font-family:var(--mono);
  font-size:11px;font-weight:400;
  color:var(--gold);
  background:var(--gold-dim);
  border:1px solid var(--gold-line);
  padding:5px 14px;
  border-radius:100px;
  white-space:nowrap;
  letter-spacing:.06em;
}

/* Sigilo inline */
.sigilo-inline{
  display:flex;align-items:center;gap:8px;
  padding:9px 14px;
  background:var(--blue-bg);
  border:1px solid var(--blue-bd);
  border-radius:var(--r-sm);
  font-size:11.5px;font-weight:400;
  color:rgba(96,165,250,.85);
  margin-bottom:14px;
  letter-spacing:.01em;
}
.sigilo-inline svg{width:12px;height:12px;flex-shrink:0}
.sigilo-inline strong{font-weight:600;color:rgba(147,197,253,.9)}

/* Steps */
.step{display:none}
.step.active{display:block}

/* Question block */
.qb{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:22px 24px;
  margin-bottom:8px;
  transition:border-color .15s,box-shadow .15s;
}
.qb:hover{border-color:rgba(201,168,76,.25);box-shadow:0 2px 10px rgba(0,0,0,.06)}
.qb.answered{border-left:3px solid var(--gold);padding-left:21px}

.qb-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}
.qb-num{
  min-width:26px;height:26px;
  background:var(--navy-card);
  border-radius:5px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);
  font-size:11px;font-weight:600;
  color:var(--gold);
  flex-shrink:0;
  margin-top:1px;
}
.qb-text{
  font-size:14px;font-weight:500;
  color:var(--text-1);
  line-height:1.6;
  letter-spacing:.01em;
}
.qb-hint{
  font-family:var(--mono);
  font-size:10px;color:var(--text-4);
  margin:-8px 0 12px 38px;
  letter-spacing:.03em;
}

/* Options */
.opt-row{display:flex;gap:8px;flex-wrap:wrap}
.opt{
  display:flex;align-items:center;gap:8px;
  padding:9px 22px;
  border:1.5px solid var(--border-md);
  border-radius:100px;
  font-size:13.5px;font-weight:400;
  color:var(--text-2);
  cursor:pointer;
  background:var(--surface-2);
  transition:all .15s var(--ease);
  user-select:none;
}
.opt:hover{border-color:var(--gold);background:var(--gold-dim);color:var(--text-1)}
.opt.sel{
  border-color:var(--gold);
  background:var(--gold-dim);
  color:var(--navy);
  font-weight:600;
}
.opt-radio{
  width:12px;height:12px;border-radius:50%;
  border:1.5px solid currentColor;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.opt.sel .opt-radio::after{
  content:'';width:4px;height:4px;border-radius:50%;background:var(--gold);
}

/* Inputs */
.sys-input,.sys-select,.sys-textarea{
  width:100%;
  background:var(--surface-2);
  border:1.5px solid var(--border-md);
  border-radius:var(--r-sm);
  padding:11px 15px;
  font-family:var(--sans);
  font-size:13.5px;font-weight:300;
  color:var(--text-1);
  outline:none;-webkit-appearance:none;
  transition:border-color .15s,box-shadow .15s;
  letter-spacing:.01em;
}
.sys-input:focus,.sys-select:focus,.sys-textarea:focus{
  border-color:var(--gold);
  background:var(--surface);
  box-shadow:0 0 0 3px rgba(201,168,76,.1);
}
.sys-input::placeholder,.sys-textarea::placeholder{color:var(--text-4);font-size:13px}
.sys-textarea{resize:vertical;min-height:80px}
.sys-select{
  cursor:pointer;color:var(--text-2);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 11 11'%3E%3Cpath d='M2 4l3.5 3.5L9 4' stroke='%23B0BAC8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;padding-right:38px;
}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* Checkbox list */
.chk-list{display:flex;flex-direction:column;gap:6px}
.chk-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:11px 15px;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  font-size:13px;font-weight:400;
  color:var(--text-2);
  cursor:pointer;
  background:var(--surface-2);
  transition:all .15s;user-select:none;line-height:1.5;
}
.chk-item:hover{border-color:var(--gold);background:var(--gold-dim);color:var(--text-1)}
.chk-item.sel{border-color:var(--gold);background:var(--gold-dim);color:var(--text-1);font-weight:500}
.chk-box{
  width:16px;height:16px;
  border:1.5px solid var(--border-md);
  border-radius:3px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:2px;transition:all .15s;
}
.chk-item.sel .chk-box{background:var(--gold);border-color:var(--gold);color:#fff}
.chk-item.sel .chk-box::after{content:'✓';font-size:10px;font-weight:700;font-family:var(--sans)}

/* Contextual message */
.ctx{
  display:none;align-items:flex-start;gap:8px;
  padding:10px 14px;border-radius:var(--r-sm);
  font-size:12px;font-weight:400;line-height:1.65;
  margin-top:8px;
  animation:ctxIn .22s var(--ease);
}
@keyframes ctxIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.ctx.visible{display:flex}
.ctx.help{background:var(--green-bg);border:1px solid var(--green-bd);color:#166534}
.ctx.alert{background:var(--amber-bg);border:1px solid var(--amber-bd);color:#7C2D12}
.ctx-ico{font-size:12px;flex-shrink:0;margin-top:1px;font-family:var(--sans);font-weight:600}
.ctx strong{font-weight:600}

/* ════════════════════════════
   FOOTER NAV
════════════════════════════ */
.footer-nav{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--surface);
  border-top:1px solid var(--border);
  padding:13px 40px;
  display:flex;align-items:center;justify-content:space-between;
  z-index:80;
  box-shadow:0 -2px 16px rgba(0,0,0,.08);
}
.fn-info{
  font-family:var(--mono);
  font-size:9.5px;letter-spacing:.08em;
  color:var(--text-4);
  display:flex;align-items:center;gap:7px;
}
.fn-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:.6}50%{opacity:1}}
.btn-group{display:flex;gap:10px}
.btn{
  font-family:var(--sans);font-size:13px;font-weight:500;
  padding:10px 24px;border-radius:var(--r-sm);cursor:pointer;
  transition:all .18s var(--ease);
  display:flex;align-items:center;gap:8px;border:1.5px solid;
  letter-spacing:.02em;
}
.btn svg{width:14px;height:14px;flex-shrink:0}
.btn-back{color:var(--text-2);border-color:var(--border-md);background:transparent}
.btn-back:hover{background:var(--surface-2)}
.btn-next{
  color:var(--navy);
  background:linear-gradient(135deg,var(--gold-hi),var(--gold));
  border-color:var(--gold);
  font-weight:600;
  box-shadow:0 2px 10px rgba(201,168,76,.3);
}
.btn-next:hover{box-shadow:0 4px 18px rgba(201,168,76,.45);transform:translateY(-1px)}

/* ════════════════════════════
   SUCCESS
════════════════════════════ */
.success{display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 40px;min-height:50vh}
.success.show{display:flex}
.success-icon{width:68px;height:68px;background:var(--green-bg);border:2px solid var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:22px;font-size:26px}
.success-title{font-family:var(--serif);font-size:30px;font-weight:500;color:var(--text-1);margin-bottom:10px}
.success-sub{font-size:14px;font-weight:300;color:var(--text-2);max-width:440px;line-height:1.75;margin-bottom:28px}
.success-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px 24px;text-align:left;max-width:400px;width:100%}
.sc-label{font-family:var(--mono);font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;font-weight:400}
.sc-steps{display:flex;flex-direction:column;gap:10px}
.sc-step{display:flex;gap:10px;font-size:12.5px;font-weight:300;color:var(--text-2);align-items:flex-start;line-height:1.5}
.sc-n{width:20px;height:20px;background:var(--gold-dim);border:1px solid var(--gold-line);border-radius:100px;font-family:var(--mono);font-size:9px;color:var(--gold);display:flex;align-items:center;justify-content:center;flex-shrink:0}

.toast{position:fixed;bottom:74px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--navy-card);color:var(--ht-1);border:1px solid rgba(255,255,255,.1);padding:9px 20px;border-radius:100px;font-size:12px;opacity:0;pointer-events:none;transition:all .3s;z-index:999;white-space:nowrap;font-family:var(--sans)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ════════════════════════════
   RESPONSIVE
════════════════════════════ */
@media(max-width:800px){
  .intro-nav,.intro-hero{padding-left:20px;padding-right:20px}
  .intro-stats{grid-template-columns:1fr}
  .site-header,.footer-nav,.form-banner,.progress-section{padding-left:16px;padding-right:16px}
  .form-body{padding:20px 16px 100px}
  .field-row{grid-template-columns:1fr}
  .sec-card{flex-direction:column;gap:10px;align-items:flex-start}
  .fb-inner{padding:0 16px}
}
