/* Augusta Software House — shared base stylesheet (auto-extracted from inline <style> blocks). */
/* 91 common rules. Page-specific styles remain inline. */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:88px}
::selection{background:var(--brand);color:#fff}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.container{width:var(--container);margin:0 auto}
.eyebrow.on-ink{color:var(--i3)}
.serif-em{font-family:var(--f-serif);font-weight:400;font-style:italic;letter-spacing:-.005em}
.btn-primary{background:var(--t1);color:var(--i1)}
.btn-primary:hover{background:var(--brand);transform:translateY(-1px);box-shadow:0 8px 24px rgba(79,70,229,.25)}
.btn-primary.on-ink{background:var(--i1);color:var(--t1)}
.btn-primary.on-ink:hover{background:var(--accent);color:#fff}
.btn-ghost{background:transparent;color:var(--t1);border:1px solid var(--paper-line)}
.btn-ghost:hover{border-color:var(--t1);background:var(--t1);color:var(--i1)}
.btn-ghost.on-ink{color:var(--i1);border-color:var(--ink-line)}
.btn:hover i{transform:translateX(2px)}
.nav.scrolled{height:68px;background:rgba(255,255,255,.92);border-bottom-color:var(--paper-line)}
.nav .inner{width:var(--container);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:32px}
.nav-logo img{height:52px;width:auto;transition:height .35s var(--e-out)}
.nav.scrolled .nav-logo img{height:44px}
.nav-list{display:flex;align-items:center;gap:4px;list-style:none}
.nav-list>li{position:relative}
.nav-list>li>a .chev{font-size:9px;opacity:.5;transition:transform .25s}
.nav-list>li:hover>a .chev{transform:rotate(180deg);opacity:.85}
.nav-list>li:hover .nav-dd{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dd li a:hover{background:var(--paper-2);color:var(--t1)}
.nav-dd li a:hover .di{background:var(--brand);color:#fff}
.hamburger{display:none;width:40px;height:40px;position:relative}
.hamburger span{display:block;width:20px;height:1.5px;background:var(--t1);position:absolute;left:10px;border-radius:1px;transition:all .3s var(--e-out)}
.hamburger span:nth-child(1){top:14px}
.hamburger span:nth-child(2){top:19px}
.hamburger span:nth-child(3){top:24px}
.hamburger.open span:nth-child(1){top:19px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){top:19px;transform:rotate(-45deg)}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu>.mg.open .ms{max-height:600px}
.mobile-menu>.mg.open>a{border-bottom-color:transparent}
.mobile-menu .ms a{display:block;padding:8px 0 8px 16px;font-size:15px;color:var(--t2);font-weight:500}
.mobile-menu .ms a:last-child{padding-bottom:14px;border-bottom:1px solid var(--paper-line)}
.mobile-menu>a .chev,.mobile-menu>.mg>a .chev{font-size:12px;opacity:.5;float:right;margin-top:6px;transition:transform .3s}
.mobile-menu>.mg.open>a .chev{transform:rotate(180deg)}
.mobile-cta{margin-top:24px;text-align:center;background:var(--t1)!important;color:var(--i1)!important;border-radius:var(--r-pill)!important;border-bottom:none!important}
@media(max-width:991px){.nav-list{display:none}.hamburger{display:block}}
.footer-grid{display:grid;grid-template-columns:1.6fr .8fr .8fr 1fr;gap:48px;padding-bottom:64px}
.footer-brand img{height:60px;margin-bottom:24px}
.footer-tagline{font-size:14.5px;line-height:1.7;color:var(--i2);max-width:340px;margin-bottom:24px}
.footer-social{display:flex;gap:8px}
.footer-social a:hover{border-color:var(--i1);color:var(--i1);background:var(--ink-2);transform:translateY(-2px)}
footer ul{list-style:none}
footer ul li{margin-bottom:10px}
footer ul a{font-size:14px;color:var(--i2);transition:color .25s}
footer ul a:hover{color:var(--i1)}
.footer-legal{display:flex;gap:24px;flex-wrap:wrap}
.footer-legal a:hover{color:var(--i2)}
@media(max-width:992px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:640px){.footer-grid{grid-template-columns:1fr}.footer-bottom{justify-content:center;text-align:center;flex-direction:column}}
.wa-float.show{opacity:1;transform:translateY(0);pointer-events:auto}
.wa-float i{font-size:26px;color:#fff}
@media(max-width:768px){.wa-float{bottom:20px;right:20px;width:52px;height:52px}}
*:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:6px}
.skip-link:focus{top:0}
.breadcrumb a:hover{color:var(--t1)}
.breadcrumb a{color:var(--t3)}
.btn i{transition:transform .3s var(--e-out)}
.btn-ghost.on-ink:hover{background:var(--i1);color:var(--t1)}
.btn{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;padding:14px 24px;border-radius:var(--r-pill);transition:all .35s var(--e-out);white-space:nowrap}
.eyebrow::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--accent)}
.eyebrow{font-family:var(--f-mono);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--t3);display:inline-flex;align-items:center;gap:10px}
.footer-bottom{border-top:1px solid var(--ink-line);padding:28px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--i4)}
.footer-legal a{color:var(--i4)}
.footer-social a{width:40px;height:40px;border-radius:50%;border:1px solid var(--ink-line);display:flex;align-items:center;justify-content:center;color:var(--i3);font-size:15px;transition:all .35s var(--e-out)}
.mobile-menu>a,.mobile-menu>.mg>a{font-family:var(--f-display);font-size:24px;font-weight:600;color:var(--t1);padding:14px 0;border-bottom:1px solid var(--paper-line);display:block;cursor:pointer}
.mobile-menu{position:fixed;inset:0;z-index:999;background:rgba(255,255,255,.98);backdrop-filter:blur(24px);display:flex;flex-direction:column;padding:96px 28px 40px;opacity:0;pointer-events:none;transition:opacity .4s;overflow-y:auto}
.nav-cta{font-size:14px!important;font-weight:600!important;color:var(--i1)!important;background:var(--t1);padding:10px 20px!important;border-radius:var(--r-pill)!important;margin-left:8px;transition:all .35s var(--e-out)!important}
.nav-dd li a .di{width:32px;height:32px;border-radius:8px;background:var(--brand-tint);color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;transition:all .2s}
.nav-dd li a{display:flex;align-items:center;gap:12px;padding:11px 14px;font-size:13.5px;font-weight:500;color:var(--t2);border-radius:var(--r)}
.nav-dd-wide .dh{grid-column:1/-1;padding:8px 14px 12px;font-family:var(--f-mono);font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--t4)}
.nav-dd-wide{min-width:540px;display:grid;grid-template-columns:1fr 1fr}
.nav-dd{position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%) translateY(8px);min-width:240px;background:var(--paper);border:1px solid var(--paper-line);border-radius:var(--r-lg);padding:8px;opacity:0;visibility:hidden;transition:all .25s var(--e-out);box-shadow:0 20px 60px rgba(15,23,42,.1);list-style:none}
.nav-list>li>a:hover,.nav-list>li:hover>a,.nav-list>li>a.active{color:var(--t1);background:var(--paper-2)}
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:80px;display:flex;align-items:center;background:rgba(255,255,255,.7);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid transparent;transition:all .35s var(--e-out)}
.scroll-progress{position:fixed;top:0;left:0;height:2px;background:var(--brand);width:0;z-index:1001;transition:width .08s linear}
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--t1);color:var(--i1);padding:12px 20px;z-index:1002;border-radius:0 0 8px 8px;font-weight:600;font-size:13px;transition:top .3s}
.wa-float:hover{transform:translateY(-4px) scale(1.06)}
.wa-float{position:fixed;bottom:28px;right:28px;width:56px;height:56px;border-radius:50%;background:#25D366;z-index:998;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(37,211,102,.3);transition:all .4s var(--e-out);opacity:0;transform:translateY(16px);pointer-events:none}
body{font-family:var(--f-sans);font-size:16px;line-height:1.6;color:var(--t1);background:var(--paper);-webkit-font-smoothing:antialiased;overflow-x:hidden;font-feature-settings:"ss01","cv11"}
footer h6{font-family:var(--f-mono);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--i4);margin-bottom:20px}
footer{background:var(--ink);color:var(--i2);padding:80px 0 0;border-top:1px solid var(--ink-line)}
h1,h2,h3,h4,h5,h6{font-family:var(--f-display);font-weight:600;line-height:1.08;letter-spacing:-.025em}

/* ═══════════════════════════════════════════════════════════════
   EDITORIAL LAYER — utilities applied across pages to add the
   classic, hand-crafted feel: subtle grain, drop caps, oversize
   numerals, hairlines, animated link rules, paper-feel hover.
   These are ADDITIVE to existing components —

/* ============================================================
   EDITORIAL LAYER
   ============================================================ */

body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: .035;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
main, footer { position: relative; z-index: 1; }
.has-ink-bg::before { mix-blend-mode: screen; opacity: .025; }

.dropcap::first-letter {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 5.6em;
  line-height: .84;
  float: left;
  margin: .06em .12em -.05em -.02em;
  color: var(--brand);
  letter-spacing: -.02em;
}
.dropcap.on-ink::first-letter { color: var(--accent); }

.numeral {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: clamp(72px, 10vw, 148px);
  line-height: .86;
  letter-spacing: -.05em;
  color: transparent;
  -webkit-text-stroke: 1.5px var(--paper-line);
  user-select: none;
  display: block;
  margin-bottom: .2em;
}
.numeral.on-ink { -webkit-text-stroke-color: var(--ink-line); }
.numeral.solid { color: var(--t1); -webkit-text-stroke: 0; }
.numeral.solid.on-ink { color: var(--i1); }
.numeral .accent { color: var(--accent); -webkit-text-stroke: 0; }

.hairline { display: block; width: 100%; height: 1px; background: var(--paper-line); border: none; margin: 0; }
.hairline.on-ink { background: var(--ink-line); }

.geo-stamp {
  font-family: var(--f-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--t4);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.geo-stamp::before {
  content: '';
  width: 14px;
  height: 1px;
  background: currentColor;
  opacity: .6;
}
.geo-stamp.on-ink { color: var(--i4); }

.pull-quote {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(26px, 3vw, 40px);
  line-height: 1.32;
  letter-spacing: -.01em;
  color: var(--t1);
  position: relative;
  padding-left: .5em;
}
.pull-quote::before {
  content: '\201C';
  position: absolute;
  left: -.42em;
  top: -.18em;
  font-size: 1.4em;
  color: var(--brand);
  opacity: .35;
  font-style: normal;
  line-height: 1;
}
.pull-quote.on-ink { color: var(--i1); }
.pull-quote.on-ink::before { color: var(--accent); opacity: .5; }
.pull-quote-attr {
  margin-top: 1.4em;
  font-family: var(--f-mono);
  font-size: 11.5px;
  font-style: normal;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--t3);
  display: flex;
  align-items: center;
  gap: 14px;
}
.pull-quote-attr::before {
  content: '';
  width: 32px;
  height: 1px;
  background: currentColor;
  opacity: .4;
  flex-shrink: 0;
}
.pull-quote-attr.on-ink { color: var(--i3); }

.text-link {
  position: relative;
  display: inline;
  color: inherit;
  background-image: linear-gradient(currentColor, currentColor);
  background-size: 0 1px;
  background-position: 0 calc(100% + 2px);
  background-repeat: no-repeat;
  transition: background-size .45s var(--e-out);
  padding-bottom: 1px;
}
.text-link:hover { background-size: 100% 1px; }
.text-link.always { background-size: 100% 1px; }
.text-link.brand { color: var(--brand); }
.text-link.accent { color: var(--accent); }

.editorial-lede {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.42;
  letter-spacing: -.012em;
  color: var(--t1);
}
.editorial-lede.on-ink { color: var(--i1); }
.editorial-lede em { font-family: var(--f-serif); font-weight: 400; font-style: italic; color: var(--brand); letter-spacing: -.005em; }
.editorial-lede.on-ink em { color: var(--accent); }

.split-grid { display: grid; gap: clamp(40px, 6vw, 96px); align-items: start; }
.split-grid.s-7-5 { grid-template-columns: 7fr 5fr; }
.split-grid.s-5-7 { grid-template-columns: 5fr 7fr; }
.split-grid.s-8-4 { grid-template-columns: 8fr 4fr; }
.split-grid.s-4-8 { grid-template-columns: 4fr 8fr; }
@media (max-width: 900px) {
  .split-grid.s-7-5, .split-grid.s-5-7, .split-grid.s-8-4, .split-grid.s-4-8 { grid-template-columns: 1fr; }
}

.row-static {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  border-top: 1px solid var(--paper-line);
  border-bottom: 1px solid var(--paper-line);
}
.row-static > * {
  flex: 1 1 0;
  min-width: 170px;
  padding: 24px 18px;
  border-right: 1px solid var(--paper-line);
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 14.5px;
  color: var(--t2);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: color .3s, background .3s;
}
.row-static > *:last-child { border-right: none; }
.row-static > *:hover { color: var(--t1); background: var(--paper-2); }

.currently {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 0;
  border-top: 1px solid var(--paper-line);
  border-bottom: 1px solid var(--paper-line);
}
.currently-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #22C55E;
  margin-top: 7px;
  flex-shrink: 0;
  animation: pulseDot 2s infinite;
}
.currently-text {
  font-size: 14px;
  line-height: 1.55;
  color: var(--t2);
}
.currently-text strong { color: var(--t1); font-weight: 600; }
.currently-text .geo-stamp { display: block; margin-bottom: 6px; }
@keyframes pulseDot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(34,197,94,.5); }
  70% { box-shadow: 0 0 0 8px rgba(34,197,94,0); }
}

.marker {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--t3);
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 18px;
}
.marker .num { color: var(--accent); font-weight: 500; }
.marker.on-ink { color: var(--i3); }

.card-edit { position: relative; transition: transform .5s var(--e-out); }
.card-edit::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: var(--t1);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .55s var(--e-out);
}
.card-edit:hover { transform: translateY(-2px); }
.card-edit:hover::after { transform: scaleX(1); }

/* ============================================================
   MOBILE RESPONSIVENESS LAYER
   ============================================================ */
@media (max-width: 992px) {
  .nav .inner { gap: 16px; }
  .hamburger { width: 44px; height: 44px; }
}
@media (max-width: 768px) {
  .nav-logo img { height: 40px !important; }
  .nav.scrolled .nav-logo img { height: 36px !important; }
  .nav { height: 64px !important; }
  .nav.scrolled { height: 56px !important; }
  .hamburger { width: 48px; height: 48px; }
  .hamburger span { left: 14px; width: 22px; }
  .mobile-menu { padding: 80px 24px 32px !important; }
  .mobile-menu > a, .mobile-menu > .mg > a { font-size: 22px; padding: 12px 0; }
  .dropcap::first-letter { font-size: 4em; }
  .numeral { font-size: clamp(54px, 14vw, 92px); }
  .pull-quote { font-size: clamp(20px, 5.2vw, 28px); padding-left: .35em; }
  .pull-quote::before { left: -.3em; font-size: 1.2em; }
  .wa-float { bottom: 18px; right: 18px; width: 48px; height: 48px; }
  .wa-float i { font-size: 22px; }
  .row-static > * { flex: 1 1 100% !important; min-width: 0; border-right: none !important; border-bottom: 1px solid var(--paper-line); }
  .row-static > *:last-child { border-bottom: none; }
  .marker { font-size: 11px; letter-spacing: .14em; }
  .geo-stamp { font-size: 9.5px; letter-spacing: .18em; }
}
@media (max-width: 480px) {
  .container { width: min(1240px, 94vw); }
  .nav .inner { gap: 8px; }
  :root {
    --pad-section: clamp(56px, 14vw, 96px);
    --pad-section-sm: clamp(40px, 10vw, 72px);
  }
  .editorial-lede { font-size: clamp(17px, 4.8vw, 21px); line-height: 1.45; }
  .currently { padding: 14px 0; }
  .currently-text { font-size: 13.5px; }
}

/* INLINE 3-col grid escape hatch (Evidence + Field Notes on index) */
@media (max-width: 900px) {
  [style*="grid-template-columns:repeat(3,1fr)"] {
    grid-template-columns: 1fr !important;
  }
  [style*="grid-template-columns:repeat(3,1fr)"] > article {
    border-right: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    border-bottom: 1px solid var(--ink-line);
    padding-top: 36px !important;
    padding-bottom: 36px !important;
  }
  [style*="grid-template-columns:repeat(3,1fr)"] > article:last-child { border-bottom: none; }
  section[style*="background:var(--paper-2)"] [style*="grid-template-columns:repeat(3,1fr)"] > article {
    border-bottom-color: var(--paper-line);
  }
}


/* ============================================================
   MOBILE CTA + DRAWER CONTAINMENT (defensive)
   ============================================================ */
.mobile-menu {
  box-sizing: border-box !important;
  overflow-x: hidden !important;
}
.mobile-menu > * {
  box-sizing: border-box !important;
  max-width: 100% !important;
}
.mobile-menu > a,
.mobile-menu > .mg > a {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.mobile-menu > a.mobile-cta {
  display: block !important;
  width: calc(100% - 16px) !important;
  max-width: calc(100% - 16px) !important;
  margin: 24px auto 8px !important;
  padding: 18px 24px !important;
  box-sizing: border-box !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  text-align: center !important;
  align-self: center !important;
  border-radius: 999px !important;
}

/* ============================================================
   HAMBURGER VISIBILITY (Android Chrome at high DPR can ghost
   1.5px lines; this makes them unmistakable on every device)
   ============================================================ */
.hamburger {
  background: var(--paper-2) !important;
  border-radius: 10px !important;
  border: 1px solid var(--paper-line) !important;
  display: none;
}
@media (max-width: 991px) {
  .hamburger {
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 44px !important;
    height: 44px !important;
    position: relative;
  }
}
@media (max-width: 768px) {
  .hamburger {
    width: 48px !important;
    height: 48px !important;
  }
}
.hamburger span {
  display: block !important;
  width: 22px !important;
  height: 2px !important;
  background: var(--t1) !important;
  border-radius: 2px !important;
  position: absolute !important;
  left: 50% !important;
  margin-left: -11px;
}
.hamburger span:nth-child(1) { top: 14px !important; }
.hamburger span:nth-child(2) { top: 21px !important; }
.hamburger span:nth-child(3) { top: 28px !important; }
.hamburger.open span:nth-child(1) { top: 21px !important; transform: rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { top: 21px !important; transform: rotate(-45deg); }
.hamburger:hover { background: var(--paper-3) !important; }
.hamburger:active { transform: scale(0.96); }

/* Adjust top positions for 48px (mobile) hamburger */
@media (max-width: 768px) {
  .hamburger span:nth-child(1) { top: 16px !important; }
  .hamburger span:nth-child(2) { top: 23px !important; }
  .hamburger span:nth-child(3) { top: 30px !important; }
  .hamburger.open span:nth-child(1) { top: 23px !important; }
  .hamburger.open span:nth-child(3) { top: 23px !important; }
}


/* ============================================================
   COOKIE CONSENT BANNER
   Slim editorial bar at the bottom; brand pill primary action.
   ============================================================ */
.cookie-banner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  max-width: 1080px;
  margin: 0 auto;
  z-index: 1100;
  background: rgba(10, 10, 18, 0.96);
  color: var(--i1, #FAFAF7);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  padding: 18px 22px;
  box-shadow: 0 24px 64px rgba(10, 10, 18, 0.32);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  transform: translateY(120%);
  opacity: 0;
  transition: transform .45s cubic-bezier(.22,1,.36,1), opacity .35s;
  font-family: var(--f-sans, system-ui, sans-serif);
}
.cookie-banner.is-visible {
  transform: translateY(0);
  opacity: 1;
}
.cookie-banner-inner {
  display: flex;
  align-items: center;
  gap: 22px;
}
.cookie-banner-text {
  flex: 1 1 auto;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(250, 250, 247, 0.78);
}
.cookie-banner-text strong {
  color: var(--i1, #FAFAF7);
  font-weight: 600;
}
.cookie-banner-link {
  color: var(--accent, #EA580C);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cookie-banner-link:hover { color: #fff; }
.cookie-banner-actions {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}
.cookie-btn {
  font-family: inherit;
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: -.005em;
  padding: 11px 20px;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all .25s ease;
  white-space: nowrap;
}
.cookie-btn-ghost {
  background: transparent;
  color: rgba(250, 250, 247, 0.72);
  border-color: rgba(255, 255, 255, 0.18);
}
.cookie-btn-ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}
.cookie-btn-primary {
  background: var(--i1, #FAFAF7);
  color: #0A0A12;
}
.cookie-btn-primary:hover {
  background: var(--accent, #EA580C);
  color: #fff;
}
@media (max-width: 768px) {
  .cookie-banner { left: 12px; right: 12px; bottom: 12px; padding: 16px 18px; }
  .cookie-banner-inner { flex-direction: column; align-items: stretch; gap: 14px; }
  .cookie-banner-text { font-size: 13.5px; }
  .cookie-banner-actions { justify-content: flex-end; }
  .cookie-btn { padding: 10px 16px; font-size: 13px; }
}

/* ============================================================
   PAGE LOADER — animated Augusta wordmark
   Logo breathes (scale + opacity), thin brand-colored bar
   advances underneath. Whole overlay fades on window.load.
   ============================================================ */
.page-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--paper, #FFFFFF);
  transition: opacity .42s ease;
  pointer-events: all;
}
.page-loader.is-fading {
  opacity: 0;
  pointer-events: none;
}
.page-loader-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
}
.page-loader-logo {
  width: clamp(140px, 22vw, 220px);
  height: auto;
  display: block;
  transform-origin: center;
  animation: augustaLogoBreathe 2.2s ease-in-out infinite;
}
@keyframes augustaLogoBreathe {
  0%, 100% { opacity: 0.55; transform: scale(0.985); }
  50%      { opacity: 1;    transform: scale(1.012); }
}
.page-loader-bar {
  position: relative;
  width: clamp(140px, 22vw, 220px);
  height: 2px;
  background: var(--paper-line, rgba(15, 23, 42, 0.08));
  border-radius: 2px;
  overflow: hidden;
}
.page-loader-bar > span {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 38%;
  background: linear-gradient(90deg,
    var(--brand, #4F46E5) 0%,
    var(--brand-soft, #6366F1) 50%,
    var(--accent, #EA580C) 100%);
  border-radius: 2px;
  animation: augustaBarSweep 1.6s ease-in-out infinite;
}
@keyframes augustaBarSweep {
  0%   { left: -42%; }
  60%  { left: 102%; }
  100% { left: 102%; }
}
