/* GlitchScript - Light Theme v3 */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;600&display=swap');

:root {
  --bg-primary:   #f4f5fb;
  --bg-secondary: #ffffff;
  --bg-card:      #ffffff;
  --bg-hover:     #eef0f9;
  --bg-input:     #f4f5fb;
  --accent:       #7c3aed;
  --accent-hover: #6d28d9;
  --accent-dim:   rgba(124,58,237,0.09);
  --accent-glow:  rgba(124,58,237,0.28);
  --green:  #059669; --green-dim:  rgba(5,150,105,0.1);
  --red:    #dc2626; --red-dim:    rgba(220,38,38,0.1);
  --yellow: #d97706; --yellow-dim: rgba(217,119,6,0.1);
  --blue:   #2563eb; --blue-dim:   rgba(37,99,235,0.1);
  --text-primary:   #111827;
  --text-secondary: #374151;
  --text-muted:     #9ca3af;
  --border:         #e5e7eb;
  --border-hover:   #d1d5db;
  --radius-sm:  6px;
  --radius-md:  10px;
  --radius-lg:  14px;
  --radius-xl:  20px;
  --shadow-sm:   0 1px 3px rgba(0,0,0,0.06),0 1px 2px rgba(0,0,0,0.04);
  --shadow-card: 0 4px 16px rgba(0,0,0,0.08);
  --shadow-hover:0 8px 30px rgba(0,0,0,0.12);
  --font-main: 'Plus Jakarta Sans', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden;max-width:100vw}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg-primary)}
::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* ===== NAVBAR ===== */
.navbar{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:0 24px;height:64px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  box-shadow:0 1px 4px rgba(0,0,0,0.06);
  width:100%;box-sizing:border-box;
}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.nav-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent),#9d50ff);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 2px 8px var(--accent-glow)}
.nav-logo span{font-size:20px;font-weight:800;color:var(--text-primary);letter-spacing:-0.5px}
.nav-logo span em{font-style:normal;color:var(--accent)}
.nav-search{flex:1;max-width:480px;position:relative}
.nav-search input{width:100%;padding:10px 16px 10px 42px;background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-xl);color:var(--text-primary);font-family:var(--font-main);font-size:14px;outline:none;transition:all 0.2s}
.nav-search input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-dim)}
.nav-search input::placeholder{color:var(--text-muted)}
.nav-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:15px}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-link{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-md);text-decoration:none;font-size:14px;font-weight:600;color:var(--text-secondary);transition:all 0.2s;white-space:nowrap}
.nav-link:hover{color:var(--text-primary);background:var(--bg-hover)}
.nav-link.active{color:var(--accent);background:var(--accent-dim)}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 20px;border-radius:var(--radius-md);font-family:var(--font-main);font-size:14px;font-weight:600;cursor:pointer;border:none;text-decoration:none;transition:all 0.2s;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}
.btn-outline{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}
.btn-outline:hover{background:var(--accent-dim)}
.btn-secondary{background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--border);color:var(--text-primary)}
.btn-sm{padding:6px 14px;font-size:13px}
.btn-lg{padding:13px 28px;font-size:16px}
.btn-danger{background:var(--red);color:#fff}
.btn-success{background:var(--green);color:#fff}
.btn-warning{background:var(--yellow);color:#fff}

/* ===== LAYOUT ===== */
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.main-layout{display:grid;grid-template-columns:240px 1fr;gap:24px;padding:24px 0}

/* ===== SIDEBAR ===== */
.sidebar{position:sticky;top:88px;height:fit-content;display:flex;flex-direction:column;gap:8px}
.sidebar-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:8px;box-shadow:var(--shadow-sm)}
.sidebar-title{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);text-decoration:none;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all 0.2s;margin-bottom:2px}
.sidebar-link:hover,.sidebar-link.active{color:var(--text-primary);background:var(--bg-hover)}
.sidebar-link.active{color:var(--accent);background:var(--accent-dim)}
.sidebar-link .icon{font-size:16px;width:20px;text-align:center}
.sidebar-link .badge-count{margin-left:auto;font-size:11px;font-weight:700;background:var(--bg-hover);color:var(--text-muted);padding:2px 8px;border-radius:20px}

/* ===== CARD ===== */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all 0.2s}
.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-hover);transform:translateY(-2px)}

/* ===== SCRIPT GRID ===== */
.script-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}

.script-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  display:flex;
  flex-direction:column;
  transition:all 0.25s;
  box-shadow:var(--shadow-sm);
}
.script-card:hover{border-color:var(--accent);box-shadow:var(--shadow-hover);transform:translateY(-3px)}

/* Thumbnail */
.script-card-thumb-placeholder{
  width:100%;height:180px;
  background:linear-gradient(135deg,#ede9fe,#ddd6fe);
  display:flex;align-items:center;justify-content:center;
  font-size:48px;position:relative;overflow:hidden;flex-shrink:0;
}
.script-card-thumb-placeholder img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}

.script-card-stats-bar{position:absolute;top:10px;left:10px;right:10px;display:flex;justify-content:space-between;align-items:center;z-index:3;pointer-events:none}
.script-card-stat-pill{background:rgba(0,0,0,0.55);backdrop-filter:blur(8px);color:#fff;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;display:flex;align-items:center;gap:4px}

.script-card-thumb-overlay,.script-card-thumb-game,.script-card-thumb-title{display:none}

/* BADGES — selalu di luar thumbnail */
.script-badges{display:flex;gap:5px;flex-wrap:wrap;padding:8px 12px 4px;background:var(--bg-card);min-height:32px}
/* Kalau badge masih ada di dalam thumb (legacy), sembunyikan */
.script-card-thumb-placeholder .script-badges{display:none !important}

.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:0.2px;white-space:nowrap}
.badge-verified {background:#d1fae5;color:#065f46}
.badge-patched  {background:#fee2e2;color:#991b1b}
.badge-key      {background:#fef3c7;color:#92400e}
.badge-universal{background:#dbeafe;color:#1e40af}
.badge-paid     {background:#fde68a;color:#78350f}
.badge-free     {background:#d1fae5;color:#065f46}
.badge-pending  {background:#fef3c7;color:#92400e}
.badge-removed  {background:#fee2e2;color:#991b1b}

/* Card body */
.script-card-body{padding:6px 12px 10px;flex:1;display:flex;flex-direction:column;gap:4px;background:var(--bg-card)}
.script-card-game{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--accent)}
.script-card-title{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.script-card-desc{font-size:13px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.script-card-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 10px;border-top:1px solid var(--border);background:#fafafa;margin-top:auto}
.script-card-author{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);text-decoration:none}
.script-card-author:hover{color:var(--accent)}

/* Avatar */
.avatar{border-radius:50%;background:linear-gradient(135deg,var(--accent),#9d50ff);display:flex;align-items:center;justify-content:center;font-weight:700;color:white;flex-shrink:0}
.avatar-sm{width:24px;height:24px;font-size:11px}
.avatar-md{width:36px;height:36px;font-size:14px}
.avatar-lg{width:56px;height:56px;font-size:20px}
.avatar-xl{width:80px;height:80px;font-size:28px}

.script-stats{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-muted)}
.script-stat{display:flex;align-items:center;gap:3px}

/* ===== FILTERS ===== */
.filters-bar{display:flex;align-items:center;gap:10px;padding:16px 0;flex-wrap:wrap}
.filter-chip{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-secondary);text-decoration:none;transition:all 0.2s;box-shadow:var(--shadow-sm)}
.filter-chip:hover,.filter-chip.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}
.filter-select{padding:7px 32px 7px 12px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-main);font-size:13px;font-weight:600;outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;box-shadow:var(--shadow-sm)}
.filter-select:focus{border-color:var(--accent)}

/* ===== HERO ===== */
.hero{padding:64px 0 48px;text-align:center;position:relative;background:linear-gradient(180deg,#f5f3ff 0%,var(--bg-primary) 100%)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(124,58,237,0.08) 0%,transparent 70%);pointer-events:none}
.hero h1{font-size:52px;font-weight:800;line-height:1.1;letter-spacing:-2px;margin-bottom:16px;color:var(--text-primary)}
.hero h1 .gradient-text{background:linear-gradient(135deg,var(--accent),#9d50ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{font-size:17px;color:var(--text-secondary);max-width:520px;margin:0 auto 32px}
.hero-stats{display:flex;justify-content:center;gap:40px;margin-bottom:40px}
.hero-stat-num{font-size:28px;font-weight:800;color:var(--text-primary);font-family:var(--font-mono)}
.hero-stat-label{font-size:13px;color:var(--text-muted);margin-top:2px}
.hero-stat{text-align:center;flex:1;min-width:0}

/* ===== SECTION ===== */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.section-title{font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px;color:var(--text-primary)}
.section-title .icon{color:var(--accent)}

/* ===== FORMS ===== */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:13px;font-weight:700;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:0.5px}
.form-control{width:100%;padding:11px 14px;background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-main);font-size:14px;outline:none;transition:all 0.2s}
.form-control:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-dim)}
.form-control::placeholder{color:var(--text-muted)}
textarea.form-control{resize:vertical;min-height:120px}
.form-control.code-editor{font-family:var(--font-mono);font-size:13px;min-height:300px;line-height:1.6;background:#1e1e2e;color:#cdd6f4;border-color:#313244}
.form-error{font-size:12px;color:var(--red);margin-top:6px;display:flex;align-items:center;gap:4px}
.form-hint{font-size:12px;color:var(--text-muted);margin-top:6px}

/* Toggle */
.toggle-group{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.toggle-group:last-child{border-bottom:none}
.toggle-info h4{font-size:14px;font-weight:600}
.toggle-info p{font-size:12px;color:var(--text-muted)}
.toggle{position:relative;display:inline-block;width:46px;height:24px}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:24px;transition:0.3s}
.toggle-slider::before{content:'';position:absolute;height:16px;width:16px;left:4px;bottom:4px;background:white;border-radius:50%;transition:0.3s;box-shadow:0 1px 3px rgba(0,0,0,0.2)}
.toggle input:checked+.toggle-slider{background:var(--accent)}
.toggle input:checked+.toggle-slider::before{transform:translateX(22px)}

/* Tag Input */
.tag-chip{display:inline-flex;align-items:center;gap:4px;background:var(--accent-dim);color:var(--accent);border:1px solid rgba(124,58,237,0.3);border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}
.tag-chip button{background:none;border:none;cursor:pointer;color:inherit;font-size:15px;padding:0;line-height:1}
#tag-container{display:flex;flex-wrap:wrap;gap:6px;align-items:center;background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:8px 12px;min-height:46px;cursor:text}
#tag-container:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
#tag-input{background:none;border:none;outline:none;color:var(--text-primary);font-family:var(--font-main);font-size:14px;min-width:120px;flex:1}
.type-option{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all 0.2s;background:var(--bg-card)}
.type-option.active{border-color:var(--accent);background:var(--accent-dim)}
.type-option input{margin:0;accent-color:var(--accent)}

/* ===== SCRIPT DETAIL ===== */
.script-detail-header{display:grid;grid-template-columns:1fr 320px;gap:28px;margin-bottom:28px}
.script-thumbnail-large{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-radius:var(--radius-lg);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:60px;border:1px solid var(--border)}
.code-block{background:#1e1e2e;border:1px solid #313244;border-radius:var(--radius-lg);padding:0;overflow:hidden;position:relative}
.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#181825;border-bottom:1px solid #313244}
.code-block-lang{font-size:12px;font-family:var(--font-mono);color:#cba6f7;font-weight:700}
.code-block pre{padding:20px;font-family:var(--font-mono);font-size:13px;line-height:1.7;color:#cdd6f4;overflow-x:auto;max-height:400px;white-space:pre-wrap;word-break:break-all}

/* ===== ALERTS ===== */
.alert{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;border-radius:var(--radius-md);font-size:14px;margin-bottom:20px;font-weight:500}
.alert-success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}
.alert-danger {background:#fee2e2;border:1px solid #fecaca;color:#991b1b}
.alert-warning{background:#fef3c7;border:1px solid #fde68a;color:#92400e}
.alert-info   {background:var(--accent-dim);border:1px solid #ddd6fe;color:var(--accent)}

/* ===== PAGINATION ===== */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:32px;flex-wrap:wrap}
.page-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);text-decoration:none;font-size:14px;font-weight:600;color:var(--text-secondary);border:1px solid var(--border);background:var(--bg-card);transition:all 0.2s;box-shadow:var(--shadow-sm)}
.page-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}
.page-btn.active{background:var(--accent);color:white;border-color:var(--accent)}

/* ===== TABLES ===== */
.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;font-size:14px;background:var(--bg-card)}
thead th{background:#f9fafb;padding:12px 16px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}
tbody tr{border-bottom:1px solid var(--border);transition:background 0.15s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--bg-hover)}
tbody td{padding:12px 16px;color:var(--text-primary);vertical-align:middle}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.4);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:all 0.2s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;transform:translateY(20px);transition:transform 0.2s;box-shadow:0 20px 60px rgba(0,0,0,0.15)}
.modal-overlay.active .modal{transform:translateY(0)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.modal-title{font-size:18px;font-weight:700}
.modal-close{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-hover);border:none;color:var(--text-muted);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.modal-close:hover{color:var(--red);background:var(--red-dim)}

/* ===== AUTH ===== */
.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px;background:linear-gradient(135deg,#f5f3ff 0%,#f0f4ff 100%)}
.auth-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:440px;box-shadow:0 20px 60px rgba(0,0,0,0.1)}
.auth-logo{text-align:center;margin-bottom:32px}
.auth-title{font-size:26px;font-weight:800;text-align:center;margin-bottom:8px;color:var(--text-primary)}
.auth-subtitle{text-align:center;color:var(--text-muted);font-size:14px;margin-bottom:32px}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-muted);font-size:12px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* ===== ADMIN ===== */
.admin-layout{display:grid;grid-template-columns:260px 1fr;min-height:calc(100vh - 64px)}
.admin-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);padding:24px 16px;position:sticky;top:64px;height:calc(100vh - 64px);overflow-y:auto}
.admin-content{padding:28px;overflow-x:hidden;background:var(--bg-primary)}
.admin-sidebar-header{padding:12px;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.admin-sidebar-role{font-size:11px;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:1px}

/* ===== STATS ===== */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:center;gap:16px;transition:all 0.2s;box-shadow:var(--shadow-sm)}
.stat-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}
.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.stat-icon.purple{background:var(--accent-dim);color:var(--accent)}
.stat-icon.green {background:var(--green-dim);color:var(--green)}
.stat-icon.red   {background:var(--red-dim);color:var(--red)}
.stat-icon.yellow{background:var(--yellow-dim);color:var(--yellow)}
.stat-icon.blue  {background:var(--blue-dim);color:var(--blue)}
.stat-num{font-size:28px;font-weight:800;font-family:var(--font-mono);line-height:1;margin-bottom:4px;color:var(--text-primary)}
.stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px}

/* ===== FOOTER ===== */
footer{border-top:1px solid var(--border);background:var(--bg-card);padding:40px 0 28px;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:32px}
.footer-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:16px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-link{font-size:14px;color:var(--text-muted);text-decoration:none;transition:color 0.2s;font-weight:500}
.footer-link:hover{color:var(--accent)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:20px;border-top:1px solid var(--border);font-size:13px;color:var(--text-muted);gap:8px;flex-wrap:wrap}
.footer-col-hide{}

/* ===== ANNOUNCEMENT ===== */
.announcement-banner{padding:10px 24px;text-align:center;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px}
.announcement-banner.info   {background:var(--accent-dim);color:var(--accent);border-bottom:1px solid #ddd6fe}
.announcement-banner.warning{background:#fef3c7;color:#92400e;border-bottom:1px solid #fde68a}
.announcement-banner.danger {background:#fee2e2;color:#991b1b;border-bottom:1px solid #fecaca}
.announcement-banner.success{background:#d1fae5;color:#065f46;border-bottom:1px solid #a7f3d0}

/* ===== MISC ===== */
.copy-btn{position:relative;display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;font-family:var(--font-main);cursor:pointer;transition:all 0.2s;font-weight:600}
.copy-btn:hover{color:var(--accent);border-color:var(--accent)}
.copy-btn.copied{color:var(--green);border-color:var(--green);background:var(--green-dim)}
.tags-list{display:flex;flex-wrap:wrap;gap:6px}
.tag{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border);text-decoration:none;transition:all 0.2s}
.tag:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}
.profile-header{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;display:flex;align-items:center;gap:24px;margin-bottom:24px;box-shadow:var(--shadow-sm)}
.profile-info h2{font-size:24px;font-weight:800;margin-bottom:4px;color:var(--text-primary)}
.profile-info p{color:var(--text-secondary);font-size:14px}
.role-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-top:8px}
.role-owner   {background:linear-gradient(135deg,#fde68a,#fbbf24);color:#78350f}
.role-admin   {background:#fee2e2;color:#991b1b}
.role-verified{background:#d1fae5;color:#065f46}
.role-member  {background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border)}
.skeleton{background:linear-gradient(90deg,#f0f0f5 25%,#e8e8ef 50%,#f0f0f5 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

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

/* ── HAMBURGER & MOBILE DRAWER ── */
.nav-hamburger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  gap:5px;width:40px;height:40px;
  background:none;border:1.5px solid var(--border);border-radius:var(--radius-md);
  cursor:pointer;flex-shrink:0;padding:8px;
}
.nav-hamburger span{
  display:block;width:18px;height:2px;
  background:var(--text-primary);border-radius:2px;
  transition:all 0.25s;transform-origin:center;
}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav-mobile-drawer{
  position:fixed;top:0;right:-280px;width:280px;height:100vh;
  background:var(--bg-card);border-left:1px solid var(--border);
  z-index:999;transition:right 0.3s cubic-bezier(.4,0,.2,1);
  padding-top:80px;overflow-y:auto;
  box-shadow:-4px 0 24px rgba(0,0,0,0.1);
}
.nav-mobile-drawer.open{right:0}
.nav-mobile-inner{display:flex;flex-direction:column;padding:8px 16px 24px;}
.nav-mobile-link{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;border-radius:var(--radius-md);
  text-decoration:none;font-size:15px;font-weight:600;
  color:var(--text-secondary);transition:all 0.15s;
  border-bottom:1px solid var(--border);
}
.nav-mobile-link:last-child{border-bottom:none}
.nav-mobile-link:hover,.nav-mobile-link.active{
  color:var(--accent);background:var(--accent-dim);
}
.nav-mobile-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,0.4);z-index:998;
  backdrop-filter:blur(2px);
}
.nav-mobile-overlay.open{display:block}

@media(max-width:1024px){
  .main-layout{grid-template-columns:1fr}
  .sidebar{position:static}
  .script-detail-header{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .admin-layout{grid-template-columns:1fr}
  .admin-sidebar{display:none}
}
@media(max-width:768px){
  .navbar{padding:0 16px}
  .nav-search{display:none}
  .nav-links-desktop{display:none}
  .nav-hamburger{display:flex}
  .hero h1{font-size:36px;letter-spacing:-1px}
  .hero-stats{gap:0}
  .hero-stat{padding:0 16px;border-right:1px solid var(--border)}
  .hero-stat:last-child{border-right:none}
  .container{padding:0 16px}
  .script-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .auth-box{padding:28px 20px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .footer-col-hide{display:none}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:4px;font-size:12px}
}
@media(max-width:480px){
  .script-grid{grid-template-columns:1fr}
  .hero h1{font-size:26px;letter-spacing:-0.5px}
  /* hero stats tetap 3 kolom horizontal di mobile */
  .hero-stats{gap:0;margin-bottom:32px}
  .hero-stat{padding:0 12px;border-right:1px solid var(--border)}
  .hero-stat:last-child{border-right:none}
  .hero-stat-num{font-size:22px}
  .hero-stat-label{font-size:11px}
  /* filter chips lebih compact */
  .filters-bar{gap:6px;padding:12px 0}
  .filter-chip{font-size:11px;padding:4px 10px;gap:3px}
  /* footer satu kolom */
  .footer-grid{grid-template-columns:1fr;gap:20px}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:4px}
}

/* ============================================================
   ONLINE STATUS BAR
   ============================================================ */
.online-status-bar {
  background: var(--bg-secondary, #f5f3ff);
  border-bottom: 1px solid var(--border, #e5e7eb);
  font-size: 12px;
  color: var(--text-muted, #888);
  font-weight: 500;
  width: 100%;
}
.online-status-bar .container {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 16px !important;
  flex-wrap: nowrap !important;
  padding-top: 5px !important;
  padding-bottom: 5px !important;
  overflow-x: auto;
  white-space: nowrap;
}
.online-stat {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
}

.online-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
  animation: pulse-dot 2s infinite;
}

.online-dot.registered {
  background: #22c55e;
  box-shadow: 0 0 6px rgba(34,197,94,0.6);
}

.online-dot.guest {
  background: #3b82f6;
  box-shadow: 0 0 6px rgba(59,130,246,0.6);
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.6; transform: scale(0.85); }
}

/* ============================================================
   ADMIN ONLINE MONITOR WIDGET
   ============================================================ */
.online-monitor-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg, 12px);
  padding: 20px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.online-monitor-item {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 140px;
}

.online-monitor-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
  animation: pulse-dot 2s infinite;
}

.online-monitor-dot.registered { background:#22c55e; box-shadow:0 0 8px rgba(34,197,94,0.5); }
.online-monitor-dot.guest       { background:#3b82f6; box-shadow:0 0 8px rgba(59,130,246,0.5); }
.online-monitor-dot.total       { background:#a855f7; box-shadow:0 0 8px rgba(168,85,247,0.5); }

.online-monitor-num {
  font-size: 28px;
  font-weight: 800;
  line-height: 1;
}

.online-monitor-label {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}

/* Recent online users table */
.online-users-table { width:100%; border-collapse:collapse; }
.online-users-table th,
.online-users-table td { padding:8px 12px; text-align:left; font-size:13px; border-bottom:1px solid var(--border); }
.online-users-table th { color:var(--text-muted); font-weight:600; font-size:11px; text-transform:uppercase; letter-spacing:.04em; }
