/* ═══════════════════════════════════════════════════════════════
   KAVINORA POS — Design System
   Enterprise-grade SaaS landing page styles
   ═══════════════════════════════════════════════════════════════ */

/* ── Reset & Base ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
body{font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;line-height:1.6;color:var(--text);background:var(--bg);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;transition:color .2s}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,textarea,select{font:inherit}

/* ── CSS Variables (Light Theme) ────────────────────────── */
:root{
  --bg:#f8fafc;
  --bg-elevated:#ffffff;
  --bg-card:#ffffff;
  --bg-card-hover:#f8fafc;
  --surface:#f1f5f9;
  --border:#e2e8f0;
  --border-light:#cbd5e1;
  --text:#0f172a;
  --text-secondary:#475569;
  --text-muted:#94a3b8;
  --primary:#2563eb;
  --primary-light:#3b82f6;
  --primary-dark:#1d4ed8;
  --primary-glow:rgba(37,99,235,.08);
  --primary-glow-strong:rgba(37,99,235,.16);
  --accent:#7c3aed;
  --accent-light:#8b5cf6;
  --success:#059669;
  --warning:#d97706;
  --danger:#dc2626;
  --info:#0284c7;
  --gradient-primary:linear-gradient(135deg,#2563eb,#7c3aed);
  --gradient-dark:linear-gradient(180deg,#f8fafc 0%,#ffffff 100%);
  --gradient-card:linear-gradient(145deg,#ffffff 0%,#f8fafc 100%);
  --gradient-glow:radial-gradient(600px circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(37,99,235,.04),transparent 40%);
  --shadow-sm:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.08),0 2px 6px rgba(0,0,0,.04);
  --shadow-lg:0 8px 32px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.05);
  --shadow-glow:0 0 32px rgba(37,99,235,.14);
  --radius-sm:6px;
  --radius-md:10px;
  --radius-lg:16px;
  --radius-xl:24px;
  --nav-height:72px;
  --section-pad:6rem 0;
  --container:1200px;
  --transition-fast:.15s ease;
  --transition:.25s ease;
  --transition-slow:.4s ease;
}

/* ── Utility ─────────────────────────────────────────────── */
.container{max-width:var(--container);margin:0 auto;padding:0 1.5rem}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.gap-4{gap:2rem}
.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}
.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}
.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}
.text-primary{color:var(--primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}
.w-full{width:100%}.relative{position:relative}.overflow-hidden{overflow:hidden}
.hidden{display:none}
.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}

/* ── Skeleton Shimmer ────────────────────────────────────── */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.skeleton{background:linear-gradient(90deg,var(--bg-card) 25%,var(--surface) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}
.skeleton-text{height:1rem;margin-bottom:.5rem;border-radius:4px}
.skeleton-text.short{width:60%}
.skeleton-heading{height:1.5rem;width:40%;margin-bottom:1rem;border-radius:4px}
.skeleton-card{height:200px;border-radius:var(--radius-lg)}
.skeleton-circle{border-radius:50%}

/* ── Animations ──────────────────────────────────────────── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes glow{0%,100%{box-shadow:0 0 20px rgba(59,130,246,.2)}50%{box-shadow:0 0 40px rgba(59,130,246,.4)}}
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

.animate-fadeInUp{animation:fadeInUp .6s ease forwards}
.animate-fadeInDown{animation:fadeInDown .5s ease forwards}
.animate-scaleIn{animation:scaleIn .5s ease forwards}
.animate-slideInLeft{animation:slideInLeft .6s ease forwards}
.animate-slideInRight{animation:slideInRight .6s ease forwards}
.animate-float{animation:float 3s ease-in-out infinite}

/* Scroll reveal */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
[data-reveal].revealed{opacity:1;transform:translateY(0)}
[data-reveal="left"]{transform:translateX(-30px)}
[data-reveal="left"].revealed{transform:translateX(0)}
[data-reveal="right"]{transform:translateX(30px)}
[data-reveal="right"].revealed{transform:translateX(0)}
[data-reveal="scale"]{transform:scale(.95)}
[data-reveal="scale"].revealed{transform:scale(1)}

/* Stagger children */
[data-reveal-stagger]>[data-reveal]{transition-delay:calc(var(--i,0) * .1s)}

/* ── Navigation ──────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,backdrop-filter .3s,box-shadow .3s;height:var(--nav-height);display:flex;align-items:center}
.nav.scrolled{background:rgba(248,250,252,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.nav-logo{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:var(--text)}
.nav-logo svg{width:32px;height:32px}
.nav-logo span{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-links{display:flex;align-items:center;gap:.25rem}
.nav-links a{padding:.5rem 1rem;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9375rem;font-weight:500;transition:color var(--transition),background var(--transition)}
.nav-links a:hover{color:var(--text);background:var(--primary-glow)}
.nav-links a.active{color:var(--primary)}
.nav-actions{display:flex;align-items:center;gap:.75rem}
.nav-mobile-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);transition:color var(--transition)}
.nav-mobile-toggle:hover{color:var(--text)}

/* Mobile nav */
.mobile-nav{position:fixed;inset:0;z-index:99;background:rgba(248,250,252,.98);backdrop-filter:blur(20px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.mobile-nav.open{opacity:1;visibility:visible}
.mobile-nav a{font-size:1.25rem;padding:.75rem 2rem;border-radius:var(--radius-md);color:var(--text-secondary);transition:color var(--transition),background var(--transition)}
.mobile-nav a:hover{color:var(--primary);background:var(--primary-glow)}

/* ── Buttons ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.5rem;border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;transition:all var(--transition);white-space:nowrap;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(rgba(255,255,255,.1),transparent);opacity:0;transition:opacity var(--transition)}
.btn:hover::after{opacity:1}
.btn:active{transform:scale(.97);transition:transform .1s}

.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 10px rgba(59,130,246,.3)}
.btn-primary:hover{box-shadow:0 4px 20px rgba(59,130,246,.4);transform:translateY(-1px)}

.btn-secondary{background:var(--bg-card);color:var(--text);border:1.5px solid var(--border);box-shadow:var(--shadow-sm)}
.btn-secondary:hover{border-color:var(--primary);background:var(--primary-glow);box-shadow:var(--shadow-md)}

.btn-ghost{color:var(--text-secondary);padding:.5rem 1rem}
.btn-ghost:hover{color:var(--text);background:var(--primary-glow)}

.btn-lg{padding:.875rem 2rem;font-size:1.0625rem;border-radius:var(--radius-lg)}
.btn-sm{padding:.375rem 1rem;font-size:.8125rem}
.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-sm)}

/* ── Section ─────────────────────────────────────────────── */
section{padding:var(--section-pad);position:relative}
.section-header{text-align:center;max-width:640px;margin:0 auto 4rem}
.section-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem 1rem;border-radius:999px;font-size:.8125rem;font-weight:600;color:var(--primary);background:var(--primary-glow);border:1px solid rgba(59,130,246,.2);margin-bottom:1rem}
.section-badge svg{width:14px;height:14px}
.section-title{font-size:2.5rem;font-weight:800;line-height:1.15;margin-bottom:1rem;letter-spacing:-.025em}
.section-title span{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-desc{font-size:1.125rem;color:var(--text-secondary);line-height:1.7}

/* ── Hero ────────────────────────────────────────────────── */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding-top:var(--nav-height);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(37,99,235,.07) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(124,58,237,.05) 0%,transparent 50%);pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(37,99,235,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.04) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%)}
.hero-content{text-align:center;max-width:800px;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;border-radius:999px;font-size:.8125rem;font-weight:600;color:var(--primary-light);background:var(--primary-glow);border:1px solid rgba(59,130,246,.15);margin-bottom:2rem;animation:fadeInDown .6s ease}
.hero-badge svg{width:16px;height:16px;animation:pulse 2s infinite}
.hero-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:800;line-height:1.1;letter-spacing:-.03em;margin-bottom:1.5rem;animation:fadeInUp .6s ease .1s backwards}
.hero-title span{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-desc{font-size:clamp(1rem,2vw,1.25rem);color:var(--text-secondary);max-width:600px;margin:0 auto 2.5rem;line-height:1.7;animation:fadeInUp .6s ease .2s backwards}
.hero-actions{display:flex;align-items:center;justify-content:center;gap:1rem;animation:fadeInUp .6s ease .3s backwards;flex-wrap:wrap}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:3rem;margin-top:4rem;animation:fadeInUp .6s ease .4s backwards}
.hero-stat{text-align:center}
.hero-stat-value{font-size:2rem;font-weight:800;color:var(--text);display:block}
.hero-stat-label{font-size:.8125rem;color:var(--text-muted);font-weight:500;margin-top:.25rem;display:block}

/* ── Feature Cards ───────────────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.feature-card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:all var(--transition);position:relative;overflow:hidden}
.feature-card::before{content:'';position:absolute;inset:0;background:var(--gradient-glow);opacity:0;transition:opacity var(--transition)}
.feature-card:hover{border-color:var(--border-light);transform:translateY(-4px);box-shadow:var(--shadow-glow)}
.feature-card:hover::before{opacity:1}
.feature-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;background:var(--primary-glow);color:var(--primary);position:relative;z-index:1}
.feature-card-icon svg{width:24px;height:24px}
.feature-card h3{font-size:1.125rem;font-weight:700;margin-bottom:.5rem;color:var(--text);position:relative;z-index:1}
.feature-card p{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;position:relative;z-index:1}

/* ── Pricing ─────────────────────────────────────────────── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.pricing-card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem 2rem;transition:all var(--transition);position:relative}
.pricing-card:hover{border-color:var(--border-light);transform:translateY(-4px)}
.pricing-card.popular{border-color:var(--primary);box-shadow:var(--shadow-glow)}
.pricing-card.popular::before{content:'Most Popular';position:absolute;top:0;left:50%;transform:translateX(-50%) translateY(-50%);background:var(--gradient-primary);color:#fff;padding:.25rem 1rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.02em}
.pricing-name{font-size:1.125rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}
.pricing-price{font-size:3rem;font-weight:800;color:var(--text);line-height:1;margin-bottom:.25rem}
.pricing-price span{font-size:1rem;font-weight:500;color:var(--text-muted)}
.pricing-desc{font-size:.875rem;color:var(--text-muted);margin-bottom:2rem}
.pricing-features{margin-bottom:2rem}
.pricing-features li{display:flex;align-items:flex-start;gap:.75rem;padding:.5rem 0;font-size:.9375rem;color:var(--text-secondary)}
.pricing-features li svg{width:18px;height:18px;color:var(--success);flex-shrink:0;margin-top:2px}
.pricing-features li.disabled{color:var(--text-muted)}
.pricing-features li.disabled svg{color:var(--text-muted)}

/* ── Testimonials ────────────────────────────────────────── */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.testimonial-card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:all var(--transition)}
.testimonial-card:hover{border-color:var(--border-light);transform:translateY(-2px)}
.testimonial-stars{display:flex;gap:.125rem;margin-bottom:1rem;color:var(--warning)}
.testimonial-stars svg{width:16px;height:16px}
.testimonial-text{font-size:.9375rem;color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:.75rem}
.testimonial-avatar{width:40px;height:40px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem}
.testimonial-name{font-weight:600;font-size:.9375rem;color:var(--text)}
.testimonial-role{font-size:.8125rem;color:var(--text-muted)}

/* ── CTA Section ─────────────────────────────────────────── */
.cta-section{background:linear-gradient(135deg,#eff6ff 0%,#f5f3ff 100%);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(37,99,235,.06),transparent 70%);pointer-events:none}
.cta-content{text-align:center;position:relative;z-index:1}

/* ── Footer ──────────────────────────────────────────────── */
.footer{background:var(--bg);border-top:1px solid var(--border);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand p{color:var(--text-secondary);font-size:.9375rem;margin-top:.75rem;line-height:1.7}
.footer-col h4{font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:1rem}
.footer-col a{display:block;padding:.375rem 0;color:var(--text-secondary);font-size:.9375rem;transition:color var(--transition)}
.footer-col a:hover{color:var(--primary)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:2rem;border-top:1px solid var(--border);font-size:.8125rem;color:var(--text-muted)}
.footer-bottom-links{display:flex;gap:1.5rem}
.footer-bottom-links a:hover{color:var(--primary)}

/* ── Responsive ──────────────────────────────────────────── */
@media(max-width:1024px){
  .features-grid,.pricing-grid,.testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-stats{gap:2rem}
  .section-title{font-size:2rem}
}
@media(max-width:768px){
  :root{--section-pad:4rem 0;--nav-height:64px}
  .nav-links,.nav-actions .btn-secondary{display:none}
  .nav-mobile-toggle{display:flex}
  .features-grid,.pricing-grid,.testimonials-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-stats{flex-direction:column;gap:1.5rem}
  .hero-actions{flex-direction:column;width:100%}
  .hero-actions .btn{width:100%;max-width:320px}
  .section-title{font-size:1.75rem}
  .section-desc{font-size:1rem}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
  .footer-bottom-links{justify-content:center}
}
@media(max-width:480px){
  .container{padding:0 1rem}
  .hero-title{font-size:2rem}
  .pricing-card{padding:2rem 1.5rem}
}

/* ── Page Loading Overlay ────────────────────────────────── */
.page-loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .4s,visibility .4s}
.page-loader.loaded{opacity:0;visibility:hidden;pointer-events:none}
.page-loader-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.page-loader-text{margin-top:1rem;font-size:.875rem;color:var(--text-muted);font-weight:500}

/* ── Stats Counter Animation ─────────────────────────────── */
[data-count]{font-variant-numeric:tabular-nums}

/* ── Scrollbar ───────────────────────────────────────────── */
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:#94a3b8}

/* ── Downloads Section ──────────────────────── */
.downloads-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:2.5rem}
.download-card{background:var(--bg);border:1.5px solid var(--border);border-radius:16px;padding:2rem 1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem;transition:border-color .2s,box-shadow .2s;position:relative;overflow:hidden}
.download-card:hover{border-color:var(--primary);box-shadow:0 8px 32px rgba(59,130,246,.12)}
.download-icon{font-size:2.5rem;line-height:1;margin-bottom:.25rem;min-height:48px;min-width:48px;display:flex;align-items:center;justify-content:center}
.download-icon svg{width:48px;height:48px}
.download-platform{font-size:1.1rem;font-weight:700;color:var(--text)}
.download-version{font-size:.8rem;color:var(--text-muted)}
.download-size{font-size:.75rem;color:var(--text-muted);margin-left:.25rem}
.download-hint{font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem}
.btn-download{display:inline-flex;align-items:center;gap:.4rem;background:var(--primary);color:#fff;border:none;border-radius:8px;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s,transform .1s;margin-top:auto;width:100%;justify-content:center}
.btn-download:hover{background:var(--primary-dark,#2563eb);transform:translateY(-1px)}
@media(max-width:640px){.downloads-grid{grid-template-columns:1fr 1fr}}
@media(max-width:400px){.downloads-grid{grid-template-columns:1fr}}

/* ── How It Works ───────────────────────────── */
.how-section{background:var(--bg-elevated)}
.how-steps{display:grid;grid-template-columns:1fr 40px 1fr 40px 1fr;align-items:start;gap:0;max-width:920px;margin:0 auto}
.how-step{text-align:center;padding:0 1rem}
.how-step-num{font-size:.6875rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--primary);background:var(--primary-glow);border:1.5px solid rgba(37,99,235,.2);border-radius:999px;padding:.3rem .875rem;display:inline-flex;margin-bottom:1.25rem}
.how-step-icon{width:72px;height:72px;border-radius:var(--radius-lg);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;box-shadow:0 6px 20px rgba(37,99,235,.22)}
.how-step-icon svg{width:30px;height:30px;color:#fff}
.how-step h3{font-size:1.125rem;font-weight:700;color:var(--text);margin-bottom:.625rem}
.how-step p{font-size:.9375rem;color:var(--text-secondary);line-height:1.65}
.how-connector{display:flex;align-items:center;justify-content:center;padding-top:2.75rem}
.how-connector svg{width:28px;height:28px;color:var(--border-light)}
.how-cta{text-align:center;margin-top:3rem}
@media(max-width:768px){
  .how-steps{grid-template-columns:1fr;max-width:400px}
  .how-connector{padding-top:0;transform:rotate(90deg)}
}

/* ── Integrations ───────────────────────────── */
.integrations-section{background:var(--bg)}
.integrations-logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem;margin-top:2.5rem}
.integration-badge{display:flex;align-items:center;gap:.625rem;padding:.625rem 1.25rem;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);font-size:.9375rem;font-weight:600;color:var(--text-secondary);transition:border-color var(--transition),color var(--transition),box-shadow var(--transition)}
.integration-badge:hover{border-color:var(--primary);color:var(--primary);box-shadow:var(--shadow-md)}
.integration-badge .int-icon{font-size:1.25rem;line-height:1}
.integration-note{text-align:center;margin-top:2rem;font-size:.875rem;color:var(--text-muted)}

/* ── Security & Trust ───────────────────────── */
.security-section{background:var(--bg-elevated)}
.security-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.security-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:border-color var(--transition),box-shadow var(--transition)}
.security-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}
.security-icon{width:52px;height:52px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;font-size:1.5rem}
.security-card h3{font-size:1.0625rem;font-weight:700;color:var(--text);margin-bottom:.5rem}
.security-card p{font-size:.9375rem;color:var(--text-secondary);line-height:1.65}
.trust-badges{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:3rem}
.trust-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;background:var(--surface);border:1.5px solid var(--border);border-radius:999px;font-size:.8125rem;font-weight:600;color:var(--text-secondary)}
.trust-badge svg{width:16px;height:16px;color:var(--success)}
@media(max-width:768px){.security-grid{grid-template-columns:1fr}}

/* ── FAQ ────────────────────────────────────── */
.faq-section{background:var(--bg)}
.faq-list{max-width:740px;margin:0 auto;display:flex;flex-direction:column;gap:.75rem}
.faq-item{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition),box-shadow var(--transition)}
.faq-item.open{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.faq-question{width:100%;text-align:left;padding:1.25rem 1.5rem;font-size:.9375rem;font-weight:600;color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer;background:none;border:none;transition:color var(--transition);line-height:1.4}
.faq-question:hover{color:var(--primary)}
.faq-chevron{width:20px;height:20px;flex-shrink:0;color:var(--text-muted);transition:transform .3s ease,color .2s}
.faq-item.open .faq-chevron{transform:rotate(180deg);color:var(--primary)}
.faq-answer{padding:0 1.5rem;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .3s ease;font-size:.9375rem;color:var(--text-secondary);line-height:1.7}
.faq-item.open .faq-answer{max-height:220px;padding:.125rem 1.5rem 1.5rem}

/* ── Testimonial verified badge ─────────────── */
.verified-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.6875rem;font-weight:600;color:var(--success);background:rgba(5,150,105,.08);border:1px solid rgba(5,150,105,.2);border-radius:999px;padding:.2rem .6rem;margin-left:.5rem}
.verified-badge svg{width:11px;height:11px}

/* ── Email chip (login step 2) ───────────────── */
.email-chip{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);margin-bottom:1rem}
.email-chip-addr{font-size:.9375rem;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.email-chip-change{font-size:.8125rem;font-weight:600;color:var(--primary);background:none;border:none;cursor:pointer;white-space:nowrap;padding:0;flex-shrink:0}
.email-chip-change:hover{color:var(--primary-dark);text-decoration:underline}

/* ── Plan badge (signup) ─────────────────────── */
.plan-badge{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(124,58,237,.06));border:1.5px solid rgba(37,99,235,.2);border-radius:var(--radius-md);margin-bottom:1.25rem}
.plan-badge-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.plan-badge-icon svg{width:18px;height:18px;color:#fff}
.plan-badge-text{flex:1}
.plan-badge-label{font-size:.75rem;font-weight:500;color:var(--text-muted)}
.plan-badge-name{font-size:.9375rem;font-weight:700;color:var(--primary)}
.plan-badge-change{font-size:.8125rem;color:var(--text-muted);font-weight:500;text-decoration:none;flex-shrink:0}
.plan-badge-change:hover{color:var(--primary)}

/* ── Footer Social Links ─────────────────────── */
.footer-social{display:flex;align-items:center;gap:.625rem;margin-top:1.125rem}
.footer-social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);background:var(--surface);border:1.5px solid var(--border);color:var(--text-muted);transition:background var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition)}
.footer-social-link:hover{background:var(--gradient-primary);border-color:transparent;color:#fff;box-shadow:0 4px 12px rgba(37,99,235,.25)}
