/* ============================================================================
   BLOS Insurance Network — Premium Platform Design System
   Direction: a private underwriting room. Deep navy ledger walls, brass
   fixtures, parchment workspaces, and ink-stamp status seals — the visual
   language of a bound policy book, not a generic SaaS dashboard.
   ============================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  /* Color tokens */
  --ink-900:#0B1A2B;
  --ink-800:#102338;
  --ink-700:#15314B;
  --ink-line:#27425E;
  --paper:#F4EFE3;
  --paper-dim:#EAE2D0;
  --paper-text:#1C2B22;
  --brass:#C9A14A;
  --brass-bright:#E0BC6F;
  --forest:#2F6B4F;
  --forest-bright:#3E8C68;
  --brick:#A8403A;
  --brick-bright:#C65A52;
  --slate:#93A1B0;
  --white:#FFFFFF;

  /* Type */
  --font-display:'Fraunces', 'Iowan Old Style', serif;
  --font-body:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:'IBM Plex Mono', 'SF Mono', monospace;

  /* Layout */
  --radius-card:18px;
  --radius-pill:999px;
  --shadow-card:0 18px 40px rgba(5,12,22,.35);
  --shadow-soft:0 8px 20px rgba(5,12,22,.22);
  --sidebar-w:240px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  background:var(--ink-900);
  color:var(--paper);
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
a{color:inherit}
button{font-family:inherit}
.hidden{display:none !important}
::selection{background:var(--brass);color:var(--ink-900)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--ink-line);border-radius:6px}
::-webkit-scrollbar-track{background:transparent}

/* Focus visibility (accessibility) */
:focus-visible{outline:2px solid var(--brass-bright);outline-offset:2px}

/* ----------------------------------------------------------------------
   Texture: faint ledger ruling on the navy shell
   ---------------------------------------------------------------------- */
.ledger-bg{
  position:fixed;inset:0;z-index:-1;
  background:
    radial-gradient(900px 500px at 85% -10%, rgba(201,161,74,.10), transparent 60%),
    repeating-linear-gradient(180deg, rgba(255,255,255,0.025) 0px, rgba(255,255,255,0.025) 1px, transparent 1px, transparent 38px),
    linear-gradient(160deg, var(--ink-900), #0a1626 70%);
}

/* ----------------------------------------------------------------------
   Brand mark
   ---------------------------------------------------------------------- */
.brandmark{display:flex;align-items:center;gap:10px}
.brandmark .seal-mini{
  width:34px;height:34px;border-radius:50%;
  border:2px solid var(--brass);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--brass-bright);
  flex:none;
}
.brandmark .wordmark{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:.01em;color:var(--paper)}
.brandmark .wordmark small{display:block;font-family:var(--font-body);font-weight:500;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate)}

/* ----------------------------------------------------------------------
   AUTH / MARKETING SCREEN
   ---------------------------------------------------------------------- */
.auth-screen{
  min-height:100vh;display:grid;grid-template-columns:1.15fr 1fr;
}
@media (max-width:920px){ .auth-screen{grid-template-columns:1fr} .auth-screen .auth-art{display:none} }

.auth-art{
  position:relative;overflow:hidden;
  padding:56px 56px 40px;
  display:flex;flex-direction:column;justify-content:space-between;
  border-right:1px solid var(--ink-line);
}
.auth-art .eyebrow{
  text-transform:uppercase;letter-spacing:.18em;font-size:11.5px;color:var(--brass-bright);font-weight:600;
}
.auth-art h1{
  font-family:var(--font-display);font-weight:600;font-size:clamp(34px,4.4vw,54px);
  line-height:1.04;margin:18px 0 16px;max-width:560px;color:var(--paper);
}
.auth-art p.lead{color:var(--slate);font-size:16px;line-height:1.6;max-width:480px}

.big-seal{
  position:relative;width:230px;height:230px;border-radius:50%;
  border:3px solid var(--brass);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  transform:rotate(-7deg);
  box-shadow:0 0 0 6px rgba(201,161,74,.08);
  margin:18px 0;
}
.big-seal::before{
  content:'';position:absolute;inset:10px;border-radius:50%;border:1px dashed rgba(201,161,74,.55);
}
.big-seal .seal-top{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-bright);font-weight:700}
.big-seal .seal-main{font-family:var(--font-display);font-weight:700;font-size:30px;color:var(--paper);margin:4px 0}
.big-seal .seal-bottom{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--slate)}

.metric-row{display:flex;gap:34px;flex-wrap:wrap}
.metric-row .metric b{display:block;font-family:var(--font-mono);font-size:26px;color:var(--brass-bright)}
.metric-row .metric span{font-size:12px;color:var(--slate);text-transform:uppercase;letter-spacing:.08em}

.auth-panel{display:flex;align-items:center;justify-content:center;padding:40px}
.auth-card{
  width:100%;max-width:400px;background:var(--ink-800);border:1px solid var(--ink-line);
  border-radius:var(--radius-card);padding:34px 32px;box-shadow:var(--shadow-card);
}
.auth-card h2{font-family:var(--font-display);font-weight:600;font-size:24px;margin:4px 0 4px}
.auth-card .sub{color:var(--slate);font-size:13.5px;margin-bottom:22px}
.tabs{display:flex;gap:6px;background:var(--ink-900);border-radius:var(--radius-pill);padding:4px;margin-bottom:22px}
.tabs button{flex:1;border:0;background:transparent;color:var(--slate);padding:9px 0;border-radius:var(--radius-pill);font-weight:600;font-size:13px;cursor:pointer;transition:.15s}
.tabs button.active{background:var(--brass);color:var(--ink-900)}

.field{margin-bottom:14px}
.field label{display:block;font-size:12px;color:var(--slate);margin-bottom:6px;font-weight:600;letter-spacing:.02em}
.field input,.field select,.field textarea{
  width:100%;background:var(--ink-900);border:1px solid var(--ink-line);color:var(--paper);
  border-radius:10px;padding:11px 13px;font-size:14px;font-family:inherit;
}
.field textarea{min-height:90px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brass)}
.field .hint{font-size:11.5px;color:var(--slate);margin-top:5px}

.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.role-grid label{
  border:1px solid var(--ink-line);border-radius:10px;padding:9px 10px;font-size:12.5px;color:var(--slate);
  cursor:pointer;display:flex;align-items:center;gap:7px;
}
.role-grid input{accent-color:var(--brass)}
.role-grid label.checked{border-color:var(--brass);color:var(--paper)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:0;border-radius:12px;padding:12px 18px;font-weight:700;font-size:14px;cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease; width:100%;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(180deg,var(--brass-bright),var(--brass));color:#1d1404;box-shadow:0 10px 22px rgba(201,161,74,.25)}
.btn-ghost{background:transparent;border:1px solid var(--ink-line);color:var(--paper)}
.btn-danger{background:var(--brick);color:#fff}
.btn-sm{padding:8px 13px;font-size:12.5px;width:auto}
.btn-block-row{display:flex;gap:10px}

.form-msg{font-size:13px;border-radius:10px;padding:10px 12px;margin-bottom:14px}
.form-msg.error{background:rgba(168,64,58,.18);color:#ffb3ae;border:1px solid rgba(168,64,58,.4)}
.form-msg.success{background:rgba(63,140,104,.18);color:#a9e6c5;border:1px solid rgba(63,140,104,.4)}

.demo-note{margin-top:18px;font-size:11.5px;color:var(--slate);text-align:center;line-height:1.5}

/* ----------------------------------------------------------------------
   APP SHELL
   ---------------------------------------------------------------------- */
.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
@media (max-width:840px){ .app-shell{grid-template-columns:1fr} .sidebar{position:fixed;left:0;top:0;bottom:0;z-index:50;transform:translateX(-100%);transition:transform .2s} .sidebar.open{transform:translateX(0)} }

.sidebar{
  background:var(--ink-800);border-right:1px solid var(--ink-line);
  display:flex;flex-direction:column;padding:22px 16px;gap:6px;width:var(--sidebar-w);
}
.sidebar .brandmark{padding:6px 8px 22px}
.nav-section{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);margin:14px 10px 6px}
.nav-link{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--slate);
  font-size:13.5px;font-weight:600;cursor:pointer;border:1px solid transparent;
}
.nav-link .dot{width:6px;height:6px;border-radius:50%;background:var(--ink-line);flex:none}
.nav-link:hover{background:var(--ink-700);color:var(--paper)}
.nav-link.active{background:rgba(201,161,74,.12);border-color:rgba(201,161,74,.35);color:var(--brass-bright)}
.nav-link.active .dot{background:var(--brass)}
.sidebar-footer{margin-top:auto;padding:14px 10px;border-top:1px solid var(--ink-line);font-size:12px;color:var(--slate)}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 28px;border-bottom:1px solid var(--ink-line);
  background:rgba(11,26,43,.7);backdrop-filter:blur(6px);position:sticky;top:0;z-index:10;
}
.topbar .crumb{font-size:13px;color:var(--slate)}
.topbar .crumb b{color:var(--paper);font-weight:700}
.menu-toggle{display:none;background:transparent;border:1px solid var(--ink-line);color:var(--paper);border-radius:8px;padding:7px 10px;cursor:pointer}
@media (max-width:840px){ .menu-toggle{display:inline-flex} }
.topbar-right{display:flex;align-items:center;gap:14px}
.user-chip{display:flex;align-items:center;gap:10px;font-size:13px}
.user-chip .avatar{width:32px;height:32px;border-radius:50%;background:var(--brass);color:#1d1404;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.user-chip .role-tag{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--slate)}

.content{padding:28px;flex:1}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-family:var(--font-display);font-weight:600;font-size:30px;margin:0 0 6px}
.page-head p{color:var(--slate);margin:0;font-size:14px;max-width:560px}

/* ----------------------------------------------------------------------
   CARDS, GRIDS, STATS
   ---------------------------------------------------------------------- */
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:1100px){ .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))} .grid-3{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:640px){ .grid-2,.grid-3,.grid-4{grid-template-columns:1fr} }

.card{
  background:var(--ink-800);border:1px solid var(--ink-line);border-radius:var(--radius-card);
  padding:22px;box-shadow:var(--shadow-soft);
}
.card.paper{background:var(--paper);color:var(--paper-text);border-color:var(--paper-dim)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}
.card-head h3{font-size:15px;margin:0;font-weight:700}
.card-head .eyebrow{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--slate)}

.stat-card b{display:block;font-family:var(--font-mono);font-size:28px;margin-bottom:2px}
.stat-card span{font-size:12px;color:var(--slate);text-transform:uppercase;letter-spacing:.06em}
.stat-card.accent-brass b{color:var(--brass-bright)}
.stat-card.accent-forest b{color:var(--forest-bright)}
.stat-card.accent-brick b{color:var(--brick-bright)}

/* ----------------------------------------------------------------------
   SEAL / STATUS STAMP — signature element
   ---------------------------------------------------------------------- */
.seal{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 11px 5px 9px;border-radius:var(--radius-pill);border:1.5px solid currentColor;
  transform:rotate(-2deg);position:relative;
}
.seal::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor}
.seal.s-active,.seal.s-approved,.seal.s-bound,.seal.s-paid,.seal.s-valid{color:var(--forest-bright)}
.seal.s-pending,.seal.s-submitted,.seal.s-requested,.seal.s-pending_review,.seal.s-pending_bind{color:var(--brass-bright)}
.seal.s-declined,.seal.s-rejected,.seal.s-cancelled,.seal.s-expired,.seal.s-chargeback,.seal.s-denied,.seal.s-suspended{color:var(--brick-bright)}
.seal.s-quoted,.seal.s-in_underwriting,.seal.s-under_review{color:#8FB6D9}

/* ----------------------------------------------------------------------
   TABLES
   ---------------------------------------------------------------------- */
.table-wrap{overflow-x:auto;border-radius:14px;border:1px solid var(--ink-line)}
table{width:100%;border-collapse:collapse;font-size:13.5px;min-width:560px}
thead th{
  text-align:left;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);
  padding:12px 16px;background:var(--ink-700);border-bottom:1px solid var(--ink-line);white-space:nowrap;
}
tbody td{padding:13px 16px;border-bottom:1px solid var(--ink-line);vertical-align:middle}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:rgba(255,255,255,.02)}
td.num,th.num{font-family:var(--font-mono);text-align:right}
.row-title{font-weight:700}
.row-sub{color:var(--slate);font-size:12px}

/* ----------------------------------------------------------------------
   FORMS within app (intake / quote / onboarding)
   ---------------------------------------------------------------------- */
.app-field{margin-bottom:14px}
.app-field label{display:block;font-size:12px;color:var(--slate);margin-bottom:6px;font-weight:600}
.app-field input,.app-field select,.app-field textarea{
  width:100%;background:var(--ink-900);border:1px solid var(--ink-line);color:var(--paper);
  border-radius:10px;padding:10px 12px;font-size:13.5px;font-family:inherit;
}
.app-field textarea{min-height:84px;resize:vertical}
.app-field input:focus,.app-field select:focus,.app-field textarea:focus{border-color:var(--brass)}
.field-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (max-width:640px){ .field-row{grid-template-columns:1fr} }

.steps{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}
.step-chip{
  font-size:11.5px;color:var(--slate);padding:7px 12px;border-radius:var(--radius-pill);border:1px solid var(--ink-line);
}
.step-chip.active{color:var(--brass-bright);border-color:var(--brass)}
.step-chip.done{color:var(--forest-bright);border-color:var(--forest)}

.progress-track{height:8px;border-radius:5px;background:var(--ink-900);overflow:hidden;border:1px solid var(--ink-line)}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--brass),var(--brass-bright));border-radius:5px}

/* ----------------------------------------------------------------------
   CAROUSEL / CARRIER CARDS
   ---------------------------------------------------------------------- */
.carrier-card{background:var(--ink-800);border:1px solid var(--ink-line);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:10px}
.carrier-card h3{margin:0;font-size:16px}
.carrier-card .tagrow{display:flex;gap:6px;flex-wrap:wrap}
.tag{font-size:11px;background:var(--ink-700);color:var(--slate);padding:4px 9px;border-radius:var(--radius-pill);border:1px solid var(--ink-line)}
.carrier-card .commission{font-family:var(--font-mono);font-size:22px;color:var(--brass-bright)}
.carrier-card p{color:var(--slate);font-size:12.5px;margin:0;line-height:1.5}

/* ----------------------------------------------------------------------
   CHARTS (pure SVG, no libraries)
   ---------------------------------------------------------------------- */
.chart-bar-bg{fill:var(--ink-700)}
.chart-bar{fill:var(--brass)}
.chart-bar.alt{fill:var(--forest)}
.chart-line{fill:none;stroke:var(--brass-bright);stroke-width:2.5}
.chart-dot{fill:var(--brass-bright)}
.chart-axis{stroke:var(--ink-line)}
.chart-label{font-family:var(--font-mono);font-size:10px;fill:var(--slate)}

/* ----------------------------------------------------------------------
   TOASTS / MODALS
   ---------------------------------------------------------------------- */
.toast-stack{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:10px;z-index:200}
.toast{
  background:var(--ink-800);border:1px solid var(--ink-line);border-left:4px solid var(--brass);
  color:var(--paper);padding:13px 16px;border-radius:10px;box-shadow:var(--shadow-card);font-size:13px;
  min-width:240px;max-width:340px;animation:toastIn .18s ease;
}
.toast.error{border-left-color:var(--brick)}
.toast.success{border-left-color:var(--forest)}
@keyframes toastIn{from{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}

.modal-backdrop{position:fixed;inset:0;background:rgba(5,11,20,.65);display:flex;align-items:center;justify-content:center;z-index:150;padding:20px}
.modal{background:var(--ink-800);border:1px solid var(--ink-line);border-radius:var(--radius-card);padding:26px;max-width:480px;width:100%;box-shadow:var(--shadow-card);max-height:86vh;overflow-y:auto}
.modal h3{margin:0 0 14px;font-family:var(--font-display);font-size:20px}

/* ----------------------------------------------------------------------
   EMPTY STATES
   ---------------------------------------------------------------------- */
.empty{
  text-align:center;padding:48px 20px;color:var(--slate);
}
.empty .seal{margin-bottom:14px}
.empty h4{color:var(--paper);margin:0 0 6px;font-size:15px}
.empty p{margin:0;font-size:13px}

footer.legal{padding:18px 28px;color:var(--slate);font-size:11.5px;border-top:1px solid var(--ink-line);line-height:1.6}
