:root{--primary: #f1b76d;--primary-dark: #d89a4f;--on-primary: #1a1f36;--success: #16a34a;--success-soft: #dcfce7;--warning: #d97706;--warning-soft: #fef3c7;--danger: #dc2626;--danger-soft: #fee2e2;--info: #2563eb;--bg: #f5f3ee;--bg-grad-1: #f7f5f0;--bg-grad-2: #ece8df;--card: #ffffff;--card-2: #faf9f6;--text: #1a1f36;--muted: #6b7280;--border: #e5e7eb;--shadow: 0 6px 24px rgba(26, 31, 54, .08);--shadow-lg: 0 14px 40px rgba(26, 31, 54, .14);--topbar: #373b56;--topbar-text: #ffffff;--radius: 16px;--radius-sm: 10px;--gap: 16px}[data-theme=dark]{--bg: #373b56;--bg-grad-1: #3a3f5e;--bg-grad-2: #2c3048;--card: #2f3349;--card-2: #353a52;--text: #ffffff;--muted: #9ca3b8;--border: #444a66;--shadow: 0 6px 24px rgba(0, 0, 0, .3);--shadow-lg: 0 14px 40px rgba(0, 0, 0, .45);--success-soft: rgba(74, 222, 128, .16);--warning-soft: rgba(251, 191, 36, .16);--danger-soft: rgba(239, 68, 68, .16);--topbar: #2c3048;--topbar-text: #ffffff}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Cairo,Segoe UI,Tahoma,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background .3s ease,color .3s ease}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit}::selection{background:var(--primary);color:var(--on-primary)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.app-shell{min-height:100%;display:flex;flex-direction:column}.page{max-width:1120px;width:100%;margin:0 auto;padding:22px 18px 90px}.page-title{font-size:22px;font-weight:900;margin-bottom:4px}.page-sub{color:var(--muted);font-size:13px;margin-bottom:18px}.row{display:flex;align-items:center;gap:10px}.row.wrap{flex-wrap:wrap}.spacer{flex:1}.grid{display:grid;gap:var(--gap)}.grid.cols-2{grid-template-columns:repeat(2,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}@media(max-width:720px){.grid.cols-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.grid.cols-2,.grid.cols-3{grid-template-columns:1fr}}.topbar{background:var(--topbar);color:var(--topbar-text);height:62px;display:flex;align-items:center;gap:16px;padding:0 18px;position:sticky;top:0;z-index:50;box-shadow:0 2px 16px #0000002e}.brand{font-weight:900;font-size:22px;letter-spacing:2px;background:linear-gradient(135deg,var(--primary),#ffd9a0);-webkit-background-clip:text;background-clip:text;color:transparent}.topbar .icon-btn{color:var(--topbar-text);width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:18px}.topbar .icon-btn:hover{background:#ffffff24}.tabbar{display:flex;gap:4px;background:var(--card);border-bottom:1px solid var(--border);padding:0 12px;position:sticky;top:62px;z-index:40;overflow-x:auto}.tab{position:relative;padding:14px 16px;font-weight:800;font-size:14px;color:var(--muted);white-space:nowrap;display:flex;align-items:center;gap:7px}.tab.active{color:var(--primary-dark)}.tab .tab-underline{position:absolute;inset-inline:10px;bottom:0;height:3px;border-radius:3px;background:var(--primary)}.pill-tabs{display:flex;gap:8px;flex-wrap:wrap}.pill{padding:8px 14px;border-radius:999px;font-weight:700;font-size:13px;background:var(--card);border:1px solid var(--border);color:var(--text);display:flex;align-items:center;gap:7px}.pill.active{background:var(--primary);border-color:var(--primary);color:var(--on-primary)}.pill .count{background:#0000001f;border-radius:999px;padding:0 7px;font-size:11px}.pill.active .count{background:#0000002e}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.card.flat{box-shadow:none}.card-title{font-size:15px;font-weight:900;margin-bottom:12px;display:flex;align-items:center;gap:8px}.card-title .dot{width:8px;height:8px;border-radius:3px;background:var(--primary)}.tile{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}.tile .tile-ico{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:20px;background:var(--primary);color:var(--on-primary)}.tile .tile-label{color:var(--muted);font-size:13px;font-weight:700}.tile .tile-value{font-size:22px;font-weight:900}.tile.clickable{cursor:pointer}.tile.clickable:hover{border-color:var(--primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-sm);padding:11px 18px;font-weight:800;font-size:14px;background:var(--primary);color:var(--on-primary);transition:filter .15s ease,transform .05s ease}.btn:hover{filter:brightness(1.05)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.block{width:100%}.btn.sm{padding:8px 13px;font-size:13px}.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn.ghost:hover{background:var(--card-2)}.btn.soft{background:var(--primary);opacity:.92}.btn.danger{background:var(--danger);color:#fff}.btn.ok{background:var(--success);color:#fff}.icon-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:var(--text)}.icon-btn:hover{background:var(--card-2)}.fab{position:fixed;inset-inline-end:22px;bottom:22px;background:var(--primary);color:var(--on-primary);border-radius:999px;padding:14px 20px;font-weight:900;font-size:14px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;z-index:30}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:800}.badge.paid{background:var(--success-soft);color:var(--success)}.badge.partial{background:var(--warning-soft);color:var(--warning)}.badge.unpaid,.badge.debt{background:var(--danger-soft);color:var(--danger)}.badge.demo{background:#7c3aed29;color:#7c3aed}.badge.muted{background:var(--card-2);color:var(--muted)}.list{display:flex;flex-direction:column;gap:10px}.list-row{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px 15px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow)}.list-row.clickable{cursor:pointer}.list-row .avatar{width:42px;height:42px;border-radius:12px;background:var(--primary);color:var(--on-primary);display:grid;place-items:center;font-weight:900;font-size:17px;flex-shrink:0;overflow:hidden}.list-row .avatar img{width:100%;height:100%;object-fit:cover}.list-row .l-main{flex:1;min-width:0}.list-row .l-title{font-weight:800;font-size:14px}.list-row .l-sub{color:var(--muted);font-size:12px}.field{margin-bottom:14px}.field label{display:block;font-weight:700;font-size:13px;margin-bottom:6px}.field input,.field select,.field textarea{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--card-2);color:var(--text)}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--primary);outline-offset:-1px}.field .hint{color:var(--muted);font-size:11px;margin-top:4px}.form-grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}@media(max-width:480px){.form-grid2{grid-template-columns:1fr}}.alert{padding:11px 14px;border-radius:var(--radius-sm);font-weight:700;font-size:13px;margin-bottom:14px}.alert.err{background:var(--danger-soft);color:var(--danger)}.alert.ok{background:var(--success-soft);color:var(--success)}.alert.info{background:var(--card-2);color:var(--muted)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c148c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;display:flex}.modal{background:var(--card);border-radius:var(--radius);padding:20px;width:min(440px,92vw);margin:auto;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}.drawer{background:var(--card);width:min(460px,96vw);margin-inline-start:auto;height:100%;overflow-y:auto;box-shadow:var(--shadow-lg);padding:20px}.modal-title{font-size:17px;font-weight:900;margin-bottom:14px}.modal-actions{display:flex;gap:10px;margin-top:16px}.kv{display:grid;grid-template-columns:auto 1fr;gap:7px 16px}.kv .k{color:var(--muted);font-size:13px}.kv .v{font-weight:700;font-size:14px;text-align:start}.empty{text-align:center;padding:48px 20px;color:var(--muted)}.empty .ico{font-size:46px;margin-bottom:10px;opacity:.6}.skeleton{background:linear-gradient(90deg,var(--card-2) 25%,var(--border) 37%,var(--card-2) 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.snackbar{position:fixed;inset-inline:0;bottom:24px;display:flex;justify-content:center;z-index:200;pointer-events:none}.snackbar .snack{background:#1f2433;color:#fff;padding:12px 20px;border-radius:999px;font-weight:700;font-size:13px;box-shadow:var(--shadow-lg)}.snackbar .snack.err{background:var(--danger)}.snackbar .snack.ok{background:var(--success)}.month-nav{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:999px;padding:5px 8px;width:max-content}.month-nav .label{font-weight:800;font-size:14px;min-width:120px;text-align:center}.segmented{display:inline-flex;background:var(--card-2);border:1px solid var(--border);border-radius:999px;padding:3px}.segmented button{padding:7px 16px;border-radius:999px;font-weight:800;font-size:13px;color:var(--muted)}.segmented button.active{background:var(--primary);color:var(--on-primary)}.auth-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1100px 600px at 80% -10%,rgba(241,183,109,.18),transparent),linear-gradient(160deg,var(--bg-grad-1),var(--bg-grad-2))}.auth-card{background:var(--card);border:1px solid var(--border);border-radius:22px;padding:34px 28px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;font-weight:900;font-size:38px;letter-spacing:3px;background:linear-gradient(135deg,var(--primary),#ffd9a0);-webkit-background-clip:text;background-clip:text;color:transparent}.auth-halo{width:70px;height:70px;border-radius:50%;margin:0 auto 8px;background:radial-gradient(circle,var(--primary),transparent 70%)}.auth-sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:22px}.link-btn{color:var(--primary-dark);font-weight:800;font-size:13px}.receipt-paper{background:#fff;color:#1a1f36;width:320px;margin:0 auto;padding:18px 16px;font-size:12px;line-height:1.7;box-shadow:var(--shadow-lg)}.receipt-paper .r-center{text-align:center}.receipt-paper .r-big{font-size:18px;font-weight:900;letter-spacing:2px}.receipt-paper .r-divider{border-top:1px dashed #999;margin:7px 0}.receipt-paper .r-line{display:flex;justify-content:space-between;gap:10px}.receipt-paper .r-line .lbl{color:#555}.receipt-paper .r-line .val{font-weight:800}@media print{body *{visibility:hidden}.receipt-print,.receipt-print *{visibility:visible}.receipt-print{position:absolute;inset-inline-start:0;top:0}.receipt-paper{box-shadow:none}}.muted{color:var(--muted);font-size:13px}.money{font-variant-numeric:tabular-nums;font-weight:900}.center-box{display:grid;place-items:center;min-height:60vh}.section-gap{margin-top:18px}.chart-box{width:100%;height:240px}
