
:root{--accent:#2f55ff;--ink:#eee;--muted:#aaa;--bg:#000}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Ubuntu,Cantarell,"Helvetica Neue",Arial,sans-serif;color:var(--ink);background:var(--bg)}
img{max-width:100%;height:auto;display:block;border-radius:10px}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.site-header{position:relative;top:0;background:#000;border-bottom:1px solid #111;z-index:50}
.site-header .container{display:flex;align-items:center;gap:16px;min-height:220px}
.logo .brand-logo{height:220px;width:auto;display:block} /* bigger, one-line logo */
.nav{display:flex;gap:14px;margin-left:auto;align-items:center;flex-wrap:wrap}
.nav a{color:#ddd}
.btn{display:inline-block;padding:.8rem 1.1rem;border-radius:10px;background:var(--accent);color:#fff;font-weight:700}
.btn:hover{text-decoration:none;filter:brightness(1.05)}
.btn.small{padding:.5rem .7rem;font-size:.9rem}
.btn.outline{background:transparent;border:2px solid var(--accent);color:#fff}
.burger{display:none;margin-left:auto;background:none;border:none;font-size:22px;color:#fff}
.hero{padding:42px 0;background:#000}
.hero .container{display:grid;gap:24px;grid-template-columns:1.1fr .9fr;align-items:center}
.hero h1{font-size:clamp(28px,4.5vw,44px);margin:0 0 8px}
.trust{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 14px;padding-left:0;margin:16px 0 0;list-style:none;color:var(--muted)}
.cta-row{display:flex;gap:12px;margin-top:10px}
.services{padding:40px 0;background:#0a0a0a}
.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.card{background:#111;border:1px solid #1a1a1a;border-radius:12px;padding:14px;display:block;text-align:center}
.card h3{margin:.6rem 0 .2rem;font-size:1.1rem;color:#fff}
.card p{color:#cfcfcf}
.page{padding:28px 0}
.row{display:grid;grid-template-columns:120px 1fr;gap:14px;align-items:start}
.row img{border-radius:14px}
.kicker{color:#9ab0ff;font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;margin-bottom:4px}
.content{padding:16px 0}
.site-footer{padding:32px 0;background:#000;color:#bbb;margin-top:32px}
.site-footer a{color:#fff}
.copy{margin-top:10px;color:#888}
.sticky-cta{position:fixed;right:16px;bottom:16px;padding:.9rem 1.1rem;border-radius:999px;background:var(--accent);color:#fff;font-weight:700;box-shadow:0 6px 20px rgba(0,0,0,.15)}
label{display:block;margin:.6rem 0 .2rem;font-weight:600}
input,textarea{width:100%;padding:.8rem;border-radius:10px;border:1px solid #222;background:#0f0f10;color:#eee}
@media (max-width: 920px){.hero .container{grid-template-columns:1fr}.cards{grid-template-columns:repeat(2,minmax(0,1fr))}.row{grid-template-columns:1fr}}
@media (max-width: 560px){.nav{display:none;position:absolute;top:96px;left:0;right:0;background:#000;border-bottom:1px solid #111;padding:10px 20px}.burger{display:block}.cards{grid-template-columns:1fr}}


/* Adjustments for bigger logo */
@media (max-width: 1024px){
  .site-header .container{
    flex-wrap: wrap;
    justify-content: center;
  }
  .nav{
    margin-left: 0;
    margin-top: 10px;
    justify-content: center;
    width: 100%;
  }
}


/* Service icon sizing */
.card img[alt$="icon"]{width:120px;height:120px}
.svc-icon{width:72px;height:72px;border-radius:14px;}

/* Extra breathing room for larger logo */
@media (max-width: 1200px){
  .site-header .container{flex-wrap:wrap;justify-content:center}
  .nav{margin-left:0;margin-top:10px;justify-content:center;width:100%}
}


/* Sections for homepage */
.section{padding:40px 0}
.section.alt{background:#0a0a0a}
.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center}
@media(max-width:920px){.grid-2{grid-template-columns:1fr}}
.bullets{list-style:none;padding-left:0;margin:10px 0 0;color:#cfcfcf}
.bullets li{margin:4px 0}
.caption{color:#9aa3b2;font-size:.9rem;margin-top:8px}
.why{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.why .card{min-height:160px;text-align:left}
.cta-band{background:#111;border:1px solid #1a1a1a;border-radius:12px;padding:18px;display:flex;justify-content:space-between;align-items:center;gap:16px}
@media(max-width:720px){.cta-band{flex-direction:column;align-items:flex-start}}
.footer-columns{display:grid;grid-template-columns:2fr 1fr 1fr;gap:20px}
@media(max-width:920px){.footer-columns{grid-template-columns:1fr}}


/* Material Symbols service icons */
.svc-icon{
  display:block;
  margin:10px auto;
  font-variation-settings: 'FILL' 0, 'wght' 700, 'GRAD' 0, 'opsz' 48;
  font-size:64px;
  line-height:1;
  color:#e6e6e6;
}



/* Safeguard: if icon name falls back to text, prevent layout break */
.svc-icon{max-width:96px; text-align:center; white-space:nowrap; overflow:hidden;}



/* --- Mobile-first enhancements --- */
@media (max-width: 1024px){
  .hero .container{grid-template-columns:1fr!important}
}
/* Touch-friendly buttons */
.btn{min-height:44px;padding:.9rem 1.2rem}
/* Sticky mobile CTA */
@media (max-width: 767px){
  .sticky-cta{
    position:fixed;left:16px;right:16px;bottom:16px;z-index:9999;
    display:flex;gap:10px;justify-content:center
  }
  .sticky-cta .btn{flex:1;text-align:center}
}
/* Badge styling */
.badge-open{
  display:inline-block;background:#111;border:1px solid #222;border-radius:999px;
  padding:6px 12px;color:#fff;font-weight:600;margin:4px 0 8px;
}



/* --- Hero minimization + optional shrink on scroll --- */
.hero{padding:16px 0}
.hero h1{font-size:clamp(24px,4vw,38px)}
/* Fallback for sites without explicit .hero class: compress first section */
body .section:first-of-type{padding-top:16px;padding-bottom:16px}
/* On scroll, compress hero further */
.compact-hero .hero{padding:6px 0}
.compact-hero .hero h1{font-size:clamp(22px,3.6vw,34px)}
.compact-hero .section:first-of-type{padding-top:6px;padding-bottom:6px}
.compact-hero .media img{max-height:220px;object-fit:cover}


/* Services dropdown */
.dropdown{position:relative;display:inline-block}
.dropbtn{padding:6px 8px;display:inline-block}
.dropdown-content{
  display:none;position:absolute;background:#0a0a0a;border:1px solid #1a1a1a;border-radius:10px;
  min-width:180px;z-index:100;box-shadow:0 6px 20px rgba(0,0,0,.25);padding:6px
}
.dropdown-content a{display:block;padding:8px 10px;color:#ddd}
.dropdown:hover .dropdown-content{display:block}
@media (max-width: 560px){
  .dropdown{width:100%}
  .dropdown-content{position:static;box-shadow:none;border:none;padding:0;margin-top:4px}
}

/* Mobile logo aspect + tighter hero */
@media (max-width: 767px){
  .logo .brand-logo{height:auto; max-height:110px; width:auto}
  .site-header .container{min-height:unset}
  .hero{padding:12px 0}
}
/* Anchor offset helper */
[id]{scroll-margin-top: 80px}


/* Pricing table polish */
table th, table td{padding:10px 12px;border-bottom:1px solid #1b1b1b}
table thead th{border-bottom:2px solid #333}



/* Mobile layout fixes */
@media (max-width: 767px){
  /* Why Choose grid: 2 columns on phones */
  .why{grid-template-columns:1fr 1fr !important; gap:10px}
  .why .card h3{font-size:16px; line-height:1.25}
  .why .card p{font-size:13px; line-height:1.45}

  /* Uniform mobile nav layout */
  .nav{display:flex; flex-direction:column; align-items:stretch; gap:0}
  .nav a{display:block; width:100%; padding:12px 10px; border-top:1px solid #1a1a1a}
  .dropdown{width:100%}
  .dropdown-content{position:static; display:block; border:none; box-shadow:none; padding:0}
  .dropdown-content a{padding:12px 10px; border-top:1px solid #1a1a1a}
}



/* Larger logo sizing */
.logo .brand-logo{height:auto; max-height:220px; width:auto}
@media (max-width: 1199px){ .logo .brand-logo{max-height:180px} }
@media (max-width: 767px){ .logo .brand-logo{max-height:140px} }



/* Reduced hero padding */
.hero{padding:20px 0 !important}
@media (max-width: 767px){
  .hero{padding:12px 0 !important}
}



/* Mobile nav toggle */
@media (max-width: 767px){
  .menu-toggle{
    display:inline-flex;align-items:center;gap:8px;
    padding:10px 12px;border:1px solid #222;border-radius:10px;background:#0f0f0f;color:#fff;
    font-weight:600
  }
  .nav{display:none !important; flex-direction:column; align-items:stretch; width:100%}
  .nav.nav--open{display:flex !important}
  .nav a, .dropdown-content a{display:block;width:100%;padding:12px 10px;border-top:1px solid #1a1a1a}
  /* Center logo block and header content */
  .site-header .container{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px}
  .logo{display:flex;justify-content:center;align-items:center;width:100%}
}

