/* Freedom Portable Toilet - Global Styles */
:root{
  --navy:#0b2545;
  --navy-2:#13315c;
  --red:#c8102e;
  --red-dark:#a30d24;
  --gold:#f0b323;
  --light:#f4f6fb;
  --text:#1a2238;
  --muted:#5b6478;
  --border:#e3e7ef;
  --white:#ffffff;
  --max:1200px;
  --shadow:0 6px 20px rgba(11,37,69,.08);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:hidden}
body{font-family:'Inter','Helvetica Neue',Arial,sans-serif;color:var(--text);line-height:1.6;background:#fff;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy);text-decoration:none}
a:hover{color:var(--red)}
h1,h2,h3,h4{font-family:'Inter','Helvetica Neue',Arial,sans-serif;color:var(--navy);line-height:1.2;margin:0 0 .6em}
h1{font-size:clamp(2rem,4.6vw,3.4rem);font-weight:900;letter-spacing:-.5px}
h2{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:800}
h3{font-size:1.25rem;font-weight:700}
p{margin:0 0 1em}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.btn{display:inline-block;padding:14px 26px;border-radius:6px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;font-size:.95rem;border:0;cursor:pointer;transition:transform .15s ease,background .15s ease}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-dark);color:#fff;transform:translateY(-1px)}
.btn-secondary{background:var(--navy);color:#fff}
.btn-secondary:hover{background:var(--navy-2);color:#fff}
.btn-ghost{background:transparent;color:#fff;border:2px solid #fff}
.btn-ghost:hover{background:#fff;color:var(--navy)}

/* ====== HEADER ====== */
.topbar{background:var(--navy);color:#fff;font-size:.85rem}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:8px 20px;max-width:var(--max);margin:0 auto;gap:10px;flex-wrap:wrap}
.topbar a{color:#fff}
.topbar .phone{font-weight:700;color:var(--gold)}
.site-header{position:sticky;top:0;z-index:1000;background:#fff;box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;max-width:var(--max);margin:0 auto;gap:14px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand img{height:54px;width:auto}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-weight:900;color:var(--navy);font-size:1.05rem;letter-spacing:.3px}
.brand-tag{font-size:.72rem;color:var(--red);font-weight:700;letter-spacing:.8px;text-transform:uppercase}

/* Desktop Nav */
.main-nav{display:flex;align-items:center;gap:4px;margin-left:auto}
.main-nav > ul{display:flex;list-style:none;margin:0;padding:0;gap:2px}
.main-nav > ul > li{position:relative}
.main-nav > ul > li > a{display:block;padding:14px 12px;font-weight:600;color:var(--navy);font-size:.93rem;border-radius:4px}
.main-nav > ul > li > a:hover,.main-nav > ul > li.active > a{color:var(--red)}
.has-dropdown > a::after{content:" ▾";font-size:.7em;color:var(--muted)}
.dropdown{position:absolute;top:100%;left:0;background:#fff;list-style:none;padding:8px 0;margin:0;min-width:230px;box-shadow:0 10px 30px rgba(0,0,0,.12);border-top:3px solid var(--red);border-radius:0 0 6px 6px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.15s ease;z-index:1100}
.has-dropdown:hover > .dropdown,.has-dropdown:focus-within > .dropdown,.has-dropdown.open > .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li a{display:block;padding:10px 18px;color:var(--text);font-size:.9rem;font-weight:500;white-space:nowrap}
.dropdown li a:hover{background:var(--light);color:var(--red)}

.call-cta{display:flex;align-items:center;gap:8px;background:var(--red);color:#fff;padding:11px 18px;border-radius:6px;font-weight:800;font-size:.95rem;margin-left:10px;white-space:nowrap}
.call-cta:hover{background:var(--red-dark);color:#fff}
.call-cta .ico{font-size:1.1em}

/* Mobile Toggle */
.menu-toggle{display:none;background:var(--navy);color:#fff;border:0;padding:10px 14px;border-radius:6px;font-size:1.4rem;cursor:pointer;line-height:1}

@media (max-width:980px){
  .main-nav{position:fixed;top:0;right:-100%;width:min(86%,360px);height:100vh;background:#fff;flex-direction:column;align-items:stretch;padding:80px 0 30px;overflow-y:auto;box-shadow:-10px 0 30px rgba(0,0,0,.15);transition:right .3s ease;z-index:1500;margin:0}
  .main-nav.open{right:0}
  .main-nav > ul{flex-direction:column;width:100%;gap:0}
  .main-nav > ul > li{border-bottom:1px solid var(--border)}
  .main-nav > ul > li > a{padding:14px 22px;font-size:1rem}
  .has-dropdown > a{display:flex;justify-content:space-between;align-items:center}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-top:0;background:var(--light);padding:0;display:none;min-width:0}
  .has-dropdown.open > .dropdown{display:block}
  .dropdown li a{padding:11px 36px;font-size:.9rem}
  .menu-toggle{display:inline-block}
  .nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;visibility:hidden;transition:.25s;z-index:1400}
  .nav-overlay.show{opacity:1;visibility:visible}
  .call-cta{padding:9px 12px;font-size:.85rem;margin-left:6px}
  .call-cta .label{display:none}
  .brand-text{display:none}
  .brand img{height:46px}
}
@media (max-width:380px){
  .call-cta{padding:8px 10px}
}

/* ====== HERO ====== */
.hero{position:relative;color:#fff;background:linear-gradient(rgba(11,37,69,.78),rgba(11,37,69,.78)),url('../images/hero.jpg') center/cover no-repeat;padding:80px 0 90px;text-align:center}
.hero h1{color:#fff;max-width:900px;margin-inline:auto}
.hero p.lead{font-size:1.2rem;max-width:760px;margin:0 auto 30px;opacity:.95}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-badges{display:flex;justify-content:center;gap:30px;margin-top:38px;flex-wrap:wrap;opacity:.95;font-size:.95rem}
.hero-badges span{display:inline-flex;align-items:center;gap:6px}
.page-hero{background:linear-gradient(rgba(11,37,69,.85),rgba(11,37,69,.85)),url('../images/location.jpg') center/cover no-repeat;color:#fff;padding:60px 0;text-align:center}
.page-hero h1{color:#fff}
.page-hero p{max-width:780px;margin:0 auto;opacity:.95;font-size:1.1rem}

/* ====== SECTIONS ====== */
section{padding:64px 0}
.section-light{background:var(--light)}
.section-dark{background:var(--navy);color:#fff}
.section-dark h2,.section-dark h3{color:#fff}
.section-title{text-align:center;margin-bottom:14px}
.section-sub{text-align:center;color:var(--muted);max-width:720px;margin:0 auto 40px;font-size:1.05rem}
.section-dark .section-sub{color:#cdd6e3}

.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:880px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid-3,.grid-4,.grid-2{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(11,37,69,.14)}
.card img{width:100%;height:200px;object-fit:cover}
.card-body{padding:22px;flex:1;display:flex;flex-direction:column}
.card-body h3{margin-bottom:10px}
.card-body p{color:var(--muted);font-size:.95rem;flex:1}
.card-body .more{margin-top:14px;font-weight:700;color:var(--red)}

.feature{padding:26px;background:#fff;border-radius:10px;border:1px solid var(--border)}
.feature .icon{width:48px;height:48px;border-radius:8px;background:var(--navy);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:14px;font-weight:800}

/* CTA Strip */
.cta-strip{background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);color:#fff;padding:50px 0;text-align:center}
.cta-strip h2{color:#fff;margin-bottom:10px}
.cta-strip p{margin-bottom:24px;opacity:.95;font-size:1.05rem}
.cta-strip .btn-secondary{background:#fff;color:var(--red)}
.cta-strip .btn-secondary:hover{background:var(--navy);color:#fff}

/* FAQ */
.faq{max-width:860px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:8px;margin-bottom:12px;overflow:hidden}
.faq-q{width:100%;text-align:left;padding:18px 22px;background:#fff;border:0;font-weight:700;font-size:1.02rem;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px}
.faq-q::after{content:"+";font-size:1.5rem;color:var(--red);transition:transform .2s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{padding:0 22px;max-height:0;overflow:hidden;transition:max-height .25s ease,padding .25s ease;color:var(--text)}
.faq-item.open .faq-a{padding:0 22px 18px;max-height:600px}

/* Lists */
.checklist{list-style:none;padding:0;margin:0 0 1.4em}
.checklist li{padding-left:30px;position:relative;margin-bottom:10px}
.checklist li::before{content:"✓";position:absolute;left:0;top:0;color:var(--red);font-weight:900}

/* Two-col content */
.two-col{display:grid;grid-template-columns:1.05fr 1fr;gap:50px;align-items:center}
@media (max-width:880px){.two-col{grid-template-columns:1fr}}
.two-col img{border-radius:10px;box-shadow:var(--shadow)}

/* Testimonial */
.tcard{background:#fff;border-left:4px solid var(--red);padding:24px;border-radius:8px;box-shadow:var(--shadow);height:100%}
.tcard p{font-style:italic;color:var(--text)}
.tcard .who{margin-top:14px;font-weight:700;color:var(--navy);font-style:normal}
.tcard .who small{display:block;font-weight:500;color:var(--muted);font-size:.85rem}

/* Form */
form.contact-form{background:#fff;padding:30px;border-radius:10px;box-shadow:var(--shadow);display:grid;gap:14px}
form.contact-form label{font-weight:600;font-size:.9rem;color:var(--navy)}
form.contact-form input,form.contact-form select,form.contact-form textarea{padding:12px 14px;border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:1rem;width:100%}
form.contact-form input:focus,form.contact-form select:focus,form.contact-form textarea:focus{outline:2px solid var(--red);border-color:var(--red)}
form.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:600px){form.contact-form .row{grid-template-columns:1fr}}
.form-success{display:none;padding:16px;background:#e6f7ec;color:#0a6b34;border-radius:6px;font-weight:600;margin-bottom:14px}

/* Tag pills */
.pill-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.pill{background:#fff;border:1px solid var(--border);padding:10px 16px;border-radius:50px;font-weight:600;color:var(--navy);font-size:.92rem;transition:.15s}
.pill:hover{background:var(--red);color:#fff;border-color:var(--red)}

/* Footer */
.site-footer{background:#0a1d39;color:#cdd6e3;padding:60px 0 0;font-size:.93rem}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.site-footer a{color:#cdd6e3;display:block;padding:4px 0}
.site-footer a:hover{color:var(--gold)}
.site-footer .brand-name{color:#fff}
.site-footer .footer-bottom{margin-top:40px;border-top:1px solid #1c3358;padding:18px 0;text-align:center;font-size:.85rem;color:#8b9bb3}
.site-footer .footer-phone{font-size:1.4rem;font-weight:800;color:var(--gold);margin:8px 0}
.site-footer address{font-style:normal;line-height:1.7}

/* Map */
.map-wrap{border-radius:10px;overflow:hidden;box-shadow:var(--shadow);height:380px}
.map-wrap iframe{width:100%;height:100%;border:0}

/* Tables */
table.simple{width:100%;border-collapse:collapse;margin:1em 0;background:#fff;box-shadow:var(--shadow);border-radius:8px;overflow:hidden}
table.simple th,table.simple td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}
table.simple th{background:var(--navy);color:#fff;font-weight:700}
table.simple tr:last-child td{border-bottom:0}

/* Content prose */
.prose{max-width:820px;margin:0 auto}
.prose h2{margin-top:1.6em}
.prose h3{margin-top:1.4em}
.prose ul{padding-left:1.2em}
.prose li{margin-bottom:.4em}

/* Skip link */
.skip{position:absolute;left:-9999px}
.skip:focus{left:10px;top:10px;background:#fff;padding:8px;z-index:9999}
