/* Nexa v2 — shared styles. Derived from web-legacy/assets/styles.css
   (warm, earthy AfCEN identity; self-hosted fonts — no CDN, no visitor-IP
   leak). Serves /  /field/  /review/. Paths are root-absolute: web/ is
   expected to be mounted at the site root by the FastAPI app. */

@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:400 700;font-display:swap;
  src:url('/assets/fonts/spacegrotesk-latin.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400 700;font-display:swap;
  src:url('/assets/fonts/jetbrainsmono-latin.woff2') format('woff2')}

:root{
  --bg:#FAF5EA;          /* cream canvas */
  --bg2:#F3E8CF;         /* warmer panel */
  --card:#FFFDF8;        /* card surface */
  --ink:#2E1305;         /* primary text */
  --ink2:#8A6A50;        /* muted text */
  --rust:#6B2410;        /* primary accent */
  --rust2:#8A3316;
  --amber:#B26A2C;
  --olive:#8F8757;
  --green:#5f7d3a;
  --red:#b8442a;
  --cream:#EFE2BD;       /* text on rust */
  --line:rgba(46,19,5,.14);
  --line-soft:rgba(46,19,5,.08);
  --sans:'Space Grotesk',system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --maxw:1000px;
  --shadow:0 30px 70px -34px rgba(46,19,5,.5);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
code{font-family:var(--mono);font-size:.86em;color:var(--rust)}

/* ── atmosphere ── */
@keyframes nk-aur1{0%{transform:translate(0,0) scale(1)}50%{transform:translate(5%,4%) scale(1.14)}100%{transform:translate(0,0) scale(1)}}
@keyframes nk-aur2{0%{transform:translate(0,0) scale(1.06)}50%{transform:translate(-6%,-4%) scale(1)}100%{transform:translate(0,0) scale(1.06)}}
.aurora{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.aurora i{position:absolute;border-radius:50%;display:block}
.aurora .a1{top:-20%;left:8%;width:52%;height:48%;filter:blur(52px);
  background:radial-gradient(circle,rgba(158,92,41,.30),transparent 64%);animation:nk-aur1 22s ease-in-out infinite}
.aurora .a2{top:-14%;right:2%;width:44%;height:46%;filter:blur(54px);
  background:radial-gradient(circle,rgba(107,36,16,.18),transparent 64%);animation:nk-aur2 26s ease-in-out infinite}
.aurora .a3{bottom:-16%;left:30%;width:44%;height:44%;filter:blur(56px);
  background:radial-gradient(circle,rgba(143,135,87,.22),transparent 66%);animation:nk-aur1 30s ease-in-out infinite}
.grain{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.05;mix-blend-mode:multiply;
  background-image:radial-gradient(rgba(46,19,5,.5) .6px,transparent .7px);background-size:3px 3px}

@keyframes nk-shine{0%{background-position:220% center}100%{background-position:-220% center}}
@keyframes nk-spin{to{transform:rotate(360deg)}}
@keyframes rise{to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(16px);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards;animation-delay:var(--d,0ms)}
@media (prefers-reduced-motion:reduce){
  .reveal{animation:none;opacity:1;transform:none}
  .aurora i,.shiny{animation:none}
}

/* ── shell / header ── */
.app{position:relative;z-index:2;min-height:100dvh;display:flex;flex-direction:column}
.app-bar{flex:none;display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:20px clamp(18px,5vw,40px);max-width:var(--maxw);margin:0 auto;width:100%}
.brand{display:flex;align-items:center;gap:11px}
.brand-logo{display:block;width:34px;height:34px;flex:none}
.wordmark{font-weight:700;font-size:22px;letter-spacing:-.5px;color:var(--ink)}
.wordmark.small{font-size:19px}
.shiny{background-image:linear-gradient(100deg,var(--rust) 20%,var(--rust) 40%,#D89B4B 50%,var(--rust) 60%,var(--rust) 80%);
  background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:nk-shine 5.5s linear infinite}
.byline{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.1em;color:var(--rust);
  border:1px solid rgba(107,36,16,.28);padding:2px 7px;border-radius:5px}
.status{font-family:var(--mono);font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--ink2)}
.status.live{color:var(--green)}.status.err{color:var(--red)}

.rule-gold{height:0;border-top:1px solid var(--line);position:relative;margin:16px 0}
.rule-gold::before{content:"";position:absolute;left:0;top:-1px;width:48px;border-top:2px solid var(--rust)}

/* ── buttons ── */
.btn-gold{font-family:var(--sans);font-weight:700;font-size:15px;color:var(--cream);cursor:pointer;border:0;
  background:var(--rust);padding:15px 24px;border-radius:11px;letter-spacing:.01em;
  box-shadow:0 14px 28px -12px rgba(107,36,16,.8);transition:transform .18s,box-shadow .18s,background .18s}
.btn-gold:hover{transform:translateY(-2px);background:var(--rust2);box-shadow:0 20px 34px -14px rgba(107,36,16,.85)}
.btn-gold:active{transform:translateY(0)}
.btn-gold:disabled{opacity:.55;cursor:default;transform:none;box-shadow:none}
.btn-gold.sm{padding:12px 18px;font-size:14px}
.btn-gold:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
.btn-gold.full{width:100%}
.btn-ghost{font-family:var(--sans);font-weight:700;font-size:14px;white-space:nowrap;color:var(--rust);cursor:pointer;
  background:transparent;border:1px solid var(--line);border-radius:10px;padding:12px 18px;transition:.18s;
  display:inline-flex;align-items:center;gap:8px;justify-content:center}
.btn-ghost:hover{border-color:var(--rust);background:rgba(107,36,16,.06)}
.btn-ghost:disabled{opacity:.55;cursor:default}
.btn-link{background:none;border:0;color:var(--rust);font-family:var(--mono);font-size:12px;font-weight:600;
  cursor:pointer;padding:0}
.btn-link:hover{text-decoration:underline}
.btn-danger{background:var(--red)}
.btn-danger:hover{background:#a03a24}

/* ── cards & forms ── */
.nx-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow);overflow:hidden}
.nx-card-pad{padding:24px clamp(20px,4vw,30px)}
.nx-card-head{background:var(--rust);color:var(--cream);padding:14px clamp(18px,3vw,26px);
  font-family:var(--mono);font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  display:flex;align-items:center;justify-content:space-between;gap:10px}
.nx-card-head .lite{color:rgba(239,226,189,.6);font-weight:400;letter-spacing:.06em;text-transform:none}
label{display:block;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--rust);margin:0 0 8px}
.req{color:var(--amber)} .opt{text-transform:none;letter-spacing:0;color:var(--ink2);font-weight:400}
.nx-in{width:100%;padding:13px 14px;background:var(--bg);border:1px solid var(--line);border-radius:10px;
  font-family:var(--sans);font-size:15px;color:var(--ink);outline:none;transition:border-color .18s,box-shadow .18s;
  margin-bottom:16px}
.nx-in:focus{border-color:var(--rust);box-shadow:0 0 0 3px rgba(107,36,16,.1)}
.nx-in::placeholder{color:#b39c86}
textarea.nx-in{resize:vertical;min-height:96px;line-height:1.55;font-family:var(--sans)}
select.nx-in{font-weight:600}
.nx-lede{font-size:14px;line-height:1.55;color:var(--ink2);margin:0 0 20px}
.nx-msg{font-size:12.5px;color:var(--red);min-height:1em;margin-top:10px;line-height:1.4}
.nx-msg.ok{color:var(--green)}
.mono-note{font-family:var(--mono);font-size:11px;line-height:1.55;color:var(--ink2)}

/* ── state badges ── */
.badge{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:3px 9px;border-radius:6px;color:var(--cream);background:var(--olive);white-space:nowrap}
.badge.s-prospect{background:var(--olive)}
.badge.s-brief_ready{background:var(--amber)}
.badge.s-intake_done,.badge.s-qualified{background:var(--rust2)}
.badge.s-proposal_sent{background:var(--rust)}
.badge.s-rights_signed,.badge.s-signed{background:var(--green)}
.badge.s-tenant{background:#2E1305}
.badge.s-declined,.badge.s-lost{background:#9a9a92}

/* ── field (phone-first) ── */
.field-wrap{flex:1;width:100%;max-width:560px;margin:0 auto;padding:4px 16px 40px;display:flex;flex-direction:column;gap:16px}
.field-wrap .nx-card{animation:rise .5s cubic-bezier(.2,.7,.2,1) both}
.qbar{position:sticky;bottom:14px;z-index:5;display:flex;justify-content:center;margin-top:auto;padding-top:18px}
.qbar .btn-gold{width:100%;background:var(--amber);box-shadow:0 14px 28px -12px rgba(178,106,44,.8)}
.qbar .btn-gold:hover{background:#c07a38}
.progress{display:flex;gap:5px;margin:0 0 16px}
.progress i{flex:1;height:4px;border-radius:3px;background:var(--line);display:block}
.progress i.done{background:var(--rust)}
.progress i.now{background:var(--amber)}
.q-count{font-family:var(--mono);font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--ink2);margin:0 0 8px}
.q-prompt{font-size:20px;font-weight:700;letter-spacing:-.3px;line-height:1.3;color:var(--ink);margin:0 0 6px}
.q-hint{font-size:13px;color:var(--ink2);margin:0 0 16px;line-height:1.5}
.consent-script{background:var(--bg);border:1px solid var(--line);border-left:3px solid var(--rust);
  border-radius:10px;padding:16px;font-size:14.5px;line-height:1.65;margin:0 0 8px}
.consent-flag{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.1em;color:var(--red);
  text-transform:uppercase;margin:0 0 14px}
.rec-pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--red);background:rgba(184,68,42,.1);
  border:1px solid rgba(184,68,42,.3);padding:5px 11px;border-radius:999px}
.rec-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--red);animation:rec-blink 1.2s infinite}
@keyframes rec-blink{0%,100%{opacity:1}50%{opacity:.25}}
.rec-pill.idle{color:var(--ink2);background:transparent;border-color:var(--line)}
.rec-pill.idle .dot{background:var(--ink2);animation:none}
.eng-list{display:flex;flex-direction:column;gap:10px}
.eng-item{text-align:left;width:100%;cursor:pointer;background:var(--bg);border:1px solid var(--line);
  border-radius:13px;padding:13px 14px;transition:.18s;font-family:var(--sans)}
.eng-item:hover{border-color:var(--rust)}
.eng-item .nm{font-size:15px;font-weight:700;color:var(--ink)}
.eng-item .mt{font-family:var(--mono);font-size:11px;color:var(--ink2);margin-top:3px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.tiers{display:flex;flex-direction:column;gap:9px;margin:6px 0 2px}
.tier{display:flex;align-items:baseline;justify-content:space-between;gap:12px;background:var(--bg);
  border:1px solid var(--line-soft);border-radius:10px;padding:10px 13px}
.tier .tn{font-weight:700;font-size:14px}
.tier .tp{font-family:var(--mono);font-size:12px;color:var(--rust);font-weight:700;text-align:right;white-space:nowrap}
.tier .td{font-size:11.5px;color:var(--ink2);line-height:1.4;flex-basis:100%}
.photo-thumb{font-family:var(--mono);font-size:11.5px;color:var(--green);margin-top:6px}
.done-check{width:66px;height:66px;margin:6px auto 20px;border-radius:18px;
  background:linear-gradient(140deg,var(--rust),var(--amber));display:flex;align-items:center;justify-content:center;
  box-shadow:0 16px 34px -16px rgba(107,36,16,.75)}
.done-t{font-weight:700;font-size:28px;line-height:1.1;color:var(--ink);margin:0 0 12px;letter-spacing:-.6px;text-align:center}
.done-s{font-size:14px;line-height:1.6;color:var(--ink2);max-width:340px;margin:0 auto 22px;text-align:center}
.outbox-note{font-family:var(--mono);font-size:11px;color:var(--amber);text-align:center;margin:8px 0 0}

/* ── review (desktop-first, dense) ── */
.review-wrap{flex:1;width:100%;max-width:1240px;margin:0 auto;padding:4px clamp(14px,3vw,32px) 48px}
.rv-grid{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start}
.rv-list{display:flex;flex-direction:column;gap:8px;max-height:calc(100dvh - 160px);overflow-y:auto;padding-right:2px}
.rv-item{text-align:left;width:100%;cursor:pointer;background:var(--card);border:1px solid var(--line);
  border-radius:12px;padding:11px 13px;transition:.18s;font-family:var(--sans)}
.rv-item:hover{border-color:var(--rust)}
.rv-item.sel{border-color:var(--rust);box-shadow:0 0 0 2px rgba(107,36,16,.14)}
.rv-item .nm{font-size:14px;font-weight:700;color:var(--ink);display:flex;justify-content:space-between;gap:8px;align-items:center}
.rv-item .mt{font-family:var(--mono);font-size:10.5px;color:var(--ink2);margin-top:4px}
.rv-detail{display:flex;flex-direction:column;gap:14px;min-width:0}
.rv-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.rv-title{font-size:24px;font-weight:700;letter-spacing:-.5px;margin:0}
.rv-meta{font-family:var(--mono);font-size:11.5px;color:var(--ink2)}
.drafts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.draft-col{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;min-width:0}
.draft-col h3{margin:0;background:var(--bg2);border-bottom:1px solid var(--line);padding:9px 13px;
  font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--rust)}
.draft-body{padding:12px 13px;font-size:12.5px;line-height:1.55;max-height:420px;overflow:auto;
  white-space:pre-wrap;overflow-wrap:anywhere}
.draft-body.empty{color:var(--ink2);font-family:var(--mono);font-size:11.5px}
.art-list{display:flex;flex-direction:column;gap:8px}
.art-item{background:var(--bg);border:1px solid var(--line-soft);border-radius:10px;padding:9px 12px}
.art-item .k{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--rust)}
.art-item .b{font-size:13px;line-height:1.5;margin-top:3px;white-space:pre-wrap;overflow-wrap:anywhere}
.rv-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.rights-form{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:10px;align-items:end}
.rights-form .nx-in{margin-bottom:0}
.gate-note{font-family:var(--mono);font-size:11px;color:var(--amber);line-height:1.5}
.rv-empty{font-family:var(--mono);font-size:12.5px;color:var(--ink2);text-align:center;padding:60px 0}

/* ── review draft cards: human-readable, never raw JSON ── */
.draft-human{padding:13px 14px;max-height:460px;overflow:auto;font-size:13px;line-height:1.55}
.draft-section-h{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--rust);margin:16px 0 8px}
.draft-section-h:first-child{margin-top:0}
.draft-sub{font-size:12px;color:var(--ink2);margin-top:4px}
.draft-sub.warn{color:var(--amber);font-weight:600}

/* qualification */
.qual-score{display:flex;align-items:baseline;gap:8px;background:var(--bg2);border:1px solid var(--line);
  border-radius:12px;padding:12px 15px}
.qual-score-n{font-size:34px;font-weight:700;line-height:1;color:var(--rust);letter-spacing:-1px}
.qual-score-d{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink2)}
.gap-list{display:flex;flex-direction:column;gap:10px}
.gap{background:var(--bg);border:1px solid var(--line-soft);border-radius:10px;padding:10px 12px}
.gap-dim{font-weight:700;font-size:13px;color:var(--ink)}
.gap-q{font-size:13px;color:var(--ink);margin-top:3px}
.gap-missing{font-family:var(--mono);font-size:10.5px;color:var(--ink2);margin-top:5px}

/* configuration pipeline */
.pipeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}
.stage{display:flex;gap:11px;padding:0 0 14px;position:relative}
.stage:not(:last-child)::before{content:"";position:absolute;left:12px;top:26px;bottom:0;
  width:2px;background:var(--line)}
.stage-n{flex:none;width:24px;height:24px;border-radius:50%;background:var(--rust);color:var(--cream);
  font-family:var(--mono);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;z-index:1}
.stage-body{flex:1;min-width:0}
.stage-name{font-weight:700;font-size:13.5px;color:var(--ink);display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.stage-desc{font-size:12.5px;color:var(--ink2);margin-top:3px;line-height:1.5}
.stage-trigger{font-family:var(--mono);font-size:10.5px;color:var(--amber);margin-top:4px}
.chip{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.04em;
  background:var(--bg2);border:1px solid var(--line);color:var(--rust);padding:2px 8px;border-radius:999px}
.chip.owner{background:rgba(143,135,87,.16);border-color:rgba(143,135,87,.4);color:var(--olive)}
.chip.sla{background:rgba(178,106,44,.14);border-color:rgba(178,106,44,.4);color:var(--amber)}
.chip-row{display:flex;flex-wrap:wrap;gap:6px}
.tmpl{background:var(--bg);border:1px solid var(--line-soft);border-radius:10px;padding:10px 12px;margin-bottom:8px}
.tmpl-name{font-weight:700;font-size:12.5px;color:var(--rust)}
.tmpl-body{font-size:12.5px;color:var(--ink);margin-top:5px;white-space:pre-wrap;line-height:1.5}

/* proposal */
.prop-tier{font-weight:700;font-size:13.5px;color:var(--rust);background:var(--bg2);
  border:1px solid var(--line);border-radius:10px;padding:9px 12px;margin-bottom:12px}
.prop-doc h2,.prop-doc h3{color:var(--rust);letter-spacing:-.2px;margin:14px 0 6px}
.prop-doc h2{font-size:16px}.prop-doc h3{font-size:14.5px}
.prop-doc h4,.prop-doc h5,.prop-doc h6{font-size:13px;margin:12px 0 4px}
.prop-doc h2:first-child,.prop-doc h3:first-child{margin-top:0}
.prop-doc p{margin:0 0 10px;font-size:13px;line-height:1.6}
.prop-doc ul{margin:0 0 10px;padding-left:20px}
.prop-doc li{margin:0 0 5px;font-size:13px}
.prop-doc strong{color:var(--rust)}

/* transcript Q/A + questions-for-us */
.qa{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.qa-pair{border-left:2px solid var(--line);padding-left:10px}
.qa-q{font-family:var(--mono);font-size:11px;color:var(--ink2);line-height:1.45}
.qa-a{font-size:13px;color:var(--ink);margin-top:2px;line-height:1.5;white-space:pre-wrap}
.art-item.qft{background:rgba(178,106,44,.08);border-color:rgba(178,106,44,.4)}
.qft-q{font-size:13.5px;font-weight:700;color:var(--ink);margin-top:3px}
.qft-a{font-size:13px;color:var(--ink);margin-top:4px;line-height:1.5}
.qft-a.pending{font-family:var(--mono);font-size:11px;color:var(--amber)}

/* ── landing ── */
.land{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:24px clamp(18px,5vw,40px) 64px;text-align:center}
.land h1{font-weight:700;font-size:clamp(36px,6.5vw,64px);line-height:1.04;letter-spacing:-1.8px;
  margin:0 0 18px;max-width:760px;text-wrap:balance}
.land h1 .box{display:inline-block;background:var(--rust);color:var(--cream);padding:0 .14em;
  border-radius:.1em;transform:rotate(-1.5deg)}
.land p{font-size:clamp(15px,1.6vw,17px);color:var(--ink2);max-width:560px;margin:0 auto 34px}
.land-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:640px}
.land-card{display:block;background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:22px;text-align:left;box-shadow:var(--shadow);transition:transform .18s,border-color .18s}
.land-card:hover{transform:translateY(-3px);border-color:var(--rust)}
.land-card .lc-k{font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--rust);margin:0 0 8px}
.land-card h2{font-size:19px;font-weight:700;letter-spacing:-.3px;margin:0 0 6px}
.land-card p{font-size:13px;color:var(--ink2);margin:0;max-width:none}
.land-foot{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink2);margin-top:36px}

/* ── responsive ── */
@media (max-width:920px){
  .rv-grid{grid-template-columns:1fr}
  .rv-list{max-height:none}
  .drafts{grid-template-columns:1fr}
  .rights-form{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .app-bar{padding:16px 18px}
  .land-cards{grid-template-columns:1fr}
  .rights-form{grid-template-columns:1fr}
}
