/* Courtnevaro Co. — Portable Sanitation */
:root{
  --blue:#1a73e8;
  --blue-dark:#0b4ea2;
  --blue-light:#e8f1fc;
  --charcoal:#1f2937;
  --charcoal-soft:#374151;
  --gray:#6b7280;
  --gray-light:#f3f4f6;
  --white:#ffffff;
  --border:#e5e7eb;
  --shadow:0 4px 14px rgba(15,23,42,.08);
  --shadow-lg:0 12px 32px rgba(15,23,42,.12);
  --radius:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',-apple-system,BlinkMacSystemFont,Roboto,Arial,sans-serif;color:var(--charcoal);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{color:var(--blue-dark)}
.container{max-width:1180px;margin:0 auto;padding:0 20px}

/* Top bar */
.topbar{background:var(--charcoal);color:#cbd5e1;font-size:.85rem;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.topbar a{color:#cbd5e1}
.topbar a:hover{color:#fff}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,.04)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:48px;width:auto}
.logo-text{font-weight:800;font-size:1.15rem;color:var(--charcoal);line-height:1.1}
.logo-text span{display:block;font-weight:500;font-size:.75rem;color:var(--gray);letter-spacing:.5px}
nav.main-nav ul{list-style:none;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
nav.main-nav a{display:inline-block;padding:8px 12px;color:var(--charcoal);font-weight:500;border-radius:6px;font-size:.95rem}
nav.main-nav a:hover,nav.main-nav a.active{background:var(--blue-light);color:var(--blue-dark)}
.header-cta{display:flex;gap:8px;align-items:center}
.btn{display:inline-block;padding:11px 20px;border-radius:var(--radius);font-weight:600;text-align:center;border:2px solid transparent;cursor:pointer;transition:all .2s ease;font-size:.95rem;line-height:1.2}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--blue-dark);border-color:var(--blue-dark);color:#fff;transform:translateY(-1px)}
.btn-outline{background:#fff;color:var(--blue);border-color:var(--blue)}
.btn-outline:hover{background:var(--blue);color:#fff}
.btn-call{background:#16a34a;color:#fff;border-color:#16a34a}
.btn-call:hover{background:#15803d;border-color:#15803d;color:#fff}
.menu-toggle{display:none;background:none;border:0;font-size:1.6rem;color:var(--charcoal);cursor:pointer}

/* Hero */
.hero{position:relative;background:linear-gradient(135deg,rgba(11,78,162,.85),rgba(31,41,55,.7)),url('../images/hero.jpg') center/cover no-repeat;color:#fff;padding:90px 0 100px;text-align:center}
.hero h1{font-size:2.8rem;line-height:1.15;margin-bottom:18px;font-weight:800}
.hero p.lead{font-size:1.2rem;max-width:780px;margin:0 auto 28px;color:#e2e8f0}
.hero .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero .trust{margin-top:32px;display:flex;gap:28px;justify-content:center;flex-wrap:wrap;color:#dbeafe;font-size:.95rem}
.hero .trust span::before{content:"✓ ";color:#86efac;font-weight:700}

/* Page hero (smaller) */
.page-hero{background:linear-gradient(135deg,var(--blue-dark),var(--charcoal));color:#fff;padding:64px 0 56px;text-align:center}
.page-hero h1{font-size:2.2rem;margin-bottom:10px}
.page-hero p{color:#cbd5e1;max-width:720px;margin:0 auto}
.breadcrumb{font-size:.9rem;color:#93c5fd;margin-top:14px}
.breadcrumb a{color:#bfdbfe}

/* Sections */
section{padding:72px 0}
.section-head{text-align:center;max-width:760px;margin:0 auto 48px}
.section-head h2{font-size:2.1rem;color:var(--charcoal);margin-bottom:12px}
.section-head p{color:var(--gray);font-size:1.05rem}
.eyebrow{display:inline-block;background:var(--blue-light);color:var(--blue-dark);font-weight:700;font-size:.78rem;letter-spacing:1.2px;text-transform:uppercase;padding:5px 12px;border-radius:20px;margin-bottom:14px}

/* Grid features */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* Feature cards */
.feature{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:all .25s ease}
.feature:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--blue)}
.feature .icon{width:52px;height:52px;border-radius:12px;background:var(--blue-light);color:var(--blue-dark);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px;font-weight:700}
.feature h3{font-size:1.15rem;margin-bottom:8px;color:var(--charcoal)}
.feature p{color:var(--gray);font-size:.95rem}

/* Service cards */
.service-card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);transition:all .25s ease;display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.service-card img{width:100%;height:220px;object-fit:cover}
.service-card .body{padding:22px;flex:1;display:flex;flex-direction:column}
.service-card h3{font-size:1.25rem;color:var(--charcoal);margin-bottom:8px}
.service-card p{color:var(--gray);margin-bottom:14px;flex:1}
.service-card a.more{font-weight:600;color:var(--blue);align-self:flex-start}

/* About split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.split h2{font-size:2rem;margin-bottom:14px;color:var(--charcoal)}
.split ul{list-style:none;margin-top:18px}
.split ul li{padding:8px 0 8px 28px;position:relative;color:var(--charcoal-soft)}
.split ul li::before{content:"✓";position:absolute;left:0;top:8px;color:var(--blue);font-weight:800}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;padding:56px 0;text-align:center}
.cta-band h2{font-size:2rem;margin-bottom:10px}
.cta-band p{color:#dbeafe;margin-bottom:24px;font-size:1.1rem}
.cta-band .btn-outline{background:transparent;color:#fff;border-color:#fff}
.cta-band .btn-outline:hover{background:#fff;color:var(--blue-dark)}

/* Areas */
.areas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.area-tile{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;transition:all .2s;display:flex;align-items:center;gap:10px;color:var(--charcoal-soft);font-weight:500}
.area-tile:hover{border-color:var(--blue);background:var(--blue-light);color:var(--blue-dark);transform:translateX(3px)}
.area-tile::before{content:"📍";font-size:1rem}

/* Testimonials */
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.testimonial .stars{color:#f59e0b;margin-bottom:12px;font-size:1.1rem}
.testimonial p.quote{font-style:italic;color:var(--charcoal-soft);margin-bottom:16px}
.testimonial .author{font-weight:700;color:var(--charcoal)}
.testimonial .role{font-size:.85rem;color:var(--gray)}

/* FAQ */
.faq{max-width:860px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;margin-bottom:12px;transition:all .2s}
.faq details[open]{border-color:var(--blue);box-shadow:var(--shadow)}
.faq summary{font-weight:600;color:var(--charcoal);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:1.02rem}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--blue);font-weight:300;transition:transform .2s}
.faq details[open] summary::after{content:"–"}
.faq details p{margin-top:12px;color:var(--gray);line-height:1.65}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.contact-info{background:var(--gray-light);padding:30px;border-radius:var(--radius)}
.contact-info h3{margin-bottom:18px;color:var(--charcoal)}
.info-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.info-item:last-child{border-bottom:0}
.info-item .ic{width:40px;height:40px;background:var(--blue);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700}
.info-item strong{display:block;color:var(--charcoal);margin-bottom:2px}
.info-item span,.info-item a{color:var(--charcoal-soft);font-size:.95rem}
form.contact-form{background:#fff;padding:30px;border-radius:var(--radius);border:1px solid var(--border)}
form.contact-form h3{margin-bottom:18px;color:var(--charcoal)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-weight:500;margin-bottom:6px;font-size:.92rem;color:var(--charcoal-soft)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:.95rem;background:#fff;transition:border .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,115,232,.15)}
.form-group textarea{resize:vertical;min-height:110px}
.map-wrap{margin-top:48px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border)}
.map-wrap iframe{display:block;width:100%;height:420px;border:0}

/* Legal pages */
.legal-content{max-width:860px;margin:0 auto}
.legal-content h2{margin:34px 0 12px;color:var(--charcoal);font-size:1.4rem}
.legal-content h3{margin:22px 0 8px;color:var(--charcoal-soft);font-size:1.1rem}
.legal-content p,.legal-content ul{margin-bottom:14px;color:var(--charcoal-soft)}
.legal-content ul{padding-left:22px}
.legal-content ul li{margin-bottom:6px}

/* Footer */
footer{background:var(--charcoal);color:#cbd5e1;padding:64px 0 24px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
footer h4{color:#fff;font-size:1.05rem;margin-bottom:16px;font-weight:700}
footer ul{list-style:none}
footer ul li{margin-bottom:8px}
footer a{color:#cbd5e1;font-size:.93rem}
footer a:hover{color:#fff}
footer .brand p{margin-top:12px;font-size:.93rem;color:#94a3b8;line-height:1.7}
.footer-bottom{border-top:1px solid #374151;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.88rem;color:#94a3b8}
.footer-bottom a{color:#94a3b8}

/* Floating call button mobile */
.float-call{display:none;position:fixed;bottom:18px;right:18px;background:#16a34a;color:#fff;width:58px;height:58px;border-radius:50%;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 6px 20px rgba(22,163,74,.45);z-index:200}

/* Responsive */
@media (max-width:960px){
  .grid-3,.grid-4,.testimonial-grid{grid-template-columns:repeat(2,1fr)}
  .split,.contact-grid{grid-template-columns:1fr;gap:30px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .hero h1{font-size:2.1rem}
  .hero p.lead{font-size:1.05rem}
}
@media (max-width:720px){
  .menu-toggle{display:block}
  nav.main-nav{position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow);max-height:0;overflow:hidden;transition:max-height .3s ease}
  nav.main-nav.open{max-height:600px}
  nav.main-nav ul{flex-direction:column;gap:0;padding:10px 16px;align-items:stretch}
  nav.main-nav a{padding:12px 14px;display:block;border-bottom:1px solid var(--border)}
  .header-cta .btn-outline{display:none}
  .grid-2,.grid-3,.grid-4,.testimonial-grid,.form-row,.footer-grid{grid-template-columns:1fr}
  .hero{padding:60px 0 70px}
  .hero h1{font-size:1.75rem}
  section{padding:54px 0}
  .float-call{display:flex}
  .topbar{font-size:.78rem;text-align:center}
  .topbar .container{justify-content:center}
}
