/* ═══════════════════════════════════════════════════
   Fools.gg — Main Stylesheet
   ═══════════════════════════════════════════════════ */

:root {
    --primary: #7C3AED;
    --primary-rgb: 124,58,237;
    --primary-dark: #5B21B6;
    --neon-green: #22D3EE;
    --neon-pink: #F472B6;
    --neon-yellow: #FBBF24;
    --bg: #0C0A14;
    --bg-lighter: #110E1A;
    --card: #16131F;
    --card-hover: #1C1829;
    --card-border: #221E2E;
    --text: #EDECF2;
    --text-secondary: #C4C1D0;
    --muted: #8B87A0;
    --dim: #5A5670;
    --green: #34D399;
    --red: #EF4444;
    --yellow: #F59E0B;
    --radius: 14px;
    --radius-sm: 10px;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body { font-family:'Space Grotesk',sans-serif; background:var(--bg); color:var(--text); line-height:1.6; overflow-x:hidden; }
a { color:inherit; text-decoration:none; }

/* ── Navbar ── */
.nav { position:fixed; top:0; left:0; right:0; z-index:1000; padding:14px 24px; background:rgba(12,10,20,0.85); backdrop-filter:blur(20px); border-bottom:1px solid rgba(34,30,46,0.5); }
.nav-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; }
.nav-logo { font-size:22px; font-weight:800; letter-spacing:-0.5px; }
.nav-logo span { color:var(--primary); }
.nav-links { display:flex; gap:28px; }
.nav-links a { font-size:14px; color:var(--muted); font-weight:500; transition:color 0.2s; }
.nav-links a:hover { color:var(--text); }
.nav-actions { display:flex; align-items:center; gap:10px; }
.btn-nav { padding:8px 18px; border-radius:10px; font-size:13px; font-weight:600; transition:all 0.2s; display:inline-flex; align-items:center; }
.btn-nav-outline { border:1px solid var(--card-border); color:var(--muted); }
.btn-nav-outline:hover { border-color:var(--primary); color:var(--text); }
.btn-nav-primary { background:var(--primary); color:white; }
.btn-nav-primary:hover { background:var(--primary-dark); transform:translateY(-1px); }
.nav-avatar { width:34px; height:34px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:700; background:var(--user-colour, var(--primary)); color:white; }
.nav-hamburger { display:none; background:none; border:none; color:var(--text); font-size:22px; cursor:pointer; }

@media (max-width:768px) {
    .nav-links { display:none; position:absolute; top:60px; left:0; right:0; background:var(--card); border-bottom:1px solid var(--card-border); flex-direction:column; padding:16px 24px; gap:12px; }
    .nav-links.open { display:flex; }
    .nav-hamburger { display:block; }
}

/* ── Hero ── */
.hero { min-height:100vh; display:flex; align-items:center; justify-content:center; text-align:center; padding:120px 24px 80px; position:relative; overflow:hidden; }
.hero-bg-effects { position:absolute; inset:0; pointer-events:none; }
.hero-orb { position:absolute; border-radius:50%; filter:blur(100px); opacity:0.15; }
.hero-orb-1 { width:600px; height:600px; background:var(--primary); top:-200px; left:-100px; animation:orb-float 12s ease-in-out infinite; }
.hero-orb-2 { width:400px; height:400px; background:var(--neon-green); bottom:-100px; right:-100px; animation:orb-float 10s ease-in-out infinite reverse; }
.hero-orb-3 { width:300px; height:300px; background:var(--neon-pink); top:50%; left:50%; transform:translate(-50%,-50%); animation:orb-float 14s ease-in-out infinite; }
@keyframes orb-float { 0%,100%{ transform:translate(0,0); } 33%{ transform:translate(30px,-20px); } 66%{ transform:translate(-20px,30px); } }

.hero-content { position:relative; z-index:1; max-width:700px; }
.hero-badge { display:inline-flex; padding:8px 18px; border-radius:50px; font-size:13px; font-weight:600; background:rgba(var(--primary-rgb),0.1); border:1px solid rgba(var(--primary-rgb),0.2); color:var(--primary); margin-bottom:24px; letter-spacing:0.3px; }
.hero h1 { font-size:clamp(36px,6vw,64px); font-weight:800; line-height:1.1; letter-spacing:-2px; margin-bottom:20px; }
.hero-gradient { background:linear-gradient(135deg, var(--primary), var(--neon-green)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.hero-sub { font-size:17px; color:var(--muted); max-width:540px; margin:0 auto 32px; line-height:1.6; }
.hero-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-bottom:48px; }
.btn-hero { padding:14px 28px; border-radius:12px; font-size:15px; font-weight:600; transition:all 0.2s; display:inline-flex; align-items:center; gap:8px; }
.btn-hero-primary { background:linear-gradient(135deg, var(--primary), var(--primary-dark)); color:white; }
.btn-hero-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(var(--primary-rgb),0.35); }
.btn-hero-outline { border:1px solid var(--card-border); color:var(--text-secondary); background:rgba(255,255,255,0.03); }
.btn-hero-outline:hover { border-color:var(--primary); background:rgba(var(--primary-rgb),0.05); }
.hero-stats { display:flex; justify-content:center; gap:48px; }
.hero-stat { text-align:center; }
.hero-stat-num { display:block; font-size:28px; font-weight:800; letter-spacing:-1px; }
.hero-stat-label { font-size:12px; color:var(--dim); text-transform:uppercase; letter-spacing:0.5px; }

/* ── Sections ── */
.section { padding:100px 24px; }
.section-dark { background:var(--bg-lighter); }
.section-inner { max-width:1100px; margin:0 auto; }
.section-head { text-align:center; margin-bottom:52px; }
.section-badge { display:inline-flex; padding:6px 16px; border-radius:50px; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; background:rgba(var(--primary-rgb),0.1); color:var(--primary); margin-bottom:16px; }
.section-head h2 { font-size:clamp(28px,4vw,42px); font-weight:800; letter-spacing:-1px; }
.section-sub { font-size:16px; color:var(--muted); margin-top:10px; max-width:500px; margin-left:auto; margin-right:auto; }

/* ── How It Works ── */
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:768px) { .steps-grid { grid-template-columns:1fr; } }
.step-card { background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius); padding:32px; text-align:center; position:relative; transition:all 0.3s; }
.step-card:hover { border-color:rgba(var(--primary-rgb),0.3); transform:translateY(-4px); }
.step-num { font-size:48px; font-weight:800; color:rgba(var(--primary-rgb),0.1); position:absolute; top:16px; right:20px; line-height:1; }
.step-icon { font-size:36px; margin-bottom:16px; }
.step-card h3 { font-size:18px; font-weight:700; margin-bottom:8px; }
.step-card p { font-size:14px; color:var(--muted); line-height:1.6; }

/* ── Game Cards ── */
.games-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); gap:18px; }
.game-card { background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius); padding:24px; transition:all 0.3s; cursor:default; position:relative; overflow:hidden; }
.game-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--game-accent); opacity:0; transition:opacity 0.3s; }
.game-card:hover { border-color:rgba(var(--primary-rgb),0.3); transform:translateY(-4px); }
.game-card:hover::before { opacity:1; }
.game-card-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.game-category { font-size:12px; color:var(--muted); font-weight:600; }
.game-tier-badge { font-size:10px; font-weight:700; padding:3px 10px; border-radius:6px; text-transform:uppercase; letter-spacing:0.4px; }
.tier-free { background:rgba(52,211,153,0.1); color:var(--green); }
.tier-starter { background:rgba(245,158,11,0.1); color:var(--yellow); }
.tier-pro { background:rgba(124,58,237,0.1); color:var(--primary); }
.game-card-title { font-size:18px; font-weight:700; margin-bottom:8px; letter-spacing:-0.3px; }
.game-card-desc { font-size:13px; color:var(--muted); line-height:1.6; margin-bottom:16px; }
.game-card-footer { display:flex; justify-content:space-between; align-items:center; }
.game-players { font-size:12px; color:var(--dim); font-weight:500; }

/* ── Pricing ── */
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:900px; margin:0 auto; }
@media (max-width:900px) { .pricing-grid { grid-template-columns:1fr; max-width:380px; } }
.price-card { background:var(--card); border:1px solid var(--card-border); border-radius:18px; padding:32px; position:relative; transition:all 0.3s; }
.price-card:hover { border-color:rgba(var(--primary-rgb),0.3); }
.price-card-featured { border-color:var(--primary); background:linear-gradient(180deg, rgba(var(--primary-rgb),0.06) 0%, var(--card) 100%); }
.price-popular { position:absolute; top:-12px; left:50%; transform:translateX(-50%); padding:4px 16px; border-radius:50px; font-size:11px; font-weight:700; background:var(--primary); color:white; white-space:nowrap; letter-spacing:0.3px; }
.price-card-header { margin-bottom:24px; }
.price-card-header h3 { font-size:20px; font-weight:700; margin-bottom:8px; }
.price-amount { font-size:36px; font-weight:800; letter-spacing:-1px; }
.price-amount span { font-size:14px; font-weight:400; color:var(--muted); }
.price-yearly { font-size:12px; color:var(--dim); margin-top:4px; }
.price-features { list-style:none; margin-bottom:24px; }
.price-features li { font-size:13px; color:var(--text-secondary); padding:6px 0; border-bottom:1px solid rgba(var(--primary-rgb),0.05); }
.price-features li:last-child { border-bottom:none; }
.btn-price { display:block; width:100%; padding:12px; border-radius:12px; font-size:14px; font-weight:600; text-align:center; transition:all 0.2s; }
.btn-price-outline { border:1px solid var(--card-border); color:var(--text-secondary); }
.btn-price-outline:hover { border-color:var(--primary); color:var(--text); }
.btn-price-primary { background:linear-gradient(135deg, var(--primary), var(--primary-dark)); color:white; border:none; }
.btn-price-primary:hover { transform:translateY(-2px); box-shadow:0 6px 24px rgba(var(--primary-rgb),0.35); }

/* ── CTA ── */
.section-cta { background:linear-gradient(180deg, var(--bg) 0%, rgba(var(--primary-rgb),0.05) 100%); padding:80px 24px; }

/* ── Footer ── */
.footer { border-top:1px solid var(--card-border); padding:48px 24px 0; }
.footer-inner { max-width:1100px; margin:0 auto; display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.footer-logo { font-size:20px; font-weight:800; margin-bottom:8px; }
.footer-left p { font-size:13px; color:var(--dim); max-width:280px; line-height:1.6; }
.footer-links { display:flex; gap:48px; }
.footer-col h4 { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--muted); margin-bottom:12px; }
.footer-col a { display:block; font-size:13px; color:var(--dim); margin-bottom:8px; transition:color 0.2s; }
.footer-col a:hover { color:var(--text); }
.footer-bottom { max-width:1100px; margin:32px auto 0; padding:20px 0; border-top:1px solid var(--card-border); text-align:center; font-size:12px; color:var(--dim); }

/* ── Auth Pages (Login/Register) ── */
.auth-page { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:20px; position:relative; }
.auth-page::before { content:''; position:fixed; top:-50%; left:-50%; width:200%; height:200%; background:radial-gradient(circle at 30% 30%, rgba(var(--primary-rgb),0.06) 0%, transparent 50%), radial-gradient(circle at 70% 70%, rgba(34,211,238,0.03) 0%, transparent 50%); pointer-events:none; }
.auth-container { width:100%; max-width:440px; position:relative; z-index:1; }
.auth-card { background:var(--card); border:1px solid var(--card-border); border-radius:20px; padding:36px; position:relative; overflow:hidden; }
.auth-card::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg, transparent, rgba(var(--primary-rgb),0.3), transparent); }
.auth-header { text-align:center; margin-bottom:28px; }
.auth-header .auth-logo { font-size:28px; font-weight:800; margin-bottom:4px; }
.auth-header .auth-logo span { color:var(--primary); }
.auth-header h2 { font-size:22px; font-weight:700; margin-bottom:4px; }
.auth-header p { font-size:13px; color:var(--muted); }
.auth-error { padding:12px 16px; border-radius:var(--radius-sm); font-size:13px; margin-bottom:20px; background:rgba(239,68,68,0.1); border:1px solid rgba(239,68,68,0.2); color:#fca5a5; }
.auth-success { padding:12px 16px; border-radius:var(--radius-sm); font-size:13px; margin-bottom:20px; background:rgba(52,211,153,0.1); border:1px solid rgba(52,211,153,0.2); color:var(--green); }
.fg { margin-bottom:18px; }
.fg label { display:block; font-size:11px; font-weight:600; color:var(--muted); margin-bottom:6px; text-transform:uppercase; letter-spacing:0.6px; }
.fg input[type="text"], .fg input[type="password"], .fg input[type="email"], .fg input[type="url"], .fg input[type="number"] {
    width:100%; padding:13px 16px; background:var(--bg); border:1px solid var(--card-border); border-radius:12px;
    color:var(--text); font-size:14px; font-family:inherit; transition:all 0.2s;
}
.fg input:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px rgba(var(--primary-rgb),0.15); }
.fg input::placeholder { color:var(--dim); }
.fg .hint { font-size:11px; color:var(--dim); margin-top:4px; }
.row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.btn-auth { display:block; width:100%; padding:14px; border:none; border-radius:12px; font-family:inherit; font-size:14px; font-weight:600; cursor:pointer; transition:all 0.2s; background:linear-gradient(135deg, var(--primary), var(--primary-dark)); color:white; margin-top:8px; }
.btn-auth:hover { transform:translateY(-1px); box-shadow:0 6px 24px rgba(var(--primary-rgb),0.35); }
.auth-footer { text-align:center; margin-top:20px; font-size:13px; color:var(--dim); }
.auth-footer a { color:var(--primary); font-weight:600; }
.auth-footer a:hover { text-decoration:underline; }

/* ── Colour Picker ── */
.colour-picker { display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }
.colour-dot { width:36px; height:36px; border-radius:50%; cursor:pointer; border:3px solid transparent; transition:all 0.2s; position:relative; }
.colour-dot:hover { transform:scale(1.15); }
.colour-dot.selected { border-color:var(--text); box-shadow:0 0 0 2px var(--bg), 0 0 0 4px rgba(255,255,255,0.3); transform:scale(1.15); }
.colour-dot input { position:absolute; opacity:0; pointer-events:none; }

/* ── Avatar Creator ── */
.avatar-creator { text-align:center; padding:24px; }
.avatar-upload-zone { width:160px; height:160px; border-radius:50%; border:3px dashed var(--card-border); display:flex; align-items:center; justify-content:center; flex-direction:column; cursor:pointer; margin:0 auto 20px; transition:all 0.3s; overflow:hidden; position:relative; background:var(--bg); }
.avatar-upload-zone:hover { border-color:var(--primary); background:rgba(var(--primary-rgb),0.03); }
.avatar-upload-zone.has-image { border-style:solid; border-color:var(--green); }
.avatar-upload-zone img { width:100%; height:100%; object-fit:cover; }
.avatar-upload-icon { font-size:32px; margin-bottom:4px; }
.avatar-upload-text { font-size:12px; color:var(--muted); }
.avatar-preview-container { display:flex; align-items:center; justify-content:center; gap:32px; margin:24px 0; flex-wrap:wrap; }
.avatar-preview { width:120px; height:120px; border-radius:50%; border:3px solid var(--card-border); display:flex; align-items:center; justify-content:center; overflow:hidden; background:var(--bg); }
.avatar-arrow { font-size:24px; color:var(--dim); }
.btn-skip { display:block; width:100%; padding:12px; border:none; border-radius:12px; font-family:inherit; font-size:13px; font-weight:500; cursor:pointer; background:var(--card-border); color:var(--muted); margin-top:10px; transition:all 0.2s; }
.btn-skip:hover { color:var(--text); background:var(--dim); }

/* ── Profile Page ── */
.profile-page { padding:100px 24px 60px; max-width:900px; margin:0 auto; }
.profile-header { display:flex; align-items:center; gap:24px; margin-bottom:36px; flex-wrap:wrap; }
.profile-avatar { width:100px; height:100px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:36px; font-weight:800; color:white; border:3px solid rgba(255,255,255,0.1); }
.profile-info h1 { font-size:28px; font-weight:800; letter-spacing:-0.5px; }
.profile-info .profile-tag { font-size:13px; color:var(--dim); }
.profile-stats { display:flex; gap:24px; margin-top:8px; }
.profile-stats .ps { font-size:13px; color:var(--muted); }
.profile-stats .ps strong { color:var(--text); font-weight:700; }
.profile-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
@media (max-width:768px) { .profile-grid { grid-template-columns:1fr; } }
.profile-card { background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius); padding:24px; }
.profile-card h3 { font-size:16px; font-weight:700; margin-bottom:16px; }
