:root {
    --teal:#234645;--teal-mid:#2d5755;--slate:#4A5859;--fieldstone:#8A8578;
    --gravel:#B8B2A6;--sandstone:#E8E4DB;--white:#FAF9F6;--charcoal:#373A36;
    --border-light:rgba(35,70,69,0.08);--border-med:rgba(138,133,120,0.2);
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;scroll-padding-top:80px;font-size:16px;}
  body{font-family:'Open Sans',sans-serif;color:var(--charcoal);background:var(--white);overflow-x:hidden;}
  .contour-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
  .contour-bg img{width:100%;height:100%;object-fit:cover;display:block;opacity:0.5;}

  /* ── HEADER ── */
  header{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--teal);border-bottom:1px solid rgba(255,255,255,0.08);}
  .header-inner{max-width:1320px;margin:0 auto;padding:0 48px;height:80px;display:flex;align-items:center;justify-content:space-between;}
  .logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
  .logo-icon{width:40px;height:40px;}
  .logo-icon rect{fill:rgba(255,255,255,0.15) !important;}
  .logo-text{font-size:0.82rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--white);line-height:1.2;}
  .logo-text span{display:block;font-weight:400;letter-spacing:0.2em;font-size:0.7rem;color:rgba(250,249,246,0.7);}
  nav{display:flex;align-items:center;gap:40px;}
  nav a{text-decoration:none;color:rgba(250,249,246,0.85);font-size:0.9rem;font-weight:500;letter-spacing:0.04em;position:relative;padding:4px 0;}
  nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--white);transition:width 0.3s ease;}
  nav a:hover::after{width:100%;}
  nav a:hover{color:var(--white);}
  nav a.cta-link{background:rgba(255,255,255,0.15);color:var(--white);padding:10px 24px;border-radius:6px;border:1px solid rgba(255,255,255,0.25);transition:background 0.2s,transform 0.2s;}
  nav a.cta-link::after{display:none;}
  nav a.cta-link:hover{background:rgba(255,255,255,0.25);transform:translateY(-1px);}

  /* ── PAGE HERO ── */
  .page-hero{position:relative;padding:160px 48px 72px;background:var(--teal);overflow:hidden;min-height:460px;}
  .page-hero .contour-bg svg path{stroke:rgba(250,249,246,0.06) !important;}
  .page-hero-inner{position:relative;z-index:2;max-width:1320px;margin:0 auto;}
  .breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:28px;}
  .breadcrumb a{font-size:0.78rem;font-weight:400;color:rgba(250,249,246,0.5);text-decoration:none;letter-spacing:0.04em;transition:color 0.2s;}
  .breadcrumb a:hover{color:rgba(250,249,246,0.8);}
  .breadcrumb .sep{color:rgba(250,249,246,0.25);font-size:0.72rem;}
  .breadcrumb .current{font-size:0.78rem;font-weight:500;color:rgba(250,249,246,0.7);letter-spacing:0.04em;}
  .page-hero h1{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:3.4rem;font-weight:600;line-height:1.12;color:var(--white);margin-bottom:24px;letter-spacing:-0.02em;max-width:700px;}
  .page-hero .subtitle{font-size:1.15rem;line-height:1.7;color:rgba(250,249,246,0.75);max-width:620px;font-weight:300;}

  /* ── STORY SECTION ── */
  .story-section{position:relative;padding:56px 48px;background:var(--white);overflow:hidden;}
  .story-layout{position:relative;z-index:2;max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start;}
  .story-label{font-size:0.72rem;font-weight:600;letter-spacing:0.3em;text-transform:uppercase;color:var(--fieldstone);margin-bottom:16px;}
  .story-title{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:2.2rem;font-weight:600;color:var(--teal);margin-bottom:20px;line-height:1.2;}
  .story-text p{font-size:1rem;line-height:1.8;color:var(--slate);font-weight:300;margin-bottom:20px;}
  .story-text p:last-child{margin-bottom:0;}

  /* ── VALUES ── */
  .values-section{position:relative;padding:56px 48px;background:var(--white);overflow:hidden;}
  .values-inner{position:relative;z-index:2;max-width:1320px;margin:0 auto;}
  .values-header{text-align:center;margin-bottom:64px;}
  .values-header .section-label{font-size:0.72rem;font-weight:600;letter-spacing:0.3em;text-transform:uppercase;color:var(--fieldstone);margin-bottom:16px;}
  .values-header h2{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:2.4rem;font-weight:600;color:var(--teal);margin-bottom:16px;}
  .values-header p{font-size:1rem;line-height:1.7;color:var(--slate);font-weight:300;max-width:640px;margin:0 auto;}
  .values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
  .value-card{background:var(--sandstone);border-radius:12px;padding:36px 28px;border:1px solid rgba(138,133,120,0.12);text-align:center;}
  .value-card .v-icon{width:48px;height:48px;margin:0 auto 20px;background:var(--teal);border-radius:12px;display:flex;align-items:center;justify-content:center;}
  .value-card .v-icon svg{width:22px;height:22px;color:var(--white);}
  .value-card h3{font-size:0.95rem;font-weight:600;color:var(--teal);margin-bottom:10px;}
  .value-card p{font-size:0.85rem;line-height:1.65;color:var(--slate);font-weight:300;}

  /* ── TEAM SECTION ── */
  .team-section{position:relative;padding:56px 48px;background:var(--sandstone);overflow:hidden;}
  .team-inner{position:relative;z-index:2;max-width:1320px;margin:0 auto;}
  .team-header{text-align:center;margin-bottom:64px;}
  .team-header .section-label{font-size:0.72rem;font-weight:600;letter-spacing:0.3em;text-transform:uppercase;color:var(--fieldstone);margin-bottom:16px;}
  .team-header h2{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:2.4rem;font-weight:600;color:var(--teal);margin-bottom:16px;}
  .team-header p{font-size:1rem;line-height:1.7;color:var(--slate);font-weight:300;max-width:640px;margin:0 auto;}
  .team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1000px;margin:0 auto;}

  /* Team card with photo hover swap */
  .team-card{text-align:center;}
  .photo-wrap{
    position:relative;width:100%;aspect-ratio:3/4;border-radius:12px;overflow:hidden;
    margin-bottom:24px;cursor:pointer;
  }
  .photo-wrap .photo-layer{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    transition:opacity 0.45s ease;
  }
  .photo-wrap .photo-formal{opacity:1;z-index:2;}
  .photo-wrap .photo-casual{opacity:0;z-index:1;}
  .photo-wrap:hover .photo-formal{opacity:0;}
  .photo-wrap:hover .photo-casual{opacity:1;}

  /* Placeholder photo styling */
  .photo-placeholder{
    position:absolute;inset:0;display:flex;flex-direction:column;
    align-items:center;justify-content:center;
  }
  .photo-placeholder.formal{background:var(--teal);z-index:2;transition:opacity 0.45s ease;}
  .photo-placeholder.casual{background:var(--fieldstone);z-index:1;transition:opacity 0.45s ease;}
  .photo-wrap:hover .photo-placeholder.formal{opacity:0;}
  .photo-wrap:hover .photo-placeholder.casual{opacity:1;}
  .photo-placeholder .initials{
    font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:3rem;font-weight:600;
    color:rgba(250,249,246,0.25);margin-bottom:8px;
  }
  .photo-placeholder .ph-label{
    font-size:0.65rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;
    color:rgba(250,249,246,0.35);
  }

  .team-card .name{
    font-size:1.1rem;font-weight:600;color:var(--teal);margin-bottom:4px;
    cursor:pointer;transition:color 0.2s;
  }
  .team-card .name:hover{color:var(--teal-mid);}
  .team-card .title-line{
    font-size:0.82rem;font-weight:400;color:var(--fieldstone);margin-bottom:10px;
    letter-spacing:0.02em;
  }
  .team-card .learn-more{
    font-size:0.78rem;font-weight:600;color:var(--teal);text-decoration:none;
    letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;
    transition:color 0.2s;display:inline-flex;align-items:center;gap:4px;
  }
  .team-card .learn-more:hover{color:var(--teal-mid);}
  .team-card .learn-more svg{width:12px;height:12px;}

  /* bio modal: inline styles */
    #bioModal .bm-photo{min-height:260px;}
    #bioModal .bm-body{padding:28px 24px;}

  /* ── CTA ── */
  .cta-band{position:relative;padding:56px 48px;background:var(--teal);text-align:center;overflow:hidden;}
  .cta-band .section-content{position:relative;z-index:2;max-width:720px;margin:0 auto;}
  .cta-band .section-label{font-size:0.72rem;font-weight:600;letter-spacing:0.3em;text-transform:uppercase;color:rgba(250,249,246,0.45);margin-bottom:16px;}
  .cta-band h2{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:2.4rem;font-weight:600;color:var(--white);margin-bottom:20px;}
  .cta-band p{font-size:1.05rem;line-height:1.75;color:rgba(250,249,246,0.75);font-weight:300;margin-bottom:36px;}
  .btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:6px;font-size:0.95rem;font-weight:500;text-decoration:none;transition:all 0.25s ease;cursor:pointer;border:none;}
  .cta-band .contour-bg svg path{stroke:rgba(250,249,246,0.06) !important;}
  .cta-band .btn-primary{background:var(--white);color:var(--teal);}
  .cta-band .btn-primary:hover{background:white;box-shadow:0 8px 24px rgba(0,0,0,0.15);}
  .cta-band .btn-outline{background:transparent;border:1.5px solid rgba(250,249,246,0.35);color:var(--white);}
  .cta-band .btn-outline:hover{background:var(--white);color:var(--teal);border-color:var(--white);}

  /* ── FOOTER ── */
  .footer{position:relative;padding:48px 48px 40px;background:var(--charcoal);overflow:hidden;}
  .footer-inner{position:relative;z-index:2;max-width:1320px;margin:0 auto;}
  .footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:60px;}
  .footer-brand .logo-text{font-size:0.9rem;margin-bottom:16px;color:var(--gravel);}
  .footer-brand .logo-text span{color:var(--gravel);}
  .footer-brand p{font-size:0.88rem;line-height:1.7;color:var(--fieldstone);font-weight:300;max-width:300px;}
  .footer-col h4{font-size:0.7rem;font-weight:600;letter-spacing:0.25em;text-transform:uppercase;color:var(--gravel);margin-bottom:20px;}
  .footer-col p,.footer-col a{font-size:0.88rem;line-height:2;color:var(--fieldstone);text-decoration:none;display:block;font-weight:300;}
  .footer-col a:hover{color:var(--white);}
  .footer-bottom{border-top:1px solid rgba(138,133,120,0.2);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;}
  .footer-bottom p{font-size:0.75rem;color:var(--fieldstone);font-weight:300;}
  .footer-bottom a{color:var(--fieldstone);text-decoration:none;font-size:0.75rem;}
  .footer-bottom a:hover{color:var(--gravel);}

  @media(max-width:1024px){
    .story-layout{grid-template-columns:1fr;gap:48px;}
    .values-grid{grid-template-columns:repeat(2,1fr);}
    .team-grid{grid-template-columns:repeat(2,1fr);max-width:680px;}
    .footer-grid{grid-template-columns:1fr;}
  }
  @media(max-width:768px){
    .page-hero h1{font-size:2.4rem;}
    .page-hero{padding:140px 24px 72px;}
    .story-section,.values-section,.team-section,.cta-band,.footer{padding-left:24px;padding-right:24px;}
    .header-inner{padding:0 20px;}
    nav{gap:20px;}
    .values-grid{grid-template-columns:1fr;}
    .team-grid{grid-template-columns:1fr;max-width:340px;}
    .footer-grid{grid-template-columns:1fr;gap:32px;}
    #bioModal .bm-body{padding:28px 24px;}
  }

  /* ── FOOTER COLOR: Option B Deep Teal ── */
  .footer{background:#1a2f2e !important;}
  .footer-brand .logo-text,.footer-brand .logo-text span{color:#aecdcb !important;}
  .footer-brand p{color:#cbdddb !important;}
  .footer-col h4{color:#aecdcb !important;}
  .footer-col p,.footer-col a{color:#cbdddb !important;}
  .footer-col a:hover{color:#ffffff !important;}
  .footer-bottom p,.footer-bottom a{color:#95b2b0 !important;}
  .footer-bottom a:hover{color:#aecdcb !important;}
  .footer-bottom{border-top-color:rgba(122,158,156,0.15) !important;}

  /* ── OSWALD TYPOGRAPHY REFINEMENTS ── */
  .page-hero h1,.hero h1{font-weight:500 !important;letter-spacing:0.04em !important;}
  .section-title,.overview-title,.story-title,
  .subservices-header h2,.values-header h2,.team-header h2,
  .audience-inner h2,.context-text h2,.cta-band h2,
  .next-inner h2,.form-card h3{font-weight:500 !important;letter-spacing:0.04em !important;}
  .card-number,.stat-num{font-weight:500 !important;letter-spacing:0.02em !important;}
  .sub-card h3{text-transform:none !important;}
  .modal-name{font-weight:500 !important;letter-spacing:0.04em !important;}
  .card-body h3{font-weight:500 !important;letter-spacing:0.03em !important;}

  /* Photo hero additions */
  .hero-photo {
    position: absolute;
    inset: 0;
    z-index: 0;
  }
  .hero-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 40%;
  }
  .hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(to bottom,
      rgba(26, 46, 45, 0.7) 0%,
      rgba(26, 46, 45, 0.5) 40%,
      rgba(26, 46, 45, 0.75) 100%);
  }
  .page-hero .contour-bg { z-index: 2 !important; }
  .page-hero-inner { position: relative; z-index: 3; }

  .page-hero { background: #1a2e2d !important; }

  /* ── BIO MODAL ── */
  .bio-overlay{position:fixed;inset:0;background:rgba(26,46,45,0.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:200;opacity:0;pointer-events:none;transition:opacity 0.3s;}
  .bio-overlay.active{opacity:1;pointer-events:auto;}
  .bio-modal{position:fixed;top:0;right:-560px;width:560px;max-width:100vw;height:100vh;background:var(--white);z-index:201;overflow-y:auto;transition:right 0.35s ease;box-shadow:-8px 0 40px rgba(0,0,0,0.15);}
  .bio-modal.active{right:0;}
  .bio-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:rgba(35,70,69,0.08);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;transition:background 0.2s;}
  .bio-close:hover{background:rgba(35,70,69,0.15);}
  .bio-close svg{width:16px;height:16px;color:var(--teal);}
  .bio-photo{width:100%;height:340px;overflow:hidden;}
  .bio-photo img{width:100%;height:100%;object-fit:cover;object-position:center 20%;}
  .bio-content{padding:36px 40px 48px;}
  .bio-name{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:2rem;font-weight:500;color:var(--teal);letter-spacing:0.04em;line-height:1.15;margin-bottom:4px;}
  .bio-title{font-size:0.88rem;font-weight:500;color:var(--fieldstone);margin-bottom:16px;}
  .bio-contact{display:flex;flex-direction:column;gap:6px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(138,133,120,0.15);}
  .bio-contact a{display:flex;align-items:center;gap:8px;font-size:0.88rem;color:var(--teal);text-decoration:none;font-weight:400;transition:color 0.2s;}
  .bio-contact a:hover{color:var(--teal-mid);}
  .bio-contact svg{width:15px;height:15px;flex-shrink:0;color:var(--fieldstone);}
  .bio-text p{font-size:0.95rem;line-height:1.8;color:var(--slate);font-weight:300;margin-bottom:14px;}
  .bio-specs{margin-top:28px;padding-top:24px;border-top:1px solid rgba(138,133,120,0.15);}
  .bio-specs h4{font-size:0.68rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--teal);margin-bottom:16px;}
  .bio-specs-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
  .bio-spec{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--sandstone);border-radius:8px;border:1px solid rgba(138,133,120,0.08);}
  .bio-spec svg{width:18px;height:18px;color:var(--teal);flex-shrink:0;}
  .bio-spec span{font-size:0.78rem;font-weight:500;color:var(--teal);text-transform:uppercase;letter-spacing:0.04em;}
  @media(max-width:600px){.bio-modal{width:100vw;}.bio-specs-grid{grid-template-columns:1fr;}}

  .footer-social { display: flex; gap: 12px; margin-top: 20px; }
  .footer-social a { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 8px; background: rgba(138,133,120,0.15); color: var(--fieldstone); transition: background 0.2s, color 0.2s; }
  .footer-social a:hover { background: rgba(138,133,120,0.3); color: var(--white); }
  .footer-social svg { width: 16px; height: 16px; }

  /* ── MOBILE NAV ── */
  .nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--white);}
  .nav-toggle svg{display:block;width:24px;height:24px;stroke:var(--white);stroke-width:2;stroke-linecap:round;}
  .nav-toggle .icon-close{display:none;}
  .nav-toggle.open .icon-open{display:none;}
  .nav-toggle.open .icon-close{display:block;}
  @media(max-width:768px){
    .nav-toggle{display:flex;align-items:center;justify-content:center;z-index:110;}
    nav{
      display:none;position:fixed;top:80px;left:0;right:0;
      background:var(--teal);flex-direction:column;
      padding:16px 0 24px;gap:0;z-index:100;
      border-top:1px solid rgba(255,255,255,0.1);
      box-shadow:0 8px 24px rgba(0,0,0,0.2);
    }
    nav.open{display:flex;}
    nav a{
      padding:14px 24px;font-size:0.95rem;width:100%;
      border-bottom:1px solid rgba(255,255,255,0.07);
    }
    nav a::after{display:none;}
    nav a.cta-link{
      margin:16px 24px 0;width:auto;
      background:var(--white);
      color:var(--teal) !important;
      border:1px solid var(--white);
      text-align:center;border-radius:6px;
    }
  }

/* FOOTER_480_INJECTED */
  @media(max-width:480px){
    .footer-grid{grid-template-columns:1fr;gap:32px;}
    .footer-brand{max-width:100%;}
  }

/* PAGE_MOBILE_INJECTED */
  @media(max-width:768px){
    .story-layout{grid-template-columns:1fr;gap:40px;}
    .story-image{order:-1;max-height:320px;overflow:hidden;}
  }
  @media(max-width:480px){
    .page-hero h1{font-size:2rem;}
    .values-grid{grid-template-columns:1fr;}
    .team-grid{grid-template-columns:1fr;max-width:280px;}
  }

  .logo-img{height:36px;width:auto;display:block;}

  @media(max-width:600px){.mv-grid{grid-template-columns:1fr !important;}}

  @media(max-width:480px){.logo-img{height:28px;max-width:120px;}}

  .nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:99;}
  .nav-overlay.open{display:block;}

  @media(max-width:640px){
    #bioModal{padding:0 !important;align-items:flex-end !important;}
    .bio-modal-inner{
      grid-template-columns:1fr !important;
      max-height:92vh !important;
      height:92vh;
      overflow:hidden !important;
      border-bottom-left-radius:0 !important;
      border-bottom-right-radius:0 !important;
      max-width:100% !important;
      width:100% !important;
    }
    .bio-modal-inner > div:first-child{min-height:200px !important;height:200px !important;flex-shrink:0;}
    .bio-modal-inner > div:last-child{overflow-y:auto !important;-webkit-overflow-scrolling:touch;max-height:none !important;flex:1;}
  }

  @media(max-width:768px){
    .contour-bg img{opacity:0.5;}
  }

  @media(max-width:640px){
    .bio-content-pane{padding:24px 20px 40px !important;overflow-y:auto !important;-webkit-overflow-scrolling:touch !important;max-height:none !important;}
  }

  @media(max-width:768px){
    .why-section,.services-section,.credentials-section,
    .overview-section,.subservices-section,.context-section,
    .audience-section,.story-section,.values-section,
    .team-section,.contact-section,
    .next-section{padding-top:40px !important;padding-bottom:40px !important;}
    .cta-band{padding-top:48px !important;padding-bottom:48px !important;}
  }
  @media(max-width:480px){
    .why-section,.services-section,.credentials-section,
    .overview-section,.subservices-section,.context-section,
    .audience-section,.story-section,.values-section,
    .team-section,.contact-section,
    .next-section{padding-top:32px !important;padding-bottom:32px !important;}
    .cta-band{padding-top:40px !important;padding-bottom:40px !important;}
  }


/* Keyboard focus visibility (accessibility) */
a:focus-visible, button:focus-visible, .btn:focus-visible,
input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--teal);
  outline-offset: 2px;
}
header nav a:focus-visible, .cta-link:focus-visible, .nav-toggle:focus-visible {
  outline: 2px solid var(--white);
  outline-offset: 4px;
}
