/* Shared service-page design system — Eden Prairie Inspection Tech
   Used by services/*.html. Scoped under .ss- prefix. */

.ss-wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.ss-crumbs{padding-top:120px;font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.ss-crumbs a{color:var(--mute);transition:color .2s}
.ss-crumbs a:hover{color:var(--accent3)}
.ss-crumbs .sep{opacity:.4}

/* HERO */
.ss-hero{position:relative;padding:36px 0 64px;overflow:hidden}
.ss-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 75% 30%,rgba(37,99,235,.18),transparent 70%);pointer-events:none}
.ss-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;position:relative;z-index:1}
.ss-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent3);padding:7px 14px;border:1px solid rgba(59,130,246,.3);border-radius:100px;background:rgba(37,99,235,.08);margin-bottom:22px}
.ss-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent3);box-shadow:0 0 10px var(--accent3);animation:ss-pulse 2s infinite}
@keyframes ss-pulse{0%,100%{opacity:1}50%{opacity:.5}}
.ss-h1{font-size:clamp(34px,5vw,58px);line-height:1.04;letter-spacing:-.025em;font-weight:700;margin-bottom:18px}
.ss-h1 em{font-style:normal;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;background-clip:text;color:transparent}
.ss-lead{font-size:18px;line-height:1.6;color:var(--mute);max-width:540px;margin-bottom:28px}
.ss-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.ss-btn{padding:13px 22px;border-radius:10px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px;transition:all .2s;white-space:nowrap}
.ss-btn-pri{background:linear-gradient(135deg,var(--accent3),var(--accent));color:#fff;box-shadow:0 0 24px var(--glow)}
.ss-btn-pri:hover{transform:translateY(-1px);box-shadow:0 6px 30px var(--glow)}
.ss-btn-ghost{border:1px solid var(--border);color:var(--ink)}
.ss-btn-ghost:hover{border-color:var(--accent3);color:var(--accent3)}
.ss-trust{display:flex;gap:24px;flex-wrap:wrap;font-family:'Geist Mono',monospace;font-size:11px;color:var(--mute);letter-spacing:.08em;text-transform:uppercase}
.ss-trust span{display:inline-flex;align-items:center;gap:6px}
.ss-trust span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--ok)}

/* HUD viewport — generic, reusable for any service hero */
.ss-hud{position:relative;display:block;width:100%;aspect-ratio:5/4;min-height:240px;border-radius:16px;border:1px solid rgba(59,130,246,.25);background:radial-gradient(ellipse at center,#0a1230 0%,#06070d 75%);overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5),inset 0 0 60px rgba(37,99,235,.08)}
.ss-hud-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(59,130,246,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.08) 1px,transparent 1px);background-size:40px 40px;mask-image:radial-gradient(ellipse 75% 65% at 50% 50%,#000 40%,transparent 90%);-webkit-mask-image:radial-gradient(ellipse 75% 65% at 50% 50%,#000 40%,transparent 90%)}
.ss-hud-art{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.ss-hud-art svg{width:78%;height:auto}
.ss-hud-corner{position:absolute;width:18px;height:18px;border:2px solid var(--accent3);opacity:.8}
.ss-hud-corner.tl{top:14px;left:14px;border-right:none;border-bottom:none}
.ss-hud-corner.tr{top:14px;right:14px;border-left:none;border-bottom:none}
.ss-hud-corner.bl{bottom:14px;left:14px;border-right:none;border-top:none}
.ss-hud-corner.br{bottom:14px;right:14px;border-left:none;border-top:none}
.ss-hud-readout{position:absolute;top:18px;left:42px;right:42px;display:flex;justify-content:space-between;font-family:'Geist Mono',monospace;font-size:10px;color:var(--accent3);letter-spacing:.12em;text-transform:uppercase;opacity:.85}
.ss-hud-readout .rec{display:inline-flex;align-items:center;gap:6px}
.ss-hud-readout .rec::before{content:"";width:7px;height:7px;border-radius:50%;background:#ef4444;box-shadow:0 0 10px #ef4444;animation:ss-pulse 1.4s infinite}
.ss-hud-bottom{position:absolute;bottom:18px;left:42px;right:42px;display:flex;justify-content:space-between;font-family:'Geist Mono',monospace;font-size:10px;color:var(--mute);letter-spacing:.12em;text-transform:uppercase}
.ss-scanline{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(59,130,246,.04) 50%,transparent 100%);background-size:100% 6px;pointer-events:none;opacity:.4}

/* SECTIONS */
.ss-section{padding:72px 0;border-top:1px solid var(--border)}
.ss-section-head{margin-bottom:40px;max-width:780px}
.ss-kicker{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent3);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.ss-kicker::before{content:"";width:32px;height:1px;background:var(--accent3)}
.ss-h2{font-size:clamp(28px,3.4vw,40px);line-height:1.1;letter-spacing:-.02em;font-weight:600;margin-bottom:14px}
.ss-section-lead{color:var(--mute);font-size:16px;line-height:1.7;max-width:680px}

/* DEFECT / FINDING TAXONOMY GRID */
.ss-defects{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ss-defect{background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));border:1px solid var(--border);border-radius:14px;padding:24px;transition:all .25s;position:relative;overflow:hidden}
.ss-defect:hover{border-color:rgba(59,130,246,.4);background:linear-gradient(180deg,rgba(37,99,235,.06),rgba(255,255,255,.01));transform:translateY(-2px)}
.ss-defect svg{width:64px;height:64px;margin-bottom:18px;display:block}
.ss-defect h3{font-size:17px;font-weight:600;margin-bottom:8px;letter-spacing:-.01em}
.ss-defect-tag{position:absolute;top:18px;right:18px;font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:3px 8px;border-radius:4px}
.ss-defect-tag.crit{background:rgba(239,68,68,.12);color:#fca5a5}
.ss-defect-tag.major{background:rgba(245,158,11,.12);color:#fcd34d}
.ss-defect-tag.mon{background:rgba(59,130,246,.12);color:#93c5fd}
.ss-defect p{color:var(--mute);font-size:14px;line-height:1.6}

/* PROCESS */
.ss-process{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--border);border-radius:14px;overflow:hidden}
.ss-step{padding:32px 28px;border-right:1px solid var(--border);position:relative}
.ss-step:last-child{border-right:none}
.ss-step-num{font-family:'Geist Mono',monospace;font-size:11px;color:var(--accent3);letter-spacing:.18em;margin-bottom:16px}
.ss-step h4{font-size:18px;font-weight:600;margin-bottom:10px;letter-spacing:-.01em}
.ss-step p{color:var(--mute);font-size:14px;line-height:1.65}
.ss-step-time{margin-top:14px;font-family:'Geist Mono',monospace;font-size:11px;color:var(--accent3);letter-spacing:.1em;text-transform:uppercase}

/* TABLE */
.ss-table{width:100%;border-collapse:collapse;font-size:14px}
.ss-table thead{background:rgba(37,99,235,.06)}
.ss-table th{text-align:left;padding:14px 18px;font-family:'Geist Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent3);font-weight:500;border-bottom:1px solid var(--border)}
.ss-table td{padding:16px 18px;border-bottom:1px solid var(--border);color:var(--ink)}
.ss-table td:nth-child(2){color:var(--mute);font-family:'Geist Mono',monospace;font-size:13px}
.ss-table td:last-child{font-family:'Geist Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.1em}
.ss-pill{display:inline-block;padding:3px 9px;border-radius:4px;font-size:10px}
.ss-pill.high{background:rgba(239,68,68,.12);color:#fca5a5}
.ss-pill.med{background:rgba(245,158,11,.12);color:#fcd34d}
.ss-pill.low{background:rgba(16,185,129,.12);color:#6ee7b7}

/* FAQ */
.ss-faq{display:flex;flex-direction:column;gap:8px}
.ss-faq details{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .2s}
.ss-faq details[open]{border-color:rgba(59,130,246,.35);background:rgba(37,99,235,.04)}
.ss-faq summary{padding:20px 24px;cursor:pointer;font-weight:500;font-size:16px;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.ss-faq summary::-webkit-details-marker{display:none}
.ss-faq summary::after{content:"+";font-family:'Geist Mono',monospace;font-size:22px;color:var(--accent3);font-weight:300;transition:transform .25s}
.ss-faq details[open] summary::after{transform:rotate(45deg)}
.ss-faq .ss-faq-a{padding:0 24px 22px;color:var(--mute);font-size:15px;line-height:1.7}

/* KEY-FACTS BANNER (no pricing) */
.ss-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.ss-fact{background:var(--bg);padding:26px 24px}
.ss-fact-num{font-size:30px;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:6px;font-family:'Geist',sans-serif}
.ss-fact-label{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}

/* INLINE CTA */
.ss-inline-cta{margin-top:48px;padding:36px 40px;border-radius:16px;background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(29,78,216,.06));border:1px solid rgba(59,130,246,.25);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.ss-inline-cta h3{font-size:22px;font-weight:600;letter-spacing:-.01em;margin-bottom:6px}
.ss-inline-cta p{color:var(--mute);font-size:14px}

/* RELATED */
.ss-related{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ss-related a{padding:20px 22px;border:1px solid var(--border);border-radius:12px;display:flex;justify-content:space-between;align-items:center;transition:all .2s;font-weight:500;font-size:15px}
.ss-related a:hover{border-color:rgba(59,130,246,.4);background:rgba(37,99,235,.04);color:var(--accent3)}
.ss-related a span{font-family:'Geist Mono',monospace;color:var(--accent3);font-size:13px}

/* RESPONSIVE — mobile-first refinements */

/* Tablet / large mobile (≤1024px) — adjust hero balance */
@media (max-width:1024px){
  .ss-wrap{padding:0 20px}
  .ss-hero-grid{grid-template-columns:1fr 1fr;gap:40px}
  .ss-h1{font-size:clamp(30px,4.5vw,46px)}
  .ss-section{padding:64px 0}
}

/* Mobile breakpoint (≤900px) — single-column everywhere */
@media (max-width:900px){
  .ss-wrap{padding:0 18px}
  .ss-crumbs{padding-top:96px;font-size:10px}
  .ss-hero{padding:24px 0 48px}
  .ss-hero-grid{grid-template-columns:1fr;gap:36px}
  .ss-eyebrow{font-size:10px;padding:6px 12px}
  .ss-h1{font-size:clamp(28px,7vw,42px);line-height:1.06}
  .ss-lead{font-size:16px}
  .ss-trust{gap:14px;font-size:10px}
  .ss-hud{max-width:520px;margin:0 auto}
  .ss-hud-readout,.ss-hud-bottom{left:30px;right:30px;font-size:9px}
  .ss-defects{grid-template-columns:1fr 1fr}
  .ss-defect{padding:20px}
  .ss-process{grid-template-columns:1fr}
  .ss-step{border-right:none;border-bottom:1px solid var(--border);padding:26px 22px}
  .ss-step:last-child{border-bottom:none}
  .ss-facts{grid-template-columns:1fr 1fr}
  .ss-fact{padding:22px 20px}
  .ss-fact-num{font-size:26px}
  .ss-related{grid-template-columns:1fr 1fr}
  .ss-section{padding:56px 0}
  .ss-section-head{margin-bottom:32px}
  .ss-h2{font-size:clamp(24px,5vw,34px)}
  .ss-table{font-size:13px}
  .ss-table th,.ss-table td{padding:12px 14px}
  .ss-table th{font-size:10px}
  .ss-inline-cta{padding:28px 26px}
  .ss-inline-cta h3{font-size:19px}
}

/* Small mobile (≤640px) — single-column finals */
@media (max-width:640px){
  .ss-defects{grid-template-columns:1fr}
  .ss-facts{grid-template-columns:1fr}
  .ss-related{grid-template-columns:1fr}
  .ss-inline-cta{flex-direction:column;align-items:flex-start;padding:24px 20px;margin-top:36px}
  .ss-inline-cta h3{font-size:18px;line-height:1.25}
  .ss-cta-row{flex-direction:column;align-items:stretch}
  .ss-cta-row .ss-btn{justify-content:center;text-align:center}
  .ss-trust{flex-direction:column;gap:8px;align-items:flex-start}
  .ss-h1{font-size:clamp(26px,8vw,34px)}
  .ss-h2{font-size:clamp(22px,6vw,28px)}
  .ss-section{padding:48px 0}
  .ss-section-head{margin-bottom:28px}
  .ss-lead{font-size:15px}
  .ss-section-lead{font-size:15px}
  .ss-fact-num{font-size:24px}
  .ss-step h4,.ss-defect h3{font-size:16px}
  .ss-faq summary{padding:16px 18px;font-size:15px}
  .ss-faq .ss-faq-a{padding:0 18px 18px;font-size:14px}
  .ss-related a{padding:16px 18px;font-size:14px}
  /* Make tables scrollable rather than crushed */
  .ss-table{font-size:12px;min-width:520px}
}

/* Very small (≤380px) — final safety */
@media (max-width:380px){
  .ss-wrap{padding:0 14px}
  .ss-h1{font-size:24px;line-height:1.1}
  .ss-h2{font-size:21px}
  .ss-hud-readout,.ss-hud-bottom{left:20px;right:20px;font-size:8px}
  .ss-hud-corner{width:14px;height:14px}
  .ss-fact{padding:18px 16px}
  .ss-fact-num{font-size:22px}
  .ss-defect{padding:18px}
  .ss-step{padding:22px 18px}
}

/* Touch targets — ensure 44px minimum on touch */
@media (pointer:coarse){
  .ss-btn{min-height:44px}
  .ss-faq summary{min-height:48px}
  .ss-related a{min-height:48px}
}

/* Reduce-motion safety */
@media (prefers-reduced-motion:reduce){
  .ss-eyebrow::before,
  .ss-hud-readout .rec::before{animation:none}
  .ss-defect:hover,
  .ss-btn-pri:hover,
  .ss-related a:hover{transform:none}
}
