:root {
  --bg: #f6f7fb;
  --panel: #ffffff;
  --text: #18212f;
  --muted: #697586;
  --brand: #1664ff;
  --brand-dark: #0d47bf;
  --green: #0f9d58;
  --red: #d93025;
  --border: #e4e7ec;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:var(--brand)}
.container{max-width:1320px;margin:0 auto;padding:20px}
.topbar{background:#0f172a;color:#fff}
.topbar .container{display:flex;justify-content:space-between;align-items:center;padding:14px 20px}
.nav-links{display:flex;gap:14px;flex-wrap:wrap}
.card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:20px;box-shadow:0 6px 20px rgba(16,24,40,.05)}
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:12px;background:var(--brand);color:#fff;padding:12px 18px;font-weight:700;cursor:pointer}
.btn:hover{background:var(--brand-dark)}
.btn.secondary{background:#eef4ff;color:#1246b5}
.btn.danger{background:var(--red)}
.btn.ghost{background:#fff;color:var(--text);border:1px solid var(--border)}
form.inline{display:inline}
input,select,textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:#fff}
label{display:block;margin-bottom:8px;font-weight:700}
.field{margin-bottom:14px}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{padding:12px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
th{font-size:13px;color:var(--muted);font-weight:700}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700}
.badge.green{background:#e8f7ef;color:#0f9d58}
.badge.blue{background:#e8f0ff;color:#1246b5}
.badge.gray{background:#f0f2f5;color:#475467}
.badge.red{background:#ffe9e8;color:#d93025}
.flash{padding:12px 14px;border-radius:12px;margin-bottom:16px}
.flash.success{background:#e8f7ef;color:#0f9d58}
.flash.error{background:#ffe9e8;color:#d93025}
.hero{padding:50px 0}
.hero h1{font-size:40px;margin:0 0 12px}
.hero p{color:var(--muted);font-size:18px;max-width:760px}
.kpi{font-size:30px;font-weight:800;margin-top:4px}
.muted{color:var(--muted)}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.wheel-shell{display:flex;flex-direction:column;align-items:center;gap:24px}
.wheel{width:300px;height:300px;border-radius:50%;border:10px solid #102a56;position:relative;background:conic-gradient(#eff6ff 0 45deg,#dbeafe 45deg 90deg,#eff6ff 90deg 135deg,#dbeafe 135deg 180deg,#eff6ff 180deg 225deg,#dbeafe 225deg 270deg,#eff6ff 270deg 315deg,#dbeafe 315deg 360deg);box-shadow:0 12px 40px rgba(16,24,40,.12);transition:transform 3s cubic-bezier(.2,.9,.2,1)}
.wheel::after{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:#0f172a}
.pointer{width:0;height:0;border-left:18px solid transparent;border-right:18px solid transparent;border-bottom:34px solid #ef4444;position:absolute;top:-18px;left:50%;transform:translateX(-50%)}
.segment-label{position:absolute;left:50%;top:50%;transform-origin:0 0;font-size:11px;font-weight:700;color:#102a56}
.center{text-align:center}
.qr-img{width:240px;height:240px;border:1px solid var(--border);border-radius:16px;background:#fff;padding:8px}
.footer-note{font-size:13px;color:var(--muted);margin-top:12px}
@media (max-width:768px){.hero h1{font-size:30px}.container{padding:16px}.wheel{width:260px;height:260px}}


.slot-page{padding:10px 0 24px}
.slot-header h1{margin:8px 0 10px;font-size:36px}
.slot-kicker{display:inline-block;background:#fff0d6;color:#8b3a04;border:1px solid #ffd08a;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.slot-layout{display:grid;grid-template-columns:300px 1fr;gap:24px;align-items:start;max-width:1080px;margin:0 auto}
.slot-prize-panel{background:linear-gradient(180deg,#c91b1b 0%,#dd3522 100%);color:#fff;border:3px solid #ffd38a;box-shadow:0 16px 36px rgba(164,18,18,.26)}
.slot-prize-title{font-size:20px;font-weight:800;margin-bottom:14px;padding:10px 12px;border-radius:14px;background:rgba(59,10,10,.25);text-align:center}
.slot-prize-items{display:flex;flex-direction:column;gap:12px}
.slot-prize-item{display:flex;gap:12px;align-items:center;padding:12px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14)}
.slot-prize-icon{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#fff1db;color:#9d3a00;font-size:28px;box-shadow:inset 0 0 0 2px rgba(255,155,71,.18)}
.slot-prize-name{font-weight:800;font-size:16px;line-height:1.2}
.slot-prize-type{font-size:12px;color:#ffe7bf;margin-top:4px}
.slot-machine-shell{background:radial-gradient(circle at top,#ff7c48 0%,#eb4a24 42%,#c81e13 100%);border:3px solid #ffbf76;box-shadow:0 18px 44px rgba(164,18,18,.28);padding:18px 18px 22px}
.slot-machine-top{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;padding:14px 18px;border-radius:20px;background:linear-gradient(180deg,#ffb46a 0%,#ff7a49 100%);border:2px solid #ffdca8}
.slot-machine-marquee{flex:1;background:#6d0f0f;color:#ffe58c;border-radius:12px;padding:12px 16px;font-size:22px;font-weight:800;letter-spacing:.03em;box-shadow:inset 0 0 0 2px rgba(255,210,127,.22)}
.slot-machine-wave{min-width:80px;text-align:center;font-size:30px;color:#fff1c3;font-weight:800}
.slot-machine-body{padding:10px 10px 6px}
.slot-window-frame{position:relative;padding:18px;border-radius:24px;background:linear-gradient(180deg,#ffcb79 0%,#ff8c51 100%);border:4px solid #ffe0b0;box-shadow:inset 0 0 0 3px rgba(247,126,42,.35)}
.slot-window-glow{position:absolute;inset:12px;border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,.28),rgba(255,255,255,0));pointer-events:none}
.slot-reels{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;position:relative;z-index:1}
.slot-reel{min-height:220px;border-radius:18px;background:#fff3d4;border:3px solid #f26628;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 2px rgba(255,184,106,.7)}
.slot-symbol-card{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px;text-align:center;gap:10px;background:linear-gradient(180deg,#fffef8 0%,#ffe7b5 100%);border-radius:14px}
.slot-symbol-emoji{font-size:58px;line-height:1}
.slot-symbol-text{font-size:24px;font-weight:800;color:#9a2508;line-height:1.15;word-break:break-word}
.slot-payline{position:absolute;left:22px;right:22px;top:50%;height:4px;background:linear-gradient(90deg,rgba(255,54,54,.05),#ff3d2e,rgba(255,54,54,.05));transform:translateY(-50%);border-radius:999px;box-shadow:0 0 18px rgba(255,61,46,.6)}
.slot-controls{margin-top:16px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.slot-spin-btn{background:linear-gradient(180deg,#ffd45d 0%,#ff9a1f 100%);color:#7e2400;border:2px solid #ffe8aa;box-shadow:0 8px 0 #d96b14;font-size:18px;padding:14px 26px}
.slot-spin-btn:hover{background:linear-gradient(180deg,#ffdf81 0%,#ffa72e 100%)}
.slot-spin-btn:disabled{opacity:.8;cursor:not-allowed}
.slot-result-box{margin-top:18px;padding:18px;border-radius:20px;background:rgba(95,12,12,.24);border:1px solid rgba(255,233,179,.34);text-align:center;color:#fff}
.slot-result-title{font-size:24px;font-weight:800}
.slot-result-text{margin:8px 0 16px;font-size:18px;color:#fff2c9}
@media (max-width:900px){.slot-layout{grid-template-columns:1fr}.slot-prize-panel{order:2}.slot-machine-shell{order:1}}
@media (max-width:640px){.slot-header h1{font-size:28px}.slot-machine-marquee{font-size:18px}.slot-reel{min-height:150px}.slot-symbol-emoji{font-size:38px}.slot-symbol-text{font-size:16px}}

.slot-reel{display:flex;align-items:center;justify-content:center;overflow:hidden}
.slot-symbol-card{transform:none;transition:opacity .12s ease, filter .12s ease;background:linear-gradient(180deg,#fffef8 0%,#ffe7b5 100%)}
.slot-card-spinning{opacity:.88;filter:blur(.6px)}
.slot-stop-pop{animation:slotPop .22s ease}
@keyframes slotPop{0%{opacity:.75}100%{opacity:1}}
.win-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:9999}
.win-modal.show{display:flex}
.win-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.58);backdrop-filter:blur(2px)}
.win-modal-card{position:relative;z-index:1;width:min(92vw,460px);border-radius:28px;padding:28px 24px;background:linear-gradient(180deg,#fff7e8 0%,#ffe3b4 100%);border:3px solid #ffd78c;box-shadow:0 24px 60px rgba(0,0,0,.28);text-align:center}
.win-modal-kicker{display:inline-block;padding:6px 12px;border-radius:999px;background:#fff0cf;color:#9b5300;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.win-modal-title{font-size:32px;font-weight:900;color:#93200b;margin-top:14px}
.win-modal-prize{margin-top:12px;font-size:28px;font-weight:900;color:#c33811;line-height:1.2}
.win-modal-sub{margin-top:10px;color:#7a3d18;font-size:15px}
.win-modal-actions{margin-top:22px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}


.slot-result-box.theme-gold,.win-modal-card.theme-gold{background:linear-gradient(180deg,#fff7d8 0%,#ffd978 100%);color:#7c3a00;border:1px solid rgba(255,205,96,.8)}
.slot-result-box.theme-blue,.win-modal-card.theme-blue{background:linear-gradient(180deg,#eef7ff 0%,#9fd2ff 100%);color:#093b74;border:1px solid rgba(111,187,255,.8)}
.slot-result-box.theme-red,.win-modal-card.theme-red{background:linear-gradient(180deg,#fff0ef 0%,#ffb39a 100%);color:#7d1f0d;border:1px solid rgba(255,142,115,.8)}
.slot-result-box.theme-purple,.win-modal-card.theme-purple{background:linear-gradient(180deg,#f6efff 0%,#cfa7ff 100%);color:#4f1e8a;border:1px solid rgba(184,132,255,.8)}
.slot-result-box.theme-gold .slot-result-text,.slot-result-box.theme-blue .slot-result-text,.slot-result-box.theme-red .slot-result-text,.slot-result-box.theme-purple .slot-result-text{color:inherit}
.win-modal-card{overflow:hidden;animation:modalPop .28s ease}
.win-modal-badge{width:86px;height:86px;border-radius:999px;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-size:42px;background:rgba(255,255,255,.42);box-shadow:0 10px 30px rgba(0,0,0,.08)}
.win-modal-card.theme-gold .win-modal-title,.win-modal-card.theme-gold .win-modal-prize{color:#8c4700}
.win-modal-card.theme-blue .win-modal-title,.win-modal-card.theme-blue .win-modal-prize{color:#0b4f8a}
.win-modal-card.theme-red .win-modal-title,.win-modal-card.theme-red .win-modal-prize{color:#9b220d}
.win-modal-card.theme-purple .win-modal-title,.win-modal-card.theme-purple .win-modal-prize{color:#5d1ea8}
.win-modal-confetti{position:absolute;inset:0;pointer-events:none;overflow:hidden;border-radius:28px}
.confetti-piece{position:absolute;top:-10px;width:10px;height:18px;opacity:.92;border-radius:2px;animation:confettiFall 1.6s ease-in forwards}
@keyframes confettiFall{0%{transform:translateY(-10px) rotate(0deg);opacity:1}100%{transform:translateY(380px) rotate(520deg);opacity:0}}
@keyframes modalPop{0%{transform:scale(.86);opacity:.2}100%{transform:scale(1);opacity:1}}

.slot-machine-shell{position:relative;overflow:hidden}
.slot-bulb-row{display:flex;justify-content:space-between;gap:8px;padding:0 6px}
.slot-bulb-row.top{margin-bottom:10px}
.slot-bulb-row.bottom{margin-top:14px}
.slot-bulb{width:14px;height:14px;border-radius:999px;background:#ffe58c;box-shadow:0 0 10px rgba(255,234,154,.8),0 0 18px rgba(255,179,71,.65);animation:bulbPulse 1.1s ease-in-out infinite alternate}
.slot-bulb:nth-child(2n){animation-delay:.15s}
.slot-bulb:nth-child(3n){animation-delay:.3s}
@keyframes bulbPulse{from{transform:scale(.92);opacity:.85}to{transform:scale(1.12);opacity:1}}
.slot-machine-footer{display:flex;justify-content:space-between;align-items:center;margin-top:18px;padding:10px 18px 0}
.slot-machine-coin{width:44px;height:64px;border-radius:18px;background:linear-gradient(180deg,#73300f,#492008);border:3px solid #ffb663;box-shadow:inset 0 0 0 3px rgba(255,214,138,.18)}
.slot-machine-speaker{flex:1;max-width:180px;height:48px;border-radius:18px;background:rgba(112,12,12,.26);border:2px solid rgba(255,212,136,.26);position:relative;margin-left:18px}
.slot-machine-speaker::before{content:'';position:absolute;inset:10px;background:repeating-linear-gradient(90deg,rgba(255,170,98,.75) 0 6px, transparent 6px 12px)}

.reward-page-wrap{max-width:1120px;margin:0 auto;padding:10px 0 30px}
.reward-top-banner h1{margin:8px 0 10px;font-size:36px}
.reward-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start}
.reward-hero-card{position:relative;overflow:hidden;border-width:2px;padding:28px}
.reward-glow{position:absolute;inset:-20% auto auto -20%;width:280px;height:280px;background:radial-gradient(circle,rgba(255,255,255,.32) 0%,rgba(255,255,255,0) 70%)}
.reward-badge{position:relative;z-index:1;width:88px;height:88px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:44px;background:rgba(255,255,255,.55);box-shadow:0 12px 30px rgba(0,0,0,.08);margin:0 auto 12px}
.reward-title{text-align:center;font-size:34px;font-weight:900;margin-top:4px}
.reward-prize-name{text-align:center;font-size:42px;font-weight:900;line-height:1.2;margin-top:8px}
.reward-desc{text-align:center;max-width:700px;margin:12px auto 18px;font-size:16px;opacity:.92}
.reward-poster-card{position:relative;background:linear-gradient(180deg,#6f0e10 0%,#d13722 100%);border-radius:28px;border:3px solid #ffcf81;overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.18);max-width:760px;margin:0 auto}
.reward-poster-head{text-align:center;padding:16px 18px;background:linear-gradient(180deg,#ffbc73,#ff7f48);font-size:22px;font-weight:900;color:#772800;letter-spacing:.08em}
.reward-poster-body{padding:28px 26px;text-align:center;color:#fff}
.reward-poster-kicker{font-size:14px;font-weight:800;letter-spacing:.18em;color:#ffd28b}
.reward-poster-prize{font-size:42px;font-weight:900;line-height:1.2;margin:14px 0}
.reward-poster-type{display:inline-block;padding:8px 16px;border-radius:999px;background:#ffe3ab;color:#873200;font-size:14px;font-weight:800}
.reward-poster-box{margin:22px auto 8px;max-width:360px;min-height:240px;border-radius:24px;background:#fff4d9;color:#7a2f00;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px;font-size:28px;font-weight:900;border:3px solid #ffc56f}
.reward-qr{width:200px;height:200px;border-radius:16px;background:#fff;padding:8px;border:1px solid #eadbb3}
.reward-qr-label{font-size:15px;font-weight:700;margin-top:12px;color:#7a3c09}
.reward-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;max-width:760px;margin:18px auto 0}
.secondary-actions{margin-top:12px}
.reward-side-title{font-size:22px;font-weight:900;margin-bottom:14px}
.reward-tip-list{display:flex;flex-direction:column;gap:12px}
.reward-tip-item{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;border-radius:16px;background:#fff7e8;border:1px solid #ffe0a8}
.reward-tip-item span{width:34px;height:34px;flex:none;border-radius:999px;background:#ffb24d;color:#7c2f00;display:flex;align-items:center;justify-content:center;font-weight:900}
.reward-qr-big-wrap{margin-top:18px;padding:16px;border-radius:18px;background:#fff8e6;border:1px solid #ffdfab;text-align:center}
.reward-qr-big{width:240px;height:240px;border-radius:20px;background:#fff;padding:12px;border:1px solid #eedcb2}
@media (max-width:900px){.reward-layout{grid-template-columns:1fr}.reward-side{order:2}.reward-action-grid{grid-template-columns:1fr}}
@media print{.topbar,.reward-side,.secondary-actions{display:none!important}.reward-layout{display:block}.reward-page-wrap{max-width:none;padding:0}.reward-hero-card{box-shadow:none;border:none}}

.arcade-flow-page{max-width:980px;margin:0 auto;padding:10px 0 28px}
.arcade-theme-shell{background:radial-gradient(circle at top,#ff7c48 0%,#eb4a24 42%,#c81e13 100%);border:3px solid #ffbf76;box-shadow:0 18px 44px rgba(164,18,18,.28);position:relative;overflow:hidden;color:#fff}
.arcade-theme-shell.light-panel{background:linear-gradient(180deg,#fff6e4 0%,#ffe4b6 100%);color:#7a3206;border-color:#ffd38a}
.arcade-flow-card{padding:0}
.arcade-flow-inner{padding:28px 26px 30px}
.arcade-title{font-size:38px;font-weight:900;margin:10px 0 8px}
.arcade-subtitle{font-size:16px;color:#fff0d4;max-width:720px;margin:0 auto 12px;line-height:1.6}
.arcade-note{color:#ffe2b3}
.arcade-lights{display:flex;justify-content:space-between;gap:8px;padding:14px 16px 0}
.arcade-lights.bottom{padding:0 16px 14px}
.arcade-lights span{width:14px;height:14px;border-radius:999px;background:#ffe58c;box-shadow:0 0 10px rgba(255,234,154,.8),0 0 18px rgba(255,179,71,.65);animation:bulbPulse 1.1s ease-in-out infinite alternate}
.arcade-lights span:nth-child(2n){animation-delay:.15s}.arcade-lights span:nth-child(3n){animation-delay:.3s}
.arcade-info-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;max-width:680px;margin:18px auto 20px}
.arcade-info-strip>div{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.12);border:1px solid rgba(255,242,200,.28)}
.arcade-info-strip strong{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#ffdca8;margin-bottom:6px}
.arcade-info-strip span{font-size:18px;font-weight:800;color:#fff}
.arcade-reward-preview{max-width:680px;margin:0 auto 20px;padding:20px;border-radius:24px;background:rgba(92,13,13,.26);border:1px solid rgba(255,233,179,.28)}
.arcade-preview-badge{width:88px;height:88px;margin:0 auto 14px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:42px;background:rgba(255,255,255,.2);box-shadow:0 10px 24px rgba(0,0,0,.12)}
.arcade-preview-title{font-size:24px;font-weight:900;color:#fff}
.arcade-preview-text{margin-top:10px;font-size:15px;line-height:1.6;color:#ffe9c4}
.arcade-button-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:18px}.arcade-button-row.compact{margin-top:10px}
.verify-shell .arcade-flow-inner,.fail-shell .arcade-flow-inner{max-width:720px;margin:0 auto}
.arcade-form-card{margin:20px auto 0;max-width:560px;padding:22px;border-radius:24px;background:rgba(255,245,224,.96);color:#7a3206;border:2px solid #ffd490;box-shadow:0 14px 30px rgba(0,0,0,.12)}
.arcade-form-card label{color:#7a3206}.arcade-form-card input{border-color:#f0c778;background:#fffaf0}
.verify-prize-chip{display:flex;align-items:center;gap:14px;max-width:560px;margin:18px auto 0;padding:16px 18px;border-radius:22px}
.verify-prize-chip.theme-red{background:linear-gradient(180deg,#fff0ef 0%,#ffb39a 100%);color:#7d1f0d;border:1px solid rgba(255,142,115,.8)}
.verify-prize-chip.theme-gold{background:linear-gradient(180deg,#fff7d8 0%,#ffd978 100%);color:#8c4700;border:1px solid rgba(255,205,96,.8)}
.verify-prize-icon{width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.45);font-size:30px;flex:none}
.verify-prize-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:800;opacity:.8}.verify-prize-name{font-size:22px;font-weight:900}
.verify-status{font-size:16px;color:#7a3206;margin-bottom:12px}
.fail-emoji{font-size:74px;margin:12px 0 6px}
.redeem-code-panel{max-width:760px;margin:8px auto 18px;padding:18px;border-radius:24px;background:#fff4da;border:2px solid #ffd388;color:#7a2c00;text-align:center}
.redeem-code-label{font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:900;color:#b35d09}.redeem-code-value{font-size:34px;font-weight:900;letter-spacing:.06em;margin-top:6px;word-break:break-word}
.reward-poster-code-label{margin-top:14px;font-size:12px;letter-spacing:.12em;font-weight:900;color:#ffd28b}
.reward-poster-code{margin:10px auto 0;display:inline-block;padding:12px 18px;border-radius:16px;background:#fff6de;color:#7d2b00;font-size:28px;font-weight:900;border:2px solid #ffd07c}
.unified-claim-layout .reward-side{padding:22px}
@media (max-width:768px){.arcade-title{font-size:30px}.arcade-info-strip{grid-template-columns:1fr}.redeem-code-value{font-size:26px}.reward-poster-code{font-size:22px}.arcade-subtitle{font-size:15px}}

.claim-container{max-width:1180px;padding-top:10px}
.no-header-gap{padding-top:0}
.admin-prize-thumb{width:58px;height:58px;object-fit:cover;border-radius:10px;border:1px solid var(--border);background:#fff}
.admin-prize-preview{width:120px;height:120px;object-fit:cover;border-radius:14px;border:1px solid var(--border);background:#fff}
.slot-prize-type{display:none}
.slot-prize-icon.image-mode{width:64px;height:64px;border-radius:14px;padding:0;overflow:hidden;background:#fff2d0}
.slot-prize-icon.image-mode img{width:100%;height:100%;object-fit:cover;display:block}
.slot-reel{height:220px;min-height:220px;max-height:220px}
.slot-symbol-card{width:100%;height:100%;padding:16px 12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;transform:none!important}
.slot-symbol-image-wrap{width:118px;height:118px;border-radius:18px;background:#fff8e5;border:2px solid #ffd590;display:flex;align-items:center;justify-content:center;overflow:hidden;flex:none}
.slot-symbol-image-wrap.placeholder{background:#fff3d4}
.slot-symbol-image{width:100%;height:100%;object-fit:cover;display:block}
.slot-symbol-emoji{font-size:52px;line-height:1}
.slot-symbol-text{font-size:18px;line-height:1.2;min-height:44px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.slot-card-spinning,.slot-stop-pop{transform:none!important}
.big-focus-panel{max-width:760px}
.vertical-stack{flex-direction:column;align-items:center}
.vertical-stack .btn{width:100%;max-width:340px}
.cta-claim-link{font-size:18px;font-weight:900;box-shadow:0 12px 26px rgba(255,122,35,.28)}
.single-column-reward{grid-template-columns:1fr}
.single-column-reward .reward-hero-card{max-width:900px;margin:0 auto}
.single-row-actions{max-width:760px}
@media (max-width:768px){.slot-reel{height:170px;min-height:170px;max-height:170px}.slot-symbol-image-wrap{width:90px;height:90px}.slot-symbol-text{font-size:15px;min-height:36px}}

.charity-page-shell{padding:12px 0 28px;max-width:1240px;margin:0 auto}
.charity-theme-shell{background:linear-gradient(180deg,#7b0f13 0%,#b71818 52%,#d73e28 100%);border:3px solid #ffd184;box-shadow:0 18px 44px rgba(145,17,17,.26);padding:20px 22px 26px;color:#fff;overflow:hidden;position:relative}
.charity-marquee{overflow:hidden;border:2px solid rgba(255,214,142,.55);background:rgba(82,12,12,.45);border-radius:18px;padding:12px 0;margin-bottom:18px}
.charity-marquee-track{display:flex;gap:34px;white-space:nowrap;animation:charityScroll 24s linear infinite;font-weight:800;color:#ffe4af}
.charity-marquee-track span{padding-left:18px;position:relative}
.charity-marquee-track span::before{content:'•';position:absolute;left:0;top:0;color:#ffd57f}
@keyframes charityScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.charity-grid{display:grid;grid-template-columns:minmax(0,1.25fr) 400px;gap:24px;align-items:start}
.charity-story h1{font-size:42px;line-height:1.18;margin:10px 0 14px}
.charity-story p{font-size:17px;line-height:1.7;color:#ffe9cc;max-width:760px}
.charity-highlights{display:grid;gap:14px;margin-top:18px}
.charity-highlight{background:rgba(255,255,255,.1);border:1px solid rgba(255,228,180,.22);border-radius:18px;padding:16px 18px}
.charity-highlight strong{display:block;font-size:18px;color:#fff6dc;margin-bottom:6px}
.charity-highlight span{font-size:15px;color:#ffe8c7;line-height:1.6}
.charity-media-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:22px}
.charity-media-card{background:rgba(255,244,222,.96);color:#7a3206;border-radius:22px;padding:18px;border:2px solid #ffd797;min-height:220px}
.charity-media-title{font-size:18px;font-weight:900;margin-bottom:10px}
.charity-media-text{font-size:15px;line-height:1.7}
.charity-video-card{background:linear-gradient(180deg,#fff7e8 0%,#ffe3b4 100%)}
.charity-video-placeholder{display:flex;gap:14px;align-items:center;height:calc(100% - 28px);min-height:150px;padding:12px;border-radius:18px;background:#fff2d3;border:1px dashed #e9b867}
.charity-video-play{width:72px;height:72px;flex:none;border-radius:999px;background:#d13a1d;color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;box-shadow:0 10px 24px rgba(209,58,29,.22)}
.charity-video-placeholder p{margin:8px 0 0;font-size:14px;color:#7a3206;line-height:1.6}
.charity-login-wrap{display:flex;align-items:start;justify-content:center}
.charity-login-card{width:100%;background:linear-gradient(180deg,#fff8ea 0%,#ffe7bc 100%);color:#7a3206;border-radius:26px;padding:24px;border:3px solid #ffd58d;box-shadow:0 16px 36px rgba(0,0,0,.12);position:sticky;top:24px}
.charity-login-badge{display:inline-block;padding:7px 14px;border-radius:999px;background:#fff1d0;color:#9e5200;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.charity-login-card h2{font-size:34px;margin:14px 0 8px}
.charity-login-card p{font-size:15px;line-height:1.6;color:#8a4210}
.charity-login-card label{color:#7a3206}
.charity-login-card input{border-color:#f1c67a;background:#fffaf0}
.charity-login-btn{width:100%;font-size:18px;padding:14px 16px;border-radius:16px;background:linear-gradient(180deg,#ffbf55 0%,#ff8e28 100%);color:#7d2b00;box-shadow:0 8px 0 #d96b14}
.charity-login-note{margin-top:14px;font-size:13px;line-height:1.7;color:#8c4713;background:#fff5dc;border:1px solid #f2cf93;border-radius:16px;padding:12px 14px}
.charity-mini-stats{display:grid;gap:10px;margin-top:14px}
.charity-mini-stats>div{background:#fff4dd;border:1px solid #f3d49f;border-radius:16px;padding:12px 14px}
.charity-mini-stats strong{display:block;font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:#a25811;margin-bottom:5px}
.charity-mini-stats span{font-size:14px;color:#7a3206;line-height:1.5}
.simple-login-shell{padding:28px 0;max-width:620px;margin:0 auto}
.simple-login-card{max-width:440px;margin:20px auto}
@media (max-width:980px){.charity-grid{grid-template-columns:1fr}.charity-login-card{position:static}.charity-story h1{font-size:34px}}
@media (max-width:700px){.charity-media-grid{grid-template-columns:1fr}.charity-story h1{font-size:30px}.charity-theme-shell{padding:16px}}


.charity-grid-wide{grid-template-columns:minmax(0,1.35fr) 390px}
.charity-grid-claim{grid-template-columns:minmax(0,1.28fr) 360px}
.charity-landing-shell .charity-story h1{max-width:880px}
.charity-hero-visual{margin:22px 0 8px}
.card-lite{border-radius:24px;padding:20px;background:rgba(255,246,226,.96);border:2px solid #ffd58b;color:#7a3206;box-shadow:0 14px 28px rgba(0,0,0,.1)}
.charity-hero-illustration{min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center}
.charity-visual-phone,.claim-hero-phone{font-size:64px;line-height:1}
.charity-visual-arrow{font-size:30px;font-weight:900;color:#d3541d}
.charity-visual-qr{width:82px;height:82px;border-radius:18px;background:#fff;border:3px solid #d3541d;display:flex;align-items:center;justify-content:center;font-size:42px;font-weight:900}
.charity-visual-caption,.claim-hero-cardline{font-size:14px;line-height:1.6;color:#8b4714;max-width:520px}
.claim-hero-card{min-height:180px}
.charity-section-title{margin:24px 0 14px;font-size:24px;font-weight:900;color:#fff5dd;line-height:1.35}
.charity-benefit-grid{display:grid;gap:16px;margin-bottom:10px}
.charity-benefit-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.charity-benefit-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,231,185,.24);border-radius:22px;padding:18px}
.charity-benefit-icon{font-size:34px;line-height:1;margin-bottom:10px}
.charity-benefit-card strong{display:block;font-size:18px;color:#fff6e1;margin-bottom:8px}
.charity-benefit-card span{display:block;font-size:15px;line-height:1.65;color:#ffe8c7}
.charity-steps-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.charity-step-card{background:rgba(82,12,12,.34);border:1px solid rgba(255,229,189,.22);border-radius:22px;padding:20px;min-height:182px}
.charity-step-no{width:42px;height:42px;border-radius:999px;background:#ffd376;color:#8b4202;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;margin-bottom:14px}
.charity-step-card strong{display:block;font-size:18px;color:#fff4d8;margin-bottom:8px}
.charity-step-card span{display:block;font-size:15px;line-height:1.65;color:#ffe6bf}
.charity-emphasis-block{margin-top:22px;padding:22px;border-radius:24px;background:rgba(255,247,226,.12);border:1px solid rgba(255,223,170,.24)}
.charity-emphasis-block p{margin:0;color:#ffe7c1}
.charity-three-way{display:flex;align-items:center;justify-content:flex-start;gap:12px;flex-wrap:wrap;margin-top:16px;font-size:18px;font-weight:900;color:#fff6de}
.charity-three-way div{padding:12px 18px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,231,185,.28)}
.charity-three-way span{font-size:22px;color:#ffd78b}
.charity-warm-panel{margin-top:22px;padding:20px;border-radius:24px;background:linear-gradient(180deg,rgba(255,248,235,.96) 0%,rgba(255,233,191,.96) 100%);border:2px solid #ffd998;color:#7a3206}
.charity-warm-panel .charity-section-title{margin:0 0 10px;color:#8a3e00}
.charity-warm-panel p{margin:0;color:#7a3206}
.charity-button-row{display:flex;gap:12px;justify-content:flex-start;flex-wrap:wrap;margin-top:20px}
.claim-top-cta{margin-top:18px;margin-bottom:8px}
.trust-zone-grid{display:grid;gap:12px}
.trust-zone-grid div{padding:14px;border-radius:16px;background:#fff2d1;border:1px solid #f1ca84}
.trust-zone-grid strong{display:block;font-size:17px;color:#8b4202;margin-bottom:6px}
.trust-zone-grid span{display:block;font-size:14px;line-height:1.6;color:#7a3206}
.claim-side-wrap .charity-login-card{position:sticky;top:24px}
.claim-side-card .charity-mini-stats{margin-top:18px}
.charity-claim-cardline{margin:18px 0;padding:14px 16px;border-radius:18px;background:#fff2d0;border:1px solid #f1c775;font-size:15px;line-height:1.6;color:#7a3206}
.compact-note{margin-top:14px}
@media (max-width:1080px){.charity-grid-wide,.charity-grid-claim{grid-template-columns:1fr}.claim-side-wrap .charity-login-card,.charity-login-card{position:static}.charity-benefit-grid-3,.charity-steps-grid{grid-template-columns:1fr}}
@media (max-width:768px){.charity-section-title{font-size:20px}.charity-story h1{font-size:32px}.charity-button-row{justify-content:stretch}.charity-button-row .btn{width:100%}}

.floating-support{position:fixed;right:18px;z-index:9998;padding:12px 14px;border-radius:999px;color:#fff;font-weight:800;box-shadow:0 12px 24px rgba(0,0,0,.18)}
.floating-support.whatsapp{bottom:92px;background:#25D366}
.floating-support.telegram{bottom:28px;background:#229ED9}
.floating-support:hover{opacity:.95;color:#fff}


.floating-support-stack{position:fixed;right:20px;bottom:22px;display:flex;flex-direction:column;gap:14px;z-index:9999}
.floating-support{display:flex;align-items:center;gap:10px;min-width:160px;padding:10px 14px 10px 10px;border-radius:999px;color:#fff;font-weight:800;box-shadow:0 16px 28px rgba(15,23,42,.22);transition:transform .18s ease, box-shadow .18s ease;position:relative;overflow:hidden}
.floating-support:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 18px 30px rgba(15,23,42,.28);color:#fff}
.floating-support::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,255,255,0));pointer-events:none}
.floating-support.whatsapp{background:linear-gradient(180deg,#26d367 0%,#15a74a 100%)}
.floating-support.telegram{background:linear-gradient(180deg,#3ea7ff 0%,#1575d1 100%)}
.floating-support-icon{width:40px;height:40px;border-radius:999px;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:21px;line-height:1;flex:none;border:1px solid rgba(255,255,255,.25)}
.floating-support-label{font-size:15px;letter-spacing:.01em}
@media (max-width:768px){.floating-support-stack{right:14px;bottom:14px}.floating-support{min-width:auto;padding:10px}.floating-support-label{display:none}.floating-support-icon{width:44px;height:44px}}


.verify-form-card{display:flex;flex-direction:column;gap:14px}
.verify-rules-panel{margin:16px 0 18px;padding:18px;border-radius:22px;background:rgba(255,244,207,.12);border:1px solid rgba(255,223,122,.45);box-shadow:0 10px 28px rgba(0,0,0,.12)}
.verify-rules-title{font-size:15px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:#fff4cf;margin-bottom:12px}
.verify-rules-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.verify-rule-item{padding:14px 12px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:4px;text-align:center}
.verify-rule-item strong{font-size:22px;color:#fff7d6}
.verify-rule-item span{font-size:12px;color:#ffe2b3;line-height:1.45}
.verify-rules-footnote{margin-top:12px;font-size:13px;line-height:1.6;color:#ffdca1}
.verify-inline-alert{padding:14px 16px;border-radius:16px;margin:0 0 16px;font-size:14px;line-height:1.6;border:1px solid transparent}
.verify-inline-alert.warning{background:#fff4d6;color:#7c4a00;border-color:#ffd37b}
.verify-inline-alert.info{background:rgba(90,159,255,.16);color:#d7ebff;border-color:rgba(144,195,255,.38)}
.verify-helper-text{font-size:13px;line-height:1.6;color:#ffe2b3}
.verify-status-pill{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;font-size:14px;font-weight:800;margin-bottom:8px}
.verify-status-pill.success{background:#e8f7ef;color:#0f9d58}
.verify-divider{position:relative;text-align:center;margin:8px 0 2px}
.verify-divider span{position:relative;z-index:1;display:inline-block;padding:0 12px;background:linear-gradient(180deg,#5f0c0c 0%,#2a0202 100%);color:#ffe2b3;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.verify-divider:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:rgba(255,226,179,.28)}
.verify-change-phone-form{display:flex;flex-direction:column;gap:12px;width:100%}
.btn-secondary{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.22);box-shadow:none}
.btn-secondary:hover{background:rgba(255,255,255,.16)}
@media (max-width: 680px){.verify-rules-grid{grid-template-columns:1fr}.verify-rules-title{text-align:center}}


.app-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:1200;padding:20px}
.app-modal.show{display:flex}
.app-modal-backdrop{position:absolute;inset:0;background:radial-gradient(circle at top,rgba(255,255,255,.08),transparent 28%),rgba(15,23,42,.70);backdrop-filter:blur(4px)}
.app-modal-card{position:relative;width:min(92vw,440px);border-radius:28px;padding:28px 24px 22px;color:#fff;text-align:center;z-index:1;overflow:hidden;border:1px solid rgba(255,255,255,.10);box-shadow:0 30px 80px rgba(2,8,23,.55);animation:appModalPop .22s ease}
.app-modal-card::before{content:"";position:absolute;inset:-40% auto auto -10%;width:160px;height:160px;border-radius:999px;background:rgba(255,255,255,.15);filter:blur(10px);opacity:.55}
.app-modal-card::after{content:"";position:absolute;inset:auto -20% -24% auto;width:220px;height:220px;border-radius:999px;background:rgba(255,255,255,.08);filter:blur(20px)}
.app-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border:none;border-radius:999px;background:rgba(255,255,255,.10);color:#fff;font-size:24px;line-height:1;cursor:pointer;transition:transform .16s ease,background .16s ease}
.app-modal-close:hover{transform:scale(1.06);background:rgba(255,255,255,.18)}
.app-modal-icon{position:relative;width:78px;height:78px;border-radius:999px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:900;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);box-shadow:0 12px 30px rgba(0,0,0,.14);animation:appModalPulse 1.4s ease-in-out infinite}
.app-modal-title{font-size:26px;font-weight:900;margin-bottom:10px;letter-spacing:.01em}
.app-modal-message{font-size:16px;line-height:1.7;color:#eef4ff;margin-bottom:18px;white-space:pre-line}
.app-modal-actions{display:flex;justify-content:center}
.app-modal .btn{min-width:132px}
.app-modal[data-tone="success"] .app-modal-card{background:linear-gradient(180deg,#0f3e31 0%,#0a2a22 100%)}
.app-modal[data-tone="warning"] .app-modal-card{background:linear-gradient(180deg,#5f3b09 0%,#362005 100%)}
.app-modal[data-tone="error"] .app-modal-card{background:linear-gradient(180deg,#5d1518 0%,#310b0e 100%)}
.app-modal[data-tone="info"] .app-modal-card{background:linear-gradient(180deg,#102a54 0%,#0a1833 100%)}
.app-modal[data-tone="success"] .app-modal-icon{background:rgba(16,185,129,.20);color:#bbf7d0;border-color:rgba(52,211,153,.45)}
.app-modal[data-tone="warning"] .app-modal-icon{background:rgba(245,158,11,.18);color:#fde68a;border-color:rgba(245,158,11,.45)}
.app-modal[data-tone="error"] .app-modal-icon{background:rgba(239,68,68,.18);color:#fecaca;border-color:rgba(248,113,113,.45)}
.app-modal[data-tone="info"] .app-modal-icon{background:rgba(59,130,246,.20);color:#dbeafe;border-color:rgba(96,165,250,.45)}
@keyframes appModalPulse{0%,100%{transform:scale(1);box-shadow:0 12px 30px rgba(0,0,0,.14)}50%{transform:scale(1.06);box-shadow:0 16px 36px rgba(0,0,0,.20)}}
@keyframes appModalPop{0%{transform:translateY(8px) scale(.96);opacity:0}100%{transform:translateY(0) scale(1);opacity:1}}
.checkbox-grid label{display:flex;gap:10px;align-items:center;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fafbff;font-weight:600}
.checkbox-grid input[type="checkbox"]{width:auto;margin:0}
.break-all{word-break:break-all}
.qr-img-large{width:280px;height:280px}


.btn.disabled{pointer-events:none;opacity:.5;cursor:not-allowed;}
.break-all{word-break:break-all;}


.action-menu{position:relative;display:inline-block}
.action-menu summary{list-style:none;cursor:pointer;min-width:108px}
.action-menu summary::-webkit-details-marker{display:none}
.action-menu[open] .action-menu-list{display:flex}
.action-menu-list{display:none;position:absolute;right:0;top:calc(100% + 8px);min-width:180px;z-index:30;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 12px 32px rgba(16,24,40,.12);padding:8px}
.action-menu-item{display:block;width:100%;padding:10px 12px;border-radius:10px;color:var(--text);background:#fff;border:none;text-align:left;font-size:14px}
.action-menu-item:hover,.action-menu-button:hover{background:#f5f8ff;color:#1246b5}
.action-menu-button{cursor:pointer}
.single-row-actions{display:flex;justify-content:center;max-width:760px}
.centered-download-btn{min-width:260px}
@media (max-width:768px){.action-menu-list{right:auto;left:0}}


.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.break-all{word-break:break-all}
.inline-edit-row{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:center}
.admin-staff-table{table-layout:fixed}
.admin-staff-table th,.admin-staff-table td{font-size:13px;word-break:break-word}
.admin-staff-table th:nth-child(1){width:15%}
.admin-staff-table th:nth-child(2){width:12%}
.admin-staff-table th:nth-child(3){width:14%}
.admin-staff-table th:nth-child(4){width:10%}
.admin-staff-table th:nth-child(5){width:10%}
.admin-staff-table th:nth-child(6){width:13%}
.admin-staff-table th:nth-child(7){width:13%}
.admin-staff-table th:nth-child(8){width:13%}
.action-menu{position:relative}
.action-menu-list{position:absolute;right:0;top:calc(100% + 8px);min-width:180px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 12px 28px rgba(16,24,40,.12);padding:8px;z-index:30}
.action-menu-item{display:block;width:100%;padding:10px 12px;border-radius:10px;color:var(--text);background:#fff;border:none;text-align:left;cursor:pointer}
.action-menu-item:hover,.action-menu-button:hover{background:#f5f7fb}
.action-menu-button{font:inherit}
.page-modal{position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center;padding:24px}
.page-modal[hidden]{display:none !important}
.page-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.45)}
.page-modal-card{position:relative;z-index:1;width:min(720px,96vw);max-height:88vh;overflow:auto;background:#fff;border:1px solid var(--border);border-radius:22px;padding:22px;box-shadow:0 24px 60px rgba(16,24,40,.2)}
.page-modal-card-wide{width:min(980px,96vw)}
body.modal-open{overflow:hidden}
@media (max-width:900px){.inline-edit-row{grid-template-columns:1fr}.page-modal{padding:14px}.admin-staff-table{min-width:860px}}


.admin-staff-table-shell{position:relative;overflow:visible;min-height:280px}
.admin-staff-table-wrap{overflow-x:auto;overflow-y:visible;padding-bottom:140px}
.admin-staff-table{min-width:100%;table-layout:fixed}
.action-menu{position:relative;z-index:5}
.action-menu[open]{z-index:60}
.action-menu-list{max-height:none}
.page-head .actions{display:flex;gap:10px;flex-wrap:wrap}


.admin-staff-table-shell{position:relative;overflow:visible;min-height:360px;padding-bottom:0}
.admin-staff-table-wrap{overflow-x:auto;overflow-y:visible;padding-bottom:0}
.staff-action-inline{display:flex;align-items:center;gap:8px;min-width:130px}
.staff-action-select{width:130px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff;font-size:14px;color:var(--text)}
.staff-action-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.admin-staff-table th,.admin-staff-table td{vertical-align:middle}

/* ===== v12 promoter mobile-first dashboard ===== */
.staff-mobile-topbar{background:linear-gradient(135deg,#07152d 0%,#0b2244 100%);position:sticky;top:0;z-index:30}
.staff-mobile-topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}
.staff-mobile-brand{display:inline-flex;max-width:150px;font-weight:900;font-size:20px;line-height:1.05;color:#fff;text-decoration:none}
.staff-mobile-nav-links{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.staff-mobile-nav-links a{color:#fff;text-decoration:none;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.1);font-size:13px;font-weight:700}
.promoter-mobile-page{max-width:960px;margin:0 auto;padding:10px 0 26px}
.promoter-hero-card{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 20px 16px;border-radius:24px;background:linear-gradient(135deg,#0d1d3a 0%,#133464 100%);color:#fff;box-shadow:0 18px 36px rgba(9,30,66,.18)}
.promoter-hero-card h1{margin:6px 0 8px;font-size:34px;line-height:1.1}
.promoter-hero-card p{margin:0;max-width:520px;color:#d6e5ff;line-height:1.6;font-size:15px}
.promoter-eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:#9bc0ff;font-weight:800}
.promoter-hero-status{display:flex;align-items:center;justify-content:flex-end;min-width:110px}
.promoter-stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:16px}
.promoter-stat-card{border-radius:22px;padding:18px 18px 16px;box-shadow:0 10px 24px rgba(10,20,35,.06)}
.promoter-stat-card.primary{background:linear-gradient(180deg,#f7fbff 0%,#eef6ff 100%)}
.promoter-stat-card.bonus{background:linear-gradient(180deg,#fff9ed 0%,#fff2cf 100%)}
.promoter-stat-card.total{background:linear-gradient(180deg,#f7fff7 0%,#eaffef 100%)}
.promoter-main-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;margin-top:16px;align-items:start}
.promoter-card-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.promoter-card-head.compact{align-items:center}
.promoter-card-head h2{margin:4px 0 0;font-size:28px;line-height:1.15}.promoter-section-label{font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:800;color:#7c8aa5}
.promoter-status-line{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.promoter-qr-card,.promoter-bonus-card,.promoter-records-card{border-radius:24px;box-shadow:0 14px 36px rgba(15,23,42,.06)}
.promoter-qr-stage{display:flex;align-items:center;justify-content:center;min-height:310px;border-radius:26px;background:linear-gradient(180deg,#f9fbff 0%,#eef4ff 100%);border:1px dashed #c7d5ee;padding:18px}
.promoter-qr-stage.has-qr{background:linear-gradient(180deg,#fffdf8 0%,#fff7e8 100%);border:1px solid #f3dfab}
.promoter-qr-img{width:min(100%,320px);border-radius:20px;background:#fff;padding:12px;border:1px solid #ebdfc0;box-shadow:0 10px 24px rgba(0,0,0,.06)}
.promoter-qr-placeholder{width:100%;min-height:250px;border-radius:22px;display:flex;align-items:center;justify-content:center;text-align:center;padding:22px;background:#f7f9fc;color:#667085;font-size:16px;line-height:1.6}
.promoter-mode-chip{margin-top:14px;display:inline-flex;flex-wrap:wrap;gap:8px;padding:10px 14px;border-radius:999px;background:#eef4ff;color:#204a9c;font-weight:800}
.promoter-link-box{margin-top:12px;padding:12px 14px;border-radius:18px;background:#f7f8fb;border:1px solid #e4e8f0;font-size:13px;line-height:1.5;color:#4d5875}
.promoter-primary-actions,.promoter-secondary-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}.promoter-secondary-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
.promoter-action-btn{font-size:16px;font-weight:900;padding:14px 16px}.promoter-tip-text{margin-top:12px;font-size:13px;line-height:1.55}
.promoter-bonus-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;min-width:220px}.promoter-bonus-summary div{background:#f6f9ff;border:1px solid #e3ecff;border-radius:18px;padding:10px 12px;text-align:center}.promoter-bonus-summary strong{display:block;font-size:22px;color:#0f2e62}.promoter-bonus-summary span{display:block;margin-top:4px;font-size:12px;color:#6b7892}
.promoter-default-note{padding:12px 14px;border-radius:18px;background:#fff6e2;border:1px solid #ffe0a0;color:#8b5a00;font-size:14px;line-height:1.55;margin-bottom:14px}
.promoter-bonus-cards{display:grid;gap:14px}
.promoter-bonus-tier{border:1px solid #e8edf7;border-radius:22px;padding:16px;background:#fff}
.promoter-bonus-tier.claimable{border-color:#96c2ff;background:linear-gradient(180deg,#f7fbff 0%,#edf6ff 100%)}
.promoter-bonus-tier.claimed_pending_settlement{border-color:#ffd690;background:linear-gradient(180deg,#fff9ee 0%,#fff1d7 100%)}
.promoter-bonus-tier.settled{border-color:#bde8c8;background:linear-gradient(180deg,#f7fff8 0%,#eaf8ec 100%)}
.promoter-tier-top{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.promoter-tier-name{font-size:18px;font-weight:900;color:#10284a}.promoter-tier-target{margin-top:4px;font-size:14px;color:#667085}.promoter-tier-amount{font-size:26px;font-weight:900;color:#0b5b35}
.promoter-progress-row{display:flex;align-items:center;gap:12px;margin-top:14px}.promoter-progress-bar{flex:1;height:12px;border-radius:999px;background:#e9eef7;overflow:hidden}.promoter-progress-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#2d7dff 0%,#55b3ff 100%)}.promoter-progress-text{font-size:13px;font-weight:800;color:#42526e;min-width:74px;text-align:right}
.promoter-tier-helper{margin-top:10px;font-size:13px;color:#667085;line-height:1.55}.promoter-tier-actions{margin-top:14px}.promoter-tier-actions .btn{width:100%;font-weight:900}
.promoter-records-card{margin-top:16px}.promoter-record-list{display:grid;gap:12px}.promoter-record-item{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:14px 16px;border-radius:18px;background:#f8fafc;border:1px solid #e7edf5}.promoter-record-main strong{display:block;font-size:16px;color:#10284a}.promoter-record-main span{display:block;margin-top:4px;font-size:13px;color:#667085}.promoter-record-side{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.promoter-record-type{font-size:12px;font-weight:800;text-transform:uppercase;color:#6b7892}.promoter-record-settle{display:inline-flex;padding:6px 10px;border-radius:999px;background:#eef4ff;color:#2753a6;font-size:12px;font-weight:800}.promoter-record-settle.paid{background:#e8f8ed;color:#1e7a42}.promoter-record-settle.pending_redeem{background:#fff4dd;color:#b05f00}.promoter-record-settle.unpaid{background:#fff6e6;color:#9f6000}
.promoter-empty-state{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:18px;border-radius:18px;background:#f8fafc;border:1px dashed #ced7e6;color:#5f6b84}.promoter-empty-state.small{padding:16px}

.hidden{display:none !important}
.promoter-hero-status-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.promoter-live-sync{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12);color:#dce9ff;font-size:12px;font-weight:800;letter-spacing:.02em}
.promoter-live-sync.warning{background:rgba(255,214,102,.18);color:#fff1c2}
.promoter-claim-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border-radius:20px;background:linear-gradient(180deg,#f6fbff 0%,#eaf4ff 100%);border:1px solid #bdd7ff;margin-bottom:14px;box-shadow:0 10px 20px rgba(37,99,235,.08)}
.promoter-claim-banner strong{display:block;font-size:18px;color:#11356f}
.promoter-claim-banner span{display:block;margin-top:4px;font-size:13px;color:#58709a;line-height:1.45}
.promoter-bonus-tier.claimable{box-shadow:0 10px 24px rgba(45,125,255,.1)}
.promoter-bonus-tier.claimable .promoter-progress-bar span{background:linear-gradient(90deg,#1d6dff 0%,#2ec5ff 100%)}
.promoter-claim-btn{position:relative}
.promoter-claim-btn::after{content:"";position:absolute;inset:-4px;border-radius:18px;border:2px solid rgba(45,125,255,.22);animation:claimPulse 1.8s ease-out infinite}
@keyframes claimPulse{0%{transform:scale(.98);opacity:.9}70%{transform:scale(1.02);opacity:0}100%{transform:scale(1.02);opacity:0}}
@media (max-width: 768px){.promoter-hero-status-wrap{align-items:flex-start;width:100%}.promoter-live-sync{font-size:11px;padding:7px 11px}.promoter-claim-banner{flex-direction:column;align-items:flex-start}.promoter-claim-banner .btn{width:100%}}

@media (max-width: 960px){.promoter-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.promoter-main-grid{grid-template-columns:1fr}.promoter-bonus-summary{min-width:0}}
@media (max-width: 768px){.container{padding:0 14px}.staff-mobile-topbar-inner{padding:10px 0}.staff-mobile-brand{max-width:120px;font-size:18px}.staff-mobile-nav-links{gap:6px}.staff-mobile-nav-links a{padding:7px 10px;font-size:12px}.promoter-mobile-page{padding:8px 0 22px}.promoter-hero-card{padding:18px 16px 14px;border-radius:22px;flex-direction:column}.promoter-hero-card h1{font-size:30px}.promoter-stats-grid{grid-template-columns:1fr 1fr;gap:12px}.promoter-stat-card{padding:16px;border-radius:20px}.promoter-card-head h2{font-size:24px}.promoter-qr-stage{min-height:280px;padding:14px}.promoter-qr-img{width:min(100%,280px)}.promoter-mode-chip{display:flex;justify-content:center;width:100%;text-align:center;font-size:13px}.promoter-primary-actions,.promoter-secondary-actions{grid-template-columns:1fr 1fr;gap:10px}.promoter-secondary-actions .btn,.promoter-primary-actions .btn{font-size:15px;padding:13px 12px}.promoter-record-item{align-items:flex-start;flex-direction:column}.promoter-record-side{align-items:flex-start}}
@media (max-width: 480px){.promoter-stats-grid{grid-template-columns:1fr}.promoter-primary-actions,.promoter-secondary-actions{grid-template-columns:1fr}.promoter-bonus-summary{grid-template-columns:1fr 1fr}.floating-support-stack{right:14px;bottom:16px}.floating-support-label{display:none}}

/* ===== v14 mobile-first promoter sprint + claim pages ===== */
.promoter-sprint-card{padding:18px 18px 16px;border-radius:24px;background:linear-gradient(180deg,#fff8eb 0%,#fff 100%);border:1px solid #f7d48a;box-shadow:0 14px 30px rgba(15,23,42,.08)}
.promoter-sprint-chip{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:#e7efff;color:#1743a3;font-weight:800;font-size:12px;letter-spacing:.02em}
.promoter-sprint-chip.ready{background:#dcfce7;color:#0f8a44}
.promoter-sprint-chip.done{background:#ede9fe;color:#6d28d9}
.promoter-sprint-grid{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:stretch;margin-top:8px}
.promoter-sprint-main{display:flex;flex-direction:column;gap:8px}
.promoter-sprint-main-label{font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#6b7ba4}
.promoter-sprint-main-value{font-size:30px;line-height:1.05;font-weight:900;color:#0f2347}
.promoter-sprint-sub{color:#52627f;line-height:1.6;font-size:14px}
.promoter-sprint-progress-wrap{margin-top:4px;display:flex;flex-direction:column;gap:8px}
.promoter-sprint-progress{height:14px;border-radius:999px;background:#e6ecfb;overflow:hidden}
.promoter-sprint-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#1f6dff 0%,#5ea2ff 100%)}
.promoter-sprint-progress-meta{display:flex;justify-content:space-between;gap:12px;font-size:13px;color:#567}
.promoter-sprint-side{display:grid;grid-template-columns:1fr;gap:10px;min-width:116px}
.promoter-mini-stat{padding:14px 12px;border-radius:18px;background:#f4f7ff;border:1px solid #dfe8ff;text-align:center;display:flex;flex-direction:column;gap:4px}
.promoter-mini-stat strong{font-size:28px;line-height:1;color:#10234c}
.promoter-mini-stat span{font-size:12px;color:#66789c}
.promoter-mini-stat.highlight{background:#fff6dc;border-color:#f5d789}
.promoter-mini-stat.highlight strong{color:#9a5b00}
.promoter-sprint-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.promoter-bonus-tier.claimable{border-color:#8cb3ff;box-shadow:0 14px 26px rgba(31,109,255,.12)}
.promoter-bonus-tier.claimed_pending_settlement{background:linear-gradient(180deg,#fff8eb 0%,#fff 100%)}
.sprint-ready-btn{animation:bonusPulse 1.2s infinite}
@keyframes bonusPulse{0%{transform:scale(1);box-shadow:0 0 0 0 rgba(37,99,235,.28)}70%{transform:scale(1.02);box-shadow:0 0 0 12px rgba(37,99,235,0)}100%{transform:scale(1)}}
.promoter-mobile-page.v14-sprint-page{padding-bottom:120px}
.promoter-qr-card,.promoter-bonus-card,.promoter-records-card{scroll-margin-top:84px}
.promoter-qr-card{position:relative;overflow:hidden}
.promoter-qr-card::after{content:'';position:absolute;right:-50px;top:-60px;width:180px;height:180px;background:radial-gradient(circle,rgba(37,99,235,.08),rgba(37,99,235,0) 70%);pointer-events:none}
.promoter-record-item{border-radius:20px}
@media (max-width:768px){
  .promoter-sprint-card{padding:16px;border-radius:22px}
  .promoter-sprint-grid{grid-template-columns:1fr;gap:12px}
  .promoter-sprint-main-value{font-size:28px}
  .promoter-sprint-side{grid-template-columns:1fr 1fr;min-width:0}
  .promoter-sprint-actions{grid-template-columns:1fr}
  .promoter-hero-card{position:relative;overflow:hidden}
  .promoter-hero-card::after{content:'';position:absolute;right:-35px;top:-30px;width:120px;height:120px;border-radius:999px;background:rgba(255,255,255,.08)}
}
@media (max-width:480px){
  .promoter-sprint-main-value{font-size:24px}
  .promoter-mini-stat strong{font-size:24px}
  .promoter-mobile-page.v14-sprint-page{padding-bottom:130px}
}

.claim-mobile-shell{max-width:560px;margin:0 auto;padding:12px 0 28px;display:flex;flex-direction:column;gap:14px}
.claim-mobile-card{background:#fff;border:1px solid #e5e7ef;border-radius:24px;padding:18px 16px;box-shadow:0 14px 30px rgba(15,23,42,.06)}
.claim-mobile-hero{background:linear-gradient(180deg,#123565 0%,#0a2041 100%);color:#fff;border:none;box-shadow:0 20px 36px rgba(10,32,65,.22)}
.claim-mobile-hero.compact{padding-bottom:16px}
.claim-mobile-kicker{font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:#91b7ff;margin-bottom:10px}
.claim-mobile-hero h1{margin:0;font-size:34px;line-height:1.08;font-weight:900}
.claim-mobile-sub{margin:10px 0 0;color:#d9e6ff;line-height:1.6;font-size:15px}
.claim-mobile-promo-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.claim-mobile-promo-badges span{padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);font-size:12px;font-weight:700}
.claim-mobile-primary-btn{display:flex;justify-content:center;align-items:center;width:100%;min-height:52px;border-radius:16px;font-size:17px;font-weight:900;margin-top:14px}
.claim-mobile-secondary-cta{margin-top:10px}
.claim-mobile-card-title{font-size:14px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:#6b7ba4;margin-bottom:12px}
.claim-mobile-steps{display:grid;grid-template-columns:1fr;gap:10px}
.claim-mobile-step{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:18px;background:#f6f8ff;border:1px solid #e5ecff}
.claim-mobile-step strong{width:30px;height:30px;border-radius:999px;background:#1743a3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px}
.claim-mobile-step span{font-weight:700;color:#11254b}
.claim-mobile-info-list,.claim-mobile-benefits{display:grid;grid-template-columns:1fr;gap:10px}
.claim-mobile-info-list div,.claim-mobile-benefits div{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;background:#f8fafc;border:1px solid #ebeff7}
.claim-mobile-info-list span,.claim-mobile-benefits strong{color:#6b7ba4;font-size:13px}
.claim-mobile-info-list strong,.claim-mobile-benefits span{color:#10234c;text-align:right}
.claim-mobile-note{margin-top:12px;padding:12px 14px;border-radius:16px;background:#fff8eb;border:1px solid #f7d48a;color:#8a5a00;line-height:1.6}
.claim-mobile-bottom-cta{position:sticky;bottom:10px;z-index:30}
.claim-mobile-summary-card,.claim-mobile-info-card,.claim-mobile-benefit-card,.claim-mobile-form-card,.claim-mobile-code-card,.claim-mobile-poster-card{border-radius:22px}
.claim-mobile-prize-row{display:flex;align-items:center;gap:12px;padding:14px;border-radius:18px;background:#f4f7ff;border:1px solid #dee8ff}
.claim-mobile-prize-row.onsite{background:#fff1f1;border-color:#f5c8c8}
.claim-mobile-prize-icon{width:50px;height:50px;border-radius:16px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 8px 18px rgba(15,23,42,.08)}
.claim-mobile-prize-row strong{display:block;font-size:20px;color:#10234c}
.claim-mobile-prize-row span{display:block;color:#6b7ba4;margin-top:4px}
.claim-mobile-divider{margin:16px 0 10px;font-size:13px;font-weight:800;color:#7788aa;text-align:center;text-transform:uppercase;letter-spacing:.08em}
.claim-mobile-footnote{margin-top:10px;font-size:13px;color:#6b7ba4;line-height:1.6}
.claim-mobile-result-prize{font-size:30px;line-height:1.1;font-weight:900;margin-top:10px}
.claim-mobile-result-hero.onsite{background:linear-gradient(180deg,#7f1d1d 0%,#991b1b 100%)}
.claim-mobile-code-card{text-align:center;background:#fffdf7;border-color:#f6d77b}
.claim-mobile-code-value{font-size:34px;line-height:1.1;font-weight:900;letter-spacing:.04em;padding:16px 14px;border-radius:18px;background:#fff;border:1px dashed #f0c65d;color:#8f4c00}
.mobile-minimal-poster{margin:0;border-radius:24px;overflow:hidden}
.claim-mobile-result-shell .result-actions{margin-top:0}
@media (max-width:768px){
  .claim-mobile-shell{padding:10px 0 22px}
  .claim-mobile-card{padding:16px 14px;border-radius:20px}
  .claim-mobile-hero h1{font-size:28px}
  .claim-mobile-result-prize,.claim-mobile-code-value{font-size:28px}
  .claim-mobile-bottom-cta{bottom:8px}
}


/* v15 charity + verified-code refinements */
.promoter-sprint-footnote{margin-top:10px;font-size:12px;line-height:1.6;color:#d7e6ff;opacity:.92}
.claim-mobile-charity-card{background:linear-gradient(180deg,#fff7ea 0%,#ffefcc 100%);border:1px solid #f3cb7b}
.claim-mobile-charity-copy p{margin:0;color:#7a3206;line-height:1.7}
.claim-mobile-charity-points{display:grid;gap:10px;margin-top:12px}
.claim-mobile-charity-points div{padding:12px 14px;border-radius:16px;background:#fff7e7;border:1px solid #f1d18f}
.claim-mobile-charity-points strong{display:block;font-size:14px;color:#9a4a06;margin-bottom:4px}
.claim-mobile-charity-points span{display:block;font-size:14px;color:#7a3206;line-height:1.55}
.slot-charity-strip{margin-bottom:12px;background:linear-gradient(180deg,#fff6e5 0%,#ffe4b3 100%);border:2px solid #f0c770;color:#7a3206}
.slot-charity-strip p,.slot-charity-footnote p{margin:0;color:#7a3206;line-height:1.65}
.slot-charity-footnote{margin-top:14px;background:#fff7ea;border:1px solid #f3cf8a}
.claim-mobile-poster-note{margin:-4px 0 12px;font-size:13px;line-height:1.6;color:#8a5a00}
@media (max-width:768px){
  .slot-charity-strip,.slot-charity-footnote{padding:14px 14px;border-radius:18px}
  .claim-mobile-charity-points div{padding:11px 12px}
}


/* v16 promoter login charity emphasis */
.charity-login-page-v16 .charity-grid-v16{grid-template-columns:minmax(0,1.35fr) 420px;gap:28px}
.charity-purpose-band{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:20px 0 22px}
.purpose-pill{background:rgba(255,255,255,.12);border:1px solid rgba(255,225,176,.35);border-radius:18px;padding:16px 14px;min-height:108px}
.purpose-pill strong{display:block;color:#fff7dd;font-size:16px;margin-bottom:8px}
.purpose-pill span{display:block;color:#ffe8c8;line-height:1.6;font-size:14px}
.charity-story-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:10px}
.charity-story-card{background:rgba(255,255,255,.11);border:1px solid rgba(255,228,180,.24);border-radius:20px;padding:18px}
.charity-story-icon{font-size:28px;margin-bottom:10px}
.charity-story-card strong{display:block;color:#fff6db;font-size:17px;margin-bottom:8px}
.charity-story-card span{display:block;color:#ffe9cb;font-size:14px;line-height:1.65}
.charity-hero-visual-v16{margin:24px 0 10px}
.charity-hero-illustration-v16{position:relative;background:linear-gradient(180deg,#fff7e9 0%,#ffe4b8 100%);border:2px solid #ffd28b;padding:22px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;min-height:320px}
.charity-visual-heart{font-size:28px;line-height:1}
.charity-steps-grid-v16{margin-top:10px}
.charity-emphasis-block-v16 p strong{color:#fff5d5}
.charity-three-way-v16{gap:14px;flex-wrap:wrap}
.charity-warm-panel-v16 p + p{margin-top:12px}
.charity-login-wrap-v16{align-items:stretch}
.charity-login-card-v16{top:18px}
.charity-login-note-v16 ul{margin:10px 0 0;padding-left:18px;color:#8a4210}
.charity-login-note-v16 li{margin:8px 0;line-height:1.55}
.charity-login-btn-v16{width:100%;min-height:52px;font-size:16px}
.charity-mini-stats-v16{display:grid;gap:12px;margin-top:18px}
.charity-mini-stats-v16 div{padding:14px 14px;border-radius:16px;background:#fff5dd;border:1px solid #f4d08f}
.charity-mini-stats-v16 strong{display:block;font-size:15px;color:#7b3607;margin-bottom:6px}
.charity-mini-stats-v16 span{display:block;font-size:13px;line-height:1.6;color:#8a4210}
@media (max-width:1100px){
  .charity-login-page-v16 .charity-grid-v16{grid-template-columns:1fr}
  .charity-login-card-v16{position:static}
}
@media (max-width:768px){
  .charity-login-page-v16{padding:8px 0 22px}
  .charity-login-page-v16 .charity-theme-shell{padding:14px 14px 18px;border-radius:22px}
  .charity-login-page-v16 .charity-story h1{font-size:30px;line-height:1.2}
  .charity-login-page-v16 .charity-story p{font-size:15px;line-height:1.7}
  .charity-purpose-band{grid-template-columns:1fr;gap:10px;margin:16px 0 18px}
  .purpose-pill{min-height:auto;padding:14px 14px}
  .charity-story-grid{grid-template-columns:1fr;gap:10px}
  .charity-story-card{padding:15px}
  .charity-hero-illustration-v16{min-height:250px;padding:18px 14px}
  .charity-login-card-v16{padding:18px;border-radius:22px}
  .charity-login-card-v16 h2{font-size:28px;line-height:1.2}
  .charity-login-btn-v16{min-height:50px}
}


/* v17 promoter login spacing + richer charity emphasis */
.charity-login-page-v17 .charity-theme-shell{padding:24px 24px 30px}
.charity-login-page-v17 .charity-marquee{margin-bottom:22px;padding:14px 0}
.charity-login-page-v17 .charity-marquee-track span{padding-left:22px;padding-right:10px}
.charity-login-page-v17 .charity-story-v16{padding:2px 4px 0}
.charity-login-page-v17 .slot-kicker{display:inline-block;margin:6px 4px 10px;padding:12px 18px;border-radius:999px;background:#fff1d7;color:#9e5200;line-height:1.1;max-width:100%}
.charity-login-page-v17 .charity-story h1{margin:12px 4px 18px}
.charity-login-page-v17 .charity-story p{margin:0 4px 18px;max-width:none}
.charity-purpose-band-v17{margin-top:6px;gap:14px}
.charity-login-page-v17 .purpose-pill{padding:18px 18px 16px;border-radius:20px}
.charity-login-page-v17 .purpose-pill strong{margin-bottom:10px}
.charity-login-page-v17 .purpose-pill span{font-size:14px;line-height:1.7}
.charity-deep-message-v17{margin:22px 4px 4px;padding:20px 20px 18px;border-radius:22px;background:rgba(255,241,213,.14);border:1px solid rgba(255,221,167,.35)}
.charity-deep-message-v17 strong{display:block;font-size:18px;color:#fff6dc;margin-bottom:10px;line-height:1.4}
.charity-deep-message-v17 p{margin:0;color:#ffe7c5;font-size:15px;line-height:1.8}
.charity-login-page-v17 .charity-section-title{margin:28px 4px 16px}
.charity-login-page-v17 .charity-story-grid{gap:14px}
.charity-login-page-v17 .charity-story-card{padding:20px 18px;border-radius:22px}
.charity-login-page-v17 .charity-story-card span{line-height:1.75}
.charity-login-page-v17 .charity-hero-visual-v16{margin:26px 4px 8px}
.charity-login-page-v17 .charity-hero-illustration-v16{padding:24px 20px;border-radius:24px}
.charity-login-page-v17 .charity-visual-caption{line-height:1.7;padding:0 8px}
.charity-login-page-v17 .charity-steps-grid-v16{gap:14px}
.charity-login-page-v17 .charity-step-card{padding:18px 18px 16px;border-radius:20px}
.charity-login-page-v17 .charity-step-card span{line-height:1.7}
.charity-login-page-v17 .charity-emphasis-block-v16{margin:24px 4px 0;padding:24px 22px;border-radius:24px}
.charity-login-page-v17 .charity-emphasis-block-v16 p{line-height:1.8}
.charity-login-page-v17 .charity-three-way-v16 div{padding:14px 18px}
.charity-login-page-v17 .charity-warm-panel-v17{margin:24px 4px 0;padding:24px 22px 22px;border-radius:24px}
.charity-login-page-v17 .charity-warm-panel-v17 p{line-height:1.82}
.charity-login-page-v17 .charity-login-card-v16{padding:26px 22px;border-radius:28px}
.charity-login-page-v17 .charity-login-card-v16 h2{line-height:1.22}
.charity-login-page-v17 .charity-login-card-v16 p{line-height:1.72}
.charity-login-page-v17 .charity-login-note-v16{padding:16px 16px 14px;border-radius:18px}
.charity-login-page-v17 .charity-login-note-v16 ul{padding-left:20px}
.charity-login-page-v17 .charity-mini-stats-v16 div{padding:16px 16px 14px}
@media (max-width:768px){
  .charity-login-page-v17{padding:8px 0 24px}
  .charity-login-page-v17 .charity-theme-shell{padding:18px 18px 24px;border-radius:24px}
  .charity-login-page-v17 .charity-marquee{margin:0 2px 18px;padding:12px 0;border-radius:18px}
  .charity-login-page-v17 .charity-marquee-track{gap:28px;font-size:15px}
  .charity-login-page-v17 .charity-marquee-track span{padding-left:22px;padding-right:12px}
  .charity-login-page-v17 .charity-story-v16{padding:0 2px}
  .charity-login-page-v17 .slot-kicker{margin:2px 4px 12px;padding:10px 14px;font-size:15px}
  .charity-login-page-v17 .charity-story h1{margin:10px 4px 16px;font-size:31px;line-height:1.22}
  .charity-login-page-v17 .charity-story p{margin:0 4px 16px;font-size:16px;line-height:1.78}
  .charity-login-page-v17 .purpose-pill{padding:18px 16px}
  .charity-deep-message-v17{margin:20px 4px 2px;padding:18px 16px}
  .charity-deep-message-v17 strong{font-size:17px;line-height:1.45}
  .charity-deep-message-v17 p{font-size:15px;line-height:1.82}
  .charity-login-page-v17 .charity-section-title{margin:26px 4px 14px;font-size:21px;line-height:1.4}
  .charity-login-page-v17 .charity-story-card{padding:18px 16px}
  .charity-login-page-v17 .charity-story-card span{font-size:14px;line-height:1.75}
  .charity-login-page-v17 .charity-hero-illustration-v16{padding:22px 16px;min-height:270px}
  .charity-login-page-v17 .charity-visual-caption{font-size:14px;line-height:1.78;padding:0 10px}
  .charity-login-page-v17 .charity-step-card{padding:18px 16px}
  .charity-login-page-v17 .charity-step-card span{font-size:14px;line-height:1.75}
  .charity-login-page-v17 .charity-emphasis-block-v16{margin:22px 4px 0;padding:20px 16px}
  .charity-login-page-v17 .charity-emphasis-block-v16 p{font-size:15px;line-height:1.8}
  .charity-login-page-v17 .charity-three-way-v16{gap:10px}
  .charity-login-page-v17 .charity-three-way-v16 div{padding:12px 14px;font-size:15px}
  .charity-login-page-v17 .charity-three-way-v16 span{font-size:18px}
  .charity-login-page-v17 .charity-warm-panel-v17{margin:22px 4px 0;padding:20px 16px 18px}
  .charity-login-page-v17 .charity-warm-panel-v17 p{font-size:15px;line-height:1.82}
  .charity-login-page-v17 .charity-login-card-v16{padding:22px 18px 20px;border-radius:24px}
  .charity-login-page-v17 .charity-login-card-v16 h2{font-size:29px;line-height:1.22}
  .charity-login-page-v17 .charity-login-card-v16 p{font-size:15px;line-height:1.75}
  .charity-login-page-v17 .charity-login-note-v16{padding:16px 14px 14px}
  .charity-login-page-v17 .charity-login-btn-v16{min-height:54px;font-size:17px}
  .charity-login-page-v17 .charity-mini-stats-v16 div{padding:15px 14px}
}

/* v18 sprint + unified mobile claim refinements */
.promoter-rally-card{padding:18px;border-radius:24px;background:linear-gradient(180deg,#fff6de 0%,#fffdf6 100%);border:1px solid #f4d08a;box-shadow:0 12px 28px rgba(15,23,42,.08)}
.promoter-rally-grid{display:grid;grid-template-columns:1.5fr .9fr;gap:14px;align-items:stretch}
.promoter-rally-highlight{padding:16px 16px 14px;border-radius:22px;background:linear-gradient(135deg,#9a3412 0%,#b45309 45%,#f59e0b 100%);color:#fff;box-shadow:0 12px 28px rgba(180,83,9,.25)}
.promoter-rally-caption{display:block;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#ffefc9}
.promoter-rally-highlight strong{display:block;margin-top:8px;font-size:32px;line-height:1.05}
.promoter-rally-highlight p{margin:10px 0 0;color:#fff4dc;line-height:1.55;font-size:14px}
.promoter-rally-metrics{display:grid;grid-template-columns:1fr;gap:12px}
.promoter-rally-metric{display:flex;flex-direction:column;justify-content:center;padding:16px;border-radius:20px;background:#f8fbff;border:1px solid #dce9ff}
.promoter-rally-metric strong{font-size:28px;line-height:1;color:#11356f}
.promoter-rally-metric span{margin-top:6px;color:#5e769e;font-size:13px}
.promoter-rally-metric.accent{background:linear-gradient(180deg,#ecfff3 0%,#f7fff9 100%);border-color:#b6ecc7}
.promoter-rally-metric.accent strong{color:#11623a}
.promoter-rally-note{margin-top:12px;padding:12px 14px;border-radius:16px;background:#fff;border:1px dashed #f2c770;color:#8b5a00;line-height:1.6;font-size:13px}
.promoter-rally-chip{padding:8px 12px;border-radius:999px;background:#fff;border:1px solid #eed09a;color:#8b5a00;font-size:12px;font-weight:800}
.promoter-qr-stage{position:relative}
.promoter-qr-zoom-btn{position:absolute;right:12px;bottom:12px;z-index:5;border:none;border-radius:999px;background:#0d3ea8;color:#fff;padding:10px 14px;font-weight:800;box-shadow:0 10px 24px rgba(13,62,168,.28)}
.promoter-qr-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:18px;z-index:1400}
.promoter-qr-overlay.show{display:flex}
.promoter-qr-overlay-backdrop{position:absolute;inset:0;background:rgba(5,15,35,.68);backdrop-filter:blur(4px)}
.promoter-qr-overlay-card{position:relative;z-index:1;width:min(100%,520px);padding:18px;border-radius:26px;background:#fff;box-shadow:0 24px 60px rgba(0,0,0,.28);text-align:center}
.promoter-qr-overlay-card h2{margin:8px 0 14px;font-size:28px;color:#10234c}
.promoter-qr-overlay-close{position:absolute;right:14px;top:12px;width:38px;height:38px;border:none;border-radius:999px;background:#eef4ff;color:#1743a3;font-size:26px;line-height:1;cursor:pointer}
.promoter-qr-overlay-stage{min-height:320px;display:flex;align-items:center;justify-content:center;padding:16px;border-radius:24px;background:#f7fbff;border:1px solid #dce9ff}
.promoter-qr-overlay-stage img{width:min(100%,360px);display:block}
.promoter-qr-overlay-empty{padding:30px 24px;color:#6b7ba4;line-height:1.7}
.promoter-qr-overlay-meta{margin-top:14px;padding:12px 14px;border-radius:18px;background:#f8fafc;border:1px solid #e5e7ef;color:#5e769e;line-height:1.6;word-break:break-all}
.claim-mobile-unified-theme .claim-mobile-card{border-color:#eadfc2}
.claim-mobile-unified-theme .claim-mobile-card-title{color:#8b5a00}
.claim-mobile-unified-hero{background:linear-gradient(180deg,#7a0f14 0%,#95151d 45%,#ae1f18 100%);box-shadow:0 22px 40px rgba(122,15,20,.22)}
.claim-mobile-flow-ribbon{margin-top:14px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.12);border:1px solid rgba(255,240,200,.24);display:grid;gap:6px}
.claim-mobile-flow-ribbon strong{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#ffe9bf}
.claim-mobile-flow-ribbon span{line-height:1.6;color:#fff4df;font-size:14px}
.claim-mobile-flow-ribbon.slim{margin-top:12px;background:#fff4df;border-color:#f3d39b}
.claim-mobile-flow-ribbon.slim strong{color:#9a4a06}
.claim-mobile-flow-ribbon.slim span{color:#7a3206}
.claim-mobile-steps-rich .claim-mobile-step{background:#fffaf0;border-color:#f3dfb1}
.claim-mobile-steps-rich .claim-mobile-step strong{background:#9a3412}
.claim-mobile-charity-points.compact{gap:8px}
.claim-mobile-charity-points.compact div{padding:11px 12px}
.claim-mobile-charity-strip,.slot-charity-footnote{background:linear-gradient(180deg,#fff6de 0%,#fffdf6 100%);border:1px solid #f4d08a}
.slot-charity-strip p,.slot-charity-footnote p{margin:0;color:#8b5a00;line-height:1.65}
.slot-machine-shell .slot-machine-marquee{letter-spacing:.08em}
@media (max-width:768px){
  .promoter-rally-card{padding:16px;border-radius:22px}
  .promoter-rally-grid{grid-template-columns:1fr;gap:12px}
  .promoter-rally-highlight strong{font-size:28px}
  .promoter-rally-metrics{grid-template-columns:1fr 1fr}
  .promoter-qr-zoom-btn{left:12px;right:auto;padding:9px 12px;font-size:13px}
  .promoter-qr-overlay-card{padding:16px;border-radius:24px}
  .promoter-qr-overlay-card h2{font-size:24px}
  .promoter-qr-overlay-stage{min-height:280px}
}


.admin-reward-kpi{border-radius:22px}
.admin-reward-kpi.onsite{background:linear-gradient(180deg,#fff7f0 0%,#ffefe1 100%)}
.admin-reward-kpi.verified{background:linear-gradient(180deg,#f3fbff 0%,#e8f4ff 100%)}
.admin-reward-kpi.bonus{background:linear-gradient(180deg,#fff8ed 0%,#fff0d6 100%)}
.admin-reward-kpi.claimable{background:linear-gradient(180deg,#f5fff5 0%,#e9ffed 100%)}
.admin-reward-table td{vertical-align:top}
.admin-reward-metric{font-size:15px;font-weight:700;color:#0f172a}
.verified-text strong{color:#1451b8}.bonus-text strong{color:#9a5a00}.claimable-text strong{color:#0f8a36}
.tier-status-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;min-width:340px}
.tier-status-chip{border-radius:16px;padding:12px 12px 10px;border:1px solid var(--border);background:#f8fafc}
.tier-status-chip .tier-status-top{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:6px;color:#0f172a}
.tier-status-chip .tier-status-label{margin-top:8px;font-size:13px;font-weight:800}
.tier-status-chip.locked{background:#f8fafc}.tier-status-chip.locked .tier-status-label{color:#667085}
.tier-status-chip.claimable{background:#effff2;border-color:#bfe6c7}.tier-status-chip.claimable .tier-status-label{color:#127c35}
.tier-status-chip.pending{background:#fff7e8;border-color:#f1d28a}.tier-status-chip.pending .tier-status-label{color:#9a5a00}
.tier-status-chip.settled{background:#eef6ff;border-color:#b8cff5}.tier-status-chip.settled .tier-status-label{color:#1451b8}
@media (max-width:1100px){.tier-status-grid{grid-template-columns:1fr;min-width:260px}}

/* v21 live QR + PIN */
.promoter-live-pin-card{margin-top:14px;padding:16px;border-radius:20px;background:linear-gradient(135deg,#1b2140,#0f1630);border:1px solid rgba(255,255,255,.08);color:#fff;box-shadow:0 12px 24px rgba(13,19,42,.25)}
.promoter-live-pin-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.promoter-live-pin-label{font-size:.88rem;letter-spacing:.04em;text-transform:uppercase;color:#9ac6ff;font-weight:700}
.promoter-live-pin-note{font-size:.84rem;line-height:1.45;color:rgba(255,255,255,.78);margin-top:4px}
.promoter-live-pin-badge{font-size:.78rem;font-weight:700;color:#0e1532;background:#ffd66b;padding:6px 10px;border-radius:999px;white-space:nowrap}
.promoter-live-pin-code{margin-top:14px;font-size:2.35rem;line-height:1;font-weight:900;letter-spacing:.32em;text-indent:.32em;text-align:center;background:rgba(255,255,255,.08);border:1px dashed rgba(255,255,255,.24);padding:18px 10px;border-radius:18px}
.promoter-live-pin-helper{margin-top:12px;font-size:.86rem;line-height:1.55;color:rgba(255,255,255,.82)}
.promoter-overlay-pin-code{margin-top:16px;font-size:2.5rem;font-weight:900;letter-spacing:.35em;text-indent:.35em;text-align:center;color:#fff;background:#111935;padding:18px;border-radius:18px}
.claim-pin-card{padding:22px;border-radius:24px}
.claim-pin-step{font-size:.82rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#8a6b00;margin-bottom:10px}
.claim-pin-copy{color:#4a4f67;line-height:1.7;margin-bottom:16px}
.claim-pin-form{display:flex;flex-direction:column;gap:14px}
.claim-pin-label{font-size:.9rem;font-weight:700;color:#233057}
.claim-pin-input{height:68px;border-radius:18px;border:1.5px solid #d7deef;padding:0 18px;font-size:2rem;font-weight:900;letter-spacing:.42em;text-indent:.42em;text-align:center;color:#111935;background:#f7f9ff}
.claim-pin-attempts{font-size:.88rem;color:#5a6078}
.claim-pin-submit{height:56px;font-size:1rem;font-weight:800}
.claim-charity-card{margin-top:16px;padding:20px;border-radius:22px;background:#fff8e9;border:1px solid #f0d9a0}
.claim-charity-title{font-size:1.02rem;font-weight:800;color:#8f5d00;margin-bottom:10px}
.claim-charity-list{margin:0;padding-left:18px;color:#5e5140;line-height:1.65}
@media (max-width:640px){.promoter-live-pin-code{font-size:2rem}.promoter-overlay-pin-code{font-size:2.1rem}.claim-pin-input{font-size:1.8rem}}


.claim-mobile-phone-group {
  display: flex;
  align-items: center;
  gap: 0;
  border: 1px solid #d8dde8;
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
}

.claim-mobile-phone-prefix {
  flex: 0 0 auto;
  min-width: 72px;
  padding: 14px 16px;
  background: #f7f0df;
  color: #8a4a00;
  font-weight: 800;
  text-align: center;
  border-right: 1px solid #ead8aa;
}

.claim-mobile-phone-group input {
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  flex: 1 1 auto;
}

/* v22 sponsor settings + sponsor display */
.sponsor-showcase-section{
  margin:24px 0 8px;
  background:#fff;
  border:1px solid #e9edf5;
  border-radius:22px;
  padding:18px 16px;
  box-shadow:0 12px 32px rgba(18,38,63,.06);
}
.sponsor-showcase-header{margin-bottom:14px;text-align:center}
.sponsor-showcase-kicker{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  background:#f3f6fb;
  color:#4c5a73;
  font-size:12px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.sponsor-showcase-header h3{margin:10px 0 0;font-size:22px;color:#1a2233}
.sponsor-logo-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.sponsor-logo-card{
  border:1px solid #edf1f7;
  border-radius:16px;
  background:#fff;
  min-height:86px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:12px;
}
.sponsor-logo-card img{
  max-width:100%;
  max-height:54px;
  object-fit:contain;
  display:block;
}
.sponsor-admin-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px;
}
.sponsor-admin-card{
  border:1px solid #e9edf5;
  border-radius:18px;
  padding:14px;
  background:#fff;
}
.sponsor-admin-thumb{
  height:110px;
  border:1px dashed #d9e1ee;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:12px;
  background:#fafbfd;
}
.sponsor-admin-thumb img{
  max-width:100%;
  max-height:90px;
  object-fit:contain;
}
.sponsor-remove-label{display:block;margin-top:8px;color:#8b1e2d;font-size:13px;font-weight:600}
@media (max-width: 768px){
  .sponsor-logo-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px;
  }
  .sponsor-logo-card{
    min-height:74px;
    padding:10px;
  }
  .sponsor-logo-card img{
    max-height:42px;
  }
}


.charity-login-card-registerable{position:relative}
.charity-login-switcher{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;background:#f3f6fb;border:1px solid var(--border);padding:8px;border-radius:18px}
.charity-tab-btn{border:none;border-radius:14px;background:transparent;color:#344054;font-weight:800;padding:12px 14px;cursor:pointer}
.charity-tab-btn.active{background:#0f172a;color:#fff;box-shadow:0 6px 16px rgba(15,23,42,.18)}
.staff-tab-panel{display:none}
.staff-tab-panel.active{display:block}
.register-notice-card,.register-success-box,.register-closed-box{margin:14px 0 16px;padding:16px 18px;border-radius:18px;border:1px solid var(--border)}
.register-notice-card{background:#fff8e8;border-color:#ffe0a3;color:#7a3206}
.register-success-box{background:#eaf7ee;border-color:#b7e0c1;color:#0f6a3a}
.register-success-title{font-size:22px;font-weight:900;margin-bottom:8px}
.register-closed-box{background:#fff4ea;border-color:#ffd5b1;color:#8a3b08}
.register-notice-card ul{margin:10px 0 0 18px;padding:0}
.register-notice-card li{margin-bottom:6px}
@media (max-width:768px){.charity-login-switcher{gap:8px}.charity-tab-btn{padding:11px 10px;font-size:15px}}


.charity-login-switcher-links { display:flex; gap:10px; }
.charity-login-switcher-links .charity-tab-btn { text-decoration:none; text-align:center; }
.register-inline-tip { margin-top:14px; display:flex; flex-direction:column; gap:10px; }
.field-help { display:block; margin-top:6px; font-size:12px; color:#666; }
.field-full { grid-column: 1 / -1; }


/* ===== admin staff table refresh ===== */
.admin-staff-card{padding:24px}
.admin-staff-head{margin-bottom:18px}
.admin-staff-toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:16px;padding:14px 16px;border:1px solid var(--border);border-radius:16px;background:#f8fafc}
.admin-staff-search-form{margin:0;flex:1 1 420px}
.admin-staff-search-box{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.admin-staff-search-input{max-width:360px;min-width:240px}
.admin-staff-filter-select{min-width:148px;max-width:180px;background:#fff}
.admin-staff-toolbar-meta{font-size:13px;white-space:nowrap}
.admin-staff-table-shell{min-height:0;overflow:hidden;border:1px solid var(--border);border-radius:18px;background:#fff}
.admin-staff-table-wrap{padding-bottom:0;overflow:auto}
.admin-staff-table-clean{min-width:1180px;table-layout:auto}
.admin-staff-table-clean th,.admin-staff-table-clean td{padding:14px 12px;font-size:14px;line-height:1.45;vertical-align:middle;word-break:normal}
.admin-staff-table-clean thead th{background:#f8fafc;color:#526071;font-size:13px;font-weight:700;white-space:nowrap}
.admin-staff-table-clean tbody tr:hover{background:#fbfdff}
.admin-staff-table-clean .nowrap{white-space:nowrap}
.admin-staff-table-clean .col-name{min-width:150px}
.admin-staff-table-clean .col-account{min-width:140px}
.admin-staff-table-clean .col-code{min-width:120px}
.admin-staff-table-clean .col-status{min-width:100px}
.admin-staff-table-clean .col-online{min-width:100px}
.admin-staff-table-clean .col-time{min-width:160px}
.admin-staff-table-clean .col-promote{min-width:160px}
.admin-staff-table-clean .col-action{min-width:150px}
.staff-name-cell strong{display:block;font-size:15px;margin-bottom:2px}
.staff-code-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#f1f5ff;color:#2448a6;font-weight:700;white-space:nowrap}
.staff-action-inline{min-width:136px}
.staff-action-select{width:136px}
@media (max-width:768px){
  .admin-staff-card{padding:16px}
  .admin-staff-toolbar{padding:12px}
  .admin-staff-search-form{flex-basis:100%}
  .admin-staff-search-input,.admin-staff-filter-select{max-width:none;min-width:0;flex:1 1 100%}
  .admin-staff-toolbar-meta{white-space:normal}
}

/* list pagination */
.list-pagination-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.list-pagination-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:0}
.pagination-jump-inline{display:flex;align-items:center;gap:8px}
.pagination-jump-inline input{width:88px}
.admin-staff-perpage-select{min-width:110px}

/* claims page */
.claims-page-card{padding:20px}
.claims-toolbar{padding:14px 16px;border:1px solid var(--border);border-radius:16px;background:#f8fafc;margin-bottom:14px}
.claims-toolbar-grid{display:grid;grid-template-columns:1fr 2fr 160px;gap:12px;align-items:end}
.claims-toolbar-search input{min-width:260px}
.claims-toolbar-actions{justify-content:flex-end;margin-top:12px;gap:10px}
.claims-toolbar-meta{margin-bottom:12px;font-size:13px}
.claims-table th,.claims-table td{white-space:nowrap}

/* settlements page */
.settlement-page{display:flex;flex-direction:column;gap:16px}
.settlement-hero-card,.settlement-section-card{padding:18px 20px}
.settlement-head,.settlement-section-head{align-items:flex-start;gap:12px;margin-bottom:14px}
.settlement-toolbar{padding:14px 16px;border:1px solid var(--border);border-radius:16px;background:#f8fafc;margin-bottom:16px}
.settlement-toolbar-grid{display:grid;grid-template-columns:2fr repeat(4,1fr) 1fr 1fr;gap:12px;align-items:end}
.settlement-toolbar-field{margin:0}
.settlement-toolbar-field label{display:block;margin-bottom:6px;font-size:13px;color:#475569;font-weight:600}
.settlement-toolbar-actions{justify-content:flex-end;margin-top:12px;gap:10px}
.settlement-summary-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}
.settlement-summary-card{border:1px solid var(--border);border-radius:16px;background:#fff;padding:14px 16px}
.settlement-summary-card-strong{background:#eff6ff;border-color:#bfdbfe}
.settlement-summary-label{font-size:13px;color:#64748b;margin-bottom:8px}.settlement-summary-value{font-size:28px;font-weight:800;line-height:1.1;color:#0f172a}
.settlement-table{width:100%;border-collapse:collapse}.settlement-table th,.settlement-table td{padding:14px 12px;border-bottom:1px solid var(--border);vertical-align:top}.settlement-table thead th{font-size:13px;color:#64748b;font-weight:700;background:#fafafa}.settlement-staff-main{margin-bottom:4px}.settlement-pay-form{display:flex;flex-direction:column;gap:8px}.settlement-pay-form input{width:100%}
@media (max-width: 1200px){.settlement-toolbar-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settlement-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width: 768px){.list-pagination-bar{align-items:stretch}.list-pagination-controls{width:100%}.claims-page-card,.settlement-hero-card,.settlement-section-card,.admin-staff-card{padding:14px}.claims-toolbar,.settlement-toolbar,.admin-staff-toolbar{padding:12px}.claims-toolbar-grid,.settlement-toolbar-grid{grid-template-columns:1fr}.claims-toolbar-actions,.settlement-toolbar-actions{justify-content:stretch;flex-wrap:wrap}.claims-toolbar-actions .btn,.settlement-toolbar-actions .btn{width:100%}.settlement-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settlement-summary-value{font-size:22px}}


/* Admin full width layout */
body.admin-body .container{max-width:none;width:100%;padding:16px 20px}
body.admin-body .topbar .container{max-width:none;width:100%;padding:14px 20px}
body.admin-body .table-wrap{overflow:auto}
body.admin-body .card{width:100%}
body.admin-body .page-head,.admin-staff-head{align-items:flex-start}
body.admin-body .nav-links{flex-wrap:wrap}
@media (max-width:768px){
  body.admin-body .container{padding:12px 14px}
  body.admin-body .topbar .container{padding:10px 14px}
}
