/* BoundaryCheck App — unified design system
   Built 2026-04-27 from feedback in "I like this make a presentation for me.docx"
   Palette: routing-v4 photo-hero (Texas sunset + courthouse navy + emerald)
*/
:root{
  --navy:#0a1628; --blue:#1e3a8a; --emerald:#059669; --emerald-light:#10b981;
  --gold:#fbbf24; --orange:#f97316; --rust:#7c2d12; --forest:#166534;
  --slate-50:#f8fafc; --slate-100:#f1f5f9; --slate-200:#e2e8f0;
  --slate-400:#94a3b8; --slate-500:#64748b; --slate-600:#475569; --slate-700:#334155;
  --white:#ffffff;
  /* Status colors for property tracking */
  --status-for-sale:#3b82f6;       /* blue */
  --status-negotiating:#f59e0b;    /* amber */
  --status-under-contract:#1e40af; /* dark blue */
  --status-closed:#16a34a;         /* green */
  --status-issues:#dc2626;         /* red */
  --status-working:#d97706;        /* dark amber */
  --status-walked:#6b7280;         /* gray */
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:-apple-system,'Segoe UI',Roboto,sans-serif;color:var(--navy);background:linear-gradient(180deg,var(--navy) 0%,#0f1f3a 60%,var(--navy) 100%) fixed;background-attachment:fixed;min-height:100vh;line-height:1.5}
body.dark{background:var(--navy);color:var(--white)}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

/* ════════ LAYOUT ════════
   Body is deep navy. Content lives in a white "card" (.app) floating on the
   navy backdrop — like a phone screen on a courthouse desk. BETA + role badges
   stay gold-on-navy per Kevin Dale 2026-05-02 directive. */
.app{max-width:540px;margin:0 auto;padding-bottom:64px;position:relative;min-height:100vh;background:var(--white);box-shadow:0 0 40px rgba(0,0,0,.4);border-top:3px solid var(--gold)}
.app-dark{background:var(--navy);color:var(--white)}

/* ════════ TOP BAR ════════
   Navy band + gold BETA badge — the brand pair Kevin Dale 2026-05-02 locked
   ('blue and goldish color throughout the entire site/app'). Stays sticky
   at the top of every page; single source of truth — every page using
   app.css inherits the navy treatment automatically. */
.topbar{background:var(--navy);color:var(--white);padding:14px 20px;display:flex;align-items:center;gap:10px;border-bottom:2px solid var(--gold);position:sticky;top:0;z-index:50}
.topbar a{color:var(--white)}
.topbar.transparent{background:transparent;border-bottom:0;color:var(--white)}
.topbar .back{background:none;border:0;font-size:18pt;cursor:pointer;color:var(--white);padding:0;margin-right:4px;text-decoration:none}
.topbar .back:hover{color:var(--gold)}
.topbar .logo{font-weight:700;font-size:13pt;color:var(--white);letter-spacing:.3pt}
.topbar .badge{background:var(--gold);color:var(--navy);font-size:8pt;letter-spacing:1pt;padding:3px 9px;border-radius:3px;font-weight:800;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.topbar .role-pill{margin-left:auto;padding:3px 10px;border-radius:999px;font-size:9pt;font-weight:700;border:1px solid}
.role-pill.realtor{background:#dbeafe;color:#1e40af;border-color:var(--blue)}
.role-pill.investor{background:#dcfce7;color:var(--forest);border-color:var(--emerald)}
.role-pill.homeowner{background:#fef3c7;color:#78350f;border-color:#d97706}

/* ════════ HEROES ════════ */
.hero-photo{background:linear-gradient(160deg,rgba(10,22,40,.4) 0%,rgba(10,22,40,.85) 70%),url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 800"><defs><linearGradient id="sky" x1="0" y1="0" x2="0" y2="1"><stop offset="0" stop-color="%23fbbf24"/><stop offset="0.5" stop-color="%23f97316"/><stop offset="1" stop-color="%237c2d12"/></linearGradient><linearGradient id="ground" x1="0" y1="0" x2="0" y2="1"><stop offset="0" stop-color="%23166534"/><stop offset="1" stop-color="%230a1628"/></linearGradient></defs><rect width="1200" height="500" fill="url(%23sky)"/><rect width="1200" height="300" y="500" fill="url(%23ground)"/><polygon points="100,500 100,350 200,260 300,350 300,500" fill="%23475569"/><polygon points="350,500 350,300 450,200 550,300 550,500" fill="%23334155"/><polygon points="600,500 600,330 720,220 840,330 840,500" fill="%23475569"/><polygon points="900,500 900,360 980,290 1060,360 1060,500" fill="%23334155"/><rect x="140" y="380" width="40" height="80" fill="%23fbbf24"/><rect x="380" y="320" width="50" height="100" fill="%23fbbf24"/><rect x="640" y="370" width="60" height="100" fill="%23fbbf24"/></svg>');background-size:cover;background-position:center;color:var(--white)}

/* ════════ TYPE ════════ */
h1{font-size:30pt;font-weight:800;line-height:1.15;margin-bottom:8px}
h1.hero{font-size:42pt;text-shadow:0 2px 12px rgba(0,0,0,.4);text-align:center}
h2{font-size:18pt;font-weight:700;color:var(--navy);margin:20px 20px 10px}
h2.section-title{font-size:11pt;color:var(--slate-600);text-transform:uppercase;letter-spacing:.5pt;font-weight:700;display:flex;align-items:center;justify-content:space-between;padding:0 6px}
.tagline{font-size:13pt;color:var(--slate-600);line-height:1.5}
.tagline.light{color:#cbd5e1;text-align:center;max-width:400px;margin:0 auto 24px}

/* ════════ BUTTONS ════════ */
.btn{background:var(--blue);color:var(--white);border:0;border-radius:10px;padding:12px 20px;font-size:13pt;font-weight:700;cursor:pointer;font-family:inherit;text-decoration:none;display:inline-block;text-align:center}
.btn:hover{filter:brightness(1.08);text-decoration:none;color:var(--white)}
.btn.green{background:var(--emerald)}
.btn.gold{background:var(--gold);color:var(--navy)}
.btn.ghost{background:transparent;color:var(--blue);border:2px solid var(--blue)}
.btn.full{width:100%}
.btn.sm{padding:6px 12px;font-size:11pt}

/* Big role-cards (landing) */
.role-stack{display:flex;flex-direction:column;gap:14px;width:100%;max-width:420px;margin:0 auto}
.role-btn{background:rgba(255,255,255,.95);color:var(--navy);border:0;border-radius:14px;padding:22px;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:16px;text-align:left;transition:.15s;backdrop-filter:blur(6px);box-shadow:0 6px 20px rgba(0,0,0,.18);text-decoration:none;color:var(--navy)}
.role-btn:hover{transform:translateY(-2px);background:#fff;text-decoration:none}
.role-btn .ic{font-size:28pt;flex-shrink:0}
.role-btn .lbl{flex:1}
.role-btn h3{font-size:15pt;font-weight:700}
.role-btn .sub{font-size:11pt;color:var(--slate-600);margin-top:2px}
.role-btn .arrow{color:var(--blue);font-size:18pt;font-weight:700}

/* ════════ CARDS ════════ */
.card{background:var(--white);border:1px solid var(--slate-200);border-radius:10px;padding:14px 16px;margin:0 14px 8px}
.card.clickable{cursor:pointer;transition:.15s}
.card.clickable:hover{border-color:var(--blue);transform:translateY(-1px)}
/* Anchors styled as cards must:
   1. Render as blocks (anchors are inline by default; when they wrap a
      block-level flex child, the inline fragments draw the white card
      background as thin vertical scars to the left and right of the dot).
   2. NOT pick up the global a:hover underline — that line would cut a
      horizontal scar through the dot and through the address text. */
a.card,a.card:hover,a.card:visited,a.card:focus,a.card:active{display:block;color:inherit;text-decoration:none}

/* ════════ STATUS PILLS / DOTS ════════ */
.pill{padding:3px 10px;border-radius:999px;font-size:9pt;font-weight:700;display:inline-block}
.pill.green{background:#dcfce7;color:var(--forest)}
.pill.yellow{background:#fef3c7;color:#78350f}
.pill.red{background:#fee2e2;color:#991b1b}
.pill.blue{background:#dbeafe;color:#1e40af}
.pill.draft{background:#fef3c7;color:#78350f}
.pill.signed{background:#dcfce7;color:var(--forest)}
.pill.locked{background:#dcfce7;color:var(--forest)}
/* Status dots for property tracking */
.dot{display:inline-block;width:12px;height:12px;border-radius:50%;flex-shrink:0}
.dot-for-sale{background:var(--status-for-sale)}
.dot-negotiating{background:var(--status-negotiating)}
.dot-under-contract{background:var(--status-under-contract)}
.dot-closed{background:var(--status-closed)}
.dot-issues{background:var(--status-issues)}
.dot-working{background:var(--status-working)}
.dot-walked{background:var(--status-walked)}

/* Risk light */
.risk{margin:12px 14px;padding:14px 16px;border:2px solid;border-radius:10px;display:flex;align-items:center;gap:14px}
.risk.green{background:#dcfce7;border-color:var(--forest)}
.risk.green .level{color:var(--forest)}
.risk.yellow{background:#fef3c7;border-color:#ca8a04}
.risk.yellow .level{color:#78350f}
.risk.red{background:#fee2e2;border-color:#dc2626}
.risk.red .level{color:#991b1b}
.risk .level{font-size:18pt;font-weight:800}
.risk .h{font-size:11pt;font-weight:600}
.risk .level + div{flex:1}
.risk .refresh{margin-left:auto;background:var(--white);border:1px solid currentColor;color:inherit;padding:6px 10px;border-radius:6px;font-family:inherit;font-size:10pt;cursor:pointer;font-weight:700}

/* Banner notice (e.g., "exam recommended") */
.banner{margin:12px 14px;padding:14px 16px;border-left:4px solid;border-radius:8px;font-size:11pt;line-height:1.5}
.banner.info{background:#dbeafe;border-color:var(--blue);color:#1e40af}
.banner.warn{background:#fef3c7;border-color:#d97706;color:#78350f}
.banner.success{background:#dcfce7;border-color:var(--forest);color:var(--forest)}

/* ════════ INPUTS ════════ */
.input-group{background:var(--white);border:2px solid var(--slate-200);border-radius:12px;padding:16px;margin:0 14px 10px;transition:.15s}
.input-group:focus-within{border-color:var(--blue)}
.input-group label{font-size:10pt;color:var(--slate-600);font-weight:700;text-transform:uppercase;letter-spacing:.5pt}
.input-group input{width:100%;border:0;background:transparent;padding:8px 0 0;font-size:15pt;outline:none;font-family:inherit;color:var(--navy)}
.input-group input::placeholder{color:var(--slate-400)}

/* ════════ BOTTOM NAV (persistent on every page after sign-in) ════════ */
/* Bottom nav matches the navy top bar — gold accents on the active tab. */
.nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:540px;background:var(--navy);border-top:2px solid var(--gold);display:flex;justify-content:space-around;padding:8px 0 12px;z-index:50}
.nav-btn{color:#cbd5e1;font-size:9pt;text-align:center;cursor:pointer;flex:1;text-decoration:none;display:block;padding:4px 0}
.nav-btn:hover{text-decoration:none;color:var(--gold)}
.nav-btn.active{color:var(--gold);font-weight:700}
.nav-btn .ic{font-size:18pt;display:block}

/* ════════ MAP MOCK ════════ */
.map{position:relative;height:55vh;background:linear-gradient(180deg,var(--slate-200) 0%,var(--slate-400) 100%);overflow:hidden}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(0deg,rgba(255,255,255,.15) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.15) 1px,transparent 1px);background-size:36px 36px}
.map-roads::before,.map-roads::after{content:'';position:absolute;background:#fafafa}
.map-roads::before{left:0;right:0;top:50%;height:5px}
.map-roads::after{top:0;bottom:0;left:32%;width:5px}
.map .pin{position:absolute;width:30px;height:30px;background:var(--status-issues);border:3px solid #fff;border-radius:50%;box-shadow:0 4px 8px rgba(0,0,0,.25);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13pt;cursor:pointer;text-decoration:none}
.map .pin.for-sale{background:var(--status-for-sale)}
.map .pin.negotiating{background:var(--status-negotiating)}
.map .pin.under-contract{background:var(--status-under-contract)}
.map .pin.closed{background:var(--status-closed)}
.map .pin.issues{background:var(--status-issues)}
.map .pin.working{background:var(--status-working)}
.map .pin.walked{background:var(--status-walked)}

/* Status legend */
.legend{padding:12px 20px;background:var(--white);border-top:1px solid var(--slate-200);display:flex;flex-wrap:wrap;gap:10px;font-size:10pt;color:var(--slate-600)}
.legend-row{display:flex;align-items:center;gap:5px}

/* ════════ UTILS ════════ */
.center{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.flex{display:flex;align-items:center;gap:10px}
.flex-1{flex:1}
.row-pad{padding:14px 20px}
.muted{color:var(--slate-500);font-size:10pt}
.pad{padding:18px 20px}

/* ════════ SCAN PROGRESS — 30-box bar (Phase 1.6 b.1) ════════
   30 boxes that fill in sequentially while the public-record pull runs
   (CAD + tax + county clerk + district clerk firing in parallel). After
   the scan completes, the boxes recolor according to the severity finding
   so the bar persists as the scan-result visual on the result page.
   Locked 2026-05-03 per project_wizard_walkthrough_architecture.md. */
.scan-bar{display:grid;grid-template-columns:repeat(30,1fr);gap:3px;padding:14px 16px;background:var(--navy);border-radius:8px;border:1px solid #1e293b}
.scan-bar .box{aspect-ratio:1;background:rgba(255,255,255,.08);border-radius:2px;transition:background .25s ease,box-shadow .25s ease}
.scan-bar .box.filled{background:var(--gold);box-shadow:0 0 6px rgba(251,191,36,.5)}
/* Severity-colored fills (used after scan completes — color reflects square) */
.scan-bar.sev-1 .box.filled{background:#16a34a;box-shadow:0 0 6px rgba(22,163,74,.5)}      /* clean — green */
.scan-bar.sev-2 .box.filled{background:#84cc16;box-shadow:0 0 6px rgba(132,204,22,.5)}     /* cosmetic — lime */
.scan-bar.sev-3 .box.filled{background:#fbbf24;box-shadow:0 0 6px rgba(251,191,36,.5)}     /* light — gold */
.scan-bar.sev-4 .box.filled{background:#f97316;box-shadow:0 0 6px rgba(249,115,22,.5)}     /* moderate — orange */
.scan-bar.sev-5 .box.filled{background:#dc2626;box-shadow:0 0 6px rgba(220,38,38,.5)}      /* heavy — red */

/* Wrapping panel for the scan-status (replaces text-only banner on home.html) */
.scan-status-panel{margin:14px;padding:14px 16px;background:var(--navy);color:var(--white);border-radius:8px;border-top:3px solid var(--gold);font-family:Arial,sans-serif}
.scan-status-panel .status-title{font-size:13pt;font-weight:700;margin-bottom:8px}
.scan-status-panel .status-detail{font-size:11pt;opacity:.85;line-height:1.4;margin-bottom:10px}
.scan-status-panel .scan-bar{padding:10px 0 0;background:transparent;border:0}

/* ════════ SEVERITY SLIDER — 5 squares (Phase 1.6 b.1) ════════
   The minimal result page's only verdict. Squares 1-5 only — no Square 6.
   Brain ADVISES, never DECIDES. Square 5 carries an attorney-review
   recommendation footer (rendered server-side; not a CSS state).
   Locked 2026-05-03 per project_wizard_walkthrough_architecture.md. */
.sev-slider{padding:18px 20px;background:var(--white);border-radius:8px;margin:14px;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.sev-slider .label{font-family:Arial,sans-serif;font-size:10pt;font-weight:700;color:var(--slate-600);text-transform:uppercase;letter-spacing:1pt;margin-bottom:10px}
.sev-slider .squares{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:8px}
.sev-slider .sq{aspect-ratio:1.4;border-radius:5px;background:#e2e8f0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#64748b;font-family:Arial,sans-serif;font-weight:800;border:2px solid transparent}
.sev-slider .sq .num{font-size:16pt;line-height:1}
.sev-slider .sq .name{font-size:8pt;letter-spacing:.5pt;text-transform:uppercase;margin-top:2px;font-weight:600}
.sev-slider .sq.active{color:var(--white);border-color:var(--navy);box-shadow:0 2px 8px rgba(0,0,0,.18)}
.sev-slider .sq.active.s1{background:#16a34a}
.sev-slider .sq.active.s2{background:#84cc16}
.sev-slider .sq.active.s3{background:#fbbf24;color:var(--navy)}
.sev-slider .sq.active.s4{background:#f97316}
.sev-slider .sq.active.s5{background:#dc2626}
.sev-slider .scale-foot{display:flex;justify-content:space-between;font-family:Arial,sans-serif;font-size:9pt;color:var(--slate-500);margin-top:6px;letter-spacing:.5pt;text-transform:uppercase}
.sev-slider .verdict{font-family:Arial,sans-serif;font-size:13pt;font-weight:700;color:var(--navy);margin-top:14px;text-align:center}
.sev-slider .verdict-sub{font-family:Arial,sans-serif;font-size:11pt;color:var(--slate-600);text-align:center;margin-top:4px;line-height:1.4}
.sev-slider .attorney-note{margin-top:14px;padding:10px 14px;background:#fef3c7;border-left:3px solid #d97706;border-radius:4px;font-family:Arial,sans-serif;font-size:11pt;color:#78350f;line-height:1.4}

/* Timing banner — shown ABOVE the slider when a scheduled event is detected
   (foreclosure noticed, tax sale, IRS sale, bankruptcy hearing). Informational
   only. Brain ADVISES — never blocks the agent's List/Not decision. */
.timing-banner{margin:14px;padding:12px 16px;background:#fef3c7;border:1px solid #d97706;border-left:5px solid #d97706;border-radius:6px;font-family:Arial,sans-serif;color:#78350f}
.timing-banner .tb-title{font-size:11pt;font-weight:800;text-transform:uppercase;letter-spacing:1pt;margin-bottom:4px}
.timing-banner .tb-detail{font-size:11pt;line-height:1.4}

/* List / Not buttons on the minimal result page */
.decide-row{display:grid;grid-template-columns:2fr 1fr;gap:10px;padding:6px 14px 18px}
.decide-row .btn-list{background:var(--emerald);color:var(--white);font-family:Arial,sans-serif;font-size:14pt;font-weight:800;padding:18px 0;border-radius:8px;text-align:center;text-decoration:none;letter-spacing:.5pt;border:0;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.decide-row .btn-list:hover{background:var(--emerald-light);text-decoration:none}
.decide-row .btn-not{background:var(--white);color:var(--slate-600);font-family:Arial,sans-serif;font-size:12pt;font-weight:700;padding:18px 0;border-radius:8px;text-align:center;text-decoration:none;border:1px solid var(--slate-200);cursor:pointer}
.decide-row .btn-not:hover{background:var(--slate-50);text-decoration:none;color:var(--navy)}
