/* ============================================
   DHC Utilities — Design System v3.1
   Vibrant Dark Cyan Theme — Performance-First
   ============================================ */

/* --- Design Tokens --- */
:root {
    --bg-body: #0a1a24;
    --bg-body-end: #0e2230;
    --surface: rgba(0,220,255,0.06);
    --surface-hover: rgba(0,220,255,0.10);
    --surface-active: rgba(0,220,255,0.16);
    --glass: rgba(10,26,36,0.90);
    --glass-border: rgba(0,220,255,0.15);
    --glass-glow: rgba(0,220,255,0.12);

    --accent: #00e5ff;
    --accent-rgb: 0,229,255;
    --accent2: #00bcd4;
    --accent2-rgb: 0,188,212;
    --accent3: #26c6da;
    --gold: #ffd740;
    --silver: #90a4ae;
    --bronze: #ff8a65;

    --success: #00e676;
    --warning: #ffab40;
    --danger: #ff5252;

    --text: #e0f7fa;
    --text-secondary: rgba(224,247,250,0.6);
    --text-muted: rgba(224,247,250,0.35);

    --radius-sm: 10px;
    --radius-md: 16px;
    --radius-lg: 24px;
    --radius-xl: 32px;

    --shadow-sm: 0 2px 8px rgba(0,0,0,0.3);
    --shadow-md: 0 8px 30px rgba(0,0,0,0.4);
    --shadow-lg: 0 20px 60px rgba(0,0,0,0.5);
    --shadow-glow: 0 0 40px rgba(var(--accent-rgb),0.2);
    --shadow-cyan: 0 0 20px rgba(var(--accent-rgb),0.15);

    --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --transition: 0.3s cubic-bezier(.4,0,.2,1);
}

/* --- Reset --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font);color:var(--text);background:var(--bg-body);min-height:100vh;line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{border:none;background:none;cursor:pointer;font-family:var(--font);color:var(--text)}
img{max-width:100%;display:block}
ul,ol{list-style:none}
input,select,textarea{font-family:var(--font);color:var(--text)}

/* --- Scrollbar --- */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(var(--accent-rgb),0.35);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(var(--accent-rgb),0.6)}

/* --- Animated Background (GPU-optimized, no blur filters) --- */
.bg-mesh{
    position:fixed;inset:0;z-index:-2;
    background:linear-gradient(135deg, var(--bg-body) 0%, #0c2233 30%, #102a38 50%, #0b1e2c 70%, var(--bg-body-end) 100%);
    contain:strict;
}
.bg-orbs{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden;contain:strict}
.bg-orb{
    position:absolute;border-radius:50%;opacity:0.10;
    background:radial-gradient(circle,currentColor 0%,transparent 70%);
    contain:strict;
}
.bg-orb:nth-child(1){width:600px;height:600px;color:#00e5ff;top:-10%;right:-5%;opacity:0.12}
.bg-orb:nth-child(2){width:500px;height:500px;color:#00838f;bottom:-15%;left:-8%;opacity:0.10}
.bg-orb:nth-child(3){width:400px;height:400px;color:#26c6da;top:50%;left:40%;opacity:0.10}

/* No grain overlay — removed for performance */

/* ============================================
   NAVIGATION
   ============================================ */
.navbar{
    position:sticky;top:0;z-index:1000;
    padding:14px 24px;
    background:var(--glass);
    border-bottom:1px solid var(--glass-border);
    transition:background 0.2s ease;
    contain:layout style;
}
.navbar.scrolled{background:rgba(6,13,18,0.95);box-shadow:0 4px 30px rgba(0,0,0,0.3)}
.nav-inner{
    max-width:1400px;margin:0 auto;
    display:flex;align-items:center;justify-content:space-between;gap:20px;
}

/* Brand */
.nav-brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nav-brand img{width:38px;height:38px;border-radius:10px;box-shadow:0 0 12px rgba(var(--accent-rgb),0.3)}
.nav-brand span{font-size:1.15rem;font-weight:700;
    background:linear-gradient(135deg,#e0f7fa 30%,var(--accent));
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* Nav links */
.nav-links{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.nav-item{
    padding:8px 16px;border-radius:var(--radius-sm);
    font-size:0.88rem;font-weight:500;color:var(--text-secondary);
    transition:all var(--transition);display:flex;align-items:center;gap:7px;
    white-space:nowrap;position:relative;
}
.nav-item:hover,.nav-item.active{color:var(--accent);background:rgba(var(--accent-rgb),0.08)}
.nav-item.active{font-weight:600;box-shadow:inset 0 -2px 0 var(--accent)}
.nav-item i{font-size:0.8rem}

/* More dropdown */
.nav-more{position:relative}
.nav-more-btn{cursor:pointer}
.nav-more-menu{
    display:none;position:absolute;top:calc(100% + 10px);right:0;
    min-width:220px;padding:8px 0;
    background:rgba(8,18,24,0.98);
    border:1px solid var(--glass-border);border-radius:var(--radius-md);
    box-shadow:var(--shadow-lg),var(--shadow-cyan);
    transform:translateY(8px);opacity:0;
    transition:opacity 0.2s,transform 0.2s;
    pointer-events:none;
}
.nav-more.open .nav-more-menu{display:block;opacity:1;transform:translateY(0);pointer-events:auto}
.nav-more-menu a{
    display:flex;align-items:center;gap:10px;padding:10px 18px;
    font-size:0.88rem;color:var(--text-secondary);transition:all 0.15s;
}
.nav-more-menu a:hover{color:var(--accent);background:rgba(var(--accent-rgb),0.06)}
.nav-more-menu a i{width:18px;text-align:center;font-size:0.82rem}

/* Mobile nav */
.nav-toggle{display:none;padding:8px;font-size:1.3rem;color:var(--text-secondary)}

/* ============================================
   LAYOUT
   ============================================ */
.page-wrap{min-height:calc(100vh - 63px);position:relative;z-index:1}
.container{max-width:1400px;margin:0 auto;padding:32px 24px}
.container-sm{max-width:900px;margin:0 auto;padding:32px 24px}
.container-md{max-width:1100px;margin:0 auto;padding:32px 24px}

/* ============================================
   CARDS / SURFACES
   ============================================ */
.glass-card{
    background:var(--surface);
    border:1px solid var(--glass-border);
    border-radius:var(--radius-lg);
    padding:32px;
    transition:border-color 0.2s ease, box-shadow 0.2s ease;
    position:relative;overflow:hidden;
    contain:content;
}
.glass-card:hover{
    border-color:rgba(var(--accent-rgb),0.25);
    box-shadow:0 8px 32px rgba(0,0,0,0.3),0 0 20px rgba(var(--accent-rgb),0.08);
}

/* Accent top bar on cards */
.glass-card.accent-top{border-top:2px solid transparent}
.glass-card.accent-top:hover{border-top-color:var(--accent)}

/* ============================================
   PAGE HEADER
   ============================================ */
.page-header{text-align:center;padding:60px 20px 40px;position:relative}
.page-header h1{
    font-size:clamp(2rem,5vw,3.2rem);font-weight:800;letter-spacing:-0.5px;
    background:linear-gradient(135deg,#e0f7fa 40%,var(--accent));
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
    margin-bottom:12px;
}
.page-header p{color:var(--text-secondary);font-size:1.1rem;max-width:600px;margin:0 auto}
.page-header .badge{margin-top:16px;display:inline-block}

/* ============================================
   STAT CARDS
   ============================================ */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin:32px 0}
.stat-card{
    background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-md);padding:28px 24px;text-align:center;
    transition:all var(--transition);position:relative;overflow:hidden;
}
.stat-card:hover{border-color:rgba(var(--accent-rgb),0.25);box-shadow:var(--shadow-cyan)}
.stat-icon{
    width:52px;height:52px;border-radius:14px;margin:0 auto 14px;
    display:grid;place-items:center;font-size:1.3rem;
    background:linear-gradient(135deg,rgba(var(--accent-rgb),0.15),rgba(var(--accent2-rgb),0.1));
    color:var(--accent);
}
.stat-number{font-size:2.2rem;font-weight:800;margin-bottom:4px;color:var(--accent)}
.stat-label{font-size:0.8rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-weight:500}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:12px 24px;border-radius:var(--radius-sm);
    font-weight:600;font-size:0.9rem;transition:all var(--transition);
    white-space:nowrap;position:relative;overflow:hidden;
}
.btn-accent{
    background:linear-gradient(135deg,var(--accent),#0097a7);color:#000;
    box-shadow:0 4px 15px rgba(var(--accent-rgb),0.3);
}
.btn-accent:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(var(--accent-rgb),0.45)}
.btn-outline{
    background:transparent;border:1px solid var(--glass-border);color:var(--text-secondary);
}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 15px rgba(var(--accent-rgb),0.1)}
.btn-glow{position:relative;overflow:hidden;box-shadow:0 0 12px rgba(var(--accent-rgb),0.3)}

/* Button hover */
.btn-accent:hover{filter:brightness(1.15)}

/* ============================================
   BADGES
   ============================================ */
.badge{
    display:inline-flex;align-items:center;gap:6px;
    padding:6px 14px;border-radius:50px;font-size:0.78rem;font-weight:600;
}
.badge-success{background:rgba(0,230,118,0.15);border:1px solid rgba(0,230,118,0.25);color:#69f0ae}
.badge-accent{background:rgba(var(--accent-rgb),0.12);border:1px solid rgba(var(--accent-rgb),0.25);color:var(--accent)}
.badge-purple{background:rgba(var(--accent2-rgb),0.12);border:1px solid rgba(var(--accent2-rgb),0.2);color:#4dd0e1}
.badge-gold{background:rgba(255,215,64,0.12);border:1px solid rgba(255,215,64,0.2);color:var(--gold)}
.badge-danger{background:rgba(255,82,82,0.12);border:1px solid rgba(255,82,82,0.2);color:#ff8a80}

/* ============================================
   SECTION TITLES
   ============================================ */
.section-title{
    font-size:1.4rem;font-weight:700;margin-bottom:24px;
    display:flex;align-items:center;gap:10px;
}
.section-title i{color:var(--accent);font-size:1.1rem}

/* ============================================
   FEATURE CARDS
   ============================================ */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.feature-card{
    background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-md);padding:28px;transition:all var(--transition);
    position:relative;overflow:hidden;
}
.feature-card:hover{border-color:rgba(var(--accent-rgb),0.25);box-shadow:var(--shadow-cyan)}
.feature-icon{
    width:48px;height:48px;border-radius:12px;margin-bottom:16px;
    display:grid;place-items:center;font-size:1.2rem;
    background:linear-gradient(135deg,rgba(var(--accent-rgb),0.15),rgba(var(--accent2-rgb),0.1));
    color:var(--accent);
}
.feature-card h3{font-size:1.05rem;font-weight:600;margin-bottom:8px}
.feature-card p{font-size:0.9rem;color:var(--text-secondary);line-height:1.6}

/* ============================================
   GUILD CARDS (Dashboard)
   ============================================ */
.guild-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.guild-card{
    background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-lg);padding:28px;text-align:center;
    transition:all 0.4s cubic-bezier(.175,.885,.32,1.275);
    position:relative;overflow:hidden;
}
.guild-card:hover{
    border-color:rgba(var(--accent-rgb),0.35);
    box-shadow:var(--shadow-glow);
}

.guild-card a{color:inherit;text-decoration:none;display:block;position:relative;z-index:1}
.guild-avatar{
    width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto 14px;
    border:3px solid rgba(var(--accent-rgb),0.35);box-shadow:0 4px 20px rgba(0,0,0,0.3);
    transition:all var(--transition);
}
.guild-card:hover .guild-avatar{box-shadow:0 0 25px rgba(var(--accent-rgb),0.25)}
.guild-avatar-fallback{
    width:80px;height:80px;border-radius:50%;margin:0 auto 14px;
    border:3px solid rgba(var(--accent-rgb),0.35);
    background:linear-gradient(135deg,var(--accent),var(--accent2));
    display:grid;place-items:center;font-size:1.8rem;font-weight:700;color:#000;
}
.guild-card .guild-name{font-size:1.1rem;font-weight:600;margin-bottom:4px}
.guild-card .guild-id{font-size:0.75rem;color:var(--text-muted);font-family:monospace;margin-bottom:12px}
.guild-card .guild-stats{
    display:flex;justify-content:center;gap:24px;
    padding-top:14px;border-top:1px solid var(--glass-border);
}
.guild-stat-val{font-size:1.05rem;font-weight:700;color:var(--accent)}
.guild-stat-lbl{font-size:0.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}

/* Guild badges */
.guild-badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:12px}
.guild-badge{
    padding:3px 10px;border-radius:50px;font-size:0.68rem;font-weight:600;
    display:flex;align-items:center;gap:4px;
}

/* ============================================
   SEARCH
   ============================================ */
.search-box{
    max-width:520px;margin:0 auto 40px;position:relative;
}
.search-box input{
    width:100%;padding:14px 20px 14px 48px;
    background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-md);color:var(--text);font-size:0.95rem;
    transition:all var(--transition);
}
.search-box input:focus{outline:none;border-color:rgba(var(--accent-rgb),0.5);box-shadow:0 0 25px rgba(var(--accent-rgb),0.12)}
.search-box input::placeholder{color:var(--text-muted)}
.search-box .search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted)}
.search-results{
    position:absolute;top:110%;left:0;right:0;
    background:rgba(8,18,24,0.97);border:1px solid var(--glass-border);
    border-radius:var(--radius-md);max-height:300px;overflow-y:auto;
    display:none;z-index:100;
}
.search-results.active{display:block}
.search-result-item{
    padding:12px 18px;border-bottom:1px solid var(--glass-border);
    transition:background 0.15s;cursor:pointer;text-align:left;
}
.search-result-item:hover{background:rgba(var(--accent-rgb),0.06)}
.search-result-item:last-child{border-bottom:none}

/* ============================================
   ADMIN BUTTON (floating)
   ============================================ */
.admin-float{
    position:fixed;top:80px;right:20px;padding:10px 18px;
    background:var(--glass);border:1px solid var(--glass-border);
    border-radius:var(--radius-sm);
    color:var(--text-secondary);font-size:0.85rem;font-weight:500;
    display:flex;align-items:center;gap:8px;transition:all var(--transition);z-index:999;
}
.admin-float:hover{border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-cyan)}
.admin-float.logged-in{background:linear-gradient(135deg,#ff5252,#ff8a65);border-color:transparent;color:#fff}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{
    margin-top:80px;padding:48px 24px 24px;
    border-top:1px solid var(--glass-border);
    background:rgba(0,0,0,0.25);
}
.footer-inner{max-width:1400px;margin:0 auto}
.footer-grid{
    display:grid;grid-template-columns:2fr repeat(3,1fr);gap:40px;
    margin-bottom:32px;
}
.footer-brand p{color:var(--text-muted);font-size:0.88rem;margin-top:8px;max-width:280px;line-height:1.6}
.footer-col h4{font-size:0.85rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);margin-bottom:14px}
.footer-col a{display:block;padding:5px 0;font-size:0.88rem;color:var(--text-muted);transition:color 0.2s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{
    padding-top:24px;border-top:1px solid var(--glass-border);
    display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:0.8rem;color:var(--text-muted)}
.footer-bottom a{color:var(--accent)}
.footer-social{display:flex;gap:12px}
.footer-social a{
    width:36px;height:36px;border-radius:10px;border:1px solid var(--glass-border);
    display:grid;place-items:center;color:var(--text-muted);font-size:0.9rem;
    transition:all var(--transition);
}
.footer-social a:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 4px 15px rgba(var(--accent-rgb),0.2)}

/* ============================================
   VIEW TOGGLE / SORT
   ============================================ */
.toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:24px}
.view-toggle{display:flex;gap:6px}
.view-btn{
    padding:8px 14px;background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition);
}
.view-btn.active,.view-btn:hover{background:rgba(var(--accent-rgb),0.12);color:var(--accent);border-color:rgba(var(--accent-rgb),0.25)}
.sort-select{
    padding:8px 14px;background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:0.88rem;
}
.sort-select option{background:#0a1419}

/* ============================================
   ANIMATIONS
   ============================================ */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity 0.6s,transform 0.6s}
.fade-up.visible{opacity:1;transform:translateY(0)}

@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* Cyan accent class */
.glow-anim{box-shadow:0 0 15px rgba(var(--accent-rgb),0.2)}

/* Status dot */
.status-dot{
    width:8px;height:8px;border-radius:50%;background:var(--success);
    display:inline-block;
}

/* ============================================
   CHANGELOG
   ============================================ */
.changelog-entry{
    background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-lg);padding:32px;margin-bottom:24px;
    position:relative;overflow:hidden;transition:all var(--transition);
}
.changelog-entry:hover{border-color:rgba(var(--accent-rgb),0.2);box-shadow:var(--shadow-cyan)}
.changelog-entry::before{
    content:'';position:absolute;top:0;left:0;width:3px;height:100%;
    background:linear-gradient(180deg,var(--accent),var(--accent2));
}
.changelog-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.changelog-header h2{font-size:1.2rem;font-weight:700}
.changelog-date{font-size:0.82rem;color:var(--text-muted)}
.changelog-section{margin-bottom:14px}
.changelog-section h3{font-size:0.95rem;font-weight:600;color:var(--accent);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.changelog-section li{padding:4px 0 4px 20px;font-size:0.9rem;color:var(--text-secondary);position:relative}
.changelog-section li::before{content:'→';position:absolute;left:0;color:var(--accent);font-size:0.8rem}

/* ============================================
   TABLE (for leaderboard etc.)
   ============================================ */
.data-table{width:100%;border-collapse:separate;border-spacing:0 4px}
.data-table th{
    padding:12px 16px;text-align:left;font-size:0.78rem;text-transform:uppercase;
    letter-spacing:1px;color:var(--text-muted);font-weight:600;
}
.data-table td{
    padding:14px 16px;background:var(--surface);font-size:0.9rem;
    transition:background var(--transition);
}
.data-table tr td:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}
.data-table tr td:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.data-table tbody tr:hover td{background:var(--surface-hover)}

/* ============================================
   COMMAND CARDS (for commands page)
   ============================================ */
.cmd-card{
    background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-md);padding:20px;margin-bottom:12px;
    transition:all var(--transition);
}
.cmd-card:hover{border-color:rgba(var(--accent-rgb),0.2)}
.cmd-name{font-weight:600;color:var(--accent);font-family:monospace;font-size:0.95rem}
.cmd-desc{font-size:0.88rem;color:var(--text-secondary);margin-top:4px}
.cmd-usage{
    margin-top:8px;padding:8px 12px;
    background:rgba(0,0,0,0.3);border-radius:var(--radius-sm);
    font-family:monospace;font-size:0.82rem;color:var(--text-muted);
}

/* ============================================
   FAQ ACCORDION
   ============================================ */
.faq-item{
    background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-md);margin-bottom:10px;overflow:hidden;
    transition:all var(--transition);
}
.faq-item:hover{border-color:rgba(var(--accent-rgb),0.2)}
.faq-question{
    padding:18px 20px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;
    font-weight:600;font-size:0.95rem;
}
.faq-question i{color:var(--accent);transition:transform var(--transition)}
.faq-item.open .faq-question i{transform:rotate(180deg)}
.faq-answer{
    padding:0 20px;max-height:0;overflow:hidden;transition:max-height 0.3s,padding 0.3s;
    color:var(--text-secondary);font-size:0.9rem;line-height:1.7;
}
.faq-item.open .faq-answer{max-height:500px;padding:0 20px 18px}

/* ============================================
   PRICING CARDS
   ============================================ */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.pricing-card{
    background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-lg);padding:36px 28px;text-align:center;
    transition:all var(--transition);position:relative;
}
.pricing-card.featured{
    border-color:rgba(var(--accent-rgb),0.35);
    box-shadow:0 0 40px rgba(var(--accent-rgb),0.1);
}
.pricing-card.featured::before{
    content:'POPULAR';position:absolute;top:14px;right:14px;
    padding:4px 12px;border-radius:50px;font-size:0.68rem;font-weight:700;
    background:linear-gradient(135deg,var(--accent),var(--accent2));color:#000;
}
.pricing-card:hover{border-color:rgba(var(--accent-rgb),0.3);box-shadow:var(--shadow-glow)}
.pricing-price{font-size:2.5rem;font-weight:800;color:var(--accent);margin:16px 0 8px}
.pricing-price span{font-size:1rem;font-weight:400;color:var(--text-muted)}
.pricing-features{text-align:left;margin:20px 0}
.pricing-features li{padding:8px 0;font-size:0.9rem;color:var(--text-secondary);display:flex;align-items:center;gap:8px}
.pricing-features li i{color:var(--accent);font-size:0.8rem}

/* ============================================
   FORM INPUTS
   ============================================ */
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:0.85rem;font-weight:600;margin-bottom:8px;color:var(--text-secondary)}
.form-input{
    width:100%;padding:12px 16px;
    background:var(--surface);border:1px solid var(--glass-border);
    border-radius:var(--radius-sm);color:var(--text);font-size:0.9rem;
    transition:all var(--transition);
}
.form-input:focus{outline:none;border-color:rgba(var(--accent-rgb),0.5);box-shadow:0 0 15px rgba(var(--accent-rgb),0.08)}
textarea.form-input{min-height:120px;resize:vertical}

/* ============================================
   ALERT / NOTICE BOX
   ============================================ */
.alert{
    padding:16px 20px;border-radius:var(--radius-md);margin-bottom:20px;
    display:flex;align-items:flex-start;gap:12px;font-size:0.9rem;
}
.alert-info{background:rgba(var(--accent-rgb),0.08);border:1px solid rgba(var(--accent-rgb),0.2);color:var(--accent)}
.alert-warning{background:rgba(255,171,64,0.08);border:1px solid rgba(255,171,64,0.2);color:var(--warning)}
.alert-danger{background:rgba(255,82,82,0.08);border:1px solid rgba(255,82,82,0.2);color:var(--danger)}
.alert-success{background:rgba(0,230,118,0.08);border:1px solid rgba(0,230,118,0.2);color:var(--success)}
.alert i{margin-top:2px;flex-shrink:0}

/* ============================================
   CODE BLOCKS
   ============================================ */
code{
    padding:2px 8px;background:rgba(0,0,0,0.3);border-radius:4px;
    font-family:'JetBrains Mono','Fira Code',monospace;font-size:0.85em;color:var(--accent3);
}
pre{
    padding:20px;background:rgba(0,0,0,0.35);border:1px solid var(--glass-border);
    border-radius:var(--radius-md);overflow-x:auto;
}
pre code{padding:0;background:none;font-size:0.88rem;color:var(--text)}

/* ============================================
   TABS
   ============================================ */
.tab-nav{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--glass-border);padding-bottom:0}
.tab-btn{
    padding:10px 20px;font-size:0.88rem;font-weight:500;color:var(--text-muted);
    border-bottom:2px solid transparent;transition:all var(--transition);
    cursor:pointer;
}
.tab-btn:hover{color:var(--text-secondary)}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-content{display:none}
.tab-content.active{display:block;animation:fadeIn 0.3s ease}

/* ============================================
   TOOLTIP
   ============================================ */
[data-tooltip]{position:relative}
[data-tooltip]::after{
    content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
    padding:6px 12px;background:rgba(0,0,0,0.9);border:1px solid var(--glass-border);
    border-radius:var(--radius-sm);font-size:0.78rem;color:var(--text);white-space:nowrap;
    opacity:0;pointer-events:none;transition:opacity 0.2s;z-index:100;
}
[data-tooltip]:hover::after{opacity:1}

/* ============================================
   LIST VIEW
   ============================================ */
.guild-grid.list-view{grid-template-columns:1fr}
.guild-grid.list-view .guild-card{display:flex;align-items:center;gap:20px;text-align:left}
.guild-grid.list-view .guild-card a{display:flex;align-items:center;gap:20px;width:100%}
.guild-grid.list-view .guild-avatar,.guild-grid.list-view .guild-avatar-fallback{
    width:56px;height:56px;font-size:1.3rem;margin:0;
}
.guild-grid.list-view .guild-stats{border-top:none;padding-top:0;border-left:1px solid var(--glass-border);padding-left:20px}

/* ============================================
   EMPTY STATE
   ============================================ */
.empty-state{padding:60px 20px;text-align:center;grid-column:1/-1}
.empty-state i{font-size:3rem;color:var(--text-muted);margin-bottom:16px;display:block}
.empty-state p{color:var(--text-secondary);font-size:1.1rem}

/* ============================================
   LOADING SKELETON
   ============================================ */
.skeleton{
    background:var(--surface);
    border-radius:var(--radius-sm);
}
.skeleton-text{height:14px;margin-bottom:8px;width:80%}
.skeleton-text:last-child{width:60%}
.skeleton-avatar{width:80px;height:80px;border-radius:50%}
.skeleton-card{height:200px;border-radius:var(--radius-lg)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
    .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
    .navbar{padding:12px 16px}
    .nav-links{gap:4px}
    .nav-item{padding:6px 12px;font-size:0.82rem}
    .container,.container-sm,.container-md{padding:20px 16px}
    .stats-grid{grid-template-columns:repeat(2,1fr)}
    .guild-grid{grid-template-columns:1fr}
    .features-grid{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr;gap:24px}
    .footer-bottom{flex-direction:column;text-align:center}
    .page-header{padding:40px 16px 24px}
    .glass-card{padding:24px}
    .pricing-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
    .nav-item span{display:none}
    .stats-grid{grid-template-columns:1fr}
    .stat-number{font-size:1.8rem}
}

/* ============================================
   PERFORMANCE: reduce animations on low-end
   ============================================ */
@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
    .bg-orb{animation:none !important;opacity:0.05}
}
