/* ============================================================
   Packard Well Drilling — "Deep Water" design system
   Built per LSSG framework v2026.04 / DataForSEO fan-out playbook
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400..600;1,9..144,400..500&family=Public+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --ink:#313163; --ink-2:#454579; --text:#1B1B2E; --muted:#56566E;
  --water:#2E9BD6; --water-deep:#1E7FB5;
  --bone:#F7F5F0; --paper:#FEFDFB; --line:#E6E1D7; --shield:#2A2A40;
  --amber:#C77D34;
  --serif:"Fraunces",Georgia,serif; --sans:"Public Sans",system-ui,sans-serif; --mono:"JetBrains Mono",monospace;
  --wrap:1180px; --r:14px; --r-sm:10px;
  --sh-1:0 1px 2px rgba(27,27,46,.05),0 4px 16px rgba(27,27,46,.06);
  --sh-2:0 8px 30px rgba(49,49,99,.14);
  --z-head:50;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bone);color:var(--text);font-family:var(--sans);
  font-size:1.0625rem;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg{max-width:100%;display:block}
a{color:var(--water-deep);text-decoration:none}
a:hover{color:var(--ink)}
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);line-height:1.08;font-weight:500;margin:0 0 .5em}
h1{font-size:clamp(2.6rem,5.2vw,4.1rem);letter-spacing:-.015em}
h2{font-size:clamp(1.9rem,3.4vw,2.6rem);letter-spacing:-.01em}
h3{font-size:clamp(1.2rem,1.8vw,1.4rem)}
p{margin:0 0 1.1em;max-width:68ch}
strong{font-weight:600;color:var(--ink-2)}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(1.1rem,4vw,2rem)}
section{padding:clamp(3.4rem,7vw,6.5rem) 0}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--water-deep);margin:0 0 1rem;font-weight:500}
.lede{font-size:clamp(1.1rem,1.5vw,1.28rem);color:var(--ink-2);line-height:1.55}

/* skip link + focus */
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--bone);padding:.7rem 1rem;z-index:100;border-radius:0 0 var(--r-sm) 0}
.skip:focus{left:0}
:focus-visible{outline:3px solid var(--water);outline-offset:2px;border-radius:4px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--sans);font-weight:600;
  font-size:1rem;padding:.85rem 1.45rem;border-radius:var(--r-sm);cursor:pointer;border:2px solid transparent;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease,border-color .18s ease;white-space:nowrap}
.btn-primary{background:var(--ink);color:var(--bone)}
.btn-primary:hover{background:var(--water-deep);color:#fff;transform:translateY(-2px);box-shadow:var(--sh-2)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bone);transform:translateY(-2px)}
.btn svg{width:18px;height:18px}

/* ---------- header ---------- */
.head{position:sticky;top:0;z-index:var(--z-head);background:rgba(247,245,240,.82);
  backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line)}
.head-in{display:flex;align-items:center;gap:1.2rem;min-height:98px}
.brand{display:flex;align-items:center;gap:.6rem;margin-right:auto}
.brand-logo{height:78.125px;width:auto;display:block}
.brand-mark{width:34px;height:34px;flex:0 0 auto}
.foot-logo{height:90.625px;width:auto;display:block;filter:brightness(0) invert(1)}
.brand-txt{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:1.16rem;letter-spacing:-.01em}
.brand-sub{font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.nav{display:flex;align-items:center;gap:1.5rem}
.nav a{color:var(--ink-2);font-weight:500;font-size:.96rem}
.nav a:hover{color:var(--water-deep)}
/* dropdown submenu */
.nav-item{position:relative;display:flex;align-items:center}
.nav-item>a{display:inline-flex;align-items:center;gap:.3rem}
.chev{width:13px;height:13px;transition:transform .2s;color:var(--muted)}
.nav-item:hover .chev,.nav-item:focus-within .chev{transform:rotate(180deg)}
.subnav{position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:172px;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--sh-2);
  padding:.4rem;display:none;flex-direction:column;z-index:60}
.nav-item:hover .subnav,.nav-item:focus-within .subnav{display:flex}
.subnav a{padding:.6rem .8rem;border-radius:8px;color:var(--ink-2);font-weight:500;font-size:.95rem;white-space:nowrap}
.subnav a:hover{background:var(--bone);color:var(--ink)}
.head-cta{display:flex;align-items:center;gap:.7rem}
.head-cta .btn{padding:.5rem 1.05rem;font-size:.92rem}
.tel{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--mono);font-weight:500;color:var(--ink);font-size:.95rem}
.tel svg{width:16px;height:16px;color:var(--water-deep)}
.menu-btn{display:none;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--line);
  background:var(--paper);border-radius:var(--r-sm);cursor:pointer;color:var(--ink)}
.menu-btn svg{width:24px;height:24px}
/* mobile nav drop panel */
.mnav{display:none;position:fixed;inset:72px 0 auto 0;z-index:49;background:var(--bone);border-bottom:1px solid var(--line);
  box-shadow:var(--sh-2);padding:1rem clamp(1.1rem,4vw,2rem) 1.4rem}
.mnav.open{display:block}
.mnav a{display:block;padding:.9rem .2rem;color:var(--ink);font-weight:600;font-size:1.05rem;border-bottom:1px solid var(--line)}
.mnav a:last-child{border-bottom:none}
.mnav a.sub{padding-left:1.6rem;font-size:.98rem;color:var(--muted)}
.mnav a.sub::before{content:"\21B3";margin-right:.5rem;color:var(--water-deep)}
.mnav a.btn{margin-top:1rem;width:100%;justify-content:center;border-bottom:none}
.mnav a.btn-primary{color:var(--bone)}
.mnav a.btn-primary:hover{color:#fff}

/* ---------- hero ---------- */
.hero{padding-top:clamp(2.6rem,5vw,4.2rem)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero h1 .ital{font-style:italic;font-weight:400;color:var(--water-deep)}
.hero .lede{margin:1.4rem 0 2rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero-note{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:var(--muted);margin-top:1.5rem;display:flex;gap:.5rem;align-items:center}
.hero-note svg{width:15px;height:15px;color:var(--water-deep);flex:0 0 auto}
/* framed field photo */
.frame{position:relative;background:var(--ink);padding:14px;border-radius:var(--r);box-shadow:var(--sh-2);max-width:460px;margin-left:auto}
.frame img{border-radius:6px;width:100%;height:auto}
.frame figcaption{font-family:var(--mono);font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(247,245,240,.82);display:flex;flex-direction:column;gap:.35rem;padding:.7rem .3rem .15rem;white-space:nowrap}
.frame .dot{color:var(--water)}

/* ---------- mono spec strip / stats ---------- */
.specs{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper)}
.specs-in{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.spec{background:var(--paper);padding:1.6rem clamp(1rem,2vw,1.6rem);text-align:center}
.spec .num{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.3rem);color:var(--ink);font-weight:500;line-height:1}
.spec .lab{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:.6rem}

/* ---------- trust strip ---------- */
.trust{background:var(--paper);border-bottom:1px solid var(--line)}
.trust-in{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:clamp(1.6rem,4vw,3.4rem)}
.trust .label{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);width:100%;text-align:center;margin-bottom:.4rem}
.trust img{height:42px;width:auto;opacity:.78;filter:grayscale(.2);transition:opacity .2s,filter .2s}
.trust img:hover{opacity:1;filter:none}
.trust .badge img{height:60px}
.partner-slot{height:42px;display:flex;align-items:center;padding:0 1.1rem;border:1px dashed var(--line);
  border-radius:var(--r-sm);font-family:var(--mono);font-size:.7rem;color:var(--muted);letter-spacing:.06em}

/* ---------- services ---------- */
.sec-head{max-width:62ch;margin-bottom:2.6rem}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.7rem 1.6rem;
  display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s,transform .2s;cursor:pointer}
.card:hover{border-color:var(--water);box-shadow:var(--sh-1);transform:translateY(-3px)}
.card .ico{width:46px;height:46px;border-radius:11px;background:rgba(46,155,214,.1);display:grid;place-items:center;margin-bottom:1.1rem}
.card .ico svg{width:24px;height:24px;color:var(--ink)}
.card h3{margin-bottom:.4rem}
.card p{font-size:.98rem;color:var(--muted);margin-bottom:1.1rem}
.card .more{margin-top:auto;font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--water-deep);font-weight:500;display:inline-flex;align-items:center;gap:.4rem}
.card:hover .more{gap:.7rem}

/* ---------- cross-section (signature) ---------- */
.shield{background:var(--shield);color:#E9E7F2}
.shield h2,.shield h3{color:#fff}
.shield .eyebrow{color:var(--water)}
.shield .lede{color:#C9C7DA}
.xsec-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.xsec-svg{width:100%;height:auto;border-radius:var(--r);background:linear-gradient(180deg,#34344e,#23233a);box-shadow:var(--sh-2)}
.steps{list-style:none;margin:0;padding:0;counter-reset:s}
.steps li{position:relative;padding:0 0 1.3rem 3rem;counter-increment:s}
.steps li::before{content:counter(s,decimal-leading-zero);position:absolute;left:0;top:-2px;
  font-family:var(--mono);font-size:.8rem;color:var(--water);border:1px solid rgba(46,155,214,.5);
  width:2rem;height:2rem;display:grid;place-items:center;border-radius:50%}
.steps li:last-child{padding-bottom:0}
.steps h4{color:#fff;margin:0 0 .25rem;font-size:1.1rem}
.steps p{color:#B9B7CC;font-size:.95rem;margin:0}

/* ---------- comparison table ---------- */
.tbl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r);background:var(--paper)}
table.cmp{width:100%;border-collapse:collapse;min-width:540px}
.cmp th,.cmp td{text-align:left;padding:1rem 1.2rem;border-bottom:1px solid var(--line);font-size:.97rem}
.cmp thead th{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:var(--bone)}
.cmp tbody th{font-weight:600;color:var(--ink-2)}
.cmp td .yes{color:var(--water-deep);font-weight:600}
.cmp tr:last-child td,.cmp tr:last-child th{border-bottom:none}

/* ---------- why / features ---------- */
.feat{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem 2.6rem}
.feat .item{display:flex;gap:1rem}
.feat .ico{flex:0 0 auto;width:42px;height:42px;border-radius:10px;background:var(--ink);display:grid;place-items:center}
.feat .ico svg{width:22px;height:22px;color:var(--water)}
.feat h3{font-size:1.15rem;margin-bottom:.25rem}
.feat p{font-size:.96rem;color:var(--muted);margin:0}

/* ---------- service area ---------- */
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,3.5rem);align-items:center}
.town-list{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.town{font-family:var(--mono);font-size:.8rem;letter-spacing:.04em;color:var(--ink-2);
  background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.45rem 1rem}
.map-card{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-1);background:var(--paper)}
.map-card iframe{width:100%;height:360px;border:0;display:block;filter:grayscale(.15)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line);padding:1.5rem 0}
.faq-item:first-of-type{border-top:1px solid var(--line)}
.faq-item h3{font-size:1.22rem;margin-bottom:.55rem;display:flex;gap:.7rem;align-items:flex-start}
.faq-item h3 .q{font-family:var(--mono);color:var(--water-deep);font-size:.95rem;flex:0 0 auto;padding-top:.15rem}
.faq-item p{color:var(--text);margin:0}

/* ---------- CTA band ---------- */
.cta{background:var(--ink);color:var(--bone);text-align:center}
.cta h2{color:#fff}
.cta p{color:#C9C7DA;margin:0 auto 2rem;max-width:54ch}
.cta .eyebrow{color:var(--water)}
.cta .hero-cta{justify-content:center}
.cta .btn-ghost{color:#fff;border-color:rgba(247,245,240,.55)}
.cta .btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}

/* ---------- footer ---------- */
.foot{background:var(--shield);color:#B9B7CC;font-size:.95rem;padding:clamp(3rem,5vw,4.5rem) 0 2rem}
.foot a{color:#C9C7DA}.foot a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem}
.foot h4{color:#fff;font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;margin:0 0 1rem}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.foot .fbrand .brand-name{color:#fff}.foot .fbrand .brand-sub{color:#8C8AA6}
.foot .nap{font-family:var(--mono);font-size:.82rem;line-height:1.8;color:#C9C7DA}
.foot-partners{display:flex;gap:1.2rem;align-items:center;margin-top:1rem}
.foot-partners img{height:30px;opacity:.7;filter:brightness(0) invert(1)}
.foot-bot{border-top:1px solid rgba(255,255,255,.12);margin-top:2.6rem;padding-top:1.4rem;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:#8C8AA6}
.foot-bot a{color:#8C8AA6}

/* ---------- placeholder honesty flag ---------- */
.todo{color:var(--amber);border-bottom:1.5px dashed var(--amber);font-style:normal;
  font-family:var(--mono);font-size:.92em;padding:0 .15em}
.todo::before{content:"⚑ "}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .frame{margin:0 auto;max-width:420px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .xsec-grid,.area-grid{grid-template-columns:1fr}
  .feat{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .specs-in{grid-template-columns:repeat(2,1fr)}
  .nav,.head-cta .btn{display:none}
  .menu-btn{display:inline-flex}
  .head-in{min-height:72px}
  .brand-logo{height:48px}
  .head .tel{font-size:.9rem}
}
@media(max-width:560px){
  .cards{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .hero-cta .btn{flex:1 1 100%;justify-content:center}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}}
