
:root{
  --bg:#090B14;--panel:#111522;--panel2:#171C2B;--card:#181E31;--muted:#8B93A8;--text:#F6F8FF;
  --line:rgba(255,255,255,.09);--brand:#7C5CFF;--brand2:#28E0B9;--hot:#FF5F7A;--warn:#FFB84D;--blue:#4DA3FF;
  --green:#27D980;--shadow:0 24px 80px rgba(0,0,0,.35);--radius:22px;
}
*{box-sizing:border-box}html,body{margin:0;min-height:100%;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",Arial,sans-serif;background:radial-gradient(circle at 18% 8%,rgba(124,92,255,.28),transparent 32%),radial-gradient(circle at 86% 18%,rgba(40,224,185,.18),transparent 30%),var(--bg);color:var(--text)}
a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit;color:inherit}button{border:0;cursor:pointer}.muted{color:var(--muted)}
.project-home{max-width:1280px;margin:0 auto;padding:36px}.home-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch}.home-card{background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.035));border:1px solid var(--line);border-radius:32px;padding:34px;box-shadow:var(--shadow);position:relative;overflow:hidden}.home-card:before{content:"";position:absolute;inset:-50px auto auto -60px;width:260px;height:260px;border-radius:50%;background:rgba(124,92,255,.28);filter:blur(22px)}.home-card>*{position:relative}.home-title{font-size:44px;line-height:1.1;margin:0 0 14px;letter-spacing:-1px}.home-sub{font-size:16px;line-height:1.8;color:#B9C0D4}.role-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:26px}.role-tile{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:22px;padding:20px;transition:.25s}.role-tile:hover{transform:translateY(-4px);border-color:rgba(124,92,255,.65)}.role-tile b{display:block;font-size:18px;margin-bottom:8px}.role-tile span{font-size:13px;color:var(--muted);line-height:1.6}.page-list{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}.page-link{padding:14px 16px;border-radius:16px;background:rgba(255,255,255,.055);border:1px solid var(--line);display:flex;justify-content:space-between;gap:10px}.page-link:hover{background:rgba(124,92,255,.14);border-color:rgba(124,92,255,.55)}.badge{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:rgba(124,92,255,.16);color:#DCD5FF;border:1px solid rgba(124,92,255,.32);font-size:12px}.badge.green{background:rgba(40,224,185,.13);color:#C7FFF2;border-color:rgba(40,224,185,.28)}.badge.hot{background:rgba(255,95,122,.15);color:#FFD6DD;border-color:rgba(255,95,122,.3)}
.preview-phone{height:680px;border-radius:36px;background:#0E111C;border:10px solid rgba(255,255,255,.08);box-shadow:var(--shadow);overflow:hidden;padding:16px;position:relative}.mini-card{height:120px;background:linear-gradient(135deg,rgba(124,92,255,.55),rgba(40,224,185,.28));border-radius:24px;margin-bottom:14px}.mini-row{height:76px;border-radius:20px;background:rgba(255,255,255,.07);margin-bottom:12px}.mini-admin{display:grid;grid-template-columns:190px 1fr;height:680px;border-radius:28px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}.mini-admin aside{background:#0D1220}.mini-admin main{background:#111827;padding:20px}.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.mini-grid div{height:94px;border-radius:18px;background:rgba(255,255,255,.08)}

/* mobile shell */
.app-bg{min-height:100vh;padding:26px 12px 36px;display:flex;justify-content:center}.phone{width:100%;max-width:430px;min-height:920px;background:linear-gradient(180deg,#111624 0%,#0B0E18 100%);border:1px solid rgba(255,255,255,.1);border-radius:34px;box-shadow:0 32px 100px rgba(0,0,0,.48);overflow:hidden;position:relative}.status{height:34px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;color:#DDE4F7;font-size:12px}.app-header{padding:12px 18px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px}.header-left{display:flex;align-items:center;gap:12px}.avatar{width:42px;height:42px;border-radius:16px;background:linear-gradient(135deg,var(--brand),var(--brand2));display:grid;place-items:center;font-weight:900}.avatar.sm{width:32px;height:32px;border-radius:12px;font-size:12px}.avatar.lg{width:74px;height:74px;border-radius:26px;font-size:24px}.h-title{font-size:20px;font-weight:900;letter-spacing:-.2px}.h-sub{font-size:12px;color:var(--muted);margin-top:3px}.icon-btn{width:40px;height:40px;border-radius:15px;background:rgba(255,255,255,.07);border:1px solid var(--line);display:grid;place-items:center}.content{padding:0 18px 92px}.search{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.06);color:var(--muted);margin-bottom:14px}.search input{flex:1;background:transparent;border:0;outline:0;color:var(--text)}.hero{position:relative;overflow:hidden;border-radius:28px;padding:22px;background:linear-gradient(135deg,rgba(124,92,255,.92),rgba(40,224,185,.72));box-shadow:0 18px 50px rgba(124,92,255,.22);margin-bottom:16px}.hero:after{content:"";position:absolute;width:180px;height:180px;border-radius:50%;right:-42px;top:-52px;background:rgba(255,255,255,.16)}.hero h1,.hero h2{margin:0 0 8px;font-size:26px;line-height:1.15}.hero p{margin:0;color:rgba(255,255,255,.82);font-size:13px;line-height:1.6}.hero-actions{display:flex;gap:10px;margin-top:18px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;border-radius:15px;background:linear-gradient(135deg,var(--brand),#5A7BFF);color:white;font-weight:800;box-shadow:0 14px 32px rgba(124,92,255,.25)}.btn.secondary{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);box-shadow:none}.btn.ghost{background:transparent;border:1px solid var(--line);box-shadow:none}.btn.full{width:100%;height:48px}.btn.hot{background:linear-gradient(135deg,var(--hot),#FF8A4C)}.btn.green{background:linear-gradient(135deg,var(--green),var(--brand2))}.section{margin:18px 0}.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title h3{font-size:17px;margin:0}.section-title a{font-size:12px;color:#B6BDF3}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.card{background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.04));border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:0 14px 40px rgba(0,0,0,.12)}.game-card{height:100px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.game-card:after{content:"";position:absolute;right:-28px;bottom:-34px;width:90px;height:90px;border-radius:50%;background:rgba(124,92,255,.25)}.game-card b{font-size:16px}.game-card span{font-size:12px;color:var(--muted)}.stat{padding:14px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid var(--line)}.stat b{font-size:22px}.stat span{display:block;color:var(--muted);font-size:12px;margin-top:6px}.metric-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.metric-row .stat{padding:12px 8px;text-align:center}.metric-row b{font-size:18px}.service-card{display:flex;gap:12px;margin-bottom:12px}.cover{width:76px;height:92px;border-radius:20px;background:linear-gradient(135deg,rgba(124,92,255,.8),rgba(40,224,185,.45));display:grid;place-items:center;font-weight:900;flex:0 0 auto;position:relative;overflow:hidden}.cover:after{content:"";position:absolute;inset:auto -20px -24px auto;width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.2)}.service-body{flex:1;min-width:0}.service-body h4{margin:2px 0 6px;font-size:16px}.tags{display:flex;gap:7px;flex-wrap:wrap;margin:9px 0}.tag,.chip{font-size:12px;color:#DDE3FF;background:rgba(255,255,255,.07);border:1px solid var(--line);padding:7px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:5px}.chip.active,.tag.active{background:rgba(124,92,255,.22);border-color:rgba(124,92,255,.55);color:white}.price{font-weight:900;color:#FFE08A}.price .small{font-size:12px;color:var(--muted);font-weight:500}.tabs{display:flex;gap:8px;overflow:auto;padding-bottom:4px}.tab{white-space:nowrap;padding:10px 13px;border-radius:999px;background:rgba(255,255,255,.055);border:1px solid var(--line);color:#BEC6DC;font-size:13px}.tab.active{background:linear-gradient(135deg,rgba(124,92,255,.85),rgba(90,123,255,.7));color:white}.panel{display:none}.panel.active{display:block}.form-group{margin-bottom:14px}.label{display:flex;justify-content:space-between;color:#CAD2E8;font-size:13px;margin-bottom:8px}.input{width:100%;height:48px;border:1px solid var(--line);background:rgba(255,255,255,.055);border-radius:16px;padding:0 14px;outline:0}.textarea{width:100%;min-height:96px;border:1px solid var(--line);background:rgba(255,255,255,.055);border-radius:18px;padding:14px;outline:0;resize:vertical}.order-step{display:flex;gap:12px;margin:12px 0;position:relative}.step-dot{width:28px;height:28px;border-radius:50%;background:rgba(124,92,255,.25);border:1px solid rgba(124,92,255,.45);display:grid;place-items:center;font-size:12px;font-weight:900;flex:0 0 auto}.step-text b{font-size:14px}.step-text p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:1.5}.progress{height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.progress i{display:block;height:100%;width:64%;border-radius:999px;background:linear-gradient(90deg,var(--brand),var(--brand2))}.chart{height:126px;display:flex;align-items:flex-end;gap:10px;padding:10px 4px 0}.bar{flex:1;border-radius:10px 10px 4px 4px;background:linear-gradient(180deg,var(--brand2),var(--brand));min-height:18px;position:relative}.bar span{position:absolute;bottom:-21px;left:50%;transform:translateX(-50%);font-size:10px;color:var(--muted)}.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.day{height:44px;border-radius:14px;background:rgba(255,255,255,.055);border:1px solid var(--line);display:grid;place-items:center;font-size:12px}.day.active{background:rgba(124,92,255,.22);border-color:rgba(124,92,255,.58)}.switch{width:52px;height:30px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid var(--line);padding:3px;transition:.2s}.switch i{display:block;width:22px;height:22px;border-radius:50%;background:#fff;transition:.2s}.switch.on{background:linear-gradient(135deg,var(--brand2),var(--green))}.switch.on i{transform:translateX(22px)}.bottom-nav{position:absolute;bottom:0;left:0;right:0;height:74px;background:rgba(12,15,25,.9);backdrop-filter:blur(18px);border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);z-index:5}.bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:#7F879E;font-size:11px}.bottom-nav a.active{color:white}.bottom-nav .nav-ico{font-size:20px}.sticky-bar{position:sticky;bottom:86px;background:rgba(17,21,34,.86);backdrop-filter:blur(18px);border:1px solid var(--line);border-radius:22px;padding:12px;margin-top:20px;display:flex;align-items:center;gap:12px;z-index:4}.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);background:#20263A;border:1px solid var(--line);border-radius:999px;padding:12px 18px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.25s;z-index:999}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.drawer,.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;z-index:100}.drawer.open,.modal-mask.open{display:block}.drawer-panel{position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:430px;background:#111624;border-radius:28px 28px 0 0;border:1px solid var(--line);padding:20px}.modal-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:380px;background:#111624;border:1px solid var(--line);border-radius:28px;padding:22px;box-shadow:var(--shadow)}.message{display:flex;gap:10px;margin:12px 0}.bubble{max-width:74%;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.07);font-size:13px;line-height:1.55}.message.me{justify-content:flex-end}.message.me .bubble{background:linear-gradient(135deg,rgba(124,92,255,.9),rgba(77,163,255,.7))}.list-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}.list-row:last-child{border-bottom:0}.rank-num{width:28px;height:28px;border-radius:10px;background:rgba(255,255,255,.07);display:grid;place-items:center;font-weight:900}.rank-num.top{background:linear-gradient(135deg,#FFD36E,#FF7A5B);color:#2B1600}.empty{padding:28px 18px;text-align:center;color:var(--muted)}

/* admin */
.admin-page{min-height:100vh;display:grid;grid-template-columns:260px 1fr;background:#0A0D16}.sidebar{background:#0D1220;border-right:1px solid var(--line);padding:22px 16px;position:sticky;top:0;height:100vh;overflow:auto}.brand{display:flex;align-items:center;gap:12px;padding:8px 8px 22px}.brand-logo{width:42px;height:42px;border-radius:16px;background:linear-gradient(135deg,var(--brand),var(--brand2));display:grid;place-items:center;font-weight:900}.brand b{font-size:18px}.side-section{margin:18px 0 8px;color:#66708A;font-size:12px;padding-left:10px}.side-link{height:42px;display:flex;align-items:center;gap:10px;padding:0 12px;border-radius:14px;color:#AEB6CC;font-size:14px;margin:4px 0}.side-link.active,.side-link:hover{background:rgba(124,92,255,.16);color:white}.main{min-width:0}.topbar{height:74px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:rgba(10,13,22,.72);backdrop-filter:blur(18px);position:sticky;top:0;z-index:10}.topbar h1{font-size:22px;margin:0}.admin-content{padding:24px 28px 48px}.admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.admin-card{background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.035));border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:0 16px 44px rgba(0,0,0,.14)}.admin-card h3{margin:0 0 12px;font-size:16px}.kpi b{display:block;font-size:30px;letter-spacing:-.8px}.kpi span{color:var(--muted);font-size:13px}.kpi em{font-style:normal;color:var(--brand2);font-size:12px}.layout-2{display:grid;grid-template-columns:1.25fr .75fr;gap:16px}.layout-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.filters{display:flex;gap:10px;flex-wrap:wrap}.admin-input{height:40px;min-width:180px;border:1px solid var(--line);background:rgba(255,255,255,.055);border-radius:13px;padding:0 12px;outline:0}.table-wrap{overflow:auto;border-radius:18px;border:1px solid var(--line)}table{width:100%;border-collapse:collapse;min-width:840px;background:rgba(255,255,255,.025)}th,td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line);font-size:13px}th{color:#9AA4BC;font-weight:700;background:rgba(255,255,255,.035)}td{color:#E3E8F7}.status-pill{display:inline-flex;padding:6px 9px;border-radius:999px;font-size:12px;background:rgba(40,224,185,.13);color:#B9FFF0;border:1px solid rgba(40,224,185,.25)}.status-pill.warn{background:rgba(255,184,77,.12);color:#FFE2AF;border-color:rgba(255,184,77,.25)}.status-pill.bad{background:rgba(255,95,122,.13);color:#FFD3DA;border-color:rgba(255,95,122,.25)}.admin-chart{height:240px;display:flex;align-items:flex-end;gap:12px;padding:16px 6px 26px;border-radius:18px;background:rgba(255,255,255,.025)}.admin-chart .bar{min-width:26px}.pie{width:180px;height:180px;border-radius:50%;background:conic-gradient(var(--brand) 0 42%,var(--brand2) 42% 68%,var(--hot) 68% 84%,#35405F 84%);margin:auto;position:relative}.pie:after{content:"";position:absolute;inset:34px;border-radius:50%;background:#141A2A}.timeline{position:relative}.timeline-item{display:flex;gap:12px;margin:0 0 15px}.timeline-dot{width:12px;height:12px;border-radius:50%;background:var(--brand2);margin-top:4px;box-shadow:0 0 0 5px rgba(40,224,185,.09)}.timeline-item b{font-size:14px}.timeline-item p{margin:4px 0 0;color:var(--muted);font-size:12px}.permission-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.perm{padding:14px;border-radius:16px;background:rgba(255,255,255,.045);border:1px solid var(--line)}.perm b{display:block;margin-bottom:8px}.perm label{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin:8px 0}.expand-row{display:none}.expand-row.show{display:table-row}.mobile-only{display:none}
@media(max-width:900px){.home-hero{grid-template-columns:1fr}.role-grid,.page-list{grid-template-columns:1fr}.admin-page{grid-template-columns:1fr}.sidebar{display:none}.admin-grid,.layout-2,.layout-3,.permission-grid{grid-template-columns:1fr}.topbar{padding:0 16px}.admin-content{padding:18px}.mobile-only{display:block}.home-title{font-size:34px}.project-home{padding:20px}}
