:root {
    --bg: var(--tg-theme-bg-color, #0e0e1a);
    --text: var(--tg-theme-text-color, #fff);
    --hint: var(--tg-theme-hint-color, #8e8e93);
    --accent: var(--tg-theme-button-color, #a855f7);
    --accent-t: var(--tg-theme-button-text-color, #fff);
    --sec-bg: var(--tg-theme-secondary-bg-color, #1a1a2e);
    --card: #1c1c30;
    --border: rgba(168,85,247,.18);
    --bar-bg: rgba(255,255,255,.08);
    --danger: #ef4444;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-tap-highlight-color:transparent}
.app{max-width:480px;margin:0 auto;padding:0 0 calc(14px + env(safe-area-inset-bottom))}
.view{animation:fadeIn .18s ease}.hidden{display:none!important}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* Nav */
.nav-bar{display:flex;align-items:center;gap:10px;padding:10px 14px 10px}
.nav-back{width:34px;height:34px;border-radius:50%;border:none;background:var(--sec-bg);color:var(--text);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.nav-bar span{font-size:18px;font-weight:700}

/* Header */
.header{text-align:center;padding:14px 14px 4px}
.header h1{font-size:20px;font-weight:700}
.user-bar{display:flex;justify-content:center;gap:14px;margin-top:6px;font-size:12px;color:var(--hint)}
.user-bar b{color:var(--text)}

/* Filters */
.filter-bar{display:flex;gap:6px;padding:8px 14px 10px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.fbtn{flex-shrink:0;padding:6px 14px;border-radius:18px;border:1px solid var(--border);background:var(--sec-bg);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:.15s}
.fbtn.on{background:var(--accent);color:var(--accent-t);border-color:var(--accent)}

/* Gallery grid — 2 columns */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 14px}
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:.12s;position:relative}
.card:active{transform:scale(.97)}
.card-img{width:100%;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;font-size:60px;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover}
.card-img .lock-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;font-size:28px}
.card-body{padding:8px 10px 10px}
.card-name{font-size:14px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-mood{font-size:11px;color:var(--hint);margin-bottom:4px}
.card-rel{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--hint)}
.card-rel .bar{flex:1;height:3px;border-radius:2px;background:var(--bar-bg);overflow:hidden}
.card-rel .fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent),#ec4899)}
.badge{position:absolute;top:6px;right:6px;font-size:10px;padding:2px 7px;border-radius:8px;background:rgba(0,0,0,.6);color:#fff;backdrop-filter:blur(4px)}

/* Detail view */
.d-hero{width:100%;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;font-size:80px;position:relative}
.d-hero img{width:100%;height:100%;object-fit:cover}
.d-hero .d-name-overlay{position:absolute;bottom:0;left:0;right:0;padding:30px 14px 14px;background:linear-gradient(transparent,rgba(0,0,0,.7));font-size:22px;font-weight:700}
.d-content{padding:0 14px 90px}
.d-setting{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px;margin:12px 0;font-size:13px;color:var(--hint);line-height:1.5;font-style:italic}
.d-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.d-stat{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px;text-align:center}
.d-stat .ico{font-size:20px;margin-bottom:2px}
.d-stat .val{font-size:15px;font-weight:700}
.d-stat .lbl{font-size:10px;color:var(--hint);margin-top:1px}
.d-progress{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:12px}
.d-progress h4{font-size:13px;margin-bottom:8px;display:flex;justify-content:space-between}
.d-progress h4 a{color:var(--accent);text-decoration:none;font-size:12px;font-weight:400;cursor:pointer}
.pbar{height:6px;border-radius:3px;background:var(--bar-bg);overflow:hidden}
.pfill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent),#ec4899);transition:width .3s}
.plbl{font-size:11px;color:var(--hint);margin-top:5px;text-align:right}
.plbl .xp-hint{color:var(--accent);font-size:10px}
.d-row{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;cursor:pointer}
.d-row .rl{font-size:13px}
.d-row .rl span{font-weight:600}
.d-row .rr{color:var(--accent);font-size:13px}
.d-row.danger .rr{color:var(--danger)}

/* Bottom action */
.bottom-action{position:fixed;bottom:0;left:0;right:0;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:linear-gradient(transparent,var(--bg) 30%)}
.bottom-action .inner{max-width:480px;margin:0 auto}
.actbtn{width:100%;padding:13px;border-radius:12px;border:none;font-size:15px;font-weight:600;cursor:pointer;display:block}
.actbtn:active{opacity:.8}
.actbtn.primary{background:var(--accent);color:var(--accent-t)}
.actbtn.locked{background:var(--sec-bg);color:var(--hint)}
.actbtn.premium{background:linear-gradient(90deg,#a855f7,#ec4899);color:#fff}

/* Levels info */
.lvl-hint{background:linear-gradient(135deg,rgba(168,85,247,.12),rgba(236,72,153,.08));border:1px solid var(--border);border-radius:10px;padding:12px;margin:0 14px 12px;font-size:13px;line-height:1.5;color:var(--hint)}
.lvl-hint b{color:var(--accent)}
.lvl-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px;margin:0 14px 8px}
.lvl-card h4{font-size:14px;margin-bottom:4px}
.lvl-card p{font-size:12px;color:var(--hint);line-height:1.4}
.lvl-card .xp{font-size:11px;color:var(--accent);margin-top:4px}

/* Mood picker */
.mood-body{padding:0 14px}
.mood-opt{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:.12s}
.mood-opt:active{transform:scale(.98)}
.mood-opt.active{border-color:var(--accent);box-shadow:0 0 12px rgba(168,85,247,.15)}
.mood-opt.disabled{opacity:.4;cursor:default}
.mood-opt .mo-left{font-size:14px}
.mood-opt .mo-lock{font-size:10px;color:var(--hint);display:block;margin-top:2px}
.mood-opt .mo-right{font-size:18px}

/* Loading */
.loading{display:none;text-align:center;padding:60px 0}.loading.visible{display:block}
.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;margin:0 auto;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
