*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:focus-visible{outline:2px solid var(--y);outline-offset:2px;border-radius:4px}
:root{
  --bp:#0D1B2A;--bp2:#1B2838;--bp3:#1E3A5F;
  --y:#F5A623;--yh:#E09000;--yg:rgba(245,166,35,.3);
  --w:#fff;--w9:rgba(255,255,255,.9);--w7:rgba(255,255,255,.7);
  --w5:rgba(255,255,255,.5);--w2:rgba(255,255,255,.2);
  --w1:rgba(255,255,255,.1);--w05:rgba(255,255,255,.05);
  --r:8px;--rl:12px;
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --safe-left:env(safe-area-inset-left,0px);
  --safe-right:env(safe-area-inset-right,0px);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;color:#e0e0e0;background:var(--bp);line-height:1.6;overflow-x:hidden;-webkit-overflow-scrolling:touch}
a{color:var(--y);text-decoration:none;transition:color .3s}a:hover{color:var(--yh)}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
/* Large-screen fix: keep site from looking small on big monitors */
@media(min-width:1600px){.container{max-width:1360px}}
@media(min-width:2000px){.container{max-width:1600px}}
@media(min-width:2560px){.container{max-width:1840px}}
@media(min-width:1700px){.partner-grid{grid-template-columns:repeat(5,1fr)}}
.btn{display:inline-block;padding:14px 30px;font-size:1rem;font-weight:700;border-radius:var(--r);cursor:pointer;transition:all .3s;border:2px solid transparent;text-align:center;font-family:inherit}
.btn-primary{background:var(--y);color:var(--bp);border-color:var(--y)}
.btn-primary:hover{background:var(--yh);transform:translateY(-2px);box-shadow:0 4px 20px var(--yg);color:var(--bp)}
.btn-outline{background:transparent;color:var(--w);border-color:var(--w2)}
.btn-outline:hover{background:var(--w1);border-color:var(--w5);color:var(--w)}
.blueprint-bg{background:#0D1B2A;position:relative;overflow:hidden}
.blueprint-bg::before{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(rgba(100,180,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.1) 1px,transparent 1px);background-size:20px 20px,20px 20px,100px 100px,100px 100px;opacity:.45}
.blueprint-grid{position:absolute;inset:0;pointer-events:none;background:linear-gradient(rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(rgba(100,180,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.1) 1px,transparent 1px);background-size:20px 20px,20px 20px,100px 100px,100px 100px;opacity:.45}
/* Animation: visible by default (fail-open), JS adds .anim-ready to enable the transition */
.anim{opacity:1;transform:translateY(0)}
.anim-ready .anim{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.anim-ready .anim.visible{opacity:1;transform:translateY(0)}

/* TOP BAR */
/* ── SITE HEADER — Single Nav Bar ────────────────────────── */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1001;
  background:rgba(10,20,34,.97);
  backdrop-filter:blur(12px);
  box-shadow:0 2px 30px rgba(0,0,0,.7);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.hdr-brand{display:none}
.hdr-rule{display:none}

/* Single nav bar */
.hdr-nav{
  display:flex;align-items:center;justify-content:center;
  padding:0 28px;
  background:rgba(255,255,255,.02);
}
.hdr-nav-left{display:flex;align-items:center;gap:4px;flex:1}
.hdr-nav-left a{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.05);color:rgba(255,255,255,.4);
  transition:all .2s;text-decoration:none;
}
.hdr-nav-left a:hover{background:var(--y);color:var(--bp)}
.nav-links{display:flex;list-style:none;gap:0}
.nav-links a{
  display:block;
  color:rgba(255,255,255,.45);
  padding:14px 24px;
  font-weight:600;font-size:.85rem;
  text-transform:uppercase;letter-spacing:1.5px;
  transition:all .2s;text-decoration:none;
  border-bottom:2px solid transparent;
}
.nav-links a:hover,.nav-links a.nav-active{
  color:var(--y);
  border-bottom-color:var(--y);
  background:rgba(245,166,35,.03);
}
.hdr-nav-right{display:flex;align-items:center;gap:14px;flex:1;justify-content:flex-end}
.hdr-nav-right .hdr-phone{
  display:flex;align-items:center;gap:6px;
  color:var(--w9)!important;font-weight:700;font-size:.95rem;
  text-decoration:none;white-space:nowrap;transition:all .2s;
  letter-spacing:.3px;
}
.hdr-nav-right .hdr-phone svg{color:var(--y)}
.hdr-nav-right .hdr-phone:hover{color:var(--y)!important}
.hdr-nav-right .hdr-email-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:8px 16px;background:transparent;
  color:var(--w7)!important;border:1px solid rgba(255,255,255,.12);
  border-radius:4px;font-family:inherit;font-size:.8rem;
  font-weight:600;cursor:pointer;transition:all .2s;
  white-space:nowrap;letter-spacing:.5px;text-transform:uppercase;
}
.hdr-nav-right .hdr-email-btn:hover{background:var(--y);color:var(--bp)!important;border-color:var(--y)}

/* Panel hero title — Matching hardhat logo gold */
.panel-hero-title{
  font-size:3.48rem;font-weight:900;
  text-transform:uppercase;letter-spacing:5px;
  line-height:1.1;margin-bottom:8px;
  background:linear-gradient(150deg,#5C3D0E 0%,#8B6508 15%,#C6911C 30%,#F5A623 45%,#E8991A 60%,#C6811C 75%,#8B5E08 90%,#5C3D0E 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  -webkit-text-stroke:0.5px rgba(80,50,10,.4);
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.5));
}
.panel-hero-tagline{
  font-size:1.15rem;font-weight:600;
  color:var(--w);font-style:italic;
  letter-spacing:.5px;margin-bottom:22px;
  opacity:.85;
  border-bottom:1px solid rgba(245,166,35,.25);
  display:inline-block;padding-bottom:4px;
}

/* Nav toggle (mobile) */
.nav-toggle{
  display:none;flex-direction:column;gap:4px;
  background:none;border:none;cursor:pointer;padding:6px;
}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--w);transition:all .3s;border-radius:2px}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* Mobile: Header */
@media(max-width:900px){
  .hdr-nav{padding:0 20px}
  .nav-links a{padding:10px 14px;font-size:.7rem;letter-spacing:1px}
  .panel-hero-title{font-size:1.8rem;letter-spacing:3px}
}
@media(max-width:640px){
  .hdr-nav{padding:0 12px;flex-wrap:wrap}
  .hdr-nav-left{order:1}
  .hdr-nav-right{order:3}
  .hdr-nav-right .hdr-phone span{display:none}
  .hdr-nav-right .hdr-email-btn{display:none}
  .nav-toggle{display:flex;order:2;margin-left:auto}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;background:#0a1422;
    border-top:1px solid var(--w1);
    box-shadow:0 10px 30px rgba(0,0,0,.5);
    order:4;width:100%;
  }
  .nav-links.active{display:flex}
  .nav-links a{padding:14px 24px;font-size:.8rem;border-bottom:1px solid var(--w05)}
  .panel-hero-title{font-size:1.4rem;letter-spacing:2px}
  .panel-hero-tagline{font-size:.85rem}
}

/* PAGES */
.page{display:block;animation:pageFadeIn .35s ease}
@keyframes pageFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* HERO */
.hero{position:relative;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 24px 60px;background:linear-gradient(180deg,#0a1628,var(--bp) 80%)}
.hero.hero-compact{padding:88px 24px 48px}
.hero.hero-tight{padding:78px 24px 28px}
.hero-content{position:relative;z-index:2;max-width:800px}
.hero h1{font-size:2.8rem;font-weight:900;line-height:1.1;color:var(--w);margin-bottom:16px;letter-spacing:-1px}
.accent{color:var(--y)}
.hero-tagline{font-size:1.2rem;font-weight:600;color:var(--w9);margin-bottom:12px}
.hero-sub{font-size:.95rem;color:var(--w5);max-width:520px;margin:0 auto 28px}
.hero .btn{margin:0 6px 10px}

/* CONTENT SECTIONS */
.content-section{padding:60px 0;position:relative}
.content-section.content-tight{padding:40px 0}
.content-section.alt{background:var(--bp2)}
.section-title{font-size:2rem;font-weight:800;color:var(--w);text-align:center;margin-bottom:36px}
.content-tight .section-title{margin-bottom:20px;font-size:1.6rem}

/* VALUE CARDS */
.values-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}
.value-card{padding:18px 22px;background:var(--w05);border-radius:var(--r);border-left:4px solid var(--y);transition:transform .3s,box-shadow .3s}
.value-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.3)}
.value-card h3{font-size:1rem;font-weight:700;color:var(--y);margin-bottom:4px}
.value-card p{font-size:.88rem;color:var(--w5)}

/* MISSION */
.mission-text{max-width:800px;margin:0 auto 16px;text-align:center;color:var(--w7);font-size:1.05rem;line-height:1.8}
.mission-tagline{max-width:600px;margin:0 auto;text-align:center;color:var(--y);font-size:1.1rem;font-weight:700;font-style:italic}

/* TESTIMONIALS */
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.test-card{padding:24px;background:var(--w05);border:1px solid var(--w1);border-radius:var(--rl);transition:transform .3s,box-shadow .3s}
.test-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.3)}
.test-card p{color:var(--w7);font-size:.9rem;line-height:1.7;margin-bottom:14px;font-style:italic}
.test-card strong{color:var(--w);font-size:.9rem}
.test-card span{font-size:.8rem;color:var(--w5)}

/* HOUSE SECTION */
.house-section{position:relative;background:#0D1B2A;border-top:none;border-bottom:1px solid var(--w1);padding:0;margin-top:0;scroll-margin-top:0}
.house-layout{display:grid;grid-template-columns:220px 1fr;min-height:48vh}
.services-sidebar{background:rgba(10,20,34,.97);border-right:1px solid var(--w1);padding:0;overflow:hidden;display:flex;flex-direction:column}
.sidebar-header{padding:10px 14px 0;flex-shrink:0}
.sidebar-title{font-size:1.1rem;font-weight:800;color:var(--y);text-transform:uppercase;letter-spacing:1.5px;margin-top:0;margin-bottom:3px}
.sidebar-sub{font-size:.75rem;color:var(--w5);margin-bottom:8px}
.services-list{list-style:none;display:flex;flex-direction:column;gap:1px;overflow-y:auto;padding:0 14px 14px;flex:1}
.service-btn{display:block;width:100%;padding:7px 12px;background:transparent;border:1px solid transparent;border-radius:var(--r);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;color:var(--w7);text-align:left;transition:all .2s}
.service-btn:hover{background:rgba(245,166,35,.08);border-color:rgba(245,166,35,.2);color:var(--y)}
.service-btn.active{background:rgba(245,166,35,.12);border-color:rgba(245,166,35,.3);color:var(--y)}
.house-canvas{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:rgba(10,20,34,.97);
  position:relative;
  overflow:hidden;
  padding-top:10px;
}
/* Blueprint grid — whisper level */
.house-canvas::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(rgba(100,180,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(100,180,255,.05) 1px,transparent 1px),
    linear-gradient(rgba(100,180,255,.1) 1px,transparent 1px),
    linear-gradient(90deg,rgba(100,180,255,.1) 1px,transparent 1px);
  background-size:20px 20px,20px 20px,100px 100px,100px 100px;
  opacity:.45;
}
/* Gold glow behind hat */
.house-canvas::after{
  content:'';position:absolute;top:-40px;left:50%;transform:translateX(-50%);
  width:420px;height:300px;pointer-events:none;
  background:radial-gradient(ellipse at 50% 45%,rgba(245,166,35,.08) 0%,transparent 68%);
}
.house-intro{
  text-align:center;
  width:100%;
  display:flex;flex-direction:column;align-items:center;
  gap:0;position:relative;z-index:1;
  padding:16px 36px 24px;
}

/* Hard hat */
.house-logo{
  width:100%;max-width:690px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:26px;
  flex-shrink:0;
}
.house-logo img{
  max-height:322px;
  width:auto;
  max-width:100%;
  object-fit:contain;
  filter:drop-shadow(0 10px 40px rgba(0,0,0,.7)) drop-shadow(0 0 60px rgba(245,166,35,.2));
}

/* Company name */
.house-company-name{
  display:flex;flex-direction:column;align-items:center;
  line-height:1;margin-bottom:16px;
}
.house-name-row1{
  font-size:3.45rem;font-weight:500;color:#fff;
  text-transform:uppercase;letter-spacing:5px;line-height:1;
}
.house-name-row2{
  display:flex;align-items:baseline;justify-content:center;
  flex-wrap:wrap;gap:8px;line-height:1.2;
}
.house-name-partners{
  font-size:3.45rem;font-weight:500;color:#fff;
  text-transform:uppercase;letter-spacing:5px;
}
.house-name-of{
  font-size:2.01rem;font-weight:600;color:#F5A623;font-style:italic;
  text-shadow:0 0 4px rgba(245,166,35,.8),0 0 8px rgba(245,166,35,.4);
}
.house-name-bay{
  font-size:2.01rem;font-weight:600;color:#F5A623;font-style:italic;
  text-shadow:0 0 4px rgba(245,166,35,.8),0 0 8px rgba(245,166,35,.4);
}
.house-name-row3{
  display:flex;align-items:flex-start;justify-content:flex-end;width:100%;
}
.house-name-inc{
  font-size:1.02rem;font-weight:600;color:#F5A623;font-style:italic;letter-spacing:.5px;
  text-shadow:0 0 4px rgba(245,166,35,.7);
  opacity:.75;
}
.house-intro h2{
  font-size:1.15rem;font-weight:700;color:#F5A623;
  margin-bottom:6px;line-height:1.4;letter-spacing:.3px;
  margin-top:32px;
}
.house-intro .house-tagline{
  color:rgba(255,255,255,.5);font-size:.95rem;
  line-height:1.5;margin-bottom:36px;
}
.house-intro .btn{
  width:78%;max-width:380px;
  padding:16px 28px;font-size:1rem;
  font-weight:700;letter-spacing:.5px;
  margin-bottom:22px;
}

/* Stat boxes — below button */
.house-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:10px;width:100%;
}
.house-stat{
  padding:12px 6px;text-align:center;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:68px;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.house-stat:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.3);border-color:rgba(245,166,35,.2)}
.house-stat-num{
  display:block;font-size:1.5rem;font-weight:700;
  color:#F5A623;line-height:1;margin-bottom:4px;
}
.house-stat-label{
  display:block;font-size:.58rem;font-weight:600;
  color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.8px;
  line-height:1.3;
}

/* DETAIL PANEL */
.detail-overlay{position:fixed;inset:0;z-index:1500;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:all .3s}
.detail-overlay.active{opacity:1;visibility:visible}
.detail-panel{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:92vw;background:var(--bp2);border-left:1px solid var(--w1);z-index:1600;transform:translateX(100%);transition:transform .35s ease;overflow-y:auto;padding:36px}
.detail-panel.active{transform:translateX(0)}
.detail-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border:none;background:var(--w05);border-radius:50%;font-size:1.5rem;color:var(--w5);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;line-height:1}
.detail-close:hover{background:var(--y);color:var(--bp)}
.detail-label{display:inline-block;padding:4px 12px;background:rgba(245,166,35,.12);color:var(--y);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;margin-bottom:16px}
.detail-company{font-size:1.5rem;font-weight:800;color:var(--w);margin-bottom:6px}
.detail-contact{color:var(--w5);font-size:.95rem;margin-bottom:20px}
.detail-desc{color:var(--w7);line-height:1.7;margin-bottom:24px}
.detail-actions{display:flex;flex-direction:column;gap:10px}
.detail-actions .btn{text-align:center}
.detail-phone{display:block;text-align:center;color:var(--w5);font-size:.9rem;font-weight:600;margin-top:8px}
.detail-phone:hover{color:var(--y)}
.coming-soon-badge{display:inline-block;padding:4px 12px;background:rgba(255,165,0,.12);color:orange;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;margin-bottom:12px;border:1px solid rgba(255,165,0,.25)}

/* EMAIL CHOOSER */
.email-chooser{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s}
.email-chooser.active{opacity:1;visibility:visible}
.email-chooser-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.email-chooser-box{position:relative;background:var(--bp2);border:1px solid var(--w1);border-radius:var(--rl);padding:32px;max-width:400px;width:90%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.5);transform:translateY(12px) scale(.97);transition:transform .3s}
.email-chooser.active .email-chooser-box{transform:translateY(0) scale(1)}
.email-chooser-close{position:absolute;top:10px;right:10px;width:32px;height:32px;border:none;background:var(--w05);border-radius:50%;font-size:1.3rem;color:var(--w5);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}
.email-chooser-close:hover{background:var(--y);color:var(--bp)}
.email-chooser-box h3{font-size:1.15rem;font-weight:800;color:var(--w);margin-bottom:8px}
.email-chooser-address{color:var(--y);font-size:.88rem;font-weight:600;margin-bottom:24px;word-break:break-all}
.email-chooser-options{display:flex;flex-direction:column;gap:10px}
.email-opt{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border-radius:var(--r);font-family:inherit;font-size:.92rem;font-weight:700;cursor:pointer;transition:all .2s;border:1px solid var(--w1);text-decoration:none;background:var(--w05);color:var(--w7)}
.email-opt:hover{background:var(--w1);color:var(--w);border-color:var(--w2)}
.email-opt-gmail{background:rgba(219,68,55,.1);color:#EA4335;border-color:rgba(219,68,55,.2)}
.email-opt-gmail:hover{background:rgba(219,68,55,.18);color:#EA4335;border-color:rgba(219,68,55,.35)}
.email-opt-outlook{background:rgba(0,120,212,.1);color:#0078D4;border-color:rgba(0,120,212,.2)}
.email-opt-outlook:hover{background:rgba(0,120,212,.18);color:#0078D4;border-color:rgba(0,120,212,.35)}
.email-opt-copy.copied{background:rgba(76,175,80,.15);color:#66BB6A;border-color:rgba(76,175,80,.3)}

/* ABOUT PAGE */
.about-hero{position:relative;padding:80px 24px 60px;text-align:center;background:linear-gradient(180deg,#0a1628,var(--bp) 80%)}
.about-hero h1{font-size:3rem;font-weight:900;color:var(--w);letter-spacing:-1px;margin-bottom:12px}
.about-hero .subtitle{font-size:1.15rem;color:var(--w5);max-width:560px;margin:0 auto}
.mission-section{padding:72px 0;position:relative}
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.mission-block h2{font-size:1.15rem;font-weight:800;color:var(--y);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}
.mission-block p{color:var(--w7);line-height:1.85;margin-bottom:16px}
.mission-block .lead{font-size:1.08rem;color:var(--w9)}
.mission-block .tagline{font-size:1.1rem;font-weight:700;color:var(--y);font-style:italic;margin-top:8px}
.gallery-section{padding:72px 0;background:#0D1B2A;position:relative;overflow:hidden}
.gallery-section .section-title{margin-bottom:12px}
.gallery-section::before{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(rgba(100,180,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.1) 1px,transparent 1px);background-size:20px 20px,20px 20px,100px 100px,100px 100px;opacity:.45}
.gallery-subtitle{text-align:center;color:var(--w5);font-size:.95rem;margin-bottom:40px}
.partner-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.partner-card-link{display:contents;color:inherit;text-decoration:none}
.partner-card{background:rgba(255,255,255,.03);border:1px solid var(--w1);border-radius:var(--rl);overflow:hidden;transition:border-color .3s,transform .3s;cursor:pointer}
.partner-card:hover{border-color:var(--y);transform:translateY(-4px)}
.headshot-placeholder{width:100%;aspect-ratio:1/1;background:linear-gradient(135deg,rgba(245,166,35,.08) 0%,rgba(245,166,35,.03) 100%);display:flex;align-items:center;justify-content:center;border-bottom:2px solid rgba(245,166,35,.2);transition:border-color .3s,background .3s;overflow:hidden}
.partner-card:hover .headshot-placeholder{border-bottom-color:var(--y);background:linear-gradient(135deg,rgba(245,166,35,.14) 0%,rgba(245,166,35,.05) 100%)}
.headshot-placeholder svg{width:48px;height:48px;opacity:.3;color:var(--y)}
.partner-info{padding:16px 14px}
.partner-name{font-size:.92rem;font-weight:800;color:var(--w);margin-bottom:3px;line-height:1.3}
.partner-company{font-size:.8rem;color:var(--y);font-weight:600;margin-bottom:8px;line-height:1.3}
.partner-service{display:inline-block;padding:3px 10px;background:rgba(245,166,35,.1);color:var(--y);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:20px}
.partner-card.placeholder .partner-service{background:rgba(255,165,0,.08);color:rgba(255,165,0,.6)}
.values-section{padding:72px 0}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.values-card{padding:32px 28px;background:rgba(255,255,255,.03);border:1px solid var(--w1);border-radius:var(--rl);text-align:center;border-top:4px solid var(--y);transition:border-color .3s,transform .3s}
.values-card:hover{transform:translateY(-4px)}
.values-card-icon{width:56px;height:56px;margin:0 auto 18px;background:rgba(245,166,35,.1);border-radius:50%;display:flex;align-items:center;justify-content:center}
.values-card-icon svg{width:28px;height:28px;color:var(--y)}
.values-card h3{font-size:1.15rem;font-weight:800;color:var(--w);margin-bottom:10px}
.values-card p{font-size:.9rem;color:var(--w5);line-height:1.7}

/* SERVICE PAGE */
.sp-hero{position:relative;padding:80px 24px 60px;text-align:center;min-height:42vh;display:flex;align-items:center;justify-content:center;background:#0D1B2A;overflow:hidden}
.sp-hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(rgba(100,180,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.1) 1px,transparent 1px);background-size:20px 20px,20px 20px,100px 100px,100px 100px;opacity:.45}
.sp-hero-inner{position:relative;z-index:2;max-width:700px}
.sp-badge{display:inline-block;padding:6px 16px;background:rgba(245,166,35,.12);color:var(--y);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-radius:20px;margin-bottom:16px}
.sp-coming-badge{display:inline-block;padding:6px 16px;background:rgba(255,140,0,.1);color:orange;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-radius:20px;margin-bottom:12px;border:1px solid rgba(255,140,0,.25)}
.sp-company{font-size:2.4rem;font-weight:900;color:var(--w);margin-bottom:8px;letter-spacing:-1px}
.sp-contact{font-size:1.1rem;color:var(--w5);margin-bottom:24px}
.sp-body{padding:60px 0 0;position:relative}
.sp-grid{max-width:960px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.6fr 1fr;gap:48px;align-items:start}
.sp-desc h3{font-size:1.3rem;font-weight:800;color:var(--w);margin-bottom:16px}
.sp-desc p{color:var(--w7);line-height:1.85;margin-bottom:14px;font-size:1rem}
.sp-desc ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.sp-desc ul li{color:var(--w7);font-size:.95rem;padding-left:20px;position:relative}
.sp-desc ul li::before{content:'→';position:absolute;left:0;color:var(--y)}
.sp-sidebar{display:flex;flex-direction:column;gap:20px}
.sp-card{background:var(--w05);border:1px solid var(--w1);border-radius:var(--rl);padding:24px}
.sp-card h4{color:var(--y);font-size:.75rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}
.sp-card p,.sp-card a{display:block;color:var(--w7);font-size:.92rem;margin-bottom:8px;word-break:break-word}
.sp-card a:hover{color:var(--y)}
.sp-social{display:flex;flex-wrap:wrap;gap:10px}
.sp-social a{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--w05);border:1px solid var(--w1);border-radius:50%;color:var(--w5);transition:all .3s}
.sp-social a:hover{background:var(--y);color:var(--bp);border-color:var(--y)}
.sp-social-disabled{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--w05);border:1px solid var(--w05);border-radius:50%;color:var(--w2);opacity:.25;cursor:default}
.sp-social-label{font-size:.7rem;font-weight:700;color:var(--w5);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.sp-social-row{margin-bottom:14px}
.sp-social-row:last-child{margin-bottom:0}
.sp-back{display:inline-flex;align-items:center;gap:8px;color:var(--w5);font-size:.9rem;font-weight:600;margin-bottom:20px;transition:color .3s;background:none;border:none;cursor:pointer;font-family:inherit}
.sp-back:hover{color:var(--y)}
.sp-license{font-size:.82rem;color:var(--w2);margin-top:4px}
.sp-cta{text-align:center;padding:48px 24px;border-top:1px solid var(--w1);position:relative;overflow:hidden;background:#0D1B2A}
.sp-cta::before{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.05) 1px,transparent 1px),linear-gradient(rgba(100,180,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(100,180,255,.1) 1px,transparent 1px);background-size:20px 20px,20px 20px,100px 100px,100px 100px;opacity:.45}
.sp-cta p{color:var(--w5);margin-bottom:20px;font-size:1rem}
.sp-cta .btn{margin:0 6px 10px}

/* JOIN PAGE */
.welcome-section{padding:60px 0 48px}
.welcome-inner{max-width:760px;margin:0 auto;text-align:center}
.welcome-inner h2{font-size:1.8rem;font-weight:800;color:var(--w);margin-bottom:16px}
.welcome-inner p{color:var(--w7);font-size:1.05rem;line-height:1.8;margin-bottom:14px}
.welcome-inner .highlight{color:var(--y);font-weight:700}
.welcome-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px}
.welcome-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:rgba(245,166,35,.08);border:1px solid rgba(245,166,35,.18);border-radius:20px;color:var(--y);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.apply-cta{text-align:center;padding:48px 24px}
.apply-cta h2{font-size:1.6rem;font-weight:800;color:var(--w);margin-bottom:10px}
.apply-cta p{color:var(--w5);font-size:1rem;margin-bottom:24px;max-width:520px;margin-left:auto;margin-right:auto}
.apply-cta .btn{min-width:280px;font-size:1.05rem;padding:16px 40px}
.faq-list{max-width:750px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--w1)}
.faq-q{display:flex;justify-content:space-between;align-items:center;width:100%;padding:18px 0;background:none;border:none;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;color:var(--w9);text-align:left;transition:color .3s}
.faq-q:hover{color:var(--y)}
.faq-q span{font-size:1.4rem;font-weight:300;color:var(--y);transition:transform .3s;flex-shrink:0;margin-left:16px}
.faq-item.active .faq-q span{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.active .faq-a{max-height:300px;padding-bottom:16px}
.faq-a p{color:var(--w5);line-height:1.7}
.faq-a a{color:var(--y);font-weight:600}
.cta-box{text-align:center;max-width:700px;margin:0 auto;padding:60px 24px}
.cta-box h2{font-size:1.8rem;font-weight:800;color:var(--w);margin-bottom:12px}
.cta-box p{color:var(--w5);font-size:1rem;line-height:1.7;margin-bottom:8px}
.cta-box .cta-contact{margin-top:24px;display:flex;flex-wrap:wrap;justify-content:center;gap:12px}
.cta-box .cta-contact a{font-weight:600;font-size:1rem;transition:opacity .3s}
.cta-box .cta-contact a:hover{opacity:.8}

/* APPLICATION FORM */
.form-section{max-width:700px;margin:0 auto}
.form-section-title{font-size:1.1rem;font-weight:800;color:var(--y);text-transform:uppercase;letter-spacing:1px;margin:32px 0 16px;padding-bottom:8px;border-bottom:1px solid var(--w1)}
.form-section-title:first-child{margin-top:0}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--w7);margin-bottom:6px}
.form-group label .required{color:var(--y)}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;background:var(--w05);border:1px solid var(--w1);border-radius:var(--r);color:var(--w);font-family:inherit;font-size:.9rem;transition:border-color .3s}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--y)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--w2)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23F5A623' fill='none' stroke-width='2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form-select option{background:var(--bp2);color:var(--w)}
.form-textarea{min-height:100px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.yn-group{background:var(--w05);border:1px solid var(--w1);border-radius:var(--rl);padding:16px 20px;margin-bottom:12px;transition:border-color .3s}
.yn-group:hover{border-color:var(--w2)}
.yn-question{font-size:.9rem;font-weight:600;color:var(--w9);margin-bottom:10px}
.yn-pills{display:flex;gap:8px}
.yn-pill{flex:1;text-align:center;padding:8px 16px;border:1px solid var(--w1);border-radius:var(--r);cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:700;color:var(--w5);background:transparent;transition:all .2s}
.yn-pill:hover{border-color:var(--w5);color:var(--w)}
.yn-pill.selected-yes{background:rgba(76,175,80,.15);border-color:rgba(76,175,80,.5);color:#66BB6A}
.yn-pill.selected-no{background:rgba(239,83,80,.12);border-color:rgba(239,83,80,.4);color:#EF5350}
.form-notice{padding:16px 20px;background:rgba(245,166,35,.06);border:1px solid rgba(245,166,35,.15);border-radius:var(--r);color:var(--w7);font-size:.85rem;line-height:1.6;margin-bottom:24px}
.form-submit{display:block;width:100%;padding:16px;background:var(--y);color:var(--bp);border:none;border-radius:var(--r);font-family:inherit;font-size:1rem;font-weight:800;cursor:pointer;transition:all .3s;margin-top:24px}
.form-submit:hover{background:var(--yh);transform:translateY(-2px);box-shadow:0 4px 20px var(--yg)}

/* FOOTER */
.footer{background:#060d16;padding:56px 0 0;border-top:1px solid var(--w1)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:36px;padding-bottom:36px;border-bottom:1px solid var(--w1)}
.footer-col h3{font-size:1.2rem;font-weight:800;color:var(--w);margin-bottom:10px}
.footer-col h4{color:var(--y);font-size:.78rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}
.footer-col p{color:var(--w5);margin-bottom:6px}
.footer-col a{color:var(--w7)}.footer-col a:hover{color:var(--y)}
.social-links{display:flex;gap:10px;margin-bottom:14px}
.social-links a{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--w05);border-radius:50%;color:var(--w5);transition:all .3s}
.social-links a:hover{background:var(--y);color:var(--bp)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:18px 0;font-size:.78rem;color:var(--w2)}
.footer-bottom a{color:var(--y)}

/* BACK TO TOP */
.back-to-top{position:fixed;bottom:28px;right:28px;z-index:900;width:48px;height:48px;background:var(--y);color:var(--bp);border:none;border-radius:50%;font-size:1.4rem;font-weight:700;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,.4);opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .3s,visibility .3s,transform .3s,background .3s;display:flex;align-items:center;justify-content:center}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--yh);transform:translateY(-2px)}


/* Service page hero title row with headshot */
.sp-hero-title-row{display:flex;align-items:center;justify-content:center;gap:24px;margin-bottom:0;flex-wrap:wrap}
.sp-hero-title-row .sp-company{margin-bottom:0}
.sp-headshot-circle{width:100px;height:100px;border-radius:50%;overflow:hidden;border:3px solid var(--y);box-shadow:0 0 0 4px rgba(245,166,35,.15);flex-shrink:0;background:var(--bp3)}
.sp-headshot-circle img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.sp-headshot-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(245,166,35,.1) 0%,rgba(245,166,35,.03) 100%)}
.sp-headshot-placeholder svg{width:42px;height:42px;opacity:.35;color:var(--y)}
@media(max-width:480px){.sp-hero-title-row{gap:16px}.sp-headshot-circle{width:80px;height:80px}}

/* Detail panel headshot */
.detail-headshot{display:flex;justify-content:center;padding:28px 0 16px}
.detail-headshot-circle{width:110px;height:110px;border-radius:50%;overflow:hidden;border:3px solid var(--y);box-shadow:0 0 0 4px rgba(245,166,35,.15);flex-shrink:0;background:var(--bp3)}
.detail-headshot-img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.detail-headshot-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(245,166,35,.1) 0%,rgba(245,166,35,.03) 100%)}
.detail-headshot-placeholder svg{width:48px;height:48px;opacity:.35;color:var(--y)}
.detail-info{padding:4px 0 16px;text-align:center}
.detail-info .detail-label{margin-top:0}
.detail-info .detail-company{text-align:left}
.detail-info .detail-contact{text-align:left}
.detail-info .detail-desc{text-align:left}

/* RESPONSIVE */
@media(max-width:1024px){.partner-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){
  .nav-toggle{display:flex}
  .nav-links{position:fixed;top:126px;left:0;right:0;background:rgba(13,27,42,.98);flex-direction:column;padding:16px 24px;gap:4px;transform:translateY(-100%);opacity:0;visibility:hidden;transition:all .4s;border-bottom:1px solid var(--w1)}
  .nav-links.active{transform:translateY(0);opacity:1;visibility:visible}
  .nav-links a,.nav-links button{display:block;padding:12px 16px;font-size:.95rem;width:100%;text-align:left}
  .hero{padding:90px 20px 48px}
  .hero.hero-compact{padding:85px 20px 36px}
  .hero.hero-tight{padding:80px 20px 20px}
  .hero h1{font-size:2rem}
  .about-hero{padding:90px 24px 50px}
  .about-hero h1{font-size:2rem}
  .sp-hero{padding:90px 24px 48px}
  .sp-company{font-size:1.8rem}
  .sp-grid{grid-template-columns:1fr;gap:32px}
  .sp-grid{padding:0 16px}
  .sp-body{padding:40px 0}
  .house-layout{grid-template-columns:1fr}
  .services-sidebar{border-right:none;border-bottom:1px solid var(--w1)}
  .services-list{flex-direction:row;flex-wrap:wrap;gap:4px}
  .service-btn{width:auto;padding:7px 12px;font-size:.75rem;white-space:nowrap}
  .house-canvas{min-height:auto}
  .house-intro{padding:20px 20px 20px}
  .house-logo{max-width:300px;margin-bottom:14px}
  .house-name-row1,.house-name-partners{font-size:1.75rem;letter-spacing:2.5px}
  .house-name-of,.house-name-bay{font-size:1.05rem}
  .house-intro h2{font-size:.82rem}
  .house-intro .btn{width:85%}
  .house-stat-num{font-size:1.2rem}
  .house-stat-label{font-size:.55rem}
  .values-row{grid-template-columns:1fr;gap:10px}
  .test-grid{grid-template-columns:1fr}
  .partner-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .mission-grid{grid-template-columns:1fr;gap:32px}
  .values-grid{grid-template-columns:1fr;gap:16px}
  .gallery-section,.mission-section,.values-section{padding:52px 0}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-bottom{flex-direction:column;gap:6px;text-align:center}
  .content-section{padding:40px 0}
  .section-title{font-size:1.6rem}
  .detail-panel{width:100%;max-width:100vw;padding:24px}
  .welcome-section{padding:40px 0 32px}
  .welcome-inner h2{font-size:1.4rem}
  .welcome-inner p{font-size:.95rem}
  .welcome-badges{gap:8px}
  .welcome-badge{font-size:.72rem;padding:6px 14px}
}
@media(max-width:480px){
  .container{padding:0 16px}
  .nav-links{top:116px}
  .hero{padding:75px 16px 40px}
  .hero.hero-compact{padding:70px 16px 28px}
  .hero.hero-tight{padding:65px 16px 16px}
  .about-hero{padding:75px 16px 40px}
  .about-hero h1{font-size:1.6rem}
  .about-hero .subtitle{font-size:.95rem}
  .sp-hero{padding:75px 16px 40px}
  .hero h1{font-size:1.7rem;letter-spacing:-.5px}
  .sp-company{font-size:1.4rem}
  .partner-grid{grid-template-columns:1fr 1fr;gap:10px}
  .partner-info{padding:12px 10px}
  .partner-name{font-size:.82rem}
  .partner-company{font-size:.74rem}
  .partner-service{font-size:.62rem}
  .values-card{padding:24px 20px}
  .mission-section,.gallery-section,.values-section{padding:40px 0}
  .house-stats{grid-template-columns:1fr;gap:10px}
  .btn{padding:12px 22px;font-size:.9rem}
  .apply-cta .btn{min-width:100%;max-width:340px}
  .footer{padding:40px 0 0}
  .back-to-top{width:42px;height:42px;font-size:1.2rem;bottom:20px;right:16px}
  .cta-box{padding:40px 16px}
  .cta-box h2{font-size:1.4rem}
  .cta-box p{font-size:.92rem}
  .welcome-section{padding:40px 0 28px}
  .apply-cta{padding:36px 16px}
  .apply-cta h2{font-size:1.3rem}
}
@supports(padding:max(0px)){
  .site-header{padding-top:env(safe-area-inset-top,0px)}
  .footer-bottom{padding-bottom:max(14px,var(--safe-bottom))}
}


