:root { --bg:#080810; --surface:#0f0f1a; --border:rgba(255,255,255,0.08); --accent:#7c6aff; --accent2:#ff6ab0; --text:#e8e8f0; --muted:#6b6b80; }
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--text);font-family:-apple-system,'Inter',sans-serif;min-height:100vh;position:relative;}
body::before{content:'';position:absolute;top:0;left:0;right:0;height:1200px;background:radial-gradient(ellipse 70% 40% at 50% 10%,rgba(124,106,255,.18) 0%,transparent 60%),radial-gradient(ellipse 50% 35% at 25% 25%,rgba(255,106,176,.1) 0%,transparent 55%),radial-gradient(ellipse 50% 35% at 75% 20%,rgba(245,197,24,.12) 0%,transparent 55%);pointer-events:none;z-index:0;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:60px;background:rgba(8,8,16,0.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);}
.logo{font-size:18px;font-weight:700;letter-spacing:-0.5px;color:#f5c518;}
.mobile-toggle{background:none;border:1px solid var(--border);border-radius:8px;padding:4px 8px;font-size:16px;cursor:pointer;opacity:.7;transition:opacity .2s;}
.mobile-toggle:hover{opacity:1;}
.mobile-toggle.active{opacity:1;background:rgba(245,197,24,.15);}
.phone-overlay{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.85);justify-content:center;align-items:center;}
.phone-overlay.active{display:flex;}
.phone-frame-wrap{position:relative;width:390px;height:844px;border-radius:40px;border:4px solid #444;background:#000;box-shadow:0 0 60px rgba(0,0,0,.8);overflow:hidden;}
.phone-frame-wrap::before{content:'';position:absolute;top:10px;left:50%;transform:translateX(-50%);width:100px;height:6px;background:#333;border-radius:3px;z-index:1;}
.phone-frame-wrap iframe{width:100%;height:100%;border:none;border-radius:36px;}
.phone-close{position:absolute;top:20px;right:20px;z-index:10000;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:24px;width:40px;height:40px;border-radius:50%;cursor:pointer;backdrop-filter:blur(10px);}
.phone-close:hover{background:rgba(255,255,255,.3);}
.logo span{font-weight:300;opacity:.7;}
.nav-right{display:flex;align-items:center;gap:10px;}
.btn{padding:7px 16px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s;}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text);}
.btn-ghost:hover{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.05);}
.btn-primary{background:var(--accent);color:#fff;}
.btn-primary:hover{background:#6a58f0;}
.user-chip{display:flex;align-items:center;gap:8px;}
.avatar{width:28px;height:28px;border-radius:50%;background:#f5c518;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;}

/* HERO */
.hero{padding:120px 24px 16px;text-align:center;position:relative;}
.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;border:1px solid rgba(245,197,24,.3);background:rgba(245,197,24,.1);font-size:12px;color:#f5c518;margin-bottom:20px;}
.hero-badge::before{content:'✦';font-size:10px;}
.hero h1{font-size:clamp(32px,6vw,64px);font-weight:800;letter-spacing:-2px;line-height:1.1;margin-bottom:16px;}
.hero h1 em{font-style:normal;color:#f5c518;}
.hero p{font-size:16px;color:var(--muted);max-width:480px;margin:0 auto 12px;line-height:1.6;}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.btn-lg{padding:12px 28px;font-size:15px;border-radius:10px;}

/* STATS */
.stats{display:flex;justify-content:center;gap:40px;padding:32px 24px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap;}
.stat{text-align:center;}
.stat-num{font-size:24px;font-weight:700;background:linear-gradient(135deg,#fff,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.stat-label{font-size:12px;color:var(--muted);margin-top:2px;}

/* GALLERY GRID */
.section{padding:16px 16px 48px;max-width:1200px;margin:0 auto;}
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px;padding:0 4px;}
.section-title{font-size:18px;font-weight:600;}
.section-sub{font-size:13px;color:var(--muted);}
.grid{display:grid;grid-template-columns:repeat(6,1fr);gap:3px;}
@media(max-width:900px){.grid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:600px){.grid{grid-template-columns:repeat(3,1fr);}}
.grid-item{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;background:var(--surface);}
.grid-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;display:block;}
.grid-item:hover img{transform:scale(1.08);}
.grid-item .hover-overlay{position:absolute;inset:0;background:rgba(0,0,0,.15);opacity:0;transition:opacity .3s;}
.grid-item:hover .hover-overlay{opacity:1;}
.placeholder-tile{aspect-ratio:1;background:linear-gradient(135deg,var(--surface) 0%,rgba(124,106,255,.05) 100%);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:22px;opacity:.4;}

/* FEATURES */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:0 16px 48px;max-width:1200px;margin:0 auto;}
@media(max-width:600px){.features{grid-template-columns:1fr;}}
.feature-card{padding:24px;border-radius:12px;border:1px solid var(--border);background:var(--surface);}
.feature-icon{font-size:24px;margin-bottom:12px;}
.feature-card h3{font-size:15px;font-weight:600;margin-bottom:6px;}
.feature-card p{font-size:13px;color:var(--muted);line-height:1.6;}

/* MOBILE PREVIEW */
.mobile-preview-wrap{display:none;position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.9);align-items:center;justify-content:center;}
.mobile-preview-wrap.active{display:flex;}
.phone-frame{width:375px;height:667px;border:8px solid #333;border-radius:40px;overflow:hidden;position:relative;background:#000;box-shadow:0 0 60px rgba(0,0,0,.8);}
.phone-frame iframe{width:100%;height:100%;border:none;}
.phone-close{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.15);border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;}

/* DETAIL MODAL */
.modal{display:none;position:fixed;inset:0;z-index:200;background:#000;align-items:center;justify-content:center;touch-action:manipulation;}
.modal.active{display:flex;}
.modal-x{position:absolute;top:10px;right:14px;z-index:10;background:none;border:none;color:rgba(255,255,255,.5);font-size:22px;cursor:pointer;padding:6px;}
.modal-x:hover{color:#fff;}
.modal-split{display:flex;align-items:stretch;gap:12px;width:100%;height:100%;padding:10px;box-sizing:border-box;}
.modal-left{flex:0 0 68%;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.iphone-frame{width:100%;aspect-ratio:9/19.5;max-height:calc(100vh - 40px);border:3px solid #333;border-radius:32px;overflow:hidden;background:#000;}
.iphone-screen{width:100%;height:100%;overflow:hidden;position:relative;}
.modal-bg-img{width:100%;height:100%;object-fit:cover;display:block;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;}
.iphone-label{margin-top:6px;font-size:9px;color:#f5c518;letter-spacing:1px;text-transform:uppercase;}
.modal-right{flex:1;display:flex;flex-direction:column;justify-content:center;gap:10px;overflow-y:auto;padding:8px 0;}
.modal-title{font-size:16px;font-weight:700;color:#fff;letter-spacing:-.3px;}
.modal-cost{font-size:12px;color:#f5c518;font-weight:600;}
.modal-divider{display:flex;align-items:center;gap:8px;font-size:10px;color:rgba(245,197,24,.6);text-transform:uppercase;letter-spacing:.5px;}
.modal-divider::after{content:'';flex:1;height:1px;background:rgba(245,197,24,.15);}
.modal-hint{font-size:10px;color:rgba(255,255,255,.4);line-height:1.4;}
.sub-row{display:flex;gap:4px;position:absolute;bottom:30px;right:10px;z-index:2;}
.sub-thumb-wrap{border-radius:8px;border:2px solid rgba(255,255,255,.5);overflow:hidden;cursor:pointer;transition:border-color .2s,transform .2s;}
.sub-thumb-wrap.sub-active{border-color:#f5c518;transform:scale(1.08);}
.sub-thumb{width:56px;height:70px;object-fit:cover;display:block;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;}
.dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.4);display:inline-block;cursor:pointer;transition:background .2s;}
.dot-active{background:#f5c518;}
.upload-slots{display:flex;gap:8px;flex-wrap:wrap;}
.upload-slot{width:56px;height:56px;border-radius:10px;border:2px dashed #f5c518;background:rgba(245,197,24,.05);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden;transition:border-color .2s;}
.upload-slot:hover{border-color:#ffd84d;background:rgba(245,197,24,.1);}
.upload-slot input{display:none;}
.upload-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:8px;}
.upload-slot .plus{font-size:20px;color:#f5c518;}
.gen-btn{width:100%;padding:10px 12px;background:#f5c518;color:#000;border:none;border-radius:12px;font-size:14px;font-weight:800;cursor:pointer;transition:background .2s;letter-spacing:.3px;line-height:1.4;}
.gen-btn:hover{background:#ffd84d;}
.gen-btn .gen-sub{display:block;font-size:11px;font-weight:600;opacity:.7;}
.result-wrap{margin-top:8px;display:none;}
.result-wrap img{width:100%;border-radius:10px;}

/* AUTH MODAL */
.auth-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;align-items:center;justify-content:center;padding:16px;}
.auth-modal.active{display:flex;}
.auth-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;width:100%;max-width:360px;}
.auth-box h2{font-size:20px;font-weight:700;margin-bottom:6px;}
.auth-box .auth-sub{font-size:13px;color:var(--muted);margin-bottom:24px;}
.auth-box label{font-size:12px;color:var(--muted);display:block;margin-bottom:6px;}
.auth-box input{width:100%;padding:10px 14px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;margin-bottom:14px;}
.auth-box input:focus{outline:none;border-color:var(--accent);}
.auth-box .submit-btn{width:100%;padding:11px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;}
.auth-box .hint{text-align:center;margin-top:12px;font-size:12px;color:var(--muted);}
.auth-close-btn{float:right;background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;margin-top:-4px;}

footer{border-top:1px solid var(--border);padding:24px 24px 10px;text-align:center;font-size:12px;color:var(--muted);}

/* TOPUP MODAL */
.topup-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;align-items:flex-end;justify-content:center;padding:0;}
.topup-modal.active{display:flex;}
.topup-box{background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;padding:24px 20px 40px;width:100%;max-width:480px;}
.topup-box h3{font-size:16px;font-weight:700;margin-bottom:4px;}
.topup-box .topup-sub{font-size:12px;color:var(--muted);margin-bottom:20px;}
.topup-close{float:right;background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;margin-top:-4px;}
.topup-pkg{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.03);margin-bottom:10px;cursor:pointer;transition:all .2s;}
.topup-pkg:hover,.topup-pkg.selected{border-color:var(--accent);background:rgba(124,106,255,.12);}
.topup-pkg .pkg-left .pkg-price{font-size:18px;font-weight:700;}
.topup-pkg .pkg-left .pkg-hint{font-size:11px;color:var(--muted);margin-top:2px;}
.topup-pkg .pkg-right{text-align:right;}
.topup-pkg .pkg-pts{font-size:15px;font-weight:600;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.topup-pkg .pkg-badge{font-size:10px;padding:2px 7px;border-radius:10px;background:rgba(124,106,255,.2);color:#a89fff;margin-top:3px;display:inline-block;}
.topup-pay-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;margin-top:6px;}
.topup-pay-btn:disabled{opacity:.4;cursor:not-allowed;}

/* BOTTOM NAV */
.bnav{position:fixed;top:auto !important;bottom:0 !important;left:0;right:0;z-index:150;display:flex;background:rgba(10,10,20,0.95);backdrop-filter:blur(20px);border-top:1px solid var(--border);border-bottom:none;height:calc(60px + env(safe-area-inset-bottom));padding:0 0 env(safe-area-inset-bottom);transform:translateZ(0);-webkit-transform:translateZ(0);}
.bnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;color:var(--muted);font-size:10px;border:none;background:none;transition:all .25s;}
.bnav-item.active{color:#f5c518;transform:scale(1.2);filter:drop-shadow(0 0 8px rgba(245,197,24,.45));}
.bnav-item:hover:not(.active){color:#fff;}
.bnav-item svg{width:22px;height:22px;}

/* PANELS */
.panel{position:fixed;inset:0 0 60px 0;z-index:140;background:var(--bg);overflow-y:auto;padding:16px 16px 20px;display:none;flex-direction:column;}
.panel.active{display:block;}
#panel-featured.active{display:flex;}
#panel-featured{overflow:hidden;padding-bottom:0;}
.feat-sticky-header{flex-shrink:0;background:var(--bg);padding:0;}
.feat-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;}
#panel-my.active{display:flex;}
.my-sticky-header{flex-shrink:0;position:sticky;top:0;z-index:2;background:var(--bg);padding-bottom:4px;}
#panel-my .my-section{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.panel-title{font-size:18px;font-weight:700;margin-bottom:20px;}
.feat-grid{column-count:2;column-gap:8px;padding:0;}
.feat-item{break-inside:avoid;margin:0 0 8px;overflow:hidden;cursor:pointer;background:var(--surface);border-radius:10px;position:relative;display:inline-block;width:100%;}
.feat-item img{width:100%;display:block;aspect-ratio:3/4;object-fit:cover;transition:transform .35s;}
.feat-item:first-child img{aspect-ratio:2/3;}
.feat-item:hover img{transform:scale(1.07);}
.feat-item .feat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 55%);border-radius:10px;pointer-events:none;}
.feat-caption{position:absolute;bottom:0;left:0;right:0;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;}
.feat-caption-title{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;}
.feat-like{display:flex;align-items:center;gap:4px;font-size:12px;color:rgba(255,255,255,.8);background:none;border:none;cursor:pointer;padding:4px;flex-shrink:0;}
.feat-like svg{width:16px;height:16px;transition:transform .2s;}
.feat-like.liked svg{fill:#ff4d6d;stroke:#ff4d6d;}
.feat-like:hover svg{transform:scale(1.2);}
.feat-tabs{display:flex;align-items:center;flex-wrap:nowrap;gap:4px;padding:4px 0;white-space:nowrap;}
.feat-tab{padding:3px 8px;border-radius:12px;border:none;background:transparent;color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;}
.feat-sticky-header .logo{font-size:13px;flex-shrink:0;}
.feat-tab.active{color:#f5c518;background:rgba(245,197,24,.1);}
.feat-grid-hidden{display:none;}
.pts-bar{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 14px;display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.pts-bar .pts-val{font-size:16px;font-weight:700;color:#f5c518;}
.pts-bar .pts-label{font-size:11px;color:var(--muted);}
.pts-pay{margin-left:auto;padding:6px 14px;border-radius:8px;background:#f5c518;color:#000;border:none;font-size:12px;font-weight:600;cursor:pointer;}
.recharge-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;margin-bottom:20px;}
.my-tabs{display:flex;gap:6px;margin-bottom:14px;align-items:center;}
.my-tab{padding:5px 16px;border-radius:20px;border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;}
.my-tab.active{background:rgba(255,255,255,.1);color:#fff;}
.my-section{display:none;}.my-section.active{display:block;}
.likes-grid{columns:2;column-gap:8px;}
.likes-item{break-inside:avoid;margin-bottom:8px;border-radius:10px;overflow:hidden;cursor:pointer;position:relative;background:var(--surface);}
.likes-item img{width:100%;display:block;aspect-ratio:3/4;object-fit:cover;}
.likes-item .feat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 55%);border-radius:10px;pointer-events:none;}
.likes-item .feat-caption{position:absolute;bottom:0;left:0;right:0;padding:8px 10px;}
.likes-item .feat-caption-title{font-size:12px;font-weight:600;color:#fff;}
.log-swipe{position:relative;overflow:hidden;border-radius:16px;margin-bottom:10px;}
.log-swipe-del{position:absolute;right:0;top:0;bottom:0;width:80px;background:#dc3545;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;letter-spacing:.5px;border-radius:0 16px 16px 0;opacity:0;transition:opacity .2s;}
.log-swipe.swiped .log-swipe-del{opacity:1;}
.log-item{display:flex;gap:14px;align-items:center;padding:21px 16px;border-radius:16px;background:rgba(255,255,255,.03);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.06);font-size:13px;transition:transform .2s ease;position:relative;z-index:1;min-height:168px;}
.log-thumb{width:168px!important;height:168px!important;min-width:168px;border-radius:14px;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,rgba(124,106,255,.08),rgba(255,106,176,.05));border:1px solid rgba(255,255,255,.08);cursor:pointer;}
.log-thumb img{width:100%!important;height:100%!important;object-fit:cover;object-position:center;display:block;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;pointer-events:none;}
.img-viewer{display:none;position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.95);align-items:center;justify-content:center;flex-direction:column;}
.img-viewer.active{display:flex;}
.img-viewer img{max-width:100%;max-height:100%;object-fit:contain;}
.viewer-dl{position:absolute;bottom:calc(40px + env(safe-area-inset-bottom));left:16px;right:16px;height:50px;border-radius:12px;border:none;background:#f5c518;color:#000;font-size:16px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px rgba(245,197,24,.5);}
.viewer-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,.15);color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
img{-webkit-touch-callout:none;}
.log-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:20px;opacity:.2;background:linear-gradient(135deg,rgba(124,106,255,.06),rgba(255,106,176,.04));}
.log-body{flex:1;min-width:0;padding-top:0;}
.log-title{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;letter-spacing:-.2px;background:linear-gradient(135deg,#fff 0%,rgba(255,255,255,.75) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.log-meta{font-size:11px;color:var(--muted);margin-bottom:6px;letter-spacing:.3px;display:flex;align-items:center;gap:6px;}
.log-meta::before{content:'';width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.5;}
.log-item .badge{padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;}
.badge-ok{background:linear-gradient(135deg,rgba(40,167,69,.15),rgba(40,167,69,.08));color:#6ee7a0;border:1px solid rgba(40,167,69,.2);box-shadow:0 0 12px rgba(40,167,69,.1);}
.badge-fail{background:linear-gradient(135deg,rgba(220,53,69,.15),rgba(220,53,69,.08));color:#f87171;border:1px solid rgba(220,53,69,.2);box-shadow:0 0 12px rgba(220,53,69,.1);}
.badge-pending{background:linear-gradient(135deg,rgba(255,193,7,.15),rgba(255,193,7,.08));color:#fcd34d;border:1px solid rgba(255,193,7,.2);box-shadow:0 0 12px rgba(255,193,7,.1);animation:pulse-badge 2s ease-in-out infinite;}
@keyframes pulse-badge{0%,100%{opacity:1}50%{opacity:.6}}
.prog-bar{height:3px;border-radius:3px;background:rgba(255,255,255,.06);overflow:hidden;margin-top:8px;width:100%;}
.prog-bar-inner{height:100%;width:30%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:3px;animation:prog 1.8s ease-in-out infinite;box-shadow:0 0 8px rgba(124,106,255,.4);}
@keyframes prog{0%{transform:translateX(-100%)}100%{transform:translateX(400%)}}
.log-result-wrap{margin-top:8px;width:100%;aspect-ratio:1;border-radius:12px;overflow:hidden;background:rgba(255,255,255,.04);}
.log-result-wrap img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.gen-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:rgba(20,20,35,.95);border:1px solid var(--border);border-radius:12px;padding:12px 20px;font-size:13px;color:var(--text);z-index:500;text-align:center;pointer-events:none;opacity:0;transition:opacity .3s;}
.gen-toast.show{opacity:1;}
.pkg-btn{padding:12px 6px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;cursor:pointer;transition:all .2s;line-height:1.6;}
.pkg-btn.selected{border-color:var(--accent);background:rgba(124,106,255,.15);color:#fff;}
.pkg-btn small{color:var(--muted);font-size:11px;}
.pkg-btn.selected small{color:#a89fff;}
.log-actions{display:flex;flex-direction:row;align-items:center;gap:2px;flex-shrink:0;}
.log-del-btn,.log-retry-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:8px;opacity:.35;transition:all .2s;display:flex;align-items:center;justify-content:center;}
.log-del-btn:hover{opacity:.8;color:#f87171;}
.log-retry-btn{opacity:.5;color:var(--accent);}
.log-retry-btn:hover{opacity:1;}
.confirm-modal{display:none;position:fixed;inset:0;z-index:700;background:rgba(0,0,0,.8);align-items:center;justify-content:center;padding:16px;}
.confirm-modal.active{display:flex;}
.confirm-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;width:100%;max-width:300px;text-align:center;}
.confirm-cancel{flex:1;padding:10px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:13px;cursor:pointer;}
.confirm-ok{flex:1;padding:10px;border-radius:8px;border:none;background:rgba(220,53,69,.8);color:#fff;font-size:13px;font-weight:600;cursor:pointer;}
/* PROFILE DROPDOWN */
.user-chip{cursor:pointer;position:relative;}
.profile-dropdown{display:none;position:absolute;top:54px;right:16px;width:280px;background:rgba(18,18,28,.97);border:1px solid var(--border);border-radius:16px;z-index:300;overflow:hidden;backdrop-filter:blur(20px);box-shadow:0 12px 40px rgba(0,0,0,.5);}
.profile-dropdown.active{display:block;}
.profile-header{padding:20px;text-align:center;border-bottom:1px solid var(--border);background:rgba(245,197,24,.05);}
.profile-avatar{width:48px;height:48px;border-radius:50%;background:#f5c518;color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;margin:0 auto 10px;}
.profile-name{font-size:15px;font-weight:600;color:#fff;}
.profile-email{font-size:12px;color:var(--muted);margin-top:2px;}
.profile-section{padding:12px 16px;border-bottom:1px solid var(--border);}
.profile-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:8px;}
.profile-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;color:var(--text);}
.profile-val{color:var(--muted);font-size:12px;}
.profile-row-btn{cursor:pointer;border-radius:6px;padding:6px 4px;}
.profile-row-btn:hover{background:rgba(255,255,255,.05);}
.pw-form{display:none;padding-top:8px;}
.pw-form.pw-show{display:block;}
.pw-form input{width:100%;padding:8px 10px;margin-bottom:6px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:8px;color:#fff;font-size:12px;outline:none;box-sizing:border-box;}
.pw-save-btn{width:100%;padding:8px;border:none;border-radius:8px;background:#f5c518;color:#000;font-size:12px;font-weight:600;cursor:pointer;}
.pw-save-btn:hover{background:#e0b400;}
.pw-msg{font-size:11px;margin-top:4px;min-height:16px;}
.profile-footer{padding:12px 16px;}
.profile-logout{display:block;text-align:center;padding:8px;border-radius:8px;border:1px solid rgba(220,53,69,.3);color:#dc3545;font-size:13px;text-decoration:none;transition:all .2s;}
.profile-logout:hover{background:rgba(220,53,69,.1);}

/* CUSTOMIZE MODAL */
.customize-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);align-items:center;justify-content:center;display:none;overflow-y:auto;}
.customize-modal.active{display:flex;}
.customize-box{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;max-width:420px;width:90%;max-height:90vh;overflow-y:auto;margin:auto;}
.customize-close{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:20px;width:32px;height:32px;border-radius:50%;cursor:pointer;transition:background .2s;}
.customize-close:hover{background:rgba(255,255,255,.2);}
.customize-box h3{font-size:20px;font-weight:700;margin-bottom:16px;color:#f5c518;}
.customize-preview{width:100%;max-width:200px;aspect-ratio:9/16;border-radius:12px;overflow:hidden;margin:0 auto 16px;background:var(--bg);}
.customize-preview img{width:100%;height:100%;object-fit:cover;image-rendering:auto;loading:lazy;}
.customize-hint{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:16px;}
.customize-box textarea{width:100%;padding:12px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:10px;color:#fff;font-size:14px;font-family:inherit;resize:vertical;outline:none;margin-bottom:16px;}
.customize-box textarea:focus{border-color:#f5c518;}
.customize-submit-btn{width:100%;padding:12px;background:#f5c518;color:#000;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;}
.customize-submit-btn:hover{background:#e0b400;}
.customize-submit-btn:disabled{opacity:.5;cursor:not-allowed;}

/* LOG CUSTOMIZE BUTTON */
.log-customize-btn{padding:4px 10px;background:rgba(124,106,255,.1);border:1px solid rgba(124,106,255,.25);border-radius:6px;color:#9b8aff;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s;margin-top:4px;position:relative;z-index:100;pointer-events:auto;display:inline-block;}
.log-customize-btn:hover{background:rgba(124,106,255,.2);border-color:rgba(124,106,255,.4);}
.log-customize-btn:active{transform:scale(0.98);}

/* 图片加载优化 - 自动添加 */
.grid-item img, .feat-item img, .log-thumb img {
  background: linear-gradient(135deg, var(--surface) 0%, rgba(124,106,255,.05) 100%);
  image-rendering: auto;
}

.grid-item img[src]:not([src=""]), 
.feat-item img[src]:not([src=""]) {
  animation: fadeIn 0.3s ease-in;
}

@keyframes fadeIn {
  from { opacity: 0; transform: scale(0.95); }
  to { opacity: 1; transform: scale(1); }
}

img[loading="lazy"]:not([src]), img[data-src] {
  background: var(--surface);
  min-height: 100px;
}

.grid-item img, .feat-item img {
  will-change: transform;
  backface-visibility: hidden;
}

/* PC / TABLET RESPONSIVE */
@media(min-width:768px){
  .panel{left:50%;right:auto;width:480px;transform:translateX(-50%);border-left:1px solid var(--border);border-right:1px solid var(--border);}
  .bnav{max-width:480px;left:50%;right:auto;transform:translateX(-50%);border-radius:16px 16px 0 0;border-left:1px solid var(--border);border-right:1px solid var(--border);}
  .bnav-item{gap:6px;font-size:11px;}
  .bnav-item svg{width:24px;height:24px;}
  .feat-grid{column-count:2;}
  .likes-grid{column-count:2;}
  .topup-box{max-width:480px;}
  .log-item{max-width:100%;}
  footer{padding-bottom:10px;}
}
