/* ==========================================================================
   Prescott Valley Plumbing Pros — Alpine Ledger
   Single external stylesheet (cached site-wide). System fonts only.
   Primary (pine) #14532D · Accent (frost cyan) #06B6D4
   ========================================================================== */

:root{
  --primary:#14532D;
  --primary-dk:#0F3D22;
  --accent:#06B6D4;
  --accent-dk:#0E7490;
  --ink:#1F2937;
  --ink-soft:#374151;
  --muted:#6B7280;
  --bg:#FFFFFF;
  --bg-alt:#F9FAFB;
  --tint:#F2F6F3;        /* pine at ~5% */
  --border:#E5E7EB;
  --border-dk:#D1D5DB;
  --serif:Georgia,"Times New Roman",Times,serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,Roboto,Helvetica,Arial,sans-serif;
  --wrap:1200px;
  --radius:8px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-dk)}
a:hover{color:var(--primary)}
p{margin:0 0 1.25rem}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 1rem}

/* Skip link */
.skip-link{position:absolute;left:-999px;top:0;background:var(--primary);color:#fff;
  padding:.6rem 1rem;z-index:300;border-radius:0 0 var(--radius) 0}
.skip-link:focus{left:0;color:#fff}

/* Focus states */
a:focus-visible,button:focus-visible,summary:focus-visible{
  outline:3px solid var(--accent);outline-offset:2px;border-radius:3px}

/* ---------- TOP BAR ---------- */
.top-bar{background:var(--primary);color:#fff;width:100%;z-index:100;font-size:.9rem}
.top-bar-inner{max-width:var(--wrap);margin:0 auto;padding:.5rem 1rem;display:flex;
  align-items:center;justify-content:space-between;gap:1rem;min-height:38px}
.top-bar-tagline{font-weight:500;letter-spacing:.2px}
.top-bar-cta{color:#fff;text-decoration:none;font-weight:700;display:inline-flex;
  align-items:center;gap:.4rem;padding:.35rem .7rem;border-radius:4px;white-space:nowrap}
.top-bar-cta:hover,.top-bar-cta:focus{background:rgba(255,255,255,.16);color:#fff}
.top-bar-cta-icon{font-size:.95rem}
@media(max-width:600px){
  .top-bar-inner{justify-content:center;min-height:44px}
  .top-bar-tagline{display:none}
  .top-bar-cta{font-size:1rem}
}

/* ---------- HEADER ---------- */
.site-header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--border);
  z-index:90}
.site-header.scrolled{box-shadow:0 2px 10px rgba(15,61,34,.08)}
.header-inner{max-width:var(--wrap);margin:0 auto;padding:.6rem 1rem;display:flex;
  align-items:center;gap:1rem}
.brand{display:flex;align-items:center;gap:.55rem;text-decoration:none;flex:0 0 auto}
.brand-mark{width:34px;height:34px;flex:0 0 auto}
.brand-name{font-family:var(--serif);font-weight:700;color:var(--primary);
  font-size:1.18rem;line-height:1.05;letter-spacing:.2px}
.brand-name small{display:block;font-family:var(--sans);font-weight:600;
  font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* Primary nav */
.nav{margin-left:auto;display:flex;align-items:center;gap:.25rem}
.nav>ul{list-style:none;display:flex;align-items:center;gap:.1rem;margin:0;padding:0}
.nav a,.nav .nav-top{display:inline-block;text-decoration:none;color:var(--ink-soft);
  font-weight:600;font-size:.96rem;padding:.55rem .7rem;border-radius:6px;background:none;
  border:0;cursor:pointer;font-family:inherit}
.nav a:hover,.nav .nav-top:hover{color:var(--primary);background:var(--tint)}
.nav .has-menu{position:relative}
.nav-top[aria-expanded="true"]{color:var(--primary);background:var(--tint)}
.caret{font-size:.7rem;margin-left:.2rem;color:var(--muted)}

/* Dropdown */
.dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:264px;background:#fff;
  border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 10px 30px rgba(15,61,34,.14);
  padding:.4rem;margin:0;list-style:none;z-index:120;display:none}
.has-menu:hover .dropdown,.has-menu:focus-within .dropdown,.dropdown.open{display:block}
.dropdown li{margin:0}
.dropdown a{display:block;padding:.55rem .7rem;border-radius:6px;font-weight:600;font-size:.92rem;
  color:var(--ink-soft)}
.dropdown a:hover{background:var(--tint);color:var(--primary)}
.dropdown .view-all{margin-top:.3rem;border-top:1px solid var(--border);padding-top:.5rem}
.dropdown .view-all a{color:var(--primary);font-weight:700}

/* Header phone button (icon + label desktop, icon-only mobile) */
.nav-phone{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;
  background:var(--accent);color:#fff;border-radius:6px;text-decoration:none;font-weight:700;
  min-height:44px;margin-left:.4rem;white-space:nowrap}
.nav-phone:hover{background:var(--accent-dk);color:#fff}
.nav-phone-icon{font-size:1rem}

/* Mobile menu toggle */
.menu-toggle{display:none;margin-left:auto;background:none;border:1px solid var(--border-dk);
  border-radius:6px;padding:.5rem .7rem;font-size:1rem;cursor:pointer;color:var(--primary);
  min-height:44px;align-items:center;gap:.4rem;font-weight:700;font-family:inherit}

@media(max-width:900px){
  .menu-toggle{display:inline-flex}
  .nav{position:fixed;top:0;right:0;height:100vh;width:min(86vw,340px);background:#fff;
    flex-direction:column;align-items:stretch;gap:0;padding:4.5rem 1rem 2rem;margin:0;
    box-shadow:-8px 0 30px rgba(15,61,34,.18);transform:translateX(100%);
    transition:transform .25s ease;overflow-y:auto;z-index:200}
  .nav.open{transform:translateX(0)}
  .nav>ul{flex-direction:column;align-items:stretch;gap:.1rem;width:100%}
  .nav a,.nav .nav-top{width:100%;text-align:left;padding:.8rem .6rem;font-size:1rem}
  .nav-top{display:flex;justify-content:space-between;align-items:center}
  .dropdown{position:static;display:none;box-shadow:none;border:0;border-left:2px solid var(--tint);
    border-radius:0;margin:.1rem 0 .4rem .6rem;padding:.2rem 0 .2rem .4rem;min-width:0}
  .dropdown.open{display:block}
  .has-menu:hover .dropdown,.has-menu:focus-within .dropdown{display:none}
  .has-menu:hover .dropdown.open,.has-menu:focus-within .dropdown.open{display:block}
  .nav-phone{margin:1rem 0 0;justify-content:center}
  .nav-backdrop{display:none;position:fixed;inset:0;background:rgba(15,61,34,.4);z-index:150}
  .nav-backdrop.open{display:block}
}

/* ---------- HERO ---------- */
.hero{background:var(--bg-alt);border-bottom:1px solid var(--border)}
.hero-inner{max-width:var(--wrap);margin:0 auto;padding:2.6rem 1rem 2.8rem;display:grid;
  grid-template-columns:1.05fr .95fr;gap:2rem;align-items:center}
.hero h1{font-family:var(--serif);font-weight:700;color:var(--primary);font-size:2.75rem;
  line-height:1.12;margin:0 0 1rem;letter-spacing:.2px}
.hero .lede{font-size:1.16rem;color:var(--ink-soft);margin:0 0 1.4rem;max-width:60ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--sans);
  font-weight:700;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--primary);background:var(--tint);border:1px solid #DCE7E0;padding:.35rem .7rem;
  border-radius:999px;margin:0 0 1rem}
@media(max-width:820px){
  .hero-inner{grid-template-columns:1fr;gap:1.4rem;padding:2rem 1rem 2.2rem}
  .hero h1{font-size:2.1rem}
  .hero .lede{font-size:1.08rem}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-weight:700;text-decoration:none;border-radius:7px;padding:.85rem 1.4rem;
  min-height:48px;font-size:1.02rem;border:2px solid transparent;cursor:pointer;
  font-family:inherit;line-height:1.1}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dk);color:#fff}
.btn-ghost{background:#fff;color:var(--primary);border-color:var(--primary)}
.btn-ghost:hover{background:var(--tint);color:var(--primary)}
.btn-phone-num{font-variant-numeric:tabular-nums}

/* ---------- SECTIONS ---------- */
main{display:block}
.section{padding:3rem 0}
.section--alt{background:var(--bg-alt)}
.section--tint{background:var(--tint)}
.section h2{font-family:var(--serif);font-weight:700;color:var(--primary);
  font-size:1.92rem;line-height:1.18;margin:0 0 1rem;letter-spacing:.2px}
.section h2 .h2-rule{display:block;width:54px;height:3px;background:var(--primary);
  margin:.7rem 0 0;border-radius:2px}
.section h3{font-family:var(--serif);font-weight:700;color:var(--primary);
  font-size:1.28rem;line-height:1.25;margin:1.6rem 0 .6rem}
.section h4{font-family:var(--sans);font-weight:700;color:var(--ink);
  font-size:1.05rem;margin:1.2rem 0 .5rem}
.lead-text{font-size:1.1rem;color:var(--ink-soft);max-width:68ch}
.prose{max-width:68ch}
.prose p,.section>.wrap>p{max-width:68ch}
.section--center h2{ }
.frost::before{content:"\2744";color:var(--accent-dk);margin-right:.4rem}

/* Cards grid */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:1.4rem}
@media(max-width:880px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.card-grid{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--border);border-top:3px solid var(--primary);
  border-radius:var(--radius);padding:1.2rem 1.15rem;text-decoration:none;color:inherit;
  display:flex;flex-direction:column;transition:box-shadow .15s ease,transform .15s ease}
a.card:hover{box-shadow:0 8px 24px rgba(15,61,34,.12);transform:translateY(-2px)}
.card .card-ico{font-size:1.5rem;margin-bottom:.4rem}
.card h3{font-family:var(--serif);color:var(--primary);font-size:1.12rem;margin:.1rem 0 .4rem}
.card p{font-size:.95rem;color:var(--ink-soft);margin:0}
.card .card-link{margin-top:.7rem;font-weight:700;color:var(--accent-dk);font-size:.92rem}
/* Service index cards with thumbnail */
.svc-card .image-slot{margin:0 0 .8rem!important;max-width:100%!important;width:100%}
.svc-card{padding-top:1rem}

/* Feature row (three signature services) */
.feature{display:grid;grid-template-columns:1fr;gap:1.2rem;margin-top:1.4rem}
.feature-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1.3rem 1.3rem;border-left:4px solid var(--accent)}
.feature-item h3{margin-top:0}
.feature-item p:last-child{margin-bottom:0}
@media(min-width:760px){.feature{grid-template-columns:repeat(3,1fr)}}

/* Callout / winter alert */
.callout{background:var(--tint);border:1px solid #DCE7E0;border-left:4px solid var(--primary);
  border-radius:var(--radius);padding:1.1rem 1.2rem;margin:1.5rem 0}
.callout h3{margin-top:0}
.callout p:last-child{margin-bottom:0}

/* Area columns */
.area-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin-top:1.3rem}
@media(max-width:680px){.area-cols{grid-template-columns:1fr}}
.area-list{list-style:none;margin:.6rem 0 0;padding:0;columns:2;column-gap:1.2rem}
@media(max-width:480px){.area-list{columns:1}}
.area-list li{margin:0 0 .45rem;break-inside:avoid}
.area-list a{text-decoration:none;color:var(--ink-soft);font-weight:600;font-size:.95rem}
.area-list a:hover{color:var(--primary)}

/* Links list (related) */
.link-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}
.chip{display:inline-block;background:#fff;border:1px solid var(--border-dk);border-radius:999px;
  padding:.45rem .9rem;text-decoration:none;color:var(--primary);font-weight:600;font-size:.9rem}
.chip:hover{background:var(--tint)}

/* Pricing table */
.table-scroll{overflow-x:auto;margin:1.2rem 0}
table.price{width:100%;border-collapse:collapse;font-size:.96rem;min-width:460px}
table.price caption{text-align:left;font-weight:700;color:var(--muted);font-size:.82rem;
  margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.08em}
table.price th,table.price td{text-align:left;padding:.7rem .8rem;border-bottom:1px solid var(--border)}
table.price thead th{background:var(--primary);color:#fff;font-weight:700}
table.price tbody tr:nth-child(even){background:var(--bg-alt)}

/* FAQ */
.faq{margin-top:1.2rem}
.faq details{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.7rem;
  background:#fff;overflow:hidden}
.faq summary{cursor:pointer;padding:1rem 1.1rem;font-weight:700;color:var(--primary);
  font-family:var(--serif);font-size:1.05rem;list-style:none;display:flex;justify-content:space-between;
  gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent-dk);font-weight:700;font-size:1.3rem}
.faq details[open] summary::after{content:"\2013"}
.faq .faq-a{padding:0 1.1rem 1.1rem;color:var(--ink-soft)}
.faq .faq-a p:last-child{margin-bottom:0}

/* CTA band */
.cta-band{background:var(--primary);color:#fff;border-radius:var(--radius);padding:2rem 1.6rem;
  text-align:center;margin-top:1rem}
.cta-band h2{color:#fff;font-family:var(--serif);margin:0 0 .6rem}
.cta-band p{color:#E6EFEA;max-width:60ch;margin:0 auto 1.3rem}
.cta-band .btn-primary{background:var(--accent)}
.cta-band .btn-primary:hover{background:var(--accent-dk)}

/* Breadcrumb */
.crumbs{font-size:.85rem;color:var(--muted);padding:.9rem 0 0}
.crumbs a{color:var(--accent-dk);text-decoration:none}
.crumbs a:hover{text-decoration:underline}
.crumbs span{color:var(--muted)}

/* Page header band (inner pages) */
.page-head{background:var(--bg-alt);border-bottom:1px solid var(--border)}
.page-head-inner{max-width:var(--wrap);margin:0 auto;padding:1.4rem 1rem 2rem}
.page-head h1{font-family:var(--serif);font-weight:700;color:var(--primary);
  font-size:2.3rem;line-height:1.14;margin:.6rem 0 .8rem;letter-spacing:.2px}
.page-head .lede{font-size:1.12rem;color:var(--ink-soft);max-width:70ch;margin:0 0 1.2rem}
@media(max-width:820px){.page-head h1{font-size:1.85rem}}

/* Image slots */
.image-slot{max-width:100%}
figure.image-slot{margin-left:auto;margin-right:auto}

/* Two-column content (service/location) */
.content-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start}
@media(min-width:980px){
  .content-grid{grid-template-columns:minmax(0,1fr) 300px}
}
.sidebar{position:sticky;top:84px}
.sidebar .panel{background:var(--tint);border:1px solid #DCE7E0;border-radius:var(--radius);
  padding:1.1rem 1.1rem;margin-bottom:1.1rem}
.sidebar h3{font-family:var(--serif);color:var(--primary);font-size:1.1rem;margin:0 0 .6rem}
.sidebar ul{list-style:none;margin:0;padding:0}
.sidebar li{margin:0 0 .45rem}
.sidebar a{text-decoration:none;color:var(--ink-soft);font-weight:600;font-size:.93rem}
.sidebar a:hover{color:var(--primary)}
.sidebar .panel--call{background:var(--primary);border-color:var(--primary)}
.sidebar .panel--call h3,.sidebar .panel--call p{color:#fff}
.sidebar .panel--call p{font-size:.92rem;margin:.2rem 0 .8rem}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--primary);color:#D8E4DC;margin-top:2.5rem}
.footer-top{max-width:var(--wrap);margin:0 auto;padding:2.4rem 1rem 1.6rem;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:1.6rem}
.footer-brand .brand-name{color:#fff}
.footer-brand p{color:#C7D6CD;font-size:.93rem;max-width:34ch}
.footer-brand .foot-phone{display:inline-flex;align-items:center;gap:.5rem;color:#fff;
  font-weight:700;text-decoration:none;font-size:1.1rem;margin-top:.3rem}
.site-footer h3{font-family:var(--serif);color:#fff;font-size:1.05rem;margin:0 0 .8rem}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin:0 0 .5rem}
.site-footer a{color:#D8E4DC;text-decoration:none;font-size:.92rem}
.site-footer a:hover{color:#fff;text-decoration:underline}
.footer-bottom{border-top:1px solid rgba(255,255,255,.16)}
.footer-bottom-inner{max-width:var(--wrap);margin:0 auto;padding:1.1rem 1rem;
  display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;
  font-size:.82rem;color:#B9CABF}
.footer-bottom-inner a{color:#B9CABF}
.footer-disclaimer{max-width:var(--wrap);margin:0 auto;padding:0 1rem 1.6rem;
  font-size:.78rem;color:#9FB3A7;line-height:1.55}
@media(max-width:820px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-top{grid-template-columns:1fr}}

/* ---------- STICKY MOBILE CTA ---------- */
.mobile-cta{display:none}
@media(max-width:900px){
  .mobile-cta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:140;
    background:var(--primary);border-top:1px solid var(--primary-dk);padding:.5rem .7rem;
    gap:.6rem;box-shadow:0 -4px 16px rgba(15,61,34,.22)}
  .mobile-cta a{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
    min-height:48px;border-radius:7px;text-decoration:none;font-weight:700;font-size:1rem}
  .mobile-cta .m-call{background:var(--accent);color:#fff}
  .mobile-cta .m-text{background:#fff;color:var(--primary)}
  body{padding-bottom:70px}
}

/* Utilities */
.center{text-align:center}
.mt0{margin-top:0}
.mb0{margin-bottom:0}
.small{font-size:.9rem;color:var(--muted)}
.divider{height:1px;background:var(--border);border:0;margin:2rem 0}
.nofollow-note{font-size:.85rem;color:var(--muted)}

@media(prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important}
}
