:root {
    --bg: #F5F5F7;
    --text: #121212;
    --muted: #555;
    --red: #E31B23;
    --red-h: #C1151B;
    --glass-bg: rgba(255,255,255,0.45);
    --glass-border: rgba(255,255,255,0.35);
    --glass-card: rgba(255,255,255,0.55);
    --shadow: 0 8px 32px rgba(0,0,0,0.06);
    --shadow-red: 0 10px 30px rgba(227,27,35,0.25);
    --bg-hover: rgba(0,0,0,0.05);
    --border-subtle: rgba(0,0,0,0.04);
    --border-input: rgba(0,0,0,0.08);
    --settings-bg: rgba(0,0,0,0.02);
    --dropdown-bg: rgba(255,255,255,0.9);
}

[data-theme="dark"] {
    --bg: #0f0f0f;
    --text: #f0f0f0;
    --muted: #888;
    --red: #E31B23;
    --red-h: #ff3b43;
    --glass-bg: rgba(30,30,30,0.55);
    --glass-border: rgba(255,255,255,0.06);
    --glass-card: rgba(30,30,30,0.65);
    --shadow: 0 8px 32px rgba(0,0,0,0.35);
    --shadow-red: 0 10px 30px rgba(227,27,35,0.3);
    --bg-hover: rgba(255,255,255,0.08);
    --border-subtle: rgba(255,255,255,0.06);
    --border-input: rgba(255,255,255,0.1);
    --settings-bg: rgba(255,255,255,0.04);
    --dropdown-bg: rgba(25,25,25,0.95);
}

*{margin:0;padding:0;box-sizing:border-box;font-family:'Inter',-apple-system,sans-serif}
body{background:var(--bg);color:var(--text);overflow-x:hidden;transition:background 0.3s,color 0.3s}

/* 3D Canvas - full width, behind everything, always visible */
#three-canvas{
    position:fixed;top:0;left:0;width:100%;height:100%;
    z-index:0;pointer-events:none;opacity:0.5;
}

/* BG Shapes */
.bg-shape{position:fixed;border-radius:50%;filter:blur(120px);z-index:0;opacity:.4;pointer-events:none}
.shape-1{width:500px;height:500px;background:radial-gradient(circle,rgba(227,27,35,.1) 0%,transparent 70%);top:-80px;right:-80px}
.shape-2{width:400px;height:400px;background:radial-gradient(circle,rgba(227,27,35,.07) 0%,transparent 70%);top:60%;left:-150px}
.shape-3{width:500px;height:500px;background:radial-gradient(circle,rgba(0,0,0,.02) 0%,transparent 70%);bottom:-50px;right:15%}

/* Scroll Reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.25,.8,.25,1),transform .7s cubic-bezier(.25,.8,.25,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Common - NO solid backgrounds, transparent sections */
.section-padding{padding:120px 5%;position:relative;z-index:1}
.section-header{text-align:center;margin-bottom:70px}
.section-header h2{font-size:44px;font-weight:800;letter-spacing:-1.5px;margin-bottom:15px}
.section-header p{font-size:18px;color:var(--muted)}

/* Glass effect for cards */
.glass{
    background:var(--glass-card);
    backdrop-filter:blur(24px);
    -webkit-backdrop-filter:blur(24px);
    border:1px solid var(--glass-border);
    box-shadow:var(--shadow);
    border-radius:24px;
}

/* Buttons */
.btn{padding:12px 24px;border-radius:50px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);border:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-h);transform:translateY(-2px);box-shadow:var(--shadow-red)}
.btn-glow{box-shadow:var(--shadow-red)}
.btn-outline{background:rgba(255,255,255,0.5);backdrop-filter:blur(10px);color:var(--red);border:2px solid var(--red)}
.btn-outline:hover{background:rgba(227,27,35,.05);transform:translateY(-2px)}

/* Header */
.header{display:flex;justify-content:space-between;align-items:center;padding:16px 5%;position:fixed;top:0;width:100%;z-index:100;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);transition:background 0.3s}
.logo-container{display:flex;align-items:center;gap:12px}
.logo-icon{display:flex;align-items:center}
.logo-img{height:44px;width:auto;object-fit:contain}
.brand-name{font-size:24px;font-weight:800;letter-spacing:-.5px}
.nav-menu{display:flex;gap:40px}
.nav-menu a{text-decoration:none;color:var(--muted);font-weight:600;transition:color .3s;font-size:15px}
.nav-menu a:hover{color:var(--red)}
.header-actions{display:flex;gap:10px}
.btn-login-outline{background:transparent;color:var(--text);font-size:14px;padding:10px 20px;border:none;cursor:pointer;border-radius:50px;font-weight:600;transition:all .3s}
.btn-login-outline:hover{background:var(--bg-hover)}
.btn-login-primary{background:var(--red);color:#fff;font-size:14px;padding:10px 24px;border-radius:50px;font-weight:600;border:none;cursor:pointer;transition:all .3s}
.btn-login-primary:hover{background:var(--red-h);box-shadow:var(--shadow-red);transform:translateY(-1px)}

/* Hero - Full Viewport */
.hero{min-height:100vh;display:flex;align-items:center;padding:0 5%;position:relative;z-index:1}
.hero-content{max-width:650px;position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(227,27,35,.06);backdrop-filter:blur(10px);border:1px solid rgba(227,27,35,.15);padding:8px 18px;border-radius:50px;font-size:14px;font-weight:500;color:var(--red);margin-bottom:30px}
.badge-dot{width:8px;height:8px;border-radius:50%;background:var(--red);animation:pulse 1.5s infinite}
.hero-title{font-size:76px;font-weight:900;line-height:1.02;margin-bottom:25px;letter-spacing:-3px}
.text-red{color:var(--red)}
.hero-subtitle{font-size:22px;color:var(--muted);margin-bottom:50px;line-height:1.6;font-weight:400}
.hero-buttons{display:flex;gap:20px}
.hero-buttons .btn{padding:18px 36px;font-size:18px}
.hero-3d-space{flex:1}

/* Scroll Indicator */
.scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;opacity:.4;animation:float 2s ease-in-out infinite}
.mouse{width:26px;height:42px;border:2px solid var(--text);border-radius:13px;position:relative}
.mouse-wheel{width:4px;height:9px;background:var(--text);border-radius:2px;position:absolute;top:8px;left:50%;transform:translateX(-50%);animation:scroll-wheel 1.5s infinite}
.scroll-indicator span{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
@keyframes scroll-wheel{0%{opacity:1;transform:translateX(-50%) translateY(0)}100%{opacity:0;transform:translateX(-50%) translateY(10px)}}
@keyframes float{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-6px)}}

/* Features - Centered, glass cards */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:30px}
.feature-card{padding:45px 35px;text-align:center;position:relative;overflow:hidden;transition:transform .4s,box-shadow .4s}
.feature-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px rgba(0,0,0,.1)}
.feature-icon{font-size:28px;color:var(--red);margin:0 auto 25px;display:flex;align-items:center;justify-content:center;width:70px;height:70px;background:rgba(227,27,35,.06);border-radius:20px}
.feature-card h3{font-size:22px;margin-bottom:15px;font-weight:700;letter-spacing:-.5px}
.feature-card p{color:var(--muted);line-height:1.7;font-size:15px}

/* Timeline - glass cards */
.timeline{display:flex;gap:30px;position:relative}
.timeline::before{content:'';position:absolute;top:30px;left:5%;right:5%;height:2px;background:rgba(227,27,35,.15);z-index:0}
.timeline-item{flex:1;padding:40px 30px;text-align:center;position:relative;z-index:1}
.step-number{width:60px;height:60px;background:var(--red);color:#fff;font-size:24px;font-weight:800;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 30px;box-shadow:var(--shadow-red);border:4px solid rgba(255,255,255,0.6)}
.step-content h3{font-size:22px;margin-bottom:15px;font-weight:700}
.step-content p{color:var(--muted);line-height:1.6}

/* FAQ - glass cards */
.faq-container{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:15px}
.faq-item{padding:25px 30px;cursor:pointer;transition:all .3s}
.faq-question{font-size:18px;font-weight:600;display:flex;justify-content:space-between;align-items:center}
.faq-question i{transition:transform .3s;color:var(--red)}
.faq-item.active .faq-question i{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s,margin-top .4s}
.faq-item.active .faq-answer{max-height:200px;margin-top:15px}
.faq-answer p{color:var(--muted);line-height:1.6}

/* Footer - glass style */
.footer{
    padding:80px 5% 30px;
    border-top:1px solid var(--border-subtle);
    position:relative;z-index:1;
    background:var(--glass-bg);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    transition:background 0.3s;
}
.footer-content{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
.footer-brand p{color:var(--muted);line-height:1.6;max-width:300px}
.footer-links h4,.footer-social h4{font-size:18px;font-weight:700;margin-bottom:20px}
.footer-links a{display:block;color:var(--muted);text-decoration:none;margin-bottom:12px;transition:color .3s}
.footer-links a:hover{color:var(--red)}
.social-icons{display:flex;gap:15px}
.social-icons a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--glass-bg);backdrop-filter:blur(10px);color:var(--text);border-radius:50%;text-decoration:none;transition:all .3s;border:1px solid var(--border-subtle)}
.social-icons a:hover{background:var(--red);color:#fff;transform:translateY(-3px);border-color:var(--red)}
.footer-bottom{text-align:center;padding-top:30px;border-top:1px solid var(--border-subtle);color:var(--muted);font-size:14px}

/* Modals */
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);backdrop-filter:blur(10px);z-index:999;opacity:0;visibility:hidden;transition:all .3s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-45%);border-radius:24px;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);z-index:1000;opacity:0;visibility:hidden;transition:all .4s cubic-bezier(.175,.885,.32,1.275);padding:40px}
.modal.active{opacity:1;visibility:visible;transform:translate(-50%,-50%)}
.glass-modal{background:var(--glass-card);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border:1px solid var(--glass-border)}
.close-modal{position:absolute;top:20px;right:20px;background:none;border:none;font-size:24px;color:var(--muted);cursor:pointer;transition:color .3s}
.close-modal:hover{color:var(--red)}

/* Wizard */
#createRoomModal{width:90%;max-width:500px;text-align:center}
.wizard-progress{width:100%;height:6px;background:rgba(0,0,0,.06);border-radius:3px;margin-bottom:35px;overflow:hidden}
.progress-bar{height:100%;width:33.33%;background:var(--red);transition:width .4s}
.wizard-step{display:none;animation:fadeIn .4s forwards}
.wizard-step.active{display:block}
#step3.active{display:flex;flex-direction:column;}
.wizard-step h2{font-size:26px;font-weight:800;margin-bottom:10px;letter-spacing:-.5px}
.wizard-step p{color:var(--muted);margin-bottom:30px}
.clean-input{width:100%;padding:16px 20px;border:2px solid var(--border-input);border-radius:12px;font-size:16px;transition:border-color .3s;outline:none;background:var(--glass-bg);backdrop-filter:blur(10px);color:var(--text)}
.clean-input:focus{border-color:var(--red)}
.input-group{margin-bottom:30px}
.wizard-actions{display:flex;gap:15px;margin-top:30px}
.wizard-actions .btn{flex:1}
.privacy-cards{display:flex;gap:20px;margin-bottom:20px}
.privacy-card{flex:1;padding:25px 20px;border:2px solid var(--border-subtle);border-radius:16px;cursor:pointer;transition:all .3s;background:var(--glass-bg);backdrop-filter:blur(10px)}
.privacy-card:hover{border-color:var(--muted);transform:translateY(-2px)}
.privacy-card.active{border-color:var(--red);background:rgba(227,27,35,.03);box-shadow:0 5px 15px rgba(227,27,35,.1)}
.privacy-card h4{margin-top:15px;font-size:18px;font-weight:700}
.privacy-card span{font-size:13px;color:var(--muted)}
.password-container{max-height:0;overflow:hidden;transition:max-height .4s,opacity .4s;opacity:0}
.password-container.show{max-height:80px;opacity:1;margin-bottom:10px}
.platform-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;margin-bottom:30px}
.platform-item{padding:20px;border:2px solid var(--border-subtle);border-radius:16px;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;transition:all .3s;font-weight:600;background:var(--glass-bg);backdrop-filter:blur(10px);color:var(--text)}
.platform-item i{font-size:36px}
.platform-item:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.06)}
.platform-item.active{border-color:var(--red);box-shadow:0 0 0 1px var(--red),0 8px 20px rgba(227,27,35,.15)}

/* Dashboard */
#joinRoomModal{width:95%;max-width:1050px;max-height:90vh;overflow-y:auto}
.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid rgba(0,0,0,.06)}
.dashboard-header h2{display:flex;align-items:center;gap:12px;font-size:28px;font-weight:800}
.live-pulse{width:12px;height:12px;background:var(--red);border-radius:50%;animation:pulse 1.5s infinite}
.search-box{display:flex;align-items:center;background:var(--glass-bg);backdrop-filter:blur(10px);padding:12px 20px;border-radius:50px;width:320px;transition:all .3s;border:1px solid var(--border-subtle)}
.search-box:focus-within{box-shadow:0 0 0 2px var(--red);border-color:var(--red)}
.search-box i{color:var(--muted);margin-right:12px}
.search-box input{border:none;background:transparent;outline:none;width:100%;font-size:15px;color:var(--text)}
.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:25px}
.room-card{padding:25px;transition:transform .3s,box-shadow .3s}
.room-card:hover{transform:translateY(-5px);box-shadow:0 15px 35px rgba(0,0,0,.1)}
.rc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.platform-badge{font-size:28px}
.rc-stats{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px;background:var(--settings-bg);padding:6px 12px;border-radius:20px}
.live-dot{width:8px;height:8px;background:var(--red);border-radius:50%;animation:blink 1s infinite}
.rc-title{font-size:20px;font-weight:700;margin-bottom:25px;line-height:1.4}
.rc-footer{display:flex;justify-content:space-between;align-items:center}
.avatars{display:flex}
.avatar{width:36px;height:36px;border-radius:50%;border:3px solid rgba(255,255,255,.8);margin-left:-12px;overflow:hidden;background:rgba(0,0,0,.05);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:bold;color:var(--muted)}
.avatar:first-child{margin-left:0}
.avatar img{width:100%;height:100%;object-fit:cover}
.btn-join{padding:10px 20px;border-radius:10px;background:var(--red);color:#fff;font-size:14px;border:none;cursor:pointer;font-weight:700;transition:all .3s}
.btn-join:hover{background:var(--red-h);transform:translateY(-2px);box-shadow:0 5px 15px rgba(227,27,35,.3)}
.btn-private{background:#1A1A1A}
.btn-private:hover{background:#333;box-shadow:0 5px 15px rgba(0,0,0,.2)}

/* Animations */
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(227,27,35,.6)}70%{box-shadow:0 0 0 10px rgba(227,27,35,0)}100%{box-shadow:0 0 0 0 rgba(227,27,35,0)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ===== HAMBURGER MENU ===== */
.hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    border-radius: 12px;
    transition: background 0.2s;
    z-index: 200;
}
.hamburger:hover { background: rgba(0,0,0,0.05); }
.hamburger span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--text);
    border-radius: 2px;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    transform-origin: center;
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile Nav Overlay */
.mobile-nav {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 150;
    background: var(--glass-card);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    opacity: 0;
    transform: translateY(-16px);
    transition: opacity 0.3s, transform 0.3s;
    pointer-events: none;
}
.mobile-nav.open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: all;
}
.mobile-nav a {
    font-size: 28px;
    font-weight: 800;
    color: var(--text);
    text-decoration: none;
    letter-spacing: -0.5px;
    padding: 12px 24px;
    border-radius: 16px;
    transition: color 0.2s, background 0.2s;
}
.mobile-nav a:hover { color: var(--red); background: rgba(227,27,35,0.06); }
.mobile-nav-divider {
    width: 40px;
    height: 2px;
    background: rgba(0,0,0,0.08);
    border-radius: 2px;
    margin: 8px 0;
}
.mobile-nav-auth {
    display: flex;
    gap: 12px;
    margin-top: 8px;
}

/* ===== RESPONSIVE BREAKPOINTS ===== */

/* Large Tablet */
@media(max-width:1024px) {
    .section-padding { padding: 80px 5%; }
    .section-header h2 { font-size: 36px; }
    .hero-title { font-size: 62px; }
    .footer-content { grid-template-columns: 1fr 1fr; gap: 40px; }
    .timeline { flex-direction: column; }
    .timeline::before { display: none; }
    .timeline-item { max-width: 600px; margin: 0 auto; width: 100%; }
}

/* Tablet */
@media(max-width:768px) {
    /* Header - fix layout for mobile */
    .header {
        padding: 14px 5%;
        justify-content: flex-start;
    }
    .nav-menu { display: none; }
    .hamburger {
        display: flex;
        margin-left: auto; /* Push hamburger to the right */
        order: 10;
    }
    .header-actions {
        order: 11;
        gap: 6px;
    }
    .mobile-nav { display: flex; }
    .header-actions #headerAuthButtons { display: none !important; }

    /* Hero */
    .hero {
        flex-direction: column;
        text-align: center;
        padding-top: 96px;
        padding-bottom: 60px;
        min-height: auto;
    }
    .hero-content { max-width: 100%; }
    .hero-title { font-size: 46px; letter-spacing: -2px; }
    .hero-subtitle { font-size: 17px; margin-bottom: 36px; }
    .hero-buttons { justify-content: center; flex-wrap: wrap; gap: 12px; }
    .hero-buttons .btn { padding: 15px 28px; font-size: 16px; }
    .hero-badge { justify-content: center; }
    .hero-3d-space { display: none; }
    .scroll-indicator { display: none; }

    /* Sections */
    .section-padding { padding: 60px 5%; }
    .section-header { margin-bottom: 40px; }
    .section-header h2 { font-size: 30px; letter-spacing: -1px; }
    .section-header p { font-size: 16px; }

    /* Features */
    .features-grid { grid-template-columns: 1fr; gap: 20px; }
    .feature-card { padding: 32px 28px; }

    /* Timeline */
    .timeline { flex-direction: column; gap: 20px; }
    .timeline::before { display: none; }
    .timeline-item { padding: 30px 24px; }
    .step-content h3 { font-size: 18px; }

    /* FAQ */
    .faq-question { font-size: 16px; }

    /* Footer */
    .footer { padding: 50px 5% 24px; }
    .footer-content { grid-template-columns: 1fr; gap: 30px; }
    .footer-brand p { max-width: 100%; }

    /* Modals */
    .modal {
        width: 95% !important;
        max-width: 95% !important;
        padding: 28px 20px !important;
        border-radius: 20px;
        top: 50%;
        max-height: 92vh;
        overflow-y: auto;
    }
    #joinRoomModal { max-height: 90vh; }
    .dashboard-header { flex-direction: column; align-items: flex-start; gap: 14px; }
    .search-box { width: 100%; }
    .room-grid { grid-template-columns: 1fr; }
    .wizard-step h2 { font-size: 22px; }
    .privacy-cards { flex-direction: column; }
    .platform-grid { grid-template-columns: repeat(2, 1fr); }

    /* Auth Modal */
    .auth-modal-inner { padding: 24px 20px; }

    /* Buttons */
    .btn { min-height: 44px; }
    .btn-login-outline, .btn-login-primary { padding: 10px 16px; font-size: 13px; }
}

/* Mobile */
@media(max-width:480px) {
    .header { padding: 12px 4%; }
    .brand-name { font-size: 20px; }
    .logo-img { height: 36px; }

    .hero-title { font-size: 36px; letter-spacing: -1.5px; }
    .hero-subtitle { font-size: 15px; }
    .hero-buttons { flex-direction: column; align-items: stretch; }
    .hero-buttons .btn { width: 100%; justify-content: center; padding: 16px 20px; font-size: 16px; }

    .section-padding { padding: 48px 4%; }
    .section-header h2 { font-size: 26px; }
    .section-header p { font-size: 15px; }

    .feature-card { padding: 28px 20px; }
    .feature-card h3 { font-size: 18px; }
    .feature-icon { width: 60px; height: 60px; font-size: 22px; }

    .timeline-item { padding: 24px 20px; }
    .step-number { width: 50px; height: 50px; font-size: 20px; }

    .faq-item { padding: 20px; }
    .faq-question { font-size: 15px; }

    .footer { padding: 40px 4% 20px; }
    .footer-links h4, .footer-social h4 { font-size: 16px; }

    /* Modals */
    .modal { padding: 24px 16px !important; border-radius: 16px; }
    .wizard-step h2 { font-size: 20px; }
    .wizard-step p { font-size: 14px; }
    .wizard-actions { flex-direction: column; }
    .wizard-actions .btn { width: 100%; }
    .clean-input { padding: 14px 16px; font-size: 15px; }
    .platform-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .platform-item { padding: 16px 10px; }
    .platform-item i { font-size: 28px; }

    /* OTP inputs */
    .otp-digit { width: 44px; height: 54px; font-size: 20px; }
    .otp-inputs { gap: 8px; }

    /* Dashboard */
    .dashboard-header h2 { font-size: 22px; }

    /* Auth */
    .auth-header h2 { font-size: 22px; }
    .auth-social-btns { flex-direction: column; }

    /* Prevent horizontal overflow globally */
    img { max-width: 100%; }
}
