/* ============================================================
   GoG Bot Panel - Light Theme (GTPhone-style) with Lilac primary
   ============================================================ */
:root {
    --primary: #9333EA;
    --primary-dark: #7C3AED;
    --primary-light: #A855F7;
    --primary-bg: #F3E8FF;
    --primary-glow: rgba(147,51,234,0.12);
    --secondary: #6366F1;
    --error: #EF4444;
    --warning: #F59E0B;
    --success: #10B981;
    --info: #3B82F6;
    --bg: #F8F9FC;
    --bg-paper: #FFFFFF;
    --bg-paper-elevated: #F9FAFB;
    --bg-card: #FFFFFF;
    --bg-header: #F3F4F6;
    --text-primary: #111827;
    --text-secondary: #6B7280;
    --text-disabled: #9CA3AF;
    --divider: #E5E7EB;
    --border: #E5E7EB;
    --shadow: 0 1px 3px rgba(0,0,0,0.08);
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.08);
    --shadow-lg: 0 10px 25px rgba(0,0,0,0.1);
    --radius: 8px;
    --radius-lg: 14px;
    --sidebar-width: 220px;
}
* { margin:0; padding:0; box-sizing:border-box; }
html, body {
    height:100%; font-family:'Roboto','Noto Sans','Noto Sans JP',sans-serif;
    background:var(--bg); color:var(--text-primary);
    font-size:14px; line-height:1.5;
}
a { color:var(--primary); text-decoration:none; }
a:hover { color:var(--primary-dark); }

/* ============================================================
   SIDEBAR (fixed, GTPhone-style)
   ============================================================ */
.sidebar {
    position:fixed; top:0; left:0; bottom:0; width:var(--sidebar-width);
    background:var(--bg-paper); border-right:1px solid var(--divider);
    display:flex; flex-direction:column; z-index:100;
    overflow-y:auto;
}
.sidebar-logo {
    display:flex; align-items:center; gap:10px; padding:20px 18px;
    border-bottom:1px solid var(--divider);
}
.sidebar-logo-icon {
    width:36px; height:36px; border-radius:10px;
    background:linear-gradient(135deg, var(--primary), var(--primary-light));
    display:flex; align-items:center; justify-content:center; color:white;
}
.sidebar-logo-icon .material-icons { font-size:20px; }
.sidebar-logo-text { font-size:16px; font-weight:700; color:var(--text-primary); }

.sidebar-section-title {
    font-size:10px; text-transform:uppercase; letter-spacing:1.5px;
    color:var(--text-disabled); padding:20px 18px 6px; font-weight:600;
}

/* Game section collapsible */
.game-section { border-bottom:1px solid var(--divider); }
.game-section:last-of-type { border-bottom:none; }
.game-section-header {
    display:flex; align-items:center; gap:10px; padding:12px 18px;
    cursor:pointer; user-select:none; transition:background 0.15s;
}
.game-section-header:hover { background:var(--bg); }
.game-section-icon { font-size:22px; }
.game-section-name {
    flex:1; font-size:13px; font-weight:600; color:var(--text-primary);
}
.game-section-arrow {
    font-size:20px; color:var(--text-disabled);
    transition:transform 0.25s ease;
}
.game-section.collapsed .game-section-arrow { transform:rotate(-90deg); }
.game-section-content {
    max-height:600px; overflow:hidden;
    transition:max-height 0.3s ease, opacity 0.2s ease;
    opacity:1;
}
.game-section.collapsed .game-section-content {
    max-height:0; opacity:0;
}
.game-section-content .sidebar-item { padding-left:28px; }
.game-section-content .sidebar-castle { padding-left:28px; }

/* Realm selector buttons */
.realm-btn {
    display:inline-flex; align-items:center; gap:4px; padding:4px 10px;
    font-size:11px; font-weight:600; border-radius:12px; cursor:pointer;
    color:var(--text-secondary); background:var(--bg); border:1px solid var(--divider);
    text-decoration:none; transition:all 0.15s;
}
.realm-btn:hover { background:var(--primary-bg); color:var(--primary); }
.realm-btn.active {
    background:var(--primary); color:white; border-color:var(--primary);
}

.sidebar-item {
    display:flex; align-items:center; gap:12px; padding:10px 18px;
    color:var(--text-secondary); font-size:13px; font-weight:500;
    transition:all 0.15s; border-radius:0;
}
.sidebar-item:hover { background:var(--bg); color:var(--text-primary); }
.sidebar-item.active {
    color:var(--primary); background:var(--primary-bg);
    border-right:3px solid var(--primary);
}
.sidebar-item .material-icons { font-size:20px; }
.sidebar-divider { height:1px; background:var(--divider); margin:8px 0; }

/* Castle items in sidebar */
.sidebar-castle { padding:8px 18px; }
.sidebar-castle-info { display:flex; flex-direction:column; flex:1; }
.sidebar-castle-name { font-size:12px; font-weight:500; color:var(--text-primary); }
.sidebar-castle-detail { font-size:10px; color:var(--text-disabled); }
.castle-status-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.dot-green { background:var(--success); }
.dot-red { background:var(--error); }

/* Sidebar user at bottom */
.sidebar-user {
    margin-top:auto; padding:14px 18px; border-top:1px solid var(--divider);
    display:flex; align-items:center; gap:10px;
}
.sidebar-user-avatar {
    width:32px; height:32px; border-radius:8px;
    background:var(--primary); color:white; display:flex;
    align-items:center; justify-content:center; font-size:14px; font-weight:700;
}
.sidebar-user-info { flex:1; }
.sidebar-user-name { font-size:13px; font-weight:600; color:var(--text-primary); }
.sidebar-user-role { font-size:10px; color:var(--text-disabled); }

/* Sidebar collapse */
.sidebar { transition:transform 0.3s ease, width 0.3s ease; }
body.sidebar-collapsed .sidebar { transform:translateX(-100%); }
body.sidebar-collapsed .main-wrapper { margin-left:0 !important; }

/* Mobile sidebar toggle */
.sidebar-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.3); z-index:99; display:none; }
.sidebar-overlay.open { display:block; }
@media (max-width:900px) {
    .sidebar { transform:translateX(-100%); z-index:200; }
    .sidebar.open { transform:translateX(0); }
    .main-wrapper { margin-left:0 !important; }
}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar {
    position:sticky; top:0; z-index:50;
    display:flex; align-items:center; padding:0 24px; height:64px;
    background:var(--bg-paper); border-bottom:1px solid var(--divider);
}
.topbar-menu-btn {
    display:inline-flex; background:none; border:none; cursor:pointer;
    color:var(--text-secondary); padding:6px; border-radius:8px;
}
.topbar-menu-btn:hover { background:var(--bg); }
.topbar-title { font-size:18px; font-weight:700; color:var(--text-primary); }
.topbar-spacer { flex:1; }
.topbar-search {
    display:flex; align-items:center; gap:6px; padding:6px 14px;
    background:var(--bg); border:1px solid var(--divider); border-radius:20px;
    margin-right:12px;
}
.topbar-search .material-icons { font-size:18px; color:var(--text-disabled); }
.topbar-search input {
    border:none; background:transparent; outline:none; font-size:13px;
    color:var(--text-primary); width:160px;
}
.topbar-badge {
    display:inline-flex; align-items:center; gap:6px;
    padding:8px 18px; border-radius:10px; font-size:15px; font-weight:700;
    margin-left:10px;
}
.badge-running { background:var(--success); color:white; }
.badge-stopped { background:rgba(239,68,68,0.1); color:var(--error); border:1px solid rgba(239,68,68,0.2); }
.badge-info { background:rgba(59,130,246,0.1); color:var(--info); border:1px solid rgba(59,130,246,0.2); }
.topbar-play-wrapper { position:relative; }
.play-dropdown {
    position:absolute; top:100%; right:0; margin-top:8px;
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); box-shadow:var(--shadow-md);
    min-width:220px; z-index:200; overflow:hidden;
}
.play-dropdown-title {
    padding:10px 16px; font-size:11px; font-weight:700;
    text-transform:uppercase; letter-spacing:1px; color:var(--text-disabled);
    border-bottom:1px solid var(--divider);
}
.play-dropdown-item {
    display:flex; align-items:center; justify-content:space-between;
    padding:10px 16px; font-size:13px; cursor:pointer;
    transition:background 0.15s;
}
.play-dropdown-item:hover { background:var(--bg); }
.play-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }

.badge-renew { background:var(--success); color:white; transition:opacity 0.2s; }
.badge-renew:hover { opacity:0.85; color:white; }
.badge-renew:visited { color:white; }
.topbar-icon-btn {
    display:inline-flex; align-items:center; justify-content:center;
    width:36px; height:36px; border:none; background:transparent;
    color:var(--text-secondary); border-radius:8px; cursor:pointer;
    margin-left:4px;
}
.topbar-icon-btn:hover { background:var(--bg); }

/* ============================================================
   MAIN WRAPPER
   ============================================================ */
.main-wrapper { margin-left:var(--sidebar-width); min-height:100vh; }
.main-content { padding:24px; max-width:1400px; margin:0 auto; }
.page-single { max-width:1200px; margin:0 auto; }
.page-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:900px) { .page-grid{grid-template-columns:1fr;} }

/* ============================================================
   PAGE HEADER
   ============================================================ */
.page-header {
    display:flex; align-items:center; justify-content:space-between;
    flex-wrap:wrap; gap:12px; margin-bottom:24px;
}
.page-header h1 { font-size:22px; font-weight:700; }

/* ============================================================
   STAT CARDS (colorful gradient cards like GTPhone)
   ============================================================ */
.stats-row {
    display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-bottom:24px;
}
@media (min-width:768px) { .stats-row{grid-template-columns:repeat(3,1fr);} }
@media (min-width:1200px) { .stats-row{grid-template-columns:repeat(4,1fr);} }

.stat-card {
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); padding:18px; text-align:center;
    box-shadow:var(--shadow-sm); transition:all 0.2s;
    position:relative; overflow:hidden;
}
.stat-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.stat-card h5 { margin:0 0 6px; font-size:0.75rem; color:var(--text-secondary); text-transform:uppercase; letter-spacing:0.5px; }
.stat-value { font-size:1.5rem; font-weight:700; margin:0; color:var(--text-primary); }
.stat-unit { font-size:0.7rem; color:var(--text-secondary); }
.stat-icon { position:absolute; top:10px; right:10px; opacity:0.06; }
.stat-icon .material-icons { font-size:40px; }

/* Gradient stat cards (GTPhone-style) */
.stat-gradient {
    border:none; color:white; border-radius:var(--radius-lg);
    padding:20px; position:relative; overflow:hidden;
}
.stat-gradient h5 { color:rgba(255,255,255,0.8); }
.stat-gradient .stat-value { color:white; font-size:1.8rem; }
.stat-gradient .stat-icon { opacity:0.15; }
.stat-gradient .stat-icon .material-icons { font-size:48px; color:white; }
.stat-gradient .stat-badge {
    position:absolute; top:12px; right:12px;
    background:rgba(255,255,255,0.2); color:white; padding:2px 8px;
    border-radius:12px; font-size:11px; font-weight:600;
}
.stat-purple { background:linear-gradient(135deg, #7C3AED, #A855F7); }
.stat-blue { background:linear-gradient(135deg, #2563EB, #3B82F6); }
.stat-green { background:linear-gradient(135deg, #059669, #10B981); }
.stat-orange { background:linear-gradient(135deg, #EA580C, #F97316); }
.stat-pink { background:linear-gradient(135deg, #DB2777, #EC4899); }
.stat-teal { background:linear-gradient(135deg, #0D9488, #14B8A6); }
.stat-red { background:linear-gradient(135deg, #DC2626, #EF4444); }
.stat-yellow { background:linear-gradient(135deg, #D97706, #FBBF24); }

.stat-table { text-align:left; }
.stat-row { display:flex; justify-content:space-between; font-size:13px; padding:2px 0; }

/* Shield styles */
.stat-shield-active { border-color:var(--success); }
.stat-shield-inactive { border-color:rgba(239,68,68,0.3); }
.shield-badge {
    display:inline-flex; align-items:center; gap:4px;
    padding:3px 10px; border-radius:20px; font-size:12px; font-weight:600;
}
.shield-yes { background:rgba(16,185,129,0.1); color:var(--success); }
.shield-no { background:rgba(239,68,68,0.1); color:var(--error); }
.shield-countdown { margin-top:6px; font-size:12px; }
.countdown-timer { font-family:'Roboto Mono',monospace; font-size:13px; color:var(--info); }

/* ============================================================
   STATS GRID (legacy compat)
   ============================================================ */
.stats-grid {
    display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-bottom:24px;
}
@media (min-width:768px) { .stats-grid{grid-template-columns:repeat(3,1fr);} }
@media (min-width:1200px) { .stats-grid{grid-template-columns:repeat(6,1fr);} }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.section-header {
    margin:24px 0 14px; font-size:14px; font-weight:700; color:var(--text-primary);
    text-transform:uppercase; letter-spacing:0.5px;
    display:flex; align-items:center; gap:8px;
}
.section-title {
    font-size:11px; font-weight:600; color:var(--text-disabled);
    text-transform:uppercase; letter-spacing:1px; margin:20px 0 10px;
    padding-bottom:6px; border-bottom:1px solid var(--divider);
}

/* ============================================================
   RESOURCES GRID
   ============================================================ */
.resources-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin-bottom:24px; }
@media (min-width:768px) { .resources-grid{grid-template-columns:repeat(3,1fr);} }
@media (min-width:1200px) { .resources-grid{grid-template-columns:repeat(5,1fr);} }
.resource-card {
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); padding:14px; text-align:center;
    box-shadow:var(--shadow-sm); transition:all 0.2s;
}
.resource-card:hover { box-shadow:var(--shadow-md); }
.resource-card h5 { margin:0 0 8px; font-size:0.85rem; font-weight:600; display:flex; align-items:center; justify-content:center; gap:6px; }
.resource-card p { margin:3px 0; font-size:0.85rem; }
.res-unit { font-size:0.7rem; color:var(--text-secondary); }
.resource-total {
    background:var(--bg); border-radius:var(--radius); padding:6px; margin-top:8px;
    font-weight:600; font-size:0.85rem; border:1px dashed var(--divider);
}
.mono { font-family:'Roboto Mono',monospace; }

/* ============================================================
   CARDS & PANELS
   ============================================================ */
.panel {
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); box-shadow:var(--shadow-sm);
}
.panel-inner { padding:16px; }
.card {
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); padding:24px; margin-bottom:16px;
    box-shadow:var(--shadow-sm);
}
.card h5 { font-size:1.15rem; font-weight:600; margin-bottom:16px; }

/* ============================================================
   ACCORDION
   ============================================================ */
.accordion {
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); margin-bottom:8px; overflow:hidden;
    box-shadow:var(--shadow-sm);
}
.accordion-header {
    display:flex; align-items:center; justify-content:space-between;
    width:100%; padding:14px 16px; background:transparent; border:none;
    color:var(--text-primary); cursor:pointer; font-family:'Roboto',sans-serif;
    transition:background 0.2s;
}
.accordion-header:hover { background:var(--bg); }
.accordion-header h6 { font-size:15px; font-weight:500; margin:0; }
.accordion-icon { transition:transform 0.3s; color:var(--text-secondary); }
.accordion.open .accordion-icon { transform:rotate(180deg); }
.accordion-body { max-height:0; overflow:hidden; transition:max-height 0.4s ease; }
.accordion.open .accordion-body { max-height:3000px; }

/* ============================================================
   GRIDS: TROOPS / BUILDINGS / SPEEDUPS / JOBS
   ============================================================ */
.troop-grid,.building-grid,.speedup-grid { display:grid; gap:8px; padding:12px 16px; }
.troop-grid { grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); }
.building-grid { grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); }
.speedup-grid { grid-template-columns:1fr; }
.troop-item,.building-item,.speedup-item {
    display:flex; align-items:center; gap:8px; font-size:13px;
    padding:6px 10px; border-radius:var(--radius);
    background:var(--bg); border:1px solid var(--divider);
}
.building-level {
    display:inline-flex; align-items:center; justify-content:center;
    min-width:28px; height:24px; background:var(--primary-bg);
    border:1px solid var(--primary); border-radius:4px;
    font-size:12px; font-weight:700; color:var(--primary);
}
.jobs-list { display:flex; flex-direction:column; gap:6px; margin-bottom:20px; }
.job-item {
    display:flex; align-items:center; gap:10px; padding:10px 14px;
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius); font-size:13px; border-left:3px solid var(--info);
    box-shadow:var(--shadow-sm);
}
.job-type { flex:1; }
.job-time { color:var(--info); font-weight:600; }

/* ============================================================
   TASKS LIST
   ============================================================ */
.tasks-list { border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--divider); box-shadow:var(--shadow-sm); }
.task-item { background:var(--bg-card); border-bottom:1px solid var(--divider); transition:all 0.2s; }
.task-item:last-child { border-bottom:none; }
.task-item:hover { background:var(--bg); }
.task-item-header { display:flex; align-items:center; gap:10px; padding:10px 14px; }
.task-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.task-name { flex:1; font-size:13px; font-weight:500; }
.task-count { font-size:0.85rem; color:var(--text-secondary); font-weight:400; }
.inactive-label { font-size:11px; color:var(--text-disabled); font-style:italic; margin-left:4px; }

/* ============================================================
   SWITCH
   ============================================================ */
.switch { position:relative; display:inline-block; width:42px; height:24px; flex-shrink:0; }
.switch input { opacity:0; width:0; height:0; }
.slider {
    position:absolute; cursor:pointer; inset:0;
    background:#D1D5DB; transition:0.3s; border-radius:24px;
}
.slider:before {
    content:""; position:absolute; height:18px; width:18px;
    left:3px; bottom:3px; background:white; transition:0.3s;
    border-radius:50%; box-shadow:0 1px 3px rgba(0,0,0,0.2);
}
input:checked + .slider { background:var(--primary); }
input:checked + .slider:before { transform:translateX(18px); }
.switch-sm { width:36px; height:20px; }
.switch-sm .slider:before { height:14px; width:14px; }
.switch-sm input:checked + .slider:before { transform:translateX(16px); }

/* ============================================================
   RENEWAL BANNER
   ============================================================ */
.renewal-banner {
    display:flex; align-items:center; gap:10px;
    background:linear-gradient(135deg, var(--success), #059669);
    color:white; padding:12px 20px; border-radius:var(--radius-lg);
    margin-bottom:20px; font-size:14px;
}

/* ============================================================
   GESTION GRID (enchantedbot style)
   ============================================================ */
.gestion-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; }
.gestion-card {
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); overflow:hidden;
    box-shadow:var(--shadow-sm); transition:box-shadow 0.2s;
}
.gestion-card:hover { box-shadow:var(--shadow-md); }
.gestion-card-header {
    display:flex; justify-content:space-between; align-items:center;
    padding:14px 16px; border-bottom:1px solid var(--divider);
}
.gestion-card-title { display:flex; flex-direction:column; gap:2px; }
.gestion-card-title strong { font-size:14px; color:var(--text-primary); }
.gestion-card-meta { font-size:11px; color:var(--text-secondary); }
.gestion-card-toggle { display:flex; align-items:center; gap:8px; }
.gestion-status-label { font-size:12px; color:var(--text-secondary); }
.gestion-card-resources {
    display:grid; grid-template-columns:repeat(3, 1fr); gap:8px;
    padding:14px 16px;
}
.gestion-res-item {
    display:flex; align-items:center; gap:6px; font-size:13px;
    color:var(--text-primary);
}
.gestion-card-actions {
    display:flex; gap:8px; padding:10px 16px;
    border-top:1px solid var(--divider); background:var(--bg);
}
.gestion-action-btn {
    display:inline-flex; align-items:center; gap:4px;
    font-size:12px; font-weight:600; color:var(--primary);
    text-decoration:none; padding:6px 12px; border-radius:6px;
    transition:background 0.15s;
}
.gestion-action-btn:hover { background:var(--primary-bg); }

/* ============================================================
   LOGIN METHOD BUTTONS
   ============================================================ */
.login-method-btn {
    display:flex; flex-direction:column; align-items:center; gap:6px;
    padding:14px 8px; border:2px solid var(--divider); border-radius:10px;
    background:var(--bg-card); cursor:pointer; transition:all 0.15s;
    font-size:12px; font-weight:600; color:var(--text-secondary);
}
.login-method-btn:hover { border-color:var(--primary-light); background:var(--bg); }
.login-method-btn.active { border-color:var(--primary); background:var(--primary-bg); color:var(--primary); }

/* ============================================================
   STATES LIST
   ============================================================ */
.states-list { display:flex; flex-direction:column; gap:4px; }
.states-item {
    display:flex; align-items:center; gap:12px;
    padding:10px 0; border-bottom:1px solid var(--divider);
}
.states-item:last-child { border-bottom:none; }
.states-name { font-size:15px; font-weight:600; color:var(--text-primary); }

/* ============================================================
   ACTIONS PAGE
   ============================================================ */
.actions-layout { display:grid; grid-template-columns:1fr 380px; gap:20px; }
@media (max-width:900px) { .actions-layout { grid-template-columns:1fr; } }
.actions-left { min-width:0; }
.actions-right {
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); overflow:hidden; align-self:start;
    position:sticky; top:80px;
}
.actions-queue-header {
    display:flex; align-items:center; gap:10px;
    padding:14px 16px; border-bottom:1px solid var(--divider);
}
.actions-queue-body { padding:8px 16px; background:var(--bg); min-height:200px; }
.queue-item {
    display:flex; align-items:center; gap:8px;
    padding:8px 0; font-size:13px; color:var(--text-primary);
    border-bottom:1px solid var(--divider);
}
.action-section-title {
    display:flex; align-items:center; gap:6px;
    font-size:12px; font-weight:700; color:var(--primary);
    text-transform:uppercase; letter-spacing:1px;
    padding:8px 0; margin-top:8px;
}
.action-row {
    display:flex; align-items:center; justify-content:space-between;
    padding:10px 14px; margin-bottom:4px;
    border:1px solid var(--divider); border-radius:8px;
    background:var(--bg-card); transition:background 0.15s;
}
.action-row:hover { background:var(--bg); }
.action-row-left { display:flex; align-items:center; gap:10px; flex:1; min-width:0; }
.action-icon { font-size:18px; }
.action-icon-instant { color:var(--primary); }
.action-icon-config { color:var(--warning); }
.action-label { font-size:13px; font-weight:600; color:var(--primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.scope-btn { font-size:12px; padding:8px 14px; }
.scope-btn.active { background:var(--primary); color:white; border-color:var(--primary); }

/* ============================================================
   OVERVIEW GRID (legacy)
   ============================================================ */
.overview-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; }
.overview-card {
    display:block; background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); padding:20px; color:var(--text-primary);
    transition:all 0.2s; box-shadow:var(--shadow-sm);
}
.overview-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.overview-card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; }
.overview-card-header h5 { margin:0; font-size:1.05rem; font-weight:600; }
.overview-stats { display:flex; gap:14px; font-size:13px; color:var(--text-secondary); }

/* ============================================================
   TABLES
   ============================================================ */
.table-responsive { overflow-x:auto; }
.data-table { width:100%; border-collapse:collapse; }
.data-table thead { background:var(--bg); }
.data-table th {
    padding:12px 16px; text-align:left; font-weight:600;
    font-size:12px; color:var(--text-secondary); text-transform:uppercase;
    letter-spacing:0.5px; border-bottom:2px solid var(--divider);
}
.data-table td { padding:10px 16px; border-bottom:1px solid var(--divider); font-size:13px; }
.data-table tbody tr { transition:background 0.15s; }
.data-table tbody tr:hover { background:var(--bg); }
.data-table .total-row { background:var(--primary-bg); }
.data-table .total-row td { font-weight:600; }
.text-right { text-align:right; }

/* ============================================================
   FORMS
   ============================================================ */
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:13px; color:var(--text-primary); margin-bottom:6px; font-weight:500; }
.form-group input, .form-group select, .select-full {
    width:100%; padding:10px 14px; background:var(--bg);
    border:1px solid var(--divider); border-radius:var(--radius);
    color:var(--text-primary); font-family:'Roboto',sans-serif; font-size:14px;
    outline:none; transition:all 0.2s;
}
.form-group input:focus, .form-group select:focus { border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-glow); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display:inline-flex; align-items:center; gap:8px; padding:10px 20px;
    border:none; border-radius:var(--radius); font-family:'Roboto',sans-serif;
    font-size:14px; font-weight:500; cursor:pointer; transition:all 0.2s;
}
.btn .material-icons { font-size:18px; }
.btn-primary { background:linear-gradient(135deg, var(--primary), var(--primary-light)); color:white; }
.btn-primary:hover { opacity:0.9; box-shadow:var(--shadow-md); }
.btn-outlined { background:transparent; border:1px solid var(--divider); color:var(--text-primary); }
.btn-outlined:hover { background:var(--bg); border-color:var(--primary); color:var(--primary); }
.btn-full { width:100%; justify-content:center; }
.btn-action {
    width:100%; justify-content:flex-start; background:var(--bg-card);
    border:1px solid var(--divider); color:var(--text-primary);
    margin-bottom:6px; padding:12px 16px; border-radius:var(--radius);
}
.btn-action:hover { border-color:var(--primary); background:var(--primary-bg); }
.btn-action .material-icons { color:var(--text-secondary); }
.btn-outline { background:transparent; border:1px solid var(--divider); color:var(--text-primary); display:inline-flex; align-items:center; gap:6px; padding:8px 16px; border-radius:var(--radius); font-size:13px; font-weight:500; cursor:pointer; transition:all 0.2s; font-family:'Roboto',sans-serif; }
.btn-outline:hover { background:var(--bg); border-color:var(--primary); color:var(--primary); }
.btn-icon { background:none; border:none; cursor:pointer; padding:6px; border-radius:50%; transition:background 0.15s; display:inline-flex; align-items:center; }
.btn-icon:hover { background:var(--bg); }

/* Input field */
.input-field { padding:8px 12px; border:1px solid var(--divider); border-radius:var(--radius); font-size:14px; font-family:'Roboto',sans-serif; color:var(--text-primary); background:var(--bg-card); outline:none; transition:border-color 0.2s; }
.input-field:focus { border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-glow); }

/* Toggle switch */
.toggle-switch { position:relative; display:inline-block; width:44px; height:24px; flex-shrink:0; }
.toggle-switch input { opacity:0; width:0; height:0; }
.toggle-slider { position:absolute; cursor:pointer; top:0; left:0; right:0; bottom:0; background:var(--divider); transition:0.3s; border-radius:24px; }
.toggle-slider:before { content:''; position:absolute; height:18px; width:18px; left:3px; bottom:3px; background:white; transition:0.3s; border-radius:50%; box-shadow:var(--shadow-sm); }
.toggle-switch input:checked + .toggle-slider { background:var(--primary); }
.toggle-switch input:checked + .toggle-slider:before { transform:translateX(20px); }

/* Table wrapper */
.table-wrapper { overflow-x:auto; }

/* ============================================================
   FILTER BAR
   ============================================================ */
.task-filter-row { display:flex; gap:8px; margin-bottom:12px; }
.task-filter-row select, .task-filter-row input {
    padding:8px 12px; background:var(--bg);
    border:1px solid var(--divider); border-radius:var(--radius);
    color:var(--text-primary); font-size:13px; outline:none;
}
.task-filter-row input { flex:1; }
.task-filter-row select:focus, .task-filter-row input:focus { border-color:var(--primary); }

/* ============================================================
   CASTLE HEADER
   ============================================================ */
.castle-header {
    display:flex; align-items:center; justify-content:space-between;
    flex-wrap:wrap; gap:12px; margin-bottom:24px;
    padding:16px 20px; background:var(--bg-card); border-radius:var(--radius-lg);
    border:1px solid var(--divider); box-shadow:var(--shadow-sm);
}
.castle-header h4 { margin:0; font-size:1.4rem; font-weight:600; }
.castle-header-left { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.castle-header-right { display:flex; align-items:center; gap:10px; }
.castle-badge {
    background:var(--bg); padding:4px 12px; border-radius:20px;
    font-size:12px; color:var(--text-secondary); border:1px solid var(--divider);
}

/* ============================================================
   QUEUE
   ============================================================ */
.queue-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:12px 16px; border-bottom:1px solid var(--divider);
}
.queue-header-left { display:flex; align-items:center; gap:8px; }
.queue-header-left h6 { font-size:15px; font-weight:500; margin:0; }
.queue-content { padding:16px; }
.queue-empty {
    display:flex; flex-direction:column; align-items:center;
    justify-content:center; padding:48px 16px; color:var(--text-disabled);
}

/* ============================================================
   TABS / PROFILE
   ============================================================ */
.tabs-bar {
    display:flex; background:var(--bg-card);
    border-radius:var(--radius-lg) var(--radius-lg) 0 0;
    margin-bottom:16px; overflow:hidden; border:1px solid var(--divider); border-bottom:none;
}
.tab {
    padding:12px 24px; background:transparent; border:none;
    color:var(--text-secondary); font-family:'Roboto',sans-serif;
    font-size:14px; font-weight:500; cursor:pointer; transition:all 0.2s;
    border-bottom:3px solid transparent;
}
.tab:hover { color:var(--text-primary); background:var(--bg); }
.tab.active { color:var(--primary); border-bottom-color:var(--primary); }
.profile-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:900px) { .profile-grid{grid-template-columns:1fr;} }
.profile-tabs { display:flex; background:var(--primary-dark); border-radius:0; margin-bottom:16px; overflow:hidden; }
.profile-tab {
    padding:12px 24px; background:transparent; border:none;
    color:rgba(255,255,255,0.7); font-family:'Roboto',sans-serif;
    font-size:14px; font-weight:600; cursor:pointer; transition:all 0.2s;
    border-bottom:3px solid transparent; letter-spacing:0.5px;
}
.profile-tab:hover { color:white; }
.profile-tab.active { color:white; border-bottom-color:white; }
.profile-email { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.email-row { display:flex; align-items:center; gap:8px; }
.verified-icon { color:var(--success); font-size:20px; }
.renew-panel { border-radius:var(--radius-lg); padding:14px 18px; margin-bottom:16px; }
.renew-panel-success { background:rgba(16,185,129,0.05); border:1px solid rgba(16,185,129,0.2); }
.renew-panel-content { display:flex; flex-direction:column; gap:4px; }
.renew-panel-line { display:flex; align-items:center; gap:8px; font-size:14px; }
.renew-panel-line.sub { font-size:12px; color:var(--text-secondary); }

/* ============================================================
   LOGS
   ============================================================ */
.logs-container {
    max-height:70vh; overflow-y:auto; font-size:12px; font-family:'Roboto Mono',monospace;
    background:var(--bg); border-radius:var(--radius-lg); padding:10px; border:1px solid var(--divider);
}
.log-entry { display:flex; gap:8px; padding:4px 8px; border-radius:4px; line-height:1.7; }
.log-entry:hover { background:rgba(0,0,0,0.03); }
.log-time { color:var(--text-disabled); min-width:65px; }
.log-level { min-width:50px; font-weight:700; font-size:11px; }
.log-info .log-level { color:var(--info); }
.log-warning .log-level { color:var(--warning); }
.log-error .log-level { color:var(--error); }
.log-account { color:var(--primary); min-width:70px; }
.log-msg { color:var(--text-primary); word-break:break-all; flex:1; }

/* ============================================================
   DIALOG / SNACKBAR
   ============================================================ */
.dialog-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,0.3); z-index:300;
    display:flex; align-items:center; justify-content:center;
    backdrop-filter:blur(4px);
}
.dialog {
    background:var(--bg-card); border-radius:var(--radius-lg);
    padding:28px; min-width:360px; max-width:90vw; border:1px solid var(--divider);
    box-shadow:var(--shadow-lg);
}
.dialog h5 { font-size:1.2rem; margin-bottom:16px; }
.dialog-actions { display:flex; justify-content:flex-end; gap:8px; margin-top:24px; }
.snackbar {
    position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(100px);
    padding:12px 28px; background:#313131; color:white; border-radius:var(--radius);
    box-shadow:var(--shadow-lg); font-size:14px; z-index:400;
    transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);
}
.snackbar.show { transform:translateX(-50%) translateY(0); }
.snackbar.snack-success { background:var(--success); }
.snackbar.snack-error { background:var(--error); }
.snackbar.snack-warning { background:var(--warning); }

/* ============================================================
   LOGIN
   ============================================================ */
.login-body {
    display:flex; align-items:center; justify-content:center; min-height:100vh;
    background:linear-gradient(135deg, #C4B5FD 0%, #A78BFA 30%, #8B5CF6 60%, #7C3AED 100%);
}
.login-card {
    background:white; border-radius:var(--radius-lg); padding:44px;
    width:100%; max-width:420px; box-shadow:var(--shadow-lg);
}
.login-header { text-align:center; margin-bottom:36px; }
.login-header h1 { font-size:26px; font-weight:700; margin-top:14px; color:var(--text-primary); }
.login-header p { color:var(--text-secondary); margin-top:8px; }
.error-text { color:var(--error); font-size:13px; margin-top:12px; text-align:center; }

/* ============================================================
   SEARCH BAR
   ============================================================ */
.search-bar {
    display:flex; align-items:center; gap:8px; padding:10px 16px;
    background:var(--bg-card); border-radius:var(--radius-lg);
    border:1px solid var(--divider); margin-bottom:16px;
}
.search-bar .material-icons { color:var(--text-secondary); }
.search-bar input { flex:1; background:transparent; border:none; color:var(--text-primary); font-size:14px; outline:none; }

/* ============================================================
   MISC
   ============================================================ */
.last-update { margin-top:24px; font-size:11px; color:var(--text-disabled); text-align:right; font-family:'Roboto Mono',monospace; }
.action-buttons { margin-top:16px; max-height:calc(100vh - 200px); overflow-y:auto; padding-right:4px; }
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:#D1D5DB; border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:#9CA3AF; }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeInUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes slideIn { from{opacity:0;transform:translateX(-20px)} to{opacity:1;transform:translateX(0)} }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.5} }
.stat-card { animation:fadeInUp 0.4s ease both; }
.stat-card:nth-child(1){animation-delay:0.05s} .stat-card:nth-child(2){animation-delay:0.1s}
.stat-card:nth-child(3){animation-delay:0.15s} .stat-card:nth-child(4){animation-delay:0.2s}
.resource-card { animation:fadeInUp 0.4s ease both; }
.overview-card { animation:fadeInUp 0.4s ease both; }
.task-item { animation:slideIn 0.3s ease both; }
.job-item { animation:slideIn 0.3s ease both; }
.castle-header { animation:fadeInUp 0.4s ease; }

/* ============================================================
   GIT PAGE (inline in git.html, keep compat)
   ============================================================ */
.git-project-card {
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:14px; padding:20px; box-shadow:var(--shadow-sm);
    animation:fadeInUp 0.4s ease both;
}
.git-project-card:nth-child(2) { animation-delay:0.1s; }
.git-project-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.git-project-info { display:flex; align-items:center; gap:12px; }
.git-project-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; color:white; }
.git-project-icon .material-icons { font-size:20px; }
.git-project-name { font-size:15px; font-weight:600; margin:0; }
.git-project-sub { font-size:11px; color:var(--text-disabled); }
.git-branch-badge { display:flex; align-items:center; gap:4px; background:var(--primary-bg); color:var(--primary); padding:4px 12px; border-radius:20px; font-size:12px; font-weight:600; }
.git-commit-info { display:flex; align-items:center; gap:8px; margin-bottom:10px; font-size:12px; }
.git-commit-hash { background:var(--bg); padding:2px 8px; border-radius:4px; font-family:'Roboto Mono',monospace; color:var(--text-secondary); }
.git-commit-msg { color:var(--text-primary); flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.git-commit-date { color:var(--text-disabled); white-space:nowrap; }
.git-changes-badge { padding:3px 10px; border-radius:20px; font-size:11px; font-weight:600; }
.git-changes-badge.ok { background:rgba(16,185,129,0.1); color:var(--success); }
.git-changes-badge.warn { background:rgba(245,158,11,0.1); color:var(--warning); }
.git-actions-row { display:flex; flex-wrap:wrap; gap:6px; }
.git-branch-item { display:flex; align-items:center; gap:8px; padding:8px 12px; border-radius:8px; cursor:pointer; font-size:13px; color:var(--text-secondary); transition:all 0.15s; }
.git-branch-item:hover { background:var(--bg); color:var(--text-primary); }
.git-branch-item.active { background:var(--primary-bg); color:var(--primary); font-weight:600; }
.git-tag-current { background:rgba(16,185,129,0.1); color:var(--success); padding:1px 6px; border-radius:4px; font-size:10px; margin-left:auto; }
.git-tag-prod { background:rgba(59,130,246,0.1); color:var(--info); padding:1px 6px; border-radius:4px; font-size:10px; margin-left:auto; }
.git-log-item { display:flex; justify-content:space-between; align-items:center; padding:8px; border-radius:8px; border:1px solid var(--divider); }
.git-log-left { display:flex; align-items:center; gap:8px; flex:1; min-width:0; }
.git-log-msg { font-size:13px; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.git-log-right { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.git-log-date { font-size:11px; color:var(--text-disabled); }

/* ============================================================
   LANGUAGE SELECTOR
   ============================================================ */
.lang-selector { position:relative; margin-left:10px; }
.lang-btn {
    display:flex; align-items:center; justify-content:center;
    width:46px; height:46px; border:2px solid var(--divider);
    border-radius:10px; background:var(--bg); cursor:pointer;
    font-size:26px; transition:all 0.2s;
}
.lang-btn:hover { border-color:var(--primary); background:var(--primary-bg); }
.lang-dropdown {
    position:absolute; top:calc(100% + 8px); right:0;
    background:var(--bg-card); border:1px solid var(--divider);
    border-radius:var(--radius-lg); box-shadow:var(--shadow-lg);
    min-width:200px; z-index:200; overflow:hidden;
    padding:6px 0;
}
.lang-item {
    display:flex; align-items:center; gap:10px; padding:12px 20px;
    font-size:16px; font-weight:500; color:var(--text-primary); cursor:pointer;
    transition:all 0.15s;
}
.lang-item:hover { background:var(--bg); color:var(--primary); }

/* Legacy compat aliases */
.drawer-overlay { display:none; }
.drawer { display:none; }
.appbar { display:none; }

/* Badge compat */
.service-badge, .service-badge-sm { display:none; }
.renew-badge { display:none; }
