/* Plan 04-8-03 Task 1 — Verbatim port of lh-setup.html <style> block.
   Setup-class terminal chrome family per
   project_setup-class-terminals-one-visual-family. Palette + scanline +
   beam + cursor + chrome — identical to src/lh-setup.html so this page
   reads as the same physical terminal as /setup/auth.html. */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
::selection{background:#00ff41;color:#010e01;}
:root{
  --p:#00ff41;--p60:rgba(0,255,65,.6);--p35:rgba(0,255,65,.35);
  --p20:rgba(0,255,65,.2);--p10:rgba(0,255,65,.1);--p06:rgba(0,255,65,.06);
  --bg:#010e01;--room:#030503;
}
html{background:var(--room);height:100%;}
body{
  background:var(--room);min-height:100vh;min-height:100dvh;
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Mono','Courier New',monospace;
  overflow:hidden;position:relative;padding:3rem 2.5rem;
  -webkit-font-smoothing:antialiased;
  -webkit-tap-highlight-color:transparent;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.038'/%3E%3C/svg%3E");
}
body::after{
  content:'';position:fixed;top:50%;left:50%;transform:translate(-50%,-52%);
  width:1000px;height:800px;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse at 50% 46%,rgba(0,255,65,.05) 0%,rgba(0,255,65,.02) 35%,transparent 65%);
}
.screen{
  position:relative;z-index:5;width:100%;max-width:780px;
  height:calc(100vh - 6rem);min-height:480px;max-height:820px;
  background:var(--bg);overflow:hidden;
  box-shadow:0 0 0 1px var(--p06),0 0 40px rgba(0,255,65,.08),0 0 100px rgba(0,255,65,.04),0 40px 120px rgba(0,0,0,.8);
  animation:flicker 9s ease-in-out infinite;
}
@keyframes flicker{0%,89%,91%,93%,100%{opacity:1}90%{opacity:.97}92%{opacity:.98}}
.screen::before{
  content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse at 50% 38%,rgba(0,255,65,.08) 0%,rgba(0,255,65,.03) 45%,transparent 75%);
}
.screen::after{
  content:'';position:absolute;inset:0;z-index:10;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.14) 2px,rgba(0,0,0,.14) 3px);
}
.vig{position:absolute;inset:0;z-index:9;pointer-events:none;background:radial-gradient(ellipse at 50% 50%,transparent 50%,rgba(0,0,0,.4) 80%,rgba(0,0,0,.72) 100%);}
.glare{position:absolute;top:-20px;left:-30px;width:260px;height:260px;z-index:11;pointer-events:none;transform:rotate(-12deg);background:radial-gradient(ellipse,rgba(255,255,255,.013) 0%,transparent 65%);}
.wipe{position:absolute;inset:0;z-index:50;pointer-events:none;opacity:0;}
.wipe.go{animation:scanwipe .22s ease-in-out forwards;}
@keyframes scanwipe{
  0%{opacity:0;background:linear-gradient(180deg,transparent 0%,rgba(0,255,65,.4) 1%,rgba(0,255,65,.4) 5%,transparent 5%);background-position:0 -10%;}
  100%{opacity:1;background:linear-gradient(180deg,transparent 0%,rgba(0,255,65,.4) 1%,rgba(0,255,65,.4) 5%,transparent 5%);background-position:0 110%;}
}
.terminal{position:relative;z-index:5;padding:28px 44px 24px;height:100%;display:flex;flex-direction:column;color:var(--p);font-size:13px;line-height:1.7;letter-spacing:.03em;}
.t-brand{flex-shrink:0;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid rgba(0,255,65,.15);}
.t-brand-wm{font-size:15px;font-weight:500;letter-spacing:.12em;color:var(--p);line-height:1;margin-bottom:3px;}
.t-brand-sub{font-size:8px;letter-spacing:.28em;color:var(--p35);text-transform:uppercase;}
.t-status{flex-shrink:0;display:flex;justify-content:space-between;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--p10);font-size:8.5px;letter-spacing:.18em;color:var(--p35);transition:opacity .3s;}
.t-status.hide{opacity:0;pointer-events:none;}
.t-body{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;}
#out{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none;padding-right:2px;}
#out::-webkit-scrollbar{display:none;}
.t-footer{flex-shrink:0;margin-top:14px;padding-top:10px;border-top:1px solid var(--p10);font-size:9px;letter-spacing:.14em;color:var(--p35);display:flex;align-items:center;gap:12px;}
.pb span{color:var(--p20);transition:color .3s;}.pb span.f{color:var(--p);}
.dim{color:var(--p35);}.mid{color:var(--p60);}.bright{color:var(--p);}.wht{color:rgba(255,255,255,.85);}
.divl{color:var(--p20);}
.cursor{display:inline-block;width:8px;height:14px;background:var(--p);margin-left:1px;vertical-align:middle;animation:blink .53s step-end infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.cursor.off{opacity:0;animation:none;}
.inp-wrap{display:flex;align-items:center;gap:8px;margin-top:2px;flex-wrap:wrap;}
.inp-lbl{color:var(--p35);white-space:nowrap;flex-shrink:0;}
.inp-val{color:var(--p);flex:1;word-break:break-word;min-width:60px;}
/* Issue Z (Plan 04-8-03 follow-up) — tap-to-continue button BELOW each
   prompt. Wraps .inp-wrap + .cont-btn together so the button stacks
   underneath the input value, matching the lh-intake promptInp pattern
   (cloudflare/pages/public/intake/index.html line 2736-2741). The
   button itself uses the shared .cont-btn class (defined below) so the
   two surfaces — setup wizard and client intake — share one visual
   family. iOS keyboard "Done" no longer leaves the operator stranded:
   they tap the visible button to advance. */
.prompt-group{display:block;margin-bottom:6px;}
/* Plan 04-8-03 follow-up — setupCluster (multi-field form-step).
   Ported from intake/index.html .cluster-block (line 66) so the
   setup-class and intake terminals share one visual family for
   multi-field input. Used for the agency BUSINESS ADDRESS step in
   s0() — operator's "form with one Continue at the bottom" ask. */
.cluster-block{margin:8px 0;}
.cluster-block .inp-wrap{margin-top:10px;flex-wrap:nowrap;}
.cluster-inp{
  background:transparent;border:none;border-bottom:1px solid var(--p20);
  color:var(--p);font-family:'DM Mono','Courier New',monospace;
  font-size:13px;letter-spacing:.03em;outline:none;
  padding:4px 6px;min-width:200px;flex:1;
  transition:border-bottom-color .18s cubic-bezier(.2,.7,.2,1),box-shadow .18s cubic-bezier(.2,.7,.2,1);
}
.cluster-inp:focus{border-bottom-color:var(--p);box-shadow:0 1px 0 0 var(--p35);}
/* Places-locality autocomplete dropdown — anchored under the city
   input. Lifted from intake .cities-* (line 1642) using the same
   var(--p*) palette so the dropdown reads as part of the phosphor
   chrome rather than a foreign overlay. */
.cluster-block .cities-input-wrap{position:relative;flex:1;min-width:0;}
.cluster-block .cities-input-wrap .cluster-inp{width:100%;}
.cities-dropdown{
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:50;
  background:rgba(2,8,4,.96);border:1px solid var(--p35);
  max-height:220px;overflow-y:auto;
  font-family:'DM Mono','Courier New',monospace;
  font-size:12px;letter-spacing:.02em;
  box-shadow:0 4px 16px rgba(0,0,0,.5);
}
.cities-dropdown[hidden]{display:none;}
.cities-dropdown .cities-row{padding:7px 10px;color:var(--p);cursor:pointer;border-bottom:1px solid var(--p06);line-height:1.3;}
.cities-dropdown .cities-row:last-child{border-bottom:none;}
.cities-dropdown .cities-row:hover,
.cities-dropdown .cities-row.is-active{background:var(--p10);color:var(--p);}
.cities-dropdown .cities-row .cities-row-pick{color:var(--p35);margin-right:6px;}
.cities-dropdown .cities-empty{padding:8px 10px;color:var(--p35);font-style:italic;}
/* #hi hidden offscreen input — verbatim from lh-setup.html. Plan
   04-8-03 hard-rule 3: ZERO new keyboard-handling code. This element is
   the SAME pattern used by canonical lh-setup.html and is NOT the same
   element touched by Plan 01 commit 0214e2f (that lives on
   intake/index.html). top:-9999px keeps the input out of the viewport
   on every browser — no scroll-into-view side effect. */
#hi{position:fixed;top:-9999px;left:-9999px;opacity:0;width:1px;height:1px;border:none;background:transparent;color:transparent;caret-color:transparent;outline:none;font-size:16px;}
.w-overlay{position:absolute;inset:0;background:rgba(0,8,0,.93);z-index:30;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}
.w-overlay.show{opacity:1;pointer-events:all;}
.w-box{border:1px solid rgba(0,255,65,.28);background:var(--bg);padding:22px 26px;min-width:360px;max-width:520px;width:90%;box-shadow:0 0 40px rgba(0,255,65,.06);}
.w-title{font-size:9px;letter-spacing:.22em;color:var(--p35);text-transform:uppercase;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--p10);}
.cgrid{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;margin-bottom:16px;}
.csw{height:24px;cursor:pointer;border:1px solid transparent;transition:border-color .1s;position:relative;}
.csw:hover{border-color:rgba(0,255,65,.5);}.csw.sel{border-color:var(--p);}
.csw.sel::after{content:'\2713';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:9px;color:rgba(0,0,0,.7);font-weight:700;}
.w-row{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.w-lbl{font-size:9px;letter-spacing:.16em;color:var(--p35);white-space:nowrap;}
.w-inp{background:transparent;border:none;border-bottom:1px solid rgba(0,255,65,.3);color:var(--p);font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.08em;padding:3px 0;width:120px;outline:none;transition:border-bottom-color .18s cubic-bezier(.2,.7,.2,1),box-shadow .18s cubic-bezier(.2,.7,.2,1);}
.w-inp:focus{border-bottom-color:var(--p);box-shadow:0 1px 0 0 var(--p35);}
.w-btns{display:flex;gap:10px;margin-top:6px;}
.w-btn{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.12em;border:1px solid rgba(0,255,65,.3);background:transparent;color:var(--p60);padding:6px 16px;cursor:pointer;text-transform:uppercase;transition:background-color .15s cubic-bezier(.2,.7,.2,1),color .15s cubic-bezier(.2,.7,.2,1),border-color .15s cubic-bezier(.2,.7,.2,1),box-shadow .15s cubic-bezier(.2,.7,.2,1);}
.w-btn:hover{background:var(--p10);color:var(--p);}
.w-btn:focus-visible{outline:none;border-color:var(--p);box-shadow:0 0 0 1px var(--p35),0 0 12px rgba(0,255,65,.15);}
.w-btn.pri{border-color:var(--p);color:var(--p);}
/* Issue 04-8-03 (A): horizontal padding so the highlight outline (set
   inline by toggleWidget.updateCursor) has breathing room between the
   border and the row text. Inner padding stays clear of the outer
   .w-box frame (.w-box padding 22px 26px) — 10px row padding + -2px
   outline-offset leaves ~14px between highlight edge and modal frame. */
.tog-row{display:flex;justify-content:space-between;align-items:center;padding:10px;border-bottom:1px solid rgba(0,255,65,.08);cursor:pointer;user-select:none;}
.tog-row:last-of-type{border-bottom:none;}.tog-row:hover{background:rgba(0,255,65,.03);}
.tog-name{font-size:11px;letter-spacing:.06em;color:var(--p60);}
.tog-st{font-size:10px;letter-spacing:.1em;}.tog-st.on{color:var(--p);}.tog-st.off{color:rgba(0,255,65,.22);}
.chk-list{margin:8px 0;}
.chk-item{display:flex;align-items:flex-start;gap:10px;padding:6px 0;border-bottom:1px solid rgba(0,255,65,.06);cursor:pointer;font-size:11px;color:var(--p60);letter-spacing:.04em;user-select:none;}
.chk-item:last-child{border-bottom:none;}.chk-item.done{color:var(--p);}
.chk-box{color:var(--p20);flex-shrink:0;font-size:10px;}.chk-item.done .chk-box{color:var(--p);}
.doc-sec{font-size:8px;letter-spacing:.2em;color:var(--p35);text-transform:uppercase;margin:12px 0 5px;border-bottom:1px solid var(--p10);padding-bottom:4px;}
.msg{font-size:10px;letter-spacing:.07em;margin-top:5px;padding:4px 8px;border:1px solid;display:none;word-break:break-word;}
.msg.show{display:block;}.msg.ok{color:var(--p);border-color:rgba(0,255,65,.3);background:rgba(0,255,65,.04);}
.msg.err{color:#f87171;border-color:rgba(248,113,113,.3);background:rgba(248,113,113,.04);}
.msg.inf{color:var(--p60);border-color:var(--p10);}
.dl-all{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid rgba(0,255,65,.2);margin-top:10px;background:rgba(0,255,65,.03);gap:10px;flex-wrap:wrap;}
.dl-all-lbl{font-size:11px;color:var(--p);letter-spacing:.06em;}
.dl-all-btn{font-family:'DM Mono',monospace;font-size:9.5px;letter-spacing:.12em;border:1px solid rgba(0,255,65,.4);background:transparent;color:var(--p);padding:5px 14px;cursor:pointer;text-transform:uppercase;transition:background-color .15s cubic-bezier(.2,.7,.2,1),box-shadow .15s cubic-bezier(.2,.7,.2,1);}
.dl-all-btn:hover{background:var(--p10);}
.dl-all-btn:focus-visible{outline:none;box-shadow:0 0 0 1px var(--p),0 0 12px rgba(0,255,65,.18);}
.nav-row{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--p10);gap:10px;}
.back-btn{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.14em;border:1px solid rgba(0,255,65,.22);background:transparent;color:var(--p60);padding:6px 16px;cursor:pointer;text-transform:uppercase;transition:background-color .15s cubic-bezier(.2,.7,.2,1),color .15s cubic-bezier(.2,.7,.2,1),border-color .15s cubic-bezier(.2,.7,.2,1),box-shadow .15s cubic-bezier(.2,.7,.2,1);}
.back-btn:hover{background:var(--p06);color:var(--p);border-color:var(--p35);}
.back-btn:focus-visible{outline:none;color:var(--p);border-color:var(--p);box-shadow:0 0 0 1px var(--p35),0 0 12px rgba(0,255,65,.15);}
.nav-hint{font-size:8px;letter-spacing:.18em;color:var(--p20);text-transform:uppercase;margin-top:6px;text-align:right;}
.cont-btn{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.12em;border:1px solid rgba(0,255,65,.4);background:transparent;color:var(--p);padding:7px 20px;cursor:pointer;text-transform:uppercase;transition:background-color .15s cubic-bezier(.2,.7,.2,1),box-shadow .15s cubic-bezier(.2,.7,.2,1);}
.cont-btn:hover{background:var(--p10);}
.cont-btn:focus-visible{outline:none;box-shadow:0 0 0 1px var(--p),0 0 14px rgba(0,255,65,.18);}
.act-btn{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.1em;border:1px solid rgba(0,255,65,.4);background:transparent;color:var(--p);padding:7px 18px;cursor:pointer;text-transform:uppercase;margin:4px 0;transition:background-color .15s cubic-bezier(.2,.7,.2,1),box-shadow .15s cubic-bezier(.2,.7,.2,1);}
.act-btn:hover{background:var(--p10);}
.act-btn:focus-visible{outline:none;box-shadow:0 0 0 1px var(--p),0 0 14px rgba(0,255,65,.18);}
.act-btn:disabled{opacity:.45;cursor:not-allowed;}
.persist-back{position:absolute;top:24px;right:34px;z-index:20;display:none;flex-direction:column;align-items:flex-end;gap:3px;pointer-events:auto;}
.persist-back.show{display:flex;}
.persist-back .back-btn{font-size:9px;padding:4px 11px;letter-spacing:.18em;background:rgba(1,14,1,.72);backdrop-filter:blur(2px);}
.persist-back .pb-hint{font-size:7px;letter-spacing:.22em;color:var(--p20);text-transform:uppercase;}
@media(max-width:600px){.persist-back{top:14px;right:16px;}.persist-back .pb-hint{display:none;}}
@media (prefers-reduced-motion: reduce){
  .screen{animation:none;}
  .cursor{animation:none;opacity:.6;}
  .wipe.go{animation-duration:.05s;}
}
@media(max-width:600px){
  body{padding:0;}
  .screen{height:100vh;max-height:none;max-width:none;box-shadow:none;}
  .terminal{padding:18px 20px 14px;font-size:11px;}
  .cgrid{grid-template-columns:repeat(6,1fr);}
  /* 44pt tap targets — Apple HIG. Mirrors intake/index.html line 486 so
     setup wizard and client intake share one mobile button affordance. */
  .cont-btn{min-height:44px;padding:12px 22px;font-size:12px;}
  .back-btn{min-height:44px;padding:11px 18px;font-size:11px;}
  /* Plan 04-8-03 follow-up — cluster form-step on phones. Label
     stacks above input; input is full-width with iOS-safe 16px font
     and a 44pt comfortable typing zone. Lifted verbatim from
     intake/index.html line 593 (same widget, same problem solved). */
  .cluster-block .inp-wrap{
    flex-direction:column;
    align-items:stretch;
    gap:4px;
    margin-top:12px;
  }
  .cluster-block .inp-wrap .inp-lbl{
    font-size:10px;
    letter-spacing:.18em;
    color:var(--p35);
    text-transform:uppercase;
    white-space:normal;
  }
  .cluster-block .cluster-inp{
    width:100%;
    min-width:0;
    font-size:16px; /* iOS no-zoom */
    min-height:44px;
    padding:10px 8px;
  }
}