/* ============================================================
   PocketReceipt — Premium Marketing Site
   Matches dashboard design language (2026-04-01)
   ============================================================ */

/* === Brand tokens (aligned with dashboard) === */
:root,[data-theme="light"]{
  --navy:#2C3E55;--navy-deep:#1a2d42;
  --teal:#39C5B5;--teal-hover:#2fb3a4;--teal-pale:#e6faf7;--teal-glow:rgba(57,197,181,.15);
  --gold:#D97706;--gold-light:#F59E0B;
  --bg:#f4f6f9;--bg-alt:#eef1f5;--bg-card:#fff;
  --text:#2C3E55;--text-sec:#5a6a7e;--text-mut:#6b7a8a;
  --border:#dfe3ea;--border-h:#39C5B5;
  --sh-sm:0 1px 2px rgba(44,62,85,.04);
  --sh-card:0 2px 8px rgba(44,62,85,.06),0 0 0 1px rgba(44,62,85,.03);
  --sh-hover:0 8px 24px rgba(44,62,85,.1),0 0 0 1px rgba(57,197,181,.15);
  --sh-hero:0 16px 48px rgba(44,62,85,.12);
  --nav-bg:rgba(255,255,255,.92);
  --fh:Montserrat,sans-serif;--fb:Inter,-apple-system,sans-serif;
  --rc:16px;--rh:20px;--rb:10px
}
[data-theme="dark"]{
  --navy:#e2e8f0;--navy-deep:#f1f5f9;
  --teal:#39C5B5;--teal-hover:#4dd9c9;--teal-pale:rgba(57,197,181,.08);--teal-glow:rgba(57,197,181,.1);
  --bg:#0c1219;--bg-alt:#111a24;--bg-card:#162030;
  --text:#e2e8f0;--text-sec:#94a3b8;--text-mut:#64748b;
  --border:#1e2d3d;--border-h:#39C5B5;
  --sh-sm:0 1px 3px rgba(0,0,0,.3);
  --sh-card:0 2px 8px rgba(0,0,0,.2),0 0 0 1px rgba(255,255,255,.03);
  --sh-hover:0 8px 24px rgba(0,0,0,.3),0 0 0 1px rgba(57,197,181,.2);
  --sh-hero:0 16px 48px rgba(0,0,0,.4);
  --nav-bg:rgba(12,18,25,.95)
}

/* === Reset === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--text);background:var(--bg);line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}

/* === Nav (premium glass) === */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--nav-bg);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid var(--border);transition:box-shadow .3s,background .3s}
.nav.scrolled{box-shadow:0 4px 20px rgba(44,62,85,.08)}
.nav-inner{max-width:1140px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:64px}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo-icon{width:36px;height:36px;border-radius:10px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.1)}
.nav-logo-icon img{width:100%;height:100%;object-fit:cover}
.nav-logo-text{font-family:var(--fh);font-size:18px;font-weight:800;letter-spacing:-.03em}
.pocket{color:var(--navy)}.receipt{color:var(--teal)}
[data-theme="dark"] .pocket{color:#e2e8f0}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{text-decoration:none;color:var(--text-sec);font-size:13.5px;font-weight:500;padding:8px 14px;border-radius:var(--rb);transition:all .2s}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:var(--bg-alt)}
.nav-cta{background:linear-gradient(135deg,var(--teal),var(--teal-hover))!important;color:#fff!important;padding:9px 20px!important;font-weight:600!important;box-shadow:0 2px 8px rgba(57,197,181,.25)}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(57,197,181,.35)!important}
.theme-toggle{background:var(--bg-alt);border:1px solid var(--border);border-radius:50%;width:34px;height:34px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .2s;margin-left:4px}
.theme-toggle:hover{border-color:var(--teal);background:var(--teal-pale)}
.nav-mobile{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-mobile span{display:block;width:20px;height:2px;background:var(--text);margin:4px 0;transition:.3s}

/* === Hero (premium gradient background) === */
.hero{padding:140px 28px 100px;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-alt) 100%);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(57,197,181,.06) 0%,transparent 70%);z-index:0}
.hero::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(57,197,181,.04) 0%,transparent 70%);z-index:0}
.hero-inner{max-width:100%;padding:0 28px 0 5%;margin:0 auto;display:grid;grid-template-columns:1fr 1.6fr;gap:30px;align-items:center;position:relative;z-index:1}
.hero-pill{display:inline-flex;align-items:center;gap:8px;background:var(--teal-pale);border:1px solid rgba(57,197,181,.2);color:#1a7a6e;font-size:12px;font-weight:600;padding:6px 16px;border-radius:100px;margin-bottom:28px}
[data-theme="dark"] .hero-pill{color:var(--teal)}
.hero-pill::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--teal);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-family:var(--fh);font-size:clamp(36px,4.5vw,54px);font-weight:800;color:var(--text);line-height:1.05;letter-spacing:-.035em;margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--teal)}
.hero-sub{font-size:17px;color:var(--text-sec);line-height:1.65;margin-bottom:36px;max-width:440px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{display:flex;justify-content:flex-end;align-items:center}
.phone-frame{width:100%;border-radius:16px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.2),0 0 0 1px rgba(57,197,181,.1);background:var(--bg-card);padding:4px;transition:transform .4s}
.phone-frame:hover{transform:translateY(-4px)}
.phone-frame img{width:100%;display:block;border-radius:12px}
.trust-strip{margin-top:48px;display:flex;gap:20px;flex-wrap:wrap}
.trust-item{font-size:13px;color:var(--text-mut);font-weight:500;display:flex;align-items:center;gap:6px}
.trust-item::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--teal);flex-shrink:0}

/* === Buttons (gradient primary) === */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--rb);font-family:var(--fb);font-size:15px;font-weight:600;text-decoration:none;transition:all .25s;border:none;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,var(--teal),var(--teal-hover));color:#fff;box-shadow:0 2px 8px rgba(57,197,181,.25)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(57,197,181,.35)}
.btn-ghost{background:var(--bg-card);color:var(--text);border:1.5px solid var(--border);box-shadow:var(--sh-sm)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);box-shadow:var(--sh-card)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:#fff;box-shadow:0 2px 8px rgba(217,119,6,.25)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(217,119,6,.35)}

/* === Sections === */
.section{padding:100px 28px}.section-inner{max-width:1140px;margin:0 auto}
.section-header{text-align:center;max-width:580px;margin:0 auto 72px}
.section-label{font-size:11px;font-weight:700;color:#1a7a6e;text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px}
[data-theme="dark"] .section-label{color:var(--teal)}
.section-title{font-family:var(--fh);font-size:clamp(28px,3.2vw,40px);font-weight:800;color:var(--text);line-height:1.1;letter-spacing:-.03em;margin-bottom:14px}
.section-desc{font-size:16px;color:var(--text-sec);line-height:1.65;max-width:520px;margin:0 auto}
.bg-alt{background:var(--bg-alt)}

/* === Feature cards (premium depth) === */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rc);padding:32px 24px;transition:all .3s;position:relative;overflow:hidden}
.feature-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-hover));opacity:0;transition:opacity .3s}
.feature-card:hover{box-shadow:var(--sh-hover);transform:translateY(-3px)}
.feature-card:hover::after{opacity:1}
.feature-emoji{font-size:28px;margin-bottom:16px;display:block}
.feature-card h3{font-family:var(--fh);font-size:17px;font-weight:700;color:var(--text);margin-bottom:8px}
.feature-card p{font-size:13.5px;color:var(--text-sec);line-height:1.6}

/* === Steps (premium numbers) === */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:step}
.step{text-align:center;padding:28px 16px}
.step::before{counter-increment:step;content:counter(step);display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:linear-gradient(135deg,var(--navy-deep),#2a4a6b);color:#fff;border-radius:50%;font-family:var(--fh);font-size:18px;font-weight:800;margin:0 auto 18px;box-shadow:0 4px 12px rgba(26,45,66,.2)}
[data-theme="dark"] .step::before{background:linear-gradient(135deg,var(--teal),var(--teal-hover));color:#0f1720}
.step h4{font-family:var(--fh);font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}
.step p{font-size:13.5px;color:var(--text-sec);line-height:1.55}

/* === Testimonials (premium cards) === */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testimonial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rc);padding:28px 24px;transition:all .3s;position:relative}
.testimonial-card:hover{box-shadow:var(--sh-hover);transform:translateY(-2px)}
.testimonial-stars{color:var(--gold);font-size:15px;letter-spacing:2px;margin-bottom:14px}
.testimonial-text{font-size:14px;color:var(--text-sec);line-height:1.65;font-style:italic;margin-bottom:18px}
.testimonial-author{display:flex;align-items:center;gap:10px}
.testimonial-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--navy-deep),#2a4a6b);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:12px;font-weight:700;box-shadow:0 2px 6px rgba(26,45,66,.2)}
[data-theme="dark"] .testimonial-avatar{background:linear-gradient(135deg,var(--teal),var(--teal-hover));color:#0f1720}
.testimonial-name{font-weight:600;font-size:13px;color:var(--text)}
.testimonial-role{font-size:12px;color:var(--text-mut)}

/* === Guides (premium cards) === */
.guides-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.guide-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rc);padding:28px;transition:all .3s;text-decoration:none;color:inherit;display:block}
.guide-card:hover{box-shadow:var(--sh-hover);transform:translateY(-2px)}
.guide-tag{font-size:10px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.guide-card h3{font-family:var(--fh);font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.25}
.guide-card p{font-size:13.5px;color:var(--text-sec);line-height:1.6;margin-bottom:14px}
.guide-link{font-size:13px;font-weight:600;color:var(--teal);display:inline-flex;align-items:center;gap:4px}
.guide-link::after{content:'\2192';transition:transform .2s}
.guide-card:hover .guide-link::after{transform:translateX(4px)}
.guide-content{max-width:720px;margin:0 auto}
.guide-content h2{font-family:var(--fh);font-size:28px;font-weight:700;color:var(--text);margin:56px 0 20px;line-height:1.2}
.guide-content h3{font-family:var(--fh);font-size:21px;font-weight:700;color:var(--text);margin:40px 0 14px}
.guide-content p{font-size:16px;color:var(--text-sec);margin-bottom:20px;line-height:1.8}
.guide-content ul{margin:20px 0 28px 20px}
.guide-content li{font-size:16px;color:var(--text-sec);margin-bottom:12px;line-height:1.8}
.callout{background:var(--teal-pale);border-left:3px solid var(--teal);padding:18px 22px;border-radius:0 var(--rb) var(--rb) 0;margin:22px 0}
.callout p{color:var(--text);margin-bottom:0}.callout strong{color:var(--text)}
.warning-callout{background:#fef9ee;border-left-color:var(--gold)}
[data-theme="dark"] .warning-callout{background:rgba(217,119,6,.08)}

/* === Pricing (premium) === */
.pricing-cards{display:grid;gap:20px}
.pricing-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--rh);padding:32px;text-align:center;position:relative;transition:all .3s}
.pricing-card:hover{box-shadow:var(--sh-hover);transform:translateY(-2px)}
.pricing-card.featured{border-color:var(--teal);box-shadow:var(--sh-hover)}
.pricing-card.featured::before{content:'Most Popular';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--teal),var(--teal-hover));color:#fff;font-size:10px;font-weight:700;padding:4px 14px;border-radius:100px;box-shadow:0 2px 8px rgba(57,197,181,.3)}
.pricing-card h3{font-family:var(--fh);font-size:20px;font-weight:700;color:var(--text);margin-bottom:4px}
.pricing-sub{color:var(--text-mut);font-size:13px}
.pricing-price{font-family:var(--fh);font-size:40px;font-weight:800;color:var(--text);margin:18px 0;letter-spacing:-.03em}
.pricing-price span{font-size:15px;font-weight:500;color:var(--text-mut)}
.pricing-features{list-style:none;margin:22px 0;text-align:left}
.pricing-features li{padding:7px 0;font-size:13px;color:var(--text-sec);display:flex;align-items:center;gap:8px}
.pricing-features li::before{content:'\2713';color:var(--teal);font-weight:700;font-size:14px}
.pricing-note{text-align:center;margin-top:20px;font-size:13px;color:var(--text-mut)}

/* === FAQ === */
.faq-list{max-width:680px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-question{width:100%;text-align:left;background:none;border:none;padding:20px 0;font-family:var(--fb);font-size:15px;font-weight:600;color:var(--text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:color .2s}
.faq-question:hover{color:var(--teal)}
.faq-arrow{font-size:20px;transition:transform .3s;color:var(--text-mut);flex-shrink:0}
.faq-item.open .faq-arrow{transform:rotate(90deg);color:var(--teal)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-answer{max-height:400px;padding-bottom:18px}
.faq-answer p{font-size:14px;color:var(--text-sec);line-height:1.65}
.faq-answer a{color:var(--teal)}

/* === Accountant section (premium dark) === */
.acc-section{background:linear-gradient(135deg,#1a2d42,#0f1f30);color:#fff}
[data-theme="dark"] .acc-section{background:linear-gradient(135deg,#0a1118,#0c1520)}
.acc-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.acc-content .section-label{color:var(--gold-light)}
.acc-content .section-title{color:#fff;text-align:left}
.acc-content .section-desc{color:#b0bec5;text-align:left}
.acc-benefits{list-style:none;margin:28px 0}
.acc-benefits li{display:flex;align-items:flex-start;gap:12px;padding:10px 0;font-size:14px;color:#cbd5e1}
.acc-benefits li::before{content:'\2713';min-width:26px;height:26px;background:rgba(57,197,181,.15);color:var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.acc-note{color:#90a4ae;font-size:13px;margin-top:8px}
.acc-form{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--rh);padding:36px;backdrop-filter:blur(8px)}
.acc-form h3{font-family:var(--fh);font-size:22px;font-weight:700;margin-bottom:6px;color:#fff}
.acc-form>p{color:#64748b;font-size:13px;margin-bottom:24px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:#94a3b8;margin-bottom:5px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--rb);color:#fff;font-family:var(--fb);font-size:14px;transition:all .2s}
.form-group input::placeholder,.form-group textarea::placeholder{color:#8494a7}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(57,197,181,.15)}
.form-group select option{background:#1a2634;color:#fff}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* === CTA banner (premium gradient) === */
.cta-banner{background:linear-gradient(135deg,var(--teal),var(--teal-hover),#2a9d8f);padding:80px 28px;text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;top:-60%;right:-20%;width:500px;height:500px;border-radius:50%;background:rgba(255,255,255,.06)}
.cta-banner::after{content:'';position:absolute;bottom:-40%;left:-10%;width:400px;height:400px;border-radius:50%;background:rgba(255,255,255,.04)}
.cta-banner h2{font-family:var(--fh);font-size:clamp(26px,3.2vw,36px);color:#fff;font-weight:800;margin-bottom:12px;position:relative;letter-spacing:-.02em}
.cta-banner p{color:rgba(255,255,255,.85);font-size:16px;margin-bottom:32px;position:relative}
.store-buttons{display:flex;justify-content:center;gap:14px;position:relative;flex-wrap:wrap}
.store-btn{display:inline-flex;align-items:center;gap:10px;background:rgba(26,45,66,.9);color:#fff;padding:13px 24px;border-radius:var(--rb);text-decoration:none;font-size:14px;font-weight:600;transition:all .25s;backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1)}
.store-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3);background:rgba(26,45,66,1)}
.store-btn-label{font-size:10px;font-weight:400;opacity:.7;display:block}
.store-btn-name{font-size:15px;display:block}

/* === Footer (premium dark) === */
.footer{background:linear-gradient(180deg,#0a1118,#060c11);padding:64px 28px 28px;color:#64748b}
.footer-inner{max-width:1140px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-brand p{font-size:13px;line-height:1.65;margin-top:14px;color:#7c8da0}
.footer h4{color:#e2e8f0;font-family:var(--fh);font-size:13px;font-weight:700;margin-bottom:14px;text-transform:uppercase;letter-spacing:.06em}
.footer-links{list-style:none}
.footer-links li{margin-bottom:8px}
.footer-links a{color:#8494a7;text-decoration:none;font-size:13px;transition:color .2s}
.footer-links a:hover{color:var(--teal)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:20px;display:flex;justify-content:space-between;font-size:12px;color:#7c8da0}
.footer a[href^="mailto"]{color:var(--teal);font-weight:500}
.footer a[href^="mailto"]:hover{color:var(--teal-hover)}

/* === Animation === */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* === Router & Niche (homepage) === */
.router-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:640px;margin:0 auto}
.router-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--rc);padding:32px 24px;text-align:center;text-decoration:none;color:inherit;transition:all .3s;position:relative;overflow:hidden}
.router-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-hover));opacity:0;transition:opacity .3s}
.router-card:hover{border-color:var(--teal);box-shadow:var(--sh-hover);transform:translateY(-3px)}
.router-card:hover::after{opacity:1}
.router-card h3{font-family:var(--fh);font-size:18px;font-weight:700;color:var(--text);margin-bottom:6px}
.router-card p{font-size:13.5px;color:var(--text-sec);line-height:1.5}
.niche-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:720px;margin:0 auto}
.niche-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rc);padding:24px 20px;text-decoration:none;color:inherit;transition:all .3s;display:flex;align-items:flex-start;gap:16px}
.niche-card:hover{box-shadow:var(--sh-hover);transform:translateY(-2px)}
.niche-card h3{font-family:var(--fh);font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.niche-card p{font-size:13px;color:var(--text-sec);line-height:1.5}
.niche-emoji{font-size:28px;flex-shrink:0}
#guide-records,#guide-expenses,#guide-vat,#guide-mileage{display:none}

/* === Pricing divider === */
.pricing-divider{max-width:1140px;margin:0 auto;padding:0 28px}
.pricing-divider hr{border:none;border-top:2px solid var(--border);margin:0}

/* === Responsive === */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-sub{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
  .hero-visual{margin-top:20px}
  .trust-strip{justify-content:center}
  .features-grid,.testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .acc-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .pricing-cards{grid-template-columns:repeat(2,1fr)!important;max-width:640px!important}
  .resp-3col{grid-template-columns:1fr!important}
  .resp-2col{grid-template-columns:1fr!important}
}
@media(max-width:768px){
  .hero-visual{display:none}
  .hero{padding:100px 20px 48px}
  .hero h1{font-size:28px}
  .hero-sub{font-size:15px}
  .hero-btns .btn{padding:16px 24px;font-size:15px;min-height:48px}
  .nav-links{display:none}
  .nav-mobile{display:block}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:var(--bg);padding:16px 28px;border-bottom:1px solid var(--border);box-shadow:var(--sh-card)}
  .nav-links.open a{padding:12px 14px;font-size:15px;min-height:48px;display:flex;align-items:center}
  .features-grid,.testimonials-grid{grid-template-columns:1fr}
  .feature-card{padding:24px 20px}
  .feature-card h3{font-size:16px}
  .feature-card p{font-size:14px;line-height:1.6}
  .feature-emoji{font-size:32px}
  .steps{grid-template-columns:1fr}
  .step p{font-size:14px}
  .guides-grid{grid-template-columns:1fr}
  .guide-card h3{font-size:16px}
  .guide-card p{font-size:14px}
  .testimonial-text{font-size:15px}
  .pricing-cards{grid-template-columns:1fr!important;max-width:400px!important}
  .pricing-card{padding:28px 24px}
  .pricing-features li{font-size:14px;padding:8px 0}
  .store-buttons{flex-direction:column;align-items:center}
  .store-btn{min-height:48px;width:100%;max-width:280px;justify-content:center}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;gap:6px}
  .form-row{grid-template-columns:1fr}
  .section{padding:56px 20px}
  .section-header{margin-bottom:40px}
  .section-title{font-size:24px}
  .section-desc{font-size:14px}
  .section-label{font-size:10px}
  .router-grid,.niche-grid{grid-template-columns:1fr}
  .router-card{padding:24px 20px}
  .router-card h3{font-size:17px}
  .router-card p{font-size:14px}
  .niche-card{padding:20px 16px}
  .niche-card h3{font-size:15px}
  .niche-card p{font-size:14px}
  .trust-strip{gap:12px;margin-top:32px}
  .trust-item{font-size:12px}
  .faq-question{font-size:14px;padding:16px 0;min-height:48px}
  .faq-answer p{font-size:13.5px}
  .cta-banner{padding:56px 20px}
  .cta-banner h2{font-size:24px}
  .cta-banner p{font-size:14px;margin-bottom:24px}
  .email-capture{padding:24px 18px}
  .email-capture h3{font-size:16px}
  .email-capture p{font-size:13px}
  .acc-grid{gap:32px}
  .acc-feature-grid{grid-template-columns:1fr!important}
  .acc-feature-grid h3{font-size:14px!important}
  .acc-feature-grid p{font-size:13px!important}
  .acc-form{padding:28px 20px}
  .acc-form h3{font-size:18px}
  .cookie-banner{flex-direction:column;text-align:center;padding:16px 20px;gap:12px}
  .cookie-btn{min-height:44px;width:100%}
}

/* === Sticky CTA bar (mobile, for-accountants) === */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:999;background:var(--nav-bg);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-top:1px solid var(--border);padding:12px 20px;display:flex;align-items:center;justify-content:center;gap:12px;transform:translateY(100%);transition:transform .3s ease;box-shadow:0 -4px 20px rgba(0,0,0,.1)}
.sticky-cta.visible{transform:translateY(0)}
.sticky-cta .btn{padding:12px 24px;font-size:14px;flex:1;max-width:200px;justify-content:center;text-align:center}
@media(min-width:769px){.sticky-cta{display:none}}

/* === Email capture form === */
.email-capture{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rc);padding:32px;text-align:center;max-width:520px;margin:0 auto}
.email-capture h3{font-family:var(--fh);font-size:18px;font-weight:700;color:var(--text);margin-bottom:6px}
.email-capture p{font-size:13.5px;color:var(--text-sec);margin-bottom:18px;line-height:1.5}
.email-capture-form{display:flex;gap:10px;max-width:420px;margin:0 auto}
.email-capture-form input[type="email"]{flex:1;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--rb);font-family:var(--fb);font-size:14px;color:var(--text);background:var(--bg);transition:border-color .2s}
.email-capture-form input[type="email"]:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(57,197,181,.15)}
.email-capture-form input[type="email"]::placeholder{color:var(--text-mut)}
.email-capture-form button{padding:12px 22px;background:linear-gradient(135deg,var(--teal),var(--teal-hover));color:#fff;border:none;border-radius:var(--rb);font-family:var(--fb);font-size:14px;font-weight:600;cursor:pointer;transition:all .25s;white-space:nowrap}
.email-capture-form button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(57,197,181,.3)}
@media(max-width:480px){.email-capture-form{flex-direction:column}.email-capture-form button{width:100%}}

/* === Cookie consent banner === */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9998;background:var(--bg-card);border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(0,0,0,.1);padding:16px 24px;display:none;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.cookie-banner.visible{display:flex}
.cookie-banner p{font-size:13px;color:var(--text-sec);line-height:1.5;margin:0;max-width:600px}
.cookie-banner p a{color:var(--teal);text-decoration:none;font-weight:500}
.cookie-banner p a:hover{text-decoration:underline}
.cookie-btn{padding:10px 20px;border-radius:var(--rb);font-family:var(--fb);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .2s}
.cookie-btn-accept{background:linear-gradient(135deg,var(--teal),var(--teal-hover));color:#fff}
.cookie-btn-accept:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(57,197,181,.3)}
.cookie-btn-reject{background:var(--bg-alt);color:var(--text-sec);border:1px solid var(--border)}
.cookie-btn-reject:hover{border-color:var(--teal);color:var(--teal)}

/* === Accessibility === */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
*:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:4px}
