/* Endless Summer Pool Service — mobile-first styles */
:root{
  --navy:#0b3a4d;
  --blue:#0e7490;
  --aqua:#22b8cf;
  --aqua-pale:#e4f6f9;
  --cta:#dd5a2f;        /* St. George red-rock terracotta */
  --cta-dark:#bf4a24;
  --sand:#fbf7f1;
  --ink:#15262e;
  --muted:#52656e;
  --line:#e4ddd2;
  --radius:14px;
  --shadow:0 2px 10px rgba(11,58,77,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--sand);line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:var(--blue)}
h1,h2,h3{line-height:1.2;color:var(--navy)}
h2{font-size:clamp(1.45rem,3.5vw,2rem);margin-bottom:.6rem}
h3{font-size:1.15rem;margin-bottom:.4rem}
.container{width:min(1080px,100% - 2.5rem);margin-inline:auto}
.center{text-align:center;margin-top:1.4rem}
.skip-link{position:absolute;left:-9999px;top:0;background:#fff;padding:.6rem 1rem;z-index:100}
.skip-link:focus{left:0}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.5rem;border-radius:999px;font-weight:700;text-decoration:none;
  font-size:1rem;border:2px solid transparent;cursor:pointer;transition:background .15s,transform .1s;
}
.btn:active{transform:scale(.98)}
.btn-cta{background:var(--cta);color:#fff}
.btn-cta:hover{background:var(--cta-dark)}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{background:var(--aqua-pale)}
.btn-ghost{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-ghost:hover{background:var(--aqua-pale)}
.btn-call{background:var(--cta);color:#fff;white-space:nowrap}
.btn-call:hover{background:var(--cta-dark)}
.btn-block{width:100%}
.btn-block-sm{width:100%;max-width:320px}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:#fff;box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem 0}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none}
.brand-logo{height:46px;width:auto}
.brand-tag{font-size:.64rem;font-weight:700;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;line-height:1.3;max-width:90px}
@media(max-width:420px){.brand-tag{display:none}}
.nav-toggle{background:none;border:0;color:var(--navy);padding:.4rem;cursor:pointer}
.site-nav{display:none}
.site-nav.open{
  display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
  background:#fff;box-shadow:var(--shadow);padding:1rem 1.25rem;gap:.35rem;
}
.site-nav a{
  text-decoration:none;color:var(--navy);font-weight:600;padding:.55rem .25rem;border-radius:8px;
}
.site-nav a.active{color:var(--blue)}
.site-nav a:hover{color:var(--blue)}
.nav-call{padding:.6rem 1.1rem;text-align:center}

/* Hero */
.hero{
  position:relative;color:#fff;
  background:linear-gradient(160deg,var(--navy) 0%,var(--blue) 58%,var(--aqua) 115%);
  padding:3rem 0 4.2rem;
}
.hero .eyebrow{
  text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:.78rem;
  color:#bfeaf2;margin-bottom:.5rem;
}
.hero h1{color:#fff;font-size:clamp(1.85rem,5.5vw,2.9rem);max-width:21ch}
.hero-sub{margin:.9rem 0 1.4rem;font-size:1.08rem;max-width:55ch;color:#e8f6f9}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.7rem}
.chips{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.3rem}
.chips li{
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);
  padding:.32rem .8rem;border-radius:999px;font-size:.82rem;font-weight:600;
}
.hero-wave{position:absolute;bottom:-1px;left:0;width:100%;height:42px}
.hero-grid{display:grid;gap:2rem;align-items:center}
.hero-photo img{width:100%;height:300px;object-fit:cover;border-radius:18px;box-shadow:0 12px 32px rgba(0,0,0,.32)}

/* Photos & galleries */
.gallery{display:grid;gap:1rem;margin-top:1.2rem}
.shot{margin:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.shot img{width:100%;height:250px;object-fit:cover}
.shot figcaption{padding:.65rem .9rem;font-size:.85rem;color:var(--muted)}
.inline-photo{width:100%;height:260px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow);margin-top:1.1rem}

/* Sections */
.section{padding:2.8rem 0}
.section-alt{background:#fff}
.section-sub{color:var(--muted);max-width:60ch;margin-bottom:1.4rem}
.split{display:grid;gap:2rem}
.fineprint{color:var(--muted);font-size:.85rem;margin-top:1.2rem}

/* Cards */
.card-grid{display:grid;gap:1rem;grid-template-columns:1fr;margin-top:1.2rem}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.4rem;box-shadow:var(--shadow);text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;gap:.45rem;
}
a.card:hover{border-color:var(--aqua)}
.card-icon{
  width:46px;height:46px;border-radius:12px;background:var(--aqua-pale);
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;
}
.card-link{font-weight:700;color:var(--cta);margin-top:auto}
.card-price{font-size:1.35rem;font-weight:800;color:var(--blue)}

/* Checklists / steps / FAQ */
.checklist{list-style:none;display:grid;gap:.55rem;margin:.8rem 0}
.checklist li{padding-left:1.7rem;position:relative}
.checklist li::before{
  content:"\2713";position:absolute;left:0;top:0;font-weight:900;color:var(--aqua);
}
.checklist.small{font-size:.93rem}
.steps{display:grid;gap:1.2rem;margin-top:1.4rem}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow)}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;
  border-radius:50%;background:var(--blue);color:#fff;font-weight:800;margin-bottom:.5rem;
}
.faq{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem 1.2rem;margin-bottom:.7rem}
.faq summary{font-weight:700;color:var(--navy);cursor:pointer}
.faq p{margin-top:.6rem;color:var(--muted)}

/* Pricing strip */
.price-strip{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-top:1.2rem}
.price-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.1rem;text-align:center;box-shadow:var(--shadow);
}
.price-num{display:block;font-size:1.5rem;font-weight:800;color:var(--blue)}
.price-label{font-size:.83rem;color:var(--muted)}
.price-card{
  background:#fff;border:2px solid var(--aqua);border-radius:var(--radius);
  padding:1.6rem;box-shadow:var(--shadow);display:grid;gap:.7rem;
}
.price-card-label{font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;color:var(--muted)}
.price-card-num{font-size:2.4rem;font-weight:800;color:var(--navy);line-height:1}
.price-card-num span{font-size:1rem;font-weight:600;color:var(--muted)}
.price-card-alt{font-weight:700;color:var(--blue)}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--navy),var(--blue));color:#fff;padding:2.4rem 0}
.cta-band h2{color:#fff;margin-bottom:1rem}
.cta-band-inner{display:grid;gap:.6rem}

/* Quote form */
.quote{padding:2.8rem 0;background:var(--aqua-pale)}
.quote-grid{display:grid;gap:2rem}
.quote-info p{margin-bottom:1rem;color:var(--muted)}
.quote-info h2{margin-bottom:.6rem}
.alt-email{font-size:.92rem;margin-top:1rem}
.quote-form{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.5rem;box-shadow:var(--shadow);display:grid;gap:1rem;
}
.form-row label{display:block;font-weight:700;font-size:.88rem;margin-bottom:.3rem;color:var(--navy)}
.form-row .opt{font-weight:400;color:var(--muted)}
.form-2col{display:grid;gap:1rem}
input[type=text],input[type=tel],input[type=email],select,textarea{
  width:100%;padding:.75rem .85rem;border:1.5px solid var(--line);border-radius:10px;
  font:inherit;background:#fff;color:var(--ink);
}
input:focus,select:focus,textarea:focus{outline:2px solid var(--aqua);border-color:var(--aqua)}
.form-note{font-size:.82rem;color:var(--muted);text-align:center}
.hp-field{display:none}

/* Meet the team */
.team-grid{display:grid;gap:1rem;grid-template-columns:1fr;margin-top:1.2rem;justify-content:center}
.team-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);text-align:center}
.team-photo{width:110px;height:110px;border-radius:50%;object-fit:cover;margin:0 auto .9rem;display:block}
.team-photo-placeholder{background:linear-gradient(160deg,var(--blue),var(--aqua));color:#fff;font-size:2.1rem;font-weight:800;display:flex;align-items:center;justify-content:center}
.team-name{margin-bottom:.1rem}
.team-role{color:var(--cta);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}
.team-years{display:inline-block;background:var(--aqua-pale);color:var(--blue);font-weight:700;font-size:.8rem;padding:.25rem .8rem;border-radius:999px;margin:.5rem 0}
.team-bio{color:var(--muted);font-size:.93rem}

/* Tools / calculators */
.tool-toc{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1rem}
.tool-toc a{background:#fff;border:1.5px solid var(--aqua);color:var(--blue);font-weight:700;text-decoration:none;padding:.5rem 1rem;border-radius:999px}
.tool-toc a:hover{background:var(--aqua-pale)}
.tool-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);display:grid;gap:1rem;margin-top:1.2rem}
.tool-card form{display:grid;gap:1rem}
.tool-btn-wrap{display:flex;align-items:flex-end}
.tool-result{background:var(--aqua-pale);border:1.5px solid var(--aqua);border-radius:12px;padding:1.1rem 1.3rem}
.tool-num{font-size:1.7rem;font-weight:800;color:var(--navy);margin-bottom:.3rem}
.tool-error{color:#9c2f12;font-weight:600}
.tool-cta{display:flex;flex-wrap:wrap;align-items:center;gap:.7rem;margin-top:1rem;font-weight:700;color:var(--navy)}
section[id]{scroll-margin-top:80px}

/* Footer */
.site-footer{background:var(--navy);color:#cfe3ea;padding:2.6rem 0 1rem}
.site-footer a{color:#9fdceb;text-decoration:none}
.site-footer a:hover{text-decoration:underline}
.footer-grid{display:grid;gap:1.8rem}
.footer-brand{font-weight:800;color:#fff;font-size:1.1rem;margin-bottom:.5rem}
.footer-head{font-weight:700;color:#fff;margin:.8rem 0 .4rem}
.site-footer ul{list-style:none;display:grid;gap:.35rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);margin-top:1.8rem;padding-top:1rem;font-size:.82rem;color:#8fb2bf}

/* Sticky mobile call bar */
.sticky-call{
  position:fixed;bottom:0;left:0;right:0;z-index:60;display:grid;grid-template-columns:1.4fr 1fr;
  box-shadow:0 -2px 12px rgba(0,0,0,.18);
}
.sticky-btn{
  text-align:center;padding:.95rem .5rem;font-weight:800;text-decoration:none;font-size:.98rem;
}
.sticky-phone{background:var(--cta);color:#fff}
.sticky-quote{background:var(--navy);color:#fff}
body{padding-bottom:56px} /* room for sticky bar (mobile default) */

/* ----- Larger screens ----- */
@media(min-width:640px){
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .form-2col{grid-template-columns:1fr 1fr}
  .price-strip{grid-template-columns:repeat(4,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(auto-fit,minmax(240px,300px))}
}
@media(min-width:900px){
  .card-grid{grid-template-columns:repeat(3,1fr)}
  .split{grid-template-columns:1fr 1fr;align-items:start}
  .quote-grid{grid-template-columns:1fr 1.2fr;align-items:start}
  .steps{grid-template-columns:repeat(4,1fr)}
  .gallery{grid-template-columns:repeat(4,1fr)}
  .gallery-2{grid-template-columns:repeat(2,1fr)}
  .gallery-3{grid-template-columns:repeat(3,1fr)}
  .hero-grid{grid-template-columns:1.25fr 1fr}
  .hero-photo img{height:400px}
  .cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
  .cta-band h2{margin-bottom:0}
}
@media(min-width:861px){
  .nav-toggle{display:none}
  .site-nav{display:flex;align-items:center;gap:1.1rem;position:static;box-shadow:none;padding:0}
  .site-nav a{padding:.3rem 0}
  .sticky-call{display:none}
  body{padding-bottom:0}
}
@media(max-width:860px){
  .nav-call{display:none} /* phone lives in sticky bar on mobile */
}
