/* ═══════════════════════════════════════════════════════
   CHANEL MOD STORE — style.css  (White/Clean Edition)
═══════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* Xóa highlight mặc định của browser khi chạm */
*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;}
button,a,[onclick]{outline:none;}

:root{
    --gr:#4CAF50;--grd:#388E3C;--grl:#E8F5E9;
    --bl:#2196F3;--rd:#F44336;--or:#FF9800;--yw:#FFC107;
    --pink:#E91E63;--pinkl:#FCE4EC;
    --bg:#F2F2F2;--wh:#fff;--t1:#212121;--t2:#616161;--t3:#9E9E9E;
    --bd:#E0E0E0;--sh:0 1px 3px rgba(0,0,0,.1);--sh2:0 2px 10px rgba(0,0,0,.14);
    --brand-gold:#D4AF37;--brand-gold-light:#F0D060;
    --header-start:#1B5E20;--header-end:#2E7D32;
    /* compat neon vars cho script.js */
    --neon-green:#4CAF50;--neon-blue:#2196F3;--neon-red:#F44336;
    --neon-gold:#D4AF37;--admin-purple:#9C27B0;--admin-blue:#1565C0;
}

/* ─── CANVAS (ẩn hoàn toàn, vẫn tồn tại cho script.js) ─── */
#matrix-canvas,#snow-canvas{
    position:fixed;top:0;left:0;width:100%;height:100%;
    pointer-events:none;z-index:-1;opacity:0!important;
}

/* ─── BODY ─── */
body{
    background:var(--bg);color:var(--t1);
    font-family:'Roboto',sans-serif;min-height:100vh;overflow-x:hidden;
    padding-bottom:24px;
}

/* ─── THEME TOGGLE (ẩn hoàn toàn) ─── */
#themeToggleBtn{display:none!important;pointer-events:none!important;}

/* ─── AVATAR LIGHTBOX ─── */
.avatar-lightbox-overlay{
    position:fixed;inset:0;background:rgba(0,0,0,.75);
    z-index:9000;display:none;flex-direction:column;
    justify-content:center;align-items:center;padding:20px;
}
.avatar-lightbox-overlay.active{display:flex;}
.avatar-lightbox-inner{text-align:center;}
#avatarLightboxImg{
    width:200px;height:200px;border-radius:50%;object-fit:cover;
    border:4px solid rgba(255,255,255,.3);box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.avatar-lightbox-name{color:#fff;font-size:16px;font-weight:700;margin-top:12px;}
.avatar-lightbox-hint{color:rgba(255,255,255,.5);font-size:12px;margin-top:4px;}

/* ═══════════════════════════════════════
   DRAWER
═══════════════════════════════════════ */
.drawer-mask{
    position:fixed;inset:0;background:rgba(0,0,0,.5);
    z-index:800;opacity:0;visibility:hidden;
    transition:opacity .3s,visibility .3s;
}
.drawer-mask.open{opacity:1;visibility:visible;}
.drawer{
    position:fixed;top:0;left:0;width:280px;height:100%;
    background:var(--wh);z-index:801;
    transform:translateX(-100%);
    transition:transform .3s cubic-bezier(.4,0,.2,1);
    box-shadow:var(--sh2);display:flex;flex-direction:column;
}
.drawer.open{transform:translateX(0);}
.drawer-head{
    background:linear-gradient(135deg,var(--header-start) 0%,var(--header-end) 50%,var(--header-start) 100%);
    padding:40px 20px 20px;color:#fff;position:relative;overflow:hidden;
}
.drawer-head::before{
    content:'';position:absolute;top:-30px;right:-30px;
    width:100px;height:100px;background:radial-gradient(circle,rgba(255,215,0,.3),transparent 70%);border-radius:50%;
}
.drawer-avatar{
    width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.25);
    display:flex;align-items:center;justify-content:center;
    margin-bottom:10px;overflow:hidden;position:relative;z-index:1;
}
.drawer-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.drawer-brand{position:relative;z-index:1;}
.drawer-brand-name{
    font-family:'Orbitron',sans-serif;font-size:16px;font-weight:900;letter-spacing:2px;
    background:linear-gradient(135deg,#FFD700,#FFA500,#FFD700);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
    filter:drop-shadow(0 0 4px rgba(255,215,0,.5));line-height:1.2;
}
.drawer-brand-sub{font-size:9px;color:rgba(255,255,255,.7);letter-spacing:1.5px;margin-top:2px;text-transform:uppercase;}
.drawer-menu{flex:1;padding:6px 0;overflow-y:auto;}
.drawer-item{
    display:flex;align-items:center;gap:14px;padding:13px 20px;
    font-size:14px;color:var(--t1);cursor:pointer;transition:background .15s;
}
.drawer-item:hover,.drawer-item:active{background:var(--bg);}
.drawer-item.active-item{background:var(--grl);color:var(--grd);font-weight:700;}
.drawer-item.active-item i{color:var(--gr);}
.drawer-item i{width:20px;text-align:center;color:var(--t2);font-size:16px;}
.drawer-divider{height:1px;background:var(--bd);margin:4px 0;}

/* ═══════════════════════════════════════
   HEADER
═══════════════════════════════════════ */
.cms-header{
    background:linear-gradient(135deg,var(--header-start) 0%,var(--header-end) 50%,var(--header-start) 100%);
    position:sticky;top:0;z-index:300;box-shadow:0 2px 6px rgba(0,0,0,.2);
}
.cms-header-row{
    display:flex;align-items:center;justify-content:space-between;
    height:58px;padding:0 4px;max-width:600px;margin:0 auto;position:relative;
}
.hbtn{
    width:46px;height:46px;display:flex;align-items:center;justify-content:center;
    color:#fff;cursor:pointer;font-size:20px;flex-shrink:0;border-radius:50%;
    transition:background .15s;text-decoration:none;
}
.hbtn:active{background:rgba(255,255,255,.18);}
.header-avatar-btn{position:relative;}
.cms-header-logo{
    position:absolute;left:50%;transform:translateX(-50%);
    display:flex;flex-direction:column;align-items:center;
    border:1.5px dashed rgba(255,215,0,.65);padding:3px 14px;border-radius:6px;
    background:rgba(0,0,0,.12);box-shadow:inset 0 0 8px rgba(255,215,0,.15);
}
.cms-logo-text{
    font-family:'Orbitron',sans-serif;font-size:17px;font-weight:900;color:transparent;
    background:repeating-linear-gradient(-45deg,#FFD700,#FFD700 3px,#fff 3px,#fff 6px);
    -webkit-background-clip:text;background-clip:text;
    filter:drop-shadow(0 0 3px rgba(255,215,0,.6));letter-spacing:1px;line-height:1.1;
}
.cms-logo-sub{
    font-size:7.5px;color:#fff;letter-spacing:2.5px;font-weight:700;
    text-transform:uppercase;opacity:.85;
}

/* ═══════════════════════════════════════
   SYS LIVE BAR
═══════════════════════════════════════ */
.sys-live-bar{
    display:flex;align-items:center;justify-content:space-between;
    background:linear-gradient(90deg,var(--header-start),#2E7D32 50%,var(--header-start));
    padding:7px 16px;max-width:600px;margin:0 auto;
    border-radius:0 0 12px 12px;
    box-shadow:0 3px 8px rgba(0,0,0,.15);
    position:sticky;top:58px;z-index:299;
}
.slb-left{display:flex;align-items:center;gap:7px;flex-wrap:wrap;}
.slb-dot{
    width:7px;height:7px;border-radius:50%;background:#69F0AE;flex-shrink:0;
    box-shadow:0 0 6px #69F0AE,0 0 12px rgba(105,240,174,.6);
    animation:pulse-dot 1.8s infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}
.slb-label{
    font-family:'Orbitron',sans-serif;font-size:9px;font-weight:700;
    color:#A5D6A7;letter-spacing:1.5px;text-transform:uppercase;
}
.slb-date{font-size:11px;font-weight:700;color:#fff;}
.slb-sep{color:rgba(255,255,255,.4);font-size:10px;}
.slb-time{
    font-family:'Orbitron',sans-serif;font-size:11px;font-weight:700;
    color:#FFD700;letter-spacing:.5px;
}
.slb-right{display:flex;align-items:center;gap:4px;}
.slb-views{font-size:11px;font-weight:700;color:rgba(255,255,255,.85);}

/* Admin monitor override (script.js thêm admin-monitor) */
.system-monitor.admin-monitor,
.sys-live-bar.admin-monitor{
    background:linear-gradient(90deg,#1a0030,#4a0080 50%,#1a0030)!important;
}

/* ═══════════════════════════════════════
   CONTAINER
═══════════════════════════════════════ */
.container,#mainContainer{max-width:600px;margin:0 auto;padding-bottom:40px;}

/* ─── SECTION LABEL ─── */
.section-label{
    display:flex;align-items:center;gap:8px;
    padding:16px 14px 8px;font-size:11px;font-weight:700;
    color:var(--t2);text-transform:uppercase;letter-spacing:1.2px;
}
.section-label-dot{
    width:8px;height:8px;border-radius:50%;
    background:var(--gr);box-shadow:0 0 6px var(--gr);flex-shrink:0;
}
.section-label-line{flex:1;height:1px;background:linear-gradient(90deg,rgba(76,175,80,.3),transparent);}

/* ═══════════════════════════════════════
   CARDS 2×2
═══════════════════════════════════════ */
.cards-grid-2x2{
    display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 10px 12px;
}
.pro-card{
    border-radius:16px;overflow:hidden;cursor:pointer;
    background:var(--wh);box-shadow:0 2px 8px rgba(0,0,0,.08);
    border:1.5px solid var(--bd);transition:transform .15s,box-shadow .15s;
    display:flex;flex-direction:column;
}
.pro-card:active{transform:scale(.97);box-shadow:0 1px 4px rgba(0,0,0,.1);}
.green-card{border-color:rgba(76,175,80,.25);}
.gold-card{border-color:rgba(212,175,55,.3);}
.red-card{border-color:rgba(244,67,54,.2);}
.pink-card{border-color:rgba(233,30,99,.2);}

.pro-card-banner{position:relative;overflow:hidden;height:90px;}
.pro-card-glow{position:absolute;inset:0;background:linear-gradient(135deg,rgba(76,175,80,.12),transparent);}
.gold-glow{background:linear-gradient(135deg,rgba(212,175,55,.18),transparent);}
.red-glow{background:linear-gradient(135deg,rgba(244,67,54,.12),transparent);}
.pink-glow{background:linear-gradient(135deg,rgba(233,30,99,.12),transparent);}
.pro-card-art{width:100%;height:90px;display:block;}

.pro-card-body{padding:10px;display:flex;flex-direction:column;gap:6px;flex:1;}
.pro-card-badge{
    display:inline-flex;align-items:center;gap:4px;
    font-size:9px;font-weight:700;padding:2px 8px;border-radius:4px;
    text-transform:uppercase;letter-spacing:.5px;width:fit-content;
}
.green-badge{background:var(--grl);color:var(--grd);}
.gold-badge{background:#FFF8E1;color:#6D4C00;}
.red-badge{background:#FFEBEE;color:#B71C1C;}
.pink-badge{background:var(--pinkl);color:#880E4F;}

.pro-card-title{
    font-family:'Orbitron',sans-serif;font-size:13px;font-weight:900;
    color:var(--t1);line-height:1.2;letter-spacing:.5px;
}
.pro-card-title span{color:var(--gr);}
.gold-title span{color:var(--brand-gold);}
.red-title span{color:var(--rd);}
.pink-title span{color:var(--pink);}

.pro-card-features{list-style:none;display:flex;flex-direction:column;gap:3px;margin-top:2px;}
.pro-card-features li{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--t2);}
.pro-card-features li i{color:var(--gr);font-size:9px;width:10px;}

.pro-card-btn{
    margin-top:auto;padding:7px 10px;border:none;border-radius:20px;
    font-size:10px;font-weight:700;cursor:pointer;font-family:'Roboto';
    display:flex;align-items:center;justify-content:center;gap:5px;transition:all .15s;
}
.green-btn{background:var(--gr);color:#fff;}
.green-btn:active{background:var(--grd);}
.gold-btn{background:linear-gradient(135deg,var(--brand-gold),#B8860B);color:#fff;}
.gold-btn:active{opacity:.9;}
.red-btn{background:var(--rd);color:#fff;}
.red-btn:active{opacity:.9;}
.pink-btn{background:var(--pink);color:#fff;}
.pink-btn:active{opacity:.9;}
.maint-btn{background:var(--t3);color:#fff;cursor:not-allowed;}

/* ═══════════════════════════════════════
   DEV BOX
═══════════════════════════════════════ */
.dev-box{
    background:var(--wh);margin:0 10px 8px;border-radius:14px;
    padding:16px;border:1px solid var(--bd);box-shadow:var(--sh);
}
.dev-box h3{
    font-family:'Orbitron',sans-serif;font-size:14px;font-weight:900;
    color:var(--t1);margin-bottom:6px;letter-spacing:.5px;
}
.dev-bio{font-size:12px;color:var(--t2);line-height:1.6;margin-bottom:12px;}
.dev-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.info-item{background:var(--bg);border-radius:8px;padding:8px 10px;}
.info-item label{display:block;font-size:9px;color:var(--t3);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;}
.info-item span{font-size:11px;font-weight:600;color:var(--t1);}

/* ═══════════════════════════════════════
   RATING
═══════════════════════════════════════ */
.rating-item{
    background:var(--wh);margin:0 10px 8px;border-radius:14px;
    padding:14px;border:1px solid var(--bd);box-shadow:var(--sh);
    cursor:pointer;position:relative;overflow:hidden;
}
.rating-highlight{
    position:absolute;top:10px;right:10px;
    background:linear-gradient(135deg,#FFC107,#FF9800);color:#fff;
    font-size:9px;font-weight:700;padding:3px 8px;border-radius:20px;
    box-shadow:0 2px 6px rgba(255,193,7,.4);
}
.rating-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.rating-title{font-size:13px;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:6px;}
.rating-count{font-size:11px;color:var(--t3);}
.rating-stats{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.average-rating{font-family:'Orbitron',sans-serif;font-size:28px;font-weight:900;color:var(--t1);}
.stars-preview{color:#FFC107;font-size:16px;letter-spacing:2px;}
.rating-summary{font-size:11px;color:var(--t2);line-height:1.5;margin-bottom:10px;}
.rating-cta-bar{
    background:var(--bg);border-radius:8px;padding:10px;
    display:flex;align-items:center;justify-content:center;gap:8px;
    font-size:11px;font-weight:700;color:var(--gr);
}
.external-reviews-container{padding:0 10px 8px;}
.no-external-reviews{text-align:center;padding:20px;color:var(--t3);font-size:12px;}

/* ═══════════════════════════════════════
   CONTACT
═══════════════════════════════════════ */
.contact-row{display:flex;gap:8px;padding:0 10px 12px;}
.c-btn{
    flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
    padding:12px;border-radius:12px;font-size:12px;font-weight:700;
    color:#fff;text-decoration:none;transition:.15s;
}
.c-btn:active{opacity:.85;transform:scale(.97);}
.c-btn.fb{background:linear-gradient(135deg,#1877F2,#0d5aab);}
.c-btn.tl{background:linear-gradient(135deg,#24A1DE,#1a7eb3);}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
.footer-wrap{
    background:var(--wh);margin:8px 10px 0;border-radius:14px;
    padding:28px 16px 20px;border:1px solid var(--bd);
}
.foot-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
.foot-brand{grid-column:1/-1;text-align:center;}
.foot-logo{
    font-family:'Orbitron',sans-serif;font-size:1.25rem;font-weight:900;letter-spacing:2px;
    background:linear-gradient(135deg,#FFD700,#FFA500,#FFD700);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    display:inline-block;margin-bottom:8px;
}
.foot-brand p{font-size:.78rem;color:var(--t2);line-height:1.5;}
.foot-col h5{color:var(--t1);font-size:.72rem;letter-spacing:1px;text-transform:uppercase;margin-bottom:12px;font-weight:900;}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.foot-col ul li a{
    font-size:.78rem;color:var(--t2);transition:color .2s;font-weight:500;
    display:flex;align-items:center;gap:6px;text-decoration:none;
}
.foot-col ul li a:active{color:var(--gr);}
.foot-col ul li a i{width:16px;text-align:center;color:var(--t3);}
.social-btn{
    display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;
    font-size:11px;font-weight:700;color:#fff;text-decoration:none;
    margin-bottom:8px;box-shadow:var(--sh);justify-content:center;transition:.15s;
}
.social-btn:active{transform:scale(.95);}
.social-btn.fb{background:linear-gradient(135deg,#1877F2,#0d5aab);}
.social-btn.tt{background:linear-gradient(135deg,#000,#333);}
.social-btn.yt{background:linear-gradient(135deg,#FF0000,#cc0000);}
.social-btn.tl{background:linear-gradient(135deg,#24A1DE,#1a7eb3);}
.foot-bottom{
    border-top:1px solid var(--bd);padding-top:16px;
    display:flex;flex-direction:column;align-items:center;gap:4px;
    font-size:.68rem;color:var(--t3);text-align:center;
}
.foot-bottom span:first-child{font-family:'Orbitron',sans-serif;letter-spacing:.5px;}

/* ═══════════════════════════════════════
   MAINTENANCE POPUP
═══════════════════════════════════════ */
.maint-popup-overlay{
    position:fixed;inset:0;background:rgba(0,0,0,.5);
    z-index:5000;display:none;justify-content:center;align-items:center;
    padding:20px;backdrop-filter:blur(4px);
}
.maint-popup-overlay.active{display:flex;}
.maint-popup-box{
    background:var(--wh);border-radius:20px;padding:30px 24px;
    max-width:320px;width:100%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.maint-popup-title{font-family:'Orbitron',sans-serif;font-size:16px;font-weight:900;color:var(--rd);letter-spacing:1px;margin-bottom:8px;}
.maint-popup-desc{font-size:13px;color:var(--t2);line-height:1.6;margin-bottom:20px;}
.maint-popup-close{width:100%;padding:12px;background:var(--gr);border:none;border-radius:24px;color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:'Roboto';}

/* ═══════════════════════════════════════
   VIP MODALS
═══════════════════════════════════════ */
.vip-notice-modal-overlay,.vip-features-modal-overlay{
    position:fixed;inset:0;background:rgba(0,0,0,.5);
    z-index:5000;display:none;justify-content:center;align-items:center;
    padding:20px;backdrop-filter:blur(4px);
}
.vip-notice-modal,.vip-features-modal{
    background:var(--wh);border-radius:20px;padding:24px;
    max-width:360px;width:100%;max-height:80vh;overflow-y:auto;
    box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.vip-notice-header{text-align:center;margin-bottom:16px;}
.vip-notice-icon{width:56px;height:56px;background:#FFF8E1;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;}
.vip-notice-icon i{font-size:24px;color:var(--brand-gold);}
.vip-notice-title{font-family:'Orbitron',sans-serif;font-size:13px;font-weight:900;color:var(--t1);letter-spacing:1px;}
.vip-notice-content p{font-size:13px;color:var(--t2);line-height:1.6;margin-bottom:12px;}
.vip-notice-highlight{
    background:linear-gradient(135deg,#FFF8E1,#FFF3CD);border:1px solid rgba(212,175,55,.3);
    border-radius:10px;padding:10px 14px;font-size:12px;font-weight:700;
    color:#6D4C00;cursor:pointer;display:flex;align-items:center;gap:6px;margin-bottom:12px;
}
.vip-notice-buttons{margin-top:16px;}
.btn-vip-close{
    width:100%;padding:12px;background:var(--gr);border:none;border-radius:24px;
    color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:'Roboto';
    display:flex;align-items:center;justify-content:center;gap:6px;
}
.vip-features-modal{position:relative;}
.vip-features-close{
    position:absolute;top:16px;right:16px;background:var(--bg);border:1px solid var(--bd);
    border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:16px;color:var(--t2);
    display:flex;align-items:center;justify-content:center;
}
.vip-features-header{text-align:center;margin-bottom:16px;}
.vip-features-title{font-family:'Orbitron',sans-serif;font-size:13px;font-weight:900;color:var(--t1);letter-spacing:1px;margin-bottom:4px;}
.vip-features-subtitle{font-size:12px;color:var(--t2);}
.vip-features-list{list-style:none;display:flex;flex-direction:column;gap:12px;}
.vip-features-list li{background:var(--bg);border-radius:10px;padding:12px;font-size:12px;color:var(--t2);line-height:1.6;}
.vip-features-list li strong{display:block;font-size:12px;font-weight:700;color:var(--t1);margin-bottom:4px;}
.vip-features-note{background:var(--grl);border-radius:8px;padding:10px 12px;font-size:11px;color:var(--grd);margin-top:12px;display:flex;align-items:flex-start;gap:6px;}

/* ═══════════════════════════════════════
   WELCOME MODAL
═══════════════════════════════════════ */
.welcome-modal-overlay{
    position:fixed;inset:0;background:rgba(0,0,0,.5);
    z-index:5000;display:none;justify-content:center;align-items:center;
    padding:20px;backdrop-filter:blur(4px);
}
.welcome-modal-overlay.active{display:flex;}
.welcome-modal{
    background:var(--wh);border-radius:20px;padding:24px;
    max-width:360px;width:100%;max-height:80vh;overflow-y:auto;
    box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.welcome-header{
    background:linear-gradient(135deg,var(--header-start),var(--header-end));
    border-radius:12px;padding:16px;text-align:center;margin:-24px -24px 16px;
}
.welcome-header h2{font-family:'Orbitron',sans-serif;font-size:15px;font-weight:900;color:#fff;letter-spacing:1px;}
.welcome-header h2 span{color:#FFD700;}
.welcome-content p{font-size:13px;color:var(--t2);line-height:1.6;margin-bottom:10px;}
.welcome-signature{font-size:12px;color:var(--t2);text-align:right;border-top:1px solid var(--bd);padding-top:10px;margin-top:10px;}
.welcome-buttons{margin-top:16px;display:flex;flex-direction:column;gap:8px;}
.btn-telegram{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:linear-gradient(135deg,#24A1DE,#1a7eb3);border-radius:24px;color:#fff;font-size:12px;font-weight:700;text-decoration:none;}
.telegram-icon{width:18px;height:18px;}
.btn-understood{width:100%;padding:12px;background:var(--bg);border:1px solid var(--bd);border-radius:24px;color:var(--t2);font-size:13px;font-weight:700;cursor:pointer;font-family:'Roboto';}

/* ═══════════════════════════════════════
   AUTO RATING PROMPT
═══════════════════════════════════════ */
.auto-rating-prompt{
    position:fixed;bottom:20px;left:50%;transform:translateX(-50%);
    z-index:4000;display:none;max-width:340px;width:calc(100% - 32px);
}
.auto-rating-prompt.active{display:block;}
.auto-rating-box{
    background:var(--wh);border-radius:16px;padding:16px;
    box-shadow:0 8px 32px rgba(0,0,0,.15);border:1px solid var(--bd);position:relative;
}
.auto-rating-close{
    position:absolute;top:10px;right:10px;background:var(--bg);border:1px solid var(--bd);
    border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:14px;color:var(--t2);
    display:flex;align-items:center;justify-content:center;
}
.auto-rating-title{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:8px;}
.auto-rating-question{font-size:12px;color:var(--t2);margin-bottom:10px;font-style:italic;}
.auto-rating-stars{display:flex;gap:6px;margin-bottom:10px;}
.auto-rating-star{font-size:24px;color:var(--bd);cursor:pointer;transition:.15s;}
.auto-rating-star.active,.auto-rating-star:hover{color:#FFC107;}
.auto-rating-buttons{display:flex;gap:8px;margin-bottom:8px;}
.btn-rating-later{flex:1;padding:8px;background:var(--bg);border:1px solid var(--bd);border-radius:20px;color:var(--t2);font-size:11px;font-weight:600;cursor:pointer;font-family:'Roboto';}
.btn-open-rating{flex:1;padding:8px;background:var(--gr);border:none;border-radius:20px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;font-family:'Roboto';}
.auto-rating-countdown{font-size:10px;color:var(--t3);text-align:center;}

/* ═══════════════════════════════════════
   RATING MODAL
═══════════════════════════════════════ */
.rating-modal-overlay{
    position:fixed;inset:0;background:rgba(0,0,0,.5);
    z-index:5000;display:none;justify-content:center;align-items:center;
    padding:20px;backdrop-filter:blur(4px);
}
.rating-modal-overlay.active{display:flex;}
.rating-modal{
    background:var(--wh);border-radius:20px;padding:24px;
    max-width:400px;width:100%;max-height:85vh;overflow-y:auto;
    box-shadow:0 20px 60px rgba(0,0,0,.2);position:relative;
}
.close-rating-modal{
    position:absolute;top:16px;right:16px;background:var(--bg);border:1px solid var(--bd);
    border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:16px;color:var(--t2);
    display:flex;align-items:center;justify-content:center;
}
.rating-modal-header{text-align:center;margin-bottom:16px;}
.rating-modal-header h3{font-family:'Orbitron',sans-serif;font-size:14px;font-weight:900;color:var(--t1);letter-spacing:1px;margin-bottom:4px;}
.success-message{display:none;text-align:center;padding:20px;background:var(--grl);border-radius:12px;margin-bottom:16px;}
.success-message.show{display:block;}
.success-message i{font-size:32px;color:var(--gr);display:block;margin-bottom:8px;}
.success-message p{font-size:13px;color:var(--grd);}
.loading-spinner{display:none;text-align:center;padding:20px;}
.loading-spinner.show{display:block;}
.spinner{width:26px;height:26px;border:3px solid var(--bd);border-top-color:var(--gr);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 8px;}
@keyframes spin{100%{transform:rotate(360deg)}}
.star-rating-container{margin-bottom:16px;}
.star-rating-title{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:10px;}
.stars-container{display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap;}
.emotion-display{font-size:24px;margin-right:4px;}
.star{font-size:28px;color:var(--bd);cursor:pointer;transition:.15s;}
.star.active,.star.hover{color:#FFC107;}
.rating-description{font-size:12px;color:var(--t2);}
.comment-section{margin-bottom:16px;}
.comment-title{font-size:12px;font-weight:700;color:var(--t1);margin-bottom:8px;}
.comment-textarea{width:100%;padding:10px;background:var(--bg);border:1.5px solid var(--bd);border-radius:10px;color:var(--t1);font-size:13px;font-family:'Roboto';outline:none;resize:vertical;min-height:80px;transition:border-color .2s;}
.comment-textarea:focus{border-color:var(--gr);}
.char-count{font-size:10px;color:var(--t3);text-align:right;margin-top:4px;}
.submit-rating-btn{width:100%;padding:12px;background:var(--gr);border:none;border-radius:24px;color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:'Roboto';margin-bottom:16px;}
.submit-rating-btn:disabled{opacity:.5;cursor:not-allowed;}
.user-reviews-section{border-top:1px solid var(--bd);padding-top:14px;}
.user-reviews-title{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:700;color:var(--t1);margin-bottom:10px;}
.reviews-count{font-size:11px;color:var(--t3);}
.reviews-container{display:flex;flex-direction:column;gap:8px;}
.no-reviews{text-align:center;font-size:12px;color:var(--t3);padding:16px;}

/* ═══════════════════════════════════════
   REVIEW ITEMS (tạo bởi script.js)
═══════════════════════════════════════ */
.review-item{background:var(--bg);border-radius:12px;padding:12px;border:1px solid var(--bd);}
.review-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.reviewer-name{font-size:13px;font-weight:700;color:var(--t1);}
.review-stars{color:#FFC107;font-size:13px;letter-spacing:1px;}
.review-comment{font-size:12px;color:var(--t2);line-height:1.6;margin-bottom:4px;}
.review-time{font-size:10px;color:var(--t3);}
.review-actions{display:flex;gap:6px;margin-top:8px;}
.edit-review-btn,.delete-review-btn{padding:5px 12px;border-radius:16px;font-size:10px;font-weight:700;cursor:pointer;font-family:'Roboto';border:1px solid;transition:.15s;}
.edit-review-btn{background:#E3F2FD;color:#1565C0;border-color:rgba(21,101,192,.3);}
.delete-review-btn{background:#FFEBEE;color:#B71C1C;border-color:rgba(183,28,28,.3);}
.response-button{
    display:inline-flex;align-items:center;gap:5px;margin-top:8px;
    padding:6px 14px;background:var(--grl);border:1.5px solid rgba(76,175,80,.35);
    border-radius:16px;color:var(--grd);font-size:11px;font-weight:700;cursor:pointer;font-family:'Roboto';
}
.response-button.disabled{background:var(--bg);border-color:var(--bd);color:var(--t3);cursor:default;}
.response-form{display:none;}
.response-form.active{display:block;margin-top:8px;}
.response-textarea{width:100%;padding:10px;background:var(--bg);border:1.5px solid var(--bd);border-radius:10px;color:var(--t1);font-size:13px;font-family:'Roboto';outline:none;resize:vertical;min-height:60px;margin-bottom:8px;}
.response-textarea:focus{border-color:var(--gr);}
.response-buttons{display:flex;gap:8px;}
.btn-response{padding:7px 14px;border-radius:16px;font-size:11px;font-weight:700;cursor:pointer;font-family:'Roboto';border:none;}
.btn-send-response{background:var(--gr);color:#fff;}
.btn-cancel-response{background:var(--bg);color:var(--t2);border:1px solid var(--bd);}
.admin-response-content{font-size:12px;color:var(--t1);line-height:1.6;margin-bottom:4px;}
.admin-response-time{font-size:10px;color:var(--t3);}

/* External reviews */
/* ── EXTERNAL REVIEW CARD — block layout ── */
.external-review-item{
    background:var(--wh);border-radius:14px;padding:14px;
    border:1px solid var(--bd);box-shadow:var(--sh);
    margin-bottom:8px;
}

/* Row trên: avatar + tên + sao */
.ext-rv-top{
    display:flex;align-items:center;gap:10px;margin-bottom:8px;
}
.external-review-avatar{
    width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;
    background:var(--bg);border:2px solid var(--bd);
    display:flex;align-items:center;justify-content:center;
}
.external-review-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.ext-rv-meta{flex:1;min-width:0;}
.external-reviewer-name{font-size:14px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.external-review-stars{color:#FFC107;font-size:13px;margin-top:2px;white-space:nowrap;}

/* Comment + time — full width */
.external-review-comment{font-size:14px;color:var(--t1);line-height:1.65;margin-bottom:4px;word-break:break-word;font-weight:500;letter-spacing:0.1px;}
.external-review-time{font-size:11px;color:var(--t3);margin-bottom:8px;}

/* Admin response — full width block */
.admin-response{
    background:linear-gradient(135deg,#FFF8E1,#FFF3CD);
    border:1px solid rgba(212,175,55,.3);border-radius:10px;
    padding:10px 12px;margin:8px 0;
    width:100%;box-sizing:border-box;
}
.admin-response-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:8px;}
.admin-response-badge{
    display:flex;align-items:center;gap:5px;
    font-size:10px;font-weight:700;color:#6D4C00;
    white-space:nowrap;flex-shrink:0;
}
.admin-response-badge i{color:var(--brand-gold);}
.admin-response-actions{display:flex;gap:4px;flex-shrink:0;}
.admin-response-action-btn{width:24px;height:24px;border-radius:50%;background:rgba(212,175,55,.2);border:1px solid rgba(212,175,55,.4);color:#6D4C00;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.admin-response-content{font-size:12px;color:var(--t1);line-height:1.6;margin-bottom:4px;word-break:break-word;}
.admin-response-time{font-size:10px;color:var(--t3);}

/* Nút phản hồi admin */
.ext-rv-response-btn{
    display:inline-flex;align-items:center;gap:6px;
    margin-top:8px;padding:6px 14px;
    background:rgba(76,175,80,.1);border:1px solid rgba(76,175,80,.4);
    border-radius:20px;color:var(--grd);font-size:11px;font-weight:700;
    cursor:pointer;font-family:'Roboto';
}

/* Vote row — full width bên dưới */
.review-vote-row{
    display:flex;align-items:center;justify-content:space-between;
    margin-top:10px;padding-top:8px;border-top:1px solid var(--bd);
}
.vote-label{font-size:11px;color:var(--t3);}
.vote-btns{display:flex;gap:8px;}
.vote-btn{
    display:inline-flex;align-items:center;gap:5px;
    padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;
    border:1.5px solid var(--bd);background:var(--bg);color:var(--t2);
    cursor:pointer;font-family:'Roboto';transition:all .15s;
}
.vote-btn:active{transform:scale(.95);}
.vote-btn svg{flex-shrink:0;}
.vote-up-btn.voted{background:#E8F5E9;border-color:rgba(76,175,80,.5);color:var(--grd);}
.vote-down-btn.voted{background:#FFEBEE;border-color:rgba(244,67,54,.4);color:#B71C1C;}
.vote-btn .vc-up,.vote-btn .vc-down{font-size:11px;font-weight:700;min-width:14px;text-align:center;}

/* ── ADMIN HEART BUTTON ── */
.admin-heart-btn{
    display:inline-flex;align-items:center;gap:6px;
    padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;
    border:1.5px solid rgba(229,57,53,.35);background:rgba(229,57,53,.07);
    color:#e53935;cursor:pointer;font-family:'Roboto';transition:all .18s;
}
.admin-heart-btn:hover{background:rgba(229,57,53,.16);border-color:#e53935;transform:scale(1.04);}
.admin-heart-btn:active{transform:scale(.92);}
.admin-heart-btn.admin-heart-active{background:rgba(229,57,53,.13);border-color:#e53935;}
.admin-heart-btn.admin-heart-active .admin-heart-svg{animation:heartPop .36s cubic-bezier(.175,.885,.32,1.275);}
@keyframes heartPop{0%{transform:scale(1);}45%{transform:scale(1.5);}70%{transform:scale(.88);}100%{transform:scale(1);}}

/* ── SLOT + AVATAR TIM INLINE (nằm gọn trong vote-row, không tràn) ── */
.admin-heart-overlay-slot{display:flex;align-items:center;margin-left:2px;}
.aho-wrap{
    position:relative;width:34px;height:34px;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;cursor:pointer;
}
.aho-avatar{
    width:34px;height:34px;border-radius:50%;object-fit:cover;display:block;
    border:2px solid #fff;box-shadow:0 2px 7px rgba(0,0,0,.22);
    transition:transform .15s;
}
.aho-wrap:active .aho-avatar{transform:scale(.93);}
.aho-heart-badge{
    position:absolute;bottom:-3px;right:-3px;
    width:17px;height:17px;border-radius:50%;
    background:#e53935;border:2px solid #fff;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 1px 5px rgba(229,57,53,.5);
    animation:heartBadgeIn .3s cubic-bezier(.175,.885,.32,1.275);
}
@keyframes heartBadgeIn{0%{transform:scale(0);opacity:0;}100%{transform:scale(1);opacity:1;}}

/* ── TOOLTIP GIẢI THÍCH ADMIN HEART ── */
.admin-heart-tooltip{
    position:absolute;z-index:9999;
    background:#1a1a1a;color:#f0f0f0;
    border-radius:12px;padding:11px 13px;
    box-shadow:0 6px 24px rgba(0,0,0,.38);
    pointer-events:none;
    opacity:0;transform:translateY(6px) scale(.97);
    transition:opacity .17s ease,transform .17s ease;
}
.admin-heart-tooltip.aht-visible{
    opacity:1;transform:translateY(0) scale(1);
}
.aht-header{
    display:flex;align-items:center;gap:6px;
    font-size:12px;font-weight:700;color:#ff6b6b;
    margin-bottom:6px;
}
.aht-body{font-size:11.5px;line-height:1.6;color:#ddd;}
.aht-body strong{color:#fff;}
.aht-body em{color:#ff9a9a;font-style:normal;font-weight:600;}

/* scroll lock — dùng chung cho tất cả modal */
html.scroll-locked{overflow:hidden;}
html.scroll-locked body{position:fixed;width:100%;overflow-y:scroll;}

═══════════════════════════════════════ */
.donate-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:6000;display:none!important;justify-content:flex-end;flex-direction:column;visibility:hidden;pointer-events:none;}
.donate-overlay.active{display:flex!important;visibility:visible;pointer-events:all;}
.donate-modal{background:var(--wh);border-radius:20px 20px 0 0;max-height:88vh;overflow-y:auto;padding-bottom:20px;}
.donate-hero{background:linear-gradient(135deg,var(--header-start),var(--header-end));padding:28px 20px;text-align:center;position:relative;}
.donate-back-btn{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:6px 12px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;font-family:'Roboto';display:flex;align-items:center;gap:6px;}
.donate-hero-svg{display:block;margin:0 auto 12px;}
.donate-hero-title{font-family:'Orbitron',sans-serif;font-size:16px;font-weight:900;color:#fff;letter-spacing:1px;margin-bottom:4px;}
.donate-hero-sub{font-size:11px;color:rgba(255,255,255,.7);letter-spacing:1px;}
.donate-section{padding:16px;}
.donate-section-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--t1);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;}
.donate-story-card{background:var(--bg);border-radius:12px;padding:12px;margin-bottom:12px;}
.dsc-header{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--t1);margin-bottom:8px;}
.donate-story-card p{font-size:12px;color:var(--t2);line-height:1.6;}
.donate-goal-box{background:var(--bg);border-radius:12px;padding:12px;margin-bottom:12px;}
.donate-goal-header{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:700;color:var(--t1);margin-bottom:8px;}
.donate-goal-pct{color:var(--pink);}
.donate-goal-bar-wrap{background:var(--bd);border-radius:4px;height:6px;margin-bottom:6px;}
.donate-goal-bar{height:6px;border-radius:4px;width:0%;background:linear-gradient(90deg,var(--pink),#F48FB1);transition:width .5s;}
.donate-goal-sub{font-size:11px;color:var(--t2);}
.donate-stats-bar{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.donate-stat{background:var(--wh);border-radius:10px;padding:10px;text-align:center;border:1px solid var(--bd);}
.donate-stat-num{font-family:'Orbitron',sans-serif;font-size:14px;font-weight:900;color:var(--t1);display:block;}
.donate-stat-label{font-size:9px;color:var(--t3);margin-top:2px;}
.donate-qr-box{background:var(--bg);border-radius:12px;padding:14px;}
.donate-step-label{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--t1);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;}
.donate-amount-row{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap;}
.donate-amount-chip{padding:6px 14px;background:var(--wh);border:1.5px solid var(--bd);border-radius:20px;font-size:12px;font-weight:700;color:var(--t2);cursor:pointer;}
.donate-amount-chip.selected{background:var(--pinkl);border-color:var(--pink);color:var(--pink);}
.donate-input-row{display:flex;align-items:center;gap:6px;margin-bottom:8px;}
.donate-amount-input{flex:1;padding:10px 14px;background:var(--wh);border:1.5px solid var(--bd);border-radius:10px;color:var(--t1);font-size:14px;font-family:'Roboto';outline:none;}
.donate-amount-input:focus{border-color:var(--pink);}
.donate-currency{font-size:12px;color:var(--t3);font-weight:700;}
.donate-msg-input{width:100%;padding:10px;background:var(--wh);border:1.5px solid var(--bd);border-radius:10px;color:var(--t1);font-size:13px;font-family:'Roboto';outline:none;resize:vertical;min-height:60px;margin-bottom:4px;}
.donate-msg-input:focus{border-color:var(--pink);}
.donate-msg-counter{font-size:10px;color:var(--t3);font-weight:normal;}
.donate-msg-hint{font-size:11px;color:var(--t3);margin-bottom:12px;}
.donate-anon-row{display:flex;align-items:center;gap:10px;background:var(--wh);border-radius:10px;padding:10px;margin-bottom:12px;cursor:pointer;}
.donate-anon-toggle-wrap{position:relative;width:36px;height:20px;flex-shrink:0;}
.donate-anon-toggle-wrap input{opacity:0;width:0;height:0;}
.donate-anon-slider{position:absolute;inset:0;background:#ccc;border-radius:20px;cursor:pointer;transition:.25s;}
.donate-anon-slider::before{content:"";position:absolute;width:14px;height:14px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 1px 3px rgba(0,0,0,.3);}
.donate-anon-toggle-wrap input:checked + .donate-anon-slider{background:var(--pink);}
.donate-anon-toggle-wrap input:checked + .donate-anon-slider::before{transform:translateX(16px);}
.donate-anon-info{flex:1;}
.donate-anon-label{display:block;font-size:12px;font-weight:700;color:var(--t1);}
.donate-anon-sub{display:block;font-size:10px;color:var(--t3);}
.donate-gen-btn{width:100%;padding:12px;background:var(--pink);border:none;border-radius:24px;color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:'Roboto';display:flex;align-items:center;justify-content:center;gap:8px;}
.donate-gen-btn:disabled{opacity:.5;cursor:not-allowed;}
.donate-qr-display{display:none;margin-top:16px;}
.donate-qr-display.active{display:block;}
.qr-countdown-bar-bg{background:var(--bd);border-radius:4px;height:4px;margin-bottom:4px;}
.qr-countdown-bar{height:4px;border-radius:4px;width:100%;background:linear-gradient(90deg,var(--gr),#81C784);transition:width 1s linear;}
.qr-countdown-text{font-size:11px;color:var(--t2);text-align:center;}
.qr-countdown-text.urgent{color:var(--rd)!important;font-weight:700;}
.donate-qr-note{font-size:12px;color:var(--t2);text-align:center;line-height:1.6;background:var(--bg);border-radius:10px;padding:10px;margin:10px 0;}
.donate-qr-amount-show{font-size:14px;font-weight:700;color:var(--t1);text-align:center;margin:8px 0;}
.donate-qr-pending-tag{display:flex;align-items:center;justify-content:center;gap:4px;font-size:11px;color:#FFC107;font-weight:700;margin-bottom:12px;}
.donate-qr-actions{display:flex;gap:8px;margin-bottom:12px;}
.donate-qr-download-btn{flex:1;padding:10px;background:var(--gr);border:none;border-radius:20px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;font-family:'Roboto';display:flex;align-items:center;justify-content:center;gap:6px;}
.donate-qr-cancel-btn{padding:10px 16px;background:var(--bg);border:1px solid var(--bd);border-radius:20px;color:var(--t2);font-size:11px;font-weight:700;cursor:pointer;font-family:'Roboto';}
.donate-submit-btn{width:100%;padding:12px;background:linear-gradient(135deg,var(--gr),var(--grd));border:none;border-radius:24px;color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:'Roboto';display:flex;align-items:center;justify-content:center;gap:8px;}
.donate-messages-list,.donate-hof-list{display:flex;flex-direction:column;gap:8px;}
.no-donors-msg,.no-pending-msg{text-align:center;font-size:12px;color:var(--t3);padding:16px;background:var(--bg);border-radius:10px;}
.donate-admin-section{background:#FFF8E1;border-radius:12px;border:1px solid rgba(212,175,55,.3);}
.donate-admin-title{font-size:12px;font-weight:700;color:#6D4C00;display:flex;align-items:center;gap:6px;margin-bottom:10px;}
.donate-pending-list{display:flex;flex-direction:column;gap:6px;}
.donate-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--t1);color:#fff;border-radius:24px;padding:10px 20px;font-size:13px;font-weight:700;z-index:9999;display:none;box-shadow:0 4px 16px rgba(0,0,0,.2);}
.donate-toast.show{display:block;}

/* Donate msg card */
.donate-msg-card{background:var(--bg);border-radius:12px;padding:12px;display:flex;gap:10px;align-items:flex-start;border:1px solid var(--bd);}
.donate-msg-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--wh);border:1.5px solid var(--bd);}
.donate-msg-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.donate-msg-name{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:3px;}
.donate-msg-amount{font-size:11px;color:var(--brand-gold);font-weight:700;display:flex;align-items:center;gap:3px;margin-bottom:4px;}
.donate-msg-text{font-size:12px;color:var(--t2);font-style:italic;line-height:1.5;margin-bottom:3px;}
.donate-msg-time{font-size:10px;color:var(--t3);}

/* Hall of Fame */
.donate-hof-item{background:var(--bg);border-radius:12px;padding:12px;display:flex;align-items:center;gap:10px;border:1px solid var(--bd);margin-bottom:6px;}
.hof-rank{width:24px;text-align:center;flex-shrink:0;}
.hof-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--wh);border:2px solid var(--bd);}
.hof-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.hof-info{flex:1;min-width:0;}
.hof-name{font-size:12px;font-weight:700;color:var(--t1);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.hof-amount{font-size:13px;font-weight:900;color:var(--brand-gold);}
.hof-time{font-size:10px;color:var(--t3);}

/* Pending items */
.donate-pending-item{background:var(--wh);border-radius:12px;padding:12px;border:1px solid rgba(212,175,55,.3);margin-bottom:8px;}
.dpi-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.dpi-name{font-size:12px;font-weight:700;color:var(--t1);}
.dpi-amount{font-size:13px;font-weight:900;color:var(--brand-gold);}
.dpi-msg{font-size:11px;color:var(--t2);font-style:italic;margin-bottom:4px;}
.dpi-time{font-size:10px;color:var(--t3);margin-bottom:8px;}
.dpi-approve-btn{width:100%;padding:8px;background:linear-gradient(135deg,var(--gr),var(--grd));border:none;border-radius:20px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;font-family:'Roboto';display:flex;align-items:center;justify-content:center;gap:6px;}

/* ═══════════════════════════════════════
   DONATE CONFIRM
═══════════════════════════════════════ */
.donate-confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:7000;display:none!important;justify-content:center;align-items:center;padding:20px;backdrop-filter:blur(4px);visibility:hidden;pointer-events:none;}
.donate-confirm-overlay.active{display:flex!important;visibility:visible;pointer-events:all;}
.donate-confirm-box{background:var(--wh);border-radius:20px;padding:24px;max-width:360px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2);position:relative;}
.dcb-close-x{position:absolute;top:16px;right:16px;background:var(--bg);border:1px solid var(--bd);border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:16px;color:var(--t2);display:flex;align-items:center;justify-content:center;}
.dcb-icon{width:56px;height:56px;background:var(--grl);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;}
.dcb-icon i{font-size:24px;color:var(--gr);}
.dcb-title{font-family:'Orbitron',sans-serif;font-size:14px;font-weight:900;color:var(--t1);text-align:center;letter-spacing:1px;margin-bottom:4px;}
.dcb-subtitle{font-size:11px;color:var(--t2);text-align:center;margin-bottom:16px;}
.dcb-reasons{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;}
.dcb-reason-item{display:flex;gap:10px;align-items:flex-start;}
.dcb-reason-icon{width:32px;height:32px;background:var(--grl);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.dcb-reason-icon i{font-size:14px;color:var(--gr);}
.dcb-reason-title{font-size:11px;font-weight:700;color:var(--t1);margin-bottom:2px;}
.dcb-reason-desc{font-size:10px;color:var(--t2);line-height:1.5;}
.dcb-time-badge{background:#FFF8E1;border:1px solid rgba(212,175,55,.3);border-radius:10px;padding:10px;font-size:11px;font-weight:700;color:#6D4C00;display:flex;align-items:center;gap:6px;margin-bottom:16px;}
.dcb-confirm-btn{width:100%;padding:12px;background:var(--gr);border:none;border-radius:24px;color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:'Roboto';display:flex;align-items:center;justify-content:center;gap:8px;}

/* ═══════════════════════════════════════
   ADMIN OVERRIDES
═══════════════════════════════════════ */
.admin-body{}
.admin-name{color:var(--gr)!important;font-weight:700!important;}
.admin-rank{color:#9C27B0!important;font-weight:700!important;}
.admin-monitor{display:flex!important;}
.admin-header{}
.admin-container{}
.admin-rating-modal{}
.admin-welcome .welcome-header h2{color:#FFD700!important;}

/* ═══ ADMIN AVATAR — Viền vàng + Vương miện ═══ */
@keyframes adminCrownFloat{
    0%,100%{transform:translateX(-50%) translateY(0) rotate(-5deg);}
    50%{transform:translateX(-50%) translateY(-4px) rotate(5deg);}
}
@keyframes adminAuraGlow{
    0%,100%{box-shadow:0 0 8px rgba(255,215,0,.55),0 0 18px rgba(255,180,0,.3),0 0 32px rgba(212,175,55,.15);}
    50%{box-shadow:0 0 14px rgba(255,215,0,.85),0 0 28px rgba(255,180,0,.5),0 0 48px rgba(212,175,55,.25);}
}
@keyframes adminRingPulse{
    0%,100%{opacity:.7;transform:scale(1);}
    50%{opacity:1;transform:scale(1.08);}
}

/* Header avatar button khi là admin */
.header-avatar-btn.admin-avatar{position:relative;}
.header-avatar-btn.admin-avatar #headerAvatarIcon{color:#FFD700!important;}
.header-avatar-btn.admin-avatar #headerAvatarImg{
    border:2px solid #FFD700!important;
    box-shadow:0 0 7px rgba(255,215,0,.5)!important;
}
/* Crown badge — inject bằng JS, nằm trên mép trên avatar, KHÔNG dùng top âm */
.admin-crown-badge{
    position:absolute;
    /* Canh giữa theo chiều ngang */
    left:50%;
    /* top:0 = mép trên của button, transform kéo crown lên đúng nửa chiều cao nó */
    top:0;
    transform:translate(-50%, -55%);
    width:24px;height:16px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 44 30'%3E%3Cpath d='M3,26 L5,11 L14,20 L22,3 L30,20 L39,11 L41,26 Z' fill='%23B8860B' stroke='%237A5700' stroke-width='1.2' stroke-linejoin='round'/%3E%3Cpath d='M3,26 L5,11 L14,20 L22,3 L30,20 L39,11 L41,20 L3,20 Z' fill='%23FFD700' opacity='0.45'/%3E%3Cpath d='M6,13 L14,20 L22,5 L30,20 L38,13 L37,16 L30,17.5 L22,8 L14,17.5 L7,16 Z' fill='%23FFEE88' opacity='0.45'/%3E%3Crect x='3' y='23' width='38' height='5' rx='2' fill='%23B8860B' stroke='%237A5700' stroke-width='1'/%3E%3Crect x='4' y='23.5' width='36' height='2' rx='1' fill='%23FFD700' opacity='0.55'/%3E%3Ccircle cx='22' cy='5.5' r='3.2' fill='%23FF1E4E' stroke='%23AA0030' stroke-width='0.8'/%3E%3Ccircle cx='13.5' cy='20.5' r='2.6' fill='%231E8FFF' stroke='%230050BB' stroke-width='0.8'/%3E%3Ccircle cx='30.5' cy='20.5' r='2.6' fill='%2320D060' stroke='%23007830' stroke-width='0.8'/%3E%3Ccircle cx='10' cy='25.5' r='1.3' fill='%23FFE566'/%3E%3Ccircle cx='22' cy='25.5' r='1.3' fill='%23FFE566'/%3E%3Ccircle cx='34' cy='25.5' r='1.3' fill='%23FFE566'/%3E%3C/svg%3E");
    background-size:contain;background-repeat:no-repeat;background-position:center;
    filter:drop-shadow(0 1px 3px rgba(184,134,11,.8));
    pointer-events:none;z-index:400;
}
/* Avatar circle trong user-avatar-container (sidebar/drawer) */
.avatar-circle.admin-avatar{
    position:relative;
    border:2.5px solid #FFD700!important;
}
.avatar-circle.admin-avatar::before{
    content:'';
    position:absolute;
    top:-24px;left:50%;
    transform:translateX(-50%);
    width:32px;height:22px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 44 30'%3E %3Cpath d='M3,26 L5,11 L14,20 L22,3 L30,20 L39,11 L41,26 Z' fill='%23B8860B' stroke='%237A5700' stroke-width='1.2' stroke-linejoin='round'/%3E %3Cpath d='M3,26 L5,11 L14,20 L22,3 L30,20 L39,11 L41,20 L3,20 Z' fill='%23FFD700' opacity='0.45'/%3E %3Cpath d='M6,13 L14,20 L22,5 L30,20 L38,13 L37,16 L30,17.5 L22,8 L14,17.5 L7,16 Z' fill='%23FFEE88' opacity='0.45'/%3E %3Crect x='3' y='23' width='38' height='5' rx='2' fill='%23B8860B' stroke='%237A5700' stroke-width='1'/%3E %3Crect x='4' y='23.5' width='36' height='2' rx='1' fill='%23FFD700' opacity='0.55'/%3E %3Ccircle cx='22' cy='5.5' r='3.2' fill='%23FF1E4E' stroke='%23AA0030' stroke-width='0.8'/%3E %3Cellipse cx='21' cy='4.5' rx='1.2' ry='0.9' fill='rgba(255,255,255,0.55)'/%3E %3Ccircle cx='13.5' cy='20.5' r='2.6' fill='%231E8FFF' stroke='%230050BB' stroke-width='0.8'/%3E %3Cellipse cx='12.8' cy='19.7' rx='1' ry='0.75' fill='rgba(255,255,255,0.5)'/%3E %3Ccircle cx='30.5' cy='20.5' r='2.6' fill='%2320D060' stroke='%23007830' stroke-width='0.8'/%3E %3Cellipse cx='29.8' cy='19.7' rx='1' ry='0.75' fill='rgba(255,255,255,0.5)'/%3E %3Ccircle cx='10' cy='25.5' r='1.3' fill='%23FFE566'/%3E %3Ccircle cx='22' cy='25.5' r='1.3' fill='%23FFE566'/%3E %3Ccircle cx='34' cy='25.5' r='1.3' fill='%23FFE566'/%3E%3C/svg%3E");
    background-size:contain;
    background-repeat:no-repeat;
    background-position:center;
    filter:drop-shadow(0 0 5px rgba(255,215,0,.95)) drop-shadow(0 0 10px rgba(255,160,0,.6));
    z-index:20;pointer-events:none;
}

/* Badge ADMIN dưới rank text — đặc biệt hơn */
.admin-rank{
    color:#9C27B0!important;font-weight:700!important;
    background:linear-gradient(135deg,rgba(212,175,55,.18),rgba(156,39,176,.18))!important;
    border:1px solid rgba(212,175,55,.45)!important;
    border-radius:4px!important;padding:1px 6px!important;
    font-size:11px!important;letter-spacing:.5px!important;
    box-shadow:0 0 6px rgba(212,175,55,.25)!important;
    text-shadow:0 0 8px rgba(212,175,55,.6)!important;
}

/* Drawer avatar khi admin */
.admin-avatar #drawerAvatar,
#drawerAvatar.admin-avatar{
    border:2px solid rgba(255,215,0,.7)!important;
    box-shadow:0 0 10px rgba(255,215,0,.4)!important;
}

/* light-mode class (từ script.js toggleTheme) — không thay đổi gì vì CSS đã trắng */
.light-mode #matrix-canvas,.light-mode #snow-canvas{opacity:0!important;}

/* Drawer items màu đặc biệt */
.drawer-item-gold{color:#8B6914!important;}
.drawer-item-gold i{color:var(--brand-gold)!important;}
.drawer-item-gold:hover,.drawer-item-gold:active{background:#FFF8E1!important;}
.drawer-item-pink{color:#880E4F!important;}
.drawer-item-pink i{color:var(--pink)!important;}
.drawer-item-pink:hover,.drawer-item-pink:active{background:var(--pinkl)!important;}

/* ═══════════════════════════════════════
/* ═══════════════════════════════════════
   FEATURED (NỔI BẬT) REVIEW
═══════════════════════════════════════ */
.review-featured{
    border:1.5px solid rgba(255,193,7,.45)!important;
    background:linear-gradient(135deg,#FFFDE7,#FFF8E1)!important;
    box-shadow:0 3px 12px rgba(255,193,7,.18)!important;
    position:relative;
}
.review-featured-badge{
    display:inline-flex;align-items:center;gap:5px;
    background:linear-gradient(135deg,#FF6F00,#FFA000);color:#fff;
    font-size:10px;font-weight:700;padding:3px 10px;border-radius:0 0 10px 0;
    position:absolute;top:0;left:0;
    box-shadow:0 2px 6px rgba(255,111,0,.35);
}

/* ═══════════════════════════════════════
   NÚT XEM THÊM
═══════════════════════════════════════ */
.see-more-reviews-btn{
    width:100%;padding:12px;margin:4px 0 8px;
    background:var(--wh);border:1.5px solid var(--bd);border-radius:12px;
    color:var(--gr);font-size:12px;font-weight:700;cursor:pointer;
    font-family:'Roboto';display:flex;align-items:center;justify-content:center;gap:8px;
    transition:.15s;
}
.see-more-reviews-btn:active{background:var(--grl);border-color:var(--gr);}

/* ═══════════════════════════════════════
   ALL REVIEWS MODAL (bottom sheet)
═══════════════════════════════════════ */
.all-reviews-overlay{
    position:fixed;inset:0;background:rgba(0,0,0,.55);
    z-index:6500;display:none;flex-direction:column;
    justify-content:flex-end;backdrop-filter:blur(3px);
}
.all-reviews-overlay.active{display:flex;}
.all-reviews-sheet{
    background:var(--wh);border-radius:20px 20px 0 0;
    max-height:88vh;display:flex;flex-direction:column;
    box-shadow:0 -4px 24px rgba(0,0,0,.15);
}
.all-reviews-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 16px 12px;border-bottom:1px solid var(--bd);flex-shrink:0;
    /* drag handle */
    background:var(--wh);border-radius:20px 20px 0 0;
    position:sticky;top:0;z-index:200; /* phải cao hơn bất cứ thứ gì trong body */
}
.all-reviews-header::before{
    content:'';position:absolute;top:8px;left:50%;transform:translateX(-50%);
    width:36px;height:4px;background:var(--bd);border-radius:2px;
}
.all-reviews-title{
    font-family:'Orbitron',sans-serif;font-size:13px;font-weight:900;
    color:var(--t1);letter-spacing:.5px;
}
.all-reviews-close{
    width:32px;height:32px;background:var(--bg);border:1px solid var(--bd);
    border-radius:50%;display:flex;align-items:center;justify-content:center;
    cursor:pointer;font-size:14px;color:var(--t2);flex-shrink:0;
    position:relative;z-index:201;pointer-events:all;
    -webkit-tap-highlight-color:rgba(0,0,0,.1);
}
.all-reviews-body{
    flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px;
    isolation:isolate; /* chứa z-index của children, không cho đè lên header */
}

/* ═══════════════════════════════════════
   TOUCH RIPPLE + PARTICLE EFFECT
═══════════════════════════════════════ */
.touch-ripple{
    position:fixed;border-radius:50%;pointer-events:none;z-index:99999;
    transform:translate(-50%,-50%) scale(0);
    animation:touchRipple .5s ease-out forwards;
    background:radial-gradient(circle, rgba(255,255,255,0.45) 0%, rgba(255,255,255,0) 70%);
}
@keyframes touchRipple{
    0%  {transform:translate(-50%,-50%) scale(0);opacity:.8;}
    100%{transform:translate(-50%,-50%) scale(1);opacity:0;}
}
.touch-particle{
    position:fixed;border-radius:50%;pointer-events:none;z-index:99999;
    transform:translate(-50%,-50%);
    animation:touchParticle var(--dur,.55s) ease-out forwards;
}
@keyframes touchParticle{
    0%  {transform:translate(-50%,-50%) translate(0,0) scale(1);opacity:.9;}
    100%{transform:translate(-50%,-50%) translate(var(--tx),var(--ty)) scale(0);opacity:0;}
}

/* ═══════════════════════════════════════════════════════════════
   POPUP ADS — Index Page (dark theme, đồng bộ với hackfree)
   ═══════════════════════════════════════════════════════════════ */
.popup-ads-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    background: rgba(0, 0, 0, 0.72);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s ease, visibility 0.25s ease;
}
.popup-ads-overlay.active {
    opacity: 1;
    visibility: visible;
}
.popup-ads-box {
    position: relative;
    width: 100%;
    max-width: 420px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    background: #1a1a2e;
    border: 1px solid rgba(255, 110, 180, 0.25);
    border-radius: 18px;
    box-shadow: 0 8px 40px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.04);
    overflow: hidden;
    animation: popupAdIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
@keyframes popupAdIn {
    from { transform: scale(0.88) translateY(20px); opacity: 0; }
    to   { transform: scale(1) translateY(0);        opacity: 1; }
}
.popup-ad-close-btn {
    position: absolute;
    top: -14px;
    right: -14px;
    z-index: 10;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: none;
    background: #fff;
    color: #222;
    font-size: 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 12px rgba(0,0,0,0.4);
    transition: transform 0.18s, box-shadow 0.18s;
}
.popup-ad-close-btn:hover  { transform: scale(1.1);  box-shadow: 0 4px 18px rgba(0,0,0,0.5); }
.popup-ad-close-btn:active { transform: scale(0.93); }
.popup-ad-close-btn:disabled {
    background: #333;
    color: #fff;
    cursor: default;
    font-size: 13px;
    font-weight: 700;
}
.popup-ad-content {
    flex: 1;
    overflow-y: auto;
    padding: 20px 16px 12px;
    -webkit-overflow-scrolling: touch;
}
.popup-ad-content img.popup-ad-img,
.popup-ad-content video {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
    border-radius: 10px;
}
.popup-ad-content .popup-ad-text {
    font-size: 14px;
    color: #e0e0e0;
    margin-top: 12px;
    text-align: center;
    line-height: 1.6;
}
.popup-ad-footer {
    padding: 10px 16px 14px;
    border-top: 1px solid rgba(255,255,255,0.08);
    background: rgba(0,0,0,0.25);
}
.popup-ad-hide-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #aaa;
    cursor: pointer;
    user-select: none;
}
.popup-hide-checkbox {
    width: 15px;
    height: 15px;
    cursor: pointer;
    accent-color: var(--neon-pink, #ff6eb4);
    flex-shrink: 0;
}
