:root {
  --ink: #0C1420;
  --ink-soft: #141E2C;
  --paper: #F4F7FA;
  --paper-dim: #E5ECF2;
  --steel: #6B7787;
  --steel-dark: #3A4654;
  --signal: #00B4F0;
  --brand-cyan: #00B4F0;
  --brand-blue: #186CB4;
  --brand-blue-dark: #0E4A7D;
  --signal-dim: #186CB4;
  --teal: #186CB4;
  --teal-light: #15C2FF;
  --line-dark: rgba(244,247,250,0.12);
  --line-light: rgba(12,20,32,0.10);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Inter',sans-serif;
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
}
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }

.wrap { max-width:1180px; margin:0 auto; padding:0 32px; }
.mono { font-family:'JetBrains Mono',monospace; letter-spacing:0.02em; }
.eyebrow {
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  display:flex;
  align-items:center;
  gap:8px;
}
.eyebrow .dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--signal);
  box-shadow:0 0 0 0 rgba(0,180,240,0.6);
  animation:pulse 2.2s infinite;
}
@keyframes pulse {
  0% { box-shadow:0 0 0 0 rgba(0,180,240,0.55); }
  70% { box-shadow:0 0 0 7px rgba(0,180,240,0); }
  100% { box-shadow:0 0 0 0 rgba(0,180,240,0); }
}

h1,h2,h3,h4 { font-family:'Archivo',sans-serif; letter-spacing:-0.01em; }

/* ---------- HEADER ---------- */
header {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:transparent;
  transition:background .3s, backdrop-filter .3s, box-shadow .3s;
}
header.scrolled {
  background:rgba(12,20,32,0.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-dark);
  box-shadow:0 1px 0 var(--line-dark), 0 10px 30px rgba(0,0,0,0.28);
}
.nav {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 32px;
  max-width:1180px; margin:0 auto;
  color:var(--paper);
}
.logo {
  font-family:'Archivo',sans-serif; font-weight:900; font-size:19px;
  color:var(--paper); display:flex; align-items:center; gap:10px;
}
.logo .mark {
  width:11px; height:11px; background:var(--signal); border-radius:50%;
  flex-shrink:0;
}
.logo img { height:40px; width:auto; display:block; }
.navlinks { display:flex; gap:34px; font-size:14px; font-weight:500; }
.navlinks a { opacity:0.78; transition:opacity .15s; }
.navlinks a:hover { opacity:1; }
.nav-cta {
  display:flex; align-items:center; gap:20px;
}
.btn {
  font-family:'JetBrains Mono',monospace;
  font-size:13px; font-weight:500; letter-spacing:0.02em;
  padding:11px 20px;
  border-radius:2px;
  display:inline-flex; align-items:center; gap:8px;
  transition:transform .15s, background .15s, color .15s;
}
.btn-solid { background:var(--signal); color:#04121E; }
.btn-solid:hover { background:#15C2FF; transform:translateY(-1px); }
.btn-ghost { border:1px solid rgba(244,247,250,0.3); color:var(--paper); }
.btn-ghost:hover { border-color:var(--paper); }
.phone-link { color:var(--paper); font-size:13px; font-family:'JetBrains Mono',monospace; opacity:0.85; }

/* ---------- HERO (legacy home-style, kept for any inner use) ---------- */
.hero {
  background:var(--ink);
  color:var(--paper);
  padding:120px 0 0;
  position:relative;
  overflow:hidden;
  min-height:640px;
}
.hero-bg { position:absolute; inset:0; z-index:0; }
.hero-poster { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0.42; }
.hero-scrim {
  position:absolute; inset:0;
  background:linear-gradient(105deg, rgba(12,20,32,0.94) 0%, rgba(12,20,32,0.82) 45%, rgba(12,20,32,0.55) 100%);
}

.marquee-track {
  background:var(--ink-soft);
  border-top:1px solid var(--line-dark);
  padding:28px 0;
  overflow:hidden;
}
.marquee-label {
  font-family:'JetBrains Mono',monospace; font-size:11.5px; letter-spacing:0.08em;
  color:var(--steel); text-transform:uppercase; text-align:center; margin-bottom:18px;
}
.marquee-row { display:flex; gap:64px; align-items:center; justify-content:center; flex-wrap:wrap; opacity:0.55; }
.marquee-row span { font-family:'Archivo',sans-serif; font-weight:700; font-size:15px; color:var(--paper); }

/* ---------- SECTIONS (light) ---------- */
section { padding:96px 0; }
.section-head { margin-bottom:52px; max-width:620px; }
.section-head .eyebrow { color:var(--signal-dim); margin-bottom:14px; }
.section-head h2 { font-size:38px; font-weight:900; line-height:1.08; }
.section-head p { margin-top:14px; font-size:16px; color:var(--steel-dark); line-height:1.6; }

/* Services */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-light); border:1px solid var(--line-light); }
.service-card { background:var(--paper); padding:36px 30px; transition:background .2s; }
.service-card:hover { background:#fff; }
.service-card .num { font-family:'JetBrains Mono',monospace; font-size:12px; color:var(--signal-dim); margin-bottom:18px; display:block; }
.service-card h3 { font-size:21px; font-weight:700; margin-bottom:10px; }
.service-card p { font-size:14.5px; color:var(--steel-dark); line-height:1.6; margin-bottom:18px; }
.service-card .link { font-family:'JetBrains Mono',monospace; font-size:12.5px; color:var(--ink); display:inline-flex; align-items:center; gap:6px; border-bottom:1px solid var(--ink); padding-bottom:2px; }

/* Visual "Other services you might need" cards (use each service's hero image) */
.related-services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.svc-card { position:relative; display:block; aspect-ratio:16/9; border-radius:4px; overflow:hidden; color:var(--paper); background:var(--ink); }
.svc-card img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0.92; transition:transform .4s cubic-bezier(.16,1,.3,1); }
.svc-card::after { content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(8,14,22,0.9) 0%, rgba(8,14,22,0.4) 55%, rgba(8,14,22,0.15) 100%); }
.svc-card:hover img { transform:scale(1.05); }
.svc-card-label { position:absolute; left:0; right:0; bottom:0; z-index:1; padding:18px 20px; font-family:'Archivo',sans-serif; font-weight:700; font-size:18px; line-height:1.2; }
.svc-card-label span { color:var(--signal); }
@media (max-width:720px){ .related-services-grid { grid-template-columns:1fr; } }

/* Work / portfolio */
.work-section { background:var(--ink); color:var(--paper); }
.work-section .section-head p { color:var(--steel); }
.work-section .section-head .eyebrow { color:var(--signal); }
.work-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.work-card {
  position:relative; aspect-ratio:4/5; border-radius:3px; overflow:hidden;
  background:linear-gradient(160deg,#2a2e33,#15171a 75%);
}
.work-card img { width:100%; height:100%; object-fit:cover; opacity:0.85; transition:opacity .2s, transform .3s; }
.work-card:hover img { opacity:1; transform:scale(1.04); }
.work-meta {
  position:absolute; bottom:0; left:0; right:0; padding:18px;
  background:linear-gradient(to top, rgba(21,23,26,0.92), transparent);
}
.work-meta .client { font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--signal); text-transform:uppercase; letter-spacing:0.06em; }
.work-meta .title { font-family:'Archivo',sans-serif; font-weight:700; font-size:16.5px; margin-top:4px; }

/* Process */
.process-row { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line-light); margin-top:8px; }
.process-step { padding:34px 30px 0; border-left:1px solid var(--line-light); }
.process-step:first-child { border-left:none; }
.process-step .mono.tag { font-size:12px; color:var(--signal-dim); }
.process-step h3 { font-size:19px; font-weight:700; margin:14px 0 10px; }
.process-step p { font-size:14.5px; color:var(--steel-dark); line-height:1.6; }

/* Testimonial */
.testimonial {
  background:var(--paper-dim);
  border-radius:4px;
  padding:56px 64px;
  display:grid; grid-template-columns:auto 1fr; gap:36px; align-items:center;
}
.testimonial .quote-mark { font-family:'Archivo',sans-serif; font-size:64px; font-weight:900; color:var(--signal); line-height:1; }
.testimonial blockquote { font-family:'Archivo',sans-serif; font-size:24px; font-weight:500; line-height:1.35; margin-bottom:18px; }
.testimonial cite { font-family:'JetBrains Mono',monospace; font-size:13px; color:var(--steel-dark); font-style:normal; }

/* CTA band */
.cta-band {
  background:var(--teal);
  color:var(--paper);
  padding:80px 0;
  text-align:center;
}
.cta-band .eyebrow { justify-content:center; color:var(--paper); opacity:0.7; margin-bottom:18px; }
.cta-band h2 { font-size:40px; font-weight:900; margin-bottom:26px; }
.cta-band .btn-solid { background:var(--signal); color:var(--ink); padding:15px 30px; font-size:14px; }
.cta-band-actions { display:flex; gap:16px; justify-content:center; }
.cta-band .btn-ghost { border-color:rgba(244,247,250,0.35); color:var(--paper); padding:15px 26px; }

/* Footer */
footer { background:var(--ink); color:var(--steel); padding:64px 0 32px; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid var(--line-dark); }
footer .logo { color:var(--paper); margin-bottom:14px; }
.footer-brand .desc { font-size:14px; line-height:1.6; max-width:260px; }
footer h4 { font-family:'JetBrains Mono',monospace; font-size:12px; letter-spacing:0.06em; text-transform:uppercase; color:var(--paper); margin-bottom:16px; }
footer ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
footer ul a { font-size:14px; color:var(--steel); transition:color .15s; }
footer ul a:hover { color:var(--paper); }
.footer-bottom { display:flex; justify-content:space-between; padding-top:24px; font-size:12.5px; font-family:'JetBrains Mono',monospace; color:var(--steel-dark); }

@media (max-width:900px){
  .services-grid, .work-grid, .process-row, .footer-grid { grid-template-columns:1fr; }
  .testimonial { grid-template-columns:1fr; padding:40px 28px; }
}

/* ---------- INNER PAGE HEADER (sub-hero) ---------- */
.page-header {
  background:var(--ink);
  color:var(--paper);
  padding:160px 0 72px;
  position:relative;
  overflow:hidden;
}
.page-header .hero-scrim { position:absolute; inset:0; background:linear-gradient(105deg, rgba(12,20,32,0.94) 0%, rgba(12,20,32,0.74) 55%, rgba(12,20,32,0.62) 100%); z-index:1; }
.page-header .hero-poster { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0.5; z-index:0; }
.page-header-inner { position:relative; z-index:2; max-width:680px; }
.page-header .eyebrow { color:var(--signal); margin-bottom:20px; }
.page-header h1 { font-size:46px; font-weight:900; line-height:1.06; margin-bottom:18px; }
.page-header p { font-size:16.5px; color:rgba(244,247,250,0.72); line-height:1.6; }
.breadcrumb { font-family:'JetBrains Mono',monospace; font-size:12px; color:var(--steel); margin-bottom:24px; display:flex; gap:8px; align-items:center; }
.breadcrumb a { color:var(--steel); }
.breadcrumb a:hover { color:var(--paper); }

/* ---------- TRUST GRID ---------- */
.trust-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-light); border:1px solid var(--line-light); }
.trust-card { background:var(--paper); padding:32px 28px; }
.trust-card .ic { width:34px; height:34px; border-radius:2px; background:var(--paper-dim); display:flex; align-items:center; justify-content:center; margin-bottom:18px; color:var(--brand-blue); font-family:'JetBrains Mono',monospace; font-size:13px; font-weight:500; }
.trust-card h3 { font-size:17px; font-weight:700; margin-bottom:8px; }
.trust-card p { font-size:14px; color:var(--steel-dark); line-height:1.6; }

/* ---------- STAT STRIP ---------- */
.stat-strip { background:var(--brand-blue-dark); color:var(--paper); padding:56px 0; }

/* When wrapped in .hero-block, the header + strip share one hero image so the
   strip reads as the bottom of the hero. The block holds the photo + scrim;
   the header and strip go transparent and sit on top. */
.hero-block { position:relative; background:var(--ink); overflow:hidden; }
.hero-block .hero-poster { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0.5; z-index:0; }
.hero-block .hero-scrim { position:absolute; inset:0; background:linear-gradient(160deg, rgba(12,20,32,0.92) 0%, rgba(12,20,32,0.7) 60%, rgba(12,20,32,0.82) 100%); z-index:1; }
.hero-block .page-header { background:none; overflow:visible; padding-bottom:40px; }
.hero-block .stat-strip { background:none; position:relative; z-index:2; padding:8px 0 60px; }
.hero-block .stat-grid .stat { border-color:rgba(244,247,250,0.18); }
.stat-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; text-align:center; }
.stat-grid .stat { border-left:1px solid var(--line-dark); padding:0 20px; }
.stat-grid .stat:first-child { border-left:none; }
.stat-grid .num { font-family:'Archivo',sans-serif; font-weight:900; font-size:40px; display:block; }
.stat-grid .label { font-family:'JetBrains Mono',monospace; font-size:11.5px; letter-spacing:0.06em; text-transform:uppercase; color:rgba(244,247,250,0.65); margin-top:8px; display:block; }

/* ---------- FAQ ACCORDION ---------- */
.faq-list { border-top:1px solid var(--line-light); }
.faq-item { border-bottom:1px solid var(--line-light); }
.faq-q {
  width:100%; text-align:left; background:none; border:none; cursor:pointer;
  padding:24px 4px; display:flex; justify-content:space-between; align-items:center;
  font-family:'Archivo',sans-serif; font-size:17px; font-weight:700; color:var(--ink);
}
.faq-q .plus { font-family:'JetBrains Mono',monospace; font-size:18px; color:var(--brand-cyan); transition:transform .2s; flex-shrink:0; margin-left:16px; }
.faq-item.open .faq-q .plus { transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .25s ease; }
.faq-a-inner { padding:0 4px 24px; font-size:15px; color:var(--steel-dark); line-height:1.65; max-width:760px; }
.faq-a-inner a { color:var(--brand-blue); border-bottom:1px solid rgba(24,108,180,0.3); }

/* ---------- SERVICE DETAIL BLOCK ---------- */
.service-detail { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; padding:72px 0; border-top:1px solid var(--line-light); }
.service-detail:first-of-type { border-top:none; }
.service-detail.reverse .sd-media { order:2; }
.sd-media { aspect-ratio:16/9; border-radius:3px; overflow:hidden; background:linear-gradient(160deg,#1a2433,#0C1420 75%); position:relative; }
.sd-media img { width:100%; height:100%; object-fit:cover; opacity:0.9; }
.sd-tag { font-family:'JetBrains Mono',monospace; font-size:12px; color:var(--brand-blue); margin-bottom:14px; display:block; text-transform:uppercase; letter-spacing:0.06em; }
.service-detail h3 { font-size:28px; font-weight:900; margin-bottom:14px; }
.service-detail p { font-size:15.5px; color:var(--steel-dark); line-height:1.7; margin-bottom:20px; }
.sd-list { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.sd-list li { font-size:14.5px; color:var(--steel-dark); display:flex; gap:10px; align-items:baseline; }
.sd-list li::before { content:'—'; color:var(--brand-cyan); font-weight:700; flex-shrink:0; }

/* ---------- PORTFOLIO FILTER + GRID ---------- */
.filter-row { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:48px; }
.filter-pill {
  font-family:'JetBrains Mono',monospace; font-size:12.5px; padding:9px 16px;
  border:1px solid var(--line-light); border-radius:2px; color:var(--steel-dark);
  background:none; cursor:pointer; transition:all .15s;
}
.filter-pill.active { background:var(--ink); color:var(--paper); border-color:var(--ink); }
.filter-pill:hover:not(.active) { border-color:var(--brand-blue); color:var(--brand-blue); }
.portfolio-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.portfolio-card { cursor:pointer; }
.portfolio-thumb {
  position:relative; aspect-ratio:16/9; border-radius:3px; overflow:hidden;
  background:linear-gradient(160deg,#1a2433,#0C1420 75%); margin-bottom:14px;
}
.portfolio-thumb img { width:100%; height:100%; object-fit:cover; opacity:0.92; transition:opacity .2s, transform .3s; }
.portfolio-card:hover .portfolio-thumb img { opacity:1; transform:scale(1.04); }
.portfolio-thumb .play {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:44px; height:44px; border-radius:50%; background:rgba(12,20,32,0.55);
  border:1.5px solid rgba(244,247,250,0.5);
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, transform .2s;
}
.portfolio-card:hover .portfolio-thumb .play { background:var(--brand-cyan); border-color:var(--brand-cyan); transform:translate(-50%,-50%) scale(1.08); }
.portfolio-thumb .play::after { content:''; width:0; height:0; border-style:solid; border-width:7px 0 7px 11px; border-color:transparent transparent transparent var(--paper); margin-left:2px; }
.portfolio-thumb .cat-badge {
  position:absolute; top:12px; left:12px; font-family:'JetBrains Mono',monospace; font-size:10.5px;
  background:rgba(12,20,32,0.7); color:var(--paper); padding:4px 8px; border-radius:2px; text-transform:uppercase; letter-spacing:0.04em;
}
.portfolio-card h4 { font-size:16px; font-weight:700; margin-bottom:6px; line-height:1.3; }
.portfolio-card p { font-size:13.5px; color:var(--steel-dark); line-height:1.5; }
.pagination { display:flex; justify-content:center; flex-wrap:wrap; gap:8px; margin-top:56px; }
.pagination a, .pagination span, .pagination button {
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  font-family:'JetBrains Mono',monospace; font-size:13px; border:1px solid var(--line-light); border-radius:2px; color:var(--steel-dark);
  background:transparent; padding:0; cursor:pointer; transition:border-color 0.15s, color 0.15s;
}
.pagination button:hover:not(:disabled):not(.current) { border-color:var(--ink); color:var(--ink); }
.pagination button:disabled { opacity:0.35; cursor:default; }
.pagination .current { background:var(--ink); color:var(--paper); border-color:var(--ink); }

/* ---------- TEAM CARDS ---------- */
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.team-card { text-align:left; }
.team-photo { aspect-ratio:1/1; border-radius:3px; overflow:hidden; margin-bottom:16px; background:linear-gradient(160deg,#1a2433,#0C1420 75%); }
.team-photo img { width:100%; height:100%; object-fit:cover; }
.team-card h3 { font-size:18px; font-weight:700; }
.team-card .role { font-family:'JetBrains Mono',monospace; font-size:12px; color:var(--brand-blue); text-transform:uppercase; letter-spacing:0.04em; margin-top:4px; }

/* ---------- CONTACT LAYOUT ---------- */
.contact-grid { display:grid; grid-template-columns:0.9fr 1.1fr; gap:64px; }
.contact-info-card { background:var(--paper-dim); border-radius:3px; padding:36px 32px; }
.contact-info-card .row { display:flex; gap:14px; align-items:flex-start; padding:16px 0; border-bottom:1px solid var(--line-light); }
.contact-info-card .row:last-child { border-bottom:none; }
.contact-info-card .row .ico { width:32px; height:32px; flex-shrink:0; border-radius:2px; background:var(--ink); color:var(--brand-cyan); display:flex; align-items:center; justify-content:center; font-family:'JetBrains Mono',monospace; font-size:13px; }
.contact-info-card .row strong { display:block; font-size:14px; font-weight:700; margin-bottom:3px; }
.contact-info-card .row span, .contact-info-card .row a { font-size:14px; color:var(--steel-dark); }
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-family:'JetBrains Mono',monospace; font-size:12px; text-transform:uppercase; letter-spacing:0.05em; color:var(--steel-dark); margin-bottom:8px; }
.form-group input, .form-group textarea {
  width:100%; padding:13px 14px; border:1px solid var(--line-light); border-radius:2px;
  font-family:'Inter',sans-serif; font-size:14.5px; background:#fff; color:var(--ink);
}
.form-group input:focus, .form-group textarea:focus { outline:2px solid var(--brand-cyan); outline-offset:1px; border-color:var(--brand-cyan); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.map-embed { border-radius:3px; overflow:hidden; aspect-ratio:16/6; border:1px solid var(--line-light); }
.map-embed iframe { width:100%; height:100%; border:0; }

@media (max-width:900px){
  .trust-grid, .stat-grid, .service-detail, .portfolio-grid, .team-grid, .contact-grid, .form-row { grid-template-columns:1fr; }
  .service-detail.reverse .sd-media { order:0; }
  .stat-grid .stat { border-left:none; border-top:1px solid var(--line-dark); padding:20px 0 0; }
  .stat-grid .stat:first-child { border-top:none; }
  .page-header h1 { font-size:32px; }
}

/* ---------- SCROLL ANIMATIONS ---------- */
.anim-on .section-head,
.anim-on .trust-card,
.anim-on .service-card,
.anim-on .work-card,
.anim-on .service-detail,
.anim-on .portfolio-card,
.anim-on .faq-item,
.anim-on .team-card,
.anim-on .testimonial,
.anim-on .contact-info-card,
.anim-on .map-embed,
.anim-on .blog-card {
  opacity:0; transform:translateY(26px);
  transition:opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1);
}
.anim-on .anim-in { opacity:1 !important; transform:none !important; }

/* ---------- BLOG ---------- */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.blog-card {
  display:flex; flex-direction:column; background:var(--paper); border-radius:4px;
  overflow:hidden; color:var(--ink); border:1px solid var(--line-light);
  transition:transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s;
}
.blog-card:hover { transform:translateY(-4px); box-shadow:0 18px 40px -24px rgba(12,20,32,0.5); }
.blog-card-media { aspect-ratio:16/9; background:linear-gradient(160deg,#2a2e33,#15171a 75%); overflow:hidden; }
.blog-card-media img { width:100%; height:100%; object-fit:cover; transition:transform .35s; }
.blog-card:hover .blog-card-media img { transform:scale(1.04); }
.blog-card-body { padding:26px 26px 30px; display:flex; flex-direction:column; flex:1; }
.blog-card-date { font-family:'JetBrains Mono',monospace; font-size:11.5px; letter-spacing:0.06em; text-transform:uppercase; color:var(--signal-dim); margin-bottom:12px; }
.blog-card-body h2, .blog-card-body h3 { font-size:20px; font-weight:700; line-height:1.22; margin-bottom:12px; }
.blog-card-body p { font-size:14px; color:var(--steel-dark); line-height:1.6; margin-bottom:18px;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.blog-card-more { margin-top:auto; font-family:'JetBrains Mono',monospace; font-size:12.5px; color:var(--ink); border-bottom:1px solid var(--ink); padding-bottom:2px; align-self:flex-start; }

/* "Related reading" grid on inner pages — adapts from 3-up to 2-up by card count */
.related-posts-grid { grid-template-columns:repeat(auto-fit, minmax(290px, 1fr)); }

/* Post article body */
.post-body { max-width:760px; margin:0 auto; }
.post-body h2 { font-size:30px; font-weight:900; line-height:1.12; margin:44px 0 16px; }
.post-body h3 { font-size:23px; font-weight:700; line-height:1.2; margin:38px 0 14px; }
.post-body h4 { font-size:18px; font-weight:700; margin:28px 0 12px; }
.post-body p { font-size:17px; color:var(--steel-dark); line-height:1.75; margin-bottom:20px; }
.post-body ul, .post-body ol { margin:0 0 22px 22px; }
.post-body li { font-size:17px; color:var(--steel-dark); line-height:1.7; margin-bottom:10px; }
.post-body a { color:var(--brand-blue); border-bottom:1px solid rgba(24,108,180,0.35); }
.post-body a:hover { border-bottom-color:var(--brand-blue); }
.post-body strong { color:var(--ink); }
.post-body img { max-width:100%; height:auto; border-radius:4px; margin:28px 0; display:block; }
.post-body figure { margin:28px 0; }
.post-body figcaption { font-size:13px; color:var(--steel); margin-top:8px; text-align:center; }
.post-body blockquote { border-left:3px solid var(--signal); padding:6px 0 6px 24px; margin:28px 0; font-size:20px; font-weight:500; font-family:'Archivo',sans-serif; color:var(--ink); }
.post-body :first-child { margin-top:0; }
.post-foot { max-width:760px; margin:48px auto 0; padding-top:32px; border-top:1px solid var(--line-light); display:flex; gap:16px; justify-content:space-between; flex-wrap:wrap; }
.post-foot .btn-ghost { border-color:var(--line-light); color:var(--ink); }
.post-foot .btn-ghost:hover { border-color:var(--ink); }

@media (max-width:900px){
  .blog-grid { grid-template-columns:1fr; }
  .post-body h2 { font-size:25px; }
  .post-body p, .post-body li { font-size:16px; }
}
@media (prefers-reduced-motion: reduce){
  .anim-on .section-head,.anim-on .trust-card,.anim-on .service-card,.anim-on .work-card,.anim-on .service-detail,.anim-on .portfolio-card,.anim-on .faq-item,.anim-on .team-card,.anim-on .testimonial,.anim-on .contact-info-card,.anim-on .map-embed{opacity:1 !important;transform:none !important;transition:none !important;}
}

/* Footer logo at 2x */
.footer-brand .logo img { height:60px; }

/* ---------- NAV SUBMENU ---------- */
.navitem { position:relative; display:inline-flex; align-items:center; }
.navitem.has-submenu > a::after {
  content:""; display:inline-block; margin-left:7px; vertical-align:middle;
  width:0; height:0;
  border-left:4px solid transparent; border-right:4px solid transparent;
  border-top:5px solid currentColor; opacity:0.55;
  transition:transform .2s ease, opacity .2s ease;
}
.navitem.has-submenu:hover > a::after,
.navitem.has-submenu:focus-within > a::after {
  transform:rotate(180deg); opacity:0.9;
}
.submenu {
  position:absolute; top:calc(100% + 12px); left:50%;
  transform:translateX(-50%) translateY(8px);
  min-width:230px; background:var(--ink-soft);
  border:1px solid var(--line-dark); border-radius:7px; padding:8px;
  box-shadow:0 26px 54px -22px rgba(0,0,0,0.65);
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .18s ease, transform .18s ease; z-index:300;
}
.submenu::before { content:""; position:absolute; bottom:100%; left:0; right:0; height:16px; }
.navitem:hover .submenu, .navitem:focus-within .submenu {
  opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0);
}
.submenu a {
  display:block; padding:10px 14px; border-radius:5px;
  font-size:13.5px; color:rgba(244,247,250,0.82); white-space:nowrap; opacity:1;
}
.submenu a:hover { background:rgba(244,247,250,0.08); color:var(--paper); }

.footer-legal a { color:var(--steel); transition:color .15s; }
.footer-legal a:hover { color:var(--paper); }

/* ---------- MOBILE NAV ---------- */
.nav-menu { display:contents; }
.nav-toggle {
  display:none; width:42px; height:42px; padding:0; border:none; background:transparent;
  cursor:pointer; flex-direction:column; justify-content:center; align-items:center; gap:5px;
}
.nav-toggle span { display:block; width:24px; height:2px; background:var(--paper); border-radius:2px; transition:transform .25s ease, opacity .2s ease; }
#site-header.menu-open .nav-toggle span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
#site-header.menu-open .nav-toggle span:nth-child(2) { opacity:0; }
#site-header.menu-open .nav-toggle span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

@media (max-width:900px){
  .nav-toggle { display:flex; }
  .nav-menu {
    display:block; position:absolute; top:100%; left:0; right:0;
    background:var(--ink-soft); border-bottom:1px solid var(--line-dark);
    box-shadow:0 24px 40px rgba(0,0,0,0.4);
    max-height:0; overflow:hidden; transition:max-height .32s ease;
  }
  #site-header.menu-open .nav-menu { max-height:calc(100vh - 70px); overflow-y:auto; }
  .nav-menu .navlinks { display:flex; flex-direction:column; gap:0; font-size:16px; padding:6px 0; }
  .navitem { display:block; }
  .navlinks > a,
  .navitem.has-submenu > a {
    display:block; padding:15px 24px; opacity:1; color:var(--paper);
    border-bottom:1px solid rgba(244,247,250,0.06);
  }
  .navitem.has-submenu > a::after { display:none; }
  .submenu {
    position:static; transform:none; opacity:1; visibility:visible; pointer-events:auto;
    background:rgba(0,0,0,0.18); border:none; border-radius:0; box-shadow:none; padding:0; min-width:0;
  }
  .submenu::before { display:none; }
  .submenu a { padding:13px 24px 13px 42px; font-size:14.5px; border-bottom:1px solid rgba(244,247,250,0.06); }
  .nav-cta { display:flex; flex-direction:column; align-items:stretch; gap:12px; padding:18px 24px 24px; }
  .nav-cta .phone-link { text-align:center; padding:8px; font-size:15px; opacity:0.9; }
  .nav-cta .btn-solid { justify-content:center; padding:14px; font-size:14px; }
}

/* ---------- VIDEO LIGHTBOX ---------- */
.video-modal {
  position:fixed; inset:0; z-index:1000; display:none;
  align-items:center; justify-content:center; padding:24px;
  background:rgba(6,12,20,0.9); backdrop-filter:blur(8px);
}
.video-modal.open { display:flex; animation:vmFade .22s ease; }
@keyframes vmFade { from { opacity:0; } to { opacity:1; } }
.video-modal-frame {
  width:min(1120px,100%); aspect-ratio:16/9; border-radius:8px; overflow:hidden;
  background:#000; box-shadow:0 40px 90px rgba(0,0,0,0.6);
  animation:vmRise .28s cubic-bezier(.16,1,.3,1);
}
@keyframes vmRise { from { opacity:0; transform:translateY(18px) scale(.98); } to { opacity:1; transform:none; } }
.video-modal-frame iframe { width:100%; height:100%; border:0; display:block; }
.video-modal-close {
  position:absolute; top:20px; right:24px; width:46px; height:46px; border:none;
  background:rgba(244,247,250,0.12); color:var(--paper); font-size:30px; line-height:44px;
  border-radius:50%; cursor:pointer; transition:background .15s, transform .15s;
}
.video-modal-close:hover { background:rgba(244,247,250,0.24); transform:rotate(90deg); }

/* ---------- VIDEO SHOWCASE (dark project section) ---------- */
.video-showcase { background:var(--ink); color:var(--paper); position:relative; }
.video-showcase .section-head h2 { color:var(--paper); }
.video-showcase .section-head p { color:rgba(244,247,250,0.6); }
.video-showcase .section-head .eyebrow { color:var(--brand-cyan); }
.video-showcase .portfolio-card { outline:none; }
.video-showcase .portfolio-card h4 { color:var(--paper); }
.video-showcase .portfolio-card p { color:rgba(244,247,250,0.58); }
.video-showcase .portfolio-thumb { box-shadow:0 16px 40px -24px rgba(0,0,0,0.8); }
.video-showcase .portfolio-thumb::after {
  content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(12,20,32,0.5), transparent 55%);
  opacity:0; transition:opacity .3s; pointer-events:none;
}
.video-showcase .portfolio-card:hover .portfolio-thumb::after { opacity:1; }
/* Bigger, glowing play affordance in the showcase */
.video-showcase .portfolio-thumb .play {
  width:66px; height:66px; background:rgba(12,20,32,0.55);
  border:2px solid rgba(244,247,250,0.85); backdrop-filter:blur(2px);
  box-shadow:0 0 0 0 rgba(0,180,240,0.5);
}
.video-showcase .portfolio-card:hover .portfolio-thumb .play {
  background:var(--brand-cyan); border-color:var(--brand-cyan);
  box-shadow:0 0 0 10px rgba(0,180,240,0.15);
}
.video-showcase .portfolio-card:focus-visible .portfolio-thumb { outline:2px solid var(--brand-cyan); outline-offset:3px; }

/* ---------- SERVICE-DETAIL VIDEO PLAY OVERLAY ---------- */
.sd-media img { transition:opacity .2s, transform .3s; }
.sd-media[data-youtube] { cursor:pointer; }
.sd-media[data-youtube]:hover img { opacity:1; transform:scale(1.04); }
.sd-media .play {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:60px; height:60px; border-radius:50%;
  background:rgba(12,20,32,0.55); border:2px solid rgba(244,247,250,0.9);
  backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s, transform .2s, box-shadow .2s;
}
.sd-media[data-youtube]:hover .play { background:var(--brand-cyan); border-color:var(--brand-cyan); transform:translate(-50%,-50%) scale(1.08); box-shadow:0 0 0 10px rgba(0,180,240,0.14); }
.sd-media .play::after { content:''; width:0; height:0; border-style:solid; border-width:8px 0 8px 13px; border-color:transparent transparent transparent var(--paper); margin-left:3px; }
.sd-media[data-youtube]:focus-visible { outline:2px solid var(--brand-cyan); outline-offset:3px; }

/* ---------- READ MORE (collapsible SEO copy) ---------- */
.readmore-content { position:relative; max-height:208px; overflow:hidden; transition:max-height .45s ease; }
.readmore-content::after {
  content:''; position:absolute; left:0; right:0; bottom:0; height:96px;
  background:linear-gradient(to bottom, rgba(229,236,242,0), var(--paper-dim));
  pointer-events:none; transition:opacity .3s;
}
.readmore.open .readmore-content { max-height:4000px; }
.readmore.open .readmore-content::after { opacity:0; }
.readmore-toggle {
  margin-top:20px; font-family:'JetBrains Mono',monospace; font-size:12.5px; letter-spacing:0.04em;
  color:var(--brand-blue); background:none; border:1px solid var(--line-light);
  padding:10px 18px; border-radius:2px; cursor:pointer; transition:border-color .15s, color .15s;
}
.readmore-toggle:hover { border-color:var(--brand-blue); }
.readmore-toggle::after { content:' ↓'; }
.readmore.open .readmore-toggle::after { content:' ↑'; }

/* ---------- GEAR & RATES ---------- */
/* Featured-kit strip: small image + label cards */
.kit-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-light); border:1px solid var(--line-light); }
.kit-card { background:var(--paper); padding:30px 28px; }
.kit-card .kit-ic { width:38px; height:38px; border-radius:2px; background:var(--paper-dim); display:flex; align-items:center; justify-content:center; margin-bottom:18px; color:var(--brand-blue); }
.kit-card .kit-ic svg { width:20px; height:20px; }
.kit-card h3 { font-size:17px; font-weight:700; margin-bottom:8px; }
.kit-card p { font-size:14px; color:var(--steel-dark); line-height:1.6; }
.kit-card .kit-model { display:block; font-family:'JetBrains Mono',monospace; font-size:11.5px; letter-spacing:0.03em; color:var(--brand-blue); margin-top:10px; }

/* Rates: jump bar */
.rate-jump { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:48px; }
.rate-jump a {
  font-family:'JetBrains Mono',monospace; font-size:12.5px; padding:9px 16px;
  border:1px solid var(--line-light); border-radius:2px; color:var(--steel-dark); transition:all .15s;
}
.rate-jump a:hover { border-color:var(--brand-blue); color:var(--brand-blue); }

/* Rates: blocks + tables */
.rate-block { margin-top:56px; scroll-margin-top:96px; }
.rate-block:first-of-type { margin-top:0; }
.rate-block-head { display:flex; align-items:center; gap:14px; margin-bottom:8px; }
.rate-block-head .rb-ic {
  width:40px; height:40px; flex-shrink:0; border-radius:2px; background:var(--ink); color:var(--brand-cyan);
  display:flex; align-items:center; justify-content:center;
}
.rate-block-head .rb-ic svg { width:21px; height:21px; }
.rate-block-head h3 { font-size:22px; font-weight:900; }
.rate-block > p.rate-lead { font-size:15px; color:var(--steel-dark); line-height:1.65; margin:0 0 22px 54px; max-width:680px; }
.rate-table-wrap { overflow-x:auto; border:1px solid var(--line-light); border-radius:4px; }
.rate-table { width:100%; border-collapse:collapse; background:#fff; min-width:420px; }
.rate-table th {
  text-align:left; font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:0.07em;
  text-transform:uppercase; color:var(--steel); background:var(--paper-dim);
  padding:14px 22px; border-bottom:1px solid var(--line-light); font-weight:500;
}
.rate-table th:last-child, .rate-table td.price { text-align:right; }
.rate-table td { padding:17px 22px; font-size:15px; color:var(--steel-dark); border-bottom:1px solid var(--line-light); line-height:1.5; }
.rate-table tbody tr:last-child td { border-bottom:none; }
.rate-table tbody tr { transition:background .15s; }
.rate-table tbody tr:hover { background:var(--paper); }
.rate-table td.price { font-family:'Archivo',sans-serif; font-weight:900; font-size:16px; color:var(--ink); white-space:nowrap; }
.rate-table td.price .gst { font-family:'JetBrains Mono',monospace; font-weight:400; font-size:11px; color:var(--steel); display:block; margin-top:2px; }
.rate-fine { list-style:none; margin:18px 0 0 54px; display:flex; flex-direction:column; gap:9px; max-width:720px; }
.rate-fine li { font-size:13.5px; color:var(--steel-dark); line-height:1.55; display:flex; gap:10px; align-items:baseline; }
.rate-fine li::before { content:'—'; color:var(--brand-cyan); font-weight:700; flex-shrink:0; }
.rate-fine.tight { margin-top:10px; }

@media (max-width:900px){
  .kit-grid { grid-template-columns:1fr; }
  .rate-block > p.rate-lead, .rate-fine { margin-left:0; }
}

/* ---------- CLIENT REVIEWS (social proof) ---------- */
.review-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.review-card { background:#fff; border:1px solid var(--line-light); border-radius:6px; padding:32px 30px; display:flex; flex-direction:column; }
.review-stars { color:#FBBC04; letter-spacing:3px; font-size:15px; margin-bottom:16px; }
.review-card blockquote { font-size:15px; color:var(--steel-dark); line-height:1.7; margin-bottom:22px; font-style:normal; }
.review-author { margin-top:auto; display:flex; flex-direction:column; gap:3px; }
.review-author .r-name { font-family:'Archivo',sans-serif; font-weight:700; font-size:15px; color:var(--ink); }
.review-author .r-meta { font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--steel); text-transform:uppercase; letter-spacing:0.06em; }
@media (max-width:900px){ .review-grid { grid-template-columns:1fr; } }

/* ---------- ULTRAWIDE: cap full-bleed hero images + feather the edges ---------- */
/* Inner-page heroes use <img class="hero-poster">. Above 2000px viewport, cap the image
   at 2000px centred so the section's dark colour shows either side, with a soft mask
   blending the image edge into it. Below 2000px it stays full-width (unchanged). */
@media (min-width:2000px){
  .hero-poster {
    max-width:2000px; margin-inline:auto;
    -webkit-mask-image:linear-gradient(to right, transparent 0, #000 180px, #000 calc(100% - 180px), transparent 100%);
            mask-image:linear-gradient(to right, transparent 0, #000 180px, #000 calc(100% - 180px), transparent 100%);
  }
}
