*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg-primary:#0a0a0a;
  --bg-secondary:#111111;
  --bg-card:#1a1a1a;
  --bg-card-hover:#222222;
  --bg-input:#1a1a1a;
  --text-primary:#ffffff;
  --text-secondary:#a0a0a0;
  --text-muted:#666666;
  --accent:#FFD700;
  --accent-hover:#FFC000;
  --accent-light:rgba(255,215,0,0.1);
  --border:#2a2a2a;
  --border-light:#333333;
  --success:#22c55e;
  --error:#ef4444;
  --warning:#f59e0b;
  --radius:8px;
  --radius-lg:12px;
  --radius-xl:16px;
  --shadow:0 4px 24px rgba(0,0,0,0.4);
  --transition:0.2s ease;
}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,sans-serif;
  background:var(--bg-primary);
  color:var(--text-primary);
  line-height:1.6;
  min-height:100vh;
}
a{color:var(--text-primary);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--accent)}
img{max-width:100%;height:auto}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);border:2px solid transparent;font-family:inherit}
.btn-primary{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#0a0a0a}
.btn-outline{background:transparent;color:var(--text-primary);border-color:var(--border-light)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-sm{padding:6px 16px;font-size:13px}
.btn-lg{padding:14px 36px;font-size:16px}
.btn-block{width:100%;justify-content:center}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(10,10,10,0.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 20px}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:700;color:var(--text-primary)}
.logo span{color:var(--accent)}
.main-nav{display:flex;align-items:center;gap:12px}
.nav-link{display:flex;align-items:center;padding:8px;color:var(--text-secondary);border-radius:var(--radius)}
.nav-link:hover{color:var(--accent);background:var(--accent-light)}
.mobile-menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.mobile-menu{display:none;position:absolute;top:64px;left:0;right:0;background:var(--bg-card);border-bottom:1px solid var(--border);padding:12px}
.mobile-menu a{display:block;padding:12px 20px;color:var(--text-secondary);border-radius:var(--radius)}
.mobile-menu a:hover{color:var(--accent);background:var(--accent-light)}

/* Hero */
.hero{position:relative;overflow:hidden;padding:140px 0 80px;text-align:center;min-height:80vh;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero-bg svg{position:absolute;width:600px;height:600px;opacity:0.15}
.hero-bg .ripple-1{top:-100px;left:-100px;animation:float 20s ease-in-out infinite}
.hero-bg .ripple-2{bottom:-100px;right:-100px;animation:float 25s ease-in-out infinite reverse}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-30px)}}
.hero-content{position:relative;z-index:1;max-width:800px;margin:0 auto}
.hero h1{font-size:clamp(36px,6vw,64px);font-weight:800;line-height:1.1;margin-bottom:24px;background:linear-gradient(135deg,#fff 60%,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-features{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:40px}
.hero-features li{display:flex;align-items:center;gap:10px;font-size:16px;color:var(--text-secondary)}
.hero-features li::before{content:'';width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0}
.hero-cta{gap:16px;display:flex;justify-content:center;flex-wrap:wrap}
.hero-preview{margin-top:60px;position:relative}
.hero-preview img{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow)}
.preview-mobile{position:absolute;bottom:-40px;right:-40px;width:240px}

/* Sections */
.section{padding:80px 0}
.section-title{font-size:clamp(28px,4vw,40px);font-weight:700;text-align:center;margin-bottom:16px}
.section-subtitle{text-align:center;color:var(--text-secondary);font-size:16px;max-width:600px;margin:0 auto 48px;line-height:1.7}
.section-bg{position:relative}
.section-bg::before{content:'';position:absolute;inset:0;background:var(--bg-secondary);pointer-events:none;z-index:-1}

/* Steps */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;margin-top:48px}
.step-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;text-align:center;transition:all var(--transition)}
.step-card:hover{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light),0 8px 32px rgba(255,215,0,0.08)}
.step-number{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#0a0a0a;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;margin:0 auto 20px}
.step-card h3{font-size:20px;font-weight:600;margin-bottom:12px}
.step-card p{color:var(--text-secondary);font-size:14px;line-height:1.7}

/* Features Grid */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:24px}
.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;transition:all var(--transition)}
.feature-card:hover{border-color:var(--accent);background:var(--bg-card-hover)}
.feature-icon{width:48px;height:48px;border-radius:var(--radius);background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--accent)}
.feature-card h3{font-size:18px;font-weight:600;margin-bottom:8px}
.feature-card p{color:var(--text-secondary);font-size:14px;line-height:1.7}

/* QR Types */
.qr-types-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:16px;margin-top:48px}
.qr-type-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 12px;text-align:center;transition:all var(--transition);cursor:pointer}
.qr-type-item:hover{border-color:var(--accent);background:var(--bg-card-hover)}
.qr-type-item span{display:block;font-size:12px;color:var(--text-secondary);margin-top:8px}

/* FAQ */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:none;border:none;color:var(--text-primary);font-size:15px;font-weight:500;cursor:pointer;text-align:left;font-family:inherit;transition:background var(--transition)}
.faq-question:hover{background:var(--bg-card)}
.faq-question svg{transition:transform var(--transition);flex-shrink:0}
.faq-item.active .faq-question svg{transform:rotate(180deg)}
.faq-answer{padding:0 20px;max-height:0;overflow:hidden;transition:all var(--transition)}
.faq-item.active .faq-answer{max-height:300px;padding:0 20px 20px}
.faq-answer p{color:var(--text-secondary);font-size:14px;line-height:1.7}

/* Auth Forms */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:100px 20px 60px}
.auth-container{width:100%;max-width:420px}
.auth-header{text-align:center;margin-bottom:32px}
.auth-header .logo{margin-bottom:16px;display:inline-flex}
.auth-header h1{font-size:24px;font-weight:700;margin-bottom:8px}
.auth-header p{color:var(--text-secondary);font-size:14px}
.auth-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:8px}
.form-group .input-icon{position:relative}
.form-group .input-icon svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);width:18px;height:18px}
.form-group .input-icon input{padding-left:44px}
.form-input{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:14px;font-family:inherit;transition:border-color var(--transition)}
.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}
.form-input::placeholder{color:var(--text-muted)}
.form-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.form-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}
.form-checkbox input{accent-color:var(--accent)}
.form-link{font-size:13px;color:var(--accent)}
.form-link:hover{text-decoration:underline}
.auth-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-muted);font-size:13px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-footer{text-align:center;margin-top:24px;font-size:14px;color:var(--text-secondary)}
.auth-footer a{color:var(--accent);font-weight:600}

/* Responsive grid helpers */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:640px){.grid-2{grid-template-columns:1fr}}

/* Alert Messages */
.alert{padding:14px 16px;border-radius:var(--radius);font-size:14px;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.alert-success{background:rgba(34,197,94,0.1);border:1px solid rgba(34,197,94,0.3);color:var(--success)}
.alert-error{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);color:var(--error)}

/* Plans Page */
.plans-page{padding:120px 20px 60px}
.plans-toggle{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:40px}
.plans-toggle span{font-size:15px;font-weight:500;color:var(--text-secondary)}
.plans-toggle .toggle-badge{background:var(--accent);color:#0a0a0a;font-size:11px;font-weight:700;padding:2px 10px;border-radius:20px}
.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;max-width:1000px;margin:0 auto}
.plan-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;position:relative;transition:all var(--transition)}
.plan-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.plan-card.popular{border-color:var(--accent);border-width:2px}
.plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#0a0a0a;font-size:12px;font-weight:700;padding:4px 16px;border-radius:20px;white-space:nowrap}
.plan-name{font-size:20px;font-weight:600;margin-bottom:8px}
.plan-price{font-size:36px;font-weight:800;margin-bottom:4px}
.plan-price span{font-size:14px;font-weight:400;color:var(--text-muted)}
.plan-period{font-size:13px;color:var(--text-muted);margin-bottom:24px}
.plan-savings{font-size:12px;color:var(--accent);font-weight:600;margin-bottom:16px}
.plan-original{text-decoration:line-through;color:var(--text-muted);font-size:18px;font-weight:400}
.plan-features{list-style:none;margin:24px 0;display:flex;flex-direction:column;gap:12px}
.plan-features li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-secondary)}
.plan-features li::before{content:'✓';color:var(--accent);font-weight:700;font-size:16px}

/* Contact */
.contact-page{padding:120px 20px 60px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;max-width:900px;margin:0 auto;align-items:start}
.contact-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px}
.contact-form h2{font-size:20px;font-weight:600;margin-bottom:8px}
.contact-form>p{color:var(--text-secondary);font-size:14px;margin-bottom:24px}
.form-select{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:14px;font-family:inherit;appearance:none;cursor:pointer}
.form-select:focus{outline:none;border-color:var(--accent)}
.form-textarea{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:14px;font-family:inherit;min-height:140px;resize:vertical}
.form-textarea:focus{outline:none;border-color:var(--accent)}
.contact-info{padding:32px}
.contact-info h2{font-size:20px;font-weight:600;margin-bottom:16px}
.contact-info p{color:var(--text-secondary);font-size:14px;line-height:1.7;margin-bottom:24px}

/* Footer */
.site-footer{background:var(--bg-secondary);border-top:1px solid var(--border);padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
.footer-brand .footer-logo{display:inline-block;margin-bottom:16px}
.footer-tagline{color:var(--text-secondary);font-size:14px;line-height:1.6;max-width:240px}
.footer-col h4{font-size:14px;font-weight:600;margin-bottom:16px;color:var(--text-primary)}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{color:var(--text-secondary);font-size:13px;transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid var(--border);margin-top:48px;padding:20px 0;text-align:center}
.footer-bottom p{color:var(--text-muted);font-size:12px}
.footer-bottom .trademark{font-size:11px;margin-top:4px}

/* Dashboard Layout */
.dashboard-layout{display:flex;min-height:100vh}
.sidebar{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border);position:fixed;top:0;left:0;bottom:0;z-index:50;display:flex;flex-direction:column;overflow-y:auto}
.sidebar-header{padding:16px 20px;border-bottom:1px solid var(--border)}
.sidebar-logo{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700}
.sidebar-logo span{color:var(--accent)}
.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px}
.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius);color:var(--text-secondary);font-size:14px;font-weight:500;transition:all var(--transition)}
.sidebar-link:hover{background:var(--accent-light);color:var(--accent)}
.sidebar-link.active{background:var(--accent-light);color:var(--accent);font-weight:600;border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;margin-left:-8px;padding-left:19px}
.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border)}
.dashboard-main{flex:1;margin-left:260px;min-height:100vh;display:flex;flex-direction:column}
.dashboard-topbar{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:40}
.sidebar-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:none}
.topbar-right{display:flex;align-items:center;gap:16px}
.topbar-user{font-size:14px;font-weight:500;color:var(--text-secondary)}
.dashboard-content{padding:24px;flex:1}
.dashboard-content h1{font-size:24px;font-weight:700;margin-bottom:4px}
.dashboard-content .page-desc{color:var(--text-secondary);font-size:14px;margin-bottom:24px}
.dashboard-content .page-desc:last-child{margin-bottom:0}

/* Quick action grid + two-col grid for dashboard */
.dashboard-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
@media(max-width:480px){.dashboard-grid-2{grid-template-columns:1fr}}
@media(max-width:380px){.dashboard-grid-2{grid-template-columns:1fr}}

/* Dashboard Cards */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition)}
.stat-card:hover{border-color:var(--accent)}
.stat-card .stat-icon{width:40px;height:40px;border-radius:var(--radius);background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:12px}
.stat-card .stat-value{font-size:28px;font-weight:700}
.stat-card .stat-label{font-size:13px;color:var(--text-secondary);margin-top:4px}

/* Table */
.table-container{overflow-x:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:0}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:12px 16px;text-align:left;font-size:14px;border-bottom:1px solid var(--border);white-space:nowrap}
.table th{font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:0.5px;background:var(--bg-secondary)}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:var(--bg-card-hover)}
.table .badge{background:var(--accent-light);color:var(--accent);font-size:11px;font-weight:600;padding:2px 10px;border-radius:20px}
.table .badge-success{background:rgba(34,197,94,0.1);color:var(--success)}
.table .badge-error{background:rgba(239,68,68,0.1);color:var(--error)}
.table-actions{display:flex;gap:6px}
.btn-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius);background:transparent;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}
.btn-icon:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}
.btn-icon.danger:hover{background:rgba(239,68,68,0.1);border-color:var(--error);color:var(--error)}

/* Create QR v2 */
.create-layout{display:grid;grid-template-columns:260px 1fr 280px;gap:20px;align-items:start}
.create-types-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;max-height:calc(100vh - 160px);overflow-y:auto;position:sticky;top:100px}
.create-types-sidebar h3{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:0.5px}
.create-types-list{display:flex;flex-direction:column;gap:2px}
.create-type-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;background:none;border:none;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);text-align:left;width:100%;font-family:inherit}
.create-type-btn:hover{background:var(--bg-input);color:var(--text-primary)}
.create-type-btn.active{background:var(--accent-light);color:var(--accent)}
.create-type-btn svg{flex-shrink:0;width:20px;height:20px}
.create-type-btn div{min-width:0}
.create-type-btn strong{display:block;font-size:13px;font-weight:500}
.create-type-btn span{display:block;font-size:11px;color:var(--text-muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.create-type-btn.active span{color:var(--accent);opacity:0.7}
.create-center{min-width:0}
.create-form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.create-form-fields{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}
.qr-preview-box{display:flex;flex-direction:column;align-items:center;gap:16px;padding-top:20px;border-top:1px solid var(--border)}
.qr-preview-white{background:#fff;border-radius:var(--radius);padding:16px;display:flex;align-items:center;justify-content:center;width:100%;max-width:280px}
.qr-preview-white img{width:100%;height:auto;image-rendering:pixelated}
.qr-customize{width:100%;max-width:280px}
.qr-customize .color-inputs{display:flex;gap:12px}
.qr-customize .color-input-group{flex:1;display:flex;flex-direction:column;gap:4px}
.qr-customize .color-input-group label{font-size:12px;color:var(--text-muted)}
.qr-customize .color-input-group input[type=color]{width:100%;height:40px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);cursor:pointer;padding:2px}
.create-phone-preview{display:flex;flex-direction:column;align-items:center;gap:12px}
.phone-mockup{width:260px;background:#1a1a1a;border:3px solid #333;border-radius:32px;padding:10px;position:relative;box-shadow:0 8px 32px rgba(0,0,0,0.5)}
.phone-notch{width:120px;height:6px;background:#000;border-radius:3px;margin:0 auto 8px}
.phone-screen{background:#0a0a0a;border-radius:20px;overflow:hidden;min-height:400px;max-height:500px;overflow-y:auto}
.phone-header{background:#111;padding:12px 16px;border-bottom:1px solid #222}
.phone-header-bar{height:6px;width:60px;background:#333;border-radius:3px;margin:0 auto}
.phone-body{padding:0;color:#fff;font-size:13px;min-height:320px}
.phone-home-btn{width:36px;height:36px;border:2px solid #333;border-radius:50%;margin:8px auto 0;display:flex;align-items:center;justify-content:center}
.phone-hint{font-size:11px;color:var(--text-muted);text-align:center;max-width:240px;line-height:1.5}
.color-inputs{display:flex;gap:12px}

/* Billing */
.billing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:16px}
.billing-card h3{font-size:18px;font-weight:600;margin-bottom:4px}
.billing-card .plan-name{color:var(--accent);font-size:14px;font-weight:500;margin-bottom:16px}
.billing-card .price{font-size:32px;font-weight:700}
.billing-card .price span{font-size:14px;color:var(--text-muted);font-weight:400}
.billing-actions{display:flex;gap:12px;margin-top:16px}

/* Analytics */
.analytics-chart{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}
.analytics-chart h3{font-size:16px;font-weight:600;margin-bottom:16px}
.chart-placeholder{width:100%;height:300px;background:var(--bg-input);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}
.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}
.analytics-filters{display:flex;gap:16px;flex-wrap:wrap;align-items:end;margin-bottom:24px}
.analytics-filters .filter-group{display:flex;flex-direction:column;gap:4px}
.analytics-filters .filter-group label{font-size:12px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:0.3px}
.analytics-filters .filter-group input,.analytics-filters .filter-group select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);padding:10px 14px;font-size:13px;font-family:inherit;min-width:160px}
.analytics-filters .filter-group input:focus,.analytics-filters .filter-group select:focus{outline:none;border-color:var(--accent)}
.analytics-filters .btn{padding:10px 20px;align-self:end;height:fit-content}
.analytics-date-display{font-size:13px;color:var(--text-muted);margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.analytics-breakdowns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;margin-bottom:24px}
@media(max-width:900px){.analytics-breakdowns{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.analytics-breakdowns{grid-template-columns:1fr}}
.breakdown-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}
.breakdown-card h3{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:16px;text-transform:uppercase;letter-spacing:0.3px}
.breakdown-list{display:flex;flex-direction:column;gap:10px}
.breakdown-item{display:flex;align-items:center;gap:10px}
.breakdown-item .bdi-label{font-size:13px;color:var(--text-primary);min-width:80px;flex-shrink:0}
.breakdown-item .bdi-bar-wrap{flex:1;height:6px;background:var(--bg-input);border-radius:3px;overflow:hidden;min-width:40px}
.breakdown-item .bdi-bar{height:100%;border-radius:3px;background:var(--accent);transition:width 0.3s ease}
.breakdown-item .bdi-bar.bdi-android{background:#3DDC84}
.breakdown-item .bdi-bar.bdi-ios{background:#999}
.breakdown-item .bdi-bar.bdi-windows{background:#00ADEF}
.breakdown-item .bdi-bar.bdi-macos,.breakdown-item .bdi-bar.bdi-osx{background:#999}
.breakdown-item .bdi-bar.bdi-linux{background:#FCC624}
.breakdown-item .bdi-bar.bdi-ubuntu{background:#E95420}
.breakdown-item .bdi-pct{font-size:12px;font-weight:600;color:var(--text-secondary);min-width:42px;text-align:right;flex-shrink:0}
.breakdown-item .bdi-count{font-size:11px;color:var(--text-muted);min-width:60px;text-align:right;flex-shrink:0}
.analytics-note{font-size:12px;color:var(--text-muted);text-align:center;padding:16px;border-top:1px solid var(--border);margin-top:-8px;margin-bottom:24px;line-height:1.5}
.stat-card .stat-tip{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--bg-input);color:var(--text-muted);font-size:10px;cursor:help;margin-left:6px;border:1px solid var(--border);vertical-align:middle;position:relative}
.stat-card .stat-tip:hover .stat-tip-text{display:block}
.stat-card .stat-tip-text{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;font-size:12px;color:var(--text-secondary);width:260px;text-align:center;font-weight:400;z-index:10;line-height:1.5;white-space:normal;box-shadow:var(--shadow)}
.stat-card .stat-tip-text::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--border)}
.chart-bars{display:flex;align-items:end;gap:4px;height:200px;padding-top:20px}
.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:end}
.chart-bar-group .cb-scans{width:100%;max-width:28px;border-radius:3px 3px 0 0;transition:height 0.3s ease}
.chart-bar-group .cb-unique{width:100%;max-width:28px;border-radius:3px 3px 0 0;transition:height 0.3s ease}
.chart-bar-group .cb-label{font-size:10px;color:var(--text-muted);text-align:center;white-space:nowrap;padding-top:4px}
.chart-legend{display:flex;gap:20px;margin-top:16px;justify-content:center;font-size:12px;color:var(--text-secondary)}
.chart-legend span{display:flex;align-items:center;gap:6px}
.chart-legend .cl-dot{width:10px;height:10px;border-radius:2px;display:inline-block}

/* vCard Preview */
.vcard-preview{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;max-width:400px;margin:0 auto;text-align:center}
.vcard-avatar{width:80px;height:80px;border-radius:50%;background:var(--bg-input);margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:32px;color:var(--accent);overflow:hidden}
.vcard-avatar img{width:100%;height:100%;object-fit:cover}
.vcard-name{font-size:20px;font-weight:700}
.vcard-title{color:var(--accent);font-size:14px;margin-bottom:4px}
.vcard-bio{color:var(--text-secondary);font-size:13px;margin-bottom:20px;line-height:1.6}
.vcard-field{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.vcard-field:last-child{border-bottom:none}
.vcard-field .field-icon{color:var(--accent);width:18px;height:18px}
.vcard-field .field-label{color:var(--text-muted);min-width:80px}
.vcard-social{display:flex;gap:12px;justify-content:center;margin-top:16px}
.vcard-social a{width:36px;height:36px;border-radius:var(--radius);background:var(--bg-input);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.vcard-social a:hover{border-color:var(--accent);background:var(--accent-light)}

/* CTA Section */
.cta-section{padding:80px 0;text-align:center}
.cta-section h2{font-size:clamp(24px,4vw,36px);font-weight:700;margin-bottom:16px}
.cta-section p{color:var(--text-secondary);font-size:16px;margin-bottom:32px}

/* Legal Pages */
.legal-page{padding:120px 20px 60px;max-width:800px;margin:0 auto}
.legal-page h1{font-size:32px;font-weight:700;margin-bottom:24px}
.legal-page h2{font-size:20px;font-weight:600;margin-top:32px;margin-bottom:12px}
.legal-page h3{font-size:16px;font-weight:600;margin-top:24px;margin-bottom:8px}
.legal-page p{color:var(--text-secondary);font-size:14px;line-height:1.8;margin-bottom:12px}
.legal-page ul{color:var(--text-secondary);font-size:14px;line-height:1.8;padding-left:20px;margin-bottom:12px}

/* Cancel Page */
.cancel-page{padding:120px 20px 60px;max-width:600px;margin:0 auto;text-align:center}
.cancel-page h1{font-size:28px;font-weight:700;margin-bottom:16px}
.cancel-page p{color:var(--text-secondary);font-size:14px;margin-bottom:24px;line-height:1.7}
.cancel-steps{text-align:left;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}
.cancel-steps ol{padding-left:20px;color:var(--text-secondary);font-size:14px;line-height:2}

/* ====== SIDEBAR BACKDROP ====== */
.sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:99;opacity:0;visibility:hidden;transition:all 0.3s ease}
.sidebar-backdrop.show{opacity:1;visibility:visible}

/* ====== RESPONSIVE ====== */
@media(max-width:1100px){
  .create-layout{grid-template-columns:240px 1fr}
  .create-center{min-width:0}
  .create-phone-preview{grid-column:1/-1;justify-self:center;margin-top:12px}
}

@media(max-width:1024px){
  .sidebar{width:240px}
  .dashboard-main{margin-left:240px}
  .stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
  .qr-types-grid{grid-template-columns:repeat(auto-fit,minmax(90px,1fr))}
}

@media(max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .analytics-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
}

@media(max-width:768px){
  /* Header */
  .main-nav .btn-outline,.main-nav .btn-primary{display:none}
  .mobile-menu-toggle{display:block}
  .mobile-menu.open{display:block}

  /* Hero */
  .hero{padding:100px 0 60px;min-height:auto}
  .hero h1{font-size:clamp(28px,7vw,36px)}
  .hero-features li{font-size:14px}
  .preview-mobile{display:none}
  .hero-cta{flex-direction:column;align-items:center}
  .hero-cta .btn{width:100%;max-width:300px;justify-content:center}

  /* Dashboard sidebar */
  .sidebar{transform:translateX(-100%);transition:transform 0.3s ease;z-index:100}
  .sidebar.open{transform:translateX(0)}
  .dashboard-main{margin-left:0}
  .sidebar-toggle{display:block}

  /* Plans */
  .plans-grid{grid-template-columns:1fr;max-width:400px}
  .plans-toggle{flex-wrap:wrap;gap:12px}
  .plans-toggle span{font-size:13px}

  /* Create QR */
  .create-layout{grid-template-columns:1fr}
  .create-types-sidebar{position:static;max-height:none;overflow-y:visible;padding:0;background:none;border:none;border-radius:0}
  .create-phone-preview{margin-top:20px}
  .create-types-sidebar h3{display:block;font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;padding:8px 0 4px;margin:0}
  .create-types-list{display:grid !important;grid-template-columns:repeat(4,1fr);gap:6px;padding:0}
  .create-type-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 6px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);cursor:pointer;transition:all .2s;text-align:center;width:auto;min-width:0}
  .create-type-btn:active{transform:scale(0.96)}
  .create-type-btn.active{border-color:var(--accent);background:var(--accent-light)}
  .create-type-btn span{display:none}
  .create-type-btn svg{width:22px;height:22px;flex-shrink:0;pointer-events:none}
  .create-type-btn strong{font-size:10px;font-weight:600;line-height:1.2;display:block}
  .create-form-card{padding:16px}

  /* Contact */
  .contact-grid{grid-template-columns:1fr}

  /* Auth */
  .auth-page{padding:80px 16px 40px}

  /* Tables - card mode on mobile */
  .table thead{display:none}
  .table tr{display:block;padding:12px 16px;border-bottom:1px solid var(--border)}
  .table td{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border:none;white-space:normal;gap:8px}
  .table td::before{content:attr(data-label);font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:0.3px;flex-shrink:0}
  .table td:last-child{border-bottom:none}
  .table .badge{white-space:nowrap}
  .table-actions{justify-content:flex-end}

  /* Stats */
  .stats-grid{margin-bottom:24px}

  /* Footer */
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}

  /* Billing */
  .billing-actions{flex-direction:column}
  .billing-actions .btn{width:100%;justify-content:center}

  /* Step cards */
  .steps-grid{gap:20px}

  /* QR types grid */
  .qr-types-grid{grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:10px}

  /* Contact */
  .contact-info{padding:24px 0}
}

@media(max-width:480px){
  .container{padding:0 16px}
  .hero{padding:80px 0 40px;min-height:auto}
  .hero h1{font-size:26px}
  .section{padding:40px 0}
  .section-title{font-size:22px;margin-bottom:12px}
  .section-subtitle{font-size:14px;margin-bottom:32px}
  .dashboard-content{padding:16px}
  .dashboard-content h1{font-size:20px}
  .dashboard-topbar{padding:10px 16px}
  
  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:20px}
  .site-footer{padding:40px 0 0}
  .footer-bottom{margin-top:32px}
  
  /* Stats */
  .stats-grid{grid-template-columns:1fr 1fr;gap:10px}
  .stat-card{padding:16px}
  .stat-card .stat-value{font-size:22px}
  
  /* Plans */
  .plans-page{padding:100px 16px 40px}
  .plan-card{padding:24px}
  .plan-price{font-size:28px}
  
  /* Create QR */
  .create-types-list{grid-template-columns:repeat(4,1fr);gap:5px}
  .create-type-btn{padding:8px 4px;gap:3px}
  .create-type-btn strong{font-size:10px}
  .create-type-btn svg{width:20px;height:20px}
  .qr-preview-white{padding:12px;max-width:220px}
  .qr-preview-white img{width:100%;height:auto}

  /* Auth */
  .auth-box{padding:24px}
  .auth-header h1{font-size:20px}
  
  /* Steps & Features */
  .step-card{padding:24px}
  .feature-card{padding:24px}
  .features-grid{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr}
  
  /* Contact */
  .contact-page{padding:100px 16px 40px}
  .contact-form{padding:24px}
  
  /* Legal */
  .legal-page{padding:100px 16px 40px}
  .legal-page h1{font-size:24px}
  
  /* Cancel */
  .cancel-page{padding:100px 16px 40px}
  
  /* Billing */
  .billing-card{padding:16px}
  .billing-card .price{font-size:24px}
  
  /* Tables on very small screens */
  .table td::before{font-size:10px}
  
  /* QR type selector buttons in create page - more compact */
  .create-types-list{grid-template-columns:repeat(3,1fr);gap:4px}
  .create-type-btn{padding:6px 4px;gap:2px}
  .create-type-btn strong{font-size:9px;line-height:1.2}
  .create-type-btn svg{width:18px;height:18px}

  /* Phone mockup override if visible */
  .phone-mockup{width:200px;border-width:2px;border-radius:24px;padding:8px}
  .phone-screen{min-height:300px}
  .phone-body{min-height:240px}
  .phone-hint{font-size:10px}
}

@media(max-width:380px){
  .stats-grid{grid-template-columns:1fr}
  .header-inner{height:56px}
  .logo{font-size:16px}
  .logo svg{width:26px;height:26px}
  .hero h1{font-size:22px}
  .hero{padding:72px 0 32px}
  .section-title{font-size:20px}
  .hero-features li{font-size:13px}
  .plans-toggle span{font-size:12px}
  .dashboard-content h1{font-size:18px}
  .create-form-card{padding:12px}
  .qr-preview-white{max-width:180px;padding:8px}
}

/* Table data-label support on desktop too for consistency */
@media(min-width:769px){
  .table td[data-label]::before{display:none}
}
