*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img,video{max-width:100%;height:auto;display:block}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
input,textarea,select{font:inherit;color:inherit}

/* ============================================================
   PALETTE — swap these hex values to your exact brand colors
   ============================================================ */
:root{
  --ink:        #000000;   /* BOCA black */
  --ink-2:      #111111;
  --ink-3:      #222222;
  --paper:      #ffffff;
  --paper-2:    #f4f6f8;
  --paper-3:    #e8ecf0;
  --rule:       #dfe4e9;
  --muted:      #6b7280;
  --accent:     #0095e2;   /* BOCA primary blue (from logo) */
  --accent-2:   #007bc1;   /* hover / medium blue */
  --accent-3:   #005da0;   /* deepest blue */
  --accent-hi:  #11b4f4;   /* highlight blue */

  --sans: 'Geist', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono: 'Geist Mono', ui-monospace, 'SF Mono', monospace;

  --max:    1320px;
  --pad:    clamp(20px, 4vw, 56px);
  --radius: 4px;
}

html{background:var(--paper)}
body{
  font-family:var(--sans);font-weight:400;
  font-size:clamp(15px,.6vw + .85rem,17px);
  line-height:1.55;color:var(--ink);background:var(--paper);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
::selection{background:var(--accent);color:var(--paper)}

/* TYPE */
.eyebrow{
  font-family:var(--mono);font-weight:500;font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:'';width:24px;height:1px;background:currentColor}

h1,h2,h3,h4{font-family:var(--sans);font-weight:600;line-height:1;letter-spacing:-.04em}
h1{font-size:clamp(2.8rem,7vw,6.8rem);font-weight:700;letter-spacing:-.05em;line-height:.92}
h2{font-size:clamp(2rem,4.6vw,4rem);font-weight:600;letter-spacing:-.045em;line-height:.96}
h3{font-size:clamp(1.3rem,1.8vw,1.7rem);font-weight:600;letter-spacing:-.025em;line-height:1.15}

p{max-width:62ch}
.lede{
  font-size:clamp(1.05rem,1.1vw + .5rem,1.35rem);
  line-height:1.4;font-weight:400;color:var(--ink-2);
  letter-spacing:-.015em;max-width:48ch;
}
.mono{font-family:var(--mono);font-size:.75rem;letter-spacing:.06em;font-weight:500}

/* LAYOUT */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad);position:relative;z-index:2}
section{position:relative;z-index:2}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  padding:.95em 1.5em;font-family:var(--sans);
  font-size:.92rem;font-weight:500;letter-spacing:-.005em;
  border:1px solid currentColor;border-radius:0;
  transition:all .35s cubic-bezier(.2,.8,.2,1);white-space:nowrap;
}
.btn .arrow{width:1.05em;height:1.05em;transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-primary:hover{background:var(--accent);border-color:var(--accent)}
.btn-accent{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.btn-accent:hover{background:var(--accent-2);border-color:var(--accent-2)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* NAV */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s ease;
}
.nav.scrolled{border-bottom-color:var(--rule)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px}
.brand{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--sans);font-size:1.4rem;font-weight:700;
  letter-spacing:-.04em;line-height:1;
}
.brand .mark{display:inline-block;width:.65em;height:.65em;background:var(--accent)}
.brand .since{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);font-weight:500;margin-left:.5em;
}
.nav-links{display:flex;align-items:center;gap:32px;font-size:.9rem;font-weight:500}
.nav-links a{position:relative;padding:6px 0}
.nav-links a:hover{color:var(--accent)}
.nav-cta{
  display:inline-flex;align-items:center;gap:.55em;
  padding:.7em 1.1em;background:var(--ink);color:var(--paper);
  font-family:var(--mono);font-size:.82rem;font-weight:500;
  letter-spacing:.02em;transition:background .25s ease;
}
.nav-cta:hover{background:var(--accent)}
.nav-cta .dot{width:7px;height:7px;background:#7dd87d;border-radius:999px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.brand-logo{height:32px;width:auto;display:block}
.foot-brand .brand-logo{height:36px;margin-bottom:6px}
@media (max-width:880px){.nav-links{display:none}.brand .since{display:none}.brand-logo{height:28px}}

/* HERO */
.hero{padding:clamp(40px,8vh,90px) 0 clamp(60px,10vh,120px);position:relative}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(var(--rule) 1px,transparent 1px),
    linear-gradient(90deg,var(--rule) 1px,transparent 1px);
  background-size:80px 80px;background-position:-1px -1px;
  opacity:.35;pointer-events:none;
  -webkit-mask-image:linear-gradient(180deg,black 0%,transparent 80%);
  mask-image:linear-gradient(180deg,black 0%,transparent 80%);
}
.hero-grid{
  display:grid;grid-template-columns:1.2fr .9fr;
  gap:clamp(32px,5vw,80px);align-items:end;
}
.hero h1 .line{display:block}
.hero h1 .accent{color:var(--accent)}
.hero h1 .underline{position:relative;display:inline-block;padding-bottom:.05em}
.hero h1 .underline::after{
  content:'';position:absolute;left:0;right:0;bottom:0;
  height:.08em;background:var(--accent);
  transform:scaleX(0);transform-origin:left;
  animation:slash 1.2s .4s cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes slash{to{transform:scaleX(1)}}
.hero-meta{display:flex;flex-direction:column;gap:28px;padding-bottom:14px}
.dual-cta{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}
.dual-cta .btn{justify-content:center;padding:1.05em 1em;font-size:.86rem}
.hero-footer{
  display:flex;align-items:center;gap:18px;
  font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;
  color:var(--muted);margin-top:8px;flex-wrap:wrap;
}
.hero-footer .dot{width:4px;height:4px;background:currentColor;display:inline-block}
.hero-footer strong{color:var(--ink);font-weight:600}
.hero-img-wrap{position:relative;margin-top:clamp(32px,6vw,72px)}
.hero-img{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--paper-3)}
.hero-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.02);transition:transform 8s ease}
.hero-img:hover img{transform:scale(1.06)}
.hero-img::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 60%,rgba(10,10,10,.3) 100%);
}
.hero-tag{
  position:absolute;bottom:20px;left:20px;
  display:inline-flex;align-items:center;gap:14px;
  padding:10px 16px;background:var(--paper);
  font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;
  text-transform:uppercase;color:var(--ink);
}
.hero-tag .num{color:var(--accent);font-weight:600}
.stat-card{
  position:absolute;top:-28px;right:-12px;
  background:var(--ink);color:var(--paper);
  padding:24px 28px;max-width:240px;
  box-shadow:0 30px 80px -30px rgba(10,10,10,.5);
}
.stat-card .big{font-size:3rem;line-height:1;font-weight:700;letter-spacing:-.04em}
.stat-card .big span{color:var(--accent)}
.stat-card .lbl{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(255,255,255,.65);margin-top:8px;
}
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-meta{padding-bottom:0}
  .stat-card{top:auto;bottom:-20px;right:12px;transform:scale(.85);transform-origin:bottom right}
  .dual-cta{grid-template-columns:1fr}
}

/* TICKER */
.ticker{
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  padding:18px 0;overflow:hidden;background:var(--paper);
}
.ticker-track{
  display:flex;align-items:center;gap:48px;white-space:nowrap;
  animation:slide 38s linear infinite;
  font-family:var(--mono);font-size:.85rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink);font-weight:500;
}
.ticker-track > div{display:inline-flex;align-items:center;gap:48px;flex-shrink:0}
.ticker-track .sep{color:var(--accent)}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
.section-head{
  display:grid;grid-template-columns:1fr 1.5fr;
  gap:clamp(32px,5vw,80px);align-items:end;
  margin-bottom:clamp(48px,6vw,80px);
}
.section-head h2{max-width:14ch}
.section-head .right p{max-width:56ch}
@media (max-width:760px){.section-head{grid-template-columns:1fr;align-items:start}}

/* SERVICES */
.services{padding:clamp(80px,10vw,160px) 0}
.svc-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.svc{
  position:relative;display:flex;flex-direction:column;
  background:var(--paper-2);overflow:hidden;
  transition:transform .5s cubic-bezier(.2,.8,.2,1),background .5s ease;
}
.svc:hover{transform:translateY(-4px);background:var(--paper-3)}
.svc-img{aspect-ratio:4/3;overflow:hidden;position:relative;background:var(--ink)}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s ease}
.svc:hover .svc-img img{transform:scale(1.05)}
.svc-num{
  position:absolute;top:16px;left:16px;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;
  background:var(--paper);color:var(--ink);padding:5px 10px;font-weight:500;
}
.svc-body{padding:28px;display:flex;flex-direction:column;gap:14px;flex:1}
.svc h3{margin-bottom:4px}
.svc p{font-size:.94rem;color:var(--ink-2)}
.svc-link{
  margin-top:auto;display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;
  text-transform:uppercase;font-weight:500;
  border-bottom:1px solid var(--ink);padding-bottom:3px;align-self:flex-start;
  transition:color .25s ease,border-color .25s ease,gap .25s ease;
}
.svc-link:hover{color:var(--accent);border-color:var(--accent);gap:.8em}
.svc:nth-child(1){grid-column:span 7}
.svc:nth-child(2){grid-column:span 5}
.svc:nth-child(3){grid-column:span 5}
.svc:nth-child(4){grid-column:span 7}
@media (max-width:860px){.svc-grid{grid-template-columns:1fr}.svc:nth-child(n){grid-column:1}}

/* WHY */
.why{padding:clamp(80px,10vw,140px) 0;background:var(--ink);color:var(--paper)}
.why .eyebrow{color:var(--accent)}
.why h2{color:var(--paper);max-width:18ch}
.why .lede{color:rgba(255,255,255,.7)}
.pillars{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(255,255,255,.1);margin-top:64px;
  border-top:1px solid rgba(255,255,255,.1);
  border-bottom:1px solid rgba(255,255,255,.1);
}
.pillar{
  background:var(--ink);padding:48px 28px 40px;
  display:flex;flex-direction:column;gap:16px;
  transition:background .35s ease;
}
.pillar:hover{background:var(--ink-2)}
.pillar .num{
  font-family:var(--mono);font-size:.82rem;letter-spacing:.14em;
  color:var(--accent);font-weight:500;
}
.pillar h3{color:var(--paper)}
.pillar p{color:rgba(255,255,255,.7);font-size:.95rem}
@media (max-width:760px){.pillars{grid-template-columns:1fr}}

/* BUILDERS */
.builders{padding:clamp(80px,10vw,160px) 0}
.builders-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,80px);align-items:center;
}
.builders-img{aspect-ratio:4/3;overflow:hidden;background:var(--paper-3);position:relative}
.builders-img img{width:100%;height:100%;object-fit:cover}
.builders-content{display:flex;flex-direction:column;gap:24px}
.builders h2{max-width:14ch}
.checks{display:grid;gap:14px;margin:8px 0}
.checks li{
  display:flex;align-items:flex-start;gap:14px;
  font-size:.97rem;list-style:none;padding:14px 0;
  border-bottom:1px solid var(--rule);
}
.checks li:last-child{border-bottom:0}
.checks .ck{
  flex:0 0 auto;width:22px;height:22px;
  background:var(--accent);color:var(--paper);
  display:grid;place-items:center;font-size:.75rem;font-weight:600;margin-top:2px;
}
.checks strong{display:block;font-weight:600;margin-bottom:2px;letter-spacing:-.01em}
.checks span{color:var(--muted);font-size:.88rem}
@media (max-width:860px){
  .builders-grid{grid-template-columns:1fr}
  .builders-img{aspect-ratio:16/10;order:2}
}

/* PROCESS */
.process{padding:clamp(80px,10vw,140px) 0;border-top:1px solid var(--rule)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.step{padding:28px 0 0;border-top:2px solid var(--ink);position:relative}
.step .step-num{
  position:absolute;top:-2px;left:0;background:var(--paper);
  padding-right:14px;transform:translateY(-55%);
  font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--accent);font-weight:500;
}
.step h3{margin-bottom:10px;font-size:1.2rem}
.step p{font-size:.92rem;color:var(--ink-2)}
@media (max-width:860px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.steps{grid-template-columns:1fr}}

/* TESTIMONIALS */
.testimonials{padding:clamp(80px,10vw,160px) 0;background:var(--paper-2)}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.tcard{
  background:var(--paper);padding:32px 28px;
  display:flex;flex-direction:column;gap:18px;
  transition:transform .4s ease;border:1px solid var(--rule);
}
.tcard:hover{transform:translateY(-3px)}
.tcard .stars{color:var(--accent);letter-spacing:.18em;font-size:.9rem}
.tcard blockquote{font-size:1.1rem;line-height:1.45;font-weight:500;letter-spacing:-.02em;color:var(--ink)}
.tcard .by{
  margin-top:auto;display:flex;align-items:center;gap:12px;
  padding-top:14px;border-top:1px solid var(--rule);font-size:.85rem;
}
.tcard .av{
  width:36px;height:36px;background:var(--ink);color:var(--paper);
  display:grid;place-items:center;font-family:var(--mono);font-size:.85rem;font-weight:500;
}
.tcard .name{font-weight:600;letter-spacing:-.01em}
.tcard .meta{
  font-family:var(--mono);color:var(--muted);font-size:.72rem;
  letter-spacing:.04em;margin-top:2px;
}
@media (max-width:860px){.t-grid{grid-template-columns:1fr}}

/* AREA */
.area{padding:clamp(80px,10vw,140px) 0}
.area-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(32px,5vw,80px);align-items:start}
.area h2{max-width:12ch}
.area-list{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--ink);margin-top:32px;
}
.area-list li{
  list-style:none;padding:18px 8px 18px 0;
  border-bottom:1px solid var(--rule);
  font-size:1.15rem;font-weight:500;letter-spacing:-.02em;
  display:flex;align-items:center;justify-content:space-between;
  transition:color .25s ease,padding-left .25s ease;cursor:default;
}
.area-list li:hover{color:var(--accent);padding-left:8px}
.area-list li::after{
  content:'→';font-family:var(--mono);font-size:.9rem;
  opacity:0;transition:opacity .25s ease;
}
.area-list li:hover::after{opacity:1}
@media (max-width:860px){
  .area-grid{grid-template-columns:1fr}
  .area-list{grid-template-columns:1fr 1fr}
}
@media (max-width:540px){.area-list{grid-template-columns:1fr}}

/* QUOTE */
.quote{padding:clamp(80px,10vw,160px) 0;background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.quote::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:80px 80px;
}
.quote-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,100px);align-items:start;position:relative;z-index:1;
}
.quote h2{color:var(--paper);max-width:14ch}
.quote .lede{color:rgba(255,255,255,.7)}
.quote .eyebrow{color:var(--accent)}
.qmeta{display:grid;gap:14px;margin-top:32px;padding-top:32px;border-top:1px solid rgba(255,255,255,.15)}
.qmeta .row{display:flex;align-items:center;gap:16px;font-size:.95rem}
.qmeta .lbl{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.5);min-width:90px;
}
.qmeta a{color:var(--paper);font-weight:500;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:2px}
.qmeta a:hover{border-color:var(--accent);color:var(--accent)}
.qform{background:var(--paper);color:var(--ink);padding:clamp(32px,4vw,48px)}
.qform h3{margin-bottom:8px;font-size:1.5rem}
.qform .sub{
  font-family:var(--mono);color:var(--muted);font-size:.78rem;
  letter-spacing:.04em;margin-bottom:24px;
}
.field{display:block;margin-bottom:16px}
.field label{
  display:block;font-family:var(--mono);font-size:.7rem;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);margin-bottom:6px;font-weight:500;
}
.field input,.field select,.field textarea{
  width:100%;padding:12px 14px;background:var(--paper-2);
  border:1px solid transparent;border-radius:0;font-size:.95rem;
  font-family:var(--sans);
  transition:border-color .2s ease,background .2s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:0;border-color:var(--ink);background:var(--paper);
}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-row .field{margin-bottom:0}
.qform .btn{width:100%;justify-content:center;margin-top:8px;position:relative}
.qform .btn-spinner{
  width:1.05em;height:1.05em;display:none;
  animation:spin .9s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.qform.is-submitting .btn{pointer-events:none;opacity:.85}
.qform.is-submitting .btn-spinner{display:block}
.qform.is-submitting .btn .arrow{display:none}
.qform-error{
  display:none;padding:12px 14px;margin-bottom:8px;
  background:#fef2f2;border:1px solid #fecaca;color:#991b1b;
  font-size:.88rem;line-height:1.4;
}
.qform-error.is-visible{display:block}
.qform-success{
  background:var(--paper);color:var(--ink);
  padding:clamp(40px,5vw,56px) clamp(32px,4vw,48px);
  text-align:center;
  animation:fadeInUp .5s cubic-bezier(.2,.8,.2,1);
}
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.qform-success-icon{
  width:60px;height:60px;border-radius:999px;
  background:var(--accent);color:var(--paper);
  display:grid;place-items:center;
  margin:0 auto 20px;
}
.qform-success-icon svg{width:30px;height:30px}
.qform-success h3{margin-bottom:10px;font-size:1.6rem}
.qform .privacy{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.04em;
  color:var(--muted);margin-top:14px;text-align:center;
}
@media (max-width:860px){.quote-grid{grid-template-columns:1fr}}

/* FOOTER */
footer{background:var(--paper);padding:clamp(60px,8vw,100px) 0 32px;border-top:1px solid var(--rule)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.foot h4{
  font-family:var(--mono);font-size:.7rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink);margin-bottom:18px;
}
.foot ul{list-style:none;display:grid;gap:10px}
.foot a{font-size:.92rem;color:var(--ink-2)}
.foot a:hover{color:var(--accent)}
.foot-brand p{font-size:.92rem;color:var(--ink-2);max-width:36ch;margin-top:14px}
.foot-bottom{
  border-top:1px solid var(--rule);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;
  color:var(--muted);flex-wrap:wrap;
}
@media (max-width:860px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:540px){.foot-grid{grid-template-columns:1fr}}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
