/* ============================================
   EZ Internet — Base & Design Tokens
   ============================================ */
:root {
    --bg-primary: #05080f;
    --bg-secondary: #0b1120;
    --bg-surface: rgba(255,255,255,0.03);
    --bg-surface-hover: rgba(255,255,255,0.07);
    --bg-glass: rgba(255,255,255,0.05);
    --border-glass: rgba(255,255,255,0.08);
    --border-glass-hover: rgba(255,255,255,0.18);
    --accent-primary: #6366f1;
    --accent-secondary: #22d3ee;
    --accent-green: #10b981;
    --accent-orange: #f97316;
    --accent-gold: #fbbf24;
    --accent-glow: #818cf8;
    --text-primary: #ffffff;
    --text-secondary: #94a3b8;
    --text-muted: #475569;
    --gradient-primary: linear-gradient(135deg, #6366f1, #22d3ee);
    --gradient-cta: linear-gradient(135deg, #f97316, #fbbf24);
    --gradient-hero: radial-gradient(ellipse at 50% 0%, rgba(99,102,241,0.15), transparent 70%);
    --font-heading: 'Space Grotesk', sans-serif;
    --font-body: 'Plus Jakarta Sans', sans-serif;
    --section-padding: 120px 0;
    --container-width: 1200px;
    --radius-sm: 12px;
    --radius-md: 20px;
    --radius-lg: 28px;
    --radius-xl: 40px;
    --transition-fast: 0.2s cubic-bezier(0.4,0,0.2,1);
    --transition-smooth: 0.4s cubic-bezier(0.4,0,0.2,1);
    --transition-spring: 0.6s cubic-bezier(0.34,1.56,0.64,1);
}
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
body { font-family:var(--font-body); background:var(--bg-primary); color:var(--text-primary); line-height:1.6; overflow-x:hidden; }
a { text-decoration:none; color:inherit; transition:color var(--transition-fast); }
img { max-width:100%; display:block; }
.container { max-width:var(--container-width); margin:0 auto; padding:0 24px; }
.gradient-text { background:var(--gradient-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
/* ============================================
   Navbar
   ============================================ */
.navbar { position:fixed; top:0; left:0; right:0; z-index:10000; padding:16px 0; transition:padding var(--transition-smooth),background var(--transition-smooth),backdrop-filter var(--transition-smooth),border-color var(--transition-smooth),box-shadow var(--transition-smooth); backdrop-filter:blur(0px); overflow:visible; }
.navbar.scrolled { padding:10px 0; background:rgba(5,8,15,0.92); backdrop-filter:blur(24px) saturate(180%); border-bottom:1px solid var(--border-glass); box-shadow:0 4px 24px rgba(0,0,0,0.4); }
.nav-container { max-width:var(--container-width); margin:0 auto; padding:0 24px; display:flex; align-items:center; justify-content:space-between; }
.nav-logo { display:flex; align-items:baseline; gap:3px; font-family:var(--font-heading); font-size:28px; font-weight:700; letter-spacing:-1px; }
.logo-ez { background:var(--gradient-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; font-weight:700; }
.logo-internet { color:var(--text-primary); font-weight:500; }
.nav-links { display:flex; list-style:none; gap:36px; }
.nav-links a { font-family:var(--font-body); font-size:15px; font-weight:500; color:var(--text-secondary); transition:color var(--transition-fast); position:relative; }
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px; background:var(--gradient-primary); transition:width var(--transition-smooth); border-radius:1px; }
.nav-links a:hover { color:var(--text-primary); }
.nav-links a:hover::after { width:100%; }
.nav-cta { display:flex; align-items:center; gap:8px; padding:10px 24px; border-radius:100px; background:var(--gradient-cta); color:#0a0e1a; font-family:var(--font-heading); font-weight:700; font-size:14px; transition:transform var(--transition-spring),box-shadow var(--transition-smooth); }
.nav-cta:hover { transform:translateY(-2px); box-shadow:0 8px 30px rgba(249,115,22,0.4); }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; }
.nav-toggle span { width:24px; height:2px; background:var(--text-primary); border-radius:2px; transition:all var(--transition-smooth); }
.nav-search { display:flex; align-items:center; background:rgba(255,255,255,0.05); border:1px solid var(--border-glass); border-radius:100px; padding:4px; margin-right:12px; transition:border-color var(--transition-smooth); }
.nav-search:focus-within { border-color:var(--accent-primary); }
.nav-search input { background:none; border:none; outline:none; font-family:var(--font-body); font-size:13px; color:var(--text-primary); padding:6px 12px; width:80px; }
.nav-search input::placeholder { color:var(--text-muted); }
.nav-search button { padding:6px 10px; border:none; border-radius:100px; background:var(--gradient-primary); color:#fff; cursor:pointer; display:flex; align-items:center; }

/* ============================================
   Hero Section
   ============================================ */
.hero { position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center; padding:120px 24px 80px; overflow:hidden; }
.hero-bg-orbs { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.orb { position:absolute; border-radius:50%; filter:blur(120px); opacity:0.25; }
.orb-1 { width:600px; height:600px; background:var(--accent-primary); top:-200px; right:-100px; animation:orbFloat 8s ease-in-out infinite; }
.orb-2 { width:400px; height:400px; background:var(--accent-secondary); bottom:-100px; left:-100px; animation:orbFloat 10s ease-in-out infinite reverse; }
.orb-3 { width:300px; height:300px; background:var(--accent-green); top:50%; left:50%; transform:translate(-50%,-50%); animation:orbFloat 12s ease-in-out infinite; opacity:0.12; }
@keyframes orbFloat { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-30px) scale(1.05)} }
#heroCanvas { position:absolute; inset:0; width:100%; height:100%; pointer-events:none; z-index:0; }
.hero-content { max-width:760px; text-align:center; position:relative; z-index:2; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; padding:8px 20px; border-radius:100px; background:var(--bg-glass); border:1px solid var(--border-glass); font-size:13px; font-weight:500; color:var(--text-secondary); margin-bottom:28px; backdrop-filter:blur(10px); }
.badge-dot { width:8px; height:8px; border-radius:50%; background:var(--accent-green); animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.4} }
.hero-title { font-family:var(--font-heading); font-size:clamp(36px,6vw,72px); font-weight:700; line-height:1.06; letter-spacing:-2.5px; margin-bottom:24px; }
.hero-subtitle { font-size:clamp(16px,2vw,20px); color:var(--text-secondary); line-height:1.7; margin-bottom:40px; max-width:560px; margin-left:auto; margin-right:auto; }

/* Search Form */
.search-form { margin-bottom:32px; }
.search-wrapper { display:flex; align-items:center; background:var(--bg-glass); border:2px solid var(--border-glass); border-radius:100px; padding:6px; max-width:540px; margin:0 auto; backdrop-filter:blur(20px); transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth); position:relative; }
.search-wrapper.glow-active { border-color:transparent; }
.search-wrapper::before { content:''; position:absolute; inset:-2px; border-radius:100px; padding:2px; background:conic-gradient(from var(--glow-angle,0deg),var(--accent-primary),var(--accent-secondary),var(--accent-green),var(--accent-primary)); -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0); -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity 0.4s; pointer-events:none; }
.search-wrapper:focus-within::before { opacity:1; }
.search-wrapper:focus-within { border-color:transparent; box-shadow:0 0 0 4px rgba(99,102,241,0.15),0 8px 40px rgba(99,102,241,0.15); }
.search-icon { padding:0 16px; display:flex; color:var(--text-muted); }
.search-wrapper input { flex:1; background:none; border:none; outline:none; font-family:var(--font-body); font-size:17px; color:var(--text-primary); padding:14px 0; }
.search-wrapper input::placeholder { color:var(--text-muted); }
.search-btn { display:flex; align-items:center; gap:8px; padding:14px 28px; border:none; border-radius:100px; background:var(--gradient-cta); color:#0a0e1a; font-family:var(--font-heading); font-weight:700; font-size:15px; cursor:pointer; transition:transform var(--transition-spring),box-shadow var(--transition-smooth); white-space:nowrap; }
.search-btn:hover { transform:scale(1.05); box-shadow:0 8px 30px rgba(249,115,22,0.4); }

/* Trust badges */
.hero-trust { display:flex; justify-content:center; gap:28px; flex-wrap:wrap; }
.trust-item { display:flex; align-items:center; gap:6px; font-size:14px; color:var(--text-secondary); font-weight:500; }

/* Floating Cards */
.hero-visual { position:absolute; inset:0; pointer-events:none; z-index:1; }
.floating-card { position:absolute; display:flex; align-items:center; gap:12px; padding:16px 24px; background:rgba(255,255,255,0.04); border:1px solid var(--border-glass); border-radius:var(--radius-md); backdrop-filter:blur(20px); pointer-events:none; }
.fc-icon { font-size:24px; }
.fc-label { display:block; font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; }
.fc-value { display:block; font-family:var(--font-heading); font-weight:700; font-size:18px; background:var(--gradient-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.card-1 { top:25%; left:5%; }
.card-2 { top:20%; right:5%; }
.card-3 { bottom:18%; right:10%; }
/* ============================================
   Section Headers
   ============================================ */
.section-header { text-align:center; margin-bottom:64px; }
.section-tag { display:inline-block; padding:6px 16px; border-radius:100px; background:rgba(99,102,241,0.1); border:1px solid rgba(99,102,241,0.2); color:var(--accent-primary); font-size:13px; font-weight:600; text-transform:uppercase; letter-spacing:1.5px; margin-bottom:20px; }
.section-title { font-family:var(--font-heading); font-size:clamp(28px,4vw,48px); font-weight:700; line-height:1.15; letter-spacing:-1px; }
.section-desc { color:var(--text-secondary); font-size:18px; margin-top:16px; }

/* ============================================
   Features — Bento Grid
   ============================================ */
.features { padding:var(--section-padding); position:relative; }
.features-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.feature-card { padding:40px 28px; background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-lg); text-align:center; transition:all var(--transition-smooth); position:relative; overflow:hidden; }
.feature-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gradient-primary); transform:scaleX(0); transition:transform var(--transition-smooth); transform-origin:left; }
.feature-card::after { content:''; position:absolute; inset:0; background:radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(99,102,241,0.08),transparent 60%); opacity:0; transition:opacity var(--transition-smooth); pointer-events:none; }
.feature-card:hover { border-color:var(--border-glass-hover); background:var(--bg-surface-hover); transform:translateY(-4px); }
.feature-card:hover::before { transform:scaleX(1); }
.feature-card:hover::after { opacity:1; }
.feature-icon { display:inline-flex; align-items:center; justify-content:center; width:60px; height:60px; border-radius:16px; background:rgba(99,102,241,0.1); color:var(--accent-primary); margin-bottom:20px; }
.feature-card h3 { font-family:var(--font-heading); font-size:20px; font-weight:700; margin-bottom:12px; }
.feature-card p { color:var(--text-secondary); font-size:15px; line-height:1.6; }

/* ============================================
   How It Works — Vertical Timeline
   ============================================ */
.how-it-works { padding:var(--section-padding); background:var(--bg-secondary); }
.timeline { position:relative; max-width:700px; margin:0 auto; padding-left:60px; }
.timeline::before { content:''; position:absolute; top:0; bottom:0; left:28px; width:2px; background:linear-gradient(to bottom,var(--accent-primary),var(--accent-secondary),var(--accent-green)); opacity:0.3; }
.timeline-step { position:relative; margin-bottom:56px; }
.timeline-step:last-child { margin-bottom:0; }
.timeline-dot { position:absolute; left:-60px; top:8px; width:56px; height:56px; border-radius:50%; background:var(--bg-glass); border:2px solid var(--accent-primary); display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-weight:700; font-size:18px; color:var(--accent-primary); z-index:2; backdrop-filter:blur(10px); }
.timeline-dot::after { content:''; position:absolute; inset:-4px; border-radius:50%; background:var(--accent-primary); opacity:0; animation:dotPulse 3s ease-in-out infinite; z-index:-1; }
@keyframes dotPulse { 0%,100%{opacity:0;transform:scale(1)} 50%{opacity:0.15;transform:scale(1.4)} }
.timeline-card { background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-lg); padding:32px; transition:all var(--transition-smooth); }
.timeline-card:hover { border-color:var(--border-glass-hover); transform:translateX(8px); }
.timeline-card h3 { font-family:var(--font-heading); font-size:20px; font-weight:700; margin-bottom:8px; }
.timeline-card p { color:var(--text-secondary); font-size:15px; line-height:1.6; margin-bottom:16px; }
.timeline-visual { display:inline-flex; }

/* Mini visualizations */
.mini-search { display:inline-flex; align-items:center; gap:8px; padding:8px 16px; background:var(--bg-primary); border:1px solid var(--border-glass); border-radius:100px; font-family:var(--font-heading); font-weight:600; font-size:14px; color:var(--text-secondary); cursor:pointer; }
.mini-btn { width:28px; height:28px; border-radius:50%; background:var(--gradient-cta); color:#0a0e1a; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:14px; }
.mini-cards { display:flex; gap:6px; }
.mc { padding:6px 12px; background:var(--bg-primary); border:1px solid var(--border-glass); border-radius:var(--radius-sm); font-size:12px; font-weight:600; color:var(--accent-primary); }
.mini-call { display:inline-flex; align-items:center; gap:6px; padding:8px 20px; border-radius:100px; background:var(--gradient-cta); color:#0a0e1a; font-weight:700; font-size:14px; }

/* ============================================
   Stats Section
   ============================================ */
.stats-section { padding:80px 0; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat-item { text-align:center; padding:32px 20px; background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-lg); transition:all var(--transition-smooth); }
.stat-item:hover { border-color:var(--border-glass-hover); transform:translateY(-4px); }
.stat-value { font-family:var(--font-heading); font-size:clamp(36px,4vw,52px); font-weight:700; background:var(--gradient-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; line-height:1.1; margin-bottom:8px; }
.stat-value::after { content:'+'; font-size:0.6em; }
.stat-label { color:var(--text-secondary); font-size:15px; font-weight:500; }

/* ============================================
   Providers Marquee
   ============================================ */
.providers-section { padding:var(--section-padding); background:var(--bg-secondary); overflow:hidden; }
.providers-marquee { margin-top:16px; overflow:hidden; mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent); -webkit-mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent); }
.providers-marquee + .providers-marquee { margin-top:16px; }
.marquee-track { display:flex; gap:16px; animation:marqueeScroll 30s linear infinite; width:max-content; }
.providers-marquee.reverse .marquee-track { animation-direction:reverse; }
@keyframes marqueeScroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.provider-logo-card { flex-shrink:0; padding:20px 36px; background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-md); font-family:var(--font-heading); font-weight:700; font-size:16px; color:var(--text-secondary); white-space:nowrap; transition:all var(--transition-smooth); }
.provider-logo-card:hover { border-color:var(--accent-primary); color:var(--text-primary); background:rgba(99,102,241,0.08); }

/* ============================================
   FAQ Accordion
   ============================================ */
.faq-section { padding:var(--section-padding); }
.faq-list { max-width:760px; margin:0 auto; }
.faq-item { border:1px solid var(--border-glass); border-radius:var(--radius-md); margin-bottom:12px; overflow:hidden; background:var(--bg-glass); transition:border-color var(--transition-smooth); }
.faq-item.active { border-color:rgba(99,102,241,0.3); }
.faq-question { display:flex; align-items:center; justify-content:space-between; padding:20px 24px; cursor:pointer; font-family:var(--font-heading); font-size:17px; font-weight:600; color:var(--text-primary); transition:color var(--transition-fast); }
.faq-question:hover { color:var(--accent-primary); }
.faq-icon { width:24px; height:24px; flex-shrink:0; color:var(--accent-primary); transition:transform var(--transition-smooth); }
.faq-item.active .faq-icon { transform:rotate(45deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.4s ease; }
.faq-answer-inner { padding:0 24px 20px; color:var(--text-secondary); font-size:15px; line-height:1.7; }
/* ============================================
   CTA Section
   ============================================ */
.cta-section { padding:var(--section-padding); }
.cta-card { text-align:center; padding:80px 40px; background:linear-gradient(135deg,rgba(99,102,241,0.08),rgba(34,211,238,0.05)); border:1px solid rgba(99,102,241,0.2); border-radius:var(--radius-xl); position:relative; overflow:hidden; }
.cta-card::before { content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%; background:radial-gradient(circle at 30% 50%,rgba(99,102,241,0.06),transparent 50%); pointer-events:none; }
.cta-card h2 { font-family:var(--font-heading); font-size:clamp(28px,4vw,44px); font-weight:700; margin-bottom:16px; position:relative; }
.cta-card p { color:var(--text-secondary); font-size:18px; max-width:500px; margin:0 auto 36px; position:relative; }
.cta-actions { display:flex; flex-direction:column; align-items:center; gap:20px; position:relative; }
.btn-primary { display:inline-flex; align-items:center; gap:10px; padding:18px 40px; border-radius:100px; background:var(--gradient-cta); color:#0a0e1a; font-family:var(--font-heading); font-weight:700; font-size:18px; transition:transform var(--transition-spring),box-shadow var(--transition-smooth); }
.btn-primary:hover { transform:translateY(-3px) scale(1.02); box-shadow:0 12px 40px rgba(249,115,22,0.5); }
.btn-lg { padding:20px 48px; font-size:20px; }
.cta-hours p { color:var(--text-muted); font-size:14px; line-height:1.6; }

/* ============================================
   Footer
   ============================================ */
.footer { padding:80px 0 40px; background:var(--bg-secondary); border-top:1px solid var(--border-glass); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand p { color:var(--text-secondary); font-size:15px; margin-top:16px; max-width:320px; }
.footer-links h4 { font-family:var(--font-heading); font-size:16px; font-weight:700; margin-bottom:16px; }
.footer-links a { display:block; color:var(--text-secondary); font-size:15px; margin-bottom:10px; transition:color var(--transition-fast); }
.footer-links a:hover { color:var(--accent-primary); }
.footer-phone-link { display:inline-flex !important; align-items:center; gap:7px; color:var(--text-primary) !important; font-family:var(--font-heading); font-weight:600; font-size:15px; padding:6px 0; margin-bottom:10px !important; transition:color var(--transition-fast) !important; }
.footer-phone-link svg { color:var(--accent-green); flex-shrink:0; }
.footer-phone-link:hover { color:var(--accent-primary) !important; }
.footer-hours { color:var(--text-muted); font-size:14px; line-height:1.7; }
.footer-bottom { padding-top:32px; border-top:1px solid var(--border-glass); }
.footer-disclaimer { color:var(--text-muted); font-size:13px; line-height:1.7; margin-bottom:20px; }
.footer-copy { display:flex; justify-content:space-between; align-items:center; color:var(--text-muted); font-size:14px; flex-wrap:wrap; gap:12px; }
.footer-copy a { color:var(--accent-primary); }
.footer-legal-links { display:flex; gap:16px; }
.footer-legal-links a { color:var(--text-muted); font-size:13px; transition:color var(--transition-fast); }
.footer-legal-links a:hover { color:var(--accent-primary); }

/* Phone Bar (Mobile) */
.phone-bar { display:none; position:fixed; bottom:0; left:0; right:0; z-index:10000; background:var(--gradient-cta); padding:14px; text-align:center; }
.phone-bar a { display:flex; align-items:center; justify-content:center; gap:8px; color:#0a0e1a; font-family:var(--font-heading); font-weight:700; font-size:16px; }

/* ============================================
   Search Results Page
   ============================================ */
.search-hero { padding:120px 24px 40px; text-align:center; position:relative; overflow:hidden; }
.search-hero .hero-bg-orbs .orb { opacity:0.12; }
.search-location { margin-bottom:32px; }
.search-location h1 { font-family:var(--font-heading); font-size:clamp(24px,4vw,42px); font-weight:700; line-height:1.2; }
.search-location .loc-details { display:flex; align-items:center; justify-content:center; gap:8px; margin-top:8px; color:var(--text-secondary); font-size:18px; }
.search-location .loc-details svg { color:var(--accent-primary); }
.results-container { max-width:1000px; margin:0 auto; padding:0 24px 80px; }
.results-count { display:flex; align-items:center; gap:8px; margin-bottom:32px; color:var(--text-secondary); font-size:15px; }
.results-count strong { color:var(--accent-primary); }

/* Provider Card */
.provider-card { background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-lg); margin-bottom:24px; overflow:hidden; transition:all var(--transition-smooth); }
.provider-card:hover { border-color:var(--border-glass-hover); box-shadow:0 8px 40px rgba(0,0,0,0.3); }
.provider-header { display:flex; align-items:center; justify-content:space-between; padding:28px 32px; border-bottom:1px solid var(--border-glass); flex-wrap:wrap; gap:16px; }
.provider-info { display:flex; align-items:center; gap:16px; }
.provider-logo-img { width:60px; height:60px; border-radius:var(--radius-sm); background:var(--bg-surface); display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-weight:700; font-size:14px; color:var(--accent-primary); border:1px solid var(--border-glass); }
.provider-name { font-family:var(--font-heading); font-size:22px; font-weight:700; }
.provider-type { font-size:13px; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; }
.btn-call { display:inline-flex; align-items:center; gap:8px; padding:12px 28px; border-radius:100px; background:var(--gradient-cta); color:#0a0e1a; font-family:var(--font-heading); font-weight:700; font-size:14px; transition:transform var(--transition-spring),box-shadow var(--transition-smooth); }
.btn-call:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(249,115,22,0.4); }
.provider-details { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border-glass); }
.detail-item { padding:24px 20px; background:var(--bg-primary); text-align:center; }
.detail-label { font-size:12px; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.detail-value { font-family:var(--font-heading); font-size:16px; font-weight:700; color:var(--text-primary); }
.no-results { text-align:center; padding:80px 20px; }
.no-results h2 { font-family:var(--font-heading); font-size:28px; margin-bottom:16px; }
.no-results p { color:var(--text-secondary); font-size:16px; margin-bottom:32px; }
.loading-state { display:flex; flex-direction:column; align-items:center; padding:60px 20px; gap:20px; }
.spinner { width:48px; height:48px; border:3px solid var(--border-glass); border-top-color:var(--accent-primary); border-radius:50%; animation:spin 0.8s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }

/* ============================================
   Standard Page Template (Privacy, Terms)
   ============================================ */
.page-hero { position:relative; padding:160px 24px 80px; text-align:center; overflow:hidden; }
.page-hero-inner { position:relative; z-index:2; max-width:760px; margin:0 auto; }
.breadcrumb { display:inline-flex; align-items:center; gap:8px; font-size:13px; color:var(--text-muted); margin-bottom:24px; }
.breadcrumb a { color:var(--accent-primary); font-weight:500; transition:opacity var(--transition-fast); }
.breadcrumb a:hover { opacity:0.8; }
.bc-sep { opacity:0.4; font-size:16px; }
.page-title { font-family:var(--font-heading); font-size:clamp(32px,5vw,56px); font-weight:700; line-height:1.1; letter-spacing:-1.5px; margin-bottom:16px; }
.page-meta { color:var(--text-muted); font-size:14px; }
.page-content-section { padding:0 24px 100px; }
.page-content-card { max-width:860px; margin:0 auto; background:var(--bg-glass); border:1px solid var(--border-glass); border-radius:var(--radius-xl); padding:60px 72px; backdrop-filter:blur(20px); position:relative; overflow:hidden; }
.page-content-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gradient-primary); }
.azw-content { color:var(--text-secondary); font-size:16px; line-height:1.8; }
.azw-content h1,.azw-content h2,.azw-content h3,.azw-content h4 { font-family:var(--font-heading); color:var(--text-primary); line-height:1.2; margin-top:40px; margin-bottom:16px; }
.azw-content h1 { font-size:clamp(26px,3vw,36px); font-weight:700; margin-top:0; }
.azw-content h2 { font-size:clamp(20px,2.5vw,28px); font-weight:700; }
.azw-content h3 { font-size:20px; font-weight:700; }
.azw-content p { margin-bottom:20px; color:var(--text-secondary); }
.azw-content ul,.azw-content ol { padding-left:24px; margin-bottom:20px; }
.azw-content li { margin-bottom:10px; color:var(--text-secondary); }
.azw-content li::marker { color:var(--accent-primary); }
.azw-content strong { color:var(--text-primary); font-weight:600; }
.azw-content a { color:var(--accent-primary); text-decoration:underline; text-decoration-color:rgba(99,102,241,0.4); transition:text-decoration-color var(--transition-fast); }
.azw-content a:hover { text-decoration-color:var(--accent-primary); }
.azw-content em { color:var(--text-muted); font-style:italic; }
.azw-content .wp-block-group { padding:0 !important; }
.azw-content hr,.azw-content .wp-block-separator { border:none; border-top:1px solid var(--border-glass); margin:40px 0; }

/* Page CTA Banner */
.page-cta-banner { padding:80px 24px 120px; background:var(--bg-secondary); }
.page-cta-inner { max-width:860px; margin:0 auto; background:linear-gradient(135deg,rgba(99,102,241,0.08),rgba(34,211,238,0.05)); border:1px solid rgba(99,102,241,0.2); border-radius:var(--radius-xl); padding:56px 60px; display:flex; align-items:center; justify-content:space-between; gap:40px; position:relative; overflow:hidden; }
.page-cta-inner::before { content:''; position:absolute; top:-50%; left:-30%; width:80%; height:200%; background:radial-gradient(circle,rgba(99,102,241,0.06),transparent 60%); pointer-events:none; }
.page-cta-text h2 { font-family:var(--font-heading); font-size:clamp(22px,3vw,32px); font-weight:700; margin-bottom:10px; line-height:1.2; }
.page-cta-text p { color:var(--text-secondary); font-size:15px; line-height:1.6; }
.page-cta-actions { display:flex; flex-direction:column; gap:16px; flex-shrink:0; }
.mini-search-form {}
.mini-search-wrap { display:flex; align-items:center; background:rgba(255,255,255,0.05); border:1px solid var(--border-glass); border-radius:100px; padding:6px; transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth); }
.mini-search-wrap:focus-within { border-color:var(--accent-primary); box-shadow:0 0 0 3px rgba(99,102,241,0.15); }
.mini-search-wrap input { background:none; border:none; outline:none; font-family:var(--font-body); font-size:15px; color:var(--text-primary); padding:10px 16px; width:160px; }
.mini-search-wrap input::placeholder { color:var(--text-muted); }
.mini-search-wrap button { padding:10px 22px; border:none; border-radius:100px; background:var(--gradient-cta); color:#0a0e1a; font-family:var(--font-heading); font-weight:700; font-size:14px; cursor:pointer; transition:transform var(--transition-spring); white-space:nowrap; }
.mini-search-wrap button:hover { transform:scale(1.05); }

/* ============================================
   Elementor Overrides
   ============================================ */
body.elementor-page,body.elementor-page .page-wrapper,.elementor-section-wrap,.e-page-content { background:var(--bg-primary) !important; color:var(--text-primary) !important; }
.elementor-section,.elementor-container,.elementor-widget-wrap,.e-container,.e-flex,.elementor-widget-container { background:transparent !important; }
.elementor-section > .elementor-container { max-width:var(--container-width); }
body.elementor-page { background-color:#05080f !important; }
.elementor-editor-active .elementor-section { background:transparent; }
.provider-section { display:none !important; }
.provider-section.active-provider { display:block !important; }

/* ============================================
   Scrollbar
   ============================================ */
::-webkit-scrollbar { width:8px; }
::-webkit-scrollbar-track { background:var(--bg-primary); }
::-webkit-scrollbar-thumb { background:rgba(99,102,241,0.3); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:rgba(99,102,241,0.5); }

/* ============================================
   Responsive
   ============================================ */
@media(max-width:1200px) {
    .features-grid { grid-template-columns:repeat(2,1fr); }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:900px) {
    :root { --section-padding:80px 0; }
    .nav-links { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(5,8,15,0.98); backdrop-filter:blur(20px); flex-direction:column; align-items:center; justify-content:center; gap:32px; z-index:9999; }
    .nav-links.open { display:flex; }
    .nav-toggle { display:flex; }
    .nav-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
    .nav-toggle.active span:nth-child(2) { opacity:0; }
    .nav-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
    .nav-links a { font-size:24px; }
    .nav-search { display:none; }
    .hero { min-height:auto; padding:140px 20px 80px; }
    .hero-title { letter-spacing:-1.5px; }
    .floating-card { display:none !important; }
    .features-grid { grid-template-columns:1fr 1fr; }
    .provider-details { grid-template-columns:repeat(2,1fr); }
    .footer-grid { grid-template-columns:1fr; gap:32px; }
    .page-content-card { padding:40px 36px; }
    .page-cta-inner { flex-direction:column; text-align:center; padding:40px 28px; }
    .page-cta-actions { align-items:center; width:100%; }
    .phone-bar { display:block; }
    .footer { padding-bottom:80px; }
    .timeline { padding-left:50px; }
    .timeline::before { left:22px; }
    .timeline-dot { left:-50px; width:44px; height:44px; font-size:15px; }
}
@media(max-width:600px) {
    .features-grid { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:1fr 1fr; }
    .hero-title { font-size:clamp(28px,8vw,42px); letter-spacing:-1px; }
    .hero-trust { flex-direction:column; align-items:center; gap:12px; }
    .search-btn span { display:none; }
    .search-btn { padding:14px 18px; }
    .provider-header { padding:20px; }
    .provider-details { grid-template-columns:1fr 1fr; }
    .footer-copy { flex-direction:column; align-items:flex-start; }
    .page-content-card { padding:28px 20px; border-radius:var(--radius-lg); }
    .azw-content h1 { font-size:24px; }
    .azw-content h2 { font-size:20px; }
    .mini-search-wrap input { width:120px; }
    .cta-card { padding:48px 24px; }
    .timeline { padding-left:44px; }
    .timeline::before { left:18px; }
    .timeline-dot { left:-44px; width:36px; height:36px; font-size:13px; }
}
/* ============================================================
   CRITICAL: Force dark theme over TwentyTwentyFive defaults
   ============================================================ */
html, body, body.ezi-page, body.ezi-home, body.ezi-search, body.ezi-standard-page,
body.page, body.home, body.single, body.archive,
.wp-site-blocks, .is-layout-constrained, .is-layout-flow,
.has-global-padding, .wp-block-template-part,
body .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)),
main, article, section, div, header, footer, nav {
    background-color: transparent !important;
    color: inherit !important;
}
html { background: #05080f !important; }
body { background: #05080f !important; color: #ffffff !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }

/* Kill ALL TwentyTwentyFive layout constraints */
.wp-site-blocks { padding: 0 !important; margin: 0 !important; }
.is-layout-constrained > * { max-width: none !important; margin-left: 0 !important; margin-right: 0 !important; }
body .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) { max-width: none !important; }
.has-global-padding { padding: 0 !important; }
.wp-block-template-part { margin: 0 !important; padding: 0 !important; }

/* Kill TwentyTwentyFive header/footer template parts */
body > .wp-site-blocks > header,
body > .wp-site-blocks > .wp-block-template-part:first-child,
.wp-block-site-title, .wp-block-navigation { display: none !important; }

/* Force our sections to show properly */
.navbar { background: transparent !important; position: fixed !important; z-index: 10000 !important; }
.navbar.scrolled { background: rgba(5,8,15,0.95) !important; backdrop-filter: blur(24px) saturate(180%) !important; }
.hero { background: transparent !important; min-height: 100vh !important; }
.features { background: #05080f !important; }
.how-it-works { background: #0b1120 !important; }
.stats-section { background: #05080f !important; }
.providers-section { background: #0b1120 !important; }
.faq-section { background: #05080f !important; }
.cta-section { background: #05080f !important; }
.footer { background: #0b1120 !important; border-top: 1px solid rgba(255,255,255,0.08) !important; }
.page-hero { background: transparent !important; }
.page-content-section { background: #05080f !important; }
.page-cta-banner { background: #0b1120 !important; }
.search-hero { background: transparent !important; }

/* Fix text colors that might be overridden */
h1, h2, h3, h4, h5, h6 { color: #ffffff !important; font-family: 'Space Grotesk', sans-serif !important; }
p, li, span, div { color: inherit; }
.hero-subtitle, .section-desc, .feature-card p, .timeline-card p,
.stat-label, .cta-card p, .cta-hours p, .footer-brand p,
.footer-links a, .footer-hours, .footer-disclaimer, .faq-answer-inner,
.trust-item span, .text-secondary { color: #94a3b8 !important; }
.text-muted, .footer-copy, .page-meta, .breadcrumb, .detail-label { color: #475569 !important; }

/* Fix gradient text */
.gradient-text {
    background: linear-gradient(135deg, #6366f1, #22d3ee) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}
.logo-ez {
    background: linear-gradient(135deg, #6366f1, #22d3ee) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

/* ============================================================
   PREMIUM DESIGN POLISH
   ============================================================ */

/* Hero — more dramatic, less generic */
.hero { background: radial-gradient(ellipse at 50% 0%, rgba(99,102,241,0.12) 0%, transparent 60%), #05080f !important; }
.hero-title { font-size: clamp(40px, 6.5vw, 78px) !important; font-weight: 700 !important; letter-spacing: -3px !important; line-height: 1.02 !important; }
.hero-subtitle { font-size: clamp(16px, 1.8vw, 19px) !important; max-width: 520px !important; opacity: 0.8; line-height: 1.75 !important; }
.hero-badge { background: rgba(99,102,241,0.08) !important; border: 1px solid rgba(99,102,241,0.2) !important; font-size: 12px !important; letter-spacing: 0.5px; text-transform: uppercase; }

/* Search bar — premium glassmorphism */
.search-wrapper { background: rgba(255,255,255,0.03) !important; border: 1.5px solid rgba(255,255,255,0.1) !important; backdrop-filter: blur(30px) !important; box-shadow: 0 4px 24px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.05) !important; max-width: 500px !important; }
.search-wrapper:focus-within { border-color: rgba(99,102,241,0.5) !important; box-shadow: 0 0 0 4px rgba(99,102,241,0.1), 0 8px 32px rgba(99,102,241,0.15) !important; }
.search-wrapper input { font-size: 16px !important; color: #ffffff !important; }
.search-wrapper input::placeholder { color: #475569 !important; }
.search-btn { background: linear-gradient(135deg, #6366f1, #4f46e5) !important; color: #ffffff !important; font-size: 14px !important; padding: 12px 24px !important; font-weight: 600 !important; letter-spacing: 0.3px; }
.search-btn:hover { box-shadow: 0 8px 24px rgba(99,102,241,0.4) !important; }

/* Nav CTA — match indigo not orange */
.nav-cta { background: linear-gradient(135deg, #6366f1, #4f46e5) !important; color: #ffffff !important; font-size: 13px !important; padding: 9px 20px !important; }
.nav-cta:hover { box-shadow: 0 8px 24px rgba(99,102,241,0.4) !important; }

/* Section tags — refined */
.section-tag { font-size: 11px !important; letter-spacing: 2px !important; padding: 5px 14px !important; background: rgba(99,102,241,0.06) !important; border: 1px solid rgba(99,102,241,0.15) !important; }

/* Section titles — tighter, more editorial */
.section-title { font-size: clamp(28px, 4vw, 46px) !important; letter-spacing: -1.5px !important; font-weight: 700 !important; line-height: 1.1 !important; }

/* Feature cards — premium glass with subtle depth */
.feature-card { background: rgba(255,255,255,0.02) !important; border: 1px solid rgba(255,255,255,0.06) !important; padding: 36px 28px !important; transition: all 0.4s cubic-bezier(0.4,0,0.2,1) !important; }
.feature-card:hover { background: rgba(255,255,255,0.04) !important; border-color: rgba(99,102,241,0.2) !important; transform: translateY(-6px) !important; box-shadow: 0 20px 40px rgba(0,0,0,0.3), 0 0 0 1px rgba(99,102,241,0.1) !important; }
.feature-icon { background: rgba(99,102,241,0.08) !important; color: #818cf8 !important; width: 52px !important; height: 52px !important; border-radius: 14px !important; }
.feature-card h3 { font-size: 18px !important; font-weight: 600 !important; margin-bottom: 10px !important; color: #ffffff !important; }
.feature-card p { font-size: 14px !important; line-height: 1.65 !important; color: #64748b !important; }

/* Timeline cards — cleaner */
.timeline-card { background: rgba(255,255,255,0.02) !important; border: 1px solid rgba(255,255,255,0.06) !important; }
.timeline-card:hover { border-color: rgba(99,102,241,0.2) !important; box-shadow: 0 12px 32px rgba(0,0,0,0.2) !important; }
.timeline-dot { background: #0b1120 !important; border: 2px solid rgba(99,102,241,0.4) !important; color: #818cf8 !important; font-size: 15px !important; }

/* Stats — bolder numbers */
.stat-item { background: rgba(255,255,255,0.02) !important; border: 1px solid rgba(255,255,255,0.06) !important; }
.stat-item:hover { border-color: rgba(99,102,241,0.2) !important; }
.stat-value { font-size: clamp(32px, 4vw, 48px) !important; font-weight: 700 !important; }

/* Provider marquee cards */
.provider-logo-card { background: rgba(255,255,255,0.02) !important; border: 1px solid rgba(255,255,255,0.06) !important; font-size: 15px !important; font-weight: 600 !important; color: #64748b !important; padding: 16px 28px !important; }
.provider-logo-card:hover { background: rgba(99,102,241,0.06) !important; border-color: rgba(99,102,241,0.2) !important; color: #ffffff !important; }

/* FAQ — cleaner */
.faq-item { background: rgba(255,255,255,0.02) !important; border: 1px solid rgba(255,255,255,0.06) !important; }
.faq-item.active { border-color: rgba(99,102,241,0.25) !important; }
.faq-question { font-size: 16px !important; font-weight: 600 !important; color: #e2e8f0 !important; }
.faq-answer-inner { color: #64748b !important; font-size: 14px !important; }

/* CTA card — premium gradient border feel */
.cta-card { background: linear-gradient(135deg, rgba(99,102,241,0.06), rgba(34,211,238,0.03)) !important; border: 1px solid rgba(99,102,241,0.15) !important; }
.cta-card h2 { font-size: clamp(26px, 4vw, 40px) !important; }
.btn-primary { background: linear-gradient(135deg, #6366f1, #4f46e5) !important; color: #ffffff !important; font-size: 16px !important; font-weight: 600 !important; }
.btn-primary:hover { box-shadow: 0 12px 32px rgba(99,102,241,0.4) !important; }
.btn-lg { padding: 18px 40px !important; font-size: 17px !important; }

/* Page content card */
.page-content-card { background: rgba(255,255,255,0.02) !important; border: 1px solid rgba(255,255,255,0.06) !important; }
.page-content-card::before { background: linear-gradient(135deg, #6366f1, #22d3ee) !important; }

/* Footer polish */
.footer-links h4 { color: #ffffff !important; font-size: 14px !important; text-transform: uppercase !important; letter-spacing: 1.5px !important; font-weight: 600 !important; }
.footer-links a { font-size: 14px !important; color: #64748b !important; }
.footer-links a:hover { color: #818cf8 !important; }
.footer-copy a, .footer-legal-links a:hover { color: #818cf8 !important; }
.footer-phone-link { color: #e2e8f0 !important; }
.footer-phone-link svg { color: #10b981 !important; }

/* Call buttons — match brand indigo */
.btn-call { background: linear-gradient(135deg, #6366f1, #4f46e5) !important; color: #ffffff !important; }
.btn-call:hover { box-shadow: 0 8px 24px rgba(99,102,241,0.4) !important; }
.mini-call { background: linear-gradient(135deg, #6366f1, #4f46e5) !important; color: #ffffff !important; }

/* Provider cards on search results */
.provider-card { background: rgba(255,255,255,0.02) !important; border: 1px solid rgba(255,255,255,0.06) !important; }
.provider-card:hover { border-color: rgba(99,102,241,0.2) !important; box-shadow: 0 16px 48px rgba(0,0,0,0.3) !important; }
.provider-header { border-bottom: 1px solid rgba(255,255,255,0.06) !important; }
.detail-item { background: #05080f !important; }
.detail-value { color: #ffffff !important; }

/* Phone bar */
.phone-bar { background: linear-gradient(135deg, #6366f1, #4f46e5) !important; }
.phone-bar a { color: #ffffff !important; }

/* Page CTA */
.page-cta-inner { background: linear-gradient(135deg, rgba(99,102,241,0.06), rgba(34,211,238,0.03)) !important; border: 1px solid rgba(99,102,241,0.15) !important; }
.mini-search-wrap { background: rgba(255,255,255,0.03) !important; border: 1px solid rgba(255,255,255,0.08) !important; }
.mini-search-wrap button { background: linear-gradient(135deg, #6366f1, #4f46e5) !important; color: #ffffff !important; }

/* Floating cards */
.floating-card { background: rgba(255,255,255,0.03) !important; border: 1px solid rgba(255,255,255,0.08) !important; backdrop-filter: blur(20px) !important; }
.fc-value { background: linear-gradient(135deg, #6366f1, #22d3ee) !important; -webkit-background-clip: text !important; -webkit-text-fill-color: transparent !important; }
.fc-label { color: #64748b !important; }

/* Orbs — subtler */
.orb { opacity: 0.15 !important; }
.orb-1 { background: #6366f1 !important; }
.orb-2 { background: #22d3ee !important; }
.orb-3 { background: #10b981 !important; opacity: 0.08 !important; }

/* Trust items */
.trust-item { color: #64748b !important; font-size: 13px !important; }
.trust-item svg { stroke: #10b981 !important; }

/* Scrollbar */
::-webkit-scrollbar { width: 6px !important; }
::-webkit-scrollbar-track { background: #05080f !important; }
::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.2) !important; border-radius: 3px !important; }

/* Loading & no results */
.loading-state p { color: #64748b !important; }
.no-results h2 { color: #ffffff !important; }
.no-results p { color: #64748b !important; }

/* Selection color */
::selection { background: rgba(99,102,241,0.3); color: #ffffff; }
