:root{--bg:#08080a;--panel:#111116;--panel2:#191920;--text:#f7f7f8;--muted:#a6a6ad;--line:#2b2b34;--red:#e50914;--red2:#ff3140;--white:#fff;--ok:#1fbe77;--warn:#ffb020}*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Tahoma,sans-serif;background:radial-gradient(circle at top,#2a080b 0,#08080a 42%,#050506 100%);color:var(--text);min-height:100vh}a{color:var(--white);text-decoration:none}input,select,button,textarea{font:inherit}input,select,textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:#0c0c10;color:var(--text);outline:none}input:focus,select:focus{border-color:var(--red2);box-shadow:0 0 0 3px rgba(229,9,20,.18)}label{display:grid;gap:8px;color:#ddd;font-weight:600}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:18px 6vw;background:rgba(5,5,6,.78);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.08)}.brand{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.3px}.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:13px;background:linear-gradient(135deg,var(--red),#8b0007);box-shadow:0 12px 34px rgba(229,9,20,.35)}nav{display:flex;align-items:center;gap:14px}.user-pill,.badge{display:inline-flex;align-items:center;border:1px solid var(--line);background:#15151b;color:#eee;padding:6px 10px;border-radius:999px;font-size:12px}.badge.pending{border-color:var(--warn);color:var(--warn)}.badge.approved{border-color:var(--ok);color:var(--ok)}.badge.rejected{border-color:var(--red2);color:var(--red2)}.container{width:min(1180px,92vw);margin:0 auto;padding:38px 0 64px}.login-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center;min-height:72vh}.hero-copy{padding:36px}.eyebrow{color:var(--red2);font-size:13px;font-weight:900;letter-spacing:2.2px}.hero-copy h1,.page-head h1{font-size:clamp(36px,6vw,72px);line-height:.95;margin:14px 0}.hero-copy p,.page-head p,.muted{color:var(--muted)}.login-card,.card,.stat-card{background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border:1px solid rgba(255,255,255,.1);border-radius:28px;box-shadow:0 28px 90px rgba(0,0,0,.42)}.login-card{padding:32px;display:grid;gap:18px}.card{padding:26px;margin:22px 0}.wide{overflow-x:auto}.narrow{max-width:520px;margin-inline:auto}.install-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}.btn{display:inline-flex;justify-content:center;align-items:center;gap:8px;border:none;border-radius:14px;padding:12px 18px;background:#24242b;color:white;font-weight:800;cursor:pointer;transition:.2s}.btn:hover{transform:translateY(-1px);filter:brightness(1.08)}.btn.primary{background:linear-gradient(135deg,var(--red),#a9000b);box-shadow:0 14px 32px rgba(229,9,20,.26)}.btn.ghost{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.05)}.btn.danger-btn{background:#781018}.btn.full{width:100%}.btn.small{padding:8px 12px;border-radius:10px;font-size:13px}.center{text-align:center}.alert{padding:14px 16px;border-radius:16px;margin:14px 0;border:1px solid}.alert-ok{background:rgba(31,190,119,.1);border-color:rgba(31,190,119,.45);color:#7ef0b9}.alert-error{background:rgba(229,9,20,.12);border-color:rgba(229,9,20,.55);color:#ff8d96}.grid-3,.grid-4{display:grid;gap:18px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.stat-card{padding:24px}.stat-card span{display:block;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.8px}.stat-card strong{display:block;font-size:34px;margin-top:8px}.stat-card.danger strong{color:var(--red2)}.actions-row,.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0}.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}.tabs a{padding:10px 14px;border-radius:999px;background:#15151b;border:1px solid var(--line)}.form-grid{display:grid;gap:16px}.inline-form{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr 1fr auto;gap:12px;align-items:end}.mini-form{display:grid;gap:8px;min-width:220px}.mini-row{display:flex;gap:8px}.mini-row input{min-width:105px}table{width:100%;border-collapse:collapse;min-width:780px}th,td{text-align:left;padding:14px;border-bottom:1px solid var(--line);vertical-align:top}th{color:#eee;font-size:13px;text-transform:uppercase;letter-spacing:.8px}td{color:#ddd}.packages{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:18px}.package-card{position:relative;padding:20px;border:1px solid var(--line);border-radius:22px;background:#101015;cursor:pointer}.package-card:has(input:checked){border-color:var(--red2);box-shadow:0 0 0 3px rgba(229,9,20,.18)}.package-card input{position:absolute;opacity:0}.pack-name{display:block;font-size:18px}.package-card strong{display:block;font-size:28px;margin:8px 0}.package-card em{color:var(--red2);font-style:normal;font-weight:900}.package-card small{display:block;color:var(--muted);margin-top:8px}.upload-box{margin:18px 0;padding:22px;border:1px dashed #666;border-radius:20px;background:#0d0d12}.slip-preview{display:none;max-width:360px;width:100%;border-radius:18px;border:1px solid var(--line);margin:12px 0}.thumb{width:96px;height:124px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}code{white-space:pre-wrap;color:#ffced2}.footer{text-align:center;color:#777;padding:26px;border-top:1px solid rgba(255,255,255,.06)}@media(max-width:900px){.login-hero,.grid-3,.grid-4,.packages{grid-template-columns:1fr}.inline-form{grid-template-columns:1fr}nav{font-size:13px}.hero-copy{padding:12px}.topbar{padding:14px 4vw}}

/* usability + responsive upgrades */
.section-row{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.search-form{display:flex;gap:10px;align-items:center;min-width:min(100%,520px)}.search-form input{min-width:260px}.table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.check-row{display:flex;align-items:center;gap:8px;white-space:nowrap}.check-row input{width:auto}.user-create-form{grid-template-columns:1.1fr 1fr 1fr 1fr .8fr 1fr auto auto}.slip-button{border:0;background:transparent;padding:0;cursor:pointer}.slip-button:focus-visible{outline:3px solid rgba(255,49,64,.5);border-radius:14px}.modal-open{overflow:hidden}.image-modal{position:fixed;inset:0;z-index:999;display:none;align-items:center;justify-content:center;padding:22px}.image-modal.open{display:flex}.image-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(4px)}.image-modal-panel{position:relative;width:min(94vw,720px);max-height:92vh;border:1px solid rgba(255,255,255,.18);border-radius:24px;background:#111116;padding:14px;box-shadow:0 30px 100px rgba(0,0,0,.65)}.image-modal-panel img{display:block;width:100%;max-height:84vh;object-fit:contain;border-radius:16px;background:#050506}.image-modal-close{position:absolute;right:10px;top:10px;z-index:2;width:42px;height:42px;border:1px solid rgba(255,255,255,.25);border-radius:999px;background:#e50914;color:#fff;font-size:30px;line-height:1;cursor:pointer}.image-modal-close:hover{filter:brightness(1.08)}

@media(max-width:1100px){.user-create-form{grid-template-columns:repeat(2,1fr)}.user-create-form .check-row,.user-create-form button{min-height:46px}.container{width:min(100% - 28px,1180px)}}
@media(max-width:760px){body{background:#08080a}.topbar{position:static;align-items:flex-start;gap:12px;flex-direction:column}.topbar nav{width:100%;overflow-x:auto;padding-bottom:4px}.brand-mark{width:34px;height:34px}.container{padding:22px 0 44px;width:min(100% - 22px,1180px)}.card,.login-card,.stat-card{border-radius:20px;padding:18px}.hero-copy h1,.page-head h1{font-size:34px;line-height:1.05}.user-create-form,.inline-form,.search-form,.mini-row{grid-template-columns:1fr;display:grid;width:100%}.search-form input{min-width:0}.section-row{align-items:stretch}.section-row h2{margin-bottom:0}table{min-width:720px}th,td{padding:12px 10px}.thumb{width:78px;height:98px}.actions-row .btn,.hero-actions .btn{width:100%}.image-modal{padding:10px}.image-modal-panel{width:96vw;padding:10px;border-radius:18px}.image-modal-panel img{max-height:82vh}.image-modal-close{right:8px;top:8px;width:38px;height:38px}}

/* renewal confirmation flow */
.renew-form{display:grid;gap:18px}.renew-step h2,.renew-slip-panel h2{margin:0 0 6px}.renew-choice-error{margin-top:12px}.renew-slip-panel[hidden]{display:none!important}.confirmed-package-box{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:4px 0 18px;padding:18px;border:1px solid rgba(255,49,64,.42);border-radius:22px;background:linear-gradient(135deg,rgba(229,9,20,.12),rgba(255,255,255,.035))}.confirmed-package-box h2{margin:6px 0}.package-card.is-confirmed{border-color:var(--ok);box-shadow:0 0 0 3px rgba(31,190,119,.16)}
@media(max-width:760px){.confirmed-package-box{align-items:stretch}.confirmed-package-box .btn{width:100%}.renew-form .section-row .btn{width:100%}}

.badge-super{border-color:#ffb020;color:#ffd37a;background:rgba(255,176,32,.08)}.danger-zone{border-color:rgba(229,9,20,.35);background:linear-gradient(180deg,rgba(229,9,20,.08),rgba(255,255,255,.025))}

/* ===== UI/UX Refresh v8: safer visual-only improvements ===== */
:root{
  --radius-lg:28px;
  --radius-md:18px;
  --shadow:0 24px 80px rgba(0,0,0,.42);
  --shadow-soft:0 12px 36px rgba(0,0,0,.28);
  --glass:rgba(255,255,255,.055);
  --glass-2:rgba(255,255,255,.032);
}
body{
  background:
    radial-gradient(circle at 12% -10%,rgba(229,9,20,.28),transparent 38%),
    radial-gradient(circle at 85% 8%,rgba(255,49,64,.12),transparent 28%),
    linear-gradient(180deg,#08080a 0%,#0b0b10 48%,#050506 100%);
  letter-spacing:.01em;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:48px 48px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.65),transparent 80%);
}
.topbar{
  min-height:76px;padding:14px clamp(16px,5vw,76px);
  background:rgba(8,8,10,.74);box-shadow:0 12px 50px rgba(0,0,0,.26);
}
.brand-text{display:grid;line-height:1.05}.brand-text small{color:var(--muted);font-size:11px;font-weight:700;margin-top:3px;letter-spacing:.8px;text-transform:uppercase}.brand-mark{box-shadow:0 14px 34px rgba(229,9,20,.38),inset 0 1px 0 rgba(255,255,255,.22)}
.topnav a,.tabs a{transition:transform .16s ease,background .16s ease,border-color .16s ease,color .16s ease}.topnav a{padding:9px 12px;border-radius:999px;color:#e8e8eb}.topnav a:hover,.tabs a:hover{background:rgba(255,255,255,.075);transform:translateY(-1px)}.logout-link{border:1px solid rgba(229,9,20,.35);color:#ffb0b6!important}.user-pill{background:rgba(255,255,255,.065);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 4px rgba(31,190,119,.12);margin-right:8px}.nav-toggle{display:none;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);color:white;border-radius:14px;width:44px;height:40px;font-size:22px;cursor:pointer}
.container{width:min(1240px,calc(100% - 40px));padding-top:34px}.page-head{margin:10px 0 26px;padding:24px;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(255,255,255,.065),rgba(255,255,255,.022));box-shadow:var(--shadow-soft)}.page-head h1{margin-top:0;margin-bottom:10px}.page-head p{max-width:760px}.login-hero{gap:42px}.hero-copy,.login-card,.card,.stat-card{position:relative;overflow:hidden}.login-card::before,.card::before,.stat-card::before,.page-head::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent)}.login-card,.card,.stat-card{background:linear-gradient(180deg,var(--glass),var(--glass-2));border-color:rgba(255,255,255,.105);box-shadow:var(--shadow);backdrop-filter:blur(10px)}.card:hover,.stat-card:hover{border-color:rgba(255,255,255,.16)}.stat-card strong{font-size:clamp(27px,3vw,38px);word-break:break-word}.stat-card span{font-weight:900}.stat-card.danger{border-color:rgba(229,9,20,.24)}.stat-card.danger strong{ text-shadow:0 0 24px rgba(229,9,20,.32)}
.btn{min-height:44px;box-shadow:inset 0 1px 0 rgba(255,255,255,.08);user-select:none}.btn:active{transform:translateY(0) scale(.99)}.btn.primary{background:linear-gradient(135deg,#ff1f2d,#b5000c 65%,#7c0008);box-shadow:0 18px 44px rgba(229,9,20,.28),inset 0 1px 0 rgba(255,255,255,.22)}.btn.ghost{background:rgba(255,255,255,.065)}.btn.danger-btn{background:linear-gradient(135deg,#a5121e,#5c0b10)}input,select,textarea{min-height:44px;background:rgba(5,5,8,.76);transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}input:hover,select:hover,textarea:hover{border-color:rgba(255,255,255,.22)}label{font-size:14px}.tabs{position:sticky;top:78px;z-index:15;padding:10px;margin:0 0 22px;border:1px solid rgba(255,255,255,.08);border-radius:999px;background:rgba(8,8,10,.76);backdrop-filter:blur(12px);box-shadow:0 16px 50px rgba(0,0,0,.22)}.tabs a{background:transparent;border-color:transparent;color:#d6d6dc}.tabs a.active{background:linear-gradient(135deg,var(--red),#8b0007);color:#fff;border-color:rgba(255,255,255,.16);box-shadow:0 10px 26px rgba(229,9,20,.24)}.section-row{margin-bottom:14px}.section-row h2{margin:0}.search-form{padding:8px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:rgba(0,0,0,.16)}.search-form input{border-color:transparent;background:rgba(255,255,255,.045)}
.table-scroll,.wide{border-radius:22px}table{border-collapse:separate;border-spacing:0}thead th{position:sticky;top:0;background:#14141a;z-index:2}th:first-child{border-top-left-radius:14px}th:last-child{border-top-right-radius:14px}tbody tr{transition:background .14s ease}tbody tr:hover{background:rgba(255,255,255,.035)}td strong{color:#fff}details summary{cursor:pointer;color:#fff;font-weight:800;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:9px 12px;display:inline-flex}details[open] summary{margin-bottom:10px;border-color:rgba(255,49,64,.35)}.badge{font-weight:900;text-transform:capitalize}.badge.pending{background:rgba(255,176,32,.08)}.badge.approved{background:rgba(31,190,119,.08)}.badge.rejected{background:rgba(229,9,20,.08)}
.packages{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.package-card{min-height:176px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.package-card:hover{transform:translateY(-3px);border-color:rgba(255,49,64,.42);box-shadow:0 18px 50px rgba(0,0,0,.32)}.package-card:has(input:checked)::after,.package-card.is-confirmed::after{content:"เลือกแล้ว";position:absolute;top:14px;right:14px;font-size:12px;font-weight:900;color:#fff;padding:6px 10px;border-radius:999px;background:linear-gradient(135deg,var(--red),#8b0007)}.upload-box{cursor:pointer;transition:border-color .16s ease,background .16s ease}.upload-box:hover{border-color:var(--red2);background:rgba(229,9,20,.06)}.slip-preview{box-shadow:0 18px 52px rgba(0,0,0,.4)}.thumb{transition:transform .18s ease,filter .18s ease}.slip-button:hover .thumb{transform:scale(1.04);filter:brightness(1.08)}.image-modal-panel{animation:popIn .18s ease}@keyframes popIn{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
.install-wrap .login-card{width:min(100%,720px)}.footer{background:rgba(0,0,0,.18)}
@media(max-width:900px){.topbar{display:grid;grid-template-columns:1fr auto;align-items:center}.topnav{grid-column:1 / -1;display:none;width:100%;padding-top:12px}.topnav.open{display:flex}.nav-toggle{display:inline-grid;place-items:center}.tabs{top:0;border-radius:20px;overflow-x:auto;flex-wrap:nowrap}.tabs a{white-space:nowrap}.container{width:min(100% - 26px,1240px)}.page-head{padding:20px;border-radius:22px}.login-hero{min-height:auto;padding-top:10px}.hero-copy{padding:18px}.hero-actions .btn,.actions-row .btn{flex:1 1 220px}}
@media(max-width:640px){.topbar{padding:12px 14px}.brand-text small{display:none}.topnav{gap:8px}.topnav.open{display:grid}.topnav a,.user-pill{width:100%;justify-content:center}.container{width:min(100% - 18px,1240px);padding-top:18px}.page-head{margin-top:2px;padding:18px}.card,.login-card,.stat-card{padding:16px;border-radius:18px}.grid-3,.grid-4{gap:12px}.stat-card{display:flex;align-items:center;justify-content:space-between;gap:12px}.stat-card strong{font-size:24px;text-align:right}.actions-row{display:grid}.btn{width:100%}.search-form{grid-template-columns:1fr;display:grid}.packages{grid-template-columns:1fr}.package-card{min-height:150px}thead th{position:static}table{font-size:14px;min-width:680px}.footer{font-size:12px;padding:20px 14px}}

/* v12: created member customer message */
.copy-card{border-color:rgba(31,190,119,.36);background:linear-gradient(180deg,rgba(31,190,119,.08),rgba(255,255,255,.025))}.copy-message{width:100%;min-height:178px;resize:vertical;line-height:1.65;background:rgba(0,0,0,.28);border-color:rgba(31,190,119,.25);color:#fff}.copy-status{margin:10px 0 0;color:#7ef0b9!important;font-weight:800}
@media(max-width:760px){.copy-card .section-row .btn{width:100%}.copy-message{min-height:210px}}

/* v14 security/settings/backup additions */
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.full-field{grid-column:1/-1}.secret-box{padding:16px;border:1px solid rgba(255,255,255,.16);border-radius:18px;background:rgba(0,0,0,.28);font-family:Consolas,monospace;font-weight:900;letter-spacing:2px;word-break:break-all;color:#fff}.checklist-ok{color:var(--ok)}.checklist-warn{color:var(--red2)}.form-grid textarea{min-height:120px}.card code{color:#ffd4d8}
@media(max-width:900px){.grid-2{grid-template-columns:1fr}.secret-box{font-size:14px;letter-spacing:1px}}


/* v15 renewal request status for members */
.renewal-latest-card{border-color:rgba(255,176,32,.28)}
.status-help{margin-top:14px;padding:14px 16px;border-radius:16px;border:1px solid rgba(255,255,255,.12);line-height:1.65}
.pending-help{background:rgba(255,176,32,.09);border-color:rgba(255,176,32,.35);color:#ffd37a}
.approved-help{background:rgba(31,190,119,.09);border-color:rgba(31,190,119,.35);color:#9ff2ca}
.rejected-help{background:rgba(229,9,20,.11);border-color:rgba(229,9,20,.38);color:#ffb1b8}
.renewal-timeline{display:grid;gap:18px}.renewal-card{margin:0}.renewal-card.status-pending{border-color:rgba(255,176,32,.28)}.renewal-card.status-approved{border-color:rgba(31,190,119,.28)}.renewal-card.status-rejected{border-color:rgba(229,9,20,.32)}
.renewal-detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:16px}.renewal-detail-grid>div{padding:14px;border:1px solid rgba(255,255,255,.09);border-radius:16px;background:rgba(0,0,0,.18)}.renewal-detail-grid span{display:block;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px}.renewal-detail-grid strong{display:block;color:#fff;word-break:break-word}.text-danger{color:var(--red2)}
@media(max-width:900px){.renewal-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.renewal-detail-grid,.grid-4{grid-template-columns:1fr}.renewal-card .section-row{align-items:stretch}.renewal-card .badge{justify-content:center}}


.bank-payment-card{border-color:rgba(255,255,255,.12)}
.bank-box{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start;margin-top:14px}
.bank-info h3{font-size:1.25rem;margin:4px 0 10px;color:#fff}
.bank-info p{margin:7px 0;line-height:1.65}
.bank-image-wrap{display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.09);border-radius:20px;padding:14px;min-height:170px}
.bank-image{display:block;max-width:100%;max-height:360px;object-fit:contain;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#fff}
.copyable-text{font-size:1.12rem;letter-spacing:.04em;color:#fff;background:rgba(229,9,20,.14);border:1px solid rgba(229,9,20,.28);padding:4px 9px;border-radius:10px;display:inline-block}
.empty-state{width:100%;min-height:120px;display:grid;place-items:center;text-align:center;color:var(--muted);border:1px dashed rgba(255,255,255,.16);border-radius:16px;padding:16px}
.check-line{display:flex;align-items:center;gap:8px;color:var(--muted)}
.check-line input{width:auto}
@media (max-width: 820px){.bank-box{grid-template-columns:1fr}.bank-image{max-height:300px}.copyable-text{font-size:1rem;word-break:break-all}}

.action-stack{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.mt-12{margin-top:12px}
.badge-danger{background:rgba(239,68,68,.16);color:#fecaca;border-color:rgba(239,68,68,.45)}
@media (max-width:700px){.action-stack{align-items:stretch}.action-stack .btn{width:100%}}


/* v20: Admin overview, filters, toast, confirm modal, and mobile card tables */
.stat-card.warn{border-color:rgba(255,176,32,.28)}
.stat-card.warn strong{color:#ffd37a;text-shadow:0 0 22px rgba(255,176,32,.22)}
.overview-grid{margin-bottom:18px}.compact-filter{display:grid;grid-template-columns:auto 120px auto;align-items:end;gap:8px;max-width:420px}.compact-filter label{color:var(--muted);font-weight:800}.member-filter-form{display:grid;grid-template-columns:minmax(220px,1fr) 180px 180px auto auto;gap:10px;margin-bottom:10px}.compact-table td,.compact-table th{padding:12px}.days-pill{display:inline-flex;align-items:center;justify-content:center;min-width:64px;padding:7px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.055);font-weight:900;color:#fff}.days-pill.warn{background:rgba(255,176,32,.13);border-color:rgba(255,176,32,.45);color:#ffd37a}.days-pill.critical{background:rgba(229,9,20,.18);border-color:rgba(255,49,64,.6);color:#ffd4d8;box-shadow:0 0 0 1px rgba(229,9,20,.08),0 0 24px rgba(229,9,20,.18)}.urgent-row{background:rgba(229,9,20,.07)!important}.critical-expiry{background:linear-gradient(180deg,rgba(229,9,20,.18),rgba(255,255,255,.025))!important;border-color:rgba(255,49,64,.56)!important}.renew-now-btn{margin-top:12px}.expiry-alert{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.expiry-alert .btn{width:auto}
.toast-stack{position:fixed;right:18px;top:92px;z-index:9999;display:grid;gap:10px;width:min(380px,calc(100vw - 28px));pointer-events:none}.toast{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;pointer-events:auto;opacity:0;transform:translateY(-8px);transition:opacity .22s ease,transform .22s ease;padding:14px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:rgba(17,17,22,.96);box-shadow:0 18px 54px rgba(0,0,0,.38);backdrop-filter:blur(12px);line-height:1.45}.toast.show{opacity:1;transform:none}.toast button{width:auto;min-height:0;padding:0 4px;border:0;background:transparent;color:#fff;font-size:20px;line-height:1;cursor:pointer}.toast-ok{border-color:rgba(31,190,119,.38)}.toast-ok span{color:#a8f4cf}.toast-error{border-color:rgba(229,9,20,.46)}.toast-error span{color:#ffc2c7}
.confirm-modal{position:fixed;inset:0;z-index:9998;display:none;align-items:center;justify-content:center;padding:18px}.confirm-modal.open{display:flex}.confirm-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(5px)}.confirm-modal-panel{position:relative;width:min(440px,100%);border:1px solid rgba(255,255,255,.14);border-radius:24px;background:linear-gradient(180deg,#191920,#0d0d12);box-shadow:0 26px 90px rgba(0,0,0,.56);padding:22px}.confirm-modal-panel h3{margin:0 0 10px}.confirm-modal-panel p{margin:0;color:var(--muted);line-height:1.65}.confirm-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}.confirm-actions .btn{width:auto;min-width:110px}
@media(max-width:980px){.member-filter-form{grid-template-columns:1fr 1fr}.member-filter-form .btn{width:100%}.compact-filter{grid-template-columns:1fr 120px}.compact-filter .btn{grid-column:1/-1}}
@media(max-width:720px){.toast-stack{top:78px;right:10px;width:calc(100vw - 20px)}.confirm-actions{display:grid}.confirm-actions .btn{width:100%}.member-filter-form,.compact-filter{grid-template-columns:1fr}.expiry-alert .btn{width:100%}table.responsive-table,table.compact-table{min-width:0!important;border-spacing:0}table.responsive-table thead,table.compact-table thead{display:none}table.responsive-table tbody,table.compact-table tbody{display:grid;gap:12px}table.responsive-table tr,table.compact-table tr{display:block;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:rgba(255,255,255,.035);padding:10px}table.responsive-table td,table.compact-table td{display:grid;grid-template-columns:118px 1fr;gap:10px;align-items:start;border:0!important;padding:9px 4px!important;word-break:break-word}table.responsive-table td::before,table.compact-table td::before{content:attr(data-label);color:var(--muted);font-weight:900;font-size:12px;text-transform:none}table.responsive-table td.center,table.compact-table td.center{display:block;text-align:center}.mini-row{display:grid;gap:8px}.mini-row .btn{width:100%}}

/* ==========================================================
   v21 Premium Dashboard Redesign - UI/UX + Page Structure
   ========================================================== */
:root{
  --v21-bg:#06070a;
  --v21-bg2:#0a0d12;
  --v21-panel:rgba(18,20,27,.78);
  --v21-panel2:rgba(25,28,36,.86);
  --v21-line:rgba(255,255,255,.105);
  --v21-line-strong:rgba(255,255,255,.18);
  --v21-text:#f7f8fb;
  --v21-muted:#9aa1ad;
  --v21-red:#e50914;
  --v21-red2:#ff2736;
  --v21-green:#37d67a;
  --v21-yellow:#ffc247;
  --v21-shadow:0 24px 80px rgba(0,0,0,.42);
  --v21-radius:22px;
}
body.admin-body{background:
  radial-gradient(circle at 16% -4%, rgba(229,9,20,.23), transparent 32%),
  radial-gradient(circle at 88% 4%, rgba(255,255,255,.075), transparent 28%),
  linear-gradient(135deg,#050608 0%,#090b10 48%,#020204 100%);
  color:var(--v21-text); overflow-x:hidden;
}
.admin-body a{color:inherit}.app-shell{min-height:100vh;display:grid;grid-template-columns:264px minmax(0,1fr)}.app-sidebar{position:sticky;top:0;height:100vh;padding:28px 18px;border-right:1px solid var(--v21-line);background:linear-gradient(180deg,rgba(14,17,23,.93),rgba(5,7,11,.96));box-shadow:18px 0 70px rgba(0,0,0,.28);display:flex;flex-direction:column;gap:22px}.sidebar-brand{display:grid;gap:3px;padding:0 12px 16px}.sidebar-logo{font-size:30px;font-weight:1000;letter-spacing:-1.5px}.sidebar-logo span,.brand-text span{color:var(--v21-red2)}.sidebar-brand small{color:#c4c8d0;letter-spacing:2px;font-size:12px}.sidebar-menu{display:grid;gap:8px}.sidebar-menu a{height:48px;display:flex;align-items:center;gap:13px;padding:0 14px;border-radius:15px;color:#dce0e8;border:1px solid transparent;font-weight:800}.sidebar-menu a:hover{background:rgba(255,255,255,.055);border-color:var(--v21-line)}.sidebar-menu a.active{background:linear-gradient(135deg,rgba(229,9,20,.96),rgba(110,11,17,.88));box-shadow:0 12px 30px rgba(229,9,20,.28);color:#fff}.menu-icon{width:26px;display:grid;place-items:center;font-size:18px}.sidebar-package{margin-top:auto;border:1px solid var(--v21-line);border-radius:20px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025));padding:18px;display:grid;gap:8px;box-shadow:var(--v21-shadow)}.sidebar-package .crown{font-size:24px;color:#ffd268}.sidebar-package span,.sidebar-package small{color:var(--v21-muted)}.sidebar-package strong{font-size:17px}.app-main{min-width:0}.admin-topbar{position:sticky;top:0;z-index:50;min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 36px;background:rgba(5,7,11,.72);backdrop-filter:blur(18px);border-bottom:1px solid var(--v21-line)}.admin-menu-button{display:none;border:1px solid var(--v21-line);background:rgba(255,255,255,.06);color:#fff;border-radius:14px;width:44px;height:44px}.admin-search{width:min(520px,42vw);height:46px;border:1px solid var(--v21-line);border-radius:16px;background:rgba(255,255,255,.045);display:flex;align-items:center;gap:10px;padding:0 14px}.admin-search span{color:#cbd0d9}.admin-search input{border:0;background:transparent;padding:0;border-radius:0;box-shadow:none}.admin-account{display:flex;align-items:center;gap:12px}.notify-bell{position:relative;font-size:19px}.notify-bell em{position:absolute;top:-10px;right:-10px;min-width:18px;height:18px;display:grid;place-items:center;border-radius:50%;background:var(--v21-red);font-size:10px;font-style:normal;font-weight:900}.avatar{width:43px;height:43px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(145deg,#4b4f59,#161920);border:1px solid var(--v21-line-strong);font-weight:1000}.account-text{display:grid;line-height:1.1}.account-text small{color:var(--v21-muted)}.admin-container{width:min(1390px,calc(100vw - 320px));margin:0 auto;padding:34px 28px 76px}.admin-container .page-head{margin-bottom:20px}.admin-container .page-head h1{font-size:clamp(30px,3vw,46px);letter-spacing:-1.3px;margin:0 0 8px;line-height:1.05}.admin-container .page-head p{margin:0;color:var(--v21-muted)}.admin-container .card,.admin-container .stat-card,.admin-container .login-card{background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.032));border:1px solid var(--v21-line);border-radius:var(--v21-radius);box-shadow:var(--v21-shadow);backdrop-filter:blur(18px)}.admin-container .card{padding:22px}.admin-container .stat-card{position:relative;overflow:hidden;min-height:122px;padding:22px}.admin-container .stat-card:before{content:"";position:absolute;right:-24px;top:-28px;width:96px;height:96px;border-radius:50%;background:radial-gradient(circle,rgba(229,9,20,.28),transparent 68%)}.admin-container .stat-card span{font-size:13px;letter-spacing:0;text-transform:none;color:#b7bdc8}.admin-container .stat-card strong{font-size:34px;line-height:1}.overview-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:14px}.grid-2{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(330px,.65fr);gap:18px}.btn{border-radius:14px;font-weight:900;min-height:42px}.btn.primary{background:linear-gradient(135deg,var(--v21-red2),#9b040c);box-shadow:0 14px 36px rgba(229,9,20,.28)}.btn.ghost{background:rgba(255,255,255,.055);border:1px solid var(--v21-line)}.btn.danger-btn{background:linear-gradient(135deg,#a90c15,#5d080f)}.alert-expiry,.expiry-alert{display:flex;align-items:center;justify-content:space-between;gap:14px;border-color:rgba(255,39,54,.65)!important;background:linear-gradient(90deg,rgba(229,9,20,.36),rgba(109,6,13,.46))!important;color:#fff!important}.premium-alert{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid rgba(255,39,54,.7);background:linear-gradient(90deg,rgba(229,9,20,.42),rgba(80,8,14,.42));border-radius:22px;padding:18px 22px;box-shadow:0 20px 60px rgba(229,9,20,.18);margin:18px 0}.premium-alert .alert-icon{width:54px;height:54px;border-radius:18px;background:rgba(229,9,20,.75);display:grid;place-items:center;font-size:25px;box-shadow:0 12px 38px rgba(229,9,20,.35)}.premium-alert h3{margin:0 0 3px;font-size:18px}.premium-alert p{margin:0;color:#ffdfe2}.filter-pills{display:flex;gap:8px;flex-wrap:wrap}.filter-pills a,.filter-pills button{padding:10px 14px;border-radius:13px;background:rgba(255,255,255,.06);border:1px solid var(--v21-line);font-weight:800;color:#dce0e8}.filter-pills a.active,.filter-pills button.active{background:linear-gradient(135deg,var(--v21-red),#8f050d);color:#fff;box-shadow:0 10px 28px rgba(229,9,20,.22)}.search-form,.member-filter-form,.compact-filter{background:rgba(255,255,255,.025);border:1px solid var(--v21-line);padding:10px;border-radius:18px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.member-filter-form input,.member-filter-form select,.compact-filter input{min-width:160px;max-width:260px}.search-form input:first-child{min-width:min(440px,100%)}.table-scroll{border:1px solid var(--v21-line);border-radius:20px;overflow:hidden;background:rgba(4,6,9,.3)}.admin-container table{min-width:840px;border-collapse:collapse}.admin-container th{background:rgba(255,255,255,.04);color:#dfe3eb;text-transform:none;letter-spacing:0;font-size:13px}.admin-container td,.admin-container th{border-bottom:1px solid rgba(255,255,255,.075);padding:13px 12px}.admin-container tbody tr:hover{background:rgba(255,255,255,.035)}.urgent-row{background:linear-gradient(90deg,rgba(229,9,20,.13),transparent)!important}.days-pill{display:inline-flex;align-items:center;justify-content:center;min-width:58px;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.075);font-weight:1000}.days-pill.warn{background:rgba(255,194,71,.14);color:var(--v21-yellow)}.days-pill.critical{background:rgba(229,9,20,.18);color:#ff6b75;border:1px solid rgba(255,39,54,.38)}.badge{border-radius:999px;background:rgba(255,255,255,.06)}.badge-super{border-color:rgba(255,194,71,.5);color:#ffd268}.copy-card{border-color:rgba(255,39,54,.35)!important}.copy-message{background:#080a0e;border:1px solid rgba(255,39,54,.28);min-height:160px;color:#fff;line-height:1.7}.toast-stack{position:fixed;right:24px;top:24px;z-index:9999;display:grid;gap:12px;pointer-events:none}.toast{pointer-events:auto;min-width:300px;max-width:min(420px,calc(100vw - 32px));display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:18px;padding:16px 18px;box-shadow:0 20px 60px rgba(0,0,0,.34);opacity:0;transform:translateY(-8px);transition:.22s}.toast.show{opacity:1;transform:translateY(0)}.toast-ok{background:linear-gradient(135deg,rgba(26,109,58,.96),rgba(14,48,31,.96));border:1px solid rgba(119,239,173,.48);color:#eafff2}.toast-error{background:linear-gradient(135deg,rgba(123,14,23,.96),rgba(54,9,14,.96));border:1px solid rgba(255,103,113,.48);color:#fff}.toast button{border:0;background:transparent;color:inherit;font-size:22px;cursor:pointer}.confirm-modal,.image-modal{position:fixed;inset:0;z-index:9998;display:none;align-items:center;justify-content:center;padding:22px}.confirm-modal.open,.image-modal.open{display:flex}.confirm-modal-backdrop,.image-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(8px)}.confirm-modal-panel,.image-modal-panel{position:relative;width:min(94vw,520px);border:1px solid var(--v21-line-strong);border-radius:24px;background:linear-gradient(180deg,rgba(25,29,38,.98),rgba(10,12,17,.98));box-shadow:0 35px 110px rgba(0,0,0,.62);padding:26px}.confirm-modal-panel h3{margin-top:0;font-size:22px}.confirm-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.image-modal-panel{width:min(94vw,780px);padding:16px}.image-modal-panel img{display:block;max-width:100%;max-height:84vh;margin:auto;border-radius:18px}.image-modal-close{position:absolute;right:10px;top:10px;width:38px;height:38px;border-radius:50%;border:1px solid var(--v21-line);background:#111;color:#fff;font-size:22px;cursor:pointer}.admin-container details summary{cursor:pointer;display:inline-flex;align-items:center;padding:8px 12px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid var(--v21-line);font-weight:900}.admin-container details[open] summary{margin-bottom:10px}.mini-form{background:rgba(0,0,0,.25);border:1px solid var(--v21-line);border-radius:16px;padding:12px}.mini-row{display:flex;gap:8px}.mini-row input{min-width:120px}.bank-widget,.side-widget{display:grid;gap:14px}.bank-widget .account-number{font-size:30px;color:var(--v21-red2);font-weight:1000;letter-spacing:1px}.bank-logo{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:#fff;color:#158046;border:5px solid #ef1a26;font-size:31px}.mobile-preview-card{display:none}.admin-body .topbar{display:none}.site-body .brand-text strong{font-size:18px;letter-spacing:-.4px}.site-body .container{width:min(1180px,92vw)}.site-body .stat-card{min-height:120px}.member-hero{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:stretch}.member-status-card{background:linear-gradient(135deg,rgba(229,9,20,.26),rgba(255,255,255,.045));border:1px solid rgba(255,39,54,.36);border-radius:26px;padding:24px;box-shadow:var(--v21-shadow)}.member-status-card.healthy{background:linear-gradient(135deg,rgba(35,155,94,.18),rgba(255,255,255,.045));border-color:rgba(83,210,143,.28)}

@media (max-width:1180px){.app-shell{grid-template-columns:1fr}.app-sidebar{position:fixed;z-index:80;left:0;top:0;transform:translateX(-104%);transition:.22s;width:min(300px,88vw)}body.sidebar-open .app-sidebar{transform:translateX(0)}.admin-menu-button{display:grid;place-items:center}.admin-container{width:min(100vw,100%);padding:24px 16px 70px}.admin-topbar{padding:14px 16px}.admin-search{width:100%;max-width:480px}.overview-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-2{grid-template-columns:1fr}.admin-account .account-text{display:none}}
@media (max-width:760px){.admin-topbar{gap:10px}.admin-search{display:none}.admin-account{margin-left:auto}.admin-container .page-head h1{font-size:30px}.overview-grid,.grid-4,.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}.premium-alert{align-items:flex-start;flex-direction:column}.premium-alert .btn{width:100%}.member-filter-form input,.member-filter-form select,.compact-filter input{max-width:none;width:100%}.search-form,.member-filter-form,.compact-filter{display:grid;grid-template-columns:1fr}.admin-container table.responsive-table,.admin-container table.compact-table{min-width:0}.admin-container table.responsive-table thead,.admin-container table.compact-table thead{display:none}.admin-container table.responsive-table,.admin-container table.responsive-table tbody,.admin-container table.compact-table,.admin-container table.compact-table tbody{display:grid;gap:12px}.admin-container table.responsive-table tr,.admin-container table.compact-table tr{display:block;border:1px solid var(--v21-line);border-radius:18px;background:rgba(255,255,255,.04);padding:10px}.admin-container table.responsive-table td,.admin-container table.compact-table td{display:grid;grid-template-columns:110px minmax(0,1fr);gap:10px;border:0;padding:8px 4px;word-break:break-word}.admin-container table.responsive-table td:before,.admin-container table.compact-table td:before{content:attr(data-label);color:var(--v21-muted);font-weight:900}.mini-row{display:grid}.mini-row .btn{width:100%}.toast-stack{right:12px;top:12px}.toast{min-width:0}.member-hero{grid-template-columns:1fr}.packages{grid-template-columns:1fr}}
@media (max-width:480px){.overview-grid,.grid-4,.grid-3{grid-template-columns:1fr}.admin-container{padding-inline:12px}.admin-container .card{padding:16px}.admin-container .stat-card strong{font-size:28px}.sidebar-logo{font-size:26px}.topbar{padding-inline:14px}.topnav{display:none}.topnav.open{display:grid;position:absolute;top:68px;left:12px;right:12px;padding:14px;background:#101217;border:1px solid var(--v21-line);border-radius:18px}.nav-toggle{display:inline-flex}.hero-copy h1,.page-head h1{font-size:34px}}

/* v22 premium member dashboard redesign */
.member-dashboard-v22{display:grid;gap:18px;margin-bottom:42px}.member-welcome-panel{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:28px;border:1px solid rgba(255,255,255,.11);border-radius:30px;background:radial-gradient(circle at 12% 20%,rgba(229,9,20,.20),transparent 28%),linear-gradient(135deg,rgba(255,255,255,.075),rgba(255,255,255,.026));box-shadow:0 24px 80px rgba(0,0,0,.35)}.member-welcome-panel:after{content:"";position:absolute;right:-80px;top:-100px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(229,9,20,.22),transparent 66%);pointer-events:none}.member-welcome-panel h1{font-size:clamp(30px,4vw,52px);line-height:1.02;letter-spacing:-1.4px;margin:4px 0 8px}.member-welcome-panel p{margin:0;color:#c9ced8;max-width:620px}.welcome-actions{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:2}.member-red-alert{display:flex;align-items:center;gap:16px;padding:18px 20px;border:1px solid rgba(255,49,64,.62);border-radius:24px;background:linear-gradient(90deg,rgba(229,9,20,.35),rgba(84,7,12,.42));box-shadow:0 18px 60px rgba(229,9,20,.16)}.member-red-alert .alert-symbol{width:48px;height:48px;border-radius:17px;display:grid;place-items:center;background:linear-gradient(135deg,#ff2130,#9b040c);font-weight:1000;font-size:26px;box-shadow:0 12px 34px rgba(229,9,20,.32)}.member-red-alert strong{display:block;font-size:18px}.member-red-alert p{margin:2px 0 0;color:#ffdce0}.member-red-alert .btn{margin-left:auto;white-space:nowrap}.member-layout-v22{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(280px,.45fr);gap:18px}.member-status-hero{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.11);border-radius:30px;background:linear-gradient(135deg,rgba(255,255,255,.085),rgba(255,255,255,.026));box-shadow:0 24px 90px rgba(0,0,0,.36);padding:28px}.member-status-hero:before{content:"";position:absolute;right:-90px;bottom:-120px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(229,9,20,.18),transparent 68%)}.member-status-hero.ok:before{background:radial-gradient(circle,rgba(66,211,132,.18),transparent 68%)}.member-status-hero.warn:before{background:radial-gradient(circle,rgba(255,190,68,.18),transparent 68%)}.status-topline{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;position:relative;z-index:1}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border-radius:999px;font-size:13px;font-weight:1000;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06)}.status-badge.ok{color:#9ff2bd;border-color:rgba(92,227,144,.35);background:rgba(36,166,92,.14)}.status-badge.warn{color:#ffd47c;border-color:rgba(255,194,71,.42);background:rgba(255,177,32,.12)}.status-badge.danger{color:#ffb9bf;border-color:rgba(255,49,64,.52);background:rgba(229,9,20,.15)}.days-display{display:flex;align-items:end;gap:14px;margin-bottom:18px;position:relative;z-index:1}.days-display strong{font-size:clamp(76px,12vw,128px);line-height:.82;letter-spacing:-5px}.days-display span{font-size:20px;color:#d8dde6;font-weight:900;margin-bottom:12px}.member-progress{height:14px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10);overflow:hidden;margin:18px 0 22px;position:relative;z-index:1}.member-progress i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#e50914,#ff4b55);box-shadow:0 0 24px rgba(229,9,20,.35)}.member-status-hero.ok .member-progress i{background:linear-gradient(90deg,#2fbf74,#75e29d);box-shadow:0 0 24px rgba(47,191,116,.28)}.member-status-hero.warn .member-progress i{background:linear-gradient(90deg,#ffb020,#ffe08a);box-shadow:0 0 24px rgba(255,176,32,.28)}.status-meta-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;position:relative;z-index:1}.status-meta-grid div{padding:14px;border:1px solid rgba(255,255,255,.10);border-radius:18px;background:rgba(0,0,0,.22);min-width:0}.status-meta-grid span{display:block;color:#aeb5c2;font-size:12px;font-weight:900;margin-bottom:5px}.status-meta-grid strong{display:block;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hero-button-grid{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px;position:relative;z-index:1}.member-side-stack{display:grid;gap:18px}.mini-status-card{border:1px solid rgba(255,255,255,.11);border-radius:26px;background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.026));box-shadow:0 20px 70px rgba(0,0,0,.28);padding:22px;display:grid;gap:8px;align-content:start}.mini-status-card.dark{background:linear-gradient(180deg,rgba(12,14,20,.94),rgba(7,8,12,.94))}.mini-status-card span{color:#aeb5c2;font-weight:900;font-size:13px}.mini-status-card strong{font-size:24px;line-height:1.15}.mini-status-card p{margin:0;color:#c7cdd7}.member-card-v22{border:1px solid rgba(255,255,255,.11);border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.026));box-shadow:0 24px 90px rgba(0,0,0,.32);padding:24px}.latest-request.pending{border-color:rgba(255,194,71,.24)}.latest-request.approved{border-color:rgba(92,227,144,.24)}.latest-request.rejected{border-color:rgba(255,49,64,.34)}.request-timeline{display:grid;grid-template-columns:auto 1fr auto 1fr auto;gap:10px;align-items:center;margin:22px 0}.timeline-step{display:flex;align-items:center;gap:9px;color:#9da5b3;font-weight:900;white-space:nowrap}.timeline-step i{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);font-style:normal}.timeline-step.active{color:#fff}.timeline-step.active i{background:linear-gradient(135deg,#e50914,#9b040c);border-color:rgba(255,49,64,.5);box-shadow:0 10px 28px rgba(229,9,20,.22)}.timeline-line{height:3px;border-radius:999px;background:rgba(255,255,255,.09)}.timeline-line.active{background:linear-gradient(90deg,#e50914,#ff4b55)}.member-quick-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.quick-action-card{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.11);border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.026));box-shadow:0 18px 70px rgba(0,0,0,.28);padding:20px;color:#fff;display:grid;gap:7px;min-height:132px}.quick-action-card:after{content:"";position:absolute;right:-46px;top:-50px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.09),transparent 66%)}.quick-action-card.red{border-color:rgba(255,49,64,.38);background:linear-gradient(135deg,rgba(229,9,20,.23),rgba(255,255,255,.028))}.quick-action-card span{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:rgba(255,255,255,.08);font-size:22px}.quick-action-card.red span{background:linear-gradient(135deg,#e50914,#9b040c);box-shadow:0 12px 34px rgba(229,9,20,.26)}.quick-action-card strong{font-size:19px}.quick-action-card small{color:#b9c0cc;font-weight:700}.member-history-table-wrap{border-radius:22px}.member-history-table{min-width:760px}.member-dashboard-v22 .section-row h2{margin-bottom:4px}.member-dashboard-v22 .btn{border-radius:15px}.member-dashboard-v22 .badge{font-weight:1000}
@media(max-width:980px){.member-layout-v22{grid-template-columns:1fr}.member-side-stack{grid-template-columns:1fr 1fr}.status-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.member-welcome-panel{align-items:flex-start;flex-direction:column}.member-red-alert{align-items:flex-start;flex-direction:column}.member-red-alert .btn{margin-left:0;width:100%}.member-quick-actions{grid-template-columns:1fr}}
@media(max-width:720px){.member-dashboard-v22{gap:14px}.member-welcome-panel,.member-status-hero,.member-card-v22{border-radius:22px;padding:18px}.member-welcome-panel h1{font-size:34px}.welcome-actions,.hero-button-grid{display:grid;width:100%}.welcome-actions .btn,.hero-button-grid .btn{width:100%}.days-display{display:grid;gap:2px}.days-display strong{font-size:88px;letter-spacing:-4px}.days-display span{margin:0;font-size:18px}.status-meta-grid{grid-template-columns:1fr}.member-side-stack{grid-template-columns:1fr}.request-timeline{grid-template-columns:1fr;gap:9px}.timeline-line{height:22px;width:3px;margin-left:14px}.timeline-step{white-space:normal}.member-history-table{min-width:0!important}.member-dashboard-v22 table.responsive-table thead{display:none}.member-dashboard-v22 table.responsive-table,.member-dashboard-v22 table.responsive-table tbody{display:grid;gap:12px}.member-dashboard-v22 table.responsive-table tr{display:block;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:rgba(255,255,255,.04);padding:10px}.member-dashboard-v22 table.responsive-table td{display:grid;grid-template-columns:105px minmax(0,1fr);gap:10px;border:0!important;padding:8px 4px!important}.member-dashboard-v22 table.responsive-table td:before{content:attr(data-label);color:#aeb5c2;font-weight:900}.member-dashboard-v22 table.responsive-table td.center{display:block;text-align:center}}

/* ===== v24 Light Accessible UI: clearer for seniors, mobile and iPad ===== */
:root{
  --bg:#f6f7fb;
  --panel:#ffffff;
  --panel2:#f9fafc;
  --text:#111827;
  --muted:#5f6b7a;
  --line:#d8dee8;
  --red:#d62828;
  --red2:#b91c1c;
  --white:#ffffff;
  --ok:#15803d;
  --warn:#b45309;
  --blue:#2563eb;
  --soft-red:#fff1f2;
  --soft-green:#ecfdf3;
  --soft-warn:#fffbeb;
  --shadow:0 16px 40px rgba(17,24,39,.08);
  --shadow-soft:0 8px 24px rgba(17,24,39,.06);
  --radius-lg:24px;
  --radius-md:16px;
  --v21-bg:#f6f7fb;
  --v21-panel:#ffffff;
  --v21-panel2:#f9fafc;
  --v21-text:#111827;
  --v21-muted:#5f6b7a;
  --v21-line:#d8dee8;
  --v21-line-strong:#c4ccd8;
  --v21-red:#d62828;
  --v21-red2:#b91c1c;
  --v21-shadow:0 16px 40px rgba(17,24,39,.08);
  --v21-radius:22px;
}
html{font-size:16px;-webkit-text-size-adjust:100%}
body,body.site-body,body.admin-body{
  background:linear-gradient(180deg,#f9fafc 0%,#f3f5f9 48%,#eef2f7 100%)!important;
  color:var(--text)!important;
  line-height:1.65;
  font-size:16px;
}
body::before{opacity:.28;background-image:linear-gradient(rgba(31,41,55,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(31,41,55,.035) 1px,transparent 1px)!important;background-size:32px 32px!important}
a{color:#9f1239}
.muted,.page-head p,.hero-copy p{color:var(--muted)!important}.text-danger{color:var(--red2)!important}
label{color:#374151!important;font-size:16px;font-weight:800;gap:7px}
input,select,textarea{
  min-height:48px;
  border:1px solid #cfd6e2!important;
  background:#fff!important;
  color:#111827!important;
  border-radius:14px!important;
  padding:13px 15px!important;
  box-shadow:0 1px 0 rgba(17,24,39,.02);
}
input::placeholder,textarea::placeholder{color:#8b95a5}
input:focus,select:focus,textarea:focus{border-color:var(--red)!important;box-shadow:0 0 0 4px rgba(214,40,40,.12)!important}

/* global surfaces */
.card,.stat-card,.login-card,.member-card-v22,.member-welcome-panel,.member-status-hero,.mini-status-card,.quick-action-card,.package-card,.renewal-card,.bank-payment-card,.copy-card,.admin-container .card,.admin-container .stat-card,.admin-container .login-card{
  background:#fff!important;
  border:1px solid #dfe5ef!important;
  color:var(--text)!important;
  box-shadow:var(--shadow)!important;
  backdrop-filter:none!important;
}
.card,.login-card,.member-card-v22,.member-status-hero,.member-welcome-panel{border-radius:26px!important}.stat-card{border-radius:22px!important}
.card h1,.card h2,.card h3,.member-card-v22 h2,.member-welcome-panel h1,.page-head h1,.admin-container .page-head h1,.hero-copy h1{color:#111827!important;letter-spacing:-.7px}
.eyebrow{color:#b91c1c!important;letter-spacing:1.4px;font-size:13px;font-weight:1000}

/* buttons and touch targets */
.btn{min-height:46px;border-radius:14px!important;font-size:16px;font-weight:900;padding:12px 18px;color:#111827;background:#eef2f7;border:1px solid #d6deea;box-shadow:none!important}
.btn:hover{transform:translateY(-1px);filter:none;background:#e5eaf2}.btn.small{min-height:40px;padding:9px 13px;font-size:14px}.btn.primary{background:linear-gradient(135deg,#d62828,#b91c1c)!important;color:#fff!important;border-color:#b91c1c!important;box-shadow:0 12px 24px rgba(214,40,40,.18)!important}.btn.ghost{background:#fff!important;border:1px solid #cfd6e2!important;color:#1f2937!important}.btn.danger-btn{background:#b91c1c!important;color:#fff!important;border-color:#991b1b!important}

/* badges and alerts */
.badge,.status-badge,.user-pill{background:#f8fafc!important;border-color:#d4dce8!important;color:#1f2937!important;font-weight:900}.badge.pending{background:#fff7ed!important;border-color:#fdba74!important;color:#9a3412!important}.badge.approved{background:#ecfdf3!important;border-color:#86efac!important;color:#166534!important}.badge.rejected,.badge-danger{background:#fff1f2!important;border-color:#fda4af!important;color:#be123c!important}.badge-super{background:#fff7ed!important;border-color:#f59e0b!important;color:#92400e!important}
.alert{border-radius:18px!important;font-weight:700}.alert-ok{background:#ecfdf3!important;border-color:#86efac!important;color:#166534!important}.alert-error{background:#fff1f2!important;border-color:#fda4af!important;color:#be123c!important}

/* public/member top navigation */
.topbar{background:rgba(255,255,255,.92)!important;border-bottom:1px solid #dfe5ef!important;box-shadow:0 12px 28px rgba(17,24,39,.06);color:#111827!important}.brand,.topnav a,.logout-link{color:#111827!important}.brand-mark{background:linear-gradient(135deg,#d62828,#b91c1c)!important;color:#fff!important;box-shadow:0 10px 22px rgba(214,40,40,.18)!important}.brand-text small{color:#6b7280!important}.brand-text span{color:#d62828!important}.dot{background:#16a34a!important}.nav-toggle{background:#fff!important;color:#111827!important;border:1px solid #cfd6e2!important}
.container{width:min(1180px,calc(100% - 32px));padding-top:30px}.footer{color:#64748b!important;background:#fff;border-top:1px solid #e5eaf2!important}

/* admin shell */
.app-shell{background:transparent!important}.app-sidebar{background:#fff!important;border-right:1px solid #dfe5ef!important;box-shadow:10px 0 28px rgba(17,24,39,.05)!important}.sidebar-logo{color:#111827!important}.sidebar-logo span{color:#d62828!important}.sidebar-brand small,.sidebar-package span,.sidebar-package small{color:#64748b!important}.sidebar-menu a{color:#334155!important;background:transparent!important;border-color:transparent!important}.sidebar-menu a:hover{background:#f3f5f9!important;border-color:#dfe5ef!important}.sidebar-menu a.active{background:linear-gradient(135deg,#d62828,#b91c1c)!important;color:#fff!important;box-shadow:0 12px 24px rgba(214,40,40,.18)!important}.sidebar-package{background:#f8fafc!important;border-color:#dfe5ef!important;box-shadow:var(--shadow-soft)!important}.sidebar-package strong{color:#111827!important}.sidebar-package .crown{color:#b45309!important}.admin-topbar{background:rgba(255,255,255,.92)!important;border-bottom:1px solid #dfe5ef!important;box-shadow:0 12px 28px rgba(17,24,39,.05)!important}.admin-menu-button{background:#fff!important;color:#111827!important;border-color:#cfd6e2!important}.admin-search{background:#fff!important;border-color:#cfd6e2!important}.admin-search span{color:#64748b!important}.admin-account,.admin-body{color:#111827!important}.notify-bell em{background:#d62828!important;color:#fff!important}.avatar{background:#f1f5f9!important;border-color:#cfd6e2!important;color:#d62828!important}.account-text small{color:#64748b!important}.admin-container{color:#111827!important}.admin-container .stat-card:before{background:radial-gradient(circle,rgba(214,40,40,.12),transparent 68%)!important}.admin-container .stat-card span,.stat-card span{color:#64748b!important;text-transform:none!important;letter-spacing:0!important}.admin-container .stat-card strong,.stat-card strong{color:#111827!important}.stat-card.danger strong,.stat-card.danger{color:#b91c1c!important}.stat-card.warn strong,.stat-card.warn{color:#b45309!important}

/* dashboard alert */
.premium-alert,.alert-expiry,.expiry-alert,.member-red-alert{background:#fff1f2!important;border:1px solid #fda4af!important;color:#991b1b!important;box-shadow:0 14px 34px rgba(190,18,60,.08)!important}.premium-alert p,.member-red-alert p{color:#7f1d1d!important}.premium-alert .alert-icon,.member-red-alert .alert-symbol{background:#d62828!important;color:#fff!important;box-shadow:0 10px 22px rgba(214,40,40,.18)!important}

/* member dashboard v24 */
.member-dashboard-v22{gap:22px}.member-welcome-panel{background:linear-gradient(135deg,#ffffff 0%,#fff7f7 100%)!important}.member-welcome-panel:after{background:radial-gradient(circle,rgba(214,40,40,.12),transparent 68%)!important}.member-welcome-panel p{color:#4b5563!important;font-size:17px}.welcome-actions .btn{min-width:168px}.member-status-hero{background:#fff!important}.member-status-hero:before{background:radial-gradient(circle,rgba(214,40,40,.08),transparent 70%)!important}.member-status-hero.ok:before{background:radial-gradient(circle,rgba(22,163,74,.10),transparent 70%)!important}.member-status-hero.warn:before{background:radial-gradient(circle,rgba(245,158,11,.12),transparent 70%)!important}.status-badge.ok{background:#ecfdf3!important;border-color:#86efac!important;color:#166534!important}.status-badge.warn{background:#fffbeb!important;border-color:#fcd34d!important;color:#92400e!important}.status-badge.danger{background:#fff1f2!important;border-color:#fda4af!important;color:#be123c!important}.days-display strong{color:#111827!important}.days-display span{color:#374151!important}.member-status-hero.danger .days-display strong{color:#b91c1c!important}.member-status-hero.warn .days-display strong{color:#b45309!important}.member-status-hero.ok .days-display strong{color:#166534!important}.member-progress{background:#eef2f7!important;border-color:#dfe5ef!important}.member-progress i{background:linear-gradient(90deg,#d62828,#ef4444)!important}.member-status-hero.ok .member-progress i{background:linear-gradient(90deg,#16a34a,#22c55e)!important}.member-status-hero.warn .member-progress i{background:linear-gradient(90deg,#f59e0b,#fbbf24)!important}.status-meta-grid div{background:#f8fafc!important;border-color:#dfe5ef!important}.status-meta-grid span,.mini-status-card span{color:#64748b!important}.status-meta-grid strong,.mini-status-card strong{color:#111827!important}.mini-status-card.dark{background:#f8fafc!important}.mini-status-card p,.quick-action-card small{color:#4b5563!important}.member-quick-actions{gap:16px}.quick-action-card{color:#111827!important;background:#fff!important}.quick-action-card span{background:#f1f5f9!important;color:#d62828!important}.quick-action-card.red{background:linear-gradient(135deg,#fff,#fff1f2)!important;border-color:#fecdd3!important}.quick-action-card.red span{background:#d62828!important;color:#fff!important}.quick-action-card:hover{transform:translateY(-2px);border-color:#d62828!important}.latest-request.pending{background:#fff!important;border-color:#fcd34d!important}.latest-request.approved{background:#fff!important;border-color:#86efac!important}.latest-request.rejected{background:#fff!important;border-color:#fda4af!important}.timeline-step{color:#64748b!important}.timeline-step i{background:#f1f5f9!important;border-color:#d4dce8!important;color:#334155!important}.timeline-step.active{color:#111827!important}.timeline-step.active i{background:#d62828!important;border-color:#d62828!important;color:#fff!important;box-shadow:none!important}.timeline-line{background:#dfe5ef!important}.timeline-line.active{background:#d62828!important}.status-help{border-radius:18px;padding:14px 16px;font-weight:700}.pending-help{background:#fffbeb;color:#92400e;border:1px solid #fcd34d}.approved-help{background:#ecfdf3;color:#166534;border:1px solid #86efac}.rejected-help{background:#fff1f2;color:#be123c;border:1px solid #fda4af}

/* tables and filters */
table{background:#fff!important;color:#111827!important}th{color:#475569!important;background:#f8fafc!important;font-size:13px}td{color:#1f2937!important;border-bottom-color:#e5eaf2!important}.table-scroll{border-radius:18px}.urgent-row{background:#fff1f2!important}.days-pill{display:inline-flex;align-items:center;justify-content:center;min-width:58px;border-radius:999px;padding:6px 10px;font-weight:1000}.days-pill.critical{background:#fff1f2!important;color:#be123c!important;border:1px solid #fda4af}.days-pill.warn{background:#fffbeb!important;color:#92400e!important;border:1px solid #fcd34d}.filter-pills a,.filter-pills button,.tabs a{background:#fff!important;border:1px solid #d4dce8!important;color:#334155!important}.filter-pills a.active,.tabs a.active{background:#d62828!important;color:#fff!important;border-color:#d62828!important}.search-form,.member-filter-form,.compact-filter{background:transparent!important}.copy-card,.copy-message,.copyable-text{background:#fff!important;color:#111827!important;border-color:#dfe5ef!important}.copyable-text,code{color:#1f2937!important;background:#f8fafc!important;border-radius:14px;padding:12px;display:block}

/* renewal, packages and upload */
.package-card{background:#fff!important}.package-card:hover{border-color:#d62828!important;box-shadow:0 14px 30px rgba(214,40,40,.10)!important}.package-card:has(input:checked){border-color:#d62828!important;box-shadow:0 0 0 4px rgba(214,40,40,.12)!important}.package-card:has(input:checked)::after,.package-card.is-confirmed::after{background:#d62828!important}.package-card strong{color:#111827!important}.package-card em{color:#d62828!important}.upload-box{background:#f8fafc!important;border-color:#cbd5e1!important;color:#111827!important}.upload-box:hover{background:#fff1f2!important;border-color:#d62828!important}.confirmed-package-box{background:#fff1f2!important;border-color:#fda4af!important;color:#991b1b!important}.bank-box,.bank-info,.bank-image-wrap{background:#fff!important;border-color:#dfe5ef!important;color:#111827!important}.thumb,.bank-image{border-color:#dfe5ef!important;box-shadow:0 8px 22px rgba(17,24,39,.10)}

/* modal and toast */
.toast{background:#fff!important;color:#111827!important;border-color:#dfe5ef!important;box-shadow:0 16px 38px rgba(17,24,39,.14)!important}.toast button{color:#374151!important}.toast-ok{border-left:5px solid #16a34a!important}.toast-ok span{color:#166534!important}.toast-error{border-left:5px solid #d62828!important}.toast-error span{color:#b91c1c!important}.confirm-modal-backdrop,.image-modal-backdrop{background:rgba(15,23,42,.55)!important}.confirm-modal-panel,.image-modal-panel{background:#fff!important;color:#111827!important;border-color:#dfe5ef!important;box-shadow:0 24px 80px rgba(15,23,42,.22)!important}.confirm-modal-panel p{color:#4b5563!important}.image-modal-close{background:#d62828!important;color:#fff!important;border-color:#d62828!important}

/* login and install */
.login-hero{align-items:center}.hero-copy{background:transparent!important}.login-card{background:#fff!important}.install-wrap{background:#f6f7fb!important}.secret-box{background:#f8fafc!important;border:1px solid #dfe5ef!important;color:#111827!important}

/* responsive: phone / tablet */
@media(max-width:1180px){.overview-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}.grid-2{grid-template-columns:1fr!important}.admin-container{width:100%!important;padding-left:22px!important;padding-right:22px!important}.member-layout-v22{grid-template-columns:1fr!important}.status-meta-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}}
@media(max-width:900px){body{font-size:17px}.app-shell{display:block!important}.app-sidebar{position:fixed!important;z-index:90;left:0;top:0;bottom:0;width:min(86vw,320px);height:100vh;transform:translateX(-105%);transition:transform .22s ease}.sidebar-open .app-sidebar,.app-sidebar.open{transform:translateX(0)}.admin-menu-button{display:grid!important;place-items:center}.admin-topbar{padding:12px 16px!important}.admin-search{display:none!important}.admin-container{padding:20px 14px 60px!important}.account-text{display:none}.overview-grid,.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))!important}.member-quick-actions{grid-template-columns:1fr!important}.packages{grid-template-columns:1fr!important}.topbar{position:sticky!important;align-items:center!important;flex-direction:row!important;padding:12px 16px!important}.topnav{display:none;position:absolute;left:12px;right:12px;top:70px;padding:12px;background:#fff;border:1px solid #dfe5ef;border-radius:18px;box-shadow:var(--shadow);z-index:60;flex-direction:column;align-items:stretch!important}.topnav.open{display:flex}.nav-toggle{display:grid!important;place-items:center;min-width:44px;height:44px}.container{width:calc(100% - 24px)!important;padding-top:20px}.member-welcome-panel{display:grid!important}.welcome-actions{display:grid!important}.welcome-actions .btn{width:100%}.status-meta-grid{grid-template-columns:1fr!important}.days-display strong{font-size:clamp(72px,28vw,112px)!important}.days-display{align-items:flex-start}.member-red-alert{display:grid!important}.member-red-alert .btn{width:100%;margin:0!important}}
@media(max-width:720px){h1{font-size:34px!important}h2{font-size:24px!important}.btn{width:auto;min-height:48px}.actions-row .btn,.hero-actions .btn,.hero-button-grid .btn{width:100%}.overview-grid,.grid-3,.grid-4{grid-template-columns:1fr!important}.admin-account .btn{display:none}.toast-stack{top:auto!important;bottom:14px!important;left:10px!important;right:10px!important;width:auto!important}.member-welcome-panel,.member-status-hero,.member-card-v22,.card,.login-card{padding:18px!important;border-radius:20px!important}.member-dashboard-v22 table.responsive-table tr,.admin-container table.responsive-table tr,.admin-container table.compact-table tr,table.responsive-table tr,table.compact-table tr{background:#fff!important;border:1px solid #dfe5ef!important;box-shadow:var(--shadow-soft);border-radius:18px!important}.member-dashboard-v22 table.responsive-table td,.admin-container table.responsive-table td,.admin-container table.compact-table td,table.responsive-table td,table.compact-table td{grid-template-columns:120px minmax(0,1fr)!important;color:#111827!important}.member-dashboard-v22 table.responsive-table td:before,.admin-container table.responsive-table td:before,.admin-container table.compact-table td:before,table.responsive-table td:before,table.compact-table td:before{color:#64748b!important}.request-timeline{display:grid!important;grid-template-columns:1fr!important}.timeline-line{height:20px!important;width:3px!important;margin-left:14px}.copy-card{font-size:16px}.brand-text small{display:none}}
@media(min-width:901px){.nav-toggle{display:none!important}}

/* v25 SlipOK */
.badge.muted-badge{background:#f1f5f9!important;border-color:#cbd5e1!important;color:#475569!important}
.alert.compact{padding:10px 12px;margin:10px 0;font-size:15px}
.clean-list{display:grid;gap:10px;margin:12px 0 0;padding-left:20px;color:var(--text)}
.toggle-row{display:flex!important;align-items:center;gap:12px;padding:12px 14px;border:1px solid #dfe5ef;border-radius:16px;background:#fff;color:#111827!important}
.toggle-row input{width:22px;height:22px;accent-color:#d62828}
button:disabled,.btn:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(1);transform:none!important}

/* ===== v27 Contrast Balance Fix: readable fonts on every light surface ===== */
:root{
  --readable-bg:#f6f7fb;
  --readable-card:#ffffff;
  --readable-card-soft:#f8fafc;
  --readable-text:#111827;
  --readable-text-2:#1f2937;
  --readable-muted:#4b5563;
  --readable-muted-2:#64748b;
  --readable-border:#d8dee8;
  --readable-border-2:#cbd5e1;
  --readable-red:#d62828;
  --readable-red-dark:#b91c1c;
  --readable-green:#166534;
  --readable-orange:#92400e;
  --readable-blue:#1d4ed8;
}
html,body{background:var(--readable-bg)!important;color:var(--readable-text)!important}
body.site-body,body.admin-body{background:linear-gradient(180deg,#fafbfc 0%,#f4f6fa 55%,#eef2f7 100%)!important;color:var(--readable-text)!important}
body::before{opacity:.18!important}

/* General text contrast */
.container,.admin-container,.app-main,.page-head,.card,.stat-card,.login-card,.member-dashboard-v22,.member-welcome-panel,.member-status-hero,.member-card-v22,.mini-status-card,.quick-action-card,.renewal-card,.package-card,.bank-payment-card,.copy-card,.modal,.confirm-modal-panel,.image-modal-panel,.toast,.sidebar-package{
  color:var(--readable-text)!important;
}
.container p,.admin-container p,.card p,.member-card-v22 p,.member-status-hero p,.page-head p,.renewal-card p,.bank-payment-card p,.copy-card p,
.container li,.admin-container li,.card li,.member-card-v22 li,
.container small,.admin-container small,.card small,.member-card-v22 small,.package-card small,.stat-card span,.mini-status-card span,.status-meta-grid span,
.muted,.help-text,.subtext,.account-text small,.sidebar-brand small,.sidebar-package small{
  color:var(--readable-muted)!important;
}
h1,h2,h3,h4,h5,h6,.page-head h1,.page-head h2,.card h1,.card h2,.card h3,.admin-container h1,.admin-container h2,.admin-container h3,.member-welcome-panel h1,.member-card-v22 h2,.member-status-hero h2{
  color:var(--readable-text)!important;
}
strong,b,.card strong,.admin-container strong,.member-card-v22 strong,.package-card strong,.copy-card strong{color:var(--readable-text)!important}

/* Surfaces */
.card,.stat-card,.login-card,.page-head,.member-welcome-panel,.member-status-hero,.member-card-v22,.mini-status-card,.quick-action-card,.renewal-card,.package-card,.bank-payment-card,.copy-card,.admin-container .card,.admin-container .stat-card{
  background:var(--readable-card)!important;
  border-color:var(--readable-border)!important;
  box-shadow:0 14px 34px rgba(15,23,42,.07)!important;
}
.card::before,.stat-card::before,.login-card::before,.page-head::before{background:linear-gradient(90deg,transparent,rgba(214,40,40,.16),transparent)!important}
.card:hover,.stat-card:hover,.package-card:hover,.quick-action-card:hover{border-color:#cbd5e1!important}

/* Inputs, labels, forms */
label,.form-grid label,.inline-form label,.mini-form label{color:#374151!important;font-weight:900!important}
input,select,textarea,.copy-message,.copyable-text{
  background:#ffffff!important;
  color:var(--readable-text)!important;
  border-color:var(--readable-border-2)!important;
}
input::placeholder,textarea::placeholder{color:#737f90!important}
select option{background:#fff!important;color:#111827!important}
input:disabled,select:disabled,textarea:disabled{background:#eef2f7!important;color:#64748b!important}
.search-form,.member-filter-form,.compact-filter,.admin-search{background:#ffffff!important;border-color:var(--readable-border)!important;color:var(--readable-text)!important}
.admin-search input{background:transparent!important;color:var(--readable-text)!important}
.admin-search span{color:var(--readable-muted)!important}

/* Links and navigation */
a{color:#9f1239!important}.card a,.admin-container a,.container a{color:#9f1239!important}.btn,.btn:visited{color:var(--readable-text)!important}.btn.primary,.btn.primary:visited,.btn.danger-btn,.btn.danger-btn:visited{color:#fff!important}.btn.ghost{color:#1f2937!important;background:#fff!important}
.topbar,.admin-topbar,.app-sidebar{background:#ffffff!important;color:var(--readable-text)!important;border-color:var(--readable-border)!important}
.brand,.brand strong,.brand-text strong,.topnav a,.sidebar-logo,.sidebar-menu a,.admin-account{color:var(--readable-text)!important}
.brand-text span,.sidebar-logo span{color:var(--readable-red)!important}.brand-text small{color:var(--readable-muted)!important}
.sidebar-menu a{color:#334155!important}.sidebar-menu a.active,.sidebar-menu a.active span,.sidebar-menu a.active .menu-icon{color:#fff!important;background:linear-gradient(135deg,var(--readable-red),var(--readable-red-dark))!important}
.logout-link{color:#b91c1c!important}
.user-pill,.avatar,.notify-bell{background:#f8fafc!important;color:#111827!important;border-color:#d8dee8!important}

/* Tables: prevent dark/white text collisions */
.table-scroll,.wide{background:#fff!important;border:1px solid var(--readable-border)!important}
table,table.responsive-table,table.compact-table{background:#ffffff!important;color:var(--readable-text)!important}
thead,thead tr,thead th,th{background:#f1f5f9!important;color:#334155!important;border-bottom-color:var(--readable-border)!important}
tbody,tr,td{background:transparent!important;color:#1f2937!important;border-bottom-color:#e5eaf2!important}
tbody tr:hover{background:#f8fafc!important}
td strong,td b{color:#111827!important}
td .muted,td small{color:#64748b!important}
.urgent-row,tbody tr.urgent-row{background:#fff1f2!important}.urgent-row td{color:#7f1d1d!important}

/* Badges and semantic status */
.badge,.status-badge,.days-pill{background:#f8fafc!important;border-color:#cbd5e1!important;color:#1f2937!important}
.badge.pending,.status-badge.pending{background:#fff7ed!important;border-color:#fdba74!important;color:#9a3412!important}
.badge.approved,.status-badge.approved{background:#ecfdf3!important;border-color:#86efac!important;color:#166534!important}
.badge.rejected,.status-badge.rejected,.badge-danger,.status-badge.danger{background:#fff1f2!important;border-color:#fda4af!important;color:#be123c!important}
.badge-super{background:#fff7ed!important;border-color:#f59e0b!important;color:#92400e!important}
.days-pill.critical{background:#fff1f2!important;color:#be123c!important;border-color:#fda4af!important}.days-pill.warn{background:#fffbeb!important;color:#92400e!important;border-color:#fcd34d!important}
.text-danger,.danger-text,.member-status-hero.danger strong,.member-status-hero.danger .days-display strong{color:#b91c1c!important}.checklist-ok{color:#166534!important}.checklist-warn{color:#b91c1c!important}

/* Alerts */
.alert,.flash-alert{font-weight:800!important}.alert-ok{background:#ecfdf3!important;border-color:#86efac!important;color:#166534!important}.alert-error{background:#fff1f2!important;border-color:#fda4af!important;color:#be123c!important}.premium-alert,.member-red-alert,.alert-expiry,.expiry-alert{background:#fff1f2!important;color:#991b1b!important;border-color:#fda4af!important}.premium-alert p,.member-red-alert p{color:#7f1d1d!important}

/* Member dashboard */
.days-display strong{color:#111827!important}.days-display span{color:#374151!important}.member-status-hero.ok .days-display strong{color:#166534!important}.member-status-hero.warn .days-display strong{color:#92400e!important}.member-status-hero.danger .days-display strong{color:#b91c1c!important}
.status-meta-grid div,.mini-status-card.dark{background:#f8fafc!important;border-color:#dfe5ef!important;color:#111827!important}.quick-action-card span{background:#f1f5f9!important;color:#d62828!important}.quick-action-card.red span{background:#d62828!important;color:#fff!important}
.timeline-step{color:#64748b!important}.timeline-step.active{color:#111827!important}.timeline-step i{background:#f1f5f9!important;color:#334155!important;border-color:#cbd5e1!important}.timeline-step.active i{background:#d62828!important;color:#fff!important;border-color:#d62828!important}.timeline-line{background:#dfe5ef!important}.timeline-line.active{background:#d62828!important}

/* Renewal / upload / bank */
.package-card{background:#fff!important;color:#111827!important}.package-card em{color:#b91c1c!important}.package-card:has(input:checked),.package-card.is-confirmed{border-color:#d62828!important;box-shadow:0 0 0 4px rgba(214,40,40,.12)!important}.package-card:has(input:checked)::after,.package-card.is-confirmed::after{background:#d62828!important;color:#fff!important}
.upload-box{background:#f8fafc!important;color:#111827!important;border-color:#cbd5e1!important}.confirmed-package-box{background:#fff1f2!important;border-color:#fda4af!important;color:#7f1d1d!important}.bank-box,.bank-info,.bank-image-wrap,.bank-payment-card{background:#fff!important;color:#111827!important;border-color:#dfe5ef!important}

/* Copy message and code blocks */
.copy-card{background:#fff!important;border-color:#bbf7d0!important}.copy-message{background:#f8fafc!important;color:#111827!important;border-color:#bbf7d0!important}.copy-status{color:#166534!important}code,pre,.secret-box{background:#f8fafc!important;color:#111827!important;border:1px solid #dfe5ef!important}

/* Modal, image popup and toast */
.toast,.confirm-modal-panel,.image-modal-panel{background:#ffffff!important;color:#111827!important;border-color:#dfe5ef!important}.toast p,.confirm-modal-panel p{color:#4b5563!important}.toast-ok span{color:#166534!important}.toast-error span{color:#b91c1c!important}.image-modal-panel img{background:#f8fafc!important}.confirm-modal-backdrop,.image-modal-backdrop{background:rgba(15,23,42,.56)!important}.image-modal-close{background:#d62828!important;color:#fff!important}

/* Mobile card table contrast */
@media(max-width:720px){
  table.responsive-table tr,table.compact-table tr,.member-dashboard-v22 table.responsive-table tr,.admin-container table.responsive-table tr,.admin-container table.compact-table tr{background:#fff!important;color:#111827!important;border:1px solid #dfe5ef!important;box-shadow:0 8px 22px rgba(15,23,42,.06)!important}
  table.responsive-table td,table.compact-table td,.member-dashboard-v22 table.responsive-table td,.admin-container table.responsive-table td,.admin-container table.compact-table td{background:#fff!important;color:#111827!important;border:0!important}
  table.responsive-table td:before,table.compact-table td:before,.member-dashboard-v22 table.responsive-table td:before,.admin-container table.responsive-table td:before,.admin-container table.compact-table td:before{color:#64748b!important;font-weight:900!important}
  .topnav.open{background:#fff!important;color:#111827!important}.topnav.open a{color:#111827!important}
}

/* ==========================================================
   v28 Mobile First UX Upgrade
   - Bottom navigation
   - Touch-friendly member/admin UI
   - Card tables on phones
   - Step-by-step renewal flow
   - iPad two-column refinement
   ========================================================== */
:root{
  --mobile-bg:#f6f8fc;
  --mobile-card:#ffffff;
  --mobile-text:#111827;
  --mobile-muted:#4b5563;
  --mobile-border:#d8e0ec;
  --mobile-red:#d62828;
  --mobile-red-dark:#b91c1c;
  --mobile-green:#15803d;
  --mobile-orange:#b45309;
  --mobile-blue:#1d4ed8;
  --mobile-shadow:0 12px 36px rgba(15,23,42,.10);
}
.mobile-bottom-nav{display:none}
.mobile-renew-stepper{display:none}
.mobile-sticky-renew{display:none}

@media (min-width:761px) and (max-width:1180px){
  .container{width:min(100% - 32px, 980px)!important}
  .admin-container{padding:24px!important}
  .grid-3,.grid-4,.overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .member-layout-v22{grid-template-columns:1fr!important}
  .member-side-stack{grid-template-columns:repeat(2,minmax(0,1fr));display:grid!important}
  .packages{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .bank-box{grid-template-columns:1fr 320px!important}
  .member-filter-form{grid-template-columns:1fr 160px 160px!important}
  .app-sidebar{width:220px!important}
  .app-main{margin-left:220px!important}
  .responsive-table{font-size:15px}
}

@media (max-width:760px){
  html{font-size:17px}
  body.site-body,body.admin-body{
    background:var(--mobile-bg)!important;
    color:var(--mobile-text)!important;
    padding-bottom:calc(84px + env(safe-area-inset-bottom))!important;
  }
  body.modal-open{overflow:hidden!important}

  /* Global touch comfort */
  a,button,.btn,input,select,textarea,summary{font-size:16px!important}
  .btn,button.btn{
    min-height:50px!important;
    border-radius:16px!important;
    padding:14px 18px!important;
    font-weight:900!important;
    width:100%;
  }
  .btn.small{min-height:44px!important;padding:12px 14px!important;font-size:15px!important}
  input,select,textarea{
    min-height:50px!important;
    border-radius:16px!important;
    padding:14px 16px!important;
    font-size:16px!important;
    background:#fff!important;
    color:#111827!important;
    border-color:#cbd5e1!important;
  }
  input::placeholder,textarea::placeholder{color:#64748b!important}

  /* Mobile topbars */
  .topbar,.admin-topbar{
    position:sticky!important;
    top:0!important;
    z-index:100!important;
    background:rgba(255,255,255,.96)!important;
    border-bottom:1px solid var(--mobile-border)!important;
    box-shadow:0 8px 24px rgba(15,23,42,.08)!important;
    backdrop-filter:blur(14px)!important;
  }
  .topbar{padding:12px 14px!important}
  .admin-topbar{padding:10px 12px!important;gap:10px!important}
  .brand-text small,.admin-account .account-text,.notify-bell,.admin-search{display:none!important}
  .brand-text strong,.brand-text span,.sidebar-logo{color:#111827!important}
  .brand-mark{width:42px!important;height:42px!important;border-radius:14px!important;background:#d62828!important;color:#fff!important}
  .nav-toggle,.admin-menu-button{
    min-width:46px!important;width:46px!important;height:46px!important;
    display:grid!important;place-items:center!important;border-radius:14px!important;
    background:#fff!important;color:#111827!important;border:1px solid var(--mobile-border)!important;
  }
  .topnav.open{
    position:fixed!important;left:12px;right:12px;top:68px;z-index:120;
    display:grid!important;gap:10px!important;background:#fff!important;padding:14px!important;
    border:1px solid var(--mobile-border)!important;border-radius:20px!important;box-shadow:var(--mobile-shadow)!important;
  }
  .topnav.open a,.topnav.open .user-pill{color:#111827!important;background:#f8fafc!important;border-color:#e2e8f0!important;min-height:46px!important}

  /* Admin shell on mobile */
  .app-shell{display:block!important}
  .app-main{margin-left:0!important;width:100%!important}
  .admin-container,.container{
    width:100%!important;
    padding:14px 12px calc(96px + env(safe-area-inset-bottom))!important;
  }
  .app-sidebar{
    position:fixed!important;z-index:130!important;top:0!important;bottom:0!important;left:0!important;
    transform:translateX(-110%)!important;width:min(86vw,320px)!important;
    background:#fff!important;border-right:1px solid var(--mobile-border)!important;
    box-shadow:22px 0 70px rgba(15,23,42,.22)!important;
    padding:18px!important;color:#111827!important;transition:transform .22s ease!important;
  }
  body.sidebar-open .app-sidebar{transform:translateX(0)!important}
  .sidebar-brand small,.sidebar-menu a,.sidebar-package,.sidebar-package small{color:#111827!important}
  .sidebar-menu a{min-height:48px!important;border-radius:16px!important;background:#f8fafc!important;border:1px solid #eef2f7!important}
  .sidebar-menu a.active{background:#d62828!important;color:#fff!important;border-color:#d62828!important}
  .sidebar-menu a.active *{color:#fff!important}

  /* Bottom navigation */
  .mobile-bottom-nav{
    position:fixed;display:grid;grid-template-columns:repeat(5,1fr);left:0;right:0;bottom:0;z-index:110;
    padding:8px 8px calc(8px + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.98);border-top:1px solid #dbe3ef;box-shadow:0 -10px 32px rgba(15,23,42,.12);
  }
  .mobile-bottom-nav a{
    display:grid;place-items:center;gap:2px;min-height:58px;border-radius:16px;color:#4b5563!important;font-weight:900;text-decoration:none!important;
  }
  .mobile-bottom-nav span{font-size:20px;line-height:1;color:inherit!important}
  .mobile-bottom-nav small{font-size:12px;line-height:1.05;color:inherit!important;white-space:nowrap}
  .mobile-bottom-nav a.active{background:#fee2e2;color:#b91c1c!important}

  /* Page/card hierarchy */
  .page-head,.member-welcome-panel,.member-status-hero,.member-card-v22,.mini-status-card,.quick-action-card,.card,.stat-card,.login-card,.bank-payment-card,.renew-form,.renewal-card{
    background:#fff!important;color:#111827!important;border:1px solid var(--mobile-border)!important;border-radius:22px!important;
    box-shadow:var(--mobile-shadow)!important;
  }
  .page-head{padding:18px!important;margin:8px 0 14px!important}
  .page-head h1,.member-welcome-panel h1,.member-card-v22 h2,.card h2{font-size:clamp(24px,7vw,32px)!important;line-height:1.18!important;margin:6px 0!important;color:#111827!important}
  .page-head p,.muted,.member-welcome-panel p,.card p,.mini-status-card p{color:#4b5563!important;line-height:1.65!important}
  .eyebrow{font-size:12px!important;color:#b91c1c!important;letter-spacing:1.2px!important}
  .section-row{align-items:stretch!important;gap:12px!important}
  .section-row>*{width:100%}

  /* Member dashboard: simplify and prioritize */
  .member-dashboard-v22{display:block!important;color:#111827!important}
  .member-welcome-panel{padding:18px!important;margin-bottom:14px!important;display:grid!important;gap:14px!important;background:linear-gradient(180deg,#fff,#f8fafc)!important}
  .welcome-actions{display:grid!important;gap:10px!important}
  .member-red-alert{
    display:grid!important;grid-template-columns:48px 1fr!important;gap:12px!important;align-items:start!important;
    padding:16px!important;border-radius:22px!important;background:#fff1f2!important;border:1px solid #fecdd3!important;color:#7f1d1d!important;box-shadow:var(--mobile-shadow)!important;
  }
  .member-red-alert .btn{grid-column:1/-1!important;background:#dc2626!important;color:#fff!important}
  .alert-symbol{width:48px!important;height:48px!important;border-radius:16px!important;background:#dc2626!important;color:#fff!important;display:grid!important;place-items:center!important;font-size:26px!important;font-weight:900!important}
  .member-layout-v22{display:grid!important;grid-template-columns:1fr!important;gap:14px!important}
  .member-status-hero{padding:18px!important;background:#fff!important;overflow:hidden!important}
  .status-topline{display:flex!important;justify-content:space-between!important;gap:10px!important;align-items:center!important}
  .status-badge{font-size:14px!important;padding:8px 12px!important}
  .days-display{display:grid!important;place-items:center!important;margin:18px 0!important;padding:18px!important;border-radius:24px!important;background:#f8fafc!important;border:1px solid #e2e8f0!important}
  .days-display strong{font-size:clamp(70px,24vw,112px)!important;line-height:.9!important;color:#111827!important;letter-spacing:-3px!important}
  .member-status-hero.danger .days-display strong{color:#dc2626!important}
  .member-status-hero.warn .days-display strong{color:#b45309!important}
  .days-display span{font-size:18px!important;color:#374151!important;font-weight:900!important}
  .member-progress{height:14px!important;background:#e5e7eb!important;border-radius:999px!important;overflow:hidden!important}
  .member-progress i{display:block!important;height:100%!important;background:linear-gradient(90deg,#dc2626,#ef4444)!important;border-radius:999px!important}
  .status-meta-grid{grid-template-columns:1fr!important;gap:10px!important;margin-top:16px!important}
  .status-meta-grid>div{padding:14px!important;border-radius:18px!important;background:#f8fafc!important;border:1px solid #e2e8f0!important}
  .status-meta-grid span{font-size:13px!important;color:#64748b!important;font-weight:900!important}
  .status-meta-grid strong{font-size:17px!important;color:#111827!important;word-break:break-word!important}
  .hero-button-grid,.member-quick-actions{display:grid!important;grid-template-columns:1fr!important;gap:10px!important;margin-top:16px!important}
  .member-side-stack{display:grid!important;gap:12px!important}
  .mini-status-card{padding:16px!important}
  .mini-status-card.dark{background:#f8fafc!important;color:#111827!important}
  .quick-action-card{padding:18px!important;display:grid!important;grid-template-columns:52px 1fr!important;gap:6px 12px!important;align-items:center!important;text-align:left!important}
  .quick-action-card span{grid-row:1/3;width:52px;height:52px;border-radius:18px;display:grid;place-items:center;background:#fee2e2;color:#b91c1c;font-size:24px!important}
  .quick-action-card strong{font-size:18px!important;color:#111827!important}
  .quick-action-card small{color:#4b5563!important;font-size:14px!important}
  .mobile-sticky-renew{
    position:fixed;left:12px;right:12px;bottom:calc(82px + env(safe-area-inset-bottom));z-index:108;
    display:flex;align-items:center;justify-content:center;min-height:54px;border-radius:18px;background:#dc2626!important;color:#fff!important;
    font-weight:1000;box-shadow:0 16px 36px rgba(220,38,38,.32);text-decoration:none!important;
  }

  /* Renewal page: step-by-step for phones */
  .mobile-renew-stepper{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin:8px 0 14px}
  .mobile-renew-stepper .step{display:grid;gap:6px;place-items:center;text-align:center;padding:10px 5px;border-radius:16px;background:#fff;border:1px solid #e2e8f0;color:#4b5563;box-shadow:0 8px 22px rgba(15,23,42,.06)}
  .mobile-renew-stepper .step span{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:#e5e7eb;color:#111827;font-weight:1000}
  .mobile-renew-stepper .step strong{font-size:11px;line-height:1.15;color:#334155}
  .mobile-renew-stepper .step.active{border-color:#fecaca;background:#fff1f2;color:#991b1b}
  .mobile-renew-stepper .step.active span{background:#dc2626;color:#fff}
  .mobile-priority-card{margin-bottom:14px!important}
  .bank-box{grid-template-columns:1fr!important;gap:12px!important}
  .bank-info h3{font-size:22px!important;color:#111827!important}
  .copyable-text{font-size:24px!important;letter-spacing:.04em!important;display:block!important;text-align:center!important;margin-top:8px!important;background:#fff1f2!important;color:#991b1b!important;border-color:#fecaca!important;padding:12px!important;border-radius:18px!important;word-break:break-all!important}
  .bank-image-wrap{background:#f8fafc!important;border-color:#e2e8f0!important}
  .bank-image{max-height:280px!important}
  .renew-form{padding:16px!important}
  .renew-step .section-row{display:grid!important}
  .packages{display:grid!important;grid-template-columns:1fr!important;gap:12px!important}
  .package-card{min-height:0!important;padding:18px!important;border-radius:22px!important;background:#fff!important;border:2px solid #e2e8f0!important;color:#111827!important;box-shadow:0 10px 26px rgba(15,23,42,.06)!important}
  .package-card:has(input:checked),.package-card.is-confirmed{border-color:#dc2626!important;box-shadow:0 0 0 4px rgba(220,38,38,.10)!important;background:#fff7f7!important}
  .pack-name{font-size:20px!important;font-weight:1000!important;color:#111827!important}
  .package-card strong{font-size:32px!important;color:#111827!important}
  .package-card em{font-size:16px!important;color:#b91c1c!important}
  .package-card small{font-size:15px!important;color:#4b5563!important;line-height:1.5!important}
  .confirmed-package-box{display:grid!important;gap:12px!important;padding:16px!important;border-radius:20px!important;background:#f8fafc!important;border:1px solid #e2e8f0!important}
  .renew-slip-panel h2{font-size:24px!important;color:#111827!important}
  .upload-box{display:grid!important;place-items:center!important;min-height:150px!important;text-align:center!important;border:2px dashed #94a3b8!important;background:#f8fafc!important;color:#111827!important;border-radius:22px!important}
  .slip-preview{max-width:100%!important;border-radius:20px!important;margin:14px 0!important;border-color:#e2e8f0!important}

  /* Admin dashboard/cards on phone */
  .grid-3,.grid-4,.overview-grid{grid-template-columns:1fr!important;gap:12px!important}
  .stat-card{display:grid!important;grid-template-columns:54px 1fr!important;gap:10px!important;align-items:center!important;padding:16px!important}
  .stat-card span{font-size:14px!important;color:#4b5563!important;text-transform:none!important;letter-spacing:0!important}
  .stat-card strong{font-size:32px!important;text-align:left!important;color:#111827!important}
  .stat-card::before{content:' ';width:54px;height:54px;border-radius:18px;background:#fee2e2;grid-row:1/3}
  .admin-alert-banner,.expiry-alert{display:grid!important;gap:12px!important;padding:16px!important;border-radius:22px!important;background:#fff1f2!important;border:1px solid #fecaca!important;color:#7f1d1d!important}
  .member-filter-form,.compact-filter,.inline-form,.search-form{grid-template-columns:1fr!important;display:grid!important;gap:10px!important}
  .tabs{display:flex!important;gap:8px!important;overflow-x:auto!important;flex-wrap:nowrap!important;padding-bottom:4px!important;margin-left:-2px;margin-right:-2px}
  .tabs a,.tabs button,.filter-chip{white-space:nowrap!important;min-height:44px!important;padding:12px 14px!important;border-radius:999px!important}

  /* Tables become readable cards */
  .table-scroll{overflow:visible!important}
  table,table.responsive-table,table.compact-table{min-width:0!important;width:100%!important;border-collapse:separate!important;border-spacing:0!important}
  table thead,table.responsive-table thead,table.compact-table thead{display:none!important}
  table tbody,table.responsive-table tbody,table.compact-table tbody{display:grid!important;gap:12px!important}
  table tr,table.responsive-table tr,table.compact-table tr{
    display:block!important;padding:14px!important;border:1px solid #dbe3ef!important;border-radius:22px!important;background:#fff!important;color:#111827!important;box-shadow:0 10px 26px rgba(15,23,42,.06)!important;
  }
  table tr.urgent-row{background:#fff1f2!important;border-color:#fecaca!important}
  table td,table.responsive-table td,table.compact-table td{
    display:grid!important;grid-template-columns:120px minmax(0,1fr)!important;gap:10px!important;align-items:start!important;
    padding:10px 0!important;border:0!important;border-bottom:1px solid #eef2f7!important;background:transparent!important;color:#111827!important;word-break:break-word!important;
  }
  table td:last-child,table.responsive-table td:last-child,table.compact-table td:last-child{border-bottom:0!important}
  table td::before,table.responsive-table td::before,table.compact-table td::before{
    content:attr(data-label)!important;color:#64748b!important;font-weight:1000!important;font-size:13px!important;line-height:1.35!important;
  }
  table td.center{display:block!important;text-align:center!important}
  table td .btn,table td button{width:100%!important;margin:3px 0!important}
  details summary{min-height:46px!important;display:flex!important;align-items:center!important;padding:12px 14px!important;border-radius:14px!important;background:#f1f5f9!important;color:#111827!important;font-weight:900!important;cursor:pointer!important}
  .mini-form,.mini-row{display:grid!important;grid-template-columns:1fr!important;gap:9px!important;min-width:0!important;margin-top:10px!important}
  .mini-row input{min-width:0!important}
  .action-stack{display:grid!important;gap:8px!important;width:100%!important}

  /* Modal/toast fit for phones */
  .toast-stack{top:auto!important;left:10px!important;right:10px!important;bottom:calc(92px + env(safe-area-inset-bottom))!important;width:auto!important}
  .toast{background:#fff!important;color:#111827!important;border-color:#dbe3ef!important;box-shadow:0 18px 46px rgba(15,23,42,.18)!important}
  .toast span{color:#111827!important}.toast button{color:#111827!important}
  .confirm-modal{align-items:flex-end!important;padding:10px!important}
  .confirm-modal-panel{width:100%!important;border-radius:26px 26px 18px 18px!important;background:#fff!important;color:#111827!important;border-color:#dbe3ef!important;padding:22px!important}
  .confirm-modal-panel p{color:#4b5563!important}
  .confirm-actions{display:grid!important;gap:10px!important}
  .image-modal-panel{width:calc(100vw - 20px)!important;max-height:calc(100vh - 120px)!important;background:#fff!important;border-color:#dbe3ef!important}
  .image-modal-panel img{max-height:calc(100vh - 170px)!important;object-fit:contain!important}
  .image-modal-close{background:#111827!important;color:#fff!important}

  /* Login phone */
  .login-hero{grid-template-columns:1fr!important;min-height:0!important;gap:14px!important;padding-top:10px!important}
  .hero-copy{padding:18px!important;background:#fff!important;border:1px solid var(--mobile-border)!important;border-radius:22px!important;box-shadow:var(--mobile-shadow)!important}
  .hero-copy h1{font-size:34px!important;line-height:1.08!important;color:#111827!important}
  .login-card{padding:18px!important}
}

/* v29 Renewal Status Simplification */
.member-dashboard-v29 .simple-member-hero{min-height:0}
.member-home-layout-v29{align-items:stretch}
.compact-member-meta{grid-template-columns:repeat(3,minmax(0,1fr))!important}
.latest-status-v29{gap:12px!important}
.latest-status-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.latest-status-head>span:first-child{color:#64748b!important;font-size:13px;font-weight:1000}
.latest-status-v29>strong{font-size:28px!important;line-height:1.15!important}
.latest-status-grid{display:grid;grid-template-columns:1fr;gap:10px;margin:4px 0}
.latest-status-grid>div{padding:12px 14px;border-radius:16px;background:#f8fafc;border:1px solid #e2e8f0}
.latest-status-grid small{display:block;color:#64748b;font-weight:900;margin-bottom:4px}
.latest-status-grid b{display:block;color:#111827;font-size:15px;line-height:1.35}
.account-security-v29{background:#fff!important}
.member-quick-actions-v29{margin-top:2px}
.history-preview-v29{padding:20px!important}
.mobile-history-list-v29{display:grid;gap:10px;margin-top:14px}
.history-row-v29{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border:1px solid #e2e8f0;border-radius:18px;background:#f8fafc}
.history-row-v29 strong{display:block;color:#111827;font-size:16px}
.history-row-v29 small{display:block;color:#64748b;font-weight:800;margin-top:3px}
.empty-state-v29{padding:20px;border:1px dashed #cbd5e1;border-radius:18px;background:#f8fafc;color:#64748b;font-weight:900;text-align:center}
.renewal-history-v29{display:grid;gap:18px;margin-bottom:40px}
.renewal-history-head-v29{display:flex;align-items:center;justify-content:space-between;gap:18px}
.renewal-history-head-v29 .actions-row{margin:0;flex-shrink:0}
.renewal-summary-grid-v29{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.renewal-summary-card{padding:18px;border:1px solid #e2e8f0;border-radius:22px;background:#fff;box-shadow:0 10px 26px rgba(15,23,42,.06)}
.renewal-summary-card span{display:block;color:#64748b;font-weight:1000;margin-bottom:6px}
.renewal-summary-card strong{display:block;font-size:34px;line-height:1;color:#111827}
.renewal-summary-card.pending{background:#fffbeb;border-color:#fcd34d}.renewal-summary-card.pending strong{color:#92400e}
.renewal-summary-card.approved{background:#ecfdf3;border-color:#86efac}.renewal-summary-card.approved strong{color:#166534}
.renewal-summary-card.rejected{background:#fff1f2;border-color:#fda4af}.renewal-summary-card.rejected strong{color:#be123c}
.latest-history-focus-v29{border-width:2px!important}
.latest-history-focus-v29.status-pending{border-color:#fcd34d!important;background:#fffdf5!important}
.latest-history-focus-v29.status-approved{border-color:#86efac!important;background:#f7fff9!important}
.latest-history-focus-v29.status-rejected{border-color:#fda4af!important;background:#fff7f8!important}
.latest-detail-strip-v29{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:16px 0}
.latest-detail-strip-v29>div{padding:14px;border:1px solid #e2e8f0;border-radius:18px;background:#fff}
.latest-detail-strip-v29 span{display:block;color:#64748b;font-weight:1000;margin-bottom:5px}
.latest-detail-strip-v29 strong{display:block;color:#111827;word-break:break-word}
.renewal-history-list-card-v29{padding:22px!important}
.renewal-timeline-v29{display:grid;gap:14px!important}
.renewal-card-v29{display:grid;gap:14px;padding:18px!important;border-width:1px!important;background:#fff!important}
.renewal-card-head-v29{display:flex;align-items:start;justify-content:space-between;gap:12px}
.renewal-card-head-v29 h3{margin:4px 0 4px;font-size:22px;color:#111827}
.compact-renewal-grid-v29{grid-template-columns:repeat(2,minmax(0,1fr))!important}
.compact-renewal-grid-v29 .span-2{grid-column:1/-1}
.compact-renewal-grid-v29>div{background:#f8fafc!important;border:1px solid #e2e8f0!important;border-radius:16px!important;padding:12px!important}

@media(max-width:900px){
  .compact-member-meta{grid-template-columns:1fr!important}
  .renewal-history-head-v29{display:grid!important}
  .renewal-history-head-v29 .actions-row{display:grid!important;width:100%}
  .renewal-summary-grid-v29{grid-template-columns:repeat(2,minmax(0,1fr))}
  .latest-detail-strip-v29{grid-template-columns:1fr}
  .compact-renewal-grid-v29{grid-template-columns:1fr!important}
}
@media(max-width:720px){
  .member-dashboard-v29{gap:14px!important}
  .simple-member-hero h1{font-size:30px!important}
  .simple-member-hero p{font-size:16px!important}
  .latest-status-v29>strong{font-size:24px!important}
  .latest-status-head{display:grid!important}
  .latest-status-head .badge{justify-content:center!important;width:100%}
  .latest-status-grid>div{padding:12px!important}
  .history-preview-v29 .section-row{display:grid!important}
  .history-preview-v29 .btn{width:100%!important}
  .history-row-v29{display:grid!important;gap:10px!important;padding:14px!important}
  .history-row-v29 .badge{justify-content:center!important;width:100%}
  .renewal-summary-grid-v29{grid-template-columns:1fr 1fr!important;gap:10px!important}
  .renewal-summary-card{padding:14px!important;border-radius:18px!important}
  .renewal-summary-card strong{font-size:28px!important}
  .latest-history-focus-v29,.renewal-history-list-card-v29{padding:16px!important;border-radius:20px!important}
  .renewal-card-head-v29{display:grid!important}
  .renewal-card-head-v29 .badge{width:100%;justify-content:center}
  .compact-renewal-grid-v29>div{display:grid!important;gap:5px!important}
  .compact-renewal-grid-v29>div span{font-size:13px!important;color:#64748b!important;font-weight:1000!important}
  .compact-renewal-grid-v29>div strong{font-size:15px!important;color:#111827!important}
}

/* v30 Compact Renewal History */
.renewal-history-v30{gap:18px!important}.renewal-history-head-v30 p{max-width:680px}.renewal-summary-grid-v30{margin-bottom:2px}.latest-history-focus-v30{overflow:hidden}.latest-focus-row-v30 h2{font-size:24px;line-height:1.25}.latest-detail-strip-v30{grid-template-columns:repeat(3,minmax(0,1fr))!important}.renewal-history-list-card-v30{padding:24px!important}.renewal-history-list-head-v30{align-items:flex-start!important}.renewal-filter-chips-v30{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;max-width:560px}.filter-chip-v30{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:10px 14px;border-radius:999px;border:1px solid #dbe3ef;background:#fff;color:#334155;font-weight:1000;text-decoration:none;box-shadow:0 8px 20px rgba(15,23,42,.05)}.filter-chip-v30 span{display:inline-flex;min-width:26px;height:26px;align-items:center;justify-content:center;padding:0 7px;border-radius:999px;background:#eef2f7;color:#475569;font-size:13px}.filter-chip-v30.active{background:#e50914;color:#fff;border-color:#e50914;box-shadow:0 12px 26px rgba(229,9,20,.22)}.filter-chip-v30.active span{background:rgba(255,255,255,.18);color:#fff}.compact-history-list-v30{display:grid;gap:10px;margin-top:18px}.compact-history-item-v30{display:grid;grid-template-columns:minmax(210px,1.5fr) minmax(150px,.8fr) minmax(180px,.9fr) auto;align-items:center;gap:12px;padding:14px;border:1px solid #e2e8f0;border-radius:20px;background:#fff;box-shadow:0 10px 24px rgba(15,23,42,.05)}.compact-history-item-v30.status-pending{border-left:5px solid #f59e0b}.compact-history-item-v30.status-approved{border-left:5px solid #16a34a}.compact-history-item-v30.status-rejected{border-left:5px solid #dc2626}.compact-history-main-v30{display:flex;align-items:center;gap:12px;min-width:0}.history-icon-v30{width:48px;height:48px;display:grid;place-items:center;flex:0 0 auto;border-radius:16px;background:#fff1f2;color:#be123c;font-size:22px;font-weight:1000;border:1px solid #fecdd3}.history-title-v30{min-width:0}.history-title-v30 strong{display:block;color:#111827;font-size:17px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-title-v30 span{display:block;color:#64748b;font-weight:850;margin-top:4px;font-size:14px}.compact-history-meta-v30{display:grid;gap:5px;color:#334155;font-weight:950}.compact-history-meta-v30 span:first-child{color:#111827}.compact-history-status-v30{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.slipok-mini-v30{display:inline-flex;align-items:center;min-height:30px;border-radius:999px;padding:6px 10px;background:#f1f5f9;color:#475569;font-size:13px;font-weight:1000}.slipok-mini-v30.ok,.slipok-mini-v30.success,.slipok-mini-v30.approved{background:#dcfce7;color:#166534}.slipok-mini-v30.error,.slipok-mini-v30.failed,.slipok-mini-v30.rejected{background:#fee2e2;color:#991b1b}.slipok-mini-v30.warning,.slipok-mini-v30.pending{background:#fef3c7;color:#92400e}.compact-history-actions-v30{display:flex;align-items:center;justify-content:flex-end;gap:8px}.compact-history-actions-v30 .btn{white-space:nowrap}.is-extra-hidden{display:none!important}.load-more-wrap-v30{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:18px;padding-top:16px;border-top:1px solid #e2e8f0}.load-more-wrap-v30 p{margin:0;font-weight:900}.renewal-detail-modal-v30{position:fixed;inset:0;z-index:9998;display:none}.renewal-detail-modal-v30.open{display:block}.renewal-detail-backdrop-v30{position:absolute;inset:0;background:rgba(15,23,42,.54);backdrop-filter:blur(6px)}.renewal-detail-panel-v30{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(760px,calc(100vw - 28px));max-height:calc(100vh - 40px);overflow:auto;background:#fff;border-radius:28px;padding:24px;border:1px solid #e2e8f0;box-shadow:0 30px 90px rgba(15,23,42,.28)}.renewal-detail-close-v30{position:absolute;right:14px;top:14px;width:42px;height:42px;border:0;border-radius:999px;background:#f1f5f9;color:#0f172a;font-size:28px;line-height:1;cursor:pointer}.renewal-detail-close-v30:hover{background:#e2e8f0}.renewal-detail-modal-head-v30{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding-right:44px;margin-bottom:16px}.renewal-detail-modal-head-v30 h3{margin:4px 0;color:#111827;font-size:24px}.renewal-detail-grid-v30{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.renewal-detail-grid-v30>div{padding:13px 14px;border-radius:16px;border:1px solid #e2e8f0;background:#f8fafc}.renewal-detail-grid-v30 span{display:block;color:#64748b;font-size:13px;font-weight:1000;margin-bottom:5px}.renewal-detail-grid-v30 strong{display:block;color:#111827;font-size:15px;line-height:1.4;word-break:break-word}.renewal-detail-actions-v30{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}
@media(max-width:1024px){.renewal-history-list-head-v30{display:grid!important}.renewal-filter-chips-v30{justify-content:flex-start;max-width:none}.compact-history-item-v30{grid-template-columns:1fr 1fr;align-items:start}.compact-history-status-v30,.compact-history-actions-v30{justify-content:flex-start}.compact-history-actions-v30{grid-column:1/-1}.compact-history-actions-v30 .btn{min-height:46px;flex:1}}
@media(max-width:720px){.renewal-history-head-v30 .actions-row{display:grid!important}.renewal-history-list-card-v30{padding:16px!important}.renewal-filter-chips-v30{display:grid;grid-template-columns:1fr 1fr;width:100%;gap:8px}.filter-chip-v30{justify-content:center;padding:11px 10px}.compact-history-list-v30{gap:12px}.compact-history-item-v30{grid-template-columns:1fr;padding:14px;border-radius:18px}.history-icon-v30{width:44px;height:44px;border-radius:14px;font-size:20px}.history-title-v30 strong{font-size:18px;white-space:normal}.history-title-v30 span{font-size:14px}.compact-history-meta-v30{display:flex;gap:8px;flex-wrap:wrap}.compact-history-meta-v30 span{padding:8px 10px;border-radius:999px;background:#f1f5f9}.compact-history-status-v30 .badge,.compact-history-status-v30 .slipok-mini-v30{width:100%;justify-content:center}.compact-history-actions-v30{display:grid!important;grid-template-columns:1fr;gap:8px}.compact-history-actions-v30 .btn{width:100%;min-height:50px}.load-more-wrap-v30{display:grid}.load-more-wrap-v30 .btn{width:100%;min-height:50px}.load-more-wrap-v30 p{text-align:center}.renewal-detail-panel-v30{left:0;right:0;bottom:0;top:auto;transform:none;width:100%;max-height:86vh;border-radius:26px 26px 0 0;padding:22px 16px 18px}.renewal-detail-modal-head-v30{display:grid;gap:10px;padding-right:46px}.renewal-detail-modal-head-v30 .badge{justify-content:center;width:100%}.renewal-detail-grid-v30{grid-template-columns:1fr}.renewal-detail-actions-v30{display:grid}.renewal-detail-actions-v30 .btn{width:100%;min-height:50px}.latest-detail-strip-v30{grid-template-columns:1fr!important}}
