@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ════════════════════════════════════════════════════════════════
   Network Class — Design System
   ════════════════════════════════════════════════════════════════ */

:root {
    --bg-primary:    #000000;
    --bg-secondary:  #080808;
    --bg-tertiary:   #111111;
    --primary:       #ffffff;
    --primary-dim:   #e0e0e0;
    --text-primary:  #ffffff;
    --text-secondary:#a0a0a0;
    --text-tertiary: #606060;
    --border-primary: rgba(255,255,255,0.08);
    --border-secondary:rgba(255,255,255,0.14);
    --border-hover:  rgba(255,255,255,0.22);
    --glass-bg:      rgba(255,255,255,0.04);
    --glass-border:  rgba(255,255,255,0.09);
    --glass-hover:   rgba(255,255,255,0.07);
    --shadow-xs:     0 1px 3px rgba(0,0,0,.6);
    --shadow-sm:     0 2px 10px rgba(0,0,0,.7);
    --shadow-md:     0 6px 24px rgba(0,0,0,.8);
    --shadow-lg:     0 12px 48px rgba(0,0,0,.9);
    --shadow-xl:     0 24px 80px rgba(0,0,0,1);
    --font-family:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --radius-sm:  6px;
    --radius-md:  10px;
    --radius-lg:  14px;
    --radius-xl:  20px;
    --radius-2xl: 28px;
    --radius-full:9999px;
    --transition-fast:  140ms cubic-bezier(.4,0,.2,1);
    --transition-base:  200ms cubic-bezier(.4,0,.2,1);
    --transition-slow:  320ms cubic-bezier(.4,0,.2,1);
    --transition-bounce:420ms cubic-bezier(.68,-.55,.265,1.55);
}

/* ── Reset ── */
*                { box-sizing:border-box; margin:0; padding:0 }
html             { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale }
a                { text-decoration:none; color:inherit; transition:color var(--transition-base) }
input,button,
select,textarea  { font-family:var(--font-family) }

body {
    width:100%; min-height:100vh;
    background:var(--bg-primary);
    color:var(--text-primary);
    font-family:var(--font-family);
    line-height:1.6; overflow-x:hidden;
    font-size:16px; font-weight:400;
    letter-spacing:-0.01em; position:relative;
}

body::before {
    content:''; position:fixed; inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
    background-size:60px 60px;
    pointer-events:none; z-index:0;
}

::-webkit-scrollbar              { width:5px }
::-webkit-scrollbar-track        { background:transparent }
::-webkit-scrollbar-thumb        { background:rgba(255,255,255,.1); border-radius:3px }
::-webkit-scrollbar-thumb:hover  { background:rgba(255,255,255,.2) }

/* ════ LOADING ═══════════════════════════════════════════════ */
.loading {
    position:fixed; inset:0; background:var(--bg-primary);
    display:flex; justify-content:center; align-items:center;
    z-index:9999; transition:opacity .5s ease;
}
.loading-content { text-align:center }
.loading-content svg { width:52px; height:52px; animation:nc-rotate 1s linear infinite; }
.loading-content circle {
    fill:none; stroke:var(--primary); stroke-width:3;
    stroke-dasharray:1,200; stroke-dashoffset:0; stroke-linecap:round;
    animation:nc-dash 1.5s ease-in-out infinite;
}
@keyframes nc-rotate { 100%{ transform:rotate(360deg) } }
@keyframes nc-dash {
    0%  { stroke-dasharray:1,200;  stroke-dashoffset:0 }
    50% { stroke-dasharray:90,200; stroke-dashoffset:-35px }
    100%{ stroke-dashoffset:-125px }
}
.loading p { color:var(--text-secondary); font-size:14px; margin-top:16px; font-weight:500; animation:nc-pulse 2s ease-in-out infinite; }

/* ════ LOGIN ═════════════════════════════════════════════════ */
.login-screen {
    min-height:100vh; display:flex; align-items:center;
    justify-content:center; background:var(--bg-primary);
    position:relative; overflow:hidden; z-index:1;
}
.login-screen::before {
    content:''; position:absolute;
    width:600px; height:600px; border-radius:50%;
    background:radial-gradient(circle, rgba(255,255,255,.06) 0%, transparent 70%);
    top:-200px; left:-200px;
    animation:nc-orb 8s ease-in-out infinite;
    pointer-events:none;
}
.login-screen::after {
    content:''; position:absolute;
    width:500px; height:500px; border-radius:50%;
    background:radial-gradient(circle, rgba(255,255,255,.04) 0%, transparent 70%);
    bottom:-150px; right:-100px;
    animation:nc-orb 10s ease-in-out infinite reverse;
    pointer-events:none;
}
@keyframes nc-orb {
    0%,100%{ transform:translate(0,0) scale(1) }
    33%    { transform:translate(30px,-40px) scale(1.05) }
    66%    { transform:translate(-20px,30px) scale(.97) }
}
.login-particles {
    position:absolute; inset:0; pointer-events:none;
    background:
        radial-gradient(circle at 20% 30%,rgba(255,255,255,.05) 0%,transparent 50%),
        radial-gradient(circle at 80% 70%,rgba(255,255,255,.04) 0%,transparent 50%),
        radial-gradient(circle at 50% 50%,rgba(255,255,255,.02) 0%,transparent 70%);
}
.login-card {
    background:rgba(12,12,12,.9);
    border:1px solid rgba(255,255,255,.12);
    border-radius:var(--radius-xl);
    padding:52px 44px;
    width:100%; max-width:440px;
    backdrop-filter:blur(40px) saturate(160%);
    position:relative; z-index:2;
    box-shadow:0 0 0 1px rgba(255,255,255,.06), var(--shadow-xl);
    animation:nc-card-in .6s cubic-bezier(.16,1,.3,1);
}
.login-card::before {
    content:''; position:absolute; inset:-1px;
    border-radius:calc(var(--radius-xl) + 1px);
    background:linear-gradient(135deg,rgba(255,255,255,.14) 0%,rgba(255,255,255,.04) 40%,rgba(255,255,255,.14) 100%);
    background-size:200% 200%;
    animation:nc-shimmer 4s linear infinite;
    z-index:-1; pointer-events:none;
}
@keyframes nc-shimmer {
    0%  { background-position:0% 50% }
    50% { background-position:100% 50% }
    100%{ background-position:0% 50% }
}
@keyframes nc-card-in {
    from { opacity:0; transform:translateY(32px) scale(.97) }
    to   { opacity:1; transform:translateY(0) scale(1) }
}
.login-logo { text-align:center; margin-bottom:36px; }
.login-logo-img {
    width:72px; height:72px;
    border-radius:var(--radius-lg);
    margin-bottom:18px;
    border:1px solid var(--border-secondary);
    box-shadow:0 0 30px rgba(255,255,255,.08);
    animation:nc-glow-pulse 3s ease-in-out infinite;
}
@keyframes nc-glow-pulse {
    0%,100%{ box-shadow:0 0 20px rgba(255,255,255,.08) }
    50%    { box-shadow:0 0 40px rgba(255,255,255,.18) }
}
.login-logo h1 { font-size:1.65rem; font-weight:800; letter-spacing:-0.03em; }
.login-subtitle {
    color:var(--text-tertiary); font-size:11px;
    margin-top:5px; font-weight:700;
    letter-spacing:.1em; text-transform:uppercase;
}
.input-group { margin-bottom:20px }
.input-group label {
    display:block; font-size:11px; font-weight:700;
    color:var(--text-tertiary); margin-bottom:8px;
    text-transform:uppercase; letter-spacing:.06em;
}
.input-group label i { margin-right:6px; color:var(--text-secondary) }
.input-group input {
    width:100%; padding:14px 18px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.09);
    border-radius:var(--radius-md);
    color:var(--text-primary); font-size:15px;
    transition:all var(--transition-base); outline:none;
}
.input-group input:hover { border-color:rgba(255,255,255,.16); background:rgba(255,255,255,.06); }
.input-group input:focus { border-color:rgba(255,255,255,.3); background:rgba(255,255,255,.06); box-shadow:0 0 0 3px rgba(255,255,255,.06); }
.input-group input::placeholder { color:var(--text-tertiary) }
.password-wrap { position:relative }
.password-wrap input { padding-right:46px }
.pw-toggle {
    position:absolute; right:14px; top:50%; transform:translateY(-50%);
    background:none; border:none; color:var(--text-tertiary); cursor:pointer;
    font-size:1rem; transition:color var(--transition-base); padding:4px;
}
.pw-toggle:hover { color:var(--text-primary) }
.login-error {
    margin-top:18px; padding:13px 16px;
    background:rgba(239,68,68,.08); border:1px solid rgba(239,68,68,.25);
    border-radius:var(--radius-md); color:#f87171; font-size:13.5px;
    display:flex; align-items:flex-start; gap:10px; line-height:1.5;
    animation:nc-shake .35s ease;
}
@keyframes nc-shake {
    0%,100%{ transform:translateX(0) }
    25%    { transform:translateX(-6px) }
    75%    { transform:translateX(6px) }
}

/* ════ BUTTONS ═══════════════════════════════════════════════ */
.btn {
    padding:14px 30px; border-radius:var(--radius-lg);
    font-weight:700; display:inline-flex; align-items:center;
    gap:8px; transition:all var(--transition-base);
    border:none; cursor:pointer; font-size:15px;
    position:relative; overflow:hidden;
    font-family:var(--font-family); letter-spacing:-0.01em;
    -webkit-tap-highlight-color:transparent;
}
.btn:active { transform:scale(.97) !important }
.btn-primary {
    background:linear-gradient(135deg, #ffffff 0%, #d4d4d4 100%);
    color:#000; box-shadow:0 0 0 1px rgba(255,255,255,.1), var(--shadow-sm);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 0 30px rgba(255,255,255,.2), var(--shadow-md); }
.btn-secondary {
    background:var(--glass-bg); border:1px solid var(--glass-border);
    color:var(--text-primary); backdrop-filter:blur(10px);
}
.btn-secondary:hover { background:var(--glass-hover); border-color:var(--border-hover); transform:translateY(-2px); }

/* ════ PAGES ═════════════════════════════════════════════════ */
.page         { display:none }
.page.active  { display:block; animation:nc-page-in .4s cubic-bezier(.16,1,.3,1) }
@keyframes nc-page-in {
    from { opacity:0; transform:translateY(18px) }
    to   { opacity:1; transform:translateY(0) }
}
@keyframes fadeInUp {
    from { opacity:0; transform:translateY(30px) }
    to   { opacity:1; transform:translateY(0) }
}
@keyframes nc-pulse {
    0%,100%{ opacity:1 } 50%{ opacity:.5 }
}

/* ════ FILTER BUTTONS ════════════════════════════════════════ */
.filter-buttons { display:flex; gap:12px; margin:20px 0 30px; flex-wrap:wrap; }
.filter-btn {
    padding:11px 24px; background:var(--glass-bg);
    backdrop-filter:blur(20px); border:1px solid var(--glass-border);
    border-radius:var(--radius-lg); color:var(--text-primary);
    font-size:14px; font-weight:600; cursor:pointer;
    transition:all var(--transition-base);
    display:flex; align-items:center; gap:8px;
    font-family:var(--font-family);
}
.filter-btn:hover { border-color:var(--border-hover); background:var(--glass-hover); transform:translateY(-2px); }
.filter-btn.active {
    background:var(--primary); color:#000; border-color:var(--primary);
    box-shadow:0 0 24px rgba(255,255,255,.2);
}

/* ════ SERIES / CARDS GRID ═══════════════════════════════════ */
.series-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
    gap:20px; margin-top:20px;
}
.serie-card {
    background:var(--glass-bg); backdrop-filter:blur(20px);
    border:1px solid var(--glass-border);
    border-radius:var(--radius-xl); padding:24px;
    transition:all var(--transition-base);
    display:flex; flex-direction:column;
    position:relative; overflow:hidden;
    animation:fadeInUp .6s ease-out both;
}
.serie-card:hover {
    border-color:var(--border-hover); transform:translateY(-6px);
    box-shadow:0 0 40px rgba(255,255,255,.04), var(--shadow-lg);
    background:var(--glass-hover);
}
.serie-header {
    display:flex; align-items:center; gap:14px;
    margin-bottom:18px; padding-bottom:18px;
    border-bottom:1px solid var(--border-primary);
}
.serie-icon {
    width:44px; height:44px;
    background:var(--glass-bg); border:1px solid var(--glass-border);
    border-radius:var(--radius-lg);
    display:flex; align-items:center; justify-content:center;
    font-size:18px; color:var(--primary); flex-shrink:0;
    transition:all var(--transition-base);
}
.serie-card:hover .serie-icon { background:rgba(255,255,255,.08); transform:scale(1.1); }
.serie-info   { flex:1 }
.serie-title  { font-size:18px; font-weight:700; margin:0 0 3px; }
.serie-count  { font-size:12px; color:var(--text-tertiary); font-weight:500 }
.serie-content { flex:1; display:flex; flex-direction:column; gap:16px; }
.volume-section { display:flex; flex-direction:column; gap:8px }
.volume-divider {
    color:var(--primary); font-weight:700; font-size:12px;
    padding:6px 0; border-bottom:1px solid var(--border-primary);
    margin-bottom:4px; text-transform:uppercase; letter-spacing:.06em;
}
.material-item {
    display:flex; align-items:center; gap:12px; padding:10px 12px;
    background:var(--glass-bg); border:1px solid var(--glass-border);
    border-radius:var(--radius-md); color:var(--text-primary);
    transition:all var(--transition-base); cursor:pointer;
}
.material-item:hover { background:var(--glass-hover); border-color:var(--border-hover); transform:translateX(6px); }
.material-item i:first-child { font-size:16px; color:var(--primary); width:20px; text-align:center; }
.material-name { flex:1; font-size:13px; font-weight:500; line-height:1.5 }
.material-link-icon { font-size:12px; color:var(--text-tertiary); transition:all var(--transition-base) }
.material-item:hover .material-link-icon { color:var(--primary); transform:translateX(4px) }

/* ════ SCRIPT CARDS ══════════════════════════════════════════ */
.script-card {
    background:var(--glass-bg); backdrop-filter:blur(20px);
    border:1px solid var(--glass-border);
    border-radius:var(--radius-xl); padding:28px;
    position:relative; overflow:hidden;
    transition:all var(--transition-base);
    animation:fadeInUp .6s ease-out both;
    display:flex; flex-direction:column;
}
.script-card:hover {
    border-color:var(--border-hover); transform:translateY(-6px);
    box-shadow:0 0 40px rgba(255,255,255,.04), var(--shadow-lg);
    background:var(--glass-hover);
}
.card-content { position:relative; z-index:1; flex:1; display:flex; flex-direction:column }
.script-icon-wrap {
    width:44px; height:44px;
    background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
    border-radius:var(--radius-lg);
    display:flex; align-items:center; justify-content:center;
    font-size:18px; color:var(--primary); margin-bottom:14px;
    transition:all var(--transition-base);
}
.script-card:hover .script-icon-wrap { background:rgba(255,255,255,.12); transform:scale(1.1); }
.script-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:14px; gap:12px }
.script-title { font-size:18px; font-weight:800; letter-spacing:-0.02em; }
.script-badge {
    background:var(--glass-bg); border:1px solid var(--glass-border);
    color:var(--primary); padding:4px 12px;
    border-radius:var(--radius-full); font-size:10px;
    font-weight:700; white-space:nowrap;
    text-transform:uppercase; letter-spacing:.05em; flex-shrink:0;
}
.script-badge.online   { background:rgba(16,185,129,.12); color:#34d399; border-color:rgba(52,211,153,.25) }
.script-badge.offline  { background:rgba(239,68,68,.1);   color:#f87171; border-color:rgba(248,113,113,.2) }
.script-badge.unstable { background:rgba(245,158,11,.1);  color:#fbbf24; border-color:rgba(251,191,36,.2) }
.script-description { color:var(--text-secondary); margin-bottom:16px; line-height:1.7; font-size:14px; }
.feature-list  { list-style:none; display:flex; flex-direction:column; gap:6px; flex:1 }
.feature-item  { display:flex; align-items:center; gap:10px; color:var(--text-secondary); font-size:13px; }
.feature-item i { color:var(--primary); font-size:9px; flex-shrink:0 }
.script-features { margin-bottom:16px; }
.script-footer {
    display:flex; justify-content:space-between; align-items:center;
    margin-top:auto; padding-top:16px;
    border-top:1px solid var(--border-primary); gap:14px;
}
.script-developer { font-size:12px; color:var(--text-tertiary) }
.script-developer strong { color:var(--text-secondary); font-weight:600 }
.script-developer i { margin-right:4px; color:var(--text-tertiary) }
.script-button {
    background:var(--primary); color:#000; border:none;
    padding:10px 20px; border-radius:var(--radius-lg);
    font-weight:700; cursor:pointer;
    transition:all var(--transition-base);
    display:flex; align-items:center; gap:8px;
    font-size:13px; font-family:var(--font-family);
}
.script-button:hover { transform:translateY(-2px); box-shadow:0 0 24px rgba(255,255,255,.2); }
.bookmark-box {
    background:rgba(255,255,255,.025); border:1px solid rgba(255,255,255,.07);
    border-radius:12px; padding:14px; margin-bottom:16px;
    display:flex; flex-direction:column; gap:12px;
}
.bookmark-info { color:var(--text-secondary); font-size:12px; display:flex; align-items:center; gap:10px; }
.bookmark-btn-single {
    background:#fff; color:#000; font-weight:800; font-size:14px;
    padding:12px; border-radius:10px;
    display:flex; align-items:center; justify-content:center;
    gap:8px; transition:all .2s; border:none; cursor:pointer;
}
.bookmark-btn-single:hover { transform:translateY(-2px); box-shadow:0 0 24px rgba(255,255,255,.2); }

/* ════ DASHBOARD LAYOUT ══════════════════════════════════════ */
.dashboard-layout {
    display:flex; height:100vh; width:100%;
    overflow:hidden; position:relative; z-index:2;
}

/* Sidebar */
.sidebar {
    width:240px;
    background:rgba(12,12,12,0.6);
    backdrop-filter:blur(20px);
    border-right:1px solid var(--border-secondary);
    display:flex; flex-direction:column;
    z-index:1000; flex-shrink:0;
    transition:transform 0.3s ease;
}
.sidebar-header {
    padding:20px; display:flex; align-items:center;
    border-bottom:1px solid var(--glass-border);
}
.sidebar-logo { display:flex; align-items:center; gap:10px; }
.sidebar-logo-img { width:28px; height:28px; border-radius:6px; }
.sidebar-title { font-size:14px; font-weight:700; color:var(--text-primary); }
.sidebar-nav { padding:16px 10px; flex:1; overflow-y:auto; }
.sidebar-menu { list-style:none; display:flex; flex-direction:column; gap:4px; }
.sidebar-link {
    display:flex; align-items:center; gap:12px; padding:11px 14px; border-radius:10px;
    color:var(--text-secondary); font-size:13.5px; font-weight:500;
    transition:all 0.2s ease; border:1px solid transparent;
}
.sidebar-link:hover { color:var(--text-primary); background:var(--glass-hover); }
.sidebar-link.active {
    background:rgba(255,255,255,0.08); color:var(--primary);
    border-color:var(--glass-border);
}
.sidebar-icon { font-size:16px; width:20px; text-align:center; color:var(--text-tertiary); transition:color 0.2s; }
.sidebar-link:hover .sidebar-icon,
.sidebar-link.active .sidebar-icon { color:var(--primary); }

/* Main Content */
.main-content {
    flex:1; display:flex; flex-direction:column;
    overflow-y:auto; overflow-x:hidden;
    min-width:0;
}

/* Topbar */
.topbar {
    display:flex; justify-content:flex-end; align-items:center;
    padding:14px 24px; background:transparent; z-index:100;
    flex-shrink:0;
}
.topbar-right { display:flex; align-items:center; }
.hamburger-mobile { display:none; color:var(--text-primary); font-size:20px; cursor:pointer; }

/* User menu */
.nav-user-menu {
    display:flex; align-items:center; gap:8px;
    cursor:pointer; padding:6px 12px; border-radius:var(--radius-md);
    transition:background var(--transition-base); position:relative; user-select:none;
}
.nav-user-menu:hover { background:rgba(255,255,255,.06) }
.nav-user-avatar {
    width:28px; height:28px; border-radius:50%;
    background:rgba(255,255,255,.08); border:1px solid var(--border-primary);
    display:flex; align-items:center; justify-content:center;
    font-size:12px; color:var(--text-secondary); overflow:hidden;
}
.nav-user-photo { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.nav-user-name {
    font-size:14px; font-weight:600;
    max-width:140px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.nav-user-chevron { font-size:10px; color:var(--text-tertiary); transition:transform var(--transition-base); }
.nav-user-menu.open .nav-user-chevron { transform:rotate(180deg) }
.nav-user-dropdown {
    position:absolute; top:calc(100% + 10px); right:0;
    background:rgba(16,16,16,.97); border:1px solid var(--border-secondary);
    border-radius:var(--radius-lg); padding:16px; min-width:210px;
    box-shadow:var(--shadow-lg);
    opacity:0; visibility:hidden; transform:translateY(-8px) scale(.97);
    transition:all var(--transition-base); z-index:9999;
    backdrop-filter:blur(20px);
}
.nav-user-menu.open .nav-user-dropdown { opacity:1; visibility:visible; transform:translateY(0) scale(1); }
.dropdown-info  { margin-bottom:12px }
.dropdown-name  { display:block; font-weight:700; font-size:15px; margin-bottom:3px }
.dropdown-ra    { font-size:12px; color:var(--text-tertiary) }
.nav-user-dropdown hr { border:none; border-top:1px solid var(--border-primary); margin:10px 0 }
.dropdown-logout {
    display:flex; align-items:center; gap:9px;
    padding:10px 12px; background:none; border:none;
    border-radius:var(--radius-md); color:#ef4444; font-size:14px; font-weight:600;
    cursor:pointer; width:100%; transition:background var(--transition-base);
    font-family:var(--font-family);
}
.dropdown-logout:hover { background:rgba(239,68,68,.1) }
.dropdown-profile {
    display:flex; align-items:center; gap:9px;
    padding:10px 12px; background:none; border:none;
    border-radius:var(--radius-md); color:var(--text-primary); font-size:14px; font-weight:600;
    cursor:pointer; width:100%; transition:background var(--transition-base);
    font-family:var(--font-family);
}
.dropdown-profile:hover { background:rgba(255,255,255,.08) }

/* Pages Container */
.pages-container { flex:1; padding:0 24px 30px; }

/* Home Dashboard */
.home-dashboard { max-width:900px; margin:0 auto; }
.dashboard-left { width:100%; }
.dashboard-section-padding { max-width:1100px; margin:0 auto; padding:0; }

/* Welcome */
.welcome-section { display:flex; align-items:center; gap:16px; margin-bottom:28px; }
.welcome-avatar {
    width:48px; height:48px; border-radius:50%;
    background:var(--glass-bg); border:1px solid var(--glass-border);
    display:flex; align-items:center; justify-content:center;
    font-size:20px; font-weight:700; color:var(--text-primary);
    overflow:hidden; flex-shrink:0;
}
.welcome-avatar img { width:100%; height:100%; object-fit:cover; }
.welcome-text h1 { font-size:22px; font-weight:800; margin-bottom:2px; }
.welcome-subtitle { font-size:11px; color:var(--text-tertiary); letter-spacing:1px; font-weight:600; text-transform:uppercase; }

/* Stats */
.stats-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:36px; }
.stat-panel {
    background:var(--glass-bg); backdrop-filter:blur(20px);
    border-radius:var(--radius-xl); padding:20px;
    position:relative; overflow:hidden;
    border:1px solid var(--glass-border);
    transition:all var(--transition-base);
}
.stat-panel:hover { border-color:var(--border-hover); transform:translateY(-4px); box-shadow:var(--shadow-md); }
.stat-icon-wrapper {
    width:34px; height:34px; border-radius:8px;
    display:flex; align-items:center; justify-content:center;
    font-size:15px; background:rgba(255,255,255,0.05);
    margin-bottom:12px;
}
.panel-red .stat-icon-wrapper { background:rgba(239,68,68,0.15); color:#ef4444; }
.panel-red { border-top:2px solid rgba(239,68,68,0.4); }
.panel-blue .stat-icon-wrapper { background:rgba(59,130,246,0.15); color:#3b82f6; }
.panel-blue { border-top:2px solid rgba(59,130,246,0.4); }
.panel-green .stat-icon-wrapper { background:rgba(16,185,129,0.15); color:#10b981; }
.panel-green { border-top:2px solid rgba(16,185,129,0.4); }
.stat-value { font-size:28px; font-weight:800; margin-bottom:2px; letter-spacing:-1px; color:var(--text-primary); }
.stat-label { font-size:12px; color:var(--text-secondary); font-weight:600; text-transform:uppercase; letter-spacing:.04em; }
.stat-alert { font-size:11px; color:#ef4444; margin-top:6px; font-weight:600; }

/* Section headers */
.section-header-mini { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.section-title-line { width:3px; height:16px; background:var(--primary); border-radius:2px; }
.section-header-mini h3 { font-size:16px; font-weight:700; flex:1; color:var(--text-primary); }
.section-header-mini h1 { font-size:22px; font-weight:800; color:var(--text-primary); }
.view-all-link { font-size:12px; color:var(--text-secondary); font-weight:500; white-space:nowrap; }
.view-all-link:hover { color:var(--primary); }

/* Mini platforms row */
.mini-scripts-section { margin-bottom:36px; }
.mini-scripts-row { display:flex; gap:12px; overflow-x:auto; padding-bottom:8px; }
.mini-scripts-row::-webkit-scrollbar { height:3px; }
.mini-script-item {
    background:var(--glass-bg); border:1px solid var(--glass-border);
    border-radius:var(--radius-lg); padding:16px 12px;
    display:flex; flex-direction:column; align-items:center;
    gap:10px; min-width:85px; cursor:pointer;
    transition:all var(--transition-base);
}
.mini-script-item:hover { transform:translateY(-3px); background:var(--glass-hover); border-color:var(--border-hover); }
.mini-script-icon {
    width:40px; height:40px; border-radius:10px;
    display:flex; align-items:center; justify-content:center;
    overflow:hidden;
}
.mini-script-icon img {
    width:100%; height:100%; object-fit:cover; border-radius:8px;
    /* NO filter — show original colors */
}
.mini-script-item span { font-size:10px; font-weight:600; text-align:center; color:var(--text-secondary); line-height:1.3; }

/* ═══ Platform Icon Cards ═══ */
.plataformas-grid-clean {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(110px,1fr));
    gap:12px;
}
.plat-icon-card {
    background:var(--glass-bg); border:1px solid var(--glass-border);
    border-radius:var(--radius-lg); padding:16px 10px;
    display:flex; flex-direction:column; align-items:center;
    justify-content:center; gap:10px; cursor:pointer;
    transition:all var(--transition-base); text-align:center;
}
.plat-icon-card:hover {
    transform:translateY(-4px); background:var(--glass-hover);
    border-color:var(--border-hover); box-shadow:var(--shadow-md);
}
.plat-icon-img {
    width:44px; height:44px; border-radius:10px; overflow:hidden;
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.plat-icon-img img {
    width:100%; height:100%; object-fit:contain;
    /* NO filter — show original icon colors */
}
.plat-icon-name {
    font-size:11px; font-weight:600; color:#fff;
    line-height:1.3; max-width:100px;
    overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}

/* ═══ Discord Home Card ═══ */
.discord-home-card {
    margin-top:36px;
    background:rgba(88,101,242,0.08);
    border:1px solid rgba(88,101,242,0.25);
    border-radius:var(--radius-xl);
    padding:24px;
    display:flex; align-items:center; gap:20px;
}
.discord-home-icon {
    background:#5865F2; border-radius:50%;
    width:48px; height:48px; min-width:48px;
    display:flex; align-items:center; justify-content:center;
    font-size:22px; color:white;
}
.discord-home-text h3 { margin:0 0 5px; color:#fff; font-size:1rem; }
.discord-home-text p { margin:0 0 12px; color:var(--text-secondary); font-size:0.85rem; line-height:1.5; }
.discord-home-btn {
    display:inline-flex; align-items:center; gap:8px;
    background:#5865F2; color:#fff;
    padding:10px 20px; border-radius:var(--radius-lg);
    font-weight:700; font-size:13px;
    transition:all var(--transition-base);
    text-decoration:none;
}
.discord-home-btn:hover { transform:translateY(-2px); box-shadow:0 0 24px rgba(88,101,242,.4); }

/* ════ IFRAME OVERLAY ════════════════════════════════════════ */
.iframe-overlay {
    position:fixed; inset:0; z-index:2000;
    background:var(--bg-primary);
    display:flex; flex-direction:column;
    animation:nc-page-in .2s ease;
}
.iframe-topbar {
    height:50px; background:rgba(6,6,6,.9);
    backdrop-filter:blur(12px);
    border-bottom:1px solid var(--border-primary);
    display:flex; align-items:center; gap:14px;
    padding:0 16px; flex-shrink:0;
}
.iframe-bar-title {
    font-size:14px; font-weight:500; color:var(--text-secondary);
    overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
    margin-left:10px;
}
.iframe-main { flex:1; width:100%; border:none; background:#fff }

/* ════ TOAST ═════════════════════════════════════════════════ */
#toast-container {
    position:fixed; bottom:32px; left:50%; transform:translateX(-50%);
    z-index:99999; display:flex; flex-direction:column;
    gap:10px; align-items:center; pointer-events:none;
}
.toast {
    background:rgba(0,0,0,.90); backdrop-filter:blur(16px);
    border:1px solid var(--border-hover);
    color:var(--primary); padding:12px 28px;
    border-radius:var(--radius-full); font-size:14px; font-weight:600;
    display:flex; align-items:center; gap:10px;
    box-shadow:0 0 30px rgba(255,255,255,.08), var(--shadow-lg);
    opacity:0; transform:translateY(20px) scale(.96);
    transition:all .32s cubic-bezier(.68,-.55,.265,1.55);
    white-space:nowrap;
}
.toast.active { opacity:1; transform:translateY(0) scale(1) }

/* Corner status */
#status-corners { position:fixed; inset:0; z-index:99990; pointer-events:none; }
.status-corner {
    position:absolute; min-width:220px; max-width:300px;
    background:rgba(4,4,4,.93); border:1px solid rgba(255,255,255,.16);
    color:var(--text-primary); border-radius:12px; padding:10px 14px;
    box-shadow:var(--shadow-lg); backdrop-filter:blur(12px);
    display:flex; align-items:center; gap:10px;
    opacity:0; transform:translateY(10px) scale(.96);
    transition:all .35s cubic-bezier(.16,1,.3,1);
}
.status-corner i { color:#7dd3fc; font-size:14px; }
.status-corner.active { opacity:1; transform:translateY(0) scale(1); }
.status-corner.top-right { top:18px; right:18px; }
.status-corner.top-left { top:18px; left:18px; }

/* Profile modal */
.profile-modal {
    position:fixed; inset:0; z-index:5000;
    background:rgba(0,0,0,.78);
    display:flex; align-items:center; justify-content:center; padding:16px;
}
.profile-modal-content {
    width:min(500px,100%);
    background:rgba(8,8,8,.95);
    border:1px solid var(--glass-border);
    border-radius:var(--radius-xl); padding:24px;
}
.profile-modal-content h3 { margin-bottom:6px; }
.profile-modal-content p { color:var(--text-secondary); margin-bottom:16px; }
.profile-preview-wrap { display:flex; justify-content:center; margin-bottom:16px; }
.profile-preview-wrap img { width:96px; height:96px; border-radius:50%; object-fit:cover; border:2px solid var(--glass-border); }
.profile-actions input[type="url"] {
    width:100%; margin-top:12px; padding:12px;
    border-radius:var(--radius-md); border:1px solid var(--glass-border);
    background:var(--glass-bg); color:var(--text-primary);
}
.profile-modal-buttons { display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }

/* Entry Discord modal */
.entry-discord-modal {
    position:fixed; inset:0; z-index:99980;
    background:rgba(0,0,0,.55); backdrop-filter:blur(8px);
    display:flex; align-items:center; justify-content:center; padding:16px;
}
.entry-discord-card {
    width:min(500px,100%);
    border:1px solid rgba(255,255,255,.18);
    border-radius:20px; background:rgba(8,8,8,.96);
    overflow:hidden; box-shadow:0 30px 80px rgba(0,0,0,.7);
    position:relative; animation:nc-card-in .42s cubic-bezier(.16,1,.3,1);
}
.entry-discord-close {
    position:absolute; top:12px; right:12px;
    width:34px; height:34px; border-radius:10px;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(0,0,0,.55); color:#fff; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    transition:all var(--transition-base);
}
.entry-discord-close:hover { transform:scale(1.06); background:rgba(255,255,255,.18); }
.entry-discord-banner { width:100%; height:200px; object-fit:cover; display:block; }
.entry-discord-content { padding:20px 22px 24px; text-align:center; }
.entry-discord-tag {
    display:inline-flex; align-items:center; gap:8px;
    border:1px solid rgba(255,255,255,.16); border-radius:9999px;
    padding:6px 12px; font-size:11px; text-transform:uppercase;
    letter-spacing:.07em; margin-bottom:12px; color:var(--text-secondary);
}
.entry-discord-content h3 { font-size:1.8rem; line-height:1.1; margin-bottom:8px; }
.entry-discord-content p { color:var(--text-secondary); margin-bottom:18px; }
.entry-discord-btn {
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    width:100%; background:#5865F2; color:#fff;
    padding:14px 30px; border-radius:var(--radius-lg);
    font-weight:700; font-size:15px;
    transition:all var(--transition-base);
    text-decoration:none;
}
.entry-discord-btn:hover { transform:translateY(-2px); box-shadow:0 0 30px rgba(88,101,242,.4); }

/* ════ RESPONSIVE ════════════════════════════════════════════ */
@media(max-width:768px) {
    .sidebar {
        position:fixed; left:0; top:0; bottom:0;
        transform:translateX(-100%); z-index:2000;
        width:240px;
    }
    .sidebar.open { transform:translateX(0); }
    .hamburger-mobile { display:block; }
    .topbar { justify-content:space-between; }

    .stats-grid { grid-template-columns:1fr 1fr; }
    .pages-container { padding:0 16px 24px; }

    .welcome-text h1 { font-size:18px; }
    .section-header-mini h1 { font-size:18px; }

    .plataformas-grid-clean { grid-template-columns:repeat(3,1fr); gap:10px; }
    .plat-icon-card { padding:12px 6px; }
    .plat-icon-img { width:36px; height:36px; }
    .plat-icon-name { font-size:10px; max-width:80px; }

    .mini-scripts-row { gap:8px; }
    .mini-script-item { min-width:70px; padding:12px 8px; }
    .mini-script-icon { width:36px; height:36px; }
    .mini-script-item span { font-size:9px; }

    .series-grid { grid-template-columns:1fr; }
    .script-card { padding:20px; }
    .script-footer { flex-direction:column; align-items:flex-start; gap:12px; }
    .script-button { width:100%; justify-content:center; }

    .discord-home-card { flex-direction:column; text-align:center; padding:20px; }
    .discord-home-btn { width:100%; justify-content:center; }

    .filter-buttons { flex-direction:column; gap:8px; }
    .filter-btn { width:100%; justify-content:center; }

    .status-corner { min-width:unset; max-width:calc(100vw - 24px); }
    .status-corner.top-right { right:12px; top:12px; }
    .status-corner.top-left { left:12px; top:12px; }

    .entry-discord-banner { height:160px; }
    .entry-discord-content h3 { font-size:1.4rem; }
    .login-card { margin:16px; padding:40px 28px; }
}

@media(max-width:480px) {
    .stats-grid { grid-template-columns:1fr; }
    .stat-panel { padding:16px; }
    .stat-value { font-size:24px; }
    .plataformas-grid-clean { grid-template-columns:repeat(3,1fr); }
    .login-card { margin:12px; padding:32px 18px; }
    .nav-user-name { max-width:100px; font-size:13px; }
}
