/* BRAND — black + red (logo colors). Legacy token NAMES kept; VALUES remapped:
   evergreen→near-black · gold/gold-deep→red accents · rust→bright red (required/error) · moss→warm stone */
:root{
  --bone:#f5efe3; --bone2:#ece3d1; --paper:#fbf7ef; --ink:#17120f; --ink-soft:#41362e;
  --evergreen:#15100e; --evergreen2:#2a201c; --moss:#6c6258; --gold:#ee2a22;
  --gold-deep:#a82318; --rust:#ee2a22; --line:#d7cdba;
  --serif:"Fraunces",Georgia,serif; --sans:"Hanken Grotesk",system-ui,sans-serif;
  --shadow:0 1px 2px rgba(23,18,15,.05),0 18px 50px -22px rgba(23,18,15,.4);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bone);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.6}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E")}
a{color:var(--gold-deep)}
::selection{background:var(--gold);color:var(--evergreen)}

.page{max-width:780px;margin:0 auto;padding:0 22px 140px;position:relative;z-index:1}

/* no-JS fallback notice */
.noscript-note{max-width:780px;margin:18px auto 0;background:var(--bone2);border:1px solid var(--line);
  border-left:3px solid var(--rust);border-radius:6px;padding:14px 16px;font-size:.92rem;color:var(--ink-soft);
  line-height:1.55;position:relative;z-index:1}
.noscript-note b{color:var(--evergreen);display:block;margin-bottom:3px}
.noscript-note a{color:var(--gold-deep);font-weight:600}

/* masthead */
.mast{display:flex;align-items:center;gap:14px;padding:30px 0 26px}
.mast .seal{width:46px;height:46px;border-radius:50%;flex:none;background:radial-gradient(circle at 50% 35%,var(--evergreen2),var(--evergreen));
  color:var(--bone);display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:17px;
  box-shadow:inset 0 0 0 2px rgba(245,239,227,.22)}
.mast .brandmark{height:56px;width:auto;flex:none;display:block}
.mast b{font-family:var(--serif);font-weight:500;font-size:1.2rem;color:var(--evergreen);line-height:1.05}
.mast span{display:block;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--moss);font-weight:600;margin-top:2px}
.mast .back{margin-left:auto;font-size:.82rem;font-weight:600;color:var(--ink-soft);text-decoration:none}
.mast .back:hover{color:var(--evergreen)}

/* hero of the form */
.intro{padding:14px 0 30px;border-top:1px solid var(--line)}
.intro .kicker{font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:14px;display:inline-flex;align-items:center;gap:10px}
.intro .kicker::before{content:"";width:26px;height:1px;background:var(--gold-deep)}
.intro h1{font-family:var(--serif);font-weight:400;font-size:clamp(2rem,5vw,3rem);line-height:1.05;letter-spacing:-.015em;color:var(--evergreen)}
.intro p{margin-top:16px;color:var(--ink-soft);font-size:1.05rem;max-width:60ch}
.privacy{margin-top:20px;display:flex;gap:12px;align-items:flex-start;background:var(--bone2);border:1px solid var(--line);
  border-left:3px solid var(--gold);border-radius:6px;padding:14px 16px;font-size:.86rem;color:var(--ink-soft);line-height:1.5}
.privacy svg{flex:none;margin-top:2px}

/* fieldsets */
fieldset{margin-top:30px;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:28px;box-shadow:var(--shadow);display:flow-root}
/* float disables the browser's special "rendered legend" border-straddle,
   placing the heading in normal flow inside the card padding */
legend{font-family:var(--serif);font-weight:500;font-size:1.3rem;color:var(--evergreen);
  float:left;width:100%;padding:0;margin:0 0 4px;line-height:1.25}
legend i{font-style:italic;font-size:.92rem;color:var(--gold-deep);margin-right:10px}
legend + *{clear:both}
.legend-sub{font-size:.85rem;color:var(--moss);margin:0 0 22px}

.field{margin-bottom:18px}
.field:last-child{margin-bottom:0}
.field label{display:block;font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;font-weight:700;color:var(--ink-soft);margin-bottom:8px}
.field .req{color:var(--rust)}
.field input,.field textarea,.field select{width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:7px;padding:13px 14px;transition:.18s}
.field textarea{min-height:104px;resize:vertical;line-height:1.55}
.field input::placeholder,.field textarea::placeholder{color:#9b917f}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--evergreen);box-shadow:0 0 0 3px rgba(21,16,14,.12)}
.field input:user-invalid,.field textarea:user-invalid{border-color:var(--rust)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* segmented choice */
.seg{display:inline-grid;grid-auto-flow:column;gap:6px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:5px}
.seg label{margin:0;text-transform:none;letter-spacing:0;font-size:.92rem;font-weight:600;color:var(--ink-soft);
  padding:9px 18px;border-radius:5px;cursor:pointer;transition:.18s}
.seg input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.seg input:checked + label{background:var(--evergreen);color:var(--bone)}

/* consent */
.consent{margin-top:30px;display:flex;gap:13px;align-items:flex-start;font-size:.92rem;color:var(--ink-soft)}
.consent input{margin-top:4px;width:18px;height:18px;accent-color:var(--evergreen);flex:none}

/* sticky submit bar */
.bar{position:fixed;left:0;right:0;bottom:0;z-index:20;background:rgba(245,239,227,.92);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);box-shadow:0 -10px 30px -16px rgba(23,18,15,.4)}
.bar .inner{max-width:780px;margin:0 auto;padding:14px 22px;display:flex;gap:12px;align-items:center;justify-content:space-between}
.bar .hint{font-size:.8rem;color:var(--moss);max-width:34ch}
.bar .acts{display:flex;gap:10px;flex:none}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:600;font-size:.9rem;cursor:pointer;
  border:none;border-radius:7px;padding:13px 22px;transition:.18s}
.btn.primary{background:var(--evergreen);color:var(--bone)}
.btn.primary:hover{background:var(--evergreen2);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--evergreen);background:var(--paper)}

/* confirmation overlay */
.done{position:fixed;inset:0;z-index:40;background:rgba(21,16,14,.96);display:none;place-items:center;text-align:center;padding:24px}
.done.show{display:grid}
.done .card{max-width:440px}
.done .check{width:74px;height:74px;border-radius:50%;border:2px solid var(--gold);margin:0 auto 24px;display:grid;place-items:center}
.done h2{font-family:var(--serif);font-weight:500;font-size:1.9rem;color:var(--bone);margin-bottom:14px}
.done p{color:rgba(245,239,227,.8);font-size:1rem;line-height:1.6;margin-bottom:26px}
.done .btn.ghost{color:var(--bone);border-color:rgba(245,239,227,.4)}

/* errors */
.err{display:none;color:var(--rust);font-size:.82rem;font-weight:600;margin-top:7px}
.field.bad .err{display:block}
.field.bad input,.field.bad textarea,.field.bad select{border-color:var(--rust)}
.consent.bad{color:var(--rust)}
.consent.bad input{outline:2px solid var(--rust);outline-offset:2px}
.consent .err{margin-top:4px}
.consent.bad .err{display:block}

/* keyboard focus ring (gold) — not browser-blue */
.field input:focus-visible,.field textarea:focus-visible,.field select:focus-visible,
.btn:focus-visible,a:focus-visible,.seg label:focus-visible,.consent input:focus-visible{
  outline:2px solid var(--gold);outline-offset:2px;border-radius:5px}

@media(max-width:600px){
  .two,.three{grid-template-columns:1fr}
  fieldset{padding:22px}
  .bar .hint{display:none}
  .bar .acts{flex:1}
  .btn{flex:1;justify-content:center}
}

/* ---------- PRINT: render a clean document copy ---------- */
@media print{
  body::before,.bar,.mast .back,.intro .kicker,.privacy,.consent{display:none!important}
  body{background:#fff}
  .page{padding:0;max-width:100%}
  fieldset{box-shadow:none;border:none;border-top:1px solid #ccc;border-radius:0;padding:14px 0;page-break-inside:avoid}
  legend{font-size:1.1rem}
  .field input,.field textarea,.field select{border:none;border-bottom:1px solid #999;border-radius:0;padding:4px 0;background:none}
  .seg{border:none;padding:0}
  .seg input:not(:checked)+label{display:none}
  .seg input:checked+label{background:none;color:#000;border:1px solid #000;padding:3px 12px}
  .intro h1{font-size:1.6rem}
}

/* ---------- reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  html{scroll-behavior:auto}
  .btn.primary:hover{transform:none}
}
