/* ============================================================
   ONSITE SCREEN FIX — Global Stylesheet
   assets/css/style.css
   ============================================================ */

:root {
  --brand:       #1a3de4;
  --brand-dark:  #0f27a8;
  --brand-light: #e8edff;
  --accent:      #ff4d00;
  --accent-light:#fff1eb;
  --dark:        #0a0f1e;
  --gray-900:    #111827;
  --gray-700:    #374151;
  --gray-500:    #6b7280;
  --gray-300:    #d1d5db;
  --gray-200:    #e5e7eb;
  --gray-100:    #f3f4f6;
  --white:       #ffffff;
  --green:       #059669;
  --green-light: #ecfdf5;

  --radius:    12px;
  --radius-lg: 20px;
  --shadow:    0 4px 24px rgba(10,15,30,.10);
  --shadow-lg: 0 12px 48px rgba(10,15,30,.16);

  --font:         'Barlow', sans-serif;
  --font-display: 'Barlow Condensed', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font);
  color: var(--gray-900);
  background: var(--white);
  line-height: 1.6;
  overflow-x: hidden;
}
img  { max-width: 100%; height: auto; display: block; }
a    { text-decoration: none; color: inherit; }
ul   { list-style: none; }

/* ── UTILITY ── */
.sr-only { position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0; }

/* ── BUTTONS ── */
.btn-primary {
  display:inline-flex;align-items:center;gap:8px;
  background:var(--brand);color:var(--white);
  padding:.875rem 1.75rem;border-radius:50px;
  font-family:var(--font);font-size:1rem;font-weight:700;
  border:none;cursor:pointer;
  transition:background .2s,transform .15s,box-shadow .2s;
  box-shadow:0 4px 16px rgba(26,61,228,.25);
  text-decoration:none;
}
.btn-primary:hover { background:var(--brand-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,61,228,.35); }
.btn-primary:active { transform:translateY(0); }

.btn-accent {
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:var(--white);
  padding:.875rem 1.75rem;border-radius:50px;
  font-family:var(--font);font-size:1rem;font-weight:700;
  border:none;cursor:pointer;
  transition:all .2s;
  box-shadow:0 4px 16px rgba(255,77,0,.30);
  text-decoration:none;
}
.btn-accent:hover { background:#e03d00;transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,77,0,.4); }

.btn-outline {
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--brand);
  padding:.875rem 1.75rem;border-radius:50px;
  font-family:var(--font);font-size:1rem;font-weight:700;
  border:2px solid var(--brand);cursor:pointer;
  transition:all .2s;
  text-decoration:none;
}
.btn-outline:hover { background:var(--brand);color:var(--white); }

.btn-white {
  display:inline-flex;align-items:center;gap:8px;
  background:var(--white);color:var(--accent);
  padding:.875rem 2rem;border-radius:50px;
  font-family:var(--font);font-size:1rem;font-weight:700;
  border:none;cursor:pointer;
  transition:all .2s;
  box-shadow:0 4px 20px rgba(0,0,0,.2);
  text-decoration:none;
}
.btn-white:hover { transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.3); }

/* ── NAVIGATION ── */
.nav {
  position:sticky;top:0;z-index:900;
  background:var(--white);
  border-bottom:1px solid var(--gray-200);
  padding:0 1.5rem;
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
  box-shadow:0 1px 8px rgba(0,0,0,.06);
}
.nav-logo {
  font-family:var(--font-display);
  font-size:1.5rem;font-weight:900;color:var(--brand);
  letter-spacing:-.5px;
  display:flex;align-items:center;gap:8px;
  text-decoration:none;
}
.nav-logo span { color:var(--accent); }
.nav-logo svg  { width:28px;height:28px; }
.nav-links { display:flex;align-items:center;gap:1.5rem; }
.nav-links a {
  font-size:.9rem;font-weight:600;color:var(--gray-700);
  transition:color .2s;text-decoration:none;
}
.nav-links a:hover,
.nav-links a[aria-current="page"] { color:var(--brand); }
.nav-cta {
  background:var(--brand);color:var(--white)!important;
  padding:.5rem 1.25rem;border-radius:50px;
  font-size:.875rem!important;transition:background .2s,transform .15s!important;
}
.nav-cta:hover { background:var(--brand-dark)!important;transform:scale(1.03); }
.nav-hamburger { display:none;cursor:pointer;border:none;background:none;padding:4px; }
.nav-hamburger svg { width:24px;height:24px;color:var(--gray-700); }

/* Mobile nav */
.mobile-nav {
  display:none;position:fixed;top:64px;left:0;right:0;
  background:var(--white);border-bottom:1px solid var(--gray-200);
  padding:1.5rem;z-index:899;
  flex-direction:column;gap:1.25rem;
  box-shadow:var(--shadow-lg);
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  font-size:1.1rem;font-weight:600;color:var(--gray-700);
  padding:.5rem 0;border-bottom:1px solid var(--gray-100);
  text-decoration:none;
}

/* ── SECTION LAYOUT ── */
section { padding:5rem 1.5rem; }
.section-inner { max-width:1100px;margin:0 auto; }
.section-tag {
  display:inline-flex;align-items:center;gap:6px;
  font-size:.75rem;font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--brand);
  margin-bottom:.875rem;
}
.section-tag::before { content:'';display:block;width:20px;height:2px;background:var(--brand);border-radius:1px; }
h2.section-title {
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3rem);
  font-weight:900;letter-spacing:-.5px;line-height:1.1;
  color:var(--dark);margin-bottom:1rem;
}
.section-sub {
  font-size:1.05rem;color:var(--gray-500);
  max-width:560px;line-height:1.7;margin-bottom:3rem;
}

/* ── SERVICE STRIP ── */
.service-strip { background:var(--brand);padding:.875rem 1.5rem;overflow:hidden; }
.strip-inner {
  display:flex;gap:3rem;align-items:center;
  animation:marquee 28s linear infinite;white-space:nowrap;
}
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.strip-item {
  display:flex;align-items:center;gap:8px;
  font-size:.875rem;font-weight:600;color:var(--white);opacity:.9;flex-shrink:0;
}
.strip-dot { width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.5); }

/* ── CARDS ── */
.service-card {
  border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);
  padding:1.75rem;transition:all .25s;position:relative;overflow:hidden;
  background:var(--white);
}
.service-card::before {
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--brand);transform:scaleX(0);transition:transform .25s;transform-origin:left;
}
.service-card:hover { border-color:var(--brand);box-shadow:var(--shadow-lg);transform:translateY(-3px); }
.service-card:hover::before { transform:scaleX(1); }
.service-icon { font-size:2.5rem;margin-bottom:1rem; }
.service-card h3 { font-size:1.15rem;font-weight:700;margin-bottom:.5rem;color:var(--dark); }
.service-card p { font-size:.9rem;color:var(--gray-500);line-height:1.6;margin-bottom:1rem; }
.service-price {
  display:inline-flex;align-items:center;gap:4px;
  background:var(--brand-light);color:var(--brand);
  padding:.3rem .875rem;border-radius:50px;font-size:.8rem;font-weight:700;
}
.service-devices { display:flex;flex-wrap:wrap;gap:6px;margin-top:.75rem; }
.device-tag {
  font-size:.72rem;font-weight:600;background:var(--gray-100);
  color:var(--gray-700);padding:3px 10px;border-radius:50px;
}

/* ── WHY CARDS ── */
.why-card {
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg);padding:1.75rem;transition:background .2s;
}
.why-card:hover { background:rgba(255,255,255,.09); }
.why-icon { font-size:2rem;margin-bottom:1rem; }
.why-card h3 { font-size:1.1rem;font-weight:700;margin-bottom:.5rem;color:var(--white); }
.why-card p  { font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.6; }

/* ── REVIEW CARDS ── */
.review-card {
  background:var(--white);border:1.5px solid var(--gray-200);
  border-radius:var(--radius-lg);padding:1.75rem;transition:box-shadow .2s;
}
.review-card:hover { box-shadow:var(--shadow-lg); }
.review-stars { display:flex;gap:3px;margin-bottom:.875rem; }
.review-stars svg { width:18px;height:18px;fill:#f59e0b; }
.review-text { font-size:.95rem;color:var(--gray-700);line-height:1.7;margin-bottom:1.25rem;font-style:italic; }
.review-author { display:flex;align-items:center;gap:10px; }
.review-avatar {
  width:40px;height:40px;border-radius:50%;
  background:var(--brand-light);color:var(--brand);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.875rem;flex-shrink:0;
}
.review-author-info strong { display:block;font-size:.875rem;font-weight:700;color:var(--dark); }
.review-author-info span  { font-size:.78rem;color:var(--gray-500); }

/* ── FAQ ── */
.faq-item { border-bottom:1px solid var(--gray-200); }
.faq-q {
  width:100%;background:none;border:none;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.25rem 0;
  font-family:var(--font);font-size:1rem;font-weight:600;
  color:var(--dark);text-align:left;transition:color .2s;
}
.faq-q:hover { color:var(--brand); }
.faq-q svg { width:20px;height:20px;flex-shrink:0;transition:transform .25s;color:var(--gray-500); }
.faq-q.open svg { transform:rotate(180deg);color:var(--brand); }
.faq-a { display:none;padding-bottom:1.25rem;font-size:.95rem;color:var(--gray-500);line-height:1.7; }
.faq-a.open { display:block; }

/* ── STEPS ── */
.step {
  background:var(--white);border-radius:var(--radius-lg);padding:2rem 1.5rem;
  box-shadow:var(--shadow);position:relative;transition:transform .2s,box-shadow .2s;
}
.step:hover { transform:translateY(-4px);box-shadow:var(--shadow-lg); }
.step-num { font-family:var(--font-display);font-size:4rem;font-weight:900;color:var(--brand-light);line-height:1;margin-bottom:.5rem;user-select:none; }
.step-icon { font-size:2rem;margin-bottom:.75rem; }
.step h3 { font-size:1.125rem;font-weight:700;margin-bottom:.5rem;color:var(--dark); }
.step p  { font-size:.9rem;color:var(--gray-500);line-height:1.6; }

/* ── STATS ── */
.stats-bg {
  background:linear-gradient(135deg,var(--brand) 0%,#0f27a8 100%);
  color:var(--white);text-align:center;padding:4rem 1.5rem;
}
.stat-num {
  font-family:var(--font-display);font-size:clamp(2.5rem,5vw,4rem);
  font-weight:900;line-height:1;color:var(--white);margin-bottom:.5rem;
}
.stat-label { font-size:.875rem;color:rgba(255,255,255,.7);font-weight:500; }

/* ── CTA BANNER ── */
.cta-banner { background:var(--accent);padding:3rem 1.5rem;text-align:center;color:var(--white); }
.cta-banner h2 { font-family:var(--font-display);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:900;margin-bottom:.75rem; }
.cta-banner p  { font-size:1.05rem;opacity:.9;margin-bottom:2rem; }

/* ── HIGHLIGHT BOX ── */
.highlight-box {
  background:var(--brand-light);border-left:4px solid var(--brand);
  border-radius:0 var(--radius) var(--radius) 0;
  padding:1.25rem 1.5rem;margin:1.5rem 0;
  font-size:.95rem;color:var(--brand-dark);font-weight:600;
}

/* ── PAGE HERO (inner pages) ── */
.page-hero {
  background:linear-gradient(135deg,var(--dark) 0%,#0d1f6b 50%,#1a3de4 100%);
  color:var(--white);padding:4rem 1.5rem;text-align:center;
}
.page-hero h1 {
  font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);
  font-weight:900;letter-spacing:-.5px;margin-bottom:1rem;
}
.page-hero p { font-size:1.1rem;color:rgba(255,255,255,.75);max-width:600px;margin:0 auto; }

/* ── BREADCRUMB ── */
.breadcrumb {
  background:var(--gray-100);padding:.875rem 1.5rem;
  font-size:.85rem;color:var(--gray-500);
}
.breadcrumb-inner { max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:8px; }
.breadcrumb a { color:var(--brand);font-weight:600;text-decoration:none; }
.breadcrumb a:hover { text-decoration:underline; }
.breadcrumb span { color:var(--gray-300); }

/* ── LOCATION CARDS ── */
.location-card {
  border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);
  padding:1.5rem;transition:all .25s;background:var(--white);display:block;text-decoration:none;
}
.location-card:hover { border-color:var(--brand);box-shadow:var(--shadow);transform:translateY(-3px); }
.location-card h3 { font-size:1rem;font-weight:700;color:var(--dark);margin-bottom:.35rem; }
.location-card p  { font-size:.82rem;color:var(--gray-500);line-height:1.5;margin-bottom:.75rem; }
.location-card .arrow { font-size:.8rem;color:var(--brand);font-weight:700; }

/* ── FOOTER ── */
footer { background:var(--gray-900);color:var(--white);padding:4rem 1.5rem 2rem; }
.footer-inner { max-width:1100px;margin:0 auto; }
.footer-top { display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem; }
.footer-brand p { font-size:.9rem;color:rgba(255,255,255,.5);line-height:1.7;margin-top:.875rem;max-width:280px; }
.footer-col h4 { font-size:.8rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:1rem; }
.footer-col a { display:block;font-size:.9rem;color:rgba(255,255,255,.6);margin-bottom:.5rem;transition:color .2s;text-decoration:none; }
.footer-col a:hover { color:var(--white); }
.footer-bottom {
  padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
  font-size:.78rem;color:rgba(255,255,255,.35);
}
.footer-bottom a { color:rgba(255,255,255,.45); }
.footer-bottom a:hover { color:var(--white); }

/* ── PHONE BADGE ── */
.phone-badge {
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  border-radius:50px;padding:.6rem 1.25rem;color:var(--white);
  font-weight:700;font-size:1.1rem;
  margin-bottom:2rem;transition:background .2s;text-decoration:none;
}
.phone-badge:hover { background:rgba(255,255,255,.14);color:var(--white); }
.phone-badge svg { width:20px;height:20px;color:#4ade80; }

/* ── STICKY CALL (mobile) ── */
.sticky-call {
  display:none;position:fixed;bottom:1rem;left:1rem;z-index:800;
  background:var(--green);color:var(--white);
  border-radius:50px;padding:.75rem 1.25rem;
  font-weight:700;font-size:.9rem;
  box-shadow:0 4px 20px rgba(5,150,105,.4);
  align-items:center;gap:8px;text-decoration:none;
}

/* ── GRIDS ── */
.grid-2 { display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem; }
.grid-3 { display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem; }
.grid-4 { display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem; }
.grid-steps { display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem; }

/* ── PROSE (terms/privacy) ── */
.prose { max-width:800px;margin:0 auto; }
.prose h2 { font-family:var(--font-display);font-size:1.6rem;font-weight:900;color:var(--dark);margin:2.5rem 0 .75rem; }
.prose h3 { font-size:1.1rem;font-weight:700;color:var(--dark);margin:1.75rem 0 .5rem; }
.prose p  { font-size:1rem;color:var(--gray-700);line-height:1.85;margin-bottom:1rem; }
.prose ul { padding-left:1.5rem;margin-bottom:1rem; }
.prose ul li { font-size:1rem;color:var(--gray-700);line-height:1.8;margin-bottom:.35rem;list-style:disc; }
.prose a  { color:var(--brand);text-decoration:underline; }
.prose .last-updated { font-size:.85rem;color:var(--gray-500);margin-bottom:2rem; }
.prose .toc { background:var(--gray-100);border-radius:var(--radius);padding:1.5rem;margin-bottom:2.5rem; }
.prose .toc h4 { font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gray-500);margin-bottom:.75rem; }
.prose .toc ol { padding-left:1.25rem; }
.prose .toc li { font-size:.9rem;color:var(--brand);line-height:1.9;list-style:decimal; }
.prose .toc a { color:var(--brand); }

/* ── RESPONSIVE ── */
@media (max-width:768px) {
  .nav-links { display:none; }
  .nav-hamburger { display:block; }
  section { padding:3.5rem 1.25rem; }
  .footer-top { grid-template-columns:1fr 1fr;gap:2rem; }
  .footer-brand { grid-column:1/-1; }
  .sticky-call { display:flex; }
  .grid-steps { grid-template-columns:1fr 1fr; }
}
@media (max-width:480px) {
  .footer-top { grid-template-columns:1fr; }
  .grid-steps { grid-template-columns:1fr; }
}
