/* === JAZUDU DESIGN SYSTEM === */
/* theme.css — shared across all pages */

/* Reset */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* ── Light theme (default) ── */
:root{
    --bg:#f8f9fb;
    --surface:#ffffff;
    --surface2:#f1f3f6;
    --border:#e2e5ea;
    --border-hover:#c9cdd4;
    --text:#1a1a2e;
    --text-secondary:#4a4a68;
    --dim:#6b6d84;
    --cyan:#0891b2;
    --purple:#7c3aed;
    --lime:#16a34a;
    --pink:#e11d63;
    --orange:#ea580c;
    --cyan-bg:rgba(8,145,178,0.08);
    --purple-bg:rgba(124,58,237,0.08);
    --lime-bg:rgba(22,163,74,0.08);
    --pink-bg:rgba(225,29,99,0.08);
    --orange-bg:rgba(234,88,12,0.08);
    --shadow-sm:0 1px 2px rgba(0,0,0,0.05);
    --shadow-md:0 4px 12px rgba(0,0,0,0.08);
    --shadow-lg:0 8px 24px rgba(0,0,0,0.1);
    --shadow-xl:0 16px 48px rgba(0,0,0,0.12);
    --nav-bg:rgba(255,255,255,0.85);
    --modal-overlay:rgba(0,0,0,0.4);
    --gradient-primary:linear-gradient(135deg,#0891b2,#7c3aed);
    --gradient-pink:linear-gradient(135deg,#e11d63,#7c3aed);
    --cell-bg:rgba(0,0,0,0.03);
    --cell-border:rgba(0,0,0,0.08);
    --cell-hover:rgba(0,0,0,0.08);
    --tooltip-bg:rgba(255,255,255,0.97);
    --tooltip-shadow:0 4px 20px rgba(0,0,0,0.15);
    --scrollbar-track:rgba(0,0,0,0.04);
    --scrollbar-thumb:rgba(0,0,0,0.15);
    --scrollbar-hover:rgba(0,0,0,0.25);
    --card-title:#1a1a2e;
    --radius:8px;
}

/* ── Dark theme ── */
[data-theme="dark"]{
    --bg:#0a0a12;
    --surface:#12111f;
    --surface2:#1a1830;
    --border:#2a2545;
    --border-hover:#3d3660;
    --text:#e4e2ec;
    --text-secondary:#b8b4c8;
    --dim:#918da8;
    --cyan:#22d3ee;
    --purple:#a78bfa;
    --lime:#4ade80;
    --pink:#f472b6;
    --orange:#fb923c;
    --cyan-bg:rgba(34,211,238,0.1);
    --purple-bg:rgba(167,139,250,0.1);
    --lime-bg:rgba(74,222,128,0.1);
    --pink-bg:rgba(244,114,182,0.1);
    --orange-bg:rgba(251,146,60,0.1);
    --shadow-sm:0 1px 3px rgba(0,0,0,0.3);
    --shadow-md:0 4px 12px rgba(0,0,0,0.4);
    --shadow-lg:0 8px 24px rgba(0,0,0,0.5);
    --shadow-xl:0 16px 48px rgba(0,0,0,0.6);
    --nav-bg:rgba(10,10,18,0.88);
    --modal-overlay:rgba(0,0,0,0.7);
    --gradient-primary:linear-gradient(135deg,#22d3ee,#a78bfa);
    --gradient-pink:linear-gradient(135deg,#f472b6,#a78bfa);
    --cell-bg:rgba(100,100,100,0.06);
    --cell-border:rgba(100,100,100,0.12);
    --cell-hover:rgba(100,100,100,0.2);
    --tooltip-bg:rgba(18,17,31,0.97);
    --tooltip-shadow:0 4px 20px rgba(0,0,0,0.5),0 0 12px rgba(167,139,250,0.15);
    --scrollbar-track:rgba(20,16,37,0.6);
    --scrollbar-thumb:var(--dim);
    --scrollbar-hover:var(--purple);
    --card-title:#fff;
}

/* ── Body ── */
html{scroll-behavior:smooth}
body{
    font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
    background:var(--bg);
    color:var(--text);
    overflow-x:hidden;
    transition:background-color 0.3s,color 0.3s;
}

/* ── Grid background ── */
.grid-bg{
    position:fixed;inset:0;z-index:0;pointer-events:none;
    background-image:
        radial-gradient(circle,rgba(0,0,0,0.06) 1px,transparent 1px);
    background-size:24px 24px;
    opacity:0.5;
}
[data-theme="dark"] .grid-bg{
    background-image:
        linear-gradient(rgba(168,85,247,0.03) 1px,transparent 1px),
        linear-gradient(90deg,rgba(168,85,247,0.03) 1px,transparent 1px);
    background-size:60px 60px;
    opacity:1;
}
[data-theme="dark"] .grid-bg::after{
    content:'';position:absolute;inset:0;
    background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(168,85,247,0.08),transparent 70%);
}

/* ── Scanlines ── */
.scanlines{
    position:fixed;inset:0;z-index:90;pointer-events:none;
    display:none;
}
[data-theme="dark"] .scanlines{
    display:block;
    background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.03) 2px,rgba(0,0,0,0.03) 4px);
}

/* ── Nav ── */
nav{
    position:fixed;top:0;left:0;right:0;z-index:100;
    height:56px;padding:0 24px;
    display:flex;align-items:center;justify-content:space-between;
    background:var(--nav-bg);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    border-bottom:1px solid var(--border);
    transition:background-color 0.3s,border-color 0.3s;
}
.nav-left{display:flex;align-items:center;gap:8px}
.nav-logo{
    font-size:16px;font-weight:800;letter-spacing:-0.5px;
    background:var(--gradient-primary);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;text-decoration:none;
}
.nav-sep{color:var(--dim);font-size:14px}
.nav-title{font-size:14px;font-weight:600;color:var(--text)}
.nav-right{display:flex;gap:16px;align-items:center}
.nav-links{display:flex;gap:20px;align-items:center}
.nav-links a,.nav-right>a{
    color:var(--dim);text-decoration:none;font-size:14px;font-weight:500;
    transition:color 0.2s;position:relative;
}
.nav-links a:hover,.nav-right>a:hover{color:var(--cyan)}
.nav-links a::after,.nav-right>a::after{
    content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;
    background:var(--cyan);transition:width 0.2s;
}
.nav-links a:hover::after,.nav-right>a:hover::after{width:100%}

/* Nav dropdown (Tools menu) */
.nav-dropdown{position:relative;display:flex;align-items:center}
.nav-dropdown-trigger{
    background:none;border:none;cursor:pointer;
    color:var(--dim);font-size:14px;font-weight:500;
    display:inline-flex;align-items:center;gap:4px;
    padding:0;transition:color 0.2s;font-family:inherit;
}
.nav-dropdown-trigger:hover{color:var(--cyan)}
.nav-chevron{transition:transform 0.2s}
.nav-dropdown:hover .nav-chevron{transform:rotate(180deg)}
.nav-dropdown-menu{
    display:none;position:absolute;top:calc(100% + 8px);left:50%;
    transform:translateX(-50%);
    min-width:180px;padding:8px 0;
    background:var(--surface);border:1px solid var(--border);
    border-radius:10px;box-shadow:var(--shadow-lg);
    z-index:200;
}
.nav-dropdown:hover .nav-dropdown-menu{display:block}
.nav-dropdown-menu::before{
    content:'';position:absolute;top:-12px;left:0;right:0;height:12px;
}
.nav-dropdown-menu a{
    display:block;padding:8px 16px;
    color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;
    transition:all 0.15s;
}
.nav-dropdown-menu a:hover{
    background:var(--cyan-bg);color:var(--cyan);
}
.nav-btn{
    display:inline-flex;align-items:center;gap:6px;
    padding:6px 14px;border-radius:8px;
    font-size:12px;font-weight:600;
    background:var(--surface2);border:1px solid var(--border);
    color:var(--dim);text-decoration:none;
    transition:all 0.2s;cursor:pointer;
}
.nav-btn:hover{border-color:var(--purple);color:var(--text)}
.nav-btn-accent{
    border-color:var(--cyan);color:var(--cyan);
    background:var(--cyan-bg);
}

/* Support nav link */
.nav-support{
    color:var(--pink)!important;font-weight:600!important;
    display:inline-flex;align-items:center;gap:4px;
}
.nav-support:hover{opacity:0.8}
.nav-support::after{display:none!important}

/* Ko-fi donate link */
.nav-kofi{
    color:var(--orange)!important;font-weight:600!important;
    display:inline-flex;align-items:center;gap:4px;
}
.nav-kofi:hover{opacity:0.8}
.nav-kofi::after{display:none!important}

/* Theme toggle */
.theme-toggle{
    width:36px;height:36px;border-radius:8px;
    border:1px solid var(--border);background:var(--surface2);
    color:var(--dim);cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:all 0.2s;padding:0;
    flex-shrink:0;
}
.theme-toggle:hover{border-color:var(--purple);color:var(--text)}
.theme-toggle .icon-sun{display:block}
.theme-toggle .icon-moon{display:none}
[data-theme="dark"] .theme-toggle .icon-sun{display:none}
[data-theme="dark"] .theme-toggle .icon-moon{display:block}

/* ── Cards ── */
.card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:12px;overflow:hidden;
    transition:all 0.3s;position:relative;
    box-shadow:var(--shadow-sm);
}
.card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow-lg);
}
[data-theme="dark"] .card:hover{
    box-shadow:0 16px 48px rgba(0,0,0,0.4);
}
.card a{display:block;text-decoration:none;color:inherit}
.card-thumb{
    width:100%;aspect-ratio:16/9;object-fit:cover;
    background:var(--surface2);display:block;
}
.card-body{padding:16px 20px}
.card-title{font-size:17px;font-weight:700;color:var(--card-title);margin-bottom:6px}
.card-desc{font-size:13px;color:var(--dim);line-height:1.5}
.card-tag{
    display:inline-block;
    padding:3px 10px;border-radius:999px;
    font-size:10px;font-weight:700;
    text-transform:uppercase;letter-spacing:0.5px;
    margin-top:10px;
}
.tag-play{background:var(--cyan-bg);color:var(--cyan)}
.tag-tool{background:var(--purple-bg);color:var(--purple)}
.tag-free{background:var(--lime-bg);color:var(--lime)}

/* ── Buttons ── */
.btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:14px 28px;border-radius:8px;
    font-size:15px;font-weight:600;
    text-decoration:none;cursor:pointer;
    transition:all 0.25s;border:none;
}
.btn-primary{
    background:var(--gradient-primary);
    color:#fff;
}
.btn-primary:hover{
    transform:translateY(-2px);
    box-shadow:0 8px 32px rgba(8,145,178,0.25);
}
[data-theme="dark"] .btn-primary{color:#000}
[data-theme="dark"] .btn-primary:hover{
    box-shadow:0 8px 32px rgba(34,211,238,0.3);
}
.btn-secondary{
    background:transparent;
    border:1px solid var(--border);
    color:var(--text);
}
.btn-secondary:hover{
    border-color:var(--purple);
    background:var(--purple-bg);
    transform:translateY(-2px);
}

/* ── Sections ── */
.section{
    position:relative;z-index:1;
    max-width:1100px;margin:0 auto;
    padding:80px 24px;
}
.section-label{
    display:inline-flex;align-items:center;gap:8px;
    font-size:11px;font-weight:700;
    text-transform:uppercase;letter-spacing:2px;
    color:var(--cyan);margin-bottom:12px;
}
.section-label svg{width:16px;height:16px}
.section h2{
    font-size:clamp(28px,4vw,42px);
    font-weight:800;letter-spacing:-1px;
    margin-bottom:16px;
}
.section-desc{
    color:var(--dim);font-size:16px;
    max-width:560px;line-height:1.6;
    margin-bottom:48px;
}

/* ── Card grid ── */
.card-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
    gap:20px;
}

/* ── Feature cards ── */
.features{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
    gap:16px;
}
.feature{
    padding:28px 24px;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:12px;
    transition:all 0.25s;
    box-shadow:var(--shadow-sm);
}
.feature:hover{
    border-color:var(--border-hover);
    transform:translateY(-3px);
    box-shadow:var(--shadow-md);
}
.feature-icon{
    width:40px;height:40px;
    border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    font-size:20px;margin-bottom:14px;
}
.feature h3{
    font-size:15px;font-weight:700;
    margin-bottom:6px;color:var(--card-title);
}
.feature p{font-size:13px;color:var(--dim);line-height:1.5}

/* ── Stats bar ── */
.stats-bar{
    display:flex;gap:0;
    border:1px solid var(--border);
    border-radius:12px;overflow:hidden;
    margin-bottom:60px;
    background:var(--surface);
    box-shadow:var(--shadow-sm);
}
.stat{
    flex:1;padding:24px;text-align:center;
    border-right:1px solid var(--border);
}
.stat:last-child{border-right:none}
.stat-value{
    font-size:28px;font-weight:800;
    background:var(--gradient-primary);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
}
.stat-label{font-size:12px;color:var(--dim);margin-top:4px}

/* ── Footer ── */
.site-footer{
    position:relative;z-index:1;
    border-top:1px solid var(--border);
    background:var(--surface);
    padding:48px 24px 24px;
    transition:background-color 0.3s,border-color 0.3s;
}
.footer-grid{
    max-width:1100px;margin:0 auto;
    display:grid;
    grid-template-columns:2fr 1fr 1fr 1fr;
    gap:32px;
    margin-bottom:32px;
}
.footer-brand{
    font-size:18px;font-weight:800;
    background:var(--gradient-primary);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
    margin-bottom:8px;
}
.footer-tagline{font-size:13px;color:var(--dim);line-height:1.5}
.footer-col h4{
    font-size:11px;font-weight:700;
    text-transform:uppercase;letter-spacing:1.5px;
    color:var(--dim);margin-bottom:12px;
}
.footer-col a{
    display:block;color:var(--text-secondary);text-decoration:none;
    font-size:13px;padding:3px 0;transition:color 0.2s;
}
.footer-col a:hover{color:var(--cyan)}
.footer-bottom{
    max-width:1100px;margin:0 auto;
    padding-top:20px;
    border-top:1px solid var(--border);
    display:flex;justify-content:space-between;align-items:center;
    font-size:12px;color:var(--dim);
    flex-wrap:wrap;gap:8px;
}
.footer-bottom a{color:var(--purple);text-decoration:none}
.footer-bottom a:hover{color:var(--cyan)}

/* ── Recommendations (affiliate cards) ── */
.recommendations{
    position:relative;z-index:1;
    max-width:1100px;margin:0 auto;
    padding:48px 24px 0;
}
.recommendations h3{
    font-size:14px;font-weight:700;
    text-transform:uppercase;letter-spacing:1.5px;
    color:var(--dim);margin-bottom:20px;
}
.rec-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    gap:16px;
}
.rec-card{
    display:flex;align-items:center;gap:16px;
    padding:16px 20px;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:12px;
    text-decoration:none;color:inherit;
    transition:all 0.2s;
    box-shadow:var(--shadow-sm);
}
.rec-card:hover{
    border-color:var(--border-hover);
    box-shadow:var(--shadow-md);
    transform:translateY(-2px);
}
.rec-icon{font-size:28px;flex-shrink:0}
.rec-info{flex:1;min-width:0}
.rec-info strong{display:block;font-size:14px;color:var(--card-title);margin-bottom:2px}
.rec-info span{font-size:12px;color:var(--dim)}
.rec-badge{
    font-size:9px;font-weight:700;
    text-transform:uppercase;letter-spacing:0.5px;
    color:var(--dim);
    background:var(--surface2);
    padding:2px 6px;border-radius:4px;
    flex-shrink:0;
}

/* ── Orbs (dark mode only) ── */
.orb{
    position:absolute;border-radius:50%;filter:blur(80px);
    pointer-events:none;z-index:0;display:none;
}
[data-theme="dark"] .orb{display:block}
.orb-1{width:400px;height:400px;background:rgba(34,211,238,0.06);top:10%;left:-5%}
.orb-2{width:500px;height:500px;background:rgba(167,139,250,0.06);top:20%;right:-10%}
.orb-3{width:300px;height:300px;background:rgba(74,222,128,0.04);bottom:10%;left:30%}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:8px;height:10px}
::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:5px}
::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:5px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover);border:2px solid transparent;background-clip:padding-box}

/* ── Tooltip (shared across tool pages) ── */
.tooltip{
    position:fixed;z-index:10000;
    pointer-events:none;
    background:var(--tooltip-bg);
    border:1px solid var(--border);
    border-radius:8px;
    padding:6px 12px;
    font-size:11px;font-weight:500;
    color:var(--text);
    line-height:1.4;max-width:260px;
    box-shadow:var(--tooltip-shadow);
    opacity:0;transition:opacity 0.15s;
    white-space:normal;
}
.tooltip.visible{opacity:1}

/* ── Shared toast ── */
.toast{
    position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);
    background:var(--surface);color:var(--cyan);border:1px solid var(--cyan);
    padding:10px 24px;border-radius:var(--radius);font-size:0.9rem;z-index:9999;
    transition:transform 0.3s,opacity 0.3s;opacity:0;pointer-events:none;
}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ── Shared modal ── */
.modal-backdrop{
    position:fixed;inset:0;z-index:500;
    background:var(--modal-overlay);backdrop-filter:blur(4px);
}
.modal-backdrop.hidden{display:none}
.modal{
    position:fixed;z-index:510;top:50%;left:50%;transform:translate(-50%,-50%);
    background:var(--surface);border:1px solid var(--border);border-radius:12px;
    min-width:380px;max-width:500px;max-height:80vh;box-shadow:var(--shadow-xl);
}
.modal.hidden{display:none}
.modal-sm{min-width:320px;max-width:400px}
.modal-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 20px;border-bottom:1px solid var(--border);
}
.modal-header h2{font-size:16px;font-weight:600}
.modal-close{
    background:none;border:none;color:var(--dim);font-size:22px;
    cursor:pointer;padding:0 4px;line-height:1;
}
.modal-close:hover{color:var(--text)}
.modal-body{padding:16px 20px;overflow-y:auto;max-height:60vh}
.modal-footer{
    padding:12px 20px;border-top:1px solid var(--border);
    display:flex;justify-content:flex-end;gap:8px;
}
.modal-input{
    width:100%;padding:8px 10px;background:var(--surface2);
    border:1px solid var(--border);color:var(--text);border-radius:var(--radius);
    font-size:13px;font-family:inherit;outline:none;
}
.modal-input:focus{border-color:var(--cyan)}

/* ── Hidden utility ── */
.hidden{display:none!important}

/* ── Full nav (content pages) ── */
nav.nav-full{
    position:sticky;top:0;height:auto;
    flex-direction:column;padding:0;
    align-items:stretch;
}
.nav-full-top{
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 24px 8px;
}
.nav-brand{
    font-size:32px;font-weight:900;letter-spacing:3px;
    background:var(--gradient-primary);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;text-decoration:none;transition:opacity 0.2s;
}
.nav-brand:hover{opacity:0.85}
.nav-full-top-right{display:flex;align-items:center;gap:8px}
.nav-hamburger{
    display:none;background:none;border:none;
    color:var(--dim);cursor:pointer;padding:4px;
}
.nav-hamburger svg:last-child{display:none}
.nav-hamburger.is-open svg:first-child{display:none}
.nav-hamburger.is-open svg:last-child{display:block}
.nav-bar{
    display:flex;align-items:center;justify-content:center;
    gap:8px;padding:0 24px 12px;flex-wrap:wrap;
}
.nav-bar-btn{
    display:inline-flex;align-items:center;gap:6px;
    padding:9px 20px;border-radius:8px;
    font-size:14px;font-weight:600;
    background:var(--surface2);border:1px solid var(--border);
    color:var(--text);text-decoration:none;
    transition:all 0.2s;cursor:pointer;font-family:inherit;
}
.nav-bar-btn:hover{
    border-color:var(--cyan);color:var(--cyan);
    transform:translateY(-2px);
    box-shadow:0 4px 16px rgba(8,145,178,0.12);
}
.nav-bar-btn:active{transform:translateY(0) scale(0.97)}
[data-theme="dark"] .nav-bar-btn:hover{box-shadow:0 4px 16px rgba(34,211,238,0.2)}
.nav-bar-btn.tour-btn{border-color:var(--purple);color:var(--purple);background:var(--purple-bg)}
.nav-bar-btn.tour-btn:hover{box-shadow:0 4px 16px rgba(124,58,237,0.15)}
[data-theme="dark"] .nav-bar-btn.tour-btn:hover{box-shadow:0 4px 16px rgba(167,139,250,0.25)}
.nav-bar-btn.support-btn{border-color:var(--pink);color:var(--pink);background:var(--pink-bg)}
.nav-bar-btn.support-btn:hover{box-shadow:0 4px 16px rgba(225,29,99,0.12)}
nav.nav-full .nav-dropdown-trigger{
    display:inline-flex;align-items:center;gap:6px;
    padding:9px 20px;border-radius:8px;font-size:14px;font-weight:600;
    background:var(--surface2);border:1px solid var(--border);
    color:var(--text);cursor:pointer;transition:all 0.2s;font-family:inherit;
}
nav.nav-full .nav-dropdown-trigger:hover{
    border-color:var(--cyan);color:var(--cyan);
    transform:translateY(-2px);box-shadow:0 4px 16px rgba(8,145,178,0.12);
}
.nav-dropdown-menu.nav-dropdown-open{display:block}
.tour-pulse{animation:tour-pulse 2s ease-in-out infinite}
@keyframes tour-pulse{
    0%,100%{box-shadow:0 0 0 0 rgba(124,58,237,0.4)}
    50%{box-shadow:0 0 0 8px rgba(124,58,237,0)}
}
[data-theme="dark"] .tour-pulse{animation:tour-pulse-dark 2s ease-in-out infinite}
@keyframes tour-pulse-dark{
    0%,100%{box-shadow:0 0 0 0 rgba(167,139,250,0.4)}
    50%{box-shadow:0 0 0 8px rgba(167,139,250,0)}
}

/* ── Tour overlay ── */
.tour-overlay{
    position:fixed;inset:0;z-index:10000;
    background:var(--modal-overlay);backdrop-filter:blur(8px);
    display:flex;align-items:center;justify-content:center;
    animation:tour-fade-in 0.3s ease;
}
@keyframes tour-fade-in{from{opacity:0}to{opacity:1}}
.tour-card{
    background:var(--surface);border:1px solid var(--border);
    border-radius:16px;padding:40px 32px 24px;
    max-width:440px;width:90%;text-align:center;
    position:relative;box-shadow:var(--shadow-xl);
}
.tour-close{
    position:absolute;top:12px;right:16px;
    background:none;border:none;color:var(--dim);
    font-size:22px;cursor:pointer;padding:4px 8px;transition:color 0.2s;
}
.tour-close:hover{color:var(--text)}
.tour-slide{animation:tour-slide-in 0.25s ease}
@keyframes tour-slide-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.tour-icon{
    width:72px;height:72px;border-radius:16px;
    display:flex;align-items:center;justify-content:center;
    font-size:36px;margin:0 auto 16px;background:var(--surface2);
}
.tour-name{font-size:22px;font-weight:800;margin-bottom:8px;color:var(--card-title)}
.tour-desc{font-size:14px;color:var(--dim);line-height:1.6;margin-bottom:20px}
.tour-try{
    display:inline-flex;align-items:center;gap:6px;
    padding:10px 24px;border-radius:8px;font-size:14px;font-weight:600;
    background:var(--gradient-primary);color:#fff;
    text-decoration:none;transition:all 0.2s;margin-bottom:24px;
}
[data-theme="dark"] .tour-try{color:#000}
.tour-try:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(8,145,178,0.25)}
.tour-nav{display:flex;align-items:center;justify-content:space-between;gap:12px}
.tour-arrow{
    background:var(--surface2);border:1px solid var(--border);
    border-radius:8px;padding:8px 16px;
    color:var(--text);font-size:14px;font-weight:600;
    cursor:pointer;transition:all 0.2s;font-family:inherit;
}
.tour-arrow:hover{border-color:var(--cyan);color:var(--cyan)}
.tour-arrow:disabled{opacity:0.3;cursor:default}
.tour-arrow:disabled:hover{border-color:var(--border);color:var(--text)}
.tour-dots{display:flex;gap:6px;align-items:center}
.tour-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all 0.2s}
.tour-dot.active{background:var(--cyan);width:20px;border-radius:4px}
.tour-progress{font-size:11px;color:var(--dim);margin-top:12px}

/* ── Tour continue FAB ── */
.tour-fab{
    position:fixed;bottom:24px;left:24px;z-index:9000;
    display:inline-flex;align-items:center;gap:8px;
    padding:12px 20px;border-radius:12px;
    font-size:14px;font-weight:600;
    background:var(--surface);border:1px solid var(--purple);
    color:var(--purple);cursor:pointer;
    box-shadow:var(--shadow-lg);
    transition:all 0.25s;font-family:inherit;
    animation:tour-fab-in 0.4s ease;
}
.tour-fab:hover{
    transform:translateY(-3px);
    box-shadow:0 8px 32px rgba(124,58,237,0.25);
    border-color:var(--cyan);color:var(--cyan);
}
.tour-fab-badge{
    background:var(--purple-bg);
    padding:2px 8px;border-radius:6px;
    font-size:11px;font-weight:700;
}
@keyframes tour-fab-in{
    from{opacity:0;transform:translateY(20px)}
    to{opacity:1;transform:translateY(0)}
}

/* ── Responsive ── */
@media(max-width:768px){
    nav{padding:0 16px;height:52px}
    .nav-links{gap:12px}
    .nav-links a,.nav-right>a{font-size:12px}
    .nav-right{gap:10px}
    .nav-dropdown-trigger{font-size:12px}
    nav.nav-full{height:auto;padding:0}
    nav.nav-full .nav-full-top{padding:12px 16px 8px}
    nav.nav-full .nav-brand{font-size:24px;letter-spacing:2px}
    nav.nav-full .nav-hamburger{display:block}
    nav.nav-full .nav-bar{display:none;flex-direction:column;padding:0 16px 12px;gap:4px}
    nav.nav-full .nav-bar.nav-bar-open{display:flex}
    nav.nav-full .nav-bar-btn{width:100%;justify-content:center}
    nav.nav-full .nav-dropdown{width:100%}
    nav.nav-full .nav-dropdown-trigger{width:100%;justify-content:center}
    nav.nav-full .nav-dropdown-menu{position:static;transform:none;width:100%;border-radius:8px;margin-top:4px}
    .section{padding:48px 16px}
    .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
    .stats-bar{flex-direction:column}
    .stat{border-right:none;border-bottom:1px solid var(--border)}
    .stat:last-child{border-bottom:none}
    .rec-grid{grid-template-columns:1fr}
    .tour-card{padding:28px 20px 20px}
    .tour-icon{width:56px;height:56px;font-size:28px}
    .tour-name{font-size:18px}
}
@media(max-width:480px){
    .footer-grid{grid-template-columns:1fr}
    .footer-bottom{flex-direction:column;text-align:center}
    .card-grid{grid-template-columns:1fr}
    .features{grid-template-columns:1fr}
    .nav-right{gap:4px}
    .nav-right>a{font-size:11px}
    .nav-dropdown-trigger{font-size:11px}
    .nav-btn{padding:4px 8px;font-size:11px}
    .nav-dropdown-menu{min-width:150px;left:auto;right:0;transform:none}
}
