/* ============ Oyun Hileleri — Premium 3D Design System ============ */

:root{
  --bg-0:#050608;
  --bg-1:#0a0c11;
  --bg-2:#12151c;
  --bg-glass: rgba(18, 21, 28, 0.55);
  --border-glass: rgba(255,255,255,0.08);
  --gold: #d4af37;
  --gold-soft: #f1d78c;
  --violet: #8b5cf6;
  --cyan: #38bdf8;
  --text-0:#f5f3ee;
  --text-1:#b9b7c2;
  --text-2:#77748a;
  --danger:#e11d48;
  --success:#22c55e;
  --radius-lg: 22px;
  --radius-md: 14px;
  --radius-sm: 8px;
  --ease: cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  background: var(--bg-0);
  color: var(--text-0);
  font-family: 'Poppins', 'Segoe UI', system-ui, sans-serif;
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
}

body::before{
  content:"";
  position:fixed; inset:0;
  background:
    radial-gradient(circle at 15% 20%, rgba(139,92,246,0.14), transparent 45%),
    radial-gradient(circle at 85% 10%, rgba(212,175,55,0.12), transparent 40%),
    radial-gradient(circle at 50% 90%, rgba(56,189,248,0.10), transparent 50%);
  pointer-events:none;
  z-index:0;
}

a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; }
img{ max-width:100%; display:block; }

/* ============ Canvas 3D background ============ */
#hero-canvas{
  position:absolute;
  top:0; left:0;
  width:100%; height:100%;
  z-index:0;
  pointer-events:none;
}

/* ============ Scrollbar ============ */
::-webkit-scrollbar{ width:10px; }
::-webkit-scrollbar-track{ background:var(--bg-0); }
::-webkit-scrollbar-thumb{ background:linear-gradient(var(--gold), var(--violet)); border-radius:10px; }

/* ============ Utility ============ */
.container{
  width:100%;
  max-width:1280px;
  margin:0 auto;
  padding:0 32px;
  position:relative;
  z-index:2;
}

.gold-text{
  background: linear-gradient(120deg, var(--gold-soft), var(--gold) 45%, #a97e1a);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.section-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:600;
  margin-bottom:14px;
}
.section-tag::before{
  content:"";
  width:24px; height:1px;
  background:var(--gold);
}

.section-title{
  font-size:clamp(28px, 4vw, 44px);
  font-weight:700;
  letter-spacing:-0.5px;
  margin-bottom:14px;
}

.section-sub{
  color:var(--text-1);
  max-width:560px;
  line-height:1.7;
  font-size:15px;
}

/* ============ Navbar ============ */
.navbar{
  position:fixed;
  top:0; left:0; right:0;
  z-index:100;
  padding:18px 0;
  transition:all .4s var(--ease);
  background: transparent;
  border-bottom:1px solid transparent;
}
.navbar.scrolled{
  background: rgba(5,6,8,0.75);
  backdrop-filter: blur(18px) saturate(140%);
  border-bottom:1px solid var(--border-glass);
  padding:12px 0;
}
.navbar .container{ display:flex; align-items:center; justify-content:space-between; }

.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:700; font-size:20px; letter-spacing:0.5px;
}
.brand .logo-mark{
  width:36px; height:36px;
  border-radius:10px;
  background: conic-gradient(from 180deg, var(--gold), var(--violet), var(--cyan), var(--gold));
  display:flex; align-items:center; justify-content:center;
  font-size:16px;
  box-shadow: 0 0 24px rgba(212,175,55,0.45);
  animation: spin-slow 8s linear infinite;
}
@keyframes spin-slow{ to{ transform:rotate(360deg); } }

.nav-links{ display:flex; align-items:center; gap:36px; }
.nav-links a{
  font-size:14px; font-weight:500; color:var(--text-1);
  position:relative; transition:color .3s;
}
.nav-links a:hover{ color:var(--text-0); }
.nav-links a.active{ color:var(--gold); }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-6px;
  width:0; height:1px; background:var(--gold);
  transition:width .3s var(--ease);
}
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }

.nav-actions{ display:flex; align-items:center; gap:14px; }
.nav-mobile-auth{ display:none; }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 22px;
  border-radius:100px;
  font-size:13.5px; font-weight:600;
  border:1px solid transparent;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), background .3s;
  white-space:nowrap;
}
.btn-primary{
  background: linear-gradient(120deg, var(--gold-soft), var(--gold));
  color:#100c02;
  box-shadow: 0 8px 24px rgba(212,175,55,0.28);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 12px 32px rgba(212,175,55,0.4); }
.btn-ghost{
  border-color: var(--border-glass);
  color:var(--text-0);
  background: rgba(255,255,255,0.02);
}
.btn-ghost:hover{ border-color:var(--gold); background:rgba(212,175,55,0.08); transform:translateY(-2px); }
.btn-block{ width:100%; }
.btn-sm{ padding:8px 16px; font-size:12.5px; }
.btn-danger{ background:linear-gradient(120deg,#f43f5e,var(--danger)); color:#fff; }

.burger{ display:none; width:26px; height:20px; flex-direction:column; justify-content:space-between; }
.burger span{ height:2px; background:var(--text-0); border-radius:2px; }

/* ============ Hero ============ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; align-items:center;
  padding-top:100px;
  overflow:hidden;
}
.hero-content{
  position:relative; z-index:2;
  max-width:720px;
}
.hero-badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 16px;
  border-radius:100px;
  border:1px solid var(--border-glass);
  background: var(--bg-glass);
  backdrop-filter: blur(10px);
  font-size:12.5px;
  color:var(--gold-soft);
  margin-bottom:26px;
  animation: float-badge 4s ease-in-out infinite;
}
@keyframes float-badge{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-6px);} }
.hero-badge .dot{ width:6px; height:6px; border-radius:50%; background:var(--success); box-shadow:0 0 8px var(--success); }

.hero h1{
  font-size:clamp(38px, 6vw, 68px);
  font-weight:800;
  line-height:1.05;
  letter-spacing:-1.5px;
  margin-bottom:24px;
}

.hero p.lead{
  font-size:17px;
  color:var(--text-1);
  line-height:1.8;
  max-width:560px;
  margin-bottom:38px;
}

.hero-actions{ display:flex; gap:16px; margin-bottom:56px; flex-wrap:wrap; }

.hero-stats{ display:flex; gap:44px; flex-wrap:wrap; }
.hero-stats .stat b{
  display:block; font-size:28px; font-weight:800;
  background:linear-gradient(120deg, var(--gold-soft), var(--violet));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-stats .stat span{ font-size:12.5px; color:var(--text-2); letter-spacing:0.5px; }

/* Floating glass card decoration */
.floating-card{
  position:absolute;
  padding:16px 20px;
  border-radius:var(--radius-md);
  background:var(--bg-glass);
  border:1px solid var(--border-glass);
  backdrop-filter: blur(14px);
  box-shadow: 0 20px 50px rgba(0,0,0,0.4);
  z-index:2;
  animation: float-y 6s ease-in-out infinite;
}
@keyframes float-y{ 0%,100%{ transform:translateY(0) rotate(-1deg);} 50%{ transform:translateY(-18px) rotate(1deg);} }
.floating-card.f1{ top:14%; right:6%; animation-delay:0s; }
.floating-card.f2{ top:52%; right:16%; animation-delay:1.5s; }
.floating-card.f3{ top:76%; right:2%; animation-delay:3s; }
.floating-card .fc-title{ font-size:13px; font-weight:600; margin-bottom:4px; }
.floating-card .fc-sub{ font-size:11px; color:var(--text-2); }

/* ============ Tier / access explainer ============ */
.tiers{ padding:120px 0; position:relative; z-index:2; }
.tiers-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
  margin-top:56px;
}
.tier-card{
  position:relative;
  padding:36px 30px;
  border-radius:var(--radius-lg);
  background:var(--bg-glass);
  border:1px solid var(--border-glass);
  backdrop-filter: blur(14px);
  overflow:hidden;
  transition: transform .5s var(--ease), border-color .4s;
  transform-style:preserve-3d;
}
.tier-card:hover{ border-color:rgba(212,175,55,0.4); }
.tier-card::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(160deg, rgba(255,255,255,0.06), transparent 40%);
  opacity:0; transition:opacity .4s;
}
.tier-card:hover::before{ opacity:1; }
.tier-icon{
  width:56px; height:56px;
  border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  font-size:26px;
  margin-bottom:22px;
}
.tier-card.t1 .tier-icon{ background:linear-gradient(135deg, rgba(56,189,248,0.25), rgba(56,189,248,0.05)); }
.tier-card.t2 .tier-icon{ background:linear-gradient(135deg, rgba(212,175,55,0.3), rgba(212,175,55,0.05)); }
.tier-card.t3 .tier-icon{ background:linear-gradient(135deg, rgba(225,29,72,0.3), rgba(225,29,72,0.05)); }
.tier-card h3{ font-size:20px; margin-bottom:12px; }
.tier-card p{ color:var(--text-1); font-size:14px; line-height:1.7; margin-bottom:20px; }
.tier-card ul li{
  font-size:13.5px; color:var(--text-1);
  display:flex; align-items:center; gap:10px;
  padding:7px 0;
  border-top:1px solid rgba(255,255,255,0.05);
}
.tier-card ul li:first-child{ border-top:none; }
.tier-card ul li::before{ content:"✓"; color:var(--gold); font-weight:700; }
.tier-badge{
  position:absolute; top:24px; right:24px;
  font-size:10.5px; padding:4px 10px; border-radius:100px;
  letter-spacing:1px; text-transform:uppercase; font-weight:700;
}
.tier-card.t1 .tier-badge{ background:rgba(56,189,248,0.15); color:var(--cyan); }
.tier-card.t2 .tier-badge{ background:rgba(212,175,55,0.15); color:var(--gold); }
.tier-card.t3 .tier-badge{ background:rgba(225,29,72,0.15); color:#fb7185; }

/* ============ App grid / library ============ */
.library{ padding:100px 0; position:relative; z-index:2; }
.library-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  flex-wrap:wrap; gap:24px; margin-bottom:40px;
}
.filters{ display:flex; gap:10px; flex-wrap:wrap; }
.filter-chip{
  padding:9px 18px; border-radius:100px;
  border:1px solid var(--border-glass);
  background:var(--bg-glass);
  font-size:13px; color:var(--text-1);
  transition:all .3s;
}
.filter-chip:hover{ color:var(--text-0); border-color:var(--gold); }
.filter-chip.active{
  background:linear-gradient(120deg, var(--gold-soft), var(--gold));
  color:#100c02; border-color:transparent; font-weight:600;
}

.app-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(270px, 1fr));
  gap:24px;
}

.app-card{
  position:relative;
  border-radius:var(--radius-lg);
  background:var(--bg-glass);
  border:1px solid var(--border-glass);
  backdrop-filter: blur(14px);
  padding:26px;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
  transform-style: preserve-3d;
  cursor:pointer;
}
.app-card:hover{
  box-shadow: 0 30px 60px rgba(0,0,0,0.45);
  border-color: rgba(212,175,55,0.35);
}
.app-card-top{ display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.app-icon{
  width:54px; height:54px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:26px;
  box-shadow: 0 10px 24px -8px rgba(0,0,0,0.6);
}
.app-card h4{ font-size:16.5px; margin-bottom:3px; }
.app-meta{ font-size:12px; color:var(--text-2); }
.app-card p.desc{ font-size:13px; color:var(--text-1); line-height:1.6; margin-bottom:18px; min-height:42px; }

.app-tags{ display:flex; gap:8px; margin-bottom:18px; flex-wrap:wrap; }
.tag{
  font-size:10.5px; padding:4px 10px; border-radius:100px;
  border:1px solid var(--border-glass); color:var(--text-2);
  letter-spacing:0.4px;
}
.tag.locked{ color:var(--gold); border-color:rgba(212,175,55,0.35); background:rgba(212,175,55,0.08); }

.app-card-footer{ display:flex; align-items:center; justify-content:space-between; }
.app-rating{ font-size:12.5px; color:var(--text-1); display:flex; align-items:center; gap:5px; }
.app-rating .star{ color:var(--gold); }

/* Lock overlay for member-only content viewed as guest */
.lock-overlay{
  position:absolute; inset:0;
  border-radius:var(--radius-lg);
  background:rgba(5,6,8,0.72);
  backdrop-filter: blur(3px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:8px;
  opacity:0; pointer-events:none;
  transition:opacity .3s;
}
.app-card:hover .lock-overlay.show{ opacity:1; pointer-events:all; }
.lock-overlay .lock-icon{ font-size:22px; }
.lock-overlay span{ font-size:12px; color:var(--gold-soft); font-weight:600; }

/* ============ Modal ============ */
.modal-backdrop{
  position:fixed; inset:0; z-index:200;
  background:rgba(5,6,8,0.75);
  backdrop-filter: blur(6px);
  display:none; align-items:center; justify-content:center;
  padding:20px;
}
.modal-backdrop.open{ display:flex; }
.modal{
  width:100%; max-width:560px;
  background:var(--bg-1);
  border:1px solid var(--border-glass);
  border-radius:var(--radius-lg);
  padding:34px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.6);
  animation: modal-in .35s var(--ease);
  max-height:86vh; overflow-y:auto;
}
@keyframes modal-in{ from{ opacity:0; transform:translateY(30px) scale(.97);} to{opacity:1; transform:translateY(0) scale(1);} }
.modal-close{
  position:absolute; top:20px; right:24px;
  font-size:20px; color:var(--text-2); background:none; border:none;
}
.modal-close:hover{ color:var(--text-0); }
.modal-head{ display:flex; gap:16px; align-items:center; margin-bottom:20px; position:relative; }
.modal-head .app-icon{ width:64px; height:64px; font-size:30px; }
.modal-head h3{ font-size:22px; margin-bottom:4px; }
.modal p.desc{ color:var(--text-1); line-height:1.7; font-size:14px; margin-bottom:22px; }
.modal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:24px; }
.modal-grid .mg-item{ background:var(--bg-2); border-radius:var(--radius-sm); padding:12px; text-align:center; }
.modal-grid .mg-item b{ display:block; font-size:14px; margin-bottom:2px; }
.modal-grid .mg-item span{ font-size:10.5px; color:var(--text-2); }
.file-list{ margin-bottom:24px; }
.file-list li{
  display:flex; align-items:center; justify-content:between; gap:10px;
  padding:12px 14px; border-radius:var(--radius-sm);
  background:var(--bg-2); margin-bottom:8px; font-size:13px;
  border:1px solid var(--border-glass);
}
.file-list li .file-name{ flex:1; }
.file-list li .file-lock{ color:var(--gold); font-size:12px; }

/* ============ Auth pages ============ */
.auth-wrap{
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  padding:120px 24px 60px;
  position:relative; z-index:2;
}
.auth-card{
  width:100%; max-width:440px;
  background:var(--bg-glass);
  border:1px solid var(--border-glass);
  border-radius:var(--radius-lg);
  padding:44px 38px;
  backdrop-filter: blur(18px);
  box-shadow: 0 30px 80px rgba(0,0,0,0.5);
}
.auth-card .brand{ justify-content:center; margin-bottom:30px; }
.auth-card h2{ text-align:center; font-size:26px; margin-bottom:8px; }
.auth-card p.sub{ text-align:center; color:var(--text-1); font-size:13.5px; margin-bottom:32px; }

.field{ margin-bottom:18px; }
.field label{ display:block; font-size:12.5px; color:var(--text-1); margin-bottom:8px; letter-spacing:0.3px; }
.field input, .field select{
  width:100%; padding:13px 16px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border-glass);
  background:rgba(255,255,255,0.03);
  color:var(--text-0); font-size:14px;
  transition: border-color .3s, background .3s;
}
.field input:focus, .field select:focus{
  outline:none; border-color:var(--gold);
  background:rgba(212,175,55,0.05);
}
.field-row{ display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; font-size:13px; color:var(--text-1); }
.field-row a{ color:var(--gold-soft); }
.check{ display:flex; align-items:center; gap:8px; }

.divider{ display:flex; align-items:center; gap:14px; margin:26px 0; color:var(--text-2); font-size:12px; }
.divider::before, .divider::after{ content:""; flex:1; height:1px; background:var(--border-glass); }

.social-row{ display:flex; gap:12px; }
.social-btn{
  flex:1; display:flex; align-items:center; justify-content:center; gap:8px;
  padding:11px; border-radius:var(--radius-sm);
  border:1px solid var(--border-glass); background:rgba(255,255,255,0.02);
  font-size:13px; font-weight:500; transition:all .3s;
}
.social-btn:hover{ border-color:var(--gold); background:rgba(212,175,55,0.06); }

.auth-foot{ text-align:center; margin-top:26px; font-size:13.5px; color:var(--text-1); }
.auth-foot a{ color:var(--gold-soft); font-weight:600; }

.badge-role{
  display:inline-flex; align-items:center; gap:6px;
  margin: 0 auto 20px; padding:6px 14px; border-radius:100px;
  background:rgba(225,29,72,0.12); color:#fb7185;
  font-size:11.5px; letter-spacing:1px; text-transform:uppercase; font-weight:700;
  width:fit-content;
}

/* ============ Dashboard (member / admin) ============ */
.dash{ display:flex; min-height:100vh; position:relative; z-index:2; }
.sidebar{
  width:270px; flex-shrink:0;
  background:rgba(10,12,17,0.7);
  border-right:1px solid var(--border-glass);
  backdrop-filter: blur(18px);
  padding:28px 22px;
  position:sticky; top:0; height:100vh;
  display:flex; flex-direction:column;
}
.sidebar .brand{ margin-bottom:40px; }
.side-nav{ display:flex; flex-direction:column; gap:4px; flex:1; }
.side-nav a{
  display:flex; align-items:center; gap:12px;
  padding:12px 14px; border-radius:var(--radius-sm);
  color:var(--text-1); font-size:14px; font-weight:500;
  transition:all .25s;
}
.side-nav a .ic{ font-size:16px; width:20px; text-align:center; }
.side-nav a:hover{ background:rgba(255,255,255,0.04); color:var(--text-0); }
.side-nav a.active{
  background: linear-gradient(120deg, rgba(212,175,55,0.16), rgba(139,92,246,0.1));
  color:var(--gold-soft);
  border:1px solid rgba(212,175,55,0.25);
}
.side-user{
  display:flex; align-items:center; gap:12px;
  padding:14px; border-radius:var(--radius-sm);
  background:rgba(255,255,255,0.03); border:1px solid var(--border-glass);
  margin-top:auto;
}
.avatar{
  width:38px; height:38px; border-radius:50%;
  background:linear-gradient(135deg, var(--gold), var(--violet));
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:14px; color:#100c02;
}
.side-user .su-name{ font-size:13px; font-weight:600; }
.side-user .su-role{ font-size:11px; color:var(--text-2); }

.dash-main{ flex:1; padding:32px 40px; min-width:0; }
.dash-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:32px; flex-wrap:wrap; gap:16px; }
.dash-top h1{ font-size:26px; }
.dash-top p{ color:var(--text-1); font-size:13.5px; margin-top:4px; }

.stat-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:36px; }
.stat-card{
  background:var(--bg-glass); border:1px solid var(--border-glass);
  border-radius:var(--radius-md); padding:22px;
  backdrop-filter: blur(14px);
}
.stat-card .sc-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.stat-card .sc-icon{ width:38px; height:38px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:17px; }
.stat-card b{ font-size:26px; display:block; }
.stat-card span{ font-size:12px; color:var(--text-2); }
.trend-up{ color:var(--success); font-size:11.5px; font-weight:600; }
.trend-down{ color:var(--danger); font-size:11.5px; font-weight:600; }

.panel{
  background:var(--bg-glass); border:1px solid var(--border-glass);
  border-radius:var(--radius-lg); backdrop-filter: blur(14px);
  padding:26px; margin-bottom:28px;
}
.panel-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.panel-head h3{ font-size:17px; }

table{ width:100%; border-collapse:collapse; }
th{ text-align:left; font-size:11.5px; text-transform:uppercase; letter-spacing:0.6px; color:var(--text-2); padding:10px 12px; border-bottom:1px solid var(--border-glass); }
td{ padding:14px 12px; font-size:13.5px; border-bottom:1px solid rgba(255,255,255,0.04); color:var(--text-1); }
tr:last-child td{ border-bottom:none; }
.status-pill{ font-size:11px; padding:4px 12px; border-radius:100px; font-weight:600; }
.status-pill.active{ background:rgba(34,197,94,0.14); color:var(--success); }
.status-pill.inactive{ background:rgba(225,29,72,0.14); color:#fb7185; }
.row-actions{ display:flex; gap:8px; }
.icon-btn{
  width:30px; height:30px; border-radius:8px;
  border:1px solid var(--border-glass); background:rgba(255,255,255,0.02);
  display:flex; align-items:center; justify-content:center; font-size:13px;
  transition:all .2s;
}
.icon-btn:hover{ border-color:var(--gold); color:var(--gold); }
.icon-btn.danger:hover{ border-color:var(--danger); color:#fb7185; }

/* ============ Footer ============ */
footer{
  padding:70px 0 30px;
  border-top:1px solid var(--border-glass);
  position:relative; z-index:2;
  margin-top:80px;
}
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:50px; }
.footer-grid h5{ font-size:13px; margin-bottom:18px; color:var(--text-0); letter-spacing:0.5px; }
.footer-grid ul li{ margin-bottom:10px; }
.footer-grid ul li a{ font-size:13.5px; color:var(--text-1); transition:color .3s; }
.footer-grid ul li a:hover{ color:var(--gold); }
.footer-bottom{ display:flex; align-items:center; justify-content:space-between; font-size:12.5px; color:var(--text-2); flex-wrap:wrap; gap:12px; }

/* ============ Search button + overlay (command palette) ============ */
.search-btn{
  width:40px; height:40px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border-glass); background:rgba(255,255,255,0.03);
  color:var(--text-1); font-size:15px; transition:all .3s;
}
.search-btn:hover{ border-color:var(--gold); color:var(--gold); background:rgba(212,175,55,0.08); transform:translateY(-2px); }

.search-overlay{
  position:fixed; inset:0; z-index:300;
  background:rgba(5,6,8,0.75);
  backdrop-filter: blur(6px);
  display:none; align-items:flex-start; justify-content:center;
  padding:110px 20px 40px;
}
.search-overlay.open{ display:flex; }
.search-box{
  width:100%; max-width:600px;
  background:var(--bg-1);
  border:1px solid var(--border-glass);
  border-radius:var(--radius-lg);
  box-shadow: 0 40px 100px rgba(0,0,0,0.6);
  animation: modal-in .3s var(--ease);
  overflow:hidden;
}
.search-input-row{
  display:flex; align-items:center; gap:12px;
  padding:18px 22px;
  border-bottom:1px solid var(--border-glass);
}
.search-input-row input{
  flex:1; background:none; border:none; outline:none;
  color:var(--text-0); font-size:16px; font-family:inherit;
}
.search-input-row input::placeholder{ color:var(--text-2); }
.search-icon{ font-size:18px; }
.search-esc{
  font-size:10.5px; color:var(--text-2);
  border:1px solid var(--border-glass);
  padding:3px 7px; border-radius:6px; font-family:inherit;
}
.search-results{ max-height:420px; overflow-y:auto; padding:10px; }
.search-result-item{
  display:flex; align-items:center; gap:14px;
  padding:12px; border-radius:var(--radius-sm);
  cursor:pointer; transition: background .2s;
}
.search-result-item:hover, .search-result-item.active{ background:rgba(255,255,255,0.05); }
.search-result-item .sr-icon{
  width:38px; height:38px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; flex-shrink:0;
}
.search-result-item .sr-name{ font-weight:600; font-size:14px; }
.search-result-item .sr-meta{ font-size:11.5px; color:var(--text-2); margin-top:2px; }
.search-result-item .sr-go{ color:var(--text-2); font-size:12px; }
.search-empty{ padding:44px 20px; text-align:center; color:var(--text-2); font-size:13.5px; }
.search-hint{ padding:10px 22px 16px; font-size:11.5px; color:var(--text-2); border-top:1px solid var(--border-glass); display:flex; gap:16px; }
.search-hint b{ color:var(--text-1); }

/* ============ Page loader ============ */
#page-loader{
  position:fixed; inset:0; z-index:999;
  background:var(--bg-0);
  display:flex; align-items:center; justify-content:center;
  transition: opacity .6s var(--ease), visibility .6s var(--ease);
}
#page-loader.hidden{ opacity:0; visibility:hidden; pointer-events:none; }
#page-loader .loader-mark{
  width:64px; height:64px;
  border-radius:16px;
  background: conic-gradient(from 180deg, var(--gold), var(--violet), var(--cyan), var(--gold));
  display:flex; align-items:center; justify-content:center;
  font-size:28px;
  box-shadow: 0 0 46px rgba(212,175,55,0.55);
  animation: spin-slow 1.1s linear infinite, pulse-scale 1.4s ease-in-out infinite;
}
@keyframes pulse-scale{ 0%,100%{ transform:scale(1);} 50%{ transform:scale(1.12);} }

/* ============ Cursor glow ============ */
#cursor-glow{
  position:fixed; top:0; left:0; z-index:2;
  width:420px; height:420px;
  margin-left:-210px; margin-top:-210px;
  border-radius:50%;
  background: radial-gradient(circle, rgba(212,175,55,0.10), rgba(139,92,246,0.05) 45%, transparent 70%);
  pointer-events:none;
  opacity:0;
  transition: opacity .4s;
  will-change: transform;
}
#cursor-glow.active{ opacity:1; }
@media (max-width: 760px){ #cursor-glow{ display:none; } }

/* ============ Button shine sweep ============ */
.btn{ position:relative; overflow:hidden; }
.btn::before{
  content:"";
  position:absolute; top:0; left:-60%;
  width:40%; height:100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.35), transparent);
  transform:skewX(-20deg);
  transition: left .6s var(--ease);
  pointer-events:none;
}
.btn:hover::before{ left:120%; }

/* ============ Icon hover spin ============ */
.app-icon, .tier-icon{ transition: transform .5s var(--ease); }
.app-card:hover .app-icon{ transform:rotate(-8deg) scale(1.08); }
.tier-card:hover .tier-icon{ transform:rotate(8deg) scale(1.1); }

/* ============ Reveal animation ============ */
.reveal{ opacity:0; transform:translateY(36px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:translateY(0); }

/* ============ Sidebar mobile toggle + overlay ============ */
.sidebar-toggle{ display:none; align-items:center; justify-content:center; }
.sidebar-overlay{
  display:none;
  position:fixed; inset:0; z-index:140;
  background:rgba(0,0,0,0.55);
  backdrop-filter: blur(2px);
}
.sidebar-overlay.open{ display:block; }

/* ============ Responsive ============ */
@media (max-width: 980px){
  .tiers-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .floating-card{ display:none; }
  .stat-row{ grid-template-columns:repeat(2,1fr); }
  .sidebar{
    position:fixed; top:0; left:0; height:100vh;
    transform:translateX(-100%);
    transition:transform .35s var(--ease);
    box-shadow:0 0 60px rgba(0,0,0,0.6);
    z-index:150; width:260px;
  }
  .sidebar.open{ transform:translateX(0); }
  .dash-main{ padding:24px 20px; }
  .sidebar-toggle{ display:inline-flex !important; }
  .dash-top h1{ font-size:22px; }
}

@media (max-width: 760px){
  .container{ padding:0 20px; }
  .nav-links{
    position:fixed; top:0; right:-100%; width:78%; max-width:320px; height:100vh;
    background:var(--bg-1); flex-direction:column; align-items:flex-start;
    justify-content:flex-start; gap:22px; padding:100px 32px 40px;
    transition:right .4s var(--ease); border-left:1px solid var(--border-glass);
    overflow-y:auto;
  }
  .nav-links.open{ right:0; }
  .nav-links a{ font-size:16px; }
  .burger{ display:flex; z-index:210; }
  .nav-actions .btn{ display:none; }
  .nav-mobile-auth{
    display:flex !important; flex-direction:column; gap:12px;
    width:100%; margin-top:10px;
    padding-top:22px; border-top:1px solid var(--border-glass);
  }
  .nav-mobile-auth .btn{ display:inline-flex; width:100%; }

  .hero{ padding-top:120px; text-align:left; }
  .hero-actions{ flex-direction:column; }
  .hero-actions .btn{ width:100%; }
  .hero-stats{ gap:22px; justify-content:space-between; }
  .hero-stats .stat b{ font-size:22px; }

  .section-title{ font-size:26px; }
  .tier-card, .app-card{ padding:22px; }
  .modal{ padding:26px 20px; }
  .modal-grid{ grid-template-columns:1fr 1fr; }
  .auth-card{ padding:32px 24px; }

  .footer-grid{ grid-template-columns:1fr; gap:30px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }

  .dash-main{ padding:20px 16px; }
  .stat-row{ grid-template-columns:1fr 1fr; gap:14px; }
  .stat-card{ padding:16px; }
  .stat-card b{ font-size:20px; }
  .panel{ padding:18px; }
  table{ display:block; overflow-x:auto; white-space:nowrap; }
}

@media (max-width: 480px){
  .app-grid{ grid-template-columns:1fr; }
  .stat-row{ grid-template-columns:1fr; }
  .modal-grid{ grid-template-columns:1fr; }
  .filters{ gap:8px; }
  .filter-chip{ padding:8px 14px; font-size:12px; }
  .hero h1{ letter-spacing:-0.5px; }
  .library-head{ align-items:flex-start; }
}
