/* ==========================================================================
   Bethesda Marketing — Editorial design system
   Palette: Green #1F9947 · Beige #F1EFDA · Black #070404 · AT Reply
   ========================================================================== */
@font-face{font-family:"AT Reply";src:url("/assets/fonts/AT-Reply-Book.woff2") format("woff2"),url("/assets/fonts/AT-Reply-Book.woff") format("woff");font-weight:400;font-display:swap}
@font-face{font-family:"AT Reply";src:url("/assets/fonts/AT-Reply-Medium.woff2") format("woff2"),url("/assets/fonts/AT-Reply-Medium.woff") format("woff");font-weight:500;font-display:swap}
@font-face{font-family:"AT Reply";src:url("/assets/fonts/AT-Reply-Bold.woff2") format("woff2"),url("/assets/fonts/AT-Reply-Bold.woff") format("woff");font-weight:700;font-display:swap}

:root{
  --green:#1F9947;--green-d:#13702f;--beige:#F1EFDA;--beige-2:#e7e4c8;--black:#070404;--ink:#181613;--muted:#6a665e;
  --maxw:1280px;--ease:cubic-bezier(.16,1,.3,1);--radius:14px;
  --font:"AT Reply",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--beige);color:var(--ink);line-height:1.55;overflow-x:hidden;font-size:clamp(1rem,.95rem + .25vw,1.1rem)}
img,svg{display:block;max-width:100%}
a{color:var(--green-d);text-decoration:none}
a:hover{color:var(--green)}
::selection{background:var(--green);color:#fff}
:focus-visible{outline:3px solid var(--green);outline-offset:3px}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.2rem,5vw,4rem)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--black);color:#fff;padding:.6rem 1rem;z-index:200}
.skip-link:focus{left:.5rem;top:.5rem}
h1,h2,h3,h4{color:var(--black);letter-spacing:-.02em;line-height:1.05;font-weight:700}
p{margin:0 0 1rem}
.measure{max-width:68ch}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-weight:500;font-size:1rem;padding:.95rem 1.6rem;border-radius:100px;border:2px solid transparent;cursor:pointer;transition:background .3s var(--ease),color .3s var(--ease),transform .3s var(--ease);line-height:1}
.btn .dot{width:7px;height:7px;border-radius:50%;background:var(--green);transition:background .3s}
.btn-primary{background:var(--black);color:var(--beige)}
.btn-primary:hover{background:var(--green);color:#fff;transform:translateY(-2px)}
.btn-primary:hover .dot{background:#fff}
.btn-ghost{background:transparent;color:var(--black);border-color:var(--black)}
.btn-ghost:hover{background:var(--black);color:#fff}
.btn-beige{background:var(--beige);color:var(--black);border-color:var(--beige-2)}
.btn-beige:hover{background:var(--black);color:#fff}
.btn-light{background:#fff;color:var(--black)}
.btn-light:hover{background:var(--black);color:#fff}

/* nav — v2 wordmark; transparent over hero, solid beige bar on scroll */
.nav{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .3s,border-color .3s}
.nav.scrolled,.nav.menu-open{background:rgba(241,239,218,.92);backdrop-filter:saturate(160%) blur(10px);-webkit-backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--beige-2)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{font-weight:700;letter-spacing:-.02em;font-size:1.15rem;text-transform:uppercase;color:var(--black)}
.brand span{color:var(--green)}
.nav-menu{display:flex;align-items:center;gap:clamp(1.2rem,2.4vw,2.2rem);list-style:none;font-weight:500;font-size:.98rem}
.nav-menu a{color:var(--black);position:relative}
.nav-menu a[aria-current=page]{color:var(--green-d)}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:currentColor;transition:width .4s var(--ease)}
.nav-menu a:hover::after{width:100%}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;cursor:pointer}
.nav-toggle span{width:24px;height:2px;background:var(--black);display:block;transition:.3s}
@media(max-width:880px){
  .nav-toggle{display:flex}
  .nav-menu{position:fixed;top:84px;left:0;right:0;background:var(--beige);border-bottom:1px solid var(--beige-2);flex-direction:column;align-items:flex-start;gap:0;padding:.5rem clamp(1.2rem,5vw,4rem) 1.5rem;display:none;max-height:calc(100vh - 84px);overflow:auto}
  .nav-menu.open{display:flex}
  .nav-menu li{width:100%;padding:.7rem 0;border-bottom:1px solid var(--beige-2)}
}

/* sections */
main{padding-top:0}
section{padding-block:clamp(4rem,11vh,8rem)}
.section-beige{background:var(--beige)}
.section-white{background:#fff}
.section-dark{background:var(--black);color:#e9e7e2}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}
.section-green{background:var(--green);color:#fff}
.section-green h1,.section-green h2{color:#fff}
.eyebrow{font-weight:500;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green-d);margin-bottom:1.4rem}
.section-dark .eyebrow{color:#7fd49a}
.lead{font-size:clamp(1.1rem,1rem + .5vw,1.35rem);color:var(--muted);max-width:60ch}
.section-dark .lead{color:#bdb9b2}

/* hero (home) — matches v2 */
.hero{position:relative;background:var(--beige);padding-top:clamp(8rem,18vh,12rem);padding-bottom:clamp(3rem,8vh,6rem);min-height:100vh;display:flex;flex-direction:column;justify-content:center}
.hero .eyebrow{font-size:.8rem;letter-spacing:.22em;margin-bottom:2rem;overflow:hidden;line-height:1.5;padding-top:.15em}.hero .eyebrow span{display:inline-block}
.headline{font-weight:700;letter-spacing:-.035em;line-height:.92;font-size:clamp(3rem,12.5vw,11rem);text-transform:uppercase}
.headline .line{display:block;overflow:hidden}
.headline .line i{display:inline-block;font-style:normal;will-change:transform}
.headline .accent{color:var(--green)}
.headline .thin{-webkit-text-stroke:1.4px var(--black);color:transparent}
.hero-foot{display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;align-items:flex-end;margin-top:clamp(2.5rem,6vh,4.5rem)}
.hero-foot .lead{margin:0;max-width:42ch;font-size:clamp(1rem,.9rem + .4vw,1.25rem)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem}
.scrollcue{position:absolute;right:clamp(1.2rem,5vw,4rem);bottom:1.6rem;writing-mode:vertical-rl;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:1rem}
.scrollcue::after{content:"";width:1px;height:48px;background:var(--muted);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* page hero (inner) */
.page-hero{background:linear-gradient(180deg,var(--beige),#faf9ee);padding-top:clamp(7rem,13vh,9.5rem);padding-bottom:clamp(2.5rem,6vh,4rem)}
.page-hero h1{font-size:clamp(2.2rem,6.5vw,4.6rem);text-transform:uppercase;letter-spacing:-.035em;line-height:.98;max-width:18ch}
.page-hero .lead{margin-top:1.4rem}
.breadcrumb{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:1.2rem}
.breadcrumb a{color:var(--muted)}.breadcrumb a:hover{color:var(--green-d)}

/* marquee — matches v2 */
.marquee{background:var(--black);color:var(--beige);padding:1.3rem 0;overflow:hidden;white-space:nowrap;border-top:1px solid #2a2622}
.marquee .track{display:inline-flex;gap:3rem;animation:scroll 26s linear infinite;font-weight:700;font-size:clamp(1.3rem,3vw,2.2rem);text-transform:uppercase;letter-spacing:-.02em}
.marquee .track span{display:inline-flex;align-items:center;gap:3rem}
.marquee .track span::after{content:"✦";color:var(--green);font-size:.7em}
@keyframes scroll{to{transform:translateX(-50%)}}

/* statement — matches v2 */
.statement h2{font-weight:700;font-size:clamp(1.8rem,5.5vw,4.6rem);letter-spacing:-.03em;line-height:1.04;max-width:18ch}
.statement h2 b{color:var(--green)}

/* services editorial list — matches v2 (.svc .row) */
.svc-list .row{display:grid;grid-template-columns:6rem 1fr auto;gap:clamp(1rem,4vw,3rem);align-items:center;padding:clamp(1.8rem,4vw,3rem) 0;border-top:1px solid var(--beige-2);position:relative;text-decoration:none;color:inherit;transition:color .4s var(--ease)}
.svc-list .row:last-child{border-bottom:1px solid var(--beige-2)}
.svc-list .row .num{font-weight:500;color:var(--muted);font-size:.9rem}
.svc-list .row h3{font-size:clamp(1.8rem,5vw,3.4rem);letter-spacing:-.03em;text-transform:uppercase;transition:transform .5s var(--ease),color .4s}
.svc-list .row .desc{max-width:34ch;color:var(--muted);justify-self:end;text-align:right;font-size:.96rem;opacity:.55;transition:opacity .4s}
.svc-list .row .arrow{display:none}
.svc-list .row:hover h3{transform:translateX(1.5rem);color:var(--green)}
.svc-list .row:hover .desc{opacity:1}
@media(max-width:820px){.svc-list .row{grid-template-columns:3rem 1fr}.svc-list .row .desc{display:none}}

/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:clamp(1rem,2.5vw,1.6rem);margin-top:2.4rem}
.card{background:#fff;border:1px solid var(--beige-2);border-radius:var(--radius);padding:1.7rem;box-shadow:0 1px 2px rgba(7,4,4,.04),0 10px 30px rgba(7,4,4,.05);display:flex;flex-direction:column}
.card .num{font-weight:700;color:var(--green);font-size:.82rem;letter-spacing:.1em}
.card h3{margin:.7rem 0 .5rem;font-size:1.3rem}
.card p{color:var(--muted);margin:0 0 1rem}
.card .more{margin-top:auto;font-weight:500;color:var(--green-d)}
.section-dark .card{background:#13110f;border-color:#2a2622}
.section-dark .card p{color:#bdb9b2}

/* stats — matches v2 (4-col grid, large figures) */
.cred{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.cred .stat b{display:block;font-weight:700;font-size:clamp(2.4rem,6vw,5rem);letter-spacing:-.04em;line-height:1;color:#fff}
.cred .stat b em{font-style:normal;color:var(--green)}
.cred .stat span{display:block;margin-top:.8rem;color:#9b978f;font-size:.92rem;max-width:22ch}
@media(max-width:760px){.cred{grid-template-columns:1fr 1fr;gap:2.5rem 1.5rem}}

/* split rows */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,5vw,4rem);align-items:start}
.split h2{font-size:clamp(1.5rem,4vw,2.6rem)}
.split + .split{margin-top:clamp(2rem,5vw,3.5rem)}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:1rem}}

/* prose */
.prose{max-width:72ch}
.prose h2{font-size:clamp(1.5rem,3.5vw,2.2rem);margin:2.2rem 0 .8rem}
.prose h3{font-size:1.25rem;margin:1.6rem 0 .6rem}
.prose p,.prose li{color:var(--ink)}
.prose ul,.prose ol{padding-left:1.2rem;margin:0 0 1rem}
.prose li{margin-bottom:.5rem}
.prose .meta{color:var(--muted);font-size:.95rem}
.prose blockquote{border-left:3px solid var(--green);padding-left:1.2rem;margin:1.5rem 0;font-size:1.2rem;color:var(--black)}
.prose a{text-decoration:underline;text-underline-offset:2px}
.callout{background:#fff;border:1px solid var(--beige-2);border-left:4px solid var(--green);border-radius:10px;padding:1.3rem 1.5rem;margin:1.6rem 0}
.callout p:last-child{margin:0}

/* feature list with checks */
.features{list-style:none;padding:0;display:grid;gap:1rem;margin-top:1.5rem}
.features li{padding-left:2rem;position:relative;color:var(--ink)}
.features li::before{content:"";position:absolute;left:0;top:.3em;width:18px;height:18px;border-radius:50%;background:var(--green);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/14px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/14px no-repeat}
.features li b{color:var(--black)}

/* FAQ accordion */
.faq{max-width:60rem;margin-top:1.5rem}
.faq details{border-top:1px solid var(--beige-2);padding:1.1rem 0}
.faq details:last-child{border-bottom:1px solid var(--beige-2)}
.faq summary{font-weight:500;font-size:1.15rem;color:var(--black);cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--green);transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:.9rem 0 0;color:var(--muted)}

/* learn cards */
.learn-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem;margin-top:2.2rem}
.learn-card{background:#fff;border:1px solid var(--beige-2);border-radius:var(--radius);padding:1.7rem;display:flex;flex-direction:column;color:inherit;transition:transform .3s var(--ease),box-shadow .3s}
.learn-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(7,4,4,.08)}
.learn-card .tag{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green-d);font-weight:500;margin-bottom:.8rem}
.learn-card h3{font-size:1.3rem;margin-bottom:.5rem}
.learn-card p{color:var(--muted);margin:0 0 1rem}
.learn-card .more{margin-top:auto;color:var(--green-d);font-weight:500}

/* approach / cta */
.cta-band{text-align:center}
.cta-band h2{font-size:clamp(2.4rem,9vw,7rem);text-transform:uppercase;letter-spacing:-.04em;line-height:.95;max-width:16ch;margin-inline:auto}
.cta-band .lead{margin:1rem auto 1.8rem;text-align:center}
.bshape{position:absolute;right:-3vw;top:50%;transform:translateY(-50%);width:min(34vw,380px);opacity:.85;z-index:0;pointer-events:none}
.relative{position:relative}.relative > .wrap{position:relative;z-index:1}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:500;margin-bottom:.35rem}
.field input,.field textarea{width:100%;padding:.8rem 1rem;border:1px solid var(--beige-2);border-radius:10px;font:inherit;background:#fff;color:var(--ink)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--green)}
.info-list{list-style:none;padding:0;margin:0}
.info-list li{margin-bottom:1rem}.info-list b{display:block;color:var(--black)}
.map-embed{border:0;width:100%;height:280px;border-radius:var(--radius);margin-top:1.2rem}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* footer */
.foot{background:var(--black);color:#cfccc6;padding:clamp(3rem,7vh,5rem) 0 1.8rem}
.foot .top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.5fr;gap:clamp(1.5rem,3vw,2.5rem);padding-bottom:3rem;border-bottom:1px solid #241f1c}
.foot .brand img{height:34px;margin-bottom:.9rem}
.foot .brand p{color:#9b978f;max-width:28ch;margin:0}
.foot h4{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:1rem}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:.55rem;font-size:.95rem}
.foot a{color:#cfccc6}.foot a:hover{color:var(--green)}
.foot address{font-style:normal;line-height:1.85;font-size:.95rem}
.foot .base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:1.4rem;font-size:.82rem;color:#827e77}
@media(max-width:820px){.foot .top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot .top{grid-template-columns:1fr}}

/* cookie */
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;max-width:560px;margin-inline:auto;background:#fff;border:1px solid var(--beige-2);box-shadow:0 12px 44px rgba(7,4,4,.2);border-radius:var(--radius);padding:1.1rem 1.2rem;display:flex;flex-wrap:wrap;gap:.8rem 1rem;align-items:center;justify-content:space-between;z-index:90}
.cookie-banner[hidden]{display:none}
.cookie-banner p{margin:0;flex:1 1 280px;font-size:.92rem}
.cookie-actions{display:flex;gap:.6rem}
.cookie-banner .btn{padding:.55rem 1.1rem;font-size:.9rem}

/* reveal */
.r{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.r.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .r{opacity:1;transform:none}
  .headline .line i{transform:none!important}
}
