/* ═══════════════════════════════════════════════════════
   SHOPIFY DZ — App-Specific Styles
   Auth, Modals, Toasts, Settings, Pipeline
   ═══════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════════
   AUTH SCREEN — HYPER FUTURISTIC / CYBERPUNK / NEON GLASSMORPHISM
   ══════════════════════════════════════════════════════════════ */
.auth-screen { position:fixed; inset:0; z-index:1000; overflow:hidden; }
.auth-screen.hidden { display:none; }

/* ── BACKGROUND: Deep space + cyber grid + pulsing orbs ── */
.auth-bg {
    position:absolute; inset:0; z-index:0;
    background:radial-gradient(ellipse at 20% 50%, #0c0c2a 0%, #060612 40%, #000008 100%);
}
.auth-grid-overlay {
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(99,102,241,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(99,102,241,0.06) 1px, transparent 1px);
    background-size:40px 40px;
    animation:authGridDrift 20s linear infinite;
}
@keyframes authGridDrift {
    to { background-position:40px 40px; }
}
/* Scanline overlay */
.auth-bg::after {
    content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
    background:repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,0,0,0.03) 2px, rgba(0,0,0,0.03) 4px);
}

/* Orbs — neon pulsing */
.auth-orb {
    position:absolute; border-radius:50%; filter:blur(100px); pointer-events:none;
    animation:authOrbPulse 8s ease-in-out infinite alternate;
}
.auth-orb-1 {
    width:500px; height:500px; top:-150px; left:-150px;
    background:radial-gradient(circle, rgba(99,102,241,0.5) 0%, rgba(99,102,241,0) 70%);
}
.auth-orb-2 {
    width:450px; height:450px; bottom:-120px; right:-120px;
    background:radial-gradient(circle, rgba(139,92,246,0.45) 0%, rgba(139,92,246,0) 70%);
    animation-delay:-3s;
}
.auth-orb-3 {
    width:300px; height:300px; top:40%; left:45%;
    background:radial-gradient(circle, rgba(6,182,212,0.35) 0%, rgba(6,182,212,0) 70%);
    animation-delay:-6s;
}
@keyframes authOrbPulse {
    0%   { transform:translate(0,0) scale(1); opacity:0.5; }
    50%  { transform:translate(40px,-30px) scale(1.15); opacity:0.7; }
    100% { transform:translate(-20px,40px) scale(0.9); opacity:0.4; }
}

/* ── LAYOUT ── */
.auth-split { position:relative; z-index:2; display:flex; height:100vh; }

/* ━━━━━ LEFT BRAND PANEL ━━━━━ */
.auth-brand-panel {
    flex:0 0 44%; display:flex; align-items:center; justify-content:center;
    position:relative; overflow:hidden;
    background:linear-gradient(160deg, rgba(99,102,241,0.06) 0%, rgba(139,92,246,0.03) 100%);
    border-right:1px solid rgba(99,102,241,0.08);
}
/* Holographic shimmer */
.auth-brand-panel::before {
    content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
    background:linear-gradient(135deg, transparent 30%, rgba(99,102,241,0.04) 50%, transparent 70%);
    animation:authHoloShimmer 6s ease-in-out infinite;
}
@keyframes authHoloShimmer {
    0%,100% { opacity:0; transform:translateX(-100%); }
    50% { opacity:1; transform:translateX(100%); }
}
/* Vertical neon line */
.auth-brand-panel::after {
    content:''; position:absolute; right:0; top:10%; bottom:10%; width:1px;
    background:linear-gradient(180deg, transparent, rgba(99,102,241,0.5), rgba(139,92,246,0.3), transparent);
    box-shadow:0 0 8px rgba(99,102,241,0.3);
}

.auth-brand-content { position:relative; z-index:1; text-align:center; padding:48px 40px; }

/* Logo — orbital system */
.auth-brand-logo {
    position:relative; width:120px; height:120px; margin:0 auto 28px;
}
.auth-logo-ring {
    position:absolute; border:2px solid rgba(99,102,241,0.25); border-radius:50%;
    animation:authRingSpin 10s linear infinite;
    border-top-color:rgba(99,102,241,0.6);
}
.auth-logo-ring:not(.r2) { inset:-12px; }
.auth-logo-ring.r2 {
    inset:-24px; border-color:rgba(139,92,246,0.1);
    border-top-color:rgba(139,92,246,0.35);
    animation-duration:14s; animation-direction:reverse;
}
.auth-logo-core {
    width:120px; height:120px; border-radius:50%;
    background:linear-gradient(135deg, rgba(99,102,241,0.15), rgba(139,92,246,0.08));
    backdrop-filter:blur(12px);
    display:flex; align-items:center; justify-content:center;
    font-size:2.6rem; color:#818cf8;
    border:1px solid rgba(99,102,241,0.2);
    box-shadow:
        0 0 30px rgba(99,102,241,0.15),
        inset 0 0 30px rgba(99,102,241,0.05);
}
@keyframes authRingSpin { to { transform:rotate(360deg); } }

/* Title */
.auth-brand-title {
    font-size:2.8rem; font-weight:900; letter-spacing:-1px; margin-bottom:8px;
    text-shadow:0 0 40px rgba(99,102,241,0.2);
}
.auth-brand-title span {
    background:linear-gradient(135deg, #818cf8, #a78bfa, #06b6d4);
    -webkit-background-clip:text; background-clip:text;
    -webkit-text-fill-color:transparent; color:transparent;
}
.auth-brand-tagline {
    color:rgba(255,255,255,0.45); font-size:1rem; margin-bottom:36px;
    letter-spacing:0.5px;
}

/* Stats */
.auth-brand-stats {
    display:flex; align-items:center; justify-content:center; gap:24px;
    margin-bottom:36px;
    padding:20px 24px; border-radius:16px;
    background:rgba(255,255,255,0.02);
    border:1px solid rgba(255,255,255,0.04);
    backdrop-filter:blur(8px);
}
.auth-stat { text-align:center; }
.auth-stat-num {
    display:block; font-size:1.8rem; font-weight:900;
    background:linear-gradient(135deg, #818cf8, #06b6d4);
    -webkit-background-clip:text; background-clip:text;
    -webkit-text-fill-color:transparent; color:transparent;
}
.auth-stat-label {
    font-size:0.65rem; color:rgba(255,255,255,0.35);
    text-transform:uppercase; letter-spacing:1.5px; margin-top:2px;
}
.auth-stat-divider { width:1px; height:40px; background:linear-gradient(180deg, transparent, rgba(99,102,241,0.3), transparent); }

/* Features */
.auth-brand-features { display:flex; flex-direction:column; gap:14px; align-items:center; }
.auth-feature {
    display:flex; align-items:center; gap:12px;
    font-size:0.88rem; color:rgba(255,255,255,0.5);
    padding:8px 20px; border-radius:10px;
    background:rgba(255,255,255,0.015);
    border:1px solid rgba(255,255,255,0.03);
    transition:all 0.3s;
}
.auth-feature:hover {
    border-color:rgba(99,102,241,0.15);
    background:rgba(99,102,241,0.04);
    color:rgba(255,255,255,0.7);
}
.auth-feature i { color:#818cf8; width:20px; text-align:center; font-size:0.9rem; }

/* ━━━━━ RIGHT FORM PANEL ━━━━━ */
.auth-form-panel {
    flex:1; display:flex; align-items:center; justify-content:center;
    padding:40px; position:relative;
}
.auth-form-container {
    width:100%; max-width:440px;
    padding:36px;
    border-radius:20px;
    background:rgba(255,255,255,0.025);
    border:1px solid rgba(255,255,255,0.06);
    backdrop-filter:blur(20px);
    box-shadow:
        0 20px 60px rgba(0,0,0,0.3),
        0 0 80px rgba(99,102,241,0.04),
        inset 0 1px 0 rgba(255,255,255,0.04);
    position:relative; overflow:hidden;
}
/* Animated border glow */
.auth-form-container::before {
    content:''; position:absolute; inset:-1px; border-radius:21px; padding:1px;
    background:conic-gradient(from 0deg, transparent, rgba(99,102,241,0.3), transparent, rgba(139,92,246,0.2), transparent);
    -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor; mask-composite:exclude;
    animation:authBorderSpin 8s linear infinite;
    pointer-events:none;
}
@keyframes authBorderSpin { to { filter:hue-rotate(360deg); } }

/* Form header */
.auth-form-header { margin-bottom:28px; }
.auth-form-header h2 {
    font-size:1.7rem; font-weight:800; margin-bottom:6px;
    text-shadow:0 0 20px rgba(99,102,241,0.1);
}
.auth-form-header p { font-size:0.88rem; color:rgba(255,255,255,0.4); }
.auth-wave { display:inline-block; animation:authWave 1.5s ease-in-out infinite; transform-origin:70% 70%; }
.auth-rocket { display:inline-block; animation:authRocket 2s ease-in-out infinite; }
@keyframes authWave { 0%,100%{transform:rotate(0)} 25%{transform:rotate(20deg)} 75%{transform:rotate(-10deg)} }
@keyframes authRocket { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)} }

/* ── INPUTS — Neon glass with visible placeholders ── */
.auth-input-wrap {
    position:relative; margin-bottom:18px;
}
.auth-input-icon {
    position:absolute; left:16px; top:50%; transform:translateY(-50%);
    color:rgba(255,255,255,0.25); font-size:0.88rem; z-index:2;
    transition:all 0.3s;
}
.auth-input {
    width:100%; padding:15px 16px 15px 46px;
    background:rgba(255,255,255,0.03);
    border:1px solid rgba(255,255,255,0.07);
    border-radius:14px;
    color:#e2e8f0;
    font-size:0.92rem;
    font-family:var(--font-primary);
    outline:none;
    transition:all 0.3s cubic-bezier(0.4,0,0.2,1);
    box-sizing:border-box;
}
/* FIX: Placeholders now VISIBLE */
.auth-input::placeholder {
    color:rgba(255,255,255,0.2);
    font-size:0.88rem;
}
.auth-input:hover {
    border-color:rgba(99,102,241,0.2);
    background:rgba(99,102,241,0.02);
}
.auth-input:focus {
    border-color:rgba(99,102,241,0.5);
    background:rgba(99,102,241,0.04);
    box-shadow:
        0 0 0 3px rgba(99,102,241,0.1),
        0 0 20px rgba(99,102,241,0.08),
        inset 0 0 12px rgba(99,102,241,0.03);
}
.auth-input:focus ~ .auth-input-icon { color:#818cf8; }
.auth-input-label { display:none; }
.auth-eye {
    position:absolute; right:14px; top:50%; transform:translateY(-50%);
    background:none; border:none;
    color:rgba(255,255,255,0.25); cursor:pointer; padding:6px;
    font-size:0.88rem; transition:color 0.2s;
}
.auth-eye:hover { color:#818cf8; }

/* ── SUBMIT BUTTON — Glowing neon CTA ── */
.auth-submit-btn {
    position:relative; width:100%; padding:16px 28px;
    border:none; border-radius:14px;
    background:linear-gradient(135deg, #6366f1, #8b5cf6, #06b6d4);
    background-size:200% 200%;
    animation:authBtnGradient 4s ease infinite;
    color:#fff; font-size:0.98rem; font-weight:700;
    font-family:var(--font-primary); cursor:pointer;
    display:flex; align-items:center; justify-content:center; gap:10px;
    overflow:hidden; transition:all 0.3s;
    box-shadow:0 4px 20px rgba(99,102,241,0.25);
    text-shadow:0 1px 2px rgba(0,0,0,0.2);
}
@keyframes authBtnGradient {
    0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%}
}
.auth-submit-btn:hover {
    transform:translateY(-3px) scale(1.01);
    box-shadow:0 8px 32px rgba(99,102,241,0.4), 0 0 16px rgba(139,92,246,0.2);
}
.auth-submit-btn:active { transform:translateY(-1px) scale(0.99); }
.auth-btn-glow {
    position:absolute; width:120%; height:100%; top:0; left:-120%;
    background:linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    animation:authBtnGlow 3.5s ease-in-out infinite;
}
@keyframes authBtnGlow { 0%{left:-120%} 40%{left:120%} 100%{left:120%} }

.auth-back-btn {
    padding:16px 20px; border:1px solid rgba(255,255,255,0.06);
    border-radius:14px; background:rgba(255,255,255,0.02);
    color:rgba(255,255,255,0.45); font-size:0.88rem; font-weight:600;
    font-family:var(--font-primary); cursor:pointer;
    display:flex; align-items:center; gap:8px;
    transition:all 0.3s; backdrop-filter:blur(8px);
}
.auth-back-btn:hover {
    border-color:rgba(99,102,241,0.3); color:#818cf8;
    background:rgba(99,102,241,0.05);
    box-shadow:0 0 12px rgba(99,102,241,0.08);
}

/* ── DIVIDER ── */
.auth-divider { display:flex; align-items:center; gap:14px; margin:22px 0; }
.auth-divider::before,.auth-divider::after {
    content:''; flex:1; height:1px;
    background:linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
}
.auth-divider span { font-size:0.72rem; color:rgba(255,255,255,0.2); text-transform:uppercase; letter-spacing:2px; }

.auth-switch-text { text-align:center; font-size:0.88rem; color:rgba(255,255,255,0.35); }
.auth-switch-text a {
    color:#818cf8; font-weight:700; text-decoration:none;
    transition:all 0.3s; position:relative;
}
.auth-switch-text a::after {
    content:''; position:absolute; bottom:-2px; left:0; width:0; height:2px;
    background:linear-gradient(90deg, #6366f1, #06b6d4);
    transition:width 0.3s;
}
.auth-switch-text a:hover { color:#a78bfa; }
.auth-switch-text a:hover::after { width:100%; }

/* ── MULTI-STEP REGISTER ── */
.auth-steps { display:flex; align-items:center; gap:0; margin-bottom:28px; }
.auth-step { display:flex; align-items:center; gap:8px; flex:1; }
.auth-step-num {
    width:32px; height:32px; border-radius:50%;
    background:rgba(255,255,255,0.03);
    border:2px solid rgba(255,255,255,0.08);
    display:flex; align-items:center; justify-content:center;
    font-size:0.75rem; font-weight:800; color:rgba(255,255,255,0.3);
    transition:all 0.4s cubic-bezier(0.4,0,0.2,1);
}
.auth-step.active .auth-step-num {
    background:linear-gradient(135deg, #6366f1, #8b5cf6);
    border-color:transparent; color:#fff;
    box-shadow:0 0 20px rgba(99,102,241,0.4), 0 0 40px rgba(99,102,241,0.15);
}
.auth-step.done .auth-step-num {
    background:linear-gradient(135deg, #10b981, #06b6d4);
    border-color:transparent; color:#fff;
    box-shadow:0 0 16px rgba(16,185,129,0.3);
}
.auth-step-label {
    font-size:0.72rem; font-weight:600; color:rgba(255,255,255,0.25);
    transition:all 0.3s; letter-spacing:0.3px;
}
.auth-step.active .auth-step-label { color:#e2e8f0; }
.auth-step.done .auth-step-label { color:#34d399; }
.auth-step-line {
    flex:0 0 24px; height:2px; margin:0 6px; border-radius:2px;
    background:rgba(255,255,255,0.06); transition:all 0.4s;
}
.auth-step.done + .auth-step-line {
    background:linear-gradient(90deg, #10b981, #06b6d4);
    box-shadow:0 0 8px rgba(16,185,129,0.3);
}

.auth-step-content { display:none; animation:authStepIn 0.4s cubic-bezier(0.4,0,0.2,1); }
.auth-step-content.active { display:block; }
@keyframes authStepIn {
    from { opacity:0; transform:translateX(24px) scale(0.98); }
    to   { opacity:1; transform:translateX(0) scale(1); }
}

/* ── PASSWORD STRENGTH ── */
.auth-password-strength { margin:-8px 0 18px; padding:0 4px; }
.auth-pwd-bar {
    height:5px; border-radius:5px;
    background:rgba(255,255,255,0.04);
    overflow:hidden; margin-bottom:6px;
}
.auth-pwd-fill {
    height:100%; width:0; border-radius:5px;
    transition:all 0.4s cubic-bezier(0.4,0,0.2,1);
    box-shadow:0 0 8px currentColor;
}
.auth-pwd-text { font-size:0.72rem; color:rgba(255,255,255,0.3); font-weight:500; }

/* ── ERROR ── */
.auth-error {
    margin-top:16px; padding:12px 16px;
    background:rgba(244,63,94,0.08);
    border:1px solid rgba(244,63,94,0.15);
    border-radius:12px; color:#fb7185;
    font-size:0.85rem; text-align:center;
    backdrop-filter:blur(8px);
    box-shadow:0 0 20px rgba(244,63,94,0.05);
}

/* ── STORE PREVIEW CARD ── */
.auth-store-preview {
    border-radius:14px !important;
    background:rgba(99,102,241,0.04) !important;
    border:1px solid rgba(99,102,241,0.1) !important;
    backdrop-filter:blur(8px);
}

/* ── FLOATING PARTICLES ── */
.auth-particles {
    position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden;
}
.auth-particle {
    position:absolute; width:2px; height:2px; border-radius:50%;
    background:rgba(99,102,241,0.5);
    box-shadow:0 0 6px rgba(99,102,241,0.3);
    animation:authParticleFloat linear infinite;
}
@keyframes authParticleFloat {
    0%   { transform:translateY(100vh) scale(0); opacity:0; }
    10%  { opacity:1; }
    90%  { opacity:1; }
    100% { transform:translateY(-20px) scale(1); opacity:0; }
}

/* ── RESPONSIVE ── */
@media(max-width:960px) {
    .auth-brand-panel { display:none; }
    .auth-form-panel { padding:20px; }
    .auth-form-container { padding:28px; border-radius:16px; }
}
@media(max-width:480px) {
    .auth-form-container { padding:20px; }
    .auth-form-header h2 { font-size:1.4rem; }
    .auth-steps { gap:0; }
    .auth-step-label { font-size:0.65rem; }
}

/* ══════ PRODUCT MULTI-STEP MODAL ══════ */
.prod-step {
    display:flex; align-items:center; gap:8px; flex:1; cursor:pointer;
    padding:8px 12px; border-radius:10px; transition:all 0.3s;
}
.prod-step:hover { background:rgba(var(--accent-primary-rgb),0.04); }
.prod-step-icon {
    width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center;
    font-size:0.85rem; transition:all 0.3s;
    background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06); color:var(--text-muted);
}
.prod-step.active .prod-step-icon {
    background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));
    border-color:transparent; color:#fff;
    box-shadow:0 0 16px rgba(var(--accent-primary-rgb),0.3);
}
.prod-step.done .prod-step-icon {
    background:var(--accent-emerald); border-color:transparent; color:#fff;
    box-shadow:0 0 12px rgba(16,185,129,0.25);
}
.prod-step-label {
    font-size:0.75rem; font-weight:600; color:var(--text-muted); transition:color 0.3s;
}
.prod-step.active .prod-step-label { color:var(--text-primary); }
.prod-step.done .prod-step-label { color:var(--accent-emerald); }
.prod-step-line {
    flex:0 0 16px; height:2px; background:rgba(255,255,255,0.06); border-radius:2px;
    margin:0 2px; transition:background 0.3s;
}
.prod-step.done + .prod-step-line { background:var(--accent-emerald); }
.prod-step-content { display:none; animation:prodStepIn 0.35s ease; }
.prod-step-content.active { display:block; }
@keyframes prodStepIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
.prod-section-title {
    display:flex; align-items:center; gap:10px;
    font-size:0.95rem; font-weight:800; margin-bottom:18px;
    padding-bottom:12px; border-bottom:1px solid var(--border-color);
}
/* Light theme */
[data-theme="light"] .prod-step-icon { background:rgba(0,0,0,0.03); border-color:rgba(0,0,0,0.08); }
[data-theme="light"] .prod-step-line { background:rgba(0,0,0,0.06); }

/* ══════ UPGRADE PLANS PAGE ══════ */
.plans-hero {
    position:relative; border-radius:20px; overflow:hidden; padding:48px 32px;
    background:linear-gradient(135deg, rgba(99,102,241,0.15), rgba(139,92,246,0.1), rgba(6,182,212,0.08));
    border:1px solid rgba(99,102,241,0.15); margin-bottom:28px;
}
.plans-hero::before {
    content:''; position:absolute; inset:0;
    background:radial-gradient(circle at 20% 50%, rgba(99,102,241,0.12) 0%, transparent 50%),
               radial-gradient(circle at 80% 50%, rgba(139,92,246,0.1) 0%, transparent 50%);
}
.plans-hero-particles { position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.plans-particle {
    position:absolute; border-radius:50%;
    box-shadow:0 0 6px currentColor;
    animation:plansParticleFloat linear infinite;
}
@keyframes plansParticleFloat {
    0%   { transform:translateY(100%) scale(0); opacity:0; }
    10%  { opacity:1; }
    90%  { opacity:0.8; }
    100% { transform:translateY(-20px) scale(1.2); opacity:0; }
}
.plans-hero-content { position:relative; z-index:1; text-align:center; }
.plans-hero-badge {
    display:inline-flex; align-items:center; gap:6px; padding:6px 16px;
    border-radius:20px; font-size:0.7rem; font-weight:800; letter-spacing:2px;
    background:linear-gradient(135deg, rgba(99,102,241,0.2), rgba(139,92,246,0.15));
    border:1px solid rgba(99,102,241,0.25); color:var(--accent-primary);
    margin-bottom:14px;
}
.plans-hero-title {
    font-size:2.2rem; font-weight:900; letter-spacing:-1px; margin-bottom:8px;
    background:linear-gradient(135deg, var(--text-primary), var(--accent-primary));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.plans-hero-sub { font-size:0.95rem; color:var(--text-secondary); max-width:500px; margin:0 auto; }

/* Current plan */
.plans-current { padding:20px 24px; }
.plans-current-icon {
    width:48px; height:48px; border-radius:14px; display:flex; align-items:center; justify-content:center;
    background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    color:#fff; font-size:1.2rem; flex-shrink:0;
}
.plans-current-usage {
    display:flex; flex-direction:column; gap:4px; padding:10px 16px;
    border-radius:10px; background:rgba(var(--accent-primary-rgb),0.04);
    border:1px solid rgba(var(--accent-primary-rgb),0.08);
}

/* Billing toggle */
.plans-billing-toggle {
    display:flex; align-items:center; justify-content:center; gap:14px; margin-bottom:28px;
}
.plans-billing-label { font-size:0.88rem; font-weight:600; color:var(--text-muted); transition:color 0.3s; }
.plans-toggle-track {
    width:52px; height:28px; border-radius:14px; padding:3px; cursor:pointer;
    background:rgba(var(--accent-primary-rgb),0.15); border:1px solid rgba(var(--accent-primary-rgb),0.2);
    transition:all 0.3s; position:relative;
}
.plans-toggle-thumb {
    width:22px; height:22px; border-radius:50%;
    background:var(--accent-primary); transition:transform 0.3s; box-shadow:0 0 8px rgba(var(--accent-primary-rgb),0.3);
}
.plans-toggle-track.yearly .plans-toggle-thumb { transform:translateX(24px); }
.plans-toggle-track.yearly { background:rgba(var(--accent-emerald-rgb),0.15); border-color:rgba(var(--accent-emerald-rgb),0.2); }
.plans-toggle-track.yearly .plans-toggle-thumb { background:var(--accent-emerald); box-shadow:0 0 8px rgba(16,185,129,0.3); }
.plans-save-badge {
    display:inline-block; padding:2px 8px; border-radius:8px; font-size:0.65rem; font-weight:800;
    background:rgba(var(--accent-emerald-rgb),0.12); color:var(--accent-emerald);
    margin-left:4px; vertical-align:middle;
}

/* Plan cards grid */
.plans-grid {
    display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
    gap:20px; align-items:start;
}

/* Individual plan card */
.plans-card {
    position:relative; overflow:hidden; padding:0; transition:all 0.4s;
    border:1px solid rgba(255,255,255,0.06);
}
.plans-card:hover { transform:translateY(-6px); box-shadow:0 20px 60px rgba(0,0,0,0.15); }
.plans-card.current { border-color:var(--accent-primary); box-shadow:0 0 24px rgba(var(--accent-primary-rgb),0.12); }
.plans-card.popular { border-color:var(--accent-secondary); }

.plans-popular-badge {
    position:absolute; top:12px; right:-28px; transform:rotate(45deg);
    background:linear-gradient(135deg, #f43f5e, #ec4899); color:#fff;
    font-size:0.6rem; font-weight:800; padding:4px 36px; z-index:2;
    box-shadow:0 2px 8px rgba(244,63,94,0.3);
}

.plans-card-header {
    padding:28px 20px 20px; text-align:center; color:#fff; position:relative;
}
.plans-card-header::after {
    content:''; position:absolute; bottom:-1px; left:0; right:0; height:20px;
    background:var(--bg-card); border-radius:20px 20px 0 0;
}
.plans-card-icon {
    width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center;
    background:rgba(255,255,255,0.2); backdrop-filter:blur(8px); margin:0 auto 12px;
    font-size:1.3rem; border:2px solid rgba(255,255,255,0.3);
}
.plans-card-name { font-size:1.2rem; font-weight:800; margin-bottom:4px; }
.plans-card-desc { font-size:0.75rem; opacity:0.85; }

.plans-card-price {
    padding:20px 20px 16px; text-align:center; position:relative; z-index:1;
}
.plans-price-amount { font-size:2rem; font-weight:900; letter-spacing:-1px; }
.plans-price-currency { font-size:0.85rem; font-weight:600; color:var(--text-muted); }
.plans-price-period { font-size:0.78rem; color:var(--text-muted); }

.plans-card-quotas {
    display:grid; grid-template-columns:1fr 1fr; gap:8px; padding:0 20px 16px;
}
.plans-quota {
    display:flex; align-items:center; gap:8px; font-size:0.76rem; font-weight:500;
}
.plans-quota i { font-size:0.7rem; width:16px; text-align:center; }

.plans-card-features { padding:0 20px 16px; }
.plans-feature {
    display:flex; align-items:center; gap:8px; font-size:0.76rem; padding:4px 0;
}
.plans-feature.yes i { color:var(--accent-emerald); }
.plans-feature.no { color:var(--text-muted); opacity:0.5; }
.plans-feature.no i { color:var(--text-muted); }

.plans-card-btn {
    display:flex; align-items:center; justify-content:center; gap:8px;
    width:calc(100% - 40px); margin:0 20px 20px; padding:12px 20px;
    border-radius:12px; font-size:0.85rem; font-weight:700;
    border:none; cursor:pointer; transition:all 0.3s; color:#fff;
}
.plans-card-btn.upgrade:hover { filter:brightness(1.15); transform:scale(1.02); box-shadow:0 8px 24px rgba(0,0,0,0.2); }
.plans-card-btn.current { background:rgba(var(--accent-emerald-rgb),0.12); color:var(--accent-emerald); cursor:default; }
.plans-card-btn.downgrade { background:rgba(var(--text-muted),0.08); color:var(--text-muted); }
.plans-card-btn.downgrade:hover { background:rgba(var(--accent-rose-rgb),0.1); color:var(--accent-rose); }

/* FAQ */
.plans-faq-item {
    padding:16px; border-radius:12px;
    background:rgba(var(--accent-primary-rgb),0.02);
    border:1px solid rgba(var(--accent-primary-rgb),0.06);
    transition:all 0.3s;
}
.plans-faq-item:hover { background:rgba(var(--accent-primary-rgb),0.04); border-color:rgba(var(--accent-primary-rgb),0.12); }

/* Light theme overrides */
[data-theme="light"] .plans-hero { background:linear-gradient(135deg, rgba(99,102,241,0.06), rgba(139,92,246,0.04), rgba(6,182,212,0.03)); border-color:rgba(99,102,241,0.1); }
[data-theme="light"] .plans-card { border-color:rgba(0,0,0,0.06); }
[data-theme="light"] .plans-card-header::after { background:#fff; }
[data-theme="light"] .plans-card:hover { box-shadow:0 20px 60px rgba(0,0,0,0.08); }

/* Upgrade banner */
.upgrade-banner {
    position:relative; border-radius:14px; overflow:hidden; cursor:pointer;
    margin-bottom:20px; transition:all 0.3s;
    background:linear-gradient(135deg, rgba(99,102,241,0.1), rgba(139,92,246,0.08));
    border:1px solid rgba(99,102,241,0.15);
}
.upgrade-banner:hover { border-color:rgba(99,102,241,0.3); transform:translateY(-1px); box-shadow:0 8px 24px rgba(99,102,241,0.1); }
.upgrade-banner-glow {
    position:absolute; top:-50%; left:-20%; width:60%; height:200%;
    background:radial-gradient(circle, rgba(99,102,241,0.08) 0%, transparent 70%);
    animation:upgradeBannerGlow 4s ease-in-out infinite alternate;
}
@keyframes upgradeBannerGlow { 0%{transform:translateX(0)} 100%{transform:translateX(100%)} }
.upgrade-banner-content {
    position:relative; z-index:1; display:flex; align-items:center; gap:14px; padding:14px 20px;
}
.upgrade-banner-icon {
    width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center;
    background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    color:#fff; font-size:0.9rem; flex-shrink:0;
}
.upgrade-banner-btn {
    padding:8px 16px; border-radius:8px; font-size:0.78rem; font-weight:700; white-space:nowrap;
    background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    color:#fff; display:flex; align-items:center; gap:6px;
}
@media(max-width:640px) {
    .upgrade-banner-content { flex-direction:column; text-align:center; gap:8px; }
    .upgrade-banner-content > div:nth-child(2) span { display:block; margin:4px 0 0; }
}

/* ══════ GOOGLE SHEETS ADDON ══════ */
.gs-tabs {
    display:flex; gap:4px; margin-bottom:20px; padding:4px;
    background:rgba(var(--accent-primary-rgb),0.04); border-radius:12px;
}
.gs-tab {
    flex:1; padding:10px 16px; border-radius:10px; border:none;
    background:transparent; color:var(--text-muted); font-size:0.8rem;
    font-weight:600; cursor:pointer; transition:all 0.25s;
    display:flex; align-items:center; justify-content:center; gap:6px;
}
.gs-tab:hover { color:var(--text-primary); background:rgba(var(--accent-primary-rgb),0.04); }
.gs-tab.active {
    background:var(--bg-card); color:var(--text-primary);
    box-shadow:0 2px 8px rgba(0,0,0,0.08); font-weight:700;
}
.gs-tab-panel { display:none; }
.gs-tab-panel.active { display:block; animation:fadeSlideUp 0.25s ease; }
@keyframes fadeSlideUp { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

.gs-section {
    padding:16px; border-radius:14px; margin-bottom:16px;
    background:rgba(var(--accent-primary-rgb),0.02);
    border:1px solid rgba(var(--accent-primary-rgb),0.06);
}
.gs-section-title {
    display:flex; align-items:center; gap:8px; font-size:0.85rem;
    font-weight:700; margin-bottom:14px; padding-bottom:10px;
    border-bottom:1px solid var(--border-color);
}
.gs-toggle-row {
    display:flex; align-items:center; gap:14px; padding:14px 0;
    border-bottom:1px solid rgba(var(--accent-primary-rgb),0.04);
}
.gs-toggle-row:last-child { border-bottom:none; }

.gs-test-box {
    padding:16px; border-radius:14px;
    background:linear-gradient(135deg, rgba(var(--accent-primary-rgb),0.03), rgba(var(--accent-cyan-rgb),0.02));
    border:1px solid rgba(var(--accent-primary-rgb),0.08);
}
.gs-product-row {
    display:flex; align-items:center; gap:12px; padding:10px 12px;
    border-radius:10px; margin-bottom:6px; transition:all 0.2s;
    border:1px solid transparent;
}
.gs-product-row:hover { background:rgba(var(--accent-primary-rgb),0.03); border-color:rgba(var(--accent-primary-rgb),0.06); }

@media(max-width:640px) {
    .gs-tabs { flex-direction:column; }
    .gs-product-row { flex-direction:column; align-items:stretch; gap:8px; }
    .gs-product-row .input-field { width:100% !important; }
}

/* Plans responsive */
@media(max-width:768px) {
    .plans-hero { padding:32px 20px; }
    .plans-hero-title { font-size:1.5rem; }
    .plans-grid { grid-template-columns:1fr; }
    .plans-current .flex { flex-direction:column; gap:14px; }
    .plans-current-usage { flex-direction:row; gap:16px; }
    .plans-card-quotas { grid-template-columns:1fr; }
}

/* ══════ MODAL ══════ */
.modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 500;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
}

.modal-container {
    position: fixed;
    inset: 0;
    z-index: 501;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    overflow-y: auto;
    text-align: center;
}

.modal-container::before {
    content: '';
    display: inline-block;
    height: 100%;
    vertical-align: middle;
}

.modal {
    width: 100%;
    max-width: 920px;
    max-height: 95vh;
    overflow-y: auto;
    padding: 0;
    animation: modalIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
    position: relative;
    margin: auto;
    display: inline-block;
    vertical-align: middle;
    text-align: left;
}

/* Product modal specific sizing */
.modal[data-modal="product"] {
    max-width: 1100px;
    width: 95vw;
    margin: auto;
    position: relative;
    display: inline-block;
    vertical-align: middle;
    text-align: left;
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--border-color);
}

.modal-header h3 {
    font-size: 1.1rem;
    font-weight: 700;
}

.modal-body {
    padding: 24px;
}

.modal-footer {
    padding: 16px 24px;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

@keyframes modalIn {
    0% { opacity: 0; transform: scale(0.95) translateY(10px); }
    100% { opacity: 1; transform: scale(1) translateY(0); }
}

/* ══════ TOAST ══════ */
.toast-container {
    position: fixed;
    top: 80px;
    right: 28px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 10px;
    pointer-events: none;
}

.toast-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 18px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    backdrop-filter: blur(20px);
    box-shadow: var(--shadow-lg);
    font-size: 0.88rem;
    font-weight: 500;
    pointer-events: auto;
    opacity: 0;
    transform: translateX(40px);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    min-width: 280px;
}

.toast-item.show {
    opacity: 1;
    transform: translateX(0);
}

/* ══════ PAGE HEADER ══════ */
.page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 24px;
}

.page-title {
    font-size: 1.8rem;
    font-weight: 800;
    letter-spacing: -0.5px;
}

.page-subtitle {
    font-size: 0.9rem;
    margin-top: 4px;
}

/* ══════ STATS GRID ══════ */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.stat-card {
    padding: 20px;
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

.stat-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    flex-shrink: 0;
}

.stat-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.stat-label {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.stat-value {
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.5px;
}

.stat-footer {
    font-size: 0.78rem;
    color: var(--text-tertiary);
    display: flex;
    align-items: center;
    gap: 5px;
}

/* ══════ DASHBOARD GRID ══════ */
.dashboard-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 20px;
}

@media (max-width: 900px) {
    .dashboard-grid {
        grid-template-columns: 1fr;
    }
    .dashboard-grid > *:first-child {
        grid-column: span 1 !important;
    }
}

/* ══════ FILTER BUTTONS ══════ */
.filter-btn {
    padding: 6px 16px;
    border-radius: var(--radius-full);
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-secondary);
    background: var(--bg-glass);
    border: 1px solid var(--border-color);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.filter-btn:hover {
    border-color: var(--border-glow);
    color: var(--text-primary);
}

.filter-btn.active {
    background: var(--accent-primary);
    color: white;
    border-color: var(--accent-primary);
}

/* ══════ PIPELINE STAGES ══════ */
.pipeline-stages {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.pipeline-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    border-radius: var(--radius-md);
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-secondary);
    background: var(--bg-glass);
    border: 1px solid var(--border-color);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.pipeline-btn:hover {
    border-color: var(--border-glow);
    color: var(--text-primary);
}

.pipeline-btn.active {
    background: rgba(var(--accent-primary-rgb), 0.15);
    color: var(--accent-primary);
    border-color: rgba(var(--accent-primary-rgb), 0.3);
}

.pipeline-count {
    font-size: 0.72rem;
    padding: 1px 7px;
    border-radius: var(--radius-full);
    background: rgba(255,255,255,0.06);
}

.pipeline-btn.active .pipeline-count {
    background: rgba(var(--accent-primary-rgb), 0.2);
}

/* ══════ SETTINGS LAYOUT ══════ */
.settings-layout {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 20px;
}

.settings-nav {
    display: flex;
    flex-direction: column;
    gap: 4px;
    height: fit-content;
    position: sticky;
    top: 0;
}

.settings-nav-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: var(--radius-md);
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all var(--transition-fast);
    background: none;
    border: none;
    text-align: left;
    width: 100%;
}

.settings-nav-btn:hover {
    background: var(--bg-glass);
    color: var(--text-primary);
}

.settings-nav-btn.active {
    background: rgba(var(--accent-primary-rgb), 0.1);
    color: var(--accent-primary);
}

@media (max-width: 768px) {
    .settings-layout {
        grid-template-columns: 1fr;
    }
    .settings-nav {
        flex-direction: row;
        overflow-x: auto;
    }
    .settings-nav-btn {
        white-space: nowrap;
    }
}

/* ══════ NOTIF PANEL ══════ */
.notif-panel {
    position: fixed;
    top: var(--topbar-height);
    right: 0;
    width: 360px;
    max-height: calc(100vh - var(--topbar-height));
    background: var(--bg-card);
    border-left: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
    backdrop-filter: blur(20px);
    z-index: 200;
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform var(--transition-base);
    border-radius: 0 0 0 var(--radius-lg);
}

.notif-panel.active {
    transform: translateX(0);
}

.notif-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color);
}

.notif-header h3 {
    font-size: 1rem;
    font-weight: 700;
}

.notif-clear {
    font-size: 0.78rem;
    color: var(--accent-primary);
    cursor: pointer;
    background: none;
    border: none;
}

.notif-list {
    padding: 8px;
}

.notif-item {
    display: flex;
    gap: 12px;
    padding: 12px;
    border-radius: var(--radius-md);
    transition: background var(--transition-fast);
}

.notif-item:hover {
    background: var(--bg-glass);
}

.notif-icon {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    flex-shrink: 0;
}

.notif-icon.success { background: rgba(var(--accent-emerald-rgb), 0.12); color: var(--accent-emerald); }
.notif-icon.warning { background: rgba(var(--accent-amber-rgb), 0.12); color: var(--accent-amber); }
.notif-icon.info { background: rgba(var(--accent-cyan-rgb), 0.12); color: var(--accent-cyan); }
.notif-icon.ai { background: rgba(var(--accent-primary-rgb), 0.12); color: var(--accent-primary); }

.notif-content p {
    font-size: 0.85rem;
    font-weight: 500;
    margin-bottom: 2px;
}

.notif-content span {
    font-size: 0.75rem;
    color: var(--text-muted);
}

/* ══════ STORE SWITCHER ══════ */
.store-switcher-dropdown {
    display: none;
    margin-top: 6px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    max-height: 240px;
    overflow-y: auto;
}

.store-switcher-dropdown.active {
    display: block;
}

.store-switch-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    cursor: pointer;
    transition: background var(--transition-fast);
    border: none;
    background: none;
    width: 100%;
    text-align: left;
    color: var(--text-primary);
    font-size: 0.82rem;
}

.store-switch-item:hover {
    background: var(--bg-glass);
}

.store-switch-item.current {
    background: rgba(var(--accent-primary-rgb), 0.08);
    border-left: 3px solid var(--accent-primary);
}

.store-switch-item .store-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.store-switch-item .store-dot.active { background: var(--accent-emerald); }
.store-switch-item .store-dot.inactive { background: var(--text-muted); }

.store-switch-add {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    cursor: pointer;
    border: none;
    background: none;
    width: 100%;
    text-align: left;
    color: var(--accent-primary);
    font-size: 0.8rem;
    font-weight: 600;
    border-top: 1px solid var(--border-color);
    transition: background var(--transition-fast);
}

.store-switch-add:hover {
    background: rgba(var(--accent-primary-rgb), 0.06);
}

/* ══════ GRID AUTO ══════ */
.grid-auto {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
}

/* ══════ BADGE ══════ */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: var(--radius-full);
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: capitalize;
}

.badge-success { background: rgba(var(--accent-emerald-rgb), 0.12); color: var(--accent-emerald); }
.badge-warning { background: rgba(var(--accent-amber-rgb), 0.12); color: var(--accent-amber); }
.badge-danger { background: rgba(var(--accent-rose-rgb), 0.12); color: var(--accent-rose); }
.badge-info { background: rgba(var(--accent-cyan-rgb), 0.12); color: var(--accent-cyan); }
.badge-primary { background: rgba(var(--accent-primary-rgb), 0.12); color: var(--accent-primary); }

/* ══════ DATA TABLE ══════ */
.data-table {
    width: 100%;
    border-collapse: collapse;
}

.data-table th {
    padding: 12px 16px;
    text-align: left;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border-color);
    white-space: nowrap;
}

.data-table td {
    padding: 12px 16px;
    font-size: 0.85rem;
    border-bottom: 1px solid rgba(var(--border-color-rgb, 255,255,255), 0.04);
    vertical-align: middle;
}

.data-table tr:hover td {
    background: rgba(var(--accent-primary-rgb), 0.02);
}

.data-table .text-sm { font-size: 0.8rem; }
.data-table .text-xs { font-size: 0.72rem; }
.data-table .text-muted { color: var(--text-muted); }

/* ══════ UTILITY ══════ */
.flex { display: flex; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.gap-xs { gap: 4px; }
.gap-sm { gap: 8px; }
.gap-md { gap: 16px; }
.text-muted { color: var(--text-muted); }
.text-sm { font-size: 0.85rem; }
.text-xs { font-size: 0.72rem; }
.font-semibold { font-weight: 600; }
.w-full { width: 100%; }
.hidden { display: none !important; }
.visible { display: flex !important; }

/* ══════ INPUT ══════ */
.input-group { display: flex; flex-direction: column; gap: 6px; }
.input-group label { font-size: 0.78rem; font-weight: 600; color: var(--text-secondary); }

.input-field {
    padding: 10px 14px;
    background: var(--bg-glass);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    font-size: 0.88rem;
    font-family: var(--font-primary);
    transition: all var(--transition-fast);
    outline: none;
}

.input-field:focus {
    border-color: var(--accent-primary);
    box-shadow: 0 0 0 3px rgba(var(--accent-primary-rgb), 0.15);
}

.input-field::placeholder { color: var(--text-muted); }

textarea.input-field { resize: vertical; min-height: 60px; }
select.input-field { cursor: pointer; }

/* ══════ BUTTONS ══════ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: var(--radius-md);
    font-size: 0.85rem;
    font-weight: 600;
    font-family: var(--font-primary);
    cursor: pointer;
    transition: all var(--transition-fast);
    border: 1px solid transparent;
    white-space: nowrap;
}

.btn-primary {
    background: var(--accent-primary);
    color: white;
}
.btn-primary:hover {
    background: var(--accent-secondary);
    box-shadow: 0 4px 12px rgba(var(--accent-primary-rgb), 0.3);
}

.btn-secondary {
    background: var(--bg-glass);
    border-color: var(--border-color);
    color: var(--text-primary);
}
.btn-secondary:hover {
    border-color: var(--border-glow);
    background: rgba(var(--accent-primary-rgb), 0.06);
}

.btn-ghost {
    background: transparent;
    color: var(--text-secondary);
    padding: 6px 10px;
}
.btn-ghost:hover {
    background: var(--bg-glass);
    color: var(--text-primary);
}

.btn-sm { padding: 6px 14px; font-size: 0.78rem; }
.btn-lg { padding: 12px 24px; font-size: 0.95rem; }
.btn-icon { padding: 8px; }
.btn-icon.sm { padding: 5px; }

/* ═══════════════════════════════════════════════════════
   LIGHT THEME — App Component Overrides
   ═══════════════════════════════════════════════════════ */

/* Auth screen — light theme */
[data-theme="light"] .auth-bg { background:radial-gradient(ellipse at 20% 50%,#eef0ff 0%,#f5f7fa 40%,#f0f2ff 100%); }
[data-theme="light"] .auth-bg::after { background:none; }
[data-theme="light"] .auth-grid-overlay { background-image:linear-gradient(rgba(99,102,241,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,0.04) 1px,transparent 1px); }
[data-theme="light"] .auth-orb-1 { background:radial-gradient(circle,rgba(99,102,241,0.15) 0%,transparent 70%); }
[data-theme="light"] .auth-orb-2 { background:radial-gradient(circle,rgba(139,92,246,0.12) 0%,transparent 70%); }
[data-theme="light"] .auth-orb-3 { background:radial-gradient(circle,rgba(6,182,212,0.1) 0%,transparent 70%); }
[data-theme="light"] .auth-brand-panel { background:linear-gradient(160deg,rgba(99,102,241,0.04) 0%,rgba(139,92,246,0.02) 100%); border-right-color:rgba(0,0,0,0.06); }
[data-theme="light"] .auth-brand-panel::after { background:linear-gradient(180deg,transparent,rgba(99,102,241,0.15),rgba(139,92,246,0.08),transparent); }
[data-theme="light"] .auth-logo-core { background:linear-gradient(135deg,rgba(99,102,241,0.1),rgba(139,92,246,0.06)); border-color:rgba(99,102,241,0.15); box-shadow:0 0 30px rgba(99,102,241,0.08); }
[data-theme="light"] .auth-brand-title { text-shadow:none; }
[data-theme="light"] .auth-brand-tagline { color:#666; }
[data-theme="light"] .auth-brand-stats { background:rgba(99,102,241,0.03); border-color:rgba(0,0,0,0.06); }
[data-theme="light"] .auth-stat-label { color:#888; }
[data-theme="light"] .auth-stat-divider { background:linear-gradient(180deg,transparent,rgba(0,0,0,0.1),transparent); }
[data-theme="light"] .auth-feature { color:#555; background:rgba(99,102,241,0.02); border-color:rgba(0,0,0,0.04); }
[data-theme="light"] .auth-feature:hover { color:#333; background:rgba(99,102,241,0.05); }
[data-theme="light"] .auth-form-container { background:rgba(255,255,255,0.7); border-color:rgba(0,0,0,0.06); box-shadow:0 20px 60px rgba(0,0,0,0.06),0 0 80px rgba(99,102,241,0.03); }
[data-theme="light"] .auth-form-container::before { background:conic-gradient(from 0deg,transparent,rgba(99,102,241,0.12),transparent,rgba(139,92,246,0.08),transparent); }
[data-theme="light"] .auth-form-header h2 { color:#1a1a2e; text-shadow:none; }
[data-theme="light"] .auth-form-header p { color:#666; }
[data-theme="light"] .auth-input { background:rgba(0,0,0,0.02); border-color:rgba(0,0,0,0.08); color:#1a1a2e; }
[data-theme="light"] .auth-input::placeholder { color:rgba(0,0,0,0.3); }
[data-theme="light"] .auth-input:hover { border-color:rgba(99,102,241,0.2); background:rgba(99,102,241,0.02); }
[data-theme="light"] .auth-input:focus { background:rgba(99,102,241,0.03); border-color:rgba(99,102,241,0.4); box-shadow:0 0 0 3px rgba(99,102,241,0.08),0 0 20px rgba(99,102,241,0.04); }
[data-theme="light"] .auth-input-icon { color:rgba(0,0,0,0.3); }
[data-theme="light"] .auth-eye { color:rgba(0,0,0,0.3); }
[data-theme="light"] .auth-step-num { background:rgba(0,0,0,0.03); border-color:rgba(0,0,0,0.08); color:#999; }
[data-theme="light"] .auth-divider::before,[data-theme="light"] .auth-divider::after { background:linear-gradient(90deg,transparent,rgba(0,0,0,0.06),transparent); }
[data-theme="light"] .auth-divider span { color:#999; }
[data-theme="light"] .auth-switch-text { color:#666; }
[data-theme="light"] .auth-back-btn { border-color:rgba(0,0,0,0.08); color:#555; background:rgba(0,0,0,0.02); }
[data-theme="light"] .auth-back-btn:hover { background:rgba(99,102,241,0.04); }
[data-theme="light"] .auth-pwd-bar { background:rgba(0,0,0,0.05); }
[data-theme="light"] .auth-pwd-text { color:#888; }
[data-theme="light"] .auth-error { background:rgba(244,63,94,0.06); border-color:rgba(244,63,94,0.12); }

/* Modals */
[data-theme="light"] .modal-backdrop {
    background: rgba(0, 0, 0, 0.3);
}
[data-theme="light"] .modal {
    background: #fff;
    border-color: rgba(0, 0, 0, 0.06);
    box-shadow: 0 20px 80px rgba(0, 0, 0, 0.12);
}
[data-theme="light"] .modal-header {
    border-bottom-color: rgba(0, 0, 0, 0.06);
}
[data-theme="light"] .modal-footer {
    border-top-color: rgba(0, 0, 0, 0.06);
}

/* Toast */
[data-theme="light"] .toast-item {
    background: #fff;
    border-color: rgba(0, 0, 0, 0.06);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}

/* Notification panel */
[data-theme="light"] .notif-panel {
    background: rgba(255, 255, 255, 0.95);
    border-color: rgba(0, 0, 0, 0.06);
    box-shadow: -4px 0 24px rgba(0, 0, 0, 0.06);
}
[data-theme="light"] .notif-header {
    border-bottom-color: rgba(0, 0, 0, 0.06);
}
[data-theme="light"] .notif-item:hover {
    background: rgba(0, 0, 0, 0.03);
}

/* Pipeline buttons */
[data-theme="light"] .pipeline-btn {
    background: rgba(255, 255, 255, 0.6);
}
[data-theme="light"] .pipeline-count {
    background: rgba(0, 0, 0, 0.04);
}

/* Store switcher */
[data-theme="light"] .store-switcher-dropdown {
    background: #fff;
    border-color: rgba(0, 0, 0, 0.08);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}
[data-theme="light"] .store-switch-item:hover {
    background: rgba(0, 0, 0, 0.03);
}
[data-theme="light"] .store-switch-add {
    border-top-color: rgba(0, 0, 0, 0.06);
}

/* Preloader */
[data-theme="light"] #preloader {
    background: var(--bg-primary);
}
[data-theme="light"] .preloader-logo {
    color: #1a1a2e;
}
[data-theme="light"] .preloader-status {
    color: #888;
}

/* Product modal responsive */
@media(max-width: 768px) {
    .modal[data-modal="product"] {
        max-width: 100vw;
        width: 100vw;
        height: 100vh;
        max-height: 100vh;
        border-radius: 0;
        margin: 0;
    }
    .modal-container {
        padding: 0;
    }
    .modal-header {
        padding: 16px 20px;
    }
    .modal-body {
        padding: 20px;
    }
    #prodSteps {
        flex-direction: column;
        gap: 12px;
        margin-bottom: 20px;
    }
    .prod-step {
        flex-direction: row;
        justify-content: space-between;
        padding: 12px 16px;
    }
    .prod-step-line {
        display: none;
    }
    .prod-step-content {
        padding-bottom: 20px;
    }
    .prod-section-title {
        font-size: 0.85rem;
        margin-bottom: 14px;
    }
    .prod-step-icon {
        width: 32px;
        height: 32px;
        font-size: 0.75rem;
    }
    .prod-step-label {
        font-size: 0.7rem;
    }
}

@media(max-width: 480px) {
    .modal-header h3 {
        font-size: 1rem;
    }
    .modal-body {
        padding: 16px;
    }
    .prod-step {
        padding: 10px 12px;
    }
    .prod-step-icon {
        width: 28px;
        height: 28px;
        font-size: 0.7rem;
    }
    .prod-step-label {
        font-size: 0.65rem;
    }
    .prod-section-title {
        font-size: 0.8rem;
    }
}

/* Data table override in light */
[data-theme="light"] .data-table td {
    border-bottom-color: rgba(0, 0, 0, 0.04);
}
[data-theme="light"] .data-table tr:hover td {
    background: rgba(99, 102, 241, 0.03);
}
