:root{--green:#0c7a59;--green2:#12a678;--ink:#10231d;--muted:#6d7d77;--bg:#f3f8f6;--card:#fff;--line:#dfeae5;--gold:#d6aa46;--danger:#be3a46;--shadow:0 16px 40px rgba(15,75,57,.10)}*{box-sizing:border-box}html{font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;background:var(--bg);color:var(--ink)}body{margin:0}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(160deg,#063c2d,#0b7858 65%,#11936c);padding:22px 16px;color:#fff;display:flex;flex-direction:column;z-index:20}.brand{display:flex;gap:12px;align-items:center;padding:4px 6px 24px}.brand-mark{width:46px;height:46px;border-radius:16px;background:linear-gradient(145deg,#fff,#d9f8ec);color:var(--green);display:grid;place-items:center;font-weight:900;box-shadow:0 10px 30px rgba(0,0,0,.2)}.brand strong,.brand small{display:block}.brand small{font-size:11px;opacity:.75;margin-top:3px}.sidebar nav{display:grid;gap:5px;overflow:auto}.nav-link{color:rgba(255,255,255,.84);text-decoration:none;padding:11px 12px;border-radius:13px;display:flex;gap:11px;align-items:center;font-size:14px}.nav-link span{width:22px;text-align:center;font-size:18px}.nav-link:hover,.nav-link.active{background:rgba(255,255,255,.15);color:#fff}.sidebar-user{margin-top:auto;padding:14px 8px 0;border-top:1px solid rgba(255,255,255,.16);display:grid;grid-template-columns:38px 1fr 24px;gap:9px;align-items:center}.sidebar-user .avatar{width:38px;height:38px;border-radius:13px;background:#fff;color:var(--green);display:grid;place-items:center;font-weight:800}.sidebar-user b,.sidebar-user small{display:block;font-size:12px}.sidebar-user small{opacity:.72;margin-top:2px}.sidebar-user a{color:#fff;text-decoration:none}.main{min-width:0}.topbar{height:86px;padding:0 28px;display:flex;align-items:center;gap:16px;background:rgba(243,248,246,.86);backdrop-filter:blur(14px);position:sticky;top:0;z-index:15;border-bottom:1px solid rgba(223,234,229,.75)}.topbar h1{font-size:22px;margin:0}.topbar p{font-size:12px;color:var(--muted);margin:3px 0 0}.menu-btn{display:none}.top-actions{margin-left:auto}.icon-btn,.btn{border:0;text-decoration:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:12px;font-weight:700}.icon-btn{width:40px;height:40px;background:#fff;color:var(--green);box-shadow:0 5px 20px rgba(12,122,89,.08)}.content{padding:26px;max-width:1500px;margin:auto}.grid{display:grid;gap:18px}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card{background:var(--card);border:1px solid rgba(223,234,229,.9);border-radius:22px;box-shadow:var(--shadow);padding:20px}.stat{position:relative;overflow:hidden}.stat:after{content:"";position:absolute;width:90px;height:90px;border-radius:50%;background:rgba(18,166,120,.08);right:-28px;top:-30px}.stat small{display:block;color:var(--muted);font-weight:700}.stat strong{font-size:26px;display:block;margin-top:8px}.stat .trend{font-size:12px;color:var(--green);margin-top:8px}.hero{background:linear-gradient(135deg,#07523d,#0d8b65 72%,#19ad7d);color:#fff;min-height:180px;display:flex;justify-content:space-between;align-items:center;position:relative;overflow:hidden}.hero:before,.hero:after{content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.09)}.hero:before{width:220px;height:220px;right:-40px;top:-100px}.hero:after{width:130px;height:130px;right:150px;bottom:-95px}.hero h2{font-size:28px;margin:0 0 8px}.hero p{opacity:.82;max-width:590px}.balance-pill{background:rgba(255,255,255,.14);padding:18px 22px;border-radius:20px;min-width:220px;position:relative;z-index:2}.balance-pill small,.balance-pill b{display:block}.balance-pill b{font-size:26px;margin-top:5px}.section-head{display:flex;justify-content:space-between;align-items:center;margin:24px 0 12px}.section-head h2{font-size:18px;margin:0}.btn{padding:11px 15px;background:var(--green);color:#fff;font-size:13px}.btn:hover{filter:brightness(.95)}.btn.secondary{background:#e8f4f0;color:var(--green)}.btn.gold{background:var(--gold);color:#2b230e}.btn.danger{background:#ffe9ec;color:var(--danger)}.btn.sm{padding:7px 10px;border-radius:9px;font-size:12px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px}.table{width:100%;border-collapse:collapse;min-width:760px}.table th,.table td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:left;font-size:13px}.table th{background:#f7fbf9;color:#53655e;font-size:12px;text-transform:uppercase;letter-spacing:.03em}.table tr:last-child td{border-bottom:0}.badge{display:inline-flex;padding:5px 9px;border-radius:99px;background:#e8f4f0;color:var(--green);font-size:11px;font-weight:800}.badge.red{background:#ffe8eb;color:var(--danger)}.badge.gold{background:#fff5d9;color:#8a6510}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:15px}.form-group{display:grid;gap:7px}.form-group.full{grid-column:1/-1}.form-group label{font-size:12px;font-weight:800;color:#53655e}.input,.select,.textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px 13px;background:#fff;color:var(--ink);outline:none}.input:focus,.select:focus,.textarea:focus{border-color:var(--green2);box-shadow:0 0 0 3px rgba(18,166,120,.1)}.textarea{min-height:90px;resize:vertical}.actions{display:flex;gap:9px;flex-wrap:wrap}.alert{padding:13px 15px;border-radius:13px;margin-bottom:16px;font-size:13px}.alert.success{background:#e4f8ef;color:#0a6c4c}.alert.danger{background:#ffe8eb;color:#9f2f3a}.member-card{display:grid;grid-template-columns:1fr auto;gap:15px;align-items:center}.member-code{font-family:ui-monospace,monospace;color:var(--green);font-weight:800}.qr-box{width:150px;height:150px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:10px;display:grid;place-items:center}.muted{color:var(--muted)}.amount.credit{color:#0a875f;font-weight:800}.amount.debit{color:#c13a47;font-weight:800}.empty{text-align:center;padding:45px 20px;color:var(--muted)}.footer{padding:24px;text-align:center;color:var(--muted);font-size:11px}.login-page{min-height:100vh;background:radial-gradient(circle at 10% 10%,#dbf7eb,transparent 30%),linear-gradient(140deg,#eef8f4,#f8fbfa);display:grid;place-items:center;padding:20px}.login-wrap{width:min(960px,100%);display:grid;grid-template-columns:1.1fr .9fr;background:#fff;border-radius:30px;overflow:hidden;box-shadow:0 30px 80px rgba(9,74,54,.16)}.login-visual{padding:50px;background:linear-gradient(145deg,#064b38,#0d8964);color:#fff;position:relative;overflow:hidden}.login-visual h1{font-size:42px;margin:20px 0 10px}.login-visual p{opacity:.8;line-height:1.7}.login-form{padding:50px;display:grid;align-content:center}.login-form h2{font-size:28px;margin:0 0 8px}.login-form>p{color:var(--muted);margin:0 0 25px}.install-card{width:min(760px,100%);margin:30px auto}.kpi-list{display:grid;gap:12px}.kpi-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px dashed var(--line)}@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:820px){.app-shell{display:block}.sidebar{position:fixed;left:-280px;transition:.25s;width:260px}.sidebar.open{left:0}.menu-btn{display:inline-grid;place-items:center;width:40px;height:40px;border:0;border-radius:12px;background:#fff;color:var(--green);font-size:20px}.topbar{padding:0 16px;height:76px}.content{padding:16px}.grid-4,.grid-3,.grid-2,.form-grid{grid-template-columns:1fr}.login-wrap{grid-template-columns:1fr}.login-visual{display:none}.login-form{padding:34px 24px}.hero{display:block}.balance-pill{margin-top:20px}.member-card{grid-template-columns:1fr}.table{min-width:680px}}@media print{.sidebar,.topbar,.footer,.no-print{display:none!important}.app-shell{display:block}.content{padding:0}.card{box-shadow:none;border:0}.table-wrap{overflow:visible}.table{min-width:0}}
/* v1.0.1 — QR member scanner */
.deposit-layout{align-items:start}.scanner-card{position:sticky;top:106px}.scanner-card h3{margin:12px 0 4px}.scan-input-row{display:grid;grid-template-columns:1fr auto;gap:8px}.camera-actions{margin-top:14px}.camera-wrap{position:relative;margin-top:14px;border-radius:18px;overflow:hidden;background:#071b15;aspect-ratio:4/3}.camera-wrap video{width:100%;height:100%;object-fit:cover;display:block}.scan-frame{position:absolute;inset:18%;border:3px solid rgba(255,255,255,.92);border-radius:18px;box-shadow:0 0 0 999px rgba(0,0,0,.24)}.scan-frame:before,.scan-frame:after{content:"";position:absolute;width:34px;height:34px;border-color:#20d99d}.scan-frame:before{left:-3px;top:-3px;border-left:5px solid #20d99d;border-top:5px solid #20d99d;border-radius:14px 0 0 0}.scan-frame:after{right:-3px;bottom:-3px;border-right:5px solid #20d99d;border-bottom:5px solid #20d99d;border-radius:0 0 14px 0}.scan-message{margin-top:13px;padding:11px 12px;border-radius:12px;background:#f6faf8;font-size:12px}.success-text{color:#087451;background:#e6f8ef}.error-text{color:#9f2f3a;background:#ffe8eb}.selected-member{margin-top:12px;padding:14px;border-radius:16px;background:linear-gradient(135deg,#07523d,#0d8b65);color:#fff;display:grid;gap:4px}.selected-member small{opacity:.72}.selected-member strong{font-size:18px}.selected-member span{font-size:12px;opacity:.86}@media(max-width:1100px){.deposit-layout{grid-template-columns:1fr}.deposit-layout>.card{grid-column:auto!important}.scanner-card{position:static}}@media(max-width:520px){.scan-input-row{grid-template-columns:1fr}.camera-actions .btn{flex:1}}
