/* =========================================================
   360BH — Editorial design system (vanilla CSS)
   Palette: Navy #0B1F3A · Gold #C9A24B · Paper #F5F1EA
   ========================================================= */

:root {
  --navy:#0B1F3A;
  --navy-mid:#14315A;
  --gold:#C9A24B;
  --gold-soft:#E2C77E;
  --paper:#F5F1EA;
  --paper-2:#EFE9DD;
  --ink:#0F0E0C;
  --muted:#6B6558;
  --border:#D9D2C2;
  --card:#FBF8F1;

  --bg: var(--paper);
  --fg: var(--ink);

  --font-display:"Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  --font-sans:"DM Sans", ui-sans-serif, system-ui, sans-serif;
  --font-mono:"JetBrains Mono", ui-monospace, monospace;

  --max:1400px;
}

*,*::before,*::after { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; }
body {
  margin:0;
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--fg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.55;
  font-size:16px;
}
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
::selection { background:var(--gold); color:var(--navy); }

h1,h2,h3,h4,h5,h6 {
  font-family:var(--font-display);
  font-weight:500;
  letter-spacing:-0.02em;
  margin:0;
  color:var(--ink);
  line-height:1.05;
}

p { margin:0; }
ul { margin:0; padding:0; list-style:none; }

.container { max-width:var(--max); margin:0 auto; padding:0 1.5rem; }
@media (min-width:768px){ .container { padding:0 2.5rem; } }

.mono { font-family:var(--font-mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--muted); }
.kicker { font-family:var(--font-mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
.gold { color:var(--gold); }
.italic { font-style:italic; color:var(--navy-mid); }

/* ================= Header ================= */
.site-header {
  position:sticky; top:0; z-index:50;
  background:transparent;
  border-bottom:1px solid transparent;
  transition:background .4s ease, border-color .4s ease, backdrop-filter .4s ease;
}
.site-header.is-scrolled {
  background:rgba(245,241,234,.88);
  backdrop-filter:blur(10px);
  border-bottom-color:var(--border);
}
.header-inner {
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem;
  padding:1rem 1.5rem;
}
@media (min-width:768px){ .header-inner { padding:1rem 2.5rem; } }

.brand { display:flex; align-items:center; gap:.75rem; color:var(--ink); }
.brand-mark { position:relative; width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center; color:var(--ink); }
.brand-mark svg { position:absolute; inset:0; }
.brand-mark-text { font-family:var(--font-display); font-size:11px; font-weight:600; }
.brand-text { display:none; line-height:1; }
.brand-name { font-family:var(--font-display); font-weight:600; font-size:1rem; display:block; }
.brand-sub { font-family:var(--font-mono); font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); display:block; margin-top:2px; }
@media (min-width:640px){ .brand-text { display:flex; flex-direction:column; } }

.site-nav { display:none; gap:2rem; align-items:center; }
@media (min-width:1024px){ .site-nav { display:flex; } }
.nav-link { display:inline-flex; align-items:center; gap:.5rem; font-size:.875rem; color:rgba(15,14,12,.8); transition:color .2s; }
.nav-link:hover, .nav-link.is-active { color:var(--ink); }
.nav-num { font-family:var(--font-mono); font-size:10px; color:var(--gold); }
.nav-label { background-image:linear-gradient(currentColor,currentColor); background-size:100% 1px; background-position:0 100%; background-repeat:no-repeat; transition:background-size .4s cubic-bezier(.22,1,.36,1); }
.nav-link:hover .nav-label { background-image:linear-gradient(var(--gold),var(--gold)); background-size:100% 2px; }

.header-actions { display:flex; align-items:center; gap:.75rem; }
.header-cta { display:none; }
@media (min-width:640px){ .header-cta { display:inline-flex; } }

.menu-toggle {
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border:1px solid var(--border); background:transparent;
  cursor:pointer;
}
@media (min-width:1024px){ .menu-toggle { display:none; } }
.menu-toggle span {
  display:block; width:20px; height:1px; background:var(--ink); margin:3px 0;
  transition:transform .25s;
}
.menu-toggle.is-open span:nth-child(1){ transform:translateY(4px) rotate(45deg); }
.menu-toggle.is-open span:nth-child(2){ transform:translateY(-4px) rotate(-45deg); }

.mobile-menu { background:var(--bg); border-top:1px solid var(--border); }
.mobile-menu nav { display:flex; flex-direction:column; padding:0 1.5rem 1rem; max-width:var(--max); margin:0 auto; }
.mobile-link { display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid rgba(217,210,194,.6); padding:1rem 0; color:var(--ink); }
.mobile-label { font-family:var(--font-display); font-size:1.25rem; margin-left:.5rem; }
.mobile-cta { margin-top:1.25rem; justify-content:center; }

/* ================= Buttons ================= */
.btn {
  display:inline-flex; align-items:center; gap:.75rem;
  padding:.85rem 1.4rem; font-size:.875rem; font-weight:500;
  border:1px solid var(--ink); background:var(--ink); color:var(--paper);
  transition:background .2s, color .2s, border-color .2s;
  cursor:pointer;
}
.btn:hover { background:var(--gold); border-color:var(--gold); color:var(--navy); }
.btn-primary { /* default */ }
.btn-gold { background:var(--gold); border-color:var(--gold); color:var(--navy); }
.btn-gold:hover { background:var(--bg); color:var(--ink); }
.btn-ghost { background:transparent; color:var(--ink); border-color:transparent; padding:.85rem .25rem; }
.btn-ghost:hover { background:transparent; color:var(--ink); }
.btn-ghost .arrow { color:var(--gold); transition:transform .2s; }
.btn-ghost:hover .arrow { transform:translateX(4px); }
.btn-ghost .underline { background-image:linear-gradient(currentColor,currentColor); background-size:100% 1px; background-position:0 100%; background-repeat:no-repeat; transition:background-size .4s; }
.btn-ghost:hover .underline { background-image:linear-gradient(var(--gold),var(--gold)); background-size:100% 2px; }

/* ================= Section helpers ================= */
.section { padding:5rem 0; }
.section-lg { padding:7rem 0; }
@media (max-width:767px){ .section, .section-lg { padding:3.5rem 0; } }
.section-tint { background:rgba(239,233,221,.5); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.section-dark { background:var(--ink); color:var(--paper); }
.section-dark h1,.section-dark h2,.section-dark h3 { color:var(--paper); }
.section-dark .mono { color:rgba(245,241,234,.6); }
.section-dark .kicker { color:var(--gold); }

.section-label { display:flex; align-items:center; gap:.75rem; }
.section-label .num { font-family:var(--font-mono); font-size:10px; color:var(--gold); letter-spacing:.3em; text-transform:uppercase; }
.section-label .label { font-family:var(--font-mono); font-size:10px; color:var(--muted); letter-spacing:.3em; text-transform:uppercase; }
.section-dark .section-label .label { color:rgba(245,241,234,.6); }

.hairline { height:1px; background:linear-gradient(to right, transparent, var(--gold) 20%, var(--gold) 80%, transparent); }

/* Grain texture */
.grain { position:relative; }
.grain::before {
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.04; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ================= Masthead bar ================= */
.masthead {
  border-bottom:1px solid var(--border);
  font-family:var(--font-mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--muted);
}
.masthead-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.85rem 1.5rem; max-width:var(--max); margin:0 auto; }
.masthead-mid { display:none; }
@media (min-width:768px){ .masthead-mid { display:inline; } .masthead-inner { padding:.85rem 2.5rem; } }

/* ================= Hero ================= */
.hero { position:relative; overflow:hidden; }
.hero-grid { display:grid; grid-template-columns:repeat(12, 1fr); gap:1.5rem; padding:4rem 0 6rem; }
.hero-main { grid-column:span 12; }
.hero-aside { grid-column:span 12; }
@media (min-width:1024px){
  .hero-main { grid-column:span 8; }
  .hero-aside { grid-column:span 4; border-left:1px solid var(--border); padding-left:2rem; }
  .hero-grid { padding:6rem 0 6rem; }
}
.hero-title {
  font-size:clamp(2.75rem, 8vw, 7rem);
  font-weight:500; line-height:.95; letter-spacing:-.035em;
  margin-top:2rem;
}
.hero-title .highlight { position:relative; display:inline-block; }
.hero-title .highlight::after {
  content:""; position:absolute; left:0; right:0; bottom:.45rem; height:.55rem; background:rgba(201,162,75,.7); z-index:-1;
}
.hero-lead {
  margin-top:2.25rem; max-width:38rem;
  font-size:1.125rem; line-height:1.6; color:rgba(15,14,12,.78);
}
@media (min-width:768px){ .hero-lead { font-size:1.25rem; } }
.hero-ctas { margin-top:2.75rem; display:flex; flex-wrap:wrap; gap:1rem; align-items:center; }

.hero-aside-list { margin-top:2rem; }
.hero-aside-list li {
  display:flex; align-items:baseline; gap:1rem;
  border-bottom:1px solid rgba(217,210,194,.6); padding:.85rem 0;
}
.hero-aside-list .page { font-family:var(--font-mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.hero-aside-list .ttl { font-family:var(--font-display); font-size:1rem; line-height:1.35; color:var(--ink); }

.indicator-card {
  margin-top:2.5rem; border:1px solid var(--border); background:var(--card); padding:1.5rem;
}
.indicator-card .big { margin-top:.6rem; font-family:var(--font-display); font-size:3rem; }
.indicator-card .big .gold { color:var(--gold); }
.indicator-card .desc { margin-top:.5rem; font-size:.875rem; color:var(--muted); }

/* ================= Clients strip ================= */
.clients { background:rgba(239,233,221,.55); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:2.5rem 0; }
.clients-list { margin-top:1.5rem; display:flex; flex-wrap:wrap; align-items:center; gap:1rem 3rem; }
.clients-list span { font-family:var(--font-display); font-size:1.25rem; letter-spacing:-.02em; color:rgba(15,14,12,.7); }

/* ================= Manifesto / 2-col editorial ================= */
.col2 { display:grid; grid-template-columns:repeat(12, 1fr); gap:1.5rem; }
.col2 .side { grid-column:span 12; }
.col2 .main { grid-column:span 12; }
@media (min-width:1024px){
  .col2 .side { grid-column:span 4; }
  .col2 .main { grid-column:span 8; }
}
.headline-xl { font-size:clamp(2rem, 4.5vw, 3.75rem); line-height:1.05; }
.headline-xl em { font-style:italic; color:var(--gold); }
.grid-2 { display:grid; grid-template-columns:1fr; gap:2.5rem; margin-top:3rem; }
@media (min-width:640px){ .grid-2 { grid-template-columns:1fr 1fr; } }
.editorial-item { border-top:1px solid var(--border); padding-top:1.25rem; }
.editorial-item h3 { font-size:1.25rem; }
.editorial-item p { margin-top:.75rem; font-size:.9rem; color:var(--muted); line-height:1.6; }

/* ================= Services grid ================= */
.services-head { display:flex; flex-direction:column; align-items:flex-start; justify-content:space-between; gap:1.5rem; }
@media (min-width:768px){ .services-head { flex-direction:row; align-items:flex-end; } }
.services-grid { margin-top:3.5rem; display:grid; grid-template-columns:repeat(12, 1fr); gap:1px; background:var(--border); }
.svc {
  grid-column:span 12;
  background:var(--bg); padding:2rem;
  transition:background .2s;
}
@media (min-width:768px){ .svc { padding:2.5rem; } }
@media (min-width:1024px){
  .svc-1 { grid-column:span 7; } .svc-2 { grid-column:span 5; }
  .svc-3, .svc-4, .svc-5 { grid-column:span 4; }
  .svc-6 { grid-column:span 12; }
}
.svc:hover { background:var(--card); }
.svc .kicker { color:var(--gold); }
.svc h3 { margin-top:1rem; font-size:1.85rem; }
@media (min-width:768px){ .svc h3 { font-size:2.15rem; } }
.svc p { margin-top:1rem; max-width:40rem; font-size:.95rem; line-height:1.7; color:rgba(15,14,12,.8); }
.svc ul { margin-top:1.25rem; display:flex; flex-direction:column; gap:.5rem; }
.svc li { display:flex; align-items:baseline; gap:.75rem; font-size:.875rem; color:var(--muted); }
.svc li::before { content:"·"; color:var(--gold); font-weight:bold; }

/* ================= Methodology ================= */
.method-grid { margin-top:3.5rem; display:grid; grid-template-columns:1fr; gap:1px; background:var(--border); }
@media (min-width:768px){ .method-grid { grid-template-columns:1fr 1fr; } }
@media (min-width:1024px){ .method-grid { grid-template-columns:repeat(4, 1fr); } }
.method { background:var(--bg); padding:2rem; }
.method .num { font-family:var(--font-mono); font-size:10px; color:var(--gold); letter-spacing:.3em; text-transform:uppercase; }
.method h3 { margin-top:1rem; font-size:1.4rem; }
.method p { margin-top:.75rem; font-size:.875rem; line-height:1.7; color:var(--muted); }

/* ================= Authority / dark dossier ================= */
.dossier-grid { display:grid; grid-template-columns:repeat(12, 1fr); gap:3rem; }
.dossier-head { grid-column:span 12; }
.dossier-stats { grid-column:span 12; display:grid; grid-template-columns:repeat(3, 1fr); gap:1.5rem; }
.dossier-quotes { grid-column:span 12; display:grid; grid-template-columns:1fr; gap:1.5rem; margin-top:2rem; }
@media (min-width:1024px){
  .dossier-head { grid-column:span 5; }
  .dossier-stats { grid-column:span 7; }
  .dossier-quotes { grid-template-columns:repeat(3,1fr); }
}
.stat { border-left:1px solid rgba(245,241,234,.2); padding-left:1.25rem; }
.stat .big { font-family:var(--font-display); font-size:3rem; }
@media (min-width:768px){ .stat .big { font-size:4.5rem; } }
.stat .label { margin-top:.75rem; font-family:var(--font-mono); font-size:10px; letter-spacing:.25em; text-transform:uppercase; color:rgba(245,241,234,.6); }
.quote { border-top:1px solid rgba(245,241,234,.15); padding-top:1.5rem; }
.quote .stars { font-family:var(--font-mono); font-size:.75rem; color:var(--gold); }
.quote blockquote { margin:1rem 0 0; font-family:var(--font-display); font-size:1.15rem; line-height:1.35; }
.quote figcaption { margin-top:1.25rem; font-family:var(--font-mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:rgba(245,241,234,.6); }

/* ================= SaaS cards ================= */
.saas-grid { margin-top:3.5rem; display:grid; grid-template-columns:1fr; gap:1.5rem; }
@media (min-width:768px){ .saas-grid { grid-template-columns:1fr 1fr; } }
.saas { border:1px solid var(--border); background:var(--card); padding:2rem; }
@media (min-width:768px){ .saas { padding:3rem; } }
.saas h3 { margin-top:1rem; font-size:2.25rem; }
.saas .sub { margin-top:.75rem; font-size:.8rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.saas p { margin-top:1.75rem; max-width:32rem; font-size:1rem; line-height:1.7; color:rgba(15,14,12,.8); }
.saas a.more { margin-top:2.25rem; display:inline-flex; align-items:center; gap:.5rem; font-size:.875rem; font-weight:500; color:var(--ink); }
.saas a.more .underline { background-image:linear-gradient(currentColor,currentColor); background-size:100% 1px; background-position:0 100%; background-repeat:no-repeat; transition:background-size .4s; }
.saas a.more:hover .underline { background-image:linear-gradient(var(--gold),var(--gold)); background-size:100% 2px; }
.saas a.more .arrow { color:var(--gold); }

/* ================= Regional cities ================= */
.cities { display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--border); }
@media (min-width:640px){ .cities { grid-template-columns:repeat(3,1fr); } }
.cities li { background:var(--bg); padding:1.1rem 1.25rem; display:flex; align-items:baseline; gap:.75rem; }
.cities .n { font-family:var(--font-mono); font-size:10px; color:var(--gold); }
.cities .name { font-family:var(--font-display); font-size:1.1rem; color:var(--ink); }

/* ================= Final CTA ================= */
.cta-final h2 { font-size:clamp(2.5rem, 6vw, 5rem); line-height:1; }
.cta-final .accent { color:var(--gold); }

/* ================= Generic page hero ================= */
.page-hero { padding:5rem 0 3rem; }
@media (min-width:768px){ .page-hero { padding:7rem 0 4rem; } }
.page-hero h1 {
  margin-top:2rem; max-width:64rem;
  font-size:clamp(2.5rem, 7vw, 5.5rem); line-height:.95;
}
.page-hero .lead { margin-top:2.25rem; max-width:38rem; font-size:1.125rem; line-height:1.6; color:rgba(15,14,12,.78); }

/* ================= Services list page ================= */
.svc-rows { border-top:1px solid var(--border); }
.svc-rows > article { display:grid; grid-template-columns:repeat(12,1fr); gap:1.5rem; padding:4rem 0; border-bottom:1px solid var(--border); }
.svc-rows > article > .left { grid-column:span 12; }
.svc-rows > article > .right { grid-column:span 12; }
@media (min-width:1024px){
  .svc-rows > article > .left { grid-column:span 4; }
  .svc-rows > article > .right { grid-column:span 8; }
}
.svc-rows h2 { margin-top:1rem; font-size:1.85rem; line-height:1.2; }
@media (min-width:768px){ .svc-rows h2 { font-size:2.15rem; } }
.svc-rows .body { font-size:1rem; line-height:1.7; color:rgba(15,14,12,.82); }
@media (min-width:768px){ .svc-rows .body { font-size:1.05rem; } }
.svc-rows .bullets { margin-top:2rem; display:grid; grid-template-columns:1fr; gap:.5rem; }
@media (min-width:640px){ .svc-rows .bullets { grid-template-columns:1fr 1fr; } }
.svc-rows .bullets li { display:flex; align-items:baseline; gap:.75rem; border-top:1px solid rgba(217,210,194,.6); padding-top:.75rem; font-size:.9rem; color:rgba(15,14,12,.85); }
.svc-rows .bullets li::before { content:"·"; color:var(--gold); font-weight:bold; }

/* Diagnostic CTA box */
.cta-box { background:var(--ink); color:var(--paper); padding:2.5rem; }
@media (min-width:768px){ .cta-box { padding:4rem; } }
.cta-box h2 { color:var(--paper); margin-top:1.5rem; font-size:clamp(2rem, 4vw, 3.5rem); line-height:1.05; max-width:48rem; }

/* ================= Portfolio table ================= */
.portfolio { border-top:1px solid var(--border); }
.port-row { display:grid; grid-template-columns:1fr; gap:.25rem; padding:1.5rem; border-bottom:1px solid var(--border); }
@media (min-width:768px){
  .port-row { grid-template-columns:4fr 3fr 2fr 3fr; gap:1.5rem; padding:1.5rem 0; }
}
.port-row .label { font-family:var(--font-mono); font-size:10px; letter-spacing:.25em; text-transform:uppercase; color:var(--muted); }
@media (min-width:768px){ .port-row .label { display:none; } }
.port-head { display:none; }
@media (min-width:768px){
  .port-head { display:grid; grid-template-columns:4fr 3fr 2fr 3fr; gap:1.5rem; padding:1rem 0; border-bottom:1px solid var(--border); font-family:var(--font-mono); font-size:10px; letter-spacing:.25em; text-transform:uppercase; color:var(--muted); }
}
.port-client .num { font-family:var(--font-mono); font-size:10px; color:var(--gold); }
.port-client .name { margin-top:.4rem; font-family:var(--font-display); font-size:1.45rem; color:var(--ink); }

/* ================= Blog grid ================= */
.blog-grid { display:grid; grid-template-columns:1fr; gap:1px; background:var(--border); border-top:1px solid var(--border); }
@media (min-width:768px){ .blog-grid { grid-template-columns:1fr 1fr; } }
.blog-card { background:var(--bg); padding:2rem; }
@media (min-width:768px){ .blog-card { padding:2.5rem; } }
.blog-card .top { display:flex; align-items:center; justify-content:space-between; }
.blog-card h2 { margin-top:1.1rem; font-size:1.5rem; line-height:1.25; }
@media (min-width:768px){ .blog-card h2 { font-size:1.75rem; } }
.blog-card p { margin-top:.75rem; font-size:.9rem; line-height:1.65; color:var(--muted); }

/* ================= Downloads ================= */
.dl-list { border-top:1px solid var(--border); }
.dl-row { display:flex; flex-direction:column; gap:.5rem; padding:1.75rem 0; border-bottom:1px solid var(--border); }
@media (min-width:768px){ .dl-row { flex-direction:row; align-items:baseline; justify-content:space-between; gap:3rem; } }
.dl-row .head { display:flex; align-items:baseline; gap:1.25rem; }
.dl-row h2 { font-size:1.4rem; }
@media (min-width:768px){ .dl-row h2 { font-size:1.6rem; } }

/* ================= Contact form ================= */
.contact-grid { display:grid; grid-template-columns:repeat(12,1fr); gap:1.5rem; padding:5rem 0 7rem; }
.contact-main { grid-column:span 12; }
.contact-aside { grid-column:span 12; margin-top:3rem; }
@media (min-width:1024px){
  .contact-main { grid-column:span 7; }
  .contact-aside { grid-column:span 4; grid-column-start:9; margin-top:0; display:flex; flex-direction:column; gap:2.5rem; }
}
.form-grid { margin-top:3rem; display:grid; gap:1.5rem; }
.row-2 { display:grid; gap:1.5rem; grid-template-columns:1fr; }
@media (min-width:640px){ .row-2 { grid-template-columns:1fr 1fr; } }
.field { display:flex; flex-direction:column; gap:.5rem; }
.field label { font-family:var(--font-mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--muted); }
.field input, .field textarea {
  border:1px solid var(--border); background:var(--bg); color:var(--ink);
  padding:.85rem 1rem; font-family:inherit; font-size:1rem; outline:none;
  transition:border-color .2s;
}
.field input:focus, .field textarea:focus { border-color:var(--gold); }
.aside-block { border-left:2px solid var(--gold); padding-left:1.25rem; }
.aside-block .label { font-family:var(--font-mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
.aside-block .big { margin-top:.6rem; font-family:var(--font-display); font-size:1.6rem; }
.aside-block .sub { margin-top:.3rem; font-size:.875rem; color:var(--muted); }
.aside-card { border:1px solid var(--border); background:var(--card); padding:1.5rem; }
.aside-card .label { font-family:var(--font-mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
.aside-card p { margin-top:.75rem; font-size:.9rem; line-height:1.7; color:rgba(15,14,12,.8); }

.alert { padding:1rem 1.25rem; border:1px solid var(--border); margin-bottom:1.5rem; font-size:.9rem; }
.alert-success { border-color:#5b8c5a; background:#eaf3ea; color:#274c26; }
.alert-error   { border-color:#a14a4a; background:#f5e7e7; color:#62211f; }

/* ================= Footer ================= */
.site-footer { margin-top:8rem; border-top:1px solid var(--border); background:var(--ink); color:var(--paper); }
.site-footer h2 { color:var(--paper); }
.footer-grid { display:grid; grid-template-columns:repeat(12,1fr); gap:3rem; padding:5rem 1.5rem 3rem; }
@media (min-width:768px){ .footer-grid { padding:5rem 2.5rem 3rem; } }
.footer-lead { grid-column:span 12; }
.footer-cols { grid-column:span 12; display:grid; grid-template-columns:1fr; gap:2.5rem; }
@media (min-width:640px){ .footer-cols { grid-template-columns:1fr 1fr; } }
@media (min-width:1024px){
  .footer-lead { grid-column:span 5; }
  .footer-cols { grid-column:span 5; grid-column-start:8; }
}
.footer-lead .kicker { color:var(--gold); }
.footer-lead h2 { margin-top:1.5rem; font-size:2.25rem; line-height:1.05; }
@media (min-width:768px){ .footer-lead h2 { font-size:2.85rem; } }
.footer-desc { margin-top:1.5rem; max-width:28rem; font-size:.9rem; line-height:1.7; color:rgba(245,241,234,.7); }
.footer-lead .btn { margin-top:2rem; }
.col-title { font-family:var(--font-mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:rgba(245,241,234,.5); }
.footer-cols ul { margin-top:1.25rem; display:flex; flex-direction:column; gap:.75rem; }
.footer-cols a { font-size:.875rem; color:rgba(245,241,234,.9); transition:color .2s; }
.footer-cols a:hover { color:var(--gold); }
.col-wide { grid-column:span 1; }
@media (min-width:640px){ .col-wide { grid-column:span 2; } }
.footer-bottom {
  display:flex; flex-direction:column; align-items:flex-start; justify-content:space-between; gap:1rem;
  border-top:1px solid rgba(245,241,234,.1); padding:2rem 1.5rem 2.5rem; font-size:.75rem; color:rgba(245,241,234,.6);
}
@media (min-width:768px){ .footer-bottom { flex-direction:row; align-items:center; padding:2rem 2.5rem 2.5rem; } }
