/* Starcel Waterproofing & Restoration — main stylesheet */
:root{
  --navy:#0e2a47;
  --navy-2:#143a61;
  --navy-dark:#091d33;
  --gray-900:#1f2937;
  --gray-700:#374151;
  --gray-600:#4b5563;
  --gray-500:#6b7280;
  --gray-300:#d1d5db;
  --gray-200:#e5e7eb;
  --gray-100:#f3f4f6;
  --gray-50:#f8fafc;
  --white:#ffffff;
  --accent:#b8c4d2;
  --border:#e2e6ec;
  --shadow:0 1px 3px rgba(15,30,55,.06), 0 1px 2px rgba(15,30,55,.04);
  --shadow-md:0 4px 12px rgba(15,30,55,.08);
  --radius:4px;
  --max:1140px;
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--gray-900);
  background:var(--white);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--navy);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3,h4{font-family:var(--font-sans);color:var(--navy);line-height:1.25;margin:0 0 .6em}
h1{font-size:2.1rem;font-weight:700;letter-spacing:-.01em}
h2{font-size:1.6rem;font-weight:700}
h3{font-size:1.2rem;font-weight:600}
p{margin:0 0 1em;color:var(--gray-700)}
ul{padding-left:1.2rem}
li{margin-bottom:.35em;color:var(--gray-700)}

.container{max-width:var(--max);margin:0 auto;padding:0 20px}

/* Top bar */
.topbar{background:var(--navy-dark);color:#cbd5e1;font-size:.82rem;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.topbar a{color:#e6eaf0}
.topbar .left span{margin-right:18px}

/* Header / nav */
.site-header{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;gap:16px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand:hover{text-decoration:none}
.brand-mark{width:38px;height:38px;background:var(--navy);color:var(--white);border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;letter-spacing:.5px}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-weight:700;color:var(--navy);font-size:1.02rem}
.brand-sub{font-size:.72rem;color:var(--gray-500);letter-spacing:.05em;text-transform:uppercase}

.nav{display:flex;align-items:center;gap:4px}
.nav a{padding:8px 12px;color:var(--gray-700);font-size:.94rem;border-radius:3px}
.nav a:hover{color:var(--navy);background:var(--gray-100);text-decoration:none}
.nav a.active{color:var(--navy);font-weight:600}
.nav-cta{margin-left:8px;background:var(--navy);color:#fff !important;padding:8px 14px;border-radius:3px;font-weight:600}
.nav-cta:hover{background:var(--navy-2);text-decoration:none}

.menu-toggle{display:none;background:none;border:1px solid var(--border);padding:8px 10px;border-radius:3px;cursor:pointer;color:var(--navy)}

/* Hero */
.hero{background:linear-gradient(180deg,#f5f7fa 0%, #ffffff 100%);border-bottom:1px solid var(--border);padding:56px 0}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.hero h1{font-size:2.4rem;margin-bottom:14px}
.hero .lead{font-size:1.1rem;color:var(--gray-700);margin-bottom:24px}
.hero-meta{display:flex;flex-wrap:wrap;gap:18px;color:var(--gray-600);font-size:.92rem;margin-top:18px}
.hero-meta span::before{content:"•";color:var(--navy);margin-right:8px}
.hero-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border)}
.hero-img img{aspect-ratio:4/3;object-fit:cover;width:100%}

/* Buttons */
.btn{display:inline-block;padding:11px 20px;border-radius:3px;font-weight:600;font-size:.95rem;text-decoration:none;border:1px solid transparent;cursor:pointer;transition:background .15s ease,color .15s ease}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-2);text-decoration:none;color:#fff}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff;text-decoration:none}
.btn-row{display:flex;gap:12px;flex-wrap:wrap}

/* Sections */
section{padding:56px 0}
.section-alt{background:var(--gray-50);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.section-head{max-width:760px;margin:0 auto 36px;text-align:center}
.section-head .eyebrow{display:inline-block;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);font-weight:600;margin-bottom:10px}
.section-head h2{font-size:1.8rem;margin-bottom:10px}
.section-head p{color:var(--gray-600)}

/* Service grid */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:border-color .15s ease, box-shadow .15s ease}
.card:hover{border-color:#cdd5df;box-shadow:var(--shadow-md)}
.card h3{margin-top:0}
.card .icon{width:42px;height:42px;background:var(--gray-100);color:var(--navy);border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:14px;font-size:1.1rem}

/* Two-col content */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.split img{border-radius:var(--radius);border:1px solid var(--border)}

/* Project gallery */
.projects{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.project{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.project .thumb{aspect-ratio:4/3;background:#eef1f5;overflow:hidden}
.project .thumb img{width:100%;height:100%;object-fit:cover}
.project .body{padding:18px}
.project h3{font-size:1.05rem;margin-bottom:6px}
.project .meta{font-size:.82rem;color:var(--gray-500);margin-bottom:8px}
.project p{font-size:.94rem;margin-bottom:0}

/* Why list */
.why-list{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:24px}
.why-item{display:flex;gap:14px;align-items:flex-start}
.why-num{flex:0 0 38px;width:38px;height:38px;background:var(--navy);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.92rem}
.why-item h4{margin:0 0 4px;color:var(--navy);font-size:1rem}
.why-item p{margin:0;font-size:.94rem;color:var(--gray-600)}

/* Property tags */
.tag-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:8px}
.tag{background:#fff;border:1px solid var(--border);padding:8px 14px;border-radius:24px;color:var(--gray-700);font-size:.9rem}

/* Service area list */
.area-list{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}
.area-item{background:#fff;border:1px solid var(--border);padding:16px;border-radius:var(--radius)}
.area-item h4{margin:0 0 4px;color:var(--navy);font-size:1rem}
.area-item span{font-size:.85rem;color:var(--gray-500)}

/* FAQ */
.faq-item{border-bottom:1px solid var(--border);padding:18px 0}
.faq-item summary{cursor:pointer;font-weight:600;color:var(--navy);list-style:none;display:flex;justify-content:space-between;align-items:center;font-size:1.02rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.4rem;color:var(--gray-500);font-weight:400;margin-left:12px}
.faq-item[open] summary::after{content:"–"}
.faq-item p{margin:12px 0 0;color:var(--gray-700)}

/* Contact / form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.contact-info p{margin:0 0 8px;color:var(--gray-700)}
.contact-info strong{color:var(--navy)}
.contact-info .row{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border)}
.contact-info .row:last-child{border-bottom:none}
.contact-info .label{flex:0 0 110px;color:var(--gray-500);font-size:.88rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;padding-top:2px}

.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px}
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.form-row label{font-size:.88rem;font-weight:600;color:var(--gray-700)}
.form-row input,.form-row textarea,.form-row select{padding:10px 12px;border:1px solid var(--border);border-radius:3px;font-family:inherit;font-size:.95rem;color:var(--gray-900);background:#fff}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 2px rgba(14,42,71,.1)}
.form-row textarea{min-height:120px;resize:vertical}
.form-note{font-size:.8rem;color:var(--gray-500)}

/* CTA band */
.cta-band{background:var(--navy);color:#fff;padding:46px 0;text-align:center}
.cta-band h2{color:#fff;margin-bottom:10px}
.cta-band p{color:#cdd9e6;margin-bottom:22px}
.cta-band .btn-outline{color:#fff;border-color:#fff}
.cta-band .btn-outline:hover{background:#fff;color:var(--navy)}
.cta-band .btn-primary{background:#fff;color:var(--navy)}
.cta-band .btn-primary:hover{background:var(--accent);color:var(--navy)}

/* Footer */
.site-footer{background:#0a1f36;color:#cbd5e1;padding:48px 0 24px;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
.site-footer h4{color:#fff;font-size:.95rem;margin-bottom:14px;text-transform:uppercase;letter-spacing:.08em}
.site-footer a{color:#cbd5e1}
.site-footer a:hover{color:#fff}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:8px}
.footer-brand p{color:#94a3b8;font-size:.92rem}
.footer-bottom{margin-top:32px;padding-top:18px;border-top:1px solid #1a3553;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#94a3b8;font-size:.85rem}

/* Page header (inner pages) */
.page-header{background:var(--navy);color:#fff;padding:50px 0}
.page-header h1{color:#fff;margin-bottom:8px}
.page-header p{color:#cbd5e1;margin:0;font-size:1.05rem}
.crumbs{font-size:.85rem;color:#9fb1c7;margin-bottom:8px}
.crumbs a{color:#cbd5e1}

/* Prose */
.prose p{font-size:1rem}
.prose h2{margin-top:1.6em}
.prose h3{margin-top:1.4em}
.prose ul li{margin-bottom:.4em}

/* Service detail */
.service-block{padding:30px 0;border-bottom:1px solid var(--border)}
.service-block:last-child{border-bottom:none}
.service-block .split{gap:36px}

/* Map */
.map-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-top:14px}
.map-wrap iframe{display:block;width:100%;height:340px;border:0}

/* Utility */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}
.muted{color:var(--gray-500);font-size:.9rem}

/* Responsive */
@media (max-width: 960px){
  .hero{padding:40px 0}
  .hero-grid,.split,.contact-grid{grid-template-columns:1fr;gap:28px}
  .grid-3,.projects,.area-list{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .why-list{grid-template-columns:1fr}
  h1{font-size:1.8rem}
  .hero h1{font-size:1.9rem}
}
@media (max-width: 640px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);flex-direction:column;align-items:stretch;padding:8px;gap:0}
  .nav.open{display:flex}
  .nav a{padding:12px 14px;border-radius:0;border-bottom:1px solid var(--gray-100)}
  .nav-cta{margin:8px;text-align:center}
  .menu-toggle{display:inline-block}
  .site-header .container{position:relative}
  .grid-3,.projects,.area-list,.grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .topbar .left span{display:block;margin-right:0;margin-bottom:2px}
  section{padding:42px 0}
  .hero{padding:32px 0}
  .contact-info .row{flex-direction:column;gap:2px}
  .contact-info .label{flex:none}
}
