/* ============================================================
   JESUP SEPTIC — Shared Stylesheet
   Scope: all service pages (loaded via <link rel="stylesheet" href="styles.css" />)
   Palette: Civic Navy #1a3665 + Forest Green #22643e
   Fonts: Exo 2 (headings/UI), Inter (body)
   ============================================================ */

:root{
  --primary:#1a3665;
  --primary-light:#22428a;
  --primary-mid:#1d3c75;
  --primary-dark:#122b55;
  --primary-rgb:26,54,101;

  --accent-rgb:34,100,62;
  --accent:#22643e;
  --accent-light:#2d7d50;
  --accent-dark:#174d2e;
  --accent-bright:#52c97d;
  --accent-gradient:linear-gradient(135deg,var(--accent),var(--accent-light));
  --accent-secondary:#5c7a9e;
  --navy-gradient:linear-gradient(135deg,var(--primary-light),var(--primary));
  --ice-blue:#eef2f9;
  --ice-blue-dark:#d8e4f0;

  --header-navy:#152e58;
  --header-navy-rgb:21,46,88;
  --depth-dark:#0f2248;
  --depth-darker:#091838;
  --slate-gradient:linear-gradient(135deg,var(--primary-light),var(--primary));
  --depth-gradient:linear-gradient(135deg,var(--primary),var(--primary-dark));

  --white:#ffffff;
  --warm-white:#f0f4f9;
  --off-white:#eef1f7;
  --surface-chat:#f8fafc;
  --surface-alt:var(--ice-blue);
  --gray:#4e6180;
  --gray-light:#c4d3e4;
  --gray-dark:#2d3f58;
  --text-muted:#7f8c9a;
  --red-urgent:#c0392b;
  --red-urgent-rgb:192,57,43;
  --success:#27ae60;
  --warning:#e67e22;

  --shadow-sm:0 2px 4px rgba(var(--primary-rgb),.12);
  --shadow-md:0 4px 12px rgba(var(--primary-rgb),.18);
  --shadow-lg:0 8px 24px rgba(var(--primary-rgb),.22);
  --shadow-xl:0 16px 48px rgba(var(--primary-rgb),.28);

  --transition-fast:.2s ease;
  --transition-base:.3s ease;
  --transition-slow:.5s ease;

  --radius-sm:3px;
  --radius-md:6px;
  --radius-lg:10px;
  --radius-xl:14px;

  --space-xs:.5rem;
  --space-sm:1rem;
  --space-md:1.5rem;
  --space-lg:2rem;
  --space-xl:3rem;
  --space-2xl:4.5rem
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,sans-serif;font-size:1rem;line-height:1.65;color:var(--gray-dark);background:var(--white);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
input,select,textarea{font-family:inherit}
h1,h2,h3,h4{font-family:'Exo 2',sans-serif;font-weight:700;line-height:1.2;color:var(--primary)}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
strong{font-weight:600;color:var(--primary)}

/* ── Skip link ──────────────────────────────────────────── */
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--accent);color:var(--white);padding:.5rem 1rem;border-radius:var(--radius-sm);z-index:9999;font-weight:600;font-size:.875rem}
.skip-link:focus{top:.5rem}

/* ── Layout utilities ───────────────────────────────────── */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-lg)}

/* ── Buttons ────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent-gradient);color:var(--white);font-family:'Exo 2',sans-serif;font-weight:700;font-size:1rem;padding:.85rem 2rem;border-radius:var(--radius-lg);box-shadow:0 4px 16px rgba(var(--accent-rgb),.38);transition:transform var(--transition-base),box-shadow var(--transition-base);text-decoration:none;border:none;cursor:pointer}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 22px rgba(var(--accent-rgb),.50)}
.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;background:rgba(var(--accent-rgb),.15);border:1px solid rgba(var(--accent-rgb),.40);color:var(--accent-light);font-family:'Exo 2',sans-serif;font-weight:600;font-size:.95rem;padding:.8rem 1.75rem;border-radius:var(--radius-lg);transition:background var(--transition-base),border-color var(--transition-base);cursor:pointer;text-decoration:none}
.btn-secondary:hover{background:rgba(var(--accent-rgb),.25);border-color:rgba(var(--accent-rgb),.65)}

/* ── Header ─────────────────────────────────────────────── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:68px;display:flex;align-items:center;background:rgba(var(--header-navy-rgb),.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(var(--accent-rgb),.15);border-top:3px solid var(--accent);transition:background var(--transition-base),box-shadow var(--transition-base)}
.site-header.scrolled{background:rgba(var(--header-navy-rgb),.97);box-shadow:0 2px 20px rgba(0,0,0,.4)}
.header-inner{max-width:1200px;width:100%;margin:0 auto;padding:0 var(--space-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg)}
.site-logo{display:flex;align-items:center}
.site-logo img{height:44px;width:auto}
.site-nav{display:flex;align-items:center;gap:var(--space-lg)}
.site-nav a{color:rgba(255,255,255,.85);font-size:.925rem;font-weight:500;letter-spacing:.01em;transition:color var(--transition-fast)}
.site-nav a:hover{color:var(--accent-bright)}
.nav-cta{background:var(--accent-gradient)!important;color:var(--white)!important;padding:.55rem 1.25rem;border-radius:var(--radius-md);font-weight:600!important;font-size:.875rem!important;box-shadow:0 3px 12px rgba(var(--accent-rgb),.3);transition:transform var(--transition-fast),box-shadow var(--transition-fast)!important}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(var(--accent-rgb),.42)!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;border-radius:var(--radius-sm)}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:transform var(--transition-base),opacity var(--transition-base)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;position:fixed;top:68px;left:0;right:0;background:var(--depth-dark);border-bottom:2px solid var(--accent);padding:var(--space-md) var(--space-lg);z-index:999;flex-direction:column;gap:var(--space-sm)}
.mobile-nav.open{display:flex}
.mobile-nav a{color:rgba(255,255,255,.9);font-size:1rem;font-weight:500;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.08);transition:color var(--transition-fast)}
.mobile-nav a:last-child{border-bottom:none}
.mobile-nav a:hover{color:var(--accent-bright)}
.mobile-nav .nav-cta{text-align:center;display:block;padding:.8rem!important;margin-top:var(--space-xs);border-radius:var(--radius-md)}

/* ── Footer ──────────────────────────────────────────────── */
.site-footer{background:radial-gradient(ellipse at center,var(--header-navy) 0%,var(--depth-darker) 100%);position:relative;overflow:hidden}
.site-footer::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(var(--accent-rgb),.04) 1px,transparent 1px),linear-gradient(90deg,rgba(var(--accent-rgb),.04) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}
.footer-main{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:var(--space-2xl) var(--space-lg) var(--space-xl);display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:var(--space-xl)}
.footer-brand p{color:rgba(255,255,255,.82);font-size:.88rem;line-height:1.7;margin-top:var(--space-sm);max-width:280px}
.footer-logo{margin-bottom:var(--space-sm)}
.footer-logo img{height:38px;width:auto}
.footer-contact-item{display:flex;align-items:flex-start;gap:.5rem;color:rgba(255,255,255,.82);font-size:.875rem;margin-top:var(--space-sm);line-height:1.5}
.footer-contact-item svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--accent-bright)}
.footer-contact-item a{color:var(--accent-bright);font-weight:500;transition:color var(--transition-fast)}
.footer-contact-item a:hover{color:var(--white)}
.footer-col h4{font-family:'Exo 2',sans-serif;font-weight:700;font-size:.875rem;color:var(--white);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--space-md);padding-bottom:.5rem;border-bottom:1px solid rgba(var(--accent-rgb),.25)}
.footer-col ul li{padding:.3rem 0}
.footer-col ul li a,.footer-col ul li span{color:rgba(255,255,255,.80);font-size:.875rem;transition:color var(--transition-fast)}
.footer-col ul li a:hover{color:var(--accent-bright)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:var(--space-md) var(--space-lg);max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);color:rgba(255,255,255,.78)}
.footer-bottom a{color:rgba(255,255,255,.78);transition:color var(--transition-fast)}
.footer-bottom a:hover{color:var(--accent-bright)}

/* ── Mobile Toolbar ──────────────────────────────────────── */
.mobile-toolbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:998;background:var(--depth-dark);border-top:1px solid rgba(var(--accent-rgb),.25);padding:.6rem var(--space-md);padding-bottom:calc(.6rem + env(safe-area-inset-bottom));gap:var(--space-sm)}
.toolbar-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.7rem;border-radius:var(--radius-md);font-family:'Exo 2',sans-serif;font-weight:700;font-size:.875rem;min-height:44px;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}
.toolbar-quote{background:var(--accent-gradient);color:var(--white);box-shadow:0 3px 10px rgba(var(--accent-rgb),.30)}
.toolbar-chat{background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.35);color:var(--accent-bright)}
.toolbar-btn svg{width:18px;height:18px}
.toolbar-btn:active{transform:scale(.97)}

/* ── Chat Widget ─────────────────────────────────────────── */
.chat-btn{position:fixed;bottom:var(--space-lg);right:var(--space-lg);width:56px;height:56px;border-radius:50%;background:var(--accent-gradient);color:var(--white);box-shadow:0 4px 18px rgba(var(--accent-rgb),.42);display:flex;align-items:center;justify-content:center;z-index:990;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}
.chat-btn:hover{transform:scale(1.08);box-shadow:0 0 24px rgba(var(--accent-rgb),.58)}
.chat-btn svg{width:26px;height:26px}
.chat-badge{position:absolute;top:-2px;right:-2px;width:14px;height:14px;border-radius:50%;background:var(--success);border:2px solid var(--white)}
.chat-panel{position:fixed;bottom:calc(var(--space-lg) + 68px);right:var(--space-lg);width:340px;max-height:480px;background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),0 0 40px rgba(0,0,0,.15);display:none;flex-direction:column;z-index:991;overflow:hidden;border:1px solid rgba(var(--accent-rgb),.2)}
.chat-panel.open{display:flex}
.chat-header{background:var(--accent-gradient);padding:var(--space-sm) var(--space-md);display:flex;align-items:center;justify-content:space-between}
.chat-header-info{display:flex;align-items:center;gap:.6rem}
.chat-avatar{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center}
.chat-avatar svg{width:20px;height:20px;color:var(--white)}
.chat-name{font-family:'Exo 2',sans-serif;font-weight:700;font-size:.9rem;color:var(--white)}
.chat-status{font-size:.75rem;color:rgba(255,255,255,.78)}
.chat-close{color:rgba(255,255,255,.8);padding:4px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}
.chat-close:hover{background:rgba(255,255,255,.15)}
.chat-close svg{width:18px;height:18px}
.chat-messages{flex:1;overflow-y:auto;padding:var(--space-md);background:var(--surface-chat);display:flex;flex-direction:column;gap:var(--space-sm)}
.chat-bubble{max-width:85%;padding:.6rem .9rem;border-radius:var(--radius-lg);font-size:.875rem;line-height:1.55}
.chat-bubble.bot{background:var(--white);color:var(--gray-dark);border:1px solid var(--gray-light);align-self:flex-start;border-radius:var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg)}
.chat-bubble.user{background:var(--accent);color:var(--white);align-self:flex-end;border-radius:var(--radius-lg) var(--radius-sm) var(--radius-lg) var(--radius-lg)}
.chat-typing{display:none;align-self:flex-start;background:var(--white);border:1px solid var(--gray-light);border-radius:var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg);padding:.6rem .9rem}
.chat-typing.active{display:flex;align-items:center;gap:4px}
.dot{width:7px;height:7px;border-radius:50%;background:var(--accent-secondary)}
.dot:nth-child(1){animation:typing-dots 1.2s ease 0s infinite}
.dot:nth-child(2){animation:typing-dots 1.2s ease .2s infinite}
.dot:nth-child(3){animation:typing-dots 1.2s ease .4s infinite}
@keyframes typing-dots{0%,60%,100%{transform:translateY(0);opacity:.5}30%{transform:translateY(-6px);opacity:1}}
.chat-input-row{display:flex;padding:var(--space-sm) var(--space-md);gap:.5rem;border-top:1px solid var(--gray-light);background:var(--white);align-items:flex-end}
.chat-input{flex:1;border:1.5px solid var(--gray-light);border-radius:var(--radius-lg);padding:.55rem .9rem;font-size:.875rem;resize:none;min-height:38px;max-height:90px;line-height:1.5;color:var(--gray-dark);transition:border-color var(--transition-fast)}
.chat-input:focus{outline:none;border-color:var(--accent)}
.chat-send{width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--white);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition-fast),transform var(--transition-fast)}
.chat-send:hover{background:var(--accent-dark);transform:scale(1.05)}
.chat-send:disabled{opacity:.6;cursor:not-allowed;transform:none}
.chat-send svg{width:17px;height:17px}

/* ── Scroll animations ───────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ── Reduced motion ──────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.dot,.chat-badge{animation:none}}

/* ── 1024px ──────────────────────────────────────────────── */
@media(max-width:1024px){.footer-main{grid-template-columns:1fr 1fr;gap:var(--space-lg)}}

/* ── 768px ───────────────────────────────────────────────── */
@media(max-width:768px){:root{--space-xl:2.5rem;--space-2xl:3.5rem}.site-nav{display:none}.nav-toggle{display:flex}.footer-main{grid-template-columns:1fr 1fr;gap:var(--space-lg)}.chat-panel{width:calc(100vw - 2rem);right:1rem}.mobile-toolbar{display:flex}.chat-btn{bottom:calc(var(--space-lg) + 72px)}}

/* ── 480px ───────────────────────────────────────────────── */
@media(max-width:480px){:root{--space-xl:2rem;--space-2xl:3rem;--space-lg:1.75rem}.header-inner{padding:0 var(--space-md)}.footer-main{grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center}.chat-input{font-size:16px}}

/* ── 375px ───────────────────────────────────────────────── */
@media(max-width:375px){.footer-bottom{flex-direction:column;text-align:center}}

/* ── Cluster-links prose block (homepage) ───────────────── */
.cluster-links{max-width:860px;margin:0 auto;background:var(--white);border-left:3px solid var(--accent);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:var(--space-md) var(--space-lg);font-size:.9rem;color:var(--gray);line-height:1.7}
.cluster-links a{color:var(--accent);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.cluster-links a:hover{color:var(--accent-dark)}

/* ── Related Local Services (service pages) ─────────────── */
.related-cluster{background:var(--off-white);padding:var(--space-2xl) var(--space-lg)}
.related-cluster-inner{max-width:1100px;margin:0 auto}
.related-cluster h2{color:var(--primary);font-size:clamp(1.2rem,2.5vw,1.5rem);margin-bottom:var(--space-lg)}
.cluster-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-md)}
.cluster-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-sm);border-top:3px solid var(--accent);display:flex;flex-direction:column;gap:var(--space-xs)}
.cluster-card-icon{width:40px;height:40px;background:rgba(var(--accent-rgb),.10);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}
.cluster-card-icon svg{width:22px;height:22px}
.cluster-card h3{font-size:1rem;color:var(--primary);margin:0}
.cluster-card p{font-size:.875rem;color:var(--gray);line-height:1.65;margin:0}
.cluster-card-link{display:inline-flex;align-items:center;gap:.35rem;margin-top:auto;padding-top:var(--space-xs);font-size:.875rem;font-weight:600;color:var(--accent);text-decoration:underline;text-underline-offset:2px;transition:color var(--transition-fast)}
.cluster-card-link:hover{color:var(--accent-dark)}
