:root{
  --cream:#F7F3EC;
  --cream-dark:#EDE7DA;
  --forest:#1E3A2F;
  --forest-light:#2D5040;
  --sage:#6B8C6E;
  --sage-light:#A8C5A0;
  --gold:#C8A96E;
  --gold-light:#E8D5A8;
  --earth:#8B6B47;
  --white:#FDFCF9;
  --ink:#1A1A18;
  --ink-soft:#3D3D3A;
  --border:rgba(30,58,47,0.12);
  --shadow-sm:0 2px 20px rgba(30,58,47,0.06);
  --shadow-lg:0 8px 40px rgba(30,58,47,0.12);
  --container:1280px;
  --pad:clamp(1.5rem,5vw,5rem);
  --section-pad:clamp(4rem,8vw,8rem);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-weight:300;
  font-size:1rem;
  line-height:1.75;
  color:var(--ink-soft);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none;transition:color .3s ease}
a:hover{color:var(--forest)}
button{font:inherit;border:none;background:none;cursor:pointer;color:inherit}
ul,ol{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--serif);font-weight:400;color:var(--forest);line-height:1.15;letter-spacing:-.01em}
h1{font-size:clamp(2.8rem,6vw,5.5rem);font-weight:300;letter-spacing:-.02em}
h2{font-size:clamp(2rem,4vw,3.5rem);font-weight:400}
h3{font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:500}
h4{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:500}
em{font-style:italic;color:var(--gold)}
p{margin-bottom:1rem}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad)}
.section{padding:var(--section-pad) 0}
.label{font-family:var(--sans);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);display:inline-block;margin-bottom:1rem}
.eyebrow{font-family:var(--sans);font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--sage);font-weight:500}

/* Skip link */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--forest);color:var(--cream);padding:.75rem 1.25rem;z-index:9999}
.skip-link:focus{left:0}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.95rem 1.75rem;font-family:var(--sans);font-size:.85rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;border:1px solid transparent;cursor:pointer;transition:all .3s ease;border-radius:0}
.btn-primary{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.btn-primary:hover{background:var(--forest-light);transform:translateY(-1px);color:var(--cream)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--earth);color:var(--cream)}
.btn-outline{border-color:currentColor;background:transparent}
.btn-outline:hover{background:currentColor}
.btn-outline.cream-out{color:var(--cream)}
.btn-outline.cream-out:hover{background:var(--cream);color:var(--forest)}
.btn-outline.dark-out{color:var(--forest)}
.btn-outline.dark-out:hover{background:var(--forest);color:var(--cream)}

/* Nav */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:.55rem 0;transition:background .35s ease,box-shadow .35s ease,padding .35s ease;background:transparent}
.site-nav.scrolled{background:var(--white);box-shadow:var(--shadow-sm);padding:.45rem 0}
.site-nav.solid{background:var(--white);box-shadow:var(--shadow-sm);padding:.45rem 0}

/* Three-column centred layout */
.nav-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;max-width:var(--container);margin:0 auto;padding:0 var(--pad);gap:1.5rem}
.nav-left{display:flex;align-items:center;justify-content:flex-start}
.nav-center{display:flex;align-items:center;justify-content:center}
.nav-right{display:flex;align-items:center;justify-content:flex-end;gap:1rem}

/* Logo image — default shows dark (forest green) for white/cream backgrounds */
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{height:34px;width:auto;transition:filter .35s ease;filter:brightness(0) saturate(100%) invert(17%) sepia(56%) saturate(498%) hue-rotate(96deg) brightness(89%) contrast(96%)}
/* On dark hero: flip to white */
.site-nav.on-dark .logo img{filter:brightness(0) invert(1)}
/* When dark-hero page is scrolled: back to forest green */
.site-nav.on-dark.scrolled .logo img{filter:brightness(0) saturate(100%) invert(17%) sepia(56%) saturate(498%) hue-rotate(96deg) brightness(89%) contrast(96%)}
/* fallback text logo */
.logo-text{font-family:var(--serif);font-weight:500;font-size:1.6rem;letter-spacing:.02em;color:var(--forest)}
.site-nav.on-dark .logo-text{color:var(--cream)}
.site-nav.on-dark.scrolled .logo-text{color:var(--forest)}

.site-nav.on-dark .nav-link{color:var(--cream)}
.site-nav.on-dark.scrolled .nav-link{color:var(--forest)}
.nav-list{display:flex;align-items:center;gap:1.75rem}
.nav-item{position:relative}
.nav-link{font-family:var(--sans);font-size:.85rem;font-weight:400;color:var(--forest);padding:.5rem 0;display:inline-flex;align-items:center;gap:.35rem;cursor:pointer}
.nav-link[aria-current="page"]{border-bottom:1px solid var(--gold);color:var(--forest)}
.nav-link:hover{color:var(--gold)}
.caret{width:8px;height:8px;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:rotate(45deg);margin-top:-3px;transition:transform .3s ease}
.nav-item:hover .caret{transform:rotate(225deg);margin-top:3px}

/* Dropdowns */
.dropdown{position:absolute;top:100%;left:0;background:var(--white);min-width:240px;padding:1rem 0;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(10px);transition:all .3s ease;border-top:2px solid var(--gold)}
.nav-item:hover .dropdown,.nav-item:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:.6rem 1.25rem;font-size:.85rem;color:var(--ink-soft)}
.dropdown a:hover{background:var(--cream);color:var(--forest)}

.mega{position:fixed;top:auto;left:50%;transform:translate(-50%,10px);width:min(900px,90vw);padding:2rem;display:grid;grid-template-columns:1fr 1fr;gap:.5rem 2rem}
.nav-item:hover .mega{transform:translate(-50%,0)}
.mega a{padding:.85rem 1rem;border-radius:2px}
.mega a strong{display:block;font-family:var(--serif);font-size:1.05rem;font-weight:500;color:var(--forest);margin-bottom:.15rem}
.mega a span{font-size:.78rem;color:var(--ink-soft);line-height:1.5}

.nav-cta{padding:.65rem 1.35rem;font-size:.75rem}
.menu-toggle{display:none;width:32px;height:32px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;background:none;border:none;padding:0;color:var(--forest)}
.site-nav.on-dark .menu-toggle{color:var(--cream)}
.site-nav.on-dark.scrolled .menu-toggle{color:var(--forest)}
.menu-toggle span{display:block;width:24px;height:1.5px;background:currentColor;transition:transform .3s ease,opacity .3s ease}
.menu-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media(max-width:1024px){
  .nav-left,.nav-list{display:none}
  .nav-inner{grid-template-columns:1fr auto 1fr}
  .menu-toggle{display:flex}
}

/* Mobile menu overlay */
.mobile-menu{position:fixed;inset:0;background:var(--cream);z-index:99;padding:6rem var(--pad) 3rem;overflow-y:auto;transform:translateX(100%);transition:transform .4s ease;visibility:hidden}
.mobile-menu.open{transform:translateX(0);visibility:visible}
.mobile-menu ul{display:flex;flex-direction:column;gap:.25rem}
.mobile-menu a,.mobile-menu summary{display:block;padding:1rem 0;font-family:var(--serif);font-size:1.6rem;color:var(--forest);border-bottom:1px solid var(--border);cursor:pointer;list-style:none}
.mobile-menu summary::-webkit-details-marker{display:none}
.mobile-menu details ul{padding-left:1rem}
.mobile-menu details a{font-size:1rem;font-family:var(--sans);padding:.6rem 0;border:none}
.mobile-cta{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}

/* Hero — fullscreen video */
.hero{height:100svh;min-height:600px;color:var(--cream);position:relative;display:flex;flex-direction:column;justify-content:center;overflow:hidden;background:var(--forest)}
.hero>.container{width:100%;position:relative;z-index:3}

/* Video layer */
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}

/* Dark overlay so text stays readable */
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,30,22,.80) 0%,rgba(15,30,22,.55) 60%,rgba(15,30,22,.35) 100%);z-index:1}

/* Grain texture on top */
.hero::before{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='3' seed='5'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");opacity:.4;pointer-events:none;z-index:2}

.hero-content{position:relative;z-index:3;max-width:780px}
.hero h1{color:var(--cream);margin:1rem 0 1.5rem}
.hero h1 em{color:var(--gold);font-weight:300}
.hero p{color:rgba(247,243,236,.88);max-width:52ch;font-size:1.1rem}
.hero-cta{display:flex;gap:1rem;margin-top:2.5rem;flex-wrap:wrap}

/* Reduce motion: pause video */
@media(prefers-reduced-motion:reduce){.hero-video{display:none}}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.reveal-stagger.in > *{opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(1){transition-delay:0s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.1s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.2s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.3s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.4s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.5s}

/* Ticker */
.ticker{position:absolute;left:0;right:0;bottom:0;border-top:1px solid rgba(200,169,110,.3);border-bottom:1px solid rgba(200,169,110,.3);overflow:hidden;background:rgba(0,0,0,.15);padding:1rem 0;color:var(--gold);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase}
.ticker-track{display:flex;gap:3rem;white-space:nowrap;animation:tick 40s linear infinite;width:max-content}
.ticker-track span{padding:0 1rem;display:inline-flex;align-items:center;gap:3rem}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Stats */
.stats{background:var(--cream);padding:4rem 0;border-bottom:1px solid var(--border)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat-num{font-family:var(--serif);font-style:italic;font-size:clamp(3rem,6vw,5rem);font-weight:300;color:var(--forest);line-height:1;display:block}
.stat-label{font-family:var(--sans);text-transform:uppercase;font-size:.75rem;letter-spacing:.15em;color:var(--ink-soft);margin-top:.75rem}
@media(max-width:700px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:3rem 1.5rem}}

/* Two-column generic */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}

/* Image placeholder */
.placeholder{background:var(--cream-dark);display:flex;align-items:center;justify-content:center;color:var(--sage);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;border-radius:2px;text-align:center;padding:2rem;position:relative;overflow:hidden}
.placeholder::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.4),transparent 60%);opacity:.5}
.placeholder.square{aspect-ratio:1}
.placeholder.ratio-43{aspect-ratio:4/3}
.placeholder.ratio-169{aspect-ratio:16/9}

/* Cert logos — sizes for non-product pages (about, homepage) */
.cert-logos{display:flex;flex-wrap:wrap;gap:1.25rem 1.75rem;align-items:center;margin-top:1.5rem}
.cert-logo-item{display:flex;align-items:center;justify-content:center}
.cert-logo-item img{height:56px;width:auto;object-fit:contain;filter:grayscale(15%);transition:filter .3s ease,transform .3s ease}
.cert-logo-item img:hover{filter:grayscale(0%);transform:scale(1.06)}
@media(max-width:600px){.cert-logo-item img{height:44px}}

/* Why Viant */
.why{background:var(--forest);color:var(--cream)}
.why h2{color:var(--cream)}
.why .label{color:var(--gold)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;margin-top:3rem}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.why-grid{grid-template-columns:1fr}}
.why-card{padding:1rem 0;border-top:1px solid rgba(200,169,110,.25)}
.why-card svg{width:36px;height:36px;color:var(--gold);margin-bottom:1rem;stroke:currentColor;fill:none;stroke-width:1.25}
.why-card h3{color:var(--cream);margin-bottom:.5rem;font-weight:500}
.why-card p{color:rgba(247,243,236,.8);font-size:.9rem}

/* States */
.states-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem}
@media(max-width:900px){.states-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.states-grid{grid-template-columns:1fr}}
.state-card{background:var(--cream);padding:2rem;border:1px solid var(--border);transition:all .3s ease}
.state-card:hover{border-color:var(--gold);background:var(--white);box-shadow:var(--shadow-sm)}
.state-shape{width:80px;height:80px;color:var(--sage);margin-bottom:1rem}
.state-shape svg{width:100%;height:100%;stroke:currentColor;fill:rgba(168,197,160,.15);stroke-width:2}
.state-card h3{font-style:italic}
.state-num{font-family:var(--serif);font-size:2.5rem;font-weight:300;color:var(--gold);font-style:italic;display:block;margin:.25rem 0}
.state-products{font-size:.85rem;color:var(--ink-soft)}

/* Women */
.women{background:var(--sage);color:var(--cream)}
.women h2{color:var(--cream)}
.women blockquote{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(1.5rem,3vw,2.4rem);line-height:1.3;color:var(--cream);margin-bottom:1.5rem;padding-left:1.5rem;border-left:2px solid var(--gold)}
.women p{color:rgba(255,255,255,.9)}
.women-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.women-grid .placeholder{aspect-ratio:3/4;background:rgba(0,0,0,.15);color:var(--gold-light)}

/* Process */
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:3rem;position:relative}
.process-steps::before{content:'';position:absolute;top:30px;left:10%;right:10%;height:1px;background:var(--border);z-index:0}
@media(max-width:900px){.process-steps{grid-template-columns:repeat(2,1fr)}.process-steps::before{display:none}}
@media(max-width:500px){.process-steps{grid-template-columns:1fr}}
.step{text-align:center;position:relative;z-index:1}
.step-circle{width:60px;height:60px;background:var(--white);border:1px solid var(--border);border-radius:999px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:1rem;font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--gold)}
.step h3{margin-bottom:.5rem;font-size:1.15rem}
.step p{font-size:.85rem}

/* Blogs */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
@media(max-width:900px){.blog-grid{grid-template-columns:1fr}}
.blog-card{background:var(--white);border:1px solid var(--border);transition:all .3s ease;display:flex;flex-direction:column}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.blog-card .placeholder{aspect-ratio:16/10}
.blog-body{padding:1.75rem}
.blog-tag{display:inline-block;font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--gold);margin-bottom:.75rem}
.blog-card h3{margin-bottom:.75rem;font-size:1.3rem}
.blog-card p{font-size:.9rem;margin-bottom:1rem}

/* CTA */
.cta-band{background:var(--forest);color:var(--cream);text-align:center;padding:clamp(4rem,8vw,6rem) 0}
.cta-band h2{color:var(--cream);margin-bottom:1rem}
.cta-band p{color:rgba(247,243,236,.85);max-width:60ch;margin:0 auto 2rem}
.cta-band .btn-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* FAQ */
.faq-section{background:var(--cream)}
.faq-list{max-width:820px;margin:3rem auto 0;border-top:1px solid var(--border)}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;padding:1.5rem 0;font-family:var(--serif);font-size:1.25rem;color:var(--forest);display:flex;justify-content:space-between;align-items:center;gap:2rem}
.faq-q::after{content:'+';font-family:var(--sans);font-weight:300;font-size:1.5rem;transition:transform .3s ease;color:var(--gold)}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease;padding:0;color:var(--ink-soft)}
.faq-item.open .faq-a{max-height:300px;padding:0 0 1.5rem}

/* Footer */
.site-footer{background:var(--forest);color:var(--cream);padding:5rem 0 0;font-size:.88rem}
.site-footer .logo img{filter:none}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.4fr;gap:3rem;padding-bottom:3rem}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.foot-grid{grid-template-columns:1fr}}
.foot-grid h4{color:var(--cream);font-family:var(--sans);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;font-weight:500;margin-bottom:1.25rem}
.foot-grid ul li{margin-bottom:.6rem}
.foot-grid a{color:rgba(247,243,236,.75)}
.foot-grid a:hover{color:var(--gold)}
.foot-tagline{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--gold-light);margin:1.25rem 0}
.foot-social{display:flex;gap:.75rem;margin-top:1.5rem}
.foot-social a{width:38px;height:38px;border:1px solid rgba(200,169,110,.4);display:flex;align-items:center;justify-content:center;border-radius:999px;transition:all .3s ease;color:var(--cream)}
.foot-social a:hover{background:var(--gold);color:var(--forest);border-color:var(--gold)}
.foot-social svg{width:16px;height:16px;fill:currentColor}
.foot-contact p{color:rgba(247,243,236,.75);margin-bottom:.5rem;font-size:.85rem}
.newsletter-form{display:flex;gap:0;margin-top:1rem;border:1px solid rgba(200,169,110,.4)}
.newsletter-form input{flex:1;background:transparent;border:none;padding:.75rem 1rem;color:var(--cream);font-family:var(--sans);font-size:.85rem;outline:none}
.newsletter-form input::placeholder{color:rgba(247,243,236,.5)}
.newsletter-form button{background:var(--gold);color:var(--ink);padding:0 1.25rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em}
.cert-strip{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;align-items:center;padding:2rem 0;border-top:1px solid rgba(200,169,110,.2);border-bottom:1px solid rgba(200,169,110,.2)}
.cert-strip span{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.foot-bottom{padding:1.5rem 0;text-align:center;font-size:.78rem;color:rgba(247,243,236,.5)}

/* WhatsApp */
.whatsapp-btn{position:fixed;bottom:24px;right:24px;width:58px;height:58px;background:#25D366;color:#fff;border-radius:999px;display:flex;align-items:center;justify-content:center;z-index:50;box-shadow:0 6px 20px rgba(37,211,102,.4);transition:transform .3s ease}
.whatsapp-btn:hover{transform:scale(1.08);color:#fff}
.whatsapp-btn::before{content:'';position:absolute;inset:-4px;border-radius:999px;background:#25D366;opacity:.4;animation:pulse 2s infinite}
.whatsapp-btn svg{width:30px;height:30px;position:relative;z-index:1;fill:#fff}
.whatsapp-btn .tip{position:absolute;right:calc(100% + 12px);top:50%;transform:translateY(-50%);background:var(--forest);color:var(--cream);padding:.5rem 1rem;font-size:.75rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .3s ease}
.whatsapp-btn:hover .tip{opacity:1;visibility:visible}
@keyframes pulse{0%{transform:scale(1);opacity:.4}70%{transform:scale(1.4);opacity:0}100%{opacity:0}}

/* Page hero (sub-pages) */
.page-hero{background:var(--cream);padding:11rem 0 5rem;border-bottom:1px solid var(--border)}
.page-hero.dark{background:var(--forest);color:var(--cream)}
.page-hero.dark h1{color:var(--cream)}
.page-hero h1{margin-bottom:1rem}
.page-hero p{max-width:60ch;font-size:1.1rem}
.page-hero.dark p{color:rgba(247,243,236,.85)}
.breadcrumb{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--sage);margin-bottom:1.5rem}
.breadcrumb a{color:var(--sage)}
.breadcrumb a:hover{color:var(--gold)}
.page-hero.dark .breadcrumb{color:var(--gold-light)}
.page-hero.dark .breadcrumb a{color:var(--gold-light)}

/* Forms */
.form-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:4rem;align-items:start}
@media(max-width:900px){.form-grid{grid-template-columns:1fr}}
.field{margin-bottom:1.25rem}
.field label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);margin-bottom:.5rem;font-weight:500}
.field input,.field select,.field textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--border);background:var(--white);font-family:var(--sans);font-size:.95rem;color:var(--ink);border-radius:0;outline:none;transition:border-color .3s ease}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold)}
.field textarea{min-height:140px;resize:vertical}
.contact-card{background:var(--cream);padding:2.5rem;border:1px solid var(--border)}
.contact-card h3{margin-bottom:1rem}
.contact-card p{font-size:.9rem;margin-bottom:.5rem}
.contact-card .ico{display:inline-block;width:1rem;color:var(--gold);margin-right:.5rem}

/* Mission cards */
.mission-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
@media(max-width:900px){.mission-grid{grid-template-columns:1fr}}
.mission-card{padding:2.5rem;background:var(--cream);border:1px solid var(--border);transition:all .3s ease}
.mission-card:hover{border-color:var(--gold);background:var(--white)}
.mission-card svg{width:40px;height:40px;color:var(--gold);margin-bottom:1rem;stroke:currentColor;fill:none;stroke-width:1.25}
.mission-card h3{margin-bottom:.75rem}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .reveal,.reveal-stagger > *{opacity:1;transform:none}
}
