*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal:#1a6b5a;--teal-dark:#0f4a3e;--teal-light:#e8f2f0;--teal-mid:#2d8a75;
  --ink:#1c1c1c;--cream:#faf8f4;--warm-white:#ffffff;--sand:#f2ede4;
  --muted:#6b6560;--border:rgba(26,107,90,0.12);--border-light:rgba(28,28,28,0.1);
  --serif:'Playfair Display',Georgia,serif;--sans:'DM Sans',system-ui,sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);font-size:16px;line-height:1.6;overflow-x:hidden}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 4rem;height:76px;background:rgba(250,248,244,0.97);border-bottom:1px solid var(--border);backdrop-filter:blur(8px);transition:box-shadow 0.3s}
nav.scrolled{box-shadow:0 2px 24px rgba(15,74,62,0.08)}
.nav-logo{display:flex;align-items:center;gap:0.75rem;text-decoration:none}
.nav-logo img{height:40px;width:auto}
.nav-logo-text{font-family:var(--serif);font-size:0.95rem;font-weight:700;color:var(--teal-dark);line-height:1.2;letter-spacing:0.01em}
.nav-logo-text span{display:block;font-style:italic;font-size:0.72rem;color:var(--muted);font-weight:400}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:0.78rem;font-weight:500;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);text-decoration:none;transition:color 0.2s}
.nav-links a:hover,.nav-links a.active{color:var(--teal-dark)}
.nav-cta{background:var(--teal)!important;color:var(--warm-white)!important;padding:0.55rem 1.4rem!important;border-radius:2px!important;transition:background 0.2s!important}
.nav-cta:hover{background:var(--teal-dark)!important}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--teal-dark);transition:0.3s}
.mobile-menu{display:none;position:fixed;top:76px;left:0;right:0;background:var(--cream);border-bottom:1px solid var(--border);padding:1.5rem 2rem;z-index:99;flex-direction:column;gap:0}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:0.88rem;font-weight:500;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);text-decoration:none;padding:0.85rem 0;border-bottom:1px solid var(--border-light)}
.mobile-menu .mob-cta{background:var(--teal);color:var(--warm-white)!important;text-align:center;border-radius:2px;border:none!important;padding:0.85rem!important;margin-top:0.75rem}

/* PAGE HERO */
.page-hero{padding:10rem 4rem 5.5rem;background:var(--teal-dark);color:var(--warm-white)}
.page-hero .eyebrow{font-size:0.7rem;font-weight:500;text-transform:uppercase;letter-spacing:0.2em;color:rgba(232,242,240,0.7);margin-bottom:1.25rem;display:flex;align-items:center;gap:0.75rem}
.page-hero .eyebrow::before{content:'';display:block;width:28px;height:1.5px;background:rgba(232,242,240,0.5)}
.page-hero h1{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.6rem);font-weight:900;line-height:1.08;color:var(--warm-white);max-width:700px}
.page-hero h1 em{font-style:italic;color:#7ecfba}
.page-hero p{font-size:1.02rem;color:rgba(255,255,255,0.65);max-width:540px;margin-top:1.25rem;line-height:1.8}

/* SECTIONS */
section{padding:6rem 4rem}
.sec-label{font-size:0.68rem;font-weight:500;text-transform:uppercase;letter-spacing:0.22em;color:var(--teal);margin-bottom:0.9rem;display:flex;align-items:center;gap:0.75rem}
.sec-label::before{content:'';display:block;width:22px;height:1.5px;background:var(--teal)}
.sec-label.center{justify-content:center}
.sec-label.center::before{display:none}
h2{font-family:var(--serif);font-size:clamp(1.9rem,3vw,2.8rem);font-weight:900;line-height:1.1;color:var(--ink);margin-bottom:1.5rem}
h2 em{font-style:italic;color:var(--teal)}

/* BUTTONS */
.btn-primary{display:inline-block;background:var(--teal);color:var(--warm-white);padding:1rem 2.25rem;font-family:var(--sans);font-size:0.8rem;font-weight:500;text-transform:uppercase;letter-spacing:0.12em;text-decoration:none;border-radius:2px;transition:background 0.2s,transform 0.15s}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-1px)}
.btn-ghost{display:inline-flex;align-items:center;gap:0.5rem;color:var(--teal-dark);font-size:0.83rem;font-weight:500;text-decoration:none;border-bottom:1.5px solid var(--teal-mid);padding-bottom:2px;transition:color 0.2s,border-color 0.2s}
.btn-ghost:hover{color:var(--teal);border-color:var(--teal)}
.btn-ghost svg{width:13px;height:13px}
.btn-dark{display:inline-block;background:var(--teal-dark);color:var(--warm-white);padding:1rem 2.25rem;font-size:0.8rem;font-weight:500;text-transform:uppercase;letter-spacing:0.12em;text-decoration:none;border-radius:2px;transition:background 0.2s}
.btn-dark:hover{background:var(--teal)}
.btn-outline{display:inline-block;background:transparent;color:var(--teal-dark);padding:1rem 2.25rem;font-size:0.8rem;font-weight:500;text-transform:uppercase;letter-spacing:0.12em;text-decoration:none;border:2px solid var(--teal);border-radius:2px;transition:background 0.2s,color 0.2s}
.btn-outline:hover{background:var(--teal);color:var(--warm-white)}
.btn-teal{display:inline-block;background:var(--teal-light);color:var(--teal-dark);padding:1rem 2.25rem;font-size:0.8rem;font-weight:500;text-transform:uppercase;letter-spacing:0.12em;text-decoration:none;border-radius:2px;transition:background 0.2s}
.btn-teal:hover{background:#c8deda}

/* MARQUEE */
.marquee-wrap{background:var(--teal);padding:0.85rem 0;overflow:hidden}
.marquee-track{display:flex;gap:3rem;animation:marquee 30s linear infinite;white-space:nowrap}
.marquee-item{font-family:var(--serif);font-size:0.88rem;font-style:italic;color:rgba(255,255,255,0.9);flex-shrink:0;display:flex;align-items:center;gap:1.5rem}
.marquee-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,0.5);flex-shrink:0}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* CTA BAND */
.cta-band{background:var(--teal-light);padding:6rem 4rem;text-align:center}
.cta-band h2{color:var(--teal-dark);max-width:680px;margin:0 auto 1.25rem}
.cta-band h2 em{color:var(--teal)}
.cta-band>p{font-size:1rem;color:var(--muted);max-width:480px;margin:0 auto 2.75rem;line-height:1.75}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* FOOTER */
footer{background:var(--teal-dark);color:var(--warm-white);padding:5rem 4rem 2.5rem}
.footer-logo{display:flex;align-items:center;gap:0.75rem;text-decoration:none;margin-bottom:1rem}
.footer-logo img{height:36px;width:auto;filter:brightness(0) invert(1) opacity(0.85)}
.footer-logo-text{font-family:var(--serif);font-size:0.95rem;font-weight:700;color:rgba(255,255,255,0.9);line-height:1.2}
.footer-logo-text span{display:block;font-style:italic;font-size:0.72rem;color:rgba(255,255,255,0.45);font-weight:400}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:4rem;margin-bottom:4rem}
.footer-brand p{font-size:0.85rem;color:rgba(255,255,255,0.45);line-height:1.8;margin-top:0.25rem}
.footer-social{display:flex;gap:0.75rem;margin-top:1.5rem}
.footer-social a{width:34px;height:34px;border:1px solid rgba(255,255,255,0.15);border-radius:2px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.45);text-decoration:none;font-size:0.72rem;font-weight:500;transition:border-color 0.2s,color 0.2s}
.footer-social a:hover{border-color:rgba(255,255,255,0.6);color:rgba(255,255,255,0.9)}
.footer-col h4{font-size:0.66rem;text-transform:uppercase;letter-spacing:0.16em;color:rgba(255,255,255,0.5);margin-bottom:1.1rem}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:0.55rem}
.footer-col a{font-size:0.85rem;color:rgba(255,255,255,0.45);text-decoration:none;transition:color 0.2s}
.footer-col a:hover{color:rgba(255,255,255,0.9)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.footer-bottom p{font-size:0.75rem;color:rgba(255,255,255,0.25)}
.footer-legal{display:flex;gap:1.5rem;list-style:none}
.footer-legal a{font-size:0.75rem;color:rgba(255,255,255,0.25);text-decoration:none;transition:color 0.2s}
.footer-legal a:hover{color:rgba(255,255,255,0.6)}

/* FADE */
.fade-up{opacity:0;transform:translateY(22px);transition:opacity 0.65s ease,transform 0.65s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:1100px){
  nav{padding:0 2rem}
  .nav-links{display:none}
  .hamburger{display:flex}
  section{padding:4rem 2rem}
  .page-hero{padding:8rem 2rem 4rem}
  .cta-band{padding:4rem 2rem}
  footer{padding:4rem 2rem 2rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
}
@media(max-width:640px){.footer-grid{grid-template-columns:1fr}}
