/* ==========================================================================
   Brewlab Holdings Inc — Stylesheet v2 (editorial / agency-grade redesign)
   ========================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Refined palette: deep oxblood + cream + brass */
  --ink:#15110D;
  --ink-2:#4A413A;
  --ink-3:#6E625A;
  --paper:#FBF6EA;
  --paper-2:#F1E6CE;
  --paper-3:#E8D9B5;
  --brand:#6B2C0F;
  --brand-dark:#4A1A05;
  --brand-deep:#2A0F03;
  --brass:#B8870B;
  --brass-light:#D4A82B;
  --line:#D7C9A6;
  --line-2:#E8DCBC;
  --serif:'Fraunces','Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Inter','Helvetica Neue',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --max:1240px;
  --wide:1380px;
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);font-weight:400;color:var(--ink);background:var(--paper);
  line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"liga","kern";
  background-image:
    radial-gradient(circle at 12% 8%, rgba(184,135,11,0.04) 0, transparent 50%),
    radial-gradient(circle at 88% 92%, rgba(107,44,15,0.04) 0, transparent 50%);
}
a{color:var(--brand);text-decoration:none;transition:color .15s,opacity .15s}
a:hover{color:var(--brand-dark)}
img{max-width:100%;display:block}
:focus-visible{outline:3px solid var(--brass);outline-offset:3px;border-radius:2px}
::selection{background:var(--brass);color:#fff}

.skip{position:absolute;left:-9999px}
.skip:focus{left:1rem;top:1rem;background:var(--ink);color:var(--paper);padding:.7rem 1.1rem;z-index:1100;border-radius:6px}

.wrap{max-width:var(--max);margin:0 auto;padding:0 1.75rem}
.wrap-wide{max-width:var(--wide);margin:0 auto;padding:0 1.75rem}

/* ------- Top compliance banner ------- */
.banner{
  background:var(--brand-deep);color:rgba(255,255,255,.78);
  font-family:var(--sans);font-size:.78rem;letter-spacing:.07em;
  padding:.55rem 1rem;text-align:center;text-transform:uppercase;
}
.banner strong{color:var(--brass-light);font-weight:600}
.banner a{color:rgba(255,255,255,.78);border-bottom:1px dotted rgba(255,255,255,.4)}
.banner a:hover{color:#fff;border-bottom-color:#fff}

/* ------- Navigation ------- */
.nav{
  position:sticky;top:0;z-index:1000;background:rgba(251,246,234,0.93);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line-2);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 0;gap:2rem}
.brand{display:flex;align-items:center;gap:.85rem;color:var(--ink);font-family:var(--serif);font-weight:600}
.brand:hover{color:var(--ink)}
.brand-mark{
  width:42px;height:42px;display:grid;place-items:center;flex-shrink:0;
  background:var(--brand);color:#fff;border-radius:50%;
  font-family:var(--serif);font-weight:700;font-size:1.1rem;font-style:italic;
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.15);
}
.brand-name{display:flex;flex-direction:column;line-height:1}
.brand-name strong{font-size:1.2rem;letter-spacing:-.01em;font-weight:600}
.brand-name small{font-family:var(--sans);font-size:.68rem;color:var(--ink-3);letter-spacing:.18em;text-transform:uppercase;margin-top:.25rem;font-weight:500}
.menu{display:flex;gap:1.85rem;list-style:none;align-items:center}
.menu a{color:var(--ink-2);font-size:.93rem;font-weight:500;padding:.35rem 0;position:relative}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--brass);transition:width .25s}
.menu a:hover{color:var(--ink)}
.menu a:hover::after,.menu a.is-active::after{width:100%}
.menu a.is-active{color:var(--brand)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:.5rem}
.burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;border-radius:1px;transition:transform .2s}

/* ------- Hero (editorial) ------- */
.hero{
  position:relative;overflow:hidden;
  padding:6.5rem 0 5rem;
  background:var(--paper);
  border-bottom:1px solid var(--line-2);
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40'><circle cx='2' cy='2' r='.7' fill='%23a08555' opacity='.18'/></svg>");
  background-size:40px 40px;mask-image:linear-gradient(180deg,#000 0%,transparent 80%);
  -webkit-mask-image:linear-gradient(180deg,#000 0%,transparent 80%);
}
.hero-inner{
  position:relative;display:grid;grid-template-columns:1.25fr 1fr;
  gap:4rem;align-items:center;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-size:.75rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--brand);
  margin-bottom:1.6rem;
}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--brand);display:inline-block}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--brass);display:inline-block}

.h-display{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.6rem,6.2vw,5.2rem);line-height:1.02;letter-spacing:-.025em;
  color:var(--ink);margin-bottom:1.5rem;
  font-feature-settings:"liga","kern","onum";
}
.h-display em{font-style:italic;font-weight:300;color:var(--brand);letter-spacing:-.02em}
.h-display .ampersand{font-family:var(--serif);font-style:italic;font-weight:300;color:var(--brass)}

.lede{
  font-size:1.15rem;color:var(--ink-2);max-width:48ch;line-height:1.65;
  font-weight:400;
}
.lede strong{color:var(--ink);font-weight:600}

.hero-actions{display:flex;gap:1rem;margin-top:2.2rem;flex-wrap:wrap;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:.6rem;padding:.95rem 1.7rem;
  font-family:var(--sans);font-weight:500;font-size:.95rem;
  border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s,background-color .2s,color .2s,border-color .2s,box-shadow .2s;
  letter-spacing:.01em;
}
.btn-primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-primary:hover{background:var(--brand);border-color:var(--brand);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-1px)}
.btn-text{color:var(--brand);font-weight:500;padding:.6rem 0;display:inline-flex;align-items:center;gap:.4rem}
.btn-text::after{content:"→";transition:transform .2s}
.btn-text:hover::after{transform:translateX(3px)}

/* Hero illustration / panel */
.hero-art{
  position:relative;aspect-ratio:1/1.05;border-radius:18px;
  background:
    radial-gradient(circle at 30% 30%, rgba(184,135,11,.22), transparent 55%),
    linear-gradient(160deg,#3D1604 0%,#6B2C0F 60%,#8A3D1C 100%);
  box-shadow:0 30px 80px -20px rgba(42,15,3,.4),inset 0 1px 0 rgba(255,255,255,.05);
  overflow:hidden;
  padding:2rem;display:flex;flex-direction:column;justify-content:space-between;color:#fff;
}
.hero-art-stamp{
  position:absolute;top:1.6rem;right:1.6rem;width:96px;height:96px;
  border:1px solid rgba(212,168,43,.7);border-radius:50%;
  display:grid;place-items:center;text-align:center;
  font-family:var(--serif);font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--brass-light);
  transform:rotate(-12deg);
  background:radial-gradient(circle,rgba(212,168,43,.05) 0,transparent 70%);
}
.hero-art-stamp strong{display:block;font-size:1.05rem;font-weight:600;letter-spacing:.04em;color:#fff;text-transform:none;margin-top:.15rem;font-style:italic}
.hero-art-illu{position:absolute;inset:0;display:grid;place-items:center;opacity:.9}
.hero-art-illu svg{width:80%;max-width:380px;height:auto}
.hero-art-foot{position:relative;z-index:1}
.hero-art-foot .label{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-light);opacity:.85;margin-bottom:.4rem}
.hero-art-foot .name{font-family:var(--serif);font-size:1.35rem;font-style:italic;color:#fff;line-height:1.25;max-width:18ch}

/* Hero stats inline */
.hero-stats{
  margin-top:3.5rem;padding-top:2.5rem;border-top:1px solid var(--line-2);
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2rem 3rem;
}
.hero-stat{display:flex;flex-direction:column;gap:.4rem}
.hero-stat .n{font-family:var(--serif);font-size:2.1rem;font-weight:500;color:var(--brand);line-height:1;letter-spacing:-.02em}
.hero-stat .n em{font-style:italic;font-weight:300;color:var(--brass)}
.hero-stat .l{font-size:.82rem;color:var(--ink-3);letter-spacing:.02em;line-height:1.4}

/* ------- Section structure ------- */
section{position:relative}
.section{padding:6rem 0;position:relative}
.section.alt{background:var(--paper-2)}
.section.alt::after{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(to right,transparent,var(--line),transparent);
}
.section.dark{background:var(--brand-deep);color:var(--paper)}
.section.dark .h-section,.section.dark h2,.section.dark h3{color:#fff}
.section.dark .ink-2{color:rgba(251,246,234,.72)}
.section.dark .kicker{color:var(--brass-light)}
.section.dark .kicker::before{background:var(--brass-light)}

.section-num{
  font-family:var(--serif);font-style:italic;font-size:6rem;font-weight:300;
  color:var(--paper-3);line-height:1;letter-spacing:-.04em;
  position:absolute;top:-1.2rem;right:1.5rem;pointer-events:none;
  user-select:none;
}
.section.dark .section-num{color:rgba(184,135,11,.25)}

.kicker{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--sans);font-size:.76rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--brand);
  margin-bottom:1.1rem;
}
.kicker::before{content:"";width:24px;height:1px;background:var(--brand);display:inline-block}

.h-section{
  font-family:var(--serif);font-weight:500;font-size:clamp(1.9rem,3.6vw,2.8rem);
  line-height:1.12;letter-spacing:-.02em;color:var(--ink);margin-bottom:1.2rem;
}
.h-section em{font-style:italic;font-weight:300;color:var(--brand)}

.intro{
  font-size:1.1rem;color:var(--ink-2);max-width:64ch;line-height:1.65;
}

/* ------- Two-column ------- */
.two{display:grid;grid-template-columns:1.15fr 1fr;gap:4.5rem;align-items:start}
.two.reverse{grid-template-columns:1fr 1.15fr}
.two p{margin-bottom:1.1rem;color:var(--ink-2)}
.two ul{list-style:none;padding:0;margin:1.2rem 0}
.two ul li{padding:.65rem 0 .65rem 1.9rem;position:relative;color:var(--ink-2)}
.two ul li::before{
  content:"";position:absolute;left:0;top:1.1rem;width:.6rem;height:1px;background:var(--brass);
}

.pull-quote{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:1.55rem;line-height:1.4;color:var(--ink);
  border-left:3px solid var(--brass);padding:.3rem 0 .3rem 1.5rem;margin:1.5rem 0;
  letter-spacing:-.005em;
}

/* Illustrative panel (right column) */
.illu-card{
  background:var(--paper-2);border-radius:14px;padding:2.2rem;
  border:1px solid var(--line);position:relative;
}
.illu-card.dark{background:var(--ink);color:var(--paper);border-color:var(--brand-dark)}
.illu-card.brand{background:var(--brand);color:#fff;border-color:var(--brand)}
.illu-card svg.full{width:100%;height:auto}

/* ------- Card grid ------- */
.cards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.2rem;margin-top:2.5rem;
}
.card{
  background:#fff;border:1px solid var(--line-2);border-radius:14px;
  padding:1.8rem;display:flex;flex-direction:column;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
  position:relative;
}
.card:hover{
  transform:translateY(-4px);border-color:var(--brass);
  box-shadow:0 18px 40px -12px rgba(42,15,3,.12);
}
.card-num{
  font-family:var(--serif);font-size:.85rem;color:var(--brand);font-weight:600;
  letter-spacing:.18em;margin-bottom:1rem;text-transform:uppercase;
}
.card-num::before{content:"○ "}
.card h3{
  font-family:var(--serif);font-weight:500;font-size:1.25rem;line-height:1.25;
  color:var(--ink);margin-bottom:.55rem;letter-spacing:-.01em;
}
.card p{color:var(--ink-2);font-size:.96rem;margin-bottom:.85rem}
.card ul{padding-left:1.1rem;color:var(--ink-3);font-size:.9rem;margin-top:auto}
.card ul li{margin-bottom:.3rem;list-style:"— "}

/* ------- Charity-at-a-glance card ------- */
.glance-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:2rem;
  box-shadow:0 14px 50px -20px rgba(42,15,3,.18);
}
.glance-card h3{
  font-family:var(--serif);font-size:1.1rem;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--brand);margin-bottom:1.3rem;
}
.glance-card dl{display:grid;grid-template-columns:max-content 1fr;gap:.65rem 1.4rem;font-size:.93rem}
.glance-card dt{color:var(--ink-3);font-weight:400}
.glance-card dd{color:var(--ink);font-weight:600;font-family:var(--sans)}
.glance-card .acnc-link{
  display:inline-flex;align-items:center;gap:.4rem;
  margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid var(--line-2);
  font-size:.9rem;color:var(--brand);font-weight:500;
}
.glance-card .acnc-link:hover{color:var(--brand-dark)}
.glance-card .acnc-link::after{content:"↗"}

/* ------- Stats strip ------- */
.stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:0;margin-top:2.5rem;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.stat{
  padding:2rem 1.5rem;border-right:1px solid var(--line);
}
.stat:last-child{border-right:none}
.stat .n{
  font-family:var(--serif);font-size:2.3rem;font-weight:500;color:var(--brand);
  line-height:1;letter-spacing:-.02em;margin-bottom:.5rem;
}
.stat .n em{font-style:italic;font-weight:300;color:var(--brass)}
.stat .l{font-size:.88rem;color:var(--ink-3);line-height:1.4}

/* ------- Page hero (interior) ------- */
.page-hero{
  background:var(--brand-deep);color:#fff;padding:5rem 0 4.5rem;position:relative;overflow:hidden;
  border-bottom:6px solid var(--brass);
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 80% 30%, rgba(212,168,43,.18), transparent 60%),
    radial-gradient(circle at 15% 70%, rgba(107,44,15,.4), transparent 65%);
  pointer-events:none;
}
.page-hero .wrap{position:relative}
.page-hero .eyebrow{color:var(--brass-light)}
.page-hero .eyebrow::before{background:var(--brass-light)}
.page-hero .h-display{color:#fff;font-size:clamp(2rem,4.4vw,3.2rem);margin-bottom:1rem}
.page-hero .h-display em{color:var(--brass-light)}
.page-hero .lede{color:rgba(255,255,255,.86)}
.page-hero .lede strong{color:#fff}
.page-hero a{color:var(--brass-light)}
.page-hero a:hover{color:#fff}

/* ------- Board / committee cards ------- */
.board-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.2rem;margin:2rem 0 1rem;
}
.board-card{
  background:#fff;border:1px solid var(--line-2);border-radius:14px;padding:1.6rem;
  display:flex;align-items:center;gap:1.2rem;transition:transform .25s,box-shadow .25s,border-color .25s;
}
.board-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px -10px rgba(42,15,3,.12);border-color:var(--brass)}
.avatar{
  width:64px;height:64px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  color:#fff;font-family:var(--serif);font-weight:600;font-size:1.2rem;font-style:italic;
  letter-spacing:.02em;box-shadow:inset 0 0 0 2px rgba(255,255,255,.18);
}
.avatar-1{background:linear-gradient(135deg,#6B2C0F 0%,#8A3D1C 100%)}
.avatar-2{background:linear-gradient(135deg,#B8870B 0%,#D4A82B 100%);color:var(--brand-deep)}
.avatar-3{background:linear-gradient(135deg,#15110D 0%,#3D2E22 100%)}
.avatar-4{background:linear-gradient(135deg,#4A1A05 0%,#6B2C0F 100%)}
.avatar-5{background:linear-gradient(135deg,#7A5C3F 0%,#A88556 100%)}
.avatar-6{background:linear-gradient(135deg,#8A3D1C 0%,#B8870B 100%);color:var(--brand-deep)}
.board-info h3{font-family:var(--serif);color:var(--ink);font-size:1.12rem;font-weight:500;margin-bottom:.2rem;line-height:1.2;letter-spacing:-.005em}
.board-info .role{color:var(--ink-3);font-size:.88rem;letter-spacing:.04em;text-transform:uppercase;margin:0}

/* ------- About-page board feature ------- */
.board-feature{
  background:linear-gradient(160deg,#FBF6EA 0%,#F1E6CE 100%);
  border:1px solid var(--line);border-radius:14px;padding:2.4rem;
  position:relative;overflow:hidden;
}
.board-feature::before{
  content:"";position:absolute;top:-30px;right:-30px;width:160px;height:160px;
  border-radius:50%;background:radial-gradient(circle,rgba(184,135,11,.18),transparent 70%);
}
.board-feature h3{
  font-family:var(--serif);font-size:1.45rem;font-weight:500;letter-spacing:-.01em;
  color:var(--brand);margin-bottom:.7rem;position:relative;
}
.board-feature p{color:var(--ink-2);margin-bottom:1rem;position:relative}
.mini-board{display:flex;flex-wrap:wrap;gap:.6rem;margin:1.4rem 0;position:relative}
.mini-avatar{
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  color:#fff;font-family:var(--serif);font-weight:600;font-size:.82rem;font-style:italic;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.25);
}
.mini-note{font-size:.92rem;color:var(--ink-3);margin:0;position:relative}

/* ------- News list ------- */
.news-list{display:grid;gap:1.4rem;margin-top:2rem}
.news-item{
  background:#fff;border:1px solid var(--line-2);border-radius:14px;padding:1.7rem 1.9rem;
  display:grid;grid-template-columns:140px 1fr;gap:2rem;align-items:start;
  transition:border-color .25s,transform .25s;
}
.news-item:hover{border-color:var(--brass);transform:translateY(-2px)}
.news-date{font-family:var(--serif);color:var(--brand);font-size:1.4rem;font-weight:500;letter-spacing:-.01em;border-right:1px solid var(--line-2);padding-right:1.2rem}
.news-date small{display:block;color:var(--ink-3);font-weight:400;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;margin-top:.4rem;font-family:var(--sans)}
.news-item h3{font-family:var(--serif);color:var(--ink);font-size:1.25rem;font-weight:500;margin-bottom:.5rem;letter-spacing:-.005em;line-height:1.3}
.news-item p{color:var(--ink-2);font-size:.96rem}

/* ------- Register / glance box (interior pages) ------- */
.register-box{
  background:#fff;border:1px solid var(--line);border-left:4px solid var(--brand);
  border-radius:0 14px 14px 0;padding:2rem 2.2rem;margin-top:2.5rem;
}
.register-box h3{font-family:var(--serif);font-size:1.15rem;font-weight:500;color:var(--brand);margin-bottom:1rem;letter-spacing:.04em;text-transform:uppercase}
.register-box dl{display:grid;grid-template-columns:max-content 1fr;gap:.6rem 1.5rem;font-size:.95rem}
.register-box dt{color:var(--ink-3);font-weight:400}
.register-box dd{color:var(--ink);font-weight:500}

/* ------- Contact ------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:3.5rem;align-items:start}
.contact-block{background:#fff;border:1px solid var(--line-2);border-radius:14px;padding:2.2rem}
.contact-block h3{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--ink);margin-bottom:1.2rem;letter-spacing:-.01em}
.contact-block dl{display:grid;grid-template-columns:max-content 1fr;gap:.7rem 1.4rem;font-size:.95rem}
.contact-block dt{color:var(--ink-3);font-weight:400}
.contact-block dd{color:var(--ink);font-weight:500;word-break:break-word}

form .field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}
form label{font-size:.86rem;font-weight:500;color:var(--ink-2);letter-spacing:.02em}
form input,form select,form textarea{
  width:100%;padding:.85rem 1rem;font:inherit;color:var(--ink);
  border:1px solid var(--line);border-radius:8px;background:var(--paper);
  transition:border-color .15s,box-shadow .15s,background-color .15s;
  font-family:var(--sans);font-size:.95rem;
}
form input:focus,form select:focus,form textarea:focus{
  outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(107,44,15,.13);
}
.form-note{font-size:.82rem;color:var(--ink-3);margin-top:.5rem}
.form-msg{margin-top:1.1rem;padding:.9rem 1.1rem;border-radius:8px;font-size:.93rem;display:none}
.form-msg.success{display:block;background:#EBF6EE;color:#0F5132;border:1px solid #B7E1C1}
.form-msg.error{display:block;background:#FCE8E6;color:#8A1F11;border:1px solid #F2BAB5}

/* ------- Prose / policy pages ------- */
.prose{max-width:74ch}
.prose .h-section{margin-top:2.2rem;margin-bottom:.7rem}
.prose h3{font-family:var(--serif);color:var(--brand);margin-top:1.7rem;margin-bottom:.5rem;font-size:1.2rem;font-weight:500;letter-spacing:-.005em}
.prose p{margin-bottom:1rem;color:var(--ink-2);font-size:1.02rem;line-height:1.7}
.prose ul{margin:0 0 1.1rem 1.4rem;color:var(--ink-2)}
.prose ul li{margin-bottom:.4rem;line-height:1.65}
.prose .small{font-size:.86rem;color:var(--ink-3);margin-top:2.2rem;border-top:1px solid var(--line-2);padding-top:1.3rem;font-style:italic}

/* ------- Footer ------- */
footer{
  background:var(--brand-deep);color:rgba(251,246,234,.7);padding:4.5rem 0 1.8rem;
  font-size:.93rem;margin-top:4rem;position:relative;overflow:hidden;
}
footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(to right,transparent,var(--brass),transparent);
}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
footer h4{
  font-family:var(--serif);color:var(--brass-light);font-size:.85rem;font-weight:500;
  margin-bottom:1.1rem;letter-spacing:.2em;text-transform:uppercase;
}
footer a{color:rgba(251,246,234,.78);}
footer a:hover{color:#fff}
footer ul{list-style:none}
footer ul li{margin-bottom:.55rem}
footer .foot-brand .brand{color:#fff;margin-bottom:.9rem}
footer .foot-brand .brand-name strong{color:#fff}
footer .foot-brand .brand-name small{color:var(--brass-light)}
footer .foot-brand p{color:rgba(251,246,234,.6);margin-bottom:.5rem;font-size:.9rem;line-height:1.6}
.foot-bottom{
  border-top:1px solid rgba(184,135,11,.2);padding-top:1.4rem;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;
  font-size:.8rem;color:rgba(251,246,234,.5);
}

/* ------- Reveal animations ------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ------- Responsive ------- */
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:3rem}
  .hero-art{aspect-ratio:1.2/1;max-width:520px;margin:0 auto}
  .two,.two.reverse,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .foot-grid{grid-template-columns:1fr 1fr}
  .menu{
    display:none;position:absolute;top:100%;left:0;right:0;background:var(--paper);
    flex-direction:column;gap:0;border-bottom:1px solid var(--line);padding:.7rem 0;
  }
  .menu.is-open{display:flex}
  .menu a{padding:.95rem 1.75rem;border-bottom:1px solid var(--line-2);width:100%}
  .menu li:last-child a{border-bottom:none}
  .burger{display:block}
  .news-item{grid-template-columns:1fr;gap:.5rem}
  .news-date{border-right:none;padding-right:0;border-bottom:1px solid var(--line-2);padding-bottom:.5rem}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat{border-right:1px solid var(--line)}
  .stat:nth-child(2n){border-right:none}
  .section-num{font-size:4rem;top:-.4rem}
}
@media (max-width:600px){
  .hero{padding:4rem 0 3.5rem}
  .section{padding:4rem 0}
  .foot-grid{grid-template-columns:1fr}
  .stat{padding:1.4rem 1rem}
  .stat .n{font-size:1.9rem}
  .brand-name small{display:none}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
}
