
* { box-sizing: border-box; }
:root {
  --bg: #0e1522;
  --panel: #122033;
  --ink: #f2f7fb;
  --muted: #b7c7d9;
  --brand: #1b3950;
  --brand2: #2a77b7;
  --accent: #8fc5ff;
  --ring: rgba(42,119,183,.5);
}
html, body { margin:0; padding:0; background:var(--bg); color:var(--ink); font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; line-height:1.45; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
.container { width:min(1100px,92vw); margin:0 auto; }

header { position:sticky; top:0; z-index:50; background:rgba(14,21,34,.7); backdrop-filter:blur(10px); border-bottom:1px solid rgba(255,255,255,.06); }
.nav { display:flex; align-items:center; justify-content:space-between; padding:12px 0; gap:16px; }
.nav img { height:44px; }
.nav .cta { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

.btn { display:inline-block; padding:10px 16px; border-radius:10px; background: linear-gradient(135deg, var(--brand2), #1f59a0); color:#fff; font-weight:800; box-shadow:0 10px 24px rgba(0,0,0,.25); border:0; cursor:pointer; }
.btn.secondary { background:#1b3950; color:#fff; box-shadow:none; border:1px solid rgba(255,255,255,.1); }
.btn.ghost { background:transparent; border:1px solid rgba(255,255,255,.15); color:#d9e6f4; }
.btn:focus-visible, .input:focus-visible, textarea:focus-visible { outline:3px solid var(--ring); outline-offset:2px; }

.hero { display:grid; place-items:center; padding:64px 0 18px; background: radial-gradient(1200px 400px at 50% -50%, rgba(42,119,183,.22), transparent 70%); text-align:center; }
.hero h1 { font-size:clamp(30px,6vw,56px); margin:10px 0 8px; line-height:1.05; }
.hero p { color:var(--muted); font-size:clamp(16px,2.5vw,20px); margin:0 0 18px; }
.badges { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.badge { background:#15263d; border:1px solid rgba(255,255,255,.06); border-radius:999px; padding:6px 12px; color:#d2e5f7; font-size:14px; }

.grid { display:grid; gap:18px; }
.grid.cols-3 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.card { background:var(--panel); border:1px solid rgba(255,255,255,.06); border-radius:16px; padding:18px; }
.card h3 { margin:0 0 6px; }
.card p { margin:0; color:var(--muted); }

.section { padding:32px 0; }
.section h2 { margin:0 0 14px; font-size:clamp(22px,4.5vw,32px); }
.section p.lead { color:var(--muted); margin-top:0; }

.gallery { display:grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap:10px; }
.gallery img { width:100%; height:auto; border-radius:12px; border:1px solid rgba(255,255,255,.08); }

.faq details { background:var(--panel); border:1px solid rgba(255,255,255,.06); border-radius:12px; padding:14px 16px; }
.faq details+details { margin-top:10px; }
.faq summary { font-weight:800; cursor:pointer; }
.faq p { color:var(--muted); margin-bottom:0; }

.contact { background:linear-gradient(135deg, rgba(27,57,80,.65), rgba(42,119,183,.5)); border:1px solid rgba(255,255,255,.06); border-radius:18px; padding:22px; display:grid; grid-template-columns:1fr; gap:12px; }
.inputs { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media (max-width: 720px) { .inputs { grid-template-columns:1fr; } }
.input, textarea { width:100%; background:rgba(0,0,0,.25); border:1px solid rgba(255,255,255,.12); color:#f2f7fb; padding:10px 12px; border-radius:10px; }

footer { padding:26px 0 70px; color:#bcd1e6; text-align:center; }
.small { font-size:13px; color:#cfe3f7; }

/* Floating mobile CTA */
.fab { position:fixed; bottom:16px; right:16px; display:grid; gap:10px; }
.fab a { display:inline-block; padding:12px 14px; border-radius:999px; background:linear-gradient(135deg, var(--brand2), #1f59a0); color:#fff; font-weight:800; box-shadow:0 10px 24px rgba(0,0,0,.35); }
.fab a.secondary { background:#1b3950; border:1px solid rgba(255,255,255,.12); }
@media (min-width: 900px) { .fab { display:none; } }


/* v4.6 reviews enhancements */
.reviews-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap:14px; }
.review-card { background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); border:1px solid rgba(255,255,255,.08); border-radius:14px; padding:14px; box-shadow:0 8px 20px rgba(0,0,0,.18); }
.review-card .stars { color:#ffcf5a; letter-spacing:2px; font-size:18px; margin-bottom:6px; }
.review-card .quote { margin:0; color:#e6f1fb; }
.review-card .who { margin-top:8px; color:#b8d0ea; font-weight:700; font-size:14px; }
.reviews-cta { display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.sr { color:#b8d0ea; font-size:.9em; font-weight:600; margin-left:.35em; }


/* v4.7 social icons */
.social { display:flex; gap:12px; justify-content:center; margin-bottom:12px; }
.social-icon { display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px;
  border-radius:50%; background:#1b3950; color:#fff; font-weight:700; text-decoration:none; font-size:18px; }
.social-icon.fb:hover { background:#1877f2; }
.social-icon.yt:hover { background:#ff0000; }


/* v4.8 social CTA enhancements */
.social-cta { text-align:center; margin:10px 0 8px; }
.social-cta h3 { margin:0 0 8px; font-size:20px; }
.social { gap:14px; }
.social-icon { width:44px; height:44px; font-size:20px; box-shadow:0 8px 18px rgba(0,0,0,.25); }
.social-icon:hover { transform: translateY(-1px); }


/* v4.9 header social icons */
.header-social { display:flex; gap:8px; align-items:center; }
@media (max-width:720px) {
  .header-social { display:none; } /* hide in mobile so header isn't too crowded */
}


/* v4.12 color & UI polish */
:root{
  --accent:#2d7dd2;            /* brand blue */
  --accent-2:#1a5fb4;          /* darker */
  --accent-glow: rgba(45,125,210,.35);
}
.hero{ background: radial-gradient(1200px 600px at 20% -20%, rgba(45,125,210,.22), transparent 60%),
                   linear-gradient(180deg, rgba(255,255,255,.02), transparent 65%); }
.btn{ background: linear-gradient(135deg, var(--accent), var(--accent-2)); box-shadow: 0 8px 20px var(--accent-glow); }
.btn:hover{ transform: translateY(-1px); filter: brightness(1.03); }
.card{ border-color: rgba(158,203,255,.18); background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015)); }
h2{ border-left: 4px solid var(--accent); padding-left: 10px; }
.review-card{ background: linear-gradient(180deg, rgba(45,125,210,.08), rgba(45,125,210,.03)); }
.review-card .stars{ color:#ffd569; text-shadow: 0 0 10px rgba(255,213,105,.35); }
.social-icon{ box-shadow: 0 8px 18px rgba(0,0,0,.28); }

/* service icons */
.svc-ic{ display:inline-flex; width:26px; height:26px; align-items:center; justify-content:center;
  background:#17324a; color:#fff; border-radius:50%; font-size:15px; margin-right:8px; box-shadow:0 4px 10px rgba(0,0,0,.25); }
@media (max-width:520px){ .svc-ic{ margin-right:6px; } }


/* v4.13 streamline & footer trust row */
#contact .card p { margin: 0 0 8px; }
.footer-info{ display:flex; flex-direction:column; align-items:center; gap:8px; margin:8px 0 10px;}
.footer-pay{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; max-width:720px;}
.pay-badge{ background:#1b3950; color:#eaf3ff; padding:6px 10px; border-radius:999px; font-size:13px; border:1px solid rgba(255,255,255,.12); }
.pay-badge:hover{ background:#214864; }
.footer-hours{ color:#cfe2fa; }
@media (max-width:520px){
  .footer-hours{ text-align:center; }
}


/* v4.14 contact + footer tidy */
#contact .card a[href^="tel:"]{ font-weight:700; }
.footer-hours{ text-align:center; font-weight:600; letter-spacing:.1px; }
.footer-pay{ gap:10px; }
.pay-badge{ padding:6px 12px; font-size:13px; background:#17324a; border:1px solid rgba(255,255,255,.15); }
.pay-badge:nth-child(odd){ background:#1b3950; }
@media (max-width:520px){
  .footer-hours{ line-height:1.4; }
  .footer-pay{ justify-content:center; }
}


/* v4.15 exact fixes */
#contact .card p strong{ width:auto; }
#contact .card p a[href^="tel:"]{ font-weight:700; }

.footer-info{ display:flex; flex-direction:column; gap:10px; align-items:center; margin:10px 0 12px; }
.footer-hours{ text-align:center; font-weight:600; }
.footer-pay-wrap{ display:flex; flex-direction:column; align-items:center; gap:6px; }
.we-accept{ opacity:.9; font-weight:600; }
.footer-pay{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; }
.pay-badge{ background:#17324a; color:#eaf3ff; padding:6px 12px; border-radius:999px; font-size:13px; border:1px solid rgba(255,255,255,.14); }
@media (max-width:520px){
  .footer-hours{ line-height:1.3; }
}

/* v4.16 header + nav */
.site-header{
  position: static; top:0; z-index: 50;
  background: rgba(7,18,28,.86); backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.header-inner{ max-width: 1080px; margin:0 auto; padding:10px 14px; display:grid;
  grid-template-columns: auto 1fr auto; align-items:center; gap:12px; }
.brand-logo{ height:42px; width:auto; filter: drop-shadow(0 2px 8px rgba(0,0,0,.5)); }
.header-actions{ display:flex; gap:10px; align-items:center; }
.top-nav{ display:flex; gap:16px; justify-content:flex-end; }
.top-nav a{ color:#cfe2fa; text-decoration:none; font-weight:600; opacity:.9; }
.top-nav a:hover{ opacity:1; text-decoration:underline; }

/* hamburger for mobile */
.nav-toggle{ display:none; }
.nav-burger{ display:none; width:36px; height:28px; align-items:center; justify-content:center; cursor:pointer; }
.nav-burger span{ display:block; width:22px; height:2px; background:#cfe2fa; margin:4px 0; }
@media (max-width: 760px){
  .header-inner{ grid-template-columns:auto auto 1fr; }
  .header-actions{ display:none; }
  .nav-burger{ display:flex; justify-self:end; }
  .top-nav{ display:none; position:absolute; left:0; right:0; top:100%; background:rgba(7,18,28,.98); padding:10px 14px; border-bottom:1px solid rgba(255,255,255,.08); }
  .top-nav a{ display:block; padding:10px 6px; }
  .nav-toggle:checked ~ .nav-burger + .top-nav{ display:block; }
}
/* bump hero top spacing now that header is sticky */
.hero{ padding-top: 18px; }


/* v4.17 bigger logo + sticky header offset + mobile header layout */
.brand-logo{ height:72px; } /* desktop/tablet */
@media (max-width: 760px){
  .brand-logo{ height:58px; }
  .header-inner{ grid-template-columns: 1fr auto; grid-auto-rows: auto; align-items:center; }
  .header-actions{ display:flex; grid-column: 1 / -1; justify-content:center; gap:10px; margin-top:6px; flex-wrap:wrap; }
  .nav-burger{ justify-self:end; }
}

/* Ensure anchor targets aren't hidden behind sticky header */
#services, #pricing, #reviews, #contact { scroll-margin-top: 96px; }
@media (max-width:760px){
  #services, #pricing, #reviews, #contact { scroll-margin-top: 88px; }
}


/* v4.18: bigger logo + disable sticky header on mobile */
.brand-logo{ height:104px; } /* desktop/tablet larger */
@media (max-width: 760px){
  .site-header{ position: static; } /* no sticky on mobile */
  .brand-logo{ height:86px; }       /* bigger on mobile too */
  /* increase anchor offset only for desktop since mobile header is not sticky */
  #services, #pricing, #reviews, #contact { scroll-margin-top: 20px; }
}

/* tighten spacing under header since it's not sticky on mobile */
@media (max-width:760px){
  .hero{ padding-top: 8px; }
}


/* v4.19: Remove sticky header everywhere */
.site-header {
  position: static !important;
}


/* === v4.21 Nuke sticky header everywhere === */
.site-header,
header,
nav,
.navbar,
.header,
.sticky,
.is-sticky {
  position: static !important;
  top: auto !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  z-index: 1 !important;
}
.header-inner,
.nav-inner,
.header-wrap,
.nav-wrap { position: static !important; }

/* Slightly tighten top spacing since header is static */
.hero { padding-top: 10px; }

/* Anchor offsets can be small now */
#services, #pricing, #reviews, #contact { scroll-margin-top: 14px !important; }


/* v4.22: If any duplicate <header> sneaks in, hide all but the first one */
header { display: block; }
header:nth-of-type(n+2) { display: none !important; }


/* === Header polish (logo alignment & spacing) === */
.site-header, header .container.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
header .container.nav a img { 
  height: 44px; 
  width: auto; 
  display: block;
}
header .container.nav .cta { 
  display: inline-flex; 
  align-items: center; 
  gap: .5rem; 
  flex-wrap: wrap;
}
/* Keep nav links aligned cleanly if present */
header .container.nav .top-nav, header .top-nav {
  display: inline-flex;
  gap: 1rem;
  align-items: center;
}

/* Tighter header padding on large screens */
@media (min-width: 900px) {
  header .container.nav { padding: 10px 0; }
}

/* Mobile: stack logo and actions neatly */
@media (max-width: 899px) {
  header .container.nav { 
    flex-direction: column; 
    align-items: stretch;
    gap: .75rem;
  }
  header .container.nav .cta { justify-content: center; }
}


/* === Mobile header stacking (logo on top, buttons under) === */
.site-header .header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.site-header .brand-logo {
  height: 44px;
  width: auto;
  display: block;
}

/* Mobile-only stack */
@media (max-width: 860px) {
  .site-header .header-inner {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .75rem;
  }
  .site-header .brand {
    width: 100%;
    display: flex;
    justify-content: center;
  }
  .site-header .header-actions {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: center;
  }
  .site-header .top-nav {
    width: 100%;
    display: flex;
    justify-content: center;
  }
}


/* === Mobile header polish v2 === */
@media (max-width: 860px) {
  .site-header { padding: 12px 0 8px; }
  .site-header .header-inner { gap: .5rem; }
  .site-header .brand-logo { height: 38px; }
  .site-header .brand { display: flex; justify-content: center; width: 100%; }
  .site-header .header-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
    width: 100%;
    max-width: 560px;
    justify-items: stretch;
  }
  .site-header .header-actions .btn { width: 100%; text-align: center; }
  .site-header .header-actions .btn:nth-child(3) { grid-column: 1 / -1; }
  .site-header .top-nav {
    width: 100%;
    display: flex;
    justify-content: space-between;
    gap: .5rem;
    margin-top: .5rem;
  }
}


/* === Mobile header stack v3 (align with page container) === */
@media (max-width: 860px) {
  .site-header { padding: 12px 0 8px; }
  .site-header .header-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .75rem;
    width: 100%;
    max-width: 1100px;       /* align to main container max if used */
    padding: 0 16px;         /* align with page side padding */
    margin: 0 auto;
  }
  .site-header .brand { width: 100%; display: flex; justify-content: center; }
  .site-header .brand-logo { height: 36px; width: auto; display: block; }
  .site-header .header-actions {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: .5rem;
  }
  .site-header .header-actions .btn { width: 100%; text-align: center; }
  .site-header .top-nav { width: 100%; display: flex; justify-content: space-between; gap: .5rem; margin-top: .5rem; }
}


/* === Mobile nav behavior v5 === */
@media (max-width: 860px) {
  /* Hide nav by default on mobile */
  .site-header .top-nav {
    display: none;
    flex-direction: column;
    gap: .75rem;
    width: 100%;
    padding: 0;
  }
  /* Show as vertical stack when burger is checked */
  .site-header .nav-toggle:checked ~ .top-nav {
    display: flex;
  }
  .site-header .top-nav a {
    display: block;
    width: 100%;
    text-align: left;
    padding: 10px 0;
  }
}


/* === Logo size tweak === */
.site-header .brand-logo { height: 56px; }           /* desktop/base */
@media (max-width: 860px) {
  .site-header .brand-logo { height: 48px; }         /* mobile */
}


/* === Anchor offset for jump links === */
html { scroll-behavior: smooth; }
#top, #services, #pricing, #reviews, #contact {
  scroll-margin-top: 120px;   /* desktop/header height */
}
@media (max-width: 860px) {
  #top, #services, #pricing, #reviews, #contact {
    scroll-margin-top: 200px; /* taller mobile header stack */
  }
}

/* === Logo size tweak v7 === */
.site-header .brand-logo { height: 64px; }    /* desktop/base */
@media (max-width: 860px) {
  .site-header .brand-logo { height: 56px; }  /* mobile */
}


/* === Collapsible jump links (mobile) v8 === */
@media (max-width: 860px) {
  /* Hide the three-line burger icon spans (visual) */
  .site-header .nav-burger span { display: none; }
  /* Style the label itself as a full-width pill button */
  .site-header .nav-burger {
    display: block;
    width: 100%;
    text-align: center;
    padding: 10px 14px;
    border-radius: 10px;
    background: #132033;
    border: 1px solid rgba(255,255,255,0.08);
    margin-top: 6px;
  }
  .site-header .nav-burger .nav-label {
    display: inline-block;
    font-weight: 600;
    letter-spacing: .2px;
  }
  /* Optional chevron */
  .site-header .nav-burger .nav-label::after {
    content: " ▾";
    opacity: .8;
  }
  /* Rotate chevron when open */
  .site-header .nav-toggle:checked + label.nav-burger .nav-label::after {
    content: " ▴";
  }
  /* Collapsible nav as vertical list */
  .site-header .top-nav {
    display: none;
    flex-direction: column;
    gap: .6rem;
    width: 100%;
    padding: 8px 0 0;
  }
  .site-header .nav-toggle:checked ~ .top-nav { display: flex; }
  .site-header .top-nav a { display:block; width:100%; text-align:left; padding: 8px 0; }
}


/* === Mobile collapsible Menu v9 === */
@media (max-width: 860px) {
  .site-header .nav-burger {
    display: block;
    width: 100%;
    text-align: center;
    padding: 12px 0;
    border-radius: 8px;
    background: #132033;
    font-weight: 600;
    cursor: pointer;
  }
  .site-header .top-nav {
    display: none;
    flex-direction: column;
    gap: .6rem;
    width: 100%;
    margin-top: .5rem;
  }
  .site-header .nav-toggle:checked ~ .top-nav {
    display: flex;
  }
  .site-header .top-nav a {
    display: block;
    width: 100%;
    text-align: left;
    padding: 8px 0;
  }
}


/* === Collapsible jump links (mobile) v9 === */
@media (max-width: 860px) {
  /* default: hidden */
  .site-header .top-nav {
    display: none !important;
    flex-direction: column;
    gap: .6rem;
    width: 100%;
    padding: 8px 0 0;
  }
  /* when toggled: show */
  .site-header .nav-toggle:checked ~ .top-nav {
    display: flex !important;
  }

  /* style toggle label */
  .site-header .nav-burger {
    display: block;
    width: 100%;
    text-align: center;
    padding: 10px 14px;
    border-radius: 10px;
    background: #132033;
    border: 1px solid rgba(255,255,255,0.08);
    margin-top: 6px;
    line-height: 1.2;
  }
  .site-header .nav-burger .nav-label { display:inline-block; font-weight:600; white-space:nowrap; }
  .site-header .nav-burger span { display:none; } /* hide burger bars */
  .site-header .nav-toggle:checked + label.nav-burger .nav-label::after { content:" ▴"; }
  .site-header .nav-burger .nav-label::after { content:" ▾"; opacity:.8; }
}


/* === Center Menu label fix v10 === */
@media (max-width: 860px) {
  .site-header .nav-burger {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .site-header .nav-burger .nav-label {
    display: inline-block;
    font-weight: 600;
    white-space: nowrap;
    line-height: 1.4;
  }
}


/* === Bigger logo v11 === */
.site-header .brand-logo { height: 88px; }    /* desktop/base */
@media (max-width: 860px) {
  .site-header .brand-logo { height: 72px; }  /* mobile */
}


/* === Bigger logo v12 === */
.site-header .brand-logo { height: 120px; }    /* desktop/base */
@media (max-width: 860px) {
  .site-header .brand-logo { height: 96px; }   /* mobile */
}


.section.watermark::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: min(320px, 60%);
  height: min(160px, 30%);
  background-image: url('assets/logo.png');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: 0.08;
  pointer-events: none;
  filter: saturate(0.8) brightness(1.1);
}
@media (max-width: 860px) {
  .section.watermark::after {
    width: min(240px, 70%);
    height: min(120px, 28%);
    opacity: 0.06;
  }
}


.section.watermark::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: min(400px, 65%);
  height: min(200px, 35%);
  background-image: url('assets/logo-icon.png');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: 0.12;
  pointer-events: none;
}
/* Hero section gets lighter watermark */
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: min(500px, 70%);
  height: min(240px, 40%);
  background-image: url('assets/logo-icon.png');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: 0.07;
  pointer-events: none;
}
@media (max-width: 860px) {
  .section.watermark::after {
    width: min(240px, 80%);
    height: min(120px, 30%);
    opacity: 0.1;
  }
  .hero::after {
    width: min(300px, 80%);
    height: min(150px, 35%);
    opacity: 0.06;
  }
}


/* ensure hero can render ::after watermark */
.hero { position: relative; }

/* Watermark visibility bump */
.section.watermark::after { opacity: 0.16; }
@media (max-width: 860px) {
  .section.watermark::after { opacity: 0.12; }
}

/* === BIG TOP LOGO === */
.site-header .brand-logo {
  height: 160px !important;
  padding: 20px 0 !important;
}
@media (max-width: 860px) {
  .site-header .brand-logo {
    height: 120px !important;
    padding: 15px 0 !important;
  }
}


/* === BIGGER LOGO FIX === */
.site-header img {
  height: 160px !important;
  max-height: 160px !important;
  padding: 20px 0 !important;
}
@media (max-width: 860px) {
  .site-header img {
    height: 120px !important;
    max-height: 120px !important;
    padding: 15px 0 !important;
  }
}


/* === Responsive video embed === */
.video-section { position: relative; }
.video-wrap {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 25px rgba(0,0,0,.35);
}
.video-wrap iframe {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  border: 0;
}


/* === Full-width video section === */
.video-full {
  width: 100%;
  background: #0d1117;
  padding: 2rem 1rem;
  text-align: center;
}
.video-full h2 {
  margin-bottom: 1rem;
}
.video-wrap {
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 25px rgba(0,0,0,.35);
}
.video-wrap iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
  border: none;
}


/* === Full-width video section before Reviews === */
.video-full {
  width: 100%;
  background: #0d1117;
  padding: 2rem 1rem;
  text-align: center;
}
.video-full h2 {
  margin: 0 auto 1rem;
}
.video-wrap {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 25px rgba(0,0,0,.35);
}
.video-wrap iframe {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  border: 0;
}
@media (max-width: 860px) {
  .video-full { padding: 1.25rem .75rem; }
  .video-wrap { border-radius: 10px; }
}


/* === Full-width video section before Reviews (v2) === */
.video-full { width: 100%; background: #0d1117; padding: 2rem 1rem; text-align: center; }
.video-full h2 { margin: 0 auto 1rem; }
.video-wrap { width: 100%; max-width: 1200px; margin: 0 auto; border-radius: 12px; overflow: hidden; box-shadow: 0 10px 25px rgba(0,0,0,.35); }
.video-wrap iframe { display: block; width: 100%; height: auto; aspect-ratio: 16 / 9; border: 0; }
@media (max-width: 860px) { .video-full { padding: 1.25rem .75rem; } .video-wrap { border-radius: 10px; } }


/* === Google Photos album embed (with fallback) === */
.gallery-section .album-embed {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto 16px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 25px rgba(0,0,0,.35);
}
.gallery-section .album-embed iframe {
  display: block;
  width: 100%;
  height: min(72vh, 780px);
  border: 0;
  background: #0d1117;
}
.gallery-section .album-fallback {
  text-align: center;
}
.gallery-section .album-fallback .muted {
  display: block;
  margin-top: 6px;
  opacity: .75;
  font-size: .9rem;
}


/* === Cloudinary Gallery === */
.cloud-gallery .gallery-actions { margin-bottom: .75rem; display:flex; gap:12px; align-items:center; }
.cloud-gallery .gallery-actions .muted { opacity:.75; font-size:.9rem; }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.gallery-item { border-radius: 10px; overflow: hidden; display:block; box-shadow: 0 6px 16px rgba(0,0,0,.3); }
.gallery-item img { width:100%; height:100%; object-fit: cover; display:block; }
@media (max-width: 1024px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px)  { .gallery-grid { grid-template-columns: 1fr; } }
.gallery-empty { text-align:center; opacity:.8; }


/* Smooth anchor spacing for the Gallery section */
h2#gallery { scroll-margin-top: 96px; margin-top: 28px; padding-top: 4px; }
@media (max-width: 860px){ h2#gallery { scroll-margin-top: 120px; } }


/* === Hover polish === */
a.btn:hover, button:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.25);
  transition: all 0.2s ease-in-out;
}
.service-card:hover, .card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.2);
  transition: all 0.25s ease;
}


/* Anchor spacing for FAQ and Service Area */
h2#faq, h2#service-area { scroll-margin-top: 96px; }
@media (max-width: 860px){ h2#faq, h2#service-area { scroll-margin-top: 120px; } }

/* Anchor spacing for About Us */
h2#about { scroll-margin-top: 96px; }
@media (max-width: 860px){ h2#about { scroll-margin-top: 120px; } }


/* FAQ accordion */
.faq-accordion details {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 14px 16px;
  margin: 10px 0;
}
.faq-accordion summary {
  cursor: pointer;
  font-weight: 600;
  list-style: none;
}
.faq-accordion summary::-webkit-details-marker { display: none; }
.faq-accordion details summary::after {
  content: "▸";
  float: right;
  transition: transform 0.2s ease;
  opacity: 0.8;
}
.faq-accordion details[open] summary::after {
  transform: rotate(90deg);
}
.faq-accordion .answer {
  margin-top: 8px;
  line-height: 1.5;
  opacity: 0.95;
}


/* Thumbtack Top Pro badge placement */
.thumbtack-badge img { height: auto; max-width: 160px; }
footer .thumbtack-mini { height: 28px; width: auto; opacity: 0.9; vertical-align: middle; margin-left: 10px; }
@media (max-width: 600px) {
  .thumbtack-badge img { max-width: 140px; }
  footer .thumbtack-mini { height: 24px; margin-left: 8px; }
}


/* Adjusted Thumbtack badge styles */
.thumbtack-badge img { max-width: 160px; height: auto; }
footer .thumbtack-mini { height: 24px; width: auto; opacity: 0.85; vertical-align: middle; margin-left: 8px; }


/* Final Thumbtack badge styles */
.thumbtack-badge img { max-width: 150px; height: auto; }
footer .thumbtack-mini { height: 22px; width: auto; opacity: 0.9; vertical-align: middle; margin-left: 6px; }


/* Strict Thumbtack badge sizing */
.thumbtack-badge img { 
  max-width: 120px !important; 
  height: auto !important; 
  display: block; 
  margin: 0 auto; 
}
footer .thumbtack-mini { 
  height: 20px !important; 
  width: auto !important; 
  opacity: 0.9; 
  vertical-align: middle; 
  margin-left: 6px; 
}


/* Force Thumbtack badge to fit page flow */
.thumbtack-badge img { 
  display: block; 
  margin: 0 auto; 
  max-width: 25% !important;  /* shrink relative to container width */
  height: auto !important; 
}
footer .thumbtack-mini { 
  height: 18px !important; 
  width: auto !important; 
  opacity: 0.9; 
  vertical-align: middle; 
  margin-left: 6px; 
}


/* Force strict fixed size for Thumbtack badges */
.thumbtack-badge img { 
  display: block; 
  margin: 0 auto; 
  width: 100px !important; 
  height: auto !important; 
}
footer .thumbtack-mini { 
  height: 18px !important; 
  width: auto !important; 
  opacity: 0.9; 
  vertical-align: middle; 
  margin-left: 6px; 
}


/* Nuclear specificity override for badge sizing */
section#reviews ~ .thumbtack-badge img,
div.thumbtack-badge img,
footer .footer-pay-wrap img.thumbtack-mini,
footer img.thumbtack-mini,
img[src*="thumbtack-top-pro-2025"] {
  max-width: none !important;
}

div.thumbtack-badge img { width: 100px !important; height: auto !important; }
footer img.thumbtack-mini { height: 18px !important; width: auto !important; }


/* --- Cred chip above reviews --- */
.thumbtack-badge { 
  display: flex; 
  justify-content: center; 
  margin: 12px 0 8px;
}
.cred-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  padding: 6px 10px;
  border-radius: 999px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.cred-chip__icon {
  height: 24px !important;
  width: auto !important;
}
.cred-chip__text {
  font-size: 14px;
  line-height: 1;
  color: #e7edf7;
  letter-spacing: .2px;
  white-space: nowrap;
}

/* Footer trust bar icon */
footer .thumbtack-mini { 
  height: 18px !important; 
  width: auto !important; 
  opacity: 0.9; 
  vertical-align: middle; 
  margin-left: 6px; 
}
@media (max-width: 600px){
  .cred-chip__text { font-size: 13px; }
  .cred-chip__icon { height: 22px !important; }
}


/* Inline cred chip next to Customer Reviews heading */
.cred-chip-inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 13px;
  color: #e7edf7;
  margin-left: 10px;
  vertical-align: middle;
}
.cred-chip-inline__icon {
  height: 18px !important;
  width: auto !important;
}
.cred-chip-inline__text {
  font-size: 13px;
  line-height: 1;
  white-space: nowrap;
}


/* Force tiny inline badge next to heading */
.cred-chip-inline {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  padding: 2px 6px;
  border-radius: 999px;
  font-size: 12px;
  color: #e7edf7;
  margin-left: 8px;
}
.cred-chip-inline__icon {
  height: 16px !important;
  width: auto !important;
}
.cred-chip-inline__text {
  font-size: 12px;
  line-height: 1;
  white-space: nowrap;
}


/* Inline chip refinement */
.cred-chip-inline {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  padding: 2px 6px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  color: #e7edf7;
  margin-left: 8px;
}
.cred-chip-inline__icon {
  height: 16px !important;
  width: auto !important;
}
.cred-chip-inline__text {
  font-size: 12px;
  line-height: 1;
  white-space: nowrap;
}


/* Clean inline Top Pro label next to heading */
.cred-chip-inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-left: 10px;
  vertical-align: middle;
}
.cred-chip-inline__divider {
  opacity: 0.5;
  font-weight: 600;
}
.cred-chip-inline__icon {
  height: 16px !important;
  width: auto !important;
  display: inline-block;
}
.cred-chip-inline__text {
  font-size: 13px;
  line-height: 1;
  color: #BFD4FF; /* subtle light-blue to match theme */
  letter-spacing: .2px;
  white-space: nowrap;
  font-weight: 500;
}

/* Remove old footer mini styling since badge is gone */
footer .thumbtack-mini { display: none !important; }


/* Final fix: small inline badge with background icon */
.cred-chip-inline {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: 8px;
  font-size: 13px;
  font-weight: 500;
  color: #BFD4FF;
  position: relative;
  padding-left: 22px; /* leave space for icon */
}
.cred-chip-inline::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background:none;
}


/* Prominent badge-style highlight for Top Pro */
.cred-chip-inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-left: 10px;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(135deg, #3b82f6, #2563eb); /* soft blue gradient */
  padding: 4px 10px 4px 26px;
  border-radius: 999px;
  position: relative;
  box-shadow: 0 2px 8px rgba(59,130,246,0.6);
}
.cred-chip-inline::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background:none;
}


/* Force badge-style highlight override */
.cred-chip-inline {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin-left: 10px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #fff !important;
  background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
  padding: 4px 10px 4px 26px !important;
  border-radius: 999px !important;
  position: relative !important;
  box-shadow: 0 2px 8px rgba(59,130,246,0.6) !important;
}
.cred-chip-inline::before {
  content: "" !important;
  position: absolute !important;
  left: 8px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 18px !important;
  height: 18px !important;
  background:none;
}


/* === FORCE HIGHLIGHT STYLE (high specificity) === */
h2 .cred-chip-inline, h3 .cred-chip-inline, .section h2 .cred-chip-inline {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin-left: 10px !important;
  padding: 4px 10px 4px 26px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #3b82f6, #2563eb) !important; /* blue gradient */
  color: #ffffff !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  box-shadow: 0 2px 10px rgba(37,99,235,0.55) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  position: relative !important;
  vertical-align: middle !important;
}

h2 .cred-chip-inline::before, h3 .cred-chip-inline::before, .section h2 .cred-chip-inline::before {
  content: "" !important;
  position: absolute !important;
  left: 8px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 18px !important;
  height: 18px !important;
  background:none;
}


/* Crisp badge-style pill for Top Pro */
.cred-chip-inline{
  display:inline-flex;align-items:center;gap:8px;margin-left:10px;
  padding:4px 12px 4px 30px;border-radius:999px;
  background:linear-gradient(135deg,#3b82f6,#2563eb);
  color:#fff;font:600 14px/1 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  box-shadow:0 4px 14px rgba(37,99,235,.35);
  border:1px solid rgba(255,255,255,.15);
  position:relative;vertical-align:middle;white-space:nowrap;
}
.cred-chip-inline::before{
  content:"";position:absolute;left:10px;top:50%;transform:translateY(-50%);
  width:18px;height:18px; background:none;
}
/* absolutely ensure any stray img inside the chip is hidden */
.cred-chip-inline img{ display:none !important; }


/* Use new Top Pro icon for the badge chip */
.cred-chip-inline::before {
  background: url('assets/toppro-icon.png') center/contain no-repeat !important;
}


/* Force new Top Pro icon and bust caches */
h2 .cred-chip-inline::before, h3 .cred-chip-inline::before, .cred-chip-inline::before {
  background: url('assets/toppro-icon-v2.png?v=2') center/contain no-repeat !important;
  width: 18px !important;
  height: 18px !important;
  content: "" !important;
}


/* === Cross-device consistency fixes === */
html { -webkit-text-size-adjust: 100%; }

.main, .container, body > main, #top, .content {
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 16px;
  padding-right: 16px;
}

.embed, .video-wrap, .yt-wrap {
  position: relative;
  width: 100%;
  max-width: 100%;
  aspect-ratio: 16 / 9;
}
.embed iframe, .video-wrap iframe, .yt-wrap iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
}

#reviews, section#reviews { scroll-margin-top: 80px; }
.review-card, .reviews .card { margin-bottom: 16px; }
h2, .h2 { line-height: 1.2; }
@media (min-width: 1024px) {
  h2, .h2 { font-size: clamp(28px, 2.2vw, 34px); }
}

img { height: auto; }
img.responsive, .content img, .section img {
  max-width: 100%;
  height: auto;
}
.cred-chip-inline img{ display:none !important; }

h2 .cred-chip-inline, .cred-chip-inline {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-left: 10px !important;
  padding: 4px 12px 4px 30px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg,#3b82f6,#2563eb) !important;
  color: #fff !important;
  font: 700 14px/1 system-ui, -apple-system, Segoe UI, Roboto, sans-serif !important;
  box-shadow: 0 4px 14px rgba(37,99,235,.35) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  position: relative !important;
  vertical-align: middle !important;
  white-space: nowrap !important;
}
h2 .cred-chip-inline::before, .cred-chip-inline::before {
  content: "" !important;
  position: absolute !important;
  left: 10px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 18px !important;
  height: 18px !important;
  background: url('assets/toppro-icon-v2.png?v=3') center/contain no-repeat !important;
}


/* --- Header polish pack --- */
.site-header, header, .topbar {
  height: 64px;
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(7, 19, 34, 0.9);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06),
              0 8px 22px rgba(0,0,0,0.35);
}

.site-header .container, header .container, .topbar .container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
}

.header-logo img, .logo img {
  height: 36px;
  width: auto;
}

nav.primary, .primary-nav, .main-nav {
  display: flex;
  align-items: center;
  gap: 18px;
}
nav.primary a, .primary-nav a, .main-nav a {
  position: relative;
  top: 1px;
  font-weight: 600;
  opacity: 0.95;
}
nav.primary a:hover, .primary-nav a:hover, .main-nav a:hover {
  opacity: 1;
}

.header-ctas, .cta-group {
  display: flex;
  align-items: center;
  gap: 10px;
}
.header-ctas .btn, .cta-group .btn {
  height: 36px;
  padding: 0 12px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
}
.header-ctas .btn--primary, .cta-group .btn--primary {
  background: linear-gradient(180deg,#3b82f6,#2563eb);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.08);
}
.header-ctas .btn--ghost, .cta-group .btn--ghost {
  background: rgba(255,255,255,0.06);
  color: #e6efff;
  border: 1px solid rgba(255,255,255,0.08);
}

.header-menu-label { display: none; }
@media (max-width: 1024px) {
  .primary-nav, .main-nav { display: none; }
  .header-menu-label { display: inline-flex; }
}

.hero, .masthead { padding-top: 18px; }


/* --- Header polish pack --- */
.site-header, header, .topbar {
  height: 64px;
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(7, 19, 34, 0.9);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06),
              0 8px 22px rgba(0,0,0,0.35);
}

.site-header .container, header .container, .topbar .container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
}

.header-logo img, .logo img {
  height: 36px;
  width: auto;
}

nav.primary, .primary-nav, .main-nav {
  display: flex;
  align-items: center;
  gap: 18px;
}
nav.primary a, .primary-nav a, .main-nav a {
  position: relative;
  top: 1px;
  font-weight: 600;
  opacity: 0.95;
}
nav.primary a:hover, .primary-nav a:hover, .main-nav a:hover {
  opacity: 1;
}

.header-ctas, .cta-group {
  display: flex;
  align-items: center;
  gap: 10px;
}
.header-ctas .btn, .cta-group .btn {
  height: 36px;
  padding: 0 12px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
}
.header-ctas .btn--primary, .cta-group .btn--primary {
  background: linear-gradient(180deg,#3b82f6,#2563eb);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.08);
}
.header-ctas .btn--ghost, .cta-group .btn--ghost {
  background: rgba(255,255,255,0.06);
  color: #e6efff;
  border: 1px solid rgba(255,255,255,0.08);
}

.header-menu-label { display: none; }
@media (max-width: 1024px) {
  .primary-nav, .main-nav { display: none; }
  .header-menu-label { display: inline-flex; }
}

.hero, .masthead { padding-top: 18px; }


/* === Header polish pack (desktop + mobile) === */
.site-header, header, .topbar {
  height: 64px;
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(7,19,34,0.9);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06), 0 8px 22px rgba(0,0,0,0.35);
}

.site-header .container, header .container, .topbar .container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: auto 1fr auto;  /* logo | nav | CTAs */
  align-items: center;
  gap: 16px;
}

.header-logo img, .logo img {
  height: 36px;
  width: auto;
}

nav.primary, .primary-nav, .main-nav {
  display: flex;
  align-items: center;
  gap: 18px;
}
nav.primary a, .primary-nav a, .main-nav a {
  position: relative;
  top: 1px;
  font-weight: 600;
  opacity: .95;
}
nav.primary a:hover, .primary-nav a:hover, .main-nav a:hover {
  opacity: 1;
}

.header-ctas, .cta-group {
  display: flex;
  align-items: center;
  gap: 10px;
}
.header-ctas .btn, .cta-group .btn {
  height: 36px;
  padding: 0 12px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
}
.header-ctas .btn--primary, .cta-group .btn--primary {
  background: linear-gradient(180deg,#3b82f6,#2563eb);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.08);
}
.header-ctas .btn--ghost, .cta-group .btn--ghost {
  background: rgba(255,255,255,0.06);
  color: #e6efff;
  border: 1px solid rgba(255,255,255,0.08);
}

/* Hide literal "Menu" label on desktop; show on mobile */
.header-menu-label { display: none; }
@media (max-width: 1024px) {
  .primary-nav, .main-nav { display: none; }
  .header-menu-label { display: inline-flex; }
}

/* Give the hero some breathing room below sticky header */
.hero, .masthead { padding-top: 18px; }


/* === Rollback header polish; only hide 'Menu' text on desktop === */
.header-menu-label {
  display: none !important;
}
@media (max-width: 1024px) {
  .header-menu-label {
    display: inline-flex !important;
  }
}


/* === Fix: hide 'Menu' label on desktop, show on mobile only === */
.menu-label{ display:none !important; }
@media (max-width:1024px){
  .menu-label{ display:inline-flex !important; align-items:center; gap:6px; }
}

/* === Fix: add breathing room below sticky header === */
.hero{ padding-top: 24px; }
@media (min-width:1025px){
  .hero{ padding-top: 32px; }
}


/* === Add breathing room at very top of page === */
.site-header, header, .topbar {
  padding-top: 12px !important;
  box-sizing: border-box;
}


/* === Adjusted top padding for header === */
.site-header, header, .topbar {
  padding-top: 12px !important;
}
@media (min-width: 1025px){
  .site-header, header, .topbar {
    padding-top: 30px !important;
  }
}


/* === Header polish v2 === */

/* Softer top padding */
.site-header, header, .topbar {
  padding-top: 12px !important;
  box-sizing: border-box;
  box-shadow: 0 2px 8px rgba(0,0,0,0.35); /* subtle bottom shadow */
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
@media (min-width: 1025px){
  .site-header, header, .topbar {
    padding-top: 24px !important;
  }
}

/* Normalize CTA button heights */
.header-ctas .btn, .cta-group .btn {
  height: 36px !important;
  line-height: 36px !important;
  padding: 0 14px !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
}


/* === Header refinement: subtle separation + balanced spacing === */
.site-header, header, .topbar {
  /* subtle bottom border + soft shadow to separate from hero */
  border-bottom: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 6px 16px rgba(0,0,0,0.18);
  padding-top: 12px; /* mobile/base */
}
@media (min-width:1025px){
  .site-header, header, .topbar { padding-top: 24px; } /* desktop breathing room */
}

/* Normalize header CTA button sizing so the bar feels less busy */
.site-header .btn, header .btn, .topbar .btn,
.header-ctas .btn, .cta-group .btn {
  height: 36px;
  padding: 0 12px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}


/* === Refine CTAs and hero spacing === */

/* Darken CTA buttons (less neon, more balanced) */
.site-header .btn--primary, header .btn--primary, .topbar .btn--primary {
  background: linear-gradient(180deg,#2563eb,#1d4ed8); /* deeper blue */
  color: #fff;
}

/* Add extra breathing room below header before hero headline */
.hero {
  padding-top: 42px !important; /* bump up from 32px to 42px */
}
