/*
Theme Name: San Diego Water Pros
Theme URI: https://sandiegowaterpros.com/
Author: Straight In Design
Author URI: https://sandiegowaterpros.com/
Description: Call-first, pay-per-call water damage lead-gen theme. Localized homepage that drives emergency phone calls, with LocalBusiness schema, a one-field phone Customizer, and full blog templates.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sandiegowaterpros
*/


  :root{
    --navy:#0B2C42;
    --navy-deep:#07202F;
    --navy-soft:#103048;
    --blue:#0E6BA8;
    --blue-dark:#0A5386;
    --cyan:#17A2B8;
    --sun:#E0A32E;
    --sun-dark:#B67F14;
    --red:#E23A2F;
    --red-dark:#C22C22;
    --cream:#F7FAFC;
    --sand:#E9F1F6;
    --sand-line:#D4E2EC;
    --ink:#132330;
    --ink-soft:#41545F;
    --white:#ffffff;
    --good:#1E8A5B;
    --shadow:0 10px 30px rgba(11,44,66,.15);
    --shadow-sm:0 4px 14px rgba(11,44,66,.10);
    --radius:16px;
  }
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{margin:0;font-family:'Source Sans 3',-apple-system,'Segoe UI',Arial,sans-serif;font-size:19px;line-height:1.65;color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;}
  h1,h2,h3{font-family:'Merriweather',Georgia,serif;line-height:1.2;color:var(--navy);margin:0 0 .5em;}
  h1{font-size:2.7rem;font-weight:900;}
  h2{font-size:2.05rem;font-weight:800;}
  h3{font-size:1.35rem;}
  p{margin:0 0 1rem;}
  a{color:var(--blue);}
  img{max-width:100%;display:block;}
  .wrap{max-width:1140px;margin:0 auto;padding:0 22px;}
  .center{text-align:center;}
  [id]{scroll-margin-top:84px;}

  .skip{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:12px 18px;z-index:100;border-radius:0 0 8px 0;}
  .skip:focus{left:0;}

  .btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;font-family:'Source Sans 3',sans-serif;font-weight:700;border:0;border-radius:60px;cursor:pointer;text-decoration:none;padding:18px 32px;font-size:1.25rem;line-height:1.1;min-height:58px;transition:transform .12s ease, box-shadow .12s ease, background .12s ease;}
  .btn:focus-visible{outline:4px solid var(--sun);outline-offset:3px;}
  .btn-call{background:var(--red);color:#fff;box-shadow:0 8px 20px rgba(226,58,47,.34);}
  .btn-call:hover{background:var(--red-dark);transform:translateY(-2px);}
  .btn-call .num{font-size:1.4rem;letter-spacing:.5px;}
  .btn-ghost{background:#fff;color:var(--navy);border:2px solid var(--sand-line);}
  .btn-ghost:hover{border-color:var(--blue);color:var(--blue);}
  .btn svg{width:26px;height:26px;flex:none;}

  .eyebrow{display:inline-block;font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.88rem;color:var(--sun-dark);margin-bottom:.6rem;}

  .topbar{background:var(--navy-deep);color:#cfe0ee;font-size:.98rem;}
  .topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:9px 22px;flex-wrap:wrap;}
  .topbar strong{color:#fff;}
  .topbar .dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:#49d17f;margin-right:8px;vertical-align:middle;box-shadow:0 0 0 3px rgba(73,209,127,.25);}

  header.site{position:sticky;top:0;z-index:40;background:rgba(247,250,252,.97);backdrop-filter:blur(6px);border-bottom:1px solid var(--sand-line);}
  header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 22px;}
  .logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
  .logo .mark{width:46px;height:46px;flex:none;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--cyan));display:flex;align-items:center;justify-content:center;color:#fff;}
  .logo .mark svg{width:26px;height:26px;}
  .logo .name{font-family:'Merriweather',serif;font-weight:900;font-size:1.22rem;color:var(--navy);line-height:1.05;}
  .logo .name span{display:block;font-family:'Source Sans 3',sans-serif;font-weight:600;font-size:.72rem;letter-spacing:.14em;color:var(--sun-dark);text-transform:uppercase;}
  nav.primary{display:flex;align-items:center;gap:24px;margin-left:auto;margin-right:8px;}
  nav.primary a{text-decoration:none;color:var(--navy);font-weight:600;font-size:1.02rem;}
  nav.primary a:hover{color:var(--blue);}
  .header-call{display:flex;align-items:center;gap:16px;}
  .header-call .callline{text-align:right;line-height:1.15;}
  .header-call .callline small{display:block;font-size:.82rem;color:var(--ink-soft);}
  .header-call .callline a{font-family:'Merriweather',serif;font-weight:900;font-size:1.35rem;color:var(--navy);text-decoration:none;}
  .navtoggle{display:none;background:#fff;border:2px solid var(--sand-line);border-radius:10px;width:52px;height:52px;align-items:center;justify-content:center;cursor:pointer;}
  .navtoggle svg{width:26px;height:26px;color:var(--navy);}

  .hero{background:radial-gradient(1200px 500px at 80% -10%, rgba(14,107,168,.18), transparent 60%),linear-gradient(180deg,var(--cream),var(--sand));padding:54px 0 40px;}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;}
  .hero h1 span{color:var(--blue);}
  .hero .lead{font-size:1.3rem;color:var(--ink-soft);max-width:40ch;}
  .hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin:24px 0 16px;}
  .hero-note{font-size:1.02rem;color:var(--ink-soft);display:flex;align-items:center;gap:10px;}
  .hero-note svg{width:22px;height:22px;color:var(--good);flex:none;}
  .hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px;}
  .pill{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--sand-line);border-radius:40px;padding:9px 16px;font-weight:600;font-size:.98rem;box-shadow:var(--shadow-sm);}
  .pill svg{width:20px;height:20px;color:var(--blue);flex:none;}

  .quotecard{background:#fff;border-radius:22px;box-shadow:var(--shadow);border:1px solid var(--sand-line);padding:28px;}
  .quotecard .qc-top{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
  .quotecard .qc-top .live{display:inline-flex;align-items:center;gap:7px;font-size:.85rem;font-weight:700;color:var(--good);background:#e8f6ef;border-radius:30px;padding:4px 12px;}
  .quotecard .qc-top .live .dot{width:8px;height:8px;border-radius:50%;background:var(--good);}
  .quotecard h3{color:var(--navy);font-size:1.45rem;margin-bottom:4px;}
  .quotecard .sub{color:var(--ink-soft);margin-bottom:18px;font-size:1.02rem;}
  .quotecard ol{list-style:none;counter-reset:qc;margin:0 0 20px;padding:0;}
  .quotecard ol li{counter-increment:qc;display:flex;gap:13px;align-items:flex-start;padding:9px 0;font-size:1.05rem;}
  .quotecard ol li::before{content:counter(qc);flex:none;width:30px;height:30px;border-radius:50%;background:var(--blue);color:#fff;font-weight:800;font-size:.95rem;display:flex;align-items:center;justify-content:center;margin-top:1px;}
  .quotecard .btn-call{width:100%;}
  .quotecard .fineprint{font-size:.88rem;color:var(--ink-soft);text-align:center;margin:12px 0 0;}

  .trustrow{background:var(--white);border-top:1px solid var(--sand-line);border-bottom:1px solid var(--sand-line);}
  .trustrow .wrap{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap;padding:18px 22px;font-weight:600;color:var(--ink-soft);font-size:1.02rem;}
  .trustrow span{display:inline-flex;align-items:center;gap:10px;}
  .trustrow svg{width:24px;height:24px;color:var(--sun-dark);}

  section{padding:60px 0;}
  .section-head{max-width:52ch;margin:0 auto 38px;text-align:center;}
  .section-head p{font-size:1.15rem;color:var(--ink-soft);}

  .alertbar{background:var(--red);}
  .alertbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 22px;flex-wrap:wrap;}
  .alertbar .a-left{display:flex;align-items:center;gap:14px;}
  .alertbar svg{width:32px;height:32px;color:#fff;flex:none;}
  .alertbar h4{color:#fff;font-size:1.15rem;font-family:'Merriweather',serif;margin:0;}
  .alertbar p{color:#ffe3e0;font-size:.98rem;margin:2px 0 0;}
  .alertbar .btn{background:#fff;color:var(--red-dark);padding:13px 24px;min-height:0;font-size:1.05rem;}
  .alertbar .btn:hover{background:#fff3f2;}

  .explain{background:var(--white);}
  .explain-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center;}
  .explain h2 span{color:var(--blue);}
  .explain p{font-size:1.1rem;color:var(--ink-soft);}
  .factbox{background:var(--cream);border:1px solid var(--sand-line);border-radius:20px;padding:28px;box-shadow:var(--shadow-sm);}
  .factbox h3{font-size:1.15rem;margin-bottom:14px;}
  .factbox dl{margin:0;display:grid;grid-template-columns:1fr;gap:12px;}
  .factbox .frow{display:flex;justify-content:space-between;gap:16px;border-bottom:1px dashed var(--sand-line);padding-bottom:11px;}
  .factbox .frow:last-child{border-bottom:0;padding-bottom:0;}
  .factbox dt{font-weight:600;color:var(--ink-soft);}
  .factbox dd{margin:0;font-weight:700;color:var(--navy);text-align:right;}

  .services{background:var(--sand);}
  .bgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
  .bcard{background:#fff;border:1px solid var(--sand-line);border-radius:var(--radius);padding:28px;}
  .bcard .ico{width:56px;height:56px;border-radius:14px;background:var(--cream);border:1px solid var(--sand-line);display:flex;align-items:center;justify-content:center;margin-bottom:15px;}
  .bcard .ico svg{width:30px;height:30px;color:var(--blue);}
  .bcard h3{margin-bottom:6px;}
  .bcard p{margin:0;font-size:1.02rem;color:var(--ink-soft);}

  .problem{background:var(--white);}
  .problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;}
  .statbig{background:var(--navy);color:#fff;border-radius:22px;padding:34px;box-shadow:var(--shadow);}
  .statbig .n{font-family:'Merriweather',serif;font-weight:900;font-size:3.2rem;color:var(--sun);line-height:1;}
  .statbig p{color:#cfe0e8;font-size:1.08rem;margin:.4rem 0 1.4rem;}
  .statrow{display:flex;gap:14px;border-top:1px solid rgba(255,255,255,.16);padding-top:18px;}
  .statrow div{flex:1;}
  .statrow b{display:block;font-family:'Merriweather',serif;font-size:1.4rem;color:#fff;}
  .statrow small{color:#a9c2ce;font-size:.9rem;}
  .problem h2 span{color:var(--blue);}

  .how{background:var(--sand);}
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:step;}
  .step{position:relative;background:#fff;border:1px solid var(--sand-line);border-radius:var(--radius);padding:32px 24px 24px;text-align:center;}
  .step .no{counter-increment:step;width:54px;height:54px;border-radius:50%;background:var(--red);color:#fff;font-family:'Merriweather',serif;font-weight:900;font-size:1.5rem;display:flex;align-items:center;justify-content:center;margin:0 auto 15px;box-shadow:0 6px 16px rgba(226,58,47,.3);}
  .step .no::before{content:counter(step);}
  .step h3{margin-bottom:8px;}
  .step p{margin:0;color:var(--ink-soft);font-size:1.02rem;}

  .why{background:var(--white);}
  .why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
  .wcard{border:1px solid var(--sand-line);border-radius:var(--radius);padding:28px;background:var(--cream);display:flex;flex-direction:column;}
  .wcard.featured{background:var(--navy);color:#fff;border-color:var(--navy);}
  .wcard .tag{align-self:flex-start;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;background:var(--sand);color:var(--sun-dark);padding:6px 12px;border-radius:30px;margin-bottom:14px;}
  .wcard.featured .tag{background:var(--sun);color:var(--navy-deep);}
  .wcard h3{color:inherit;}
  .wcard.featured h3{color:#fff;}
  .wcard p{font-size:1.02rem;color:var(--ink-soft);}
  .wcard.featured p{color:#cfe0e8;}
  .wcard ul{list-style:none;margin:6px 0 0;padding:0;}
  .wcard li{display:flex;gap:10px;align-items:flex-start;padding:7px 0;font-size:1rem;}
  .wcard li svg{width:22px;height:22px;color:var(--good);flex:none;margin-top:2px;}
  .wcard.featured li svg{color:#7fe0a8;}

  .timeline-sec{background:var(--navy);color:#dbe8f2;}
  .timeline-sec .eyebrow{color:var(--cyan);}
  .timeline-sec h2{color:#fff;}
  .timeline-sec .section-head p{color:#a9c2d6;}
  .timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
  .tl{background:var(--navy-soft);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:26px 22px;border-top:4px solid var(--cyan);}
  .tl.mid{border-top-color:var(--sun);}
  .tl.late{border-top-color:var(--red);}
  .tl .when{font-family:'Merriweather',serif;font-weight:700;font-size:1.05rem;color:#fff;margin-bottom:4px;}
  .tl .lab{font-size:.9rem;color:var(--cyan);font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px;}
  .tl.mid .lab{color:#f0c064;}
  .tl.late .lab{color:#ff8f86;}
  .tl ul{list-style:none;margin:0;padding:0;font-size:1rem;color:#cddeeb;}
  .tl li{padding:6px 0 6px 22px;position:relative;}
  .tl li::before{content:"";position:absolute;left:2px;top:14px;width:8px;height:8px;border-radius:50%;background:var(--cyan);}
  .tl.mid li::before{background:var(--sun);}
  .tl.late li::before{background:var(--red);}
  .tl-cta{text-align:center;margin-top:32px;}
  .tl-cta p{color:#cddeeb;font-size:1.1rem;margin-bottom:16px;}

  .insurance{background:var(--white);}
  .ins-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;}
  .checklist{list-style:none;margin:0;padding:0;}
  .checklist li{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--sand-line);font-size:1.08rem;}
  .checklist li:last-child{border-bottom:0;}
  .checklist svg{width:26px;height:26px;color:var(--good);flex:none;margin-top:2px;}
  .ins-panel{background:linear-gradient(150deg,var(--blue),var(--cyan));color:#fff;border-radius:22px;padding:40px 32px;box-shadow:var(--shadow);text-align:center;}
  .ins-panel .big{width:70px;height:70px;margin:0 auto 12px;border-radius:18px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;}
  .ins-panel .big svg{width:38px;height:38px;color:#fff;}
  .ins-panel h3{color:#fff;font-size:1.55rem;margin-bottom:8px;}
  .ins-panel p{color:#eaf5fb;font-size:1.05rem;margin-bottom:18px;}
  .ins-panel .btn-call{width:100%;}

  .area{background:var(--sand);}
  .area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:8px;}
  .area-card{background:#fff;border:1px solid var(--sand-line);border-radius:var(--radius);padding:22px;text-align:center;}
  .area-card svg{width:34px;height:34px;color:var(--blue);margin-bottom:8px;}
  .area-card b{display:block;color:var(--navy);font-size:1.08rem;}
  .area-card small{color:var(--ink-soft);font-size:.95rem;}
  .area .note{text-align:center;margin:26px auto 0;max-width:60ch;color:var(--ink-soft);font-size:1rem;}

  .faq{background:var(--white);}
  .faq-list{max-width:820px;margin:0 auto;}
  details{background:var(--cream);border:1px solid var(--sand-line);border-radius:14px;margin-bottom:13px;box-shadow:var(--shadow-sm);}
  summary{cursor:pointer;list-style:none;padding:20px 24px;font-family:'Merriweather',serif;font-weight:700;font-size:1.15rem;color:var(--navy);display:flex;justify-content:space-between;gap:16px;align-items:center;}
  summary::-webkit-details-marker{display:none;}
  summary .plus{flex:none;width:30px;height:30px;border-radius:50%;background:var(--sand);display:flex;align-items:center;justify-content:center;color:var(--navy);font-weight:900;transition:transform .2s;}
  details[open] summary .plus{transform:rotate(45deg);background:var(--blue);color:#fff;}
  details .body{padding:0 24px 22px;color:var(--ink-soft);font-size:1.05rem;}
  details .body p{margin:0;}

  .finalcta{background:linear-gradient(135deg,var(--navy),var(--navy-deep));color:#fff;text-align:center;}
  .finalcta h2{color:#fff;font-size:2.3rem;}
  .finalcta p{color:#cfe0e8;font-size:1.2rem;max-width:44ch;margin:0 auto 26px;}
  .finalcta .btn-call{font-size:1.45rem;padding:22px 42px;}
  .finalcta .hours{margin-top:16px;color:#a9c2ce;font-size:1.02rem;}

  footer.site{background:var(--navy-deep);color:#b9ccd6;font-size:1rem;padding:46px 0 120px;}
  footer.site .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:36px;margin-bottom:28px;}
  footer.site .name{font-family:'Merriweather',serif;font-weight:900;color:#fff;font-size:1.25rem;margin-bottom:8px;}
  footer.site a{color:#cfe0e8;text-decoration:none;}
  footer.site a:hover{text-decoration:underline;}
  footer.site h4{color:#fff;font-size:1.02rem;margin:0 0 12px;letter-spacing:.03em;}
  footer.site ul{list-style:none;margin:0;padding:0;}
  footer.site li{margin-bottom:9px;}
  .disclaimer-box{border-top:1px solid rgba(255,255,255,.14);padding-top:20px;font-size:.88rem;line-height:1.6;color:#94aeb9;}
  .disclaimer-box p{margin:0 0 10px;}

  .callbar{position:fixed;left:0;right:0;bottom:0;z-index:50;background:var(--red);box-shadow:0 -6px 20px rgba(0,0,0,.2);display:none;}
  .callbar a{display:flex;align-items:center;justify-content:center;gap:12px;color:#fff;text-decoration:none;font-weight:800;font-size:1.25rem;padding:15px;}
  .callbar svg{width:26px;height:26px;}

  @media(max-width:980px){
    .hero-grid,.problem-grid,.explain-grid,.ins-grid{grid-template-columns:1fr;gap:32px;}
    .bgrid,.steps,.why-grid{grid-template-columns:1fr;}
    .timeline{grid-template-columns:1fr;}
    .area-grid{grid-template-columns:1fr 1fr;}
    h1{font-size:2.2rem;}h2{font-size:1.7rem;}
    .header-call .callline{display:none;}
    nav.primary{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-bottom:1px solid var(--sand-line);padding:8px 0;box-shadow:var(--shadow);}
    nav.primary.open{display:flex;}
    nav.primary a{padding:14px 22px;border-bottom:1px solid var(--sand-line);font-size:1.12rem;}
    .navtoggle{display:flex;}
  }
  @media(max-width:620px){
    body{font-size:18px;}
    .topbar .wrap{justify-content:center;text-align:center;}
    .hero{padding:34px 0 26px;}
    .hero-cta .btn{width:100%;}
    footer.site .cols{grid-template-columns:1fr;}
    .callbar{display:block;}
    .area-grid{grid-template-columns:1fr;}
    .alertbar .btn{width:100%;}
    h1{font-size:2rem;}
  }


/* ---- Blog / inner page templates ---- */
.pagewrap{padding:60px 0;background:var(--cream);}
.prose{max-width:820px;margin:0 auto;}
.prose h1{font-size:2.3rem;margin-bottom:.3em;}
.prose h2{font-size:1.6rem;margin:1.4em 0 .5em;}
.prose h3{font-size:1.3rem;margin:1.2em 0 .4em;}
.prose p,.prose li{font-size:1.08rem;color:var(--ink-soft);}
.prose img{border-radius:14px;margin:1.2em 0;}
.prose .meta{color:var(--ink-soft);font-size:.98rem;margin-bottom:1.4em;}
.prose a{color:var(--blue);}
.post-card{border-bottom:1px solid var(--sand-line);padding:22px 0;margin-bottom:8px;}
.post-card h2{margin-bottom:.2em;}
.post-card h2 a{color:var(--navy);text-decoration:none;}
.post-card h2 a:hover{color:var(--blue);}
.pagination,.nav-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px;}
.pagination a,.pagination .current,.page-numbers{display:inline-flex;padding:8px 14px;border:1px solid var(--sand-line);border-radius:10px;background:#fff;color:var(--navy);text-decoration:none;font-weight:600;}
.pagination .current,.page-numbers.current{background:var(--blue);color:#fff;border-color:var(--blue);}
.err404{text-align:center;padding:80px 0;}
.err404 h1{font-size:4rem;color:var(--blue);}
.comment-list{list-style:none;padding:0;}
.comment-list li{border:1px solid var(--sand-line);border-radius:12px;padding:16px 18px;margin-bottom:12px;background:#fff;}
