/* ============================================================
   Ask Hava — Lake Ink & Brass design system (Phase-0 foundation)
   Ported VERBATIM from askhava-redesign/mockups/lake.css (the v10
   system), with self-hosted @font-face prepended. Do not redesign
   here — this file is the single source of truth that every Lake
   template + component consumes. Keep it in sync with the mockups.
   ============================================================ */

/* Self-hosted variable fonts (OFL-1.1; files + licenses in /static/fonts/).
   Replaces the runtime Google Fonts <link> from the desert theme — better
   LCP, privacy, and reliability. `font-display:swap` avoids invisible text;
   the two primary weights are <link rel=preload>ed in base_lake.html. */
@font-face{
  font-family:"Inter";
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url("../fonts/inter-latin-wght-normal.woff2") format("woff2");
}
@font-face{
  font-family:"Fraunces";
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url("../fonts/fraunces-latin-wght-normal.woff2") format("woff2");
}

:root{
  --ink:#10202b; --ink-soft:#1b2f3a; --ink-2:#374954; --muted:#5e6e79;
  --hair:#dbe3e9; --hair-2:#c6d2da;
  --paper:#e8eef3; --surface:#f1f5f8; --raised:#ffffff;
  --brass:#b07a22; --brass-deep:#835914; --brass-light:#d8a64e; --brass-wash:#f7ecd5; --brass-edge:#e7d1a3;
  --good:#2c7d57; --warn:#b4511c; --havasu:#1c9bb4;
  --disp:"Fraunces",Georgia,serif; --ui:"Inter",system-ui,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --sh-1:0 1px 1px rgba(16,32,43,.05), 0 3px 8px -5px rgba(16,32,43,.14);
  --sh-card:0 1px 2px rgba(16,32,43,.04), 0 6px 14px -8px rgba(16,32,43,.16), 0 18px 40px -22px rgba(16,32,43,.30);
  --sh-2:0 18px 44px -22px rgba(16,32,43,.5);
  --sh-pop:0 30px 60px -28px rgba(16,32,43,.55);
}
*,*::before,*::after{box-sizing:border-box}*{font-style:normal}
html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);font-family:var(--ui);font-size:16px;line-height:1.5;font-optical-sizing:auto;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip;position:relative;
  background:radial-gradient(120% 80% at 50% -10%,#f1f6f9 0%,#e8eef3 45%,#e0e8ee 100%) fixed}
a{color:inherit;text-decoration:none}h1,h2,h3,h4,h5,p{margin:0}ul{margin:0;padding:0;list-style:none}svg{display:block}
.disp{font-family:var(--disp);font-weight:600;letter-spacing:-.015em}
.tnum{font-variant-numeric:tabular-nums}
.wrap{max-width:1140px;margin:0 auto;padding:0 34px}
.eyebrow{font:600 12px/1 var(--ui);text-transform:uppercase;letter-spacing:.14em;color:var(--brass-deep)}
.skip{position:absolute;left:-999px;top:0;background:#fff;color:var(--ink);padding:10px 16px;border-radius:0 0 10px 0;z-index:100}
.skip:focus{left:0}
a:focus-visible,button:focus-visible,[tabindex]:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px var(--havasu);border-radius:10px}

/* buttons + chips */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--ui);font-weight:600;font-size:14px;border-radius:999px;padding:11px 20px;cursor:pointer;border:1px solid transparent;transition:transform .14s var(--ease),background .18s,border-color .18s,box-shadow .18s;min-height:44px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(160deg,#22394a,#10202b);color:#fff}
.btn-ghost{background:var(--raised);color:var(--ink);border-color:var(--hair-2);box-shadow:var(--sh-1)}
.btn-ghost:hover{border-color:var(--ink);box-shadow:var(--sh-card);transform:translateY(-1px)}
.btn-brass{background:var(--brass);color:#fff}.btn-brass:hover{background:var(--brass-light)}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:500;color:var(--ink-2);background:linear-gradient(180deg,#fff,#fbfcfd);border:1px solid var(--hair-2);border-radius:999px;padding:7px 15px;cursor:pointer;box-shadow:var(--sh-1);transition:.16s;min-height:38px}
.chip:hover{border-color:var(--ink);transform:translateY(-1px)}
.chip.on{background:linear-gradient(165deg,#1b2f3a,#10202b);color:#fff;border-color:var(--ink);box-shadow:var(--sh-card)}
.tag{font-size:10.5px;font-weight:600;color:var(--ink-2);background:var(--surface);border:1px solid var(--hair-2);border-radius:6px;padding:2px 7px}
.tag.free{color:var(--good);border-color:rgba(44,125,87,.3);background:rgba(44,125,87,.08)}
.tag.spon{color:var(--brass-deep);background:var(--brass-wash);border-color:var(--brass-edge)}

/* brand */
.brand{display:flex;align-items:center;gap:12px;flex:none}
.brand .mk{width:auto;height:26px;flex:none}
.brand .wm{font-family:var(--disp);font-weight:600;font-size:21px;letter-spacing:-.02em;color:#eef3f7}
.brand .wm .b{color:var(--brass-light)}

/* header + conditions bar */
.hdr{position:sticky;top:0;z-index:50;background:linear-gradient(180deg,#13242f,#0e1d27)}
.hdr-in{max-width:1140px;margin:0 auto;padding:0 34px;display:flex;align-items:center;gap:20px;height:64px}
.hdr .nav{margin-left:auto;display:flex;align-items:center;gap:24px;font-size:14.5px;font-weight:500;color:#9fb1bc}
.hdr .nav a:hover{color:#fff}.hdr .nav .biz{color:var(--brass-light);font-weight:600}
.condband{background:linear-gradient(180deg,#fbfdfe,#eef3f7);border-bottom:1px solid var(--hair)}
.cb-in{display:flex;align-items:center;gap:18px;height:42px;font-size:13px;white-space:nowrap}
.cb-loc{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--ink);flex:none}
.cb-loc .cb-dot{width:6px;height:6px;border-radius:50%;background:var(--brass);box-shadow:0 0 0 3px rgba(176,122,34,.16)}
.cb-loc .cb-date{font-weight:500;color:var(--muted)}
.cb-stats{margin-left:auto;display:flex;align-items:stretch;overflow-x:auto;scrollbar-width:none;min-width:0}
.cb-stats::-webkit-scrollbar{display:none}
.cb-stat{display:flex;flex-direction:column;justify-content:center;gap:1px;padding:0 15px;border-left:1px solid var(--hair);flex:none}
.cb-stat:first-child{border-left:0}
.cb-stat .v{font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.01em;line-height:1.15}
.cb-stat .v small{font-weight:500;color:var(--muted);font-size:11px}.cb-stat .v.sev{color:var(--warn)}
.cb-stat .l{font-size:10.5px;color:var(--muted)}.cb-stat .l.ok{color:var(--good)}
.cb-live{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--havasu);flex:none;padding-left:6px}
.cb-live .pulse{width:7px;height:7px;border-radius:50%;background:var(--havasu)}

/* breadcrumbs + page head */
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);padding:18px 0 0;flex-wrap:wrap}
.crumbs a{color:var(--brass-deep);font-weight:600}.crumbs .sep{color:var(--hair-2)}
.pagehead{padding:14px 0 8px}
.pagehead h1{font-family:var(--disp);font-weight:600;font-size:clamp(28px,4.4vw,40px);letter-spacing:-.02em;line-height:1.05}
.pagehead .sub{font-size:15px;color:var(--ink-2);margin-top:8px;max-width:60ch;line-height:1.55}

/* generic card + section */
.card{background:var(--raised);border:1px solid var(--hair);border-radius:18px;box-shadow:var(--sh-card);overflow:hidden}
.section{padding:34px 0}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.sec-head h2{font-family:var(--disp);font-weight:600;font-size:26px;letter-spacing:-.02em}
.sec-head .more{font-size:14px;font-weight:600;color:var(--brass-deep);display:inline-flex;align-items:center;gap:7px}

/* sponsored unit (honest, one label) */
.adbar{display:flex;align-items:center;gap:15px;background:linear-gradient(180deg,#fffdf8,#fbf6ec);border:1px solid var(--brass-edge);border-radius:16px;padding:13px 18px;box-shadow:var(--sh-1);position:relative;overflow:hidden}
.adbar::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(var(--brass-light),var(--brass))}
.adbar .mono{width:48px;height:48px;border-radius:13px;background:linear-gradient(160deg,#f9eed7,#f1e0bd);border:1px solid var(--brass-edge);display:flex;align-items:center;justify-content:center;flex:none;font-family:var(--disp);font-weight:600;font-size:21px;color:var(--brass-deep)}
.adbar .ab{min-width:0;flex:1}
.adbar .stag{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--brass-deep);background:var(--brass-wash);border:1px solid var(--brass-edge);border-radius:6px;padding:2px 8px;margin-bottom:4px}
.adbar .an{font-family:var(--disp);font-weight:600;font-size:17px}
.adbar .am{font-size:13px;color:var(--ink-2);margin-top:1px}.adbar .am .open{color:var(--good);font-weight:600}.adbar .am .star{color:var(--brass-deep);font-weight:600}
.adbar .ar{margin-left:auto;flex:none}

/* event rows (list) */
.elist{background:var(--raised);border:1px solid var(--hair);border-radius:18px;overflow:hidden;box-shadow:var(--sh-card)}
.eitem{border-top:1px solid var(--hair)}.eitem:first-child{border-top:0}
.erow{display:flex;align-items:center;gap:14px;padding:13px 16px;position:relative}
.eitem.feat .erow{background:linear-gradient(180deg,#fcf3de,#f9edd0)}
.eitem.feat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(var(--brass-light),var(--brass))}
.erow .mono{width:42px;height:42px;border-radius:12px;background:var(--brass-wash);border:1px solid var(--brass-edge);display:flex;align-items:center;justify-content:center;flex:none;font-family:var(--disp);font-weight:600;font-size:15px;color:var(--brass-deep)}
.erow .body{min-width:0;flex:1}
.erow .l1{display:flex;align-items:baseline;gap:12px}
.erow .tm{font-size:13.5px;font-weight:600;color:var(--ink-2);width:74px;flex:none;white-space:nowrap}
.erow .ti2{font-family:var(--disp);font-weight:500;font-size:16px;color:var(--ink)}
.erow .flag{margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--brass-deep);background:var(--brass-wash);border:1px solid var(--brass-edge);border-radius:5px;padding:2px 6px;align-self:center}
.erow .l2{font-size:12.5px;color:var(--ink-2);margin-top:2px;margin-left:88px}
.erow .chev{margin-left:auto;color:var(--muted)}.erow .chev svg{width:16px;height:16px}

/* directory tiles */
.exgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.extile{background:linear-gradient(180deg,#fff,#fbfdfe);border:1px solid var(--hair);border-radius:18px;padding:24px;position:relative;box-shadow:var(--sh-1);transition:transform .25s var(--ease),box-shadow .25s,border-color .25s}
.extile:hover{transform:translateY(-5px);box-shadow:var(--sh-pop);border-color:var(--hair-2)}
.extile .ic{width:40px;height:40px;border-radius:12px;background:var(--brass-wash);border:1px solid var(--brass-edge);display:flex;align-items:center;justify-content:center;color:var(--brass-deep)}.extile .ic svg{width:22px;height:22px}
.extile h3{font-family:var(--disp);font-weight:600;font-size:20px;margin-top:15px}.extile h3 .c{font-family:var(--ui);font-weight:500;font-size:13px;color:var(--muted);margin-left:8px}
.extile p{font-size:13.5px;color:var(--ink-2);margin-top:5px}

/* business card (directory listing) */
.bizcard{display:flex;gap:15px;padding:16px;border-top:1px solid var(--hair)}
.bizcard:first-child{border-top:0}
.bizcard .ph{width:84px;height:84px;border-radius:14px;background:linear-gradient(160deg,#dde6ec,#cdd9e1);flex:none;border:1px solid var(--hair-2);overflow:hidden}
.bizcard .bb{flex:1;min-width:0}
.bizcard .bn{font-family:var(--disp);font-weight:600;font-size:18px;display:flex;align-items:center;gap:8px}
.bizcard .meta{font-size:13px;color:var(--ink-2);margin-top:3px}
.bizcard .meta .open{color:var(--good);font-weight:600}.bizcard .meta .star{color:var(--brass-deep);font-weight:600}
.bizcard .chips{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap}
.bizcard .act{margin-left:auto;display:flex;flex-direction:column;gap:8px;align-items:flex-end;flex:none}

/* forms */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--hair-2);border-radius:12px;padding:11px 14px;font-family:var(--ui);font-size:15px;background:#fff;color:var(--ink);min-height:46px}
.field .hint{font-size:12px;color:var(--muted);margin-top:5px}
.field .err{font-size:12.5px;color:var(--warn);margin-top:5px}

/* tables (admin) */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding:11px 14px;border-bottom:1px solid var(--hair)}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--hair);color:var(--ink-2)}
.tbl tr:hover td{background:var(--surface)}
.pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;border-radius:999px;padding:3px 9px}
.pill.ok{color:var(--good);background:rgba(44,125,87,.1)}.pill.warn{color:var(--warn);background:rgba(180,81,28,.1)}.pill.spon{color:var(--brass-deep);background:var(--brass-wash)}

/* article (editorial/static) */
.article{max-width:720px;margin:0 auto;padding:8px 0 40px}
.article h2{font-family:var(--disp);font-weight:600;font-size:26px;letter-spacing:-.02em;margin:34px 0 10px}
.article p{font-size:16px;color:var(--ink-2);line-height:1.7;margin:0 0 16px}
.article .lead{font-size:19px;color:var(--ink);line-height:1.6}

/* footer */
.ft{background:linear-gradient(180deg,#13242f,#0d1b24);color:#c2ced6;padding:56px 0 28px;margin-top:40px}
.ft-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:34px}
.ft .brand .wm{color:#fff}.ft .tag{font-size:14px;color:#90a3ae;max-width:30ch;line-height:1.6;margin-top:14px}
.ft h5{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#7d909a;margin-bottom:12px}
.ft a.fl{display:block;padding:5px 0;font-size:14px;color:#c2ced6}.ft a.fl:hover{color:#fff}
.ft-trust{margin-top:40px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);font-size:13px;color:#90a3ae;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ft-trust .tl{display:flex;gap:8px;flex-wrap:wrap}.ft-trust .tl span{display:inline-flex;align-items:center;gap:6px}.ft-trust .tl .d{width:5px;height:5px;border-radius:50%;background:var(--brass-light)}

@media(max-width:1080px){.exgrid{grid-template-columns:repeat(2,1fr)}.ft-top{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.wrap,.hdr-in{padding-left:20px;padding-right:20px}.cb-loc .cb-date{display:none}.exgrid{grid-template-columns:1fr}.ft-top{grid-template-columns:1fr 1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
