/* Variables & Base */
:root{--bg:#0f172a;--bg-alt:#0b1327;--card:#0e2247;--text:#e6edf7;--muted:#9fb3d1;--primary:#7c3aed;--border:rgba(255,255,255,.08)}
*{box-sizing:border-box}body{margin:0;font-family:'Nunito',system-ui,sans-serif;color:var(--text);background:linear-gradient(180deg,var(--bg),var(--bg-alt));line-height:1.6}
.container{max-width:1280px;margin:0 auto;padding:0 1.25rem}.section{padding:4.5rem 0}.alt{background:linear-gradient(180deg,rgba(255,255,255,.02),transparent)}

/* Header */
.site-header{position:sticky;top:0;background:rgba(10,16,34,.7);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}
.brand{display:flex;gap:.6rem;align-items:center;font-weight:800}.logo{width:32px;height:32px}
.nav{display:flex;gap:1rem}.nav a{color:var(--text);text-decoration:none;padding:.35rem .5rem;border-radius:.5rem}.nav a:hover{background:rgba(255,255,255,.06)}

/* Hero */
.grid-2{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:center}
.hero-title{font-size:clamp(2rem,4.2vw,3.2rem);line-height:1.15;margin:0}.hero-sub{font-weight:800;margin:.5rem 0 1rem 0;color:#c6d4f7}
.hero-body{color:var(--muted);max-width:60ch}.cta-row{display:flex;gap:.75rem;margin-top:1.25rem}
.btn{display:inline-block;border-radius:.75rem;padding:.75rem 1rem;font-weight:700;text-decoration:none;border:1px solid var(--border)}
.btn-primary{background:var(--primary);color:white;border-color:transparent}.btn-outline{background:transparent;color:var(--text)}
.hero-media{position:relative}.hero-img{width:100%;height:auto;border-radius:1.25rem;border:1px solid var(--border);box-shadow:0 10px 40px rgba(0,0,0,.45)}

/* Badges */
.badge{position:absolute;background:rgba(0,0,0,.6);border:1px solid var(--border);border-radius:1rem;padding:.6rem .8rem;display:flex;gap:.6rem;align-items:center;backdrop-filter:blur(4px)}
.badge-emoji{font-size:1.25rem} .badge-text{font-size:.9rem;line-height:1.1}
.badge-ring{width:48px;height:48px;border-radius:999px;border:3px solid #d9d9d9;display:flex;align-items:center;justify-content:center;font-weight:800;margin-right:.4rem}
.badge-tl{left:-.6rem;top:-.6rem}.badge-tr{right:-.6rem;top:-.6rem}.badge-bl{left:-.6rem;bottom:-.6rem}

/* Cards */
.section-head{text-align:center;margin-bottom:2rem}.section-head h2{margin:0 0 .25rem;font-size:clamp(1.4rem,3vw,2rem)}.section-head p{color:var(--muted)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:1rem;padding:1.25rem}
.card .icon{font-size:1.6rem}.card h3{margin:.5rem 0}

/* Steps */
.steps{list-style:none;display:grid;gap:1rem;padding:0;margin:0}
.step{display:grid;grid-template-columns:120px 1fr;gap:1rem;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:1rem;padding:1rem}
.step img{width:100%;height:90px;object-fit:cover;border-radius:.75rem;border:1px solid var(--border)}

/* Contact */
.form label{display:block;margin-top:.75rem;margin-bottom:.25rem}
.form input,.form textarea{width:100%;padding:.7rem .9rem;border-radius:.6rem;border:1px solid var(--border);background:#0a1a36;color:var(--text)}
.checkbox{display:flex;gap:.5rem;align-items:flex-start;margin:.5rem 0}.form-note{color:var(--muted);min-height:1.5rem}
.list,.hours{list-style:none;padding:0;margin:0}.hours li{display:flex;justify-content:space-between;border-bottom:1px dashed var(--border);padding:.35rem 0}
.card.contact-card{background:var(--card)}

/* Footer */
.site-footer{border-top:1px solid var(--border);padding:2rem 0;background:rgba(0,0,0,.12)}.footer-inner{display:flex;justify-content:center}

/* Responsive */
@media (max-width: 900px){.grid-2{grid-template-columns:1fr}.cards{grid-template-columns:1fr}}


/* Image Cards */
.cards-with-images{grid-template-columns:repeat(3,1fr);gap:1rem}
.card-img{width:100%;height:160px;object-fit:cover;border-radius:.75rem;border:1px solid var(--border);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.card-body{margin-top:.75rem}

/* Featured Banner */
.featured{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:1rem;padding:1rem}
.featured img{width:100%;height:260px;object-fit:cover;border-radius:.75rem;border:1px solid var(--border)}
.featured-text h3{margin:.25rem 0}
@media (max-width: 900px){
  .cards-with-images{grid-template-columns:1fr}
  .featured{grid-template-columns:1fr}
}

.eyebrow{font-size:.9rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#bde0fe;margin:0 0 .25rem 0}
.btn-cta{background:#10b981;color:#0b1327;border-color:transparent;border-radius:999px;padding:.5rem .9rem;font-weight:800} .btn-cta:hover{filter:brightness(1.05)}
.nav .btn-cta{margin-left:.25rem}

/* --- Full-bleed service images --- */
.cards-with-images .card{padding:0;overflow:hidden;border-radius:1rem;border:1px solid var(--border);background:var(--card);box-shadow:0 10px 30px rgba(0,0,0,.25)}
.cards-with-images .card-img{display:block;width:100%;aspect-ratio:16/10;height:auto;object-fit:cover;border:none;border-radius:1rem 1rem 0 0;box-shadow:none}
.cards-with-images .card-body{padding:1rem 1rem 1.2rem}
@supports not (aspect-ratio: 1 / 1){
  .cards-with-images .card-img{height:220px}
}


/* --- Bigger, dominant hero image --- */
.hero .grid-2{grid-template-columns:.9fr 1.1fr;gap:2.5rem}
.hero{padding-top:5rem;padding-bottom:3rem}
.hero-media{position:relative}
.hero-media .hero-img{display:block;width:100%;aspect-ratio:16/9;height:auto;object-fit:cover;border-radius:1.5rem;border:1px solid var(--border);box-shadow:0 20px 50px rgba(0,0,0,.45)}
@media (min-width:1400px){
  .hero-media .hero-img{aspect-ratio:21/9}
}


/* --- Service images: show more, avoid cutting --- */
.cards-with-images .card-img{aspect-ratio:4/3;object-fit:cover;object-position:center 20%}
@media (max-width: 900px){
  .cards-with-images .card-img{aspect-ratio:16/10;object-position:center}
}


/* Headline clamp fix */
@media (max-width: 420px){ .hero-title{font-size:2rem} }
