:root{
    --bg:#f4f7fb;
    --card:#ffffff;
    --text:#0f172a;
    --muted:#64748b;
    --primary:#2563eb;
    --primary-dark:#1d4ed8;
    --line:#e2e8f0;
    --success:#16a34a;
    --warning:#d97706;
    --danger:#dc2626;
    --dark:#334155;
    --shadow:0 18px 40px rgba(15,23,42,.08);
    --radius:22px;
}
*{box-sizing:border-box}
html{min-height:100%;background:var(--bg)}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--text);background:linear-gradient(180deg,#eaf2ff 0,#f4f7fb 260px);min-height:100%;}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
.app-shell{max-width:520px;margin:0 auto;min-height:100vh;position:relative;background:transparent;padding-bottom:88px;}
.content-wrap{padding:12px 16px 24px;}
.mobile-header{padding:24px 16px 8px;display:flex;align-items:center;justify-content:space-between;gap:12px;position:sticky;top:0;z-index:20;background:linear-gradient(180deg,#eaf2ff 0,#eef5ff 82%,rgba(238,245,255,.0));backdrop-filter:blur(10px);}
.mobile-header h1{margin:2px 0 0;font-size:22px;line-height:1.1;letter-spacing:-.03em;}
.avatar-btn{width:44px;height:44px;border-radius:18px;display:grid;place-items:center;background:var(--primary);color:#fff;font-weight:800;box-shadow:var(--shadow)}
.small{font-size:12px}.muted{color:var(--muted)}
.child-switcher{padding:0 16px 10px;position:sticky;top:74px;z-index:19;background:rgba(239,246,255,.84);backdrop-filter:blur(10px)}
.child-switcher select{width:100%;border:1px solid #bfdbfe;background:#fff;border-radius:16px;padding:12px 14px;font-weight:700;color:#1e3a8a;box-shadow:0 10px 25px rgba(37,99,235,.08)}
.card{background:var(--card);border:1px solid rgba(226,232,240,.85);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin:12px 0;}
.card.compact{padding:12px;border-radius:18px;box-shadow:0 10px 25px rgba(15,23,42,.06)}
.card-title{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.card-title h2,.card-title h3{margin:0;font-size:17px;line-height:1.2}.card-title p{margin:4px 0 0;color:var(--muted);font-size:12px}
.hero-card{background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;border:0;padding:20px;overflow:hidden;position:relative}.hero-card:after{content:"";position:absolute;right:-40px;top:-60px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.13)}.hero-card .muted{color:#dbeafe}.hero-value{font-size:34px;line-height:1.05;font-weight:900;letter-spacing:-.05em;margin:14px 0 8px}.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}.mini-stat{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:12px}.mini-stat b{display:block;font-size:16px;margin-top:4px}.mini-stat span{font-size:11px;color:#dbeafe}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:14px;border-radius:20px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 24px rgba(15,23,42,.05)}.stat-card span{font-size:12px;color:var(--muted)}.stat-card b{display:block;font-size:20px;letter-spacing:-.04em;margin-top:5px}.stat-card.success b{color:var(--success)}.stat-card.warning b{color:var(--warning)}.stat-card.danger b{color:var(--danger)}
.btn{border:0;border-radius:16px;padding:12px 16px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;background:#e2e8f0;color:var(--text);min-height:44px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:active{background:var(--primary-dark)}.btn-outline{background:#fff;border:1px solid var(--line);color:var(--text)}.btn-danger{background:#fee2e2;color:#991b1b}.btn-success{background:#dcfce7;color:#166534}.btn-sm{padding:8px 11px;border-radius:12px;min-height:34px;font-size:12px}.btn-block{width:100%}.btn-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.btn-row .btn{flex:1}.fab{position:fixed;right:max(16px,calc(50% - 244px));bottom:94px;width:56px;height:56px;border-radius:22px;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:30px;font-weight:700;box-shadow:0 20px 40px rgba(37,99,235,.32);z-index:30}
.form-group{margin-bottom:12px}.form-group label{display:block;font-size:12px;font-weight:800;color:#334155;margin:0 0 6px}.form-control{width:100%;border:1px solid var(--line);border-radius:16px;padding:12px 14px;background:#fff;min-height:46px;outline:0}.form-control:focus{border-color:#93c5fd;box-shadow:0 0 0 4px rgba(37,99,235,.1)}textarea.form-control{min-height:94px;resize:vertical}.form-help{font-size:12px;color:var(--muted);margin-top:5px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.money-prefix{position:relative}.money-prefix input{padding-left:42px}.money-prefix:before{content:"Rp";position:absolute;left:14px;top:36px;color:var(--muted);font-weight:800;font-size:12px;z-index:2}
.list{display:flex;flex-direction:column;gap:10px}.list-item{background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:0 10px 25px rgba(15,23,42,.045)}.list-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.list-title{font-weight:900;line-height:1.25}.list-sub{font-size:12px;color:var(--muted);margin-top:3px}.list-amount{text-align:right;font-weight:900;color:#0f172a;white-space:nowrap}.list-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.kv{display:grid;grid-template-columns:1fr auto;gap:8px;padding:7px 0;border-bottom:1px dashed #e2e8f0}.kv:last-child{border-bottom:0}.kv span:first-child{color:var(--muted)}.kv b{text-align:right}.status-badge{display:inline-flex;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;white-space:nowrap}.badge-danger{background:#fee2e2;color:#991b1b}.badge-warning{background:#fef3c7;color:#92400e}.badge-success{background:#dcfce7;color:#166534}.badge-dark{background:#e2e8f0;color:#334155}.badge-muted{background:#f1f5f9;color:#475569}
.progress{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,#22c55e,#2563eb);border-radius:999px}.empty{padding:28px 18px;text-align:center;color:var(--muted);background:#fff;border:1px dashed #cbd5e1;border-radius:22px}.empty b{display:block;color:var(--text);margin-bottom:4px}.alert{margin:10px 0;border-radius:16px;padding:12px 14px;font-size:13px;font-weight:700}.alert-success{background:#dcfce7;color:#166534}.alert-danger{background:#fee2e2;color:#991b1b}.alert-warning{background:#fef3c7;color:#92400e}.alert-info{background:#dbeafe;color:#1e40af}.filter-pills{display:flex;gap:8px;overflow-x:auto;padding:4px 0 10px;scrollbar-width:none}.filter-pills::-webkit-scrollbar{display:none}.pill{display:inline-flex;border-radius:999px;background:#fff;border:1px solid var(--line);padding:9px 12px;font-size:12px;font-weight:800;white-space:nowrap}.pill.active{background:var(--primary);border-color:var(--primary);color:#fff}.section-title{font-size:15px;margin:20px 0 8px;color:#0f172a;letter-spacing:-.02em}.login-wrap{min-height:100vh;display:flex;align-items:center;padding:24px}.login-card{width:100%;background:#fff;border-radius:28px;padding:24px;box-shadow:var(--shadow)}.login-logo{width:62px;height:62px;border-radius:22px;background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;display:grid;place-items:center;font-size:28px;font-weight:900;margin-bottom:18px}.login-card h1{font-size:26px;margin:0 0 6px;letter-spacing:-.04em}.login-card p{margin:0 0 20px;color:var(--muted)}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.menu-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:0 10px 25px rgba(15,23,42,.05);min-height:112px}.menu-card span{font-size:26px;display:block;margin-bottom:10px}.menu-card b{display:block;font-size:15px}.menu-card small{color:var(--muted);font-size:11px}.bottom-nav{position:fixed;left:50%;transform:translateX(-50%);bottom:0;z-index:50;width:100%;max-width:520px;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);border-top:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr;padding:8px 8px calc(8px + env(safe-area-inset-bottom));box-shadow:0 -12px 35px rgba(15,23,42,.08)}.bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#64748b;font-size:10px;font-weight:800;min-height:54px;border-radius:18px}.bottom-nav a span{font-size:20px;line-height:1}.bottom-nav a.active{color:var(--primary);background:#eff6ff}.bottom-nav .nav-pay{margin-top:-28px;background:var(--primary);color:#fff;border-radius:23px;box-shadow:0 12px 30px rgba(37,99,235,.35)}.bottom-nav .nav-pay.active{background:var(--primary);color:#fff}.bottom-nav .nav-pay span{font-size:26px}.doc-thumb{width:54px;height:54px;border-radius:16px;background:#eff6ff;display:grid;place-items:center;color:var(--primary);font-weight:900;overflow:hidden;flex:0 0 auto}.doc-thumb img{width:100%;height:100%;object-fit:cover}.inline-search{position:relative}.inline-search input{padding-left:42px}.inline-search:before{content:"⌕";position:absolute;left:14px;top:12px;color:var(--muted);font-weight:900}.print-only{display:none}
@media(min-width:760px){body{background:#eaf2ff}.app-shell{margin:24px auto;border-radius:32px;background:#f4f7fb;min-height:calc(100vh - 48px);box-shadow:0 30px 80px rgba(15,23,42,.16);overflow:hidden}.bottom-nav{bottom:24px;border-radius:28px;border:1px solid var(--line)}}
@media print{body{background:#fff}.app-shell{max-width:none;padding:0}.mobile-header,.bottom-nav,.child-switcher,.no-print,.fab{display:none!important}.content-wrap{padding:0}.card{box-shadow:none;border:1px solid #ddd;border-radius:8px;break-inside:avoid}.print-only{display:block}.list-item{box-shadow:none;border-radius:8px}}
