@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";@import "https://fonts.googleapis.com/css2?family=Roboto+Flex:opsz,wdth,wght@8..144,75..125,100..900&display=swap";@import "https://fonts.googleapis.com/icon?family=Material+Icons";@import "https://fonts.googleapis.com/icon?family=Material+Icons+Outlined";@import "https://fonts.googleapis.com/icon?family=Material+Icons+Round";:root{--accent:#ecede1;--secondary:#959687;--stroke:#d7d8cb;--gray:#f5f5f5;--bg:#f6f7ee;--label-bg:#e4e5dd;--black:#111;--white:#fff;--gray-mid:#898b90;--gray-light:#ececec;--gray-line:#d5d9dd;--green:#59886d;--bg-green:#e4f8ec;--red:#cc3939;--bg-red:#f8e4e4;--pink:#c585b3;--orange:#ef8354;--bg-orange:#f8f0e4;--blue:#85a0c5;--ink:#111;--ink-2:#111;--cream:#f6f7ee;--accent-2:#ecede1;--muted:#959687;--white-c:#fff;--pine:#59886d;--coral:#ef8354;--orchid:#c585b3;--slate:#85a0c5;--label:#e4e5dd;--gray-2:#f5f5f5;--sans:"Inter", system-ui, -apple-system, sans-serif;--mono:"Inter", system-ui, sans-serif;--text-72:72px;--text-48:48px;--text-40:40px;--text-32:32px;--text-24:24px;--text-20:20px;--text-18:18px;--text-16:16px;--text-14:14px;--text-12:12px;--semibold:600;--medium:500;--lh-headline:120%;--lh-title:130%;--lh-body:140%;--r-sm:6px;--r-md:8px;--r-input:10px;--r-card:12px;--r-lg:16px;--shadow-sm:0 1px 4px #1111110f;--shadow-md:0 4px 16px #11111114;--shadow-lg:0 8px 32px #1111111a;--sidebar-w:224px;--topbar-h:60px;--maxw:1200px;--page-pad:24px}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:var(--text-14);font-weight:var(--medium);line-height:var(--lh-body);color:var(--black);background:var(--bg);-webkit-font-smoothing:antialiased}img,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}button{cursor:pointer;background:0 0;border:none}:focus-visible{outline:2px solid var(--black);outline-offset:2px;border-radius:var(--r-sm)}.h-72{font-size:var(--text-72);font-weight:var(--semibold);letter-spacing:-2px;line-height:120%}.h-48{font-size:var(--text-48);font-weight:var(--semibold);letter-spacing:-1px;line-height:130%}.h-40{font-size:var(--text-40);font-weight:var(--medium);letter-spacing:-1px;line-height:130%}.h-32{font-size:var(--text-32);font-weight:var(--medium);letter-spacing:-2px;line-height:130%}.h-24{font-size:var(--text-24);font-weight:var(--semibold);letter-spacing:-1px;line-height:130%}.t-20{font-size:var(--text-20);font-weight:var(--semibold);letter-spacing:-1px;line-height:130%}.t-18{font-size:var(--text-18);font-weight:var(--semibold);letter-spacing:-.8px;line-height:130%}.t-16{font-size:var(--text-16);font-weight:var(--semibold);letter-spacing:-.5px;line-height:140%}.t-14{font-size:var(--text-14);font-weight:var(--semibold);letter-spacing:-.4px;line-height:130%}.t-12{font-size:var(--text-12);font-weight:var(--semibold);letter-spacing:0;line-height:130%}.b-18{font-size:var(--text-18);font-weight:var(--medium);letter-spacing:-1px;line-height:130%}.b-16{font-size:var(--text-16);font-weight:var(--medium);letter-spacing:-.5px;line-height:140%}.b-14{font-size:var(--text-14);font-weight:var(--medium);letter-spacing:-.5px;line-height:140%}.b-12{font-size:var(--text-12);font-weight:var(--medium);letter-spacing:0;line-height:130%}.text-secondary{color:var(--secondary)}.text-gray-mid{color:var(--gray-mid)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-orange{color:var(--orange)}.text-blue{color:var(--blue)}.text-pink{color:var(--pink)}.text-white{color:var(--white)}.btn{font-family:Inter,sans-serif;font-size:var(--text-14);font-weight:var(--semibold);letter-spacing:-.4px;border-radius:var(--r-input);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 18px;line-height:130%;text-decoration:none;transition:opacity .15s,background .15s,border-color .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--black);color:var(--white);border-color:var(--black)}.btn-primary:hover{opacity:.85}.btn-secondary{background:var(--white);color:var(--black);border-color:var(--gray-line)}.btn-secondary:hover{background:var(--gray)}.btn-ghost{background:var(--accent);color:var(--black);border-color:var(--stroke)}.btn-ghost:hover{background:var(--label-bg)}.btn-danger{background:var(--red);color:var(--white);border-color:var(--red)}.btn-danger:hover{opacity:.85}.btn-success{background:var(--green);color:var(--white);border-color:var(--green)}.btn-success:hover{opacity:.85}.btn-sm{font-size:var(--text-12);padding:7px 14px}.btn-lg{font-size:var(--text-16);padding:13px 24px}.btn-icon{aspect-ratio:1;padding:9px}.btn.loading{color:#0000;pointer-events:none;position:relative}.btn.loading:after{content:"";border:2px solid #ffffff4d;border-top-color:var(--white);border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;position:absolute}.btn-ink{background:var(--black);color:var(--white);border-color:var(--black);border-radius:var(--r-input)}.btn-ink:hover{opacity:.85}.btn-pine{background:var(--green);color:var(--white);border-color:var(--green);border-radius:var(--r-input)}.btn-coral{background:var(--orange);color:var(--white);border-color:var(--orange);border-radius:var(--r-input)}.input-group{flex-direction:column;gap:6px;display:flex}.input-label{font-size:var(--text-14);font-weight:var(--semibold);color:var(--black);letter-spacing:-.4px}.input{width:100%;font-family:Inter,sans-serif;font-size:var(--text-14);font-weight:var(--medium);color:var(--black);background:var(--white);border:1px solid var(--gray-line);border-radius:var(--r-input);appearance:none;padding:10px 14px;transition:border-color .15s,box-shadow .15s;display:block}.input::placeholder{color:var(--gray-mid)}.input:hover{border-color:#b8bcc0}.input:focus{border-color:var(--black);outline:none;box-shadow:0 0 0 3px #11111114}.input:disabled{background:var(--gray);color:var(--gray-mid);cursor:not-allowed}.input-wrapper{position:relative}.input-icon{color:var(--gray-mid);pointer-events:none;align-items:center;font-size:16px;display:flex;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.input-wrapper.has-right .input{padding-right:40px}.input-icon-right{color:var(--gray-mid);cursor:pointer;align-items:center;font-size:16px;display:flex;position:absolute;top:50%;right:13px;transform:translateY(-50%)}textarea.input{resize:vertical;min-height:90px;line-height:var(--lh-body)}select.input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23898B90' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:38px}.input-hint{font-size:var(--text-12);color:var(--gray-mid)}.input-error-text{font-size:var(--text-12);color:var(--red)}.input-search{background:var(--white);border:1px solid var(--gray-line);border-radius:var(--r-input);align-items:center;gap:8px;padding:10px 14px;display:flex}.input-search input{font-size:var(--text-14);font-weight:var(--medium);color:var(--black);background:0 0;border:none;outline:none;flex:1}.input-search input::placeholder{color:var(--gray-mid)}.card{background:var(--white);border:1px solid var(--stroke);border-radius:var(--r-card);overflow:hidden}.card-flat{background:var(--white);border:1px solid var(--stroke);border-radius:var(--r-card)}.card-accent{background:var(--accent);border:1px solid var(--stroke);border-radius:var(--r-card)}.card-elevated{background:var(--white);border:1px solid var(--stroke);border-radius:var(--r-card);box-shadow:var(--shadow-md)}.card-header{border-bottom:1px solid var(--gray-line);justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;display:flex}.card-body{padding:18px 20px}.card-footer{border-top:1px solid var(--gray-line);justify-content:flex-end;align-items:center;gap:10px;padding:14px 20px;display:flex}.stat-card{background:var(--white);border:1px solid var(--stroke);border-radius:var(--r-card);flex-direction:column;gap:8px;padding:18px 20px;display:flex}.stat-card-label{font-size:var(--text-12);font-weight:var(--medium);color:var(--secondary)}.stat-card-value{font-size:var(--text-24);font-weight:var(--semibold);color:var(--black);letter-spacing:-1px;line-height:130%}.stat-card-change{font-size:var(--text-12);font-weight:var(--semibold)}.stat-card-change.up{color:var(--green)}.stat-card-change.down{color:var(--red)}.badge{font-size:var(--text-12);font-weight:var(--semibold);border-radius:var(--r-sm);white-space:nowrap;align-items:center;gap:4px;padding:3px 10px;display:inline-flex}.badge-active{background:var(--bg-green);color:var(--green)}.badge-inactive{background:var(--gray-light);color:var(--gray-mid)}.badge-pending{background:var(--bg-orange);color:var(--orange)}.badge-completed{background:var(--bg-green);color:var(--green)}.badge-rejected{background:var(--bg-red);color:var(--red)}.badge-success{background:var(--bg-green);color:var(--green);border-radius:var(--r-sm);font-size:var(--text-12);font-weight:var(--semibold);padding:3px 10px;display:inline-flex}.badge-danger{background:var(--bg-red);color:var(--red);border-radius:var(--r-sm);font-size:var(--text-12);font-weight:var(--semibold);padding:3px 10px;display:inline-flex}.badge-info{color:var(--blue);border-radius:var(--r-sm);font-size:var(--text-12);font-weight:var(--semibold);background:#85a0c526;padding:3px 10px;display:inline-flex}.badge-warning{background:var(--bg-orange);color:var(--orange);border-radius:var(--r-sm);font-size:var(--text-12);font-weight:var(--semibold);padding:3px 10px;display:inline-flex}.badge-neutral{background:var(--gray-light);color:var(--gray-mid);border-radius:var(--r-sm);font-size:var(--text-12);font-weight:var(--semibold);padding:3px 10px;display:inline-flex}.badge-primary{background:var(--label-bg);color:var(--black);border-radius:var(--r-sm);font-size:var(--text-12);font-weight:var(--semibold);padding:3px 10px;display:inline-flex}.alert{border-radius:var(--r-md);font-size:var(--text-14);font-weight:var(--medium);line-height:var(--lh-body);gap:10px;padding:12px 16px;display:flex}.alert-content{flex:1;min-width:0}.alert-title{font-weight:var(--semibold);margin-bottom:2px}.alert-success,.alert-pine{background:var(--bg-green);color:var(--green)}.alert-danger,.alert-coral{background:var(--bg-red);color:var(--red)}.alert-info,.alert-slate{color:var(--blue);background:#85a0c526}.alert-warning{background:var(--bg-orange);color:var(--orange)}.alert-neutral{background:var(--gray-light);color:var(--gray-mid)}.modal-overlay{z-index:500;background:#1111114d;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--white);border:1px solid var(--stroke);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;max-width:460px;max-height:90vh;animation:.2s slideUp;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;gap:12px;padding:20px 24px 16px;display:flex}.modal-title{font-size:var(--text-18);font-weight:var(--semibold);color:var(--black);letter-spacing:-.8px}.modal-body{flex-direction:column;gap:14px;padding:0 24px 20px;display:flex}.modal-footer{border-top:1px solid var(--gray-line);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.table-container{background:var(--white);border:1px solid var(--stroke);border-radius:var(--r-card);overflow:hidden}.table{border-collapse:collapse;width:100%;font-size:var(--text-14)}.table thead{border-bottom:1px solid var(--gray-line)}.table th{text-align:left;font-size:var(--text-12);font-weight:var(--semibold);color:var(--secondary);white-space:nowrap;padding:12px 16px}.table td{color:var(--black);border-bottom:1px solid var(--gray-line);vertical-align:middle;font-weight:var(--medium);padding:14px 16px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--bg)}.table tbody tr.clickable{cursor:pointer}.tabs{border-bottom:1px solid var(--gray-line);gap:2px;display:flex}.tab{font-size:var(--text-14);font-weight:var(--medium);color:var(--secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 16px;transition:color .15s,border-color .15s}.tab:hover{color:var(--black)}.tab.active{color:var(--black);border-bottom-color:var(--black);font-weight:var(--semibold)}.dropdown-menu{background:var(--white);border:1px solid var(--stroke);border-radius:var(--r-card);box-shadow:var(--shadow-md);z-index:100;min-width:200px;animation:.12s fadeIn;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.dropdown-header{border-bottom:1px solid var(--gray-line);padding:14px 16px 10px}.dropdown-header-name{font-size:var(--text-14);font-weight:var(--semibold);color:var(--black)}.dropdown-header-email{font-size:var(--text-12);font-weight:var(--medium);color:var(--secondary);margin-top:2px}.dropdown-item{font-size:var(--text-14);font-weight:var(--medium);color:var(--black);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:11px 16px;transition:background .12s;display:flex}.dropdown-item:hover{background:var(--bg)}.dropdown-item.danger:hover{background:var(--bg-red)}.dropdown-divider{border:none;border-top:1px solid var(--gray-line);margin:4px 0}.avatar{font-weight:var(--semibold);font-size:var(--text-14);background:var(--accent);color:var(--secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.avatar img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.avatar-xs{width:24px;height:24px;font-size:10px}.toast-container{z-index:600;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--white);border:1px solid var(--stroke);border-radius:var(--r-card);box-shadow:var(--shadow-lg);font-size:var(--text-14);font-weight:var(--medium);color:var(--black);pointer-events:auto;align-items:flex-start;gap:12px;min-width:260px;max-width:360px;padding:14px 16px;animation:.2s slideUp;display:flex}.toast-success{border-left:3px solid var(--green)}.toast-danger{border-left:3px solid var(--red)}.toast-info{border-left:3px solid var(--blue)}.spinner{border:2px solid var(--gray-line);border-top-color:var(--black);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}.spinner-sm{width:14px;height:14px}.spinner-light{border-color:#ffffff4d;border-top-color:var(--white)}.skeleton{background:linear-gradient(90deg, var(--gray) 25%, var(--gray-line) 50%, var(--gray) 75%);border-radius:var(--r-md);background-size:200% 100%;animation:1.6s ease-in-out infinite shimmer}.skeleton-text{border-radius:4px;height:13px}.skeleton-heading{border-radius:4px;height:20px}.skeleton-card{border-radius:var(--r-card);height:100px}.skeleton-avatar{border-radius:50%}.bar{background:var(--gray-light);border-radius:999px;width:100%;height:8px;overflow:hidden}.bar i{background:var(--green);border-radius:999px;height:100%;display:block}.bar.red i{background:var(--red)}.bar.orange i{background:var(--orange)}.bar.blue i{background:var(--blue)}.bar.sm{height:5px}.bar.lg{height:12px}.divider{border:none;border-top:1px solid var(--gray-line)}.divider-label{font-size:var(--text-12);font-weight:var(--medium);color:var(--gray-mid);align-items:center;gap:12px;display:flex}.divider-label:before,.divider-label:after{content:"";border-top:1px solid var(--gray-line);flex:1}.stepper{align-items:center;gap:0;display:flex}.step-circle{width:28px;height:28px;font-size:var(--text-12);font-weight:var(--semibold);border:1px solid var(--gray-line);background:var(--white);color:var(--gray-mid);z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex;position:relative}.step.active .step-circle,.step.completed .step-circle{border-color:var(--black);background:var(--black);color:var(--white)}.step-line{background:var(--gray-line);flex:1;height:1px;transition:background .3s}.step.completed .step-line{background:var(--black)}.step-label{font-size:var(--text-12);font-weight:var(--medium);color:var(--gray-mid);margin-top:6px}.step.active .step-label,.step.completed .step-label{color:var(--black);font-weight:var(--semibold)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 24px;display:flex}.empty-state-icon{border-radius:var(--r-card);background:var(--gray);width:48px;height:48px;color:var(--gray-mid);justify-content:center;align-items:center;margin-bottom:4px;display:flex}.empty-state-title{font-size:var(--text-16);font-weight:var(--semibold);color:var(--black)}.empty-state-text{font-size:var(--text-14);font-weight:var(--medium);color:var(--secondary);max-width:260px;line-height:var(--lh-body)}.form-stack{flex-direction:column;gap:16px;display:flex}.form-row{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;display:grid}.form-actions{border-top:1px solid var(--gray-line);justify-content:flex-end;gap:10px;margin-top:4px;padding-top:16px;display:flex}.app-shell,.dashboard-layout{background:var(--bg);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--white);border-right:1px solid var(--stroke);z-index:200;flex-direction:column;flex-shrink:0;height:100vh;min-height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--stroke);align-items:center;gap:10px;padding:18px 20px 16px;text-decoration:none;display:flex}.sidebar-logo img{width:auto;height:26px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px;display:flex}.sidebar-section-label{font-size:var(--text-12);font-weight:var(--semibold);color:var(--secondary);margin-top:4px;padding:12px 8px 6px}.sidebar-link{border-radius:var(--r-md);font-size:var(--text-14);font-weight:var(--medium);color:var(--secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 10px;text-decoration:none;transition:all .12s;display:flex}.sidebar-link:hover{background:var(--bg);color:var(--black)}.sidebar-link.active{background:var(--bg);color:var(--black);font-weight:var(--semibold)}.sidebar-icon{width:18px;height:18px;color:var(--gray-mid);flex-shrink:0}.sidebar-link.active .sidebar-icon{color:var(--black)}.sidebar-link-badge{background:var(--black);color:var(--white);font-size:11px;font-weight:var(--semibold);border-radius:999px;margin-left:auto;padding:1px 7px}.sidebar-footer{border-top:1px solid var(--stroke);flex-direction:column;gap:2px;padding:12px;display:flex}.topbar{height:var(--topbar-h);background:var(--white);border-bottom:1px solid var(--stroke);z-index:100;justify-content:space-between;align-items:center;gap:16px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{font-size:var(--text-18);font-weight:var(--semibold);color:var(--black);letter-spacing:-.8px}.app-main,.dashboard-main{flex-direction:column;flex:1;min-width:0;display:flex}.page-content{padding:var(--page-pad);flex:1}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-header-left{flex-direction:column;gap:4px;display:flex}.page-title{font-size:var(--text-24);font-weight:var(--semibold);color:var(--black);letter-spacing:-1px}.page-subtitle{font-size:var(--text-14);font-weight:var(--medium);color:var(--secondary)}.page-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.portal-layout{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.portal-topbar{background:var(--white);border-bottom:1px solid var(--stroke);z-index:100;justify-content:space-between;align-items:center;gap:16px;padding:14px 20px;display:flex;position:sticky;top:0}.portal-logo{align-items:center;gap:10px;text-decoration:none;display:flex}.portal-logo img{width:auto;height:24px}.portal-body{flex:1;width:100%;max-width:480px;margin:0 auto;padding:20px}.portal-bottom-nav{background:var(--white);border-top:1px solid var(--stroke);padding:10px 0;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px));z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.portal-nav-item{cursor:pointer;color:var(--gray-mid);font-size:11px;font-weight:var(--semibold);flex-direction:column;flex:1;align-items:center;gap:3px;padding:4px 0;text-decoration:none;transition:color .12s;display:flex}.portal-nav-item:hover{color:var(--secondary)}.portal-nav-item.active{color:var(--black)}.portal-nav-item svg{width:22px;height:22px}.pcard{aspect-ratio:1.586;color:var(--white);border-radius:16px;flex-direction:column;justify-content:space-between;padding:22px 24px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 24px #1111112e}.pcard.ink{background:var(--black)}.pcard.green{background:var(--green)}.pcard.pink{background:var(--pink)}.pcard .num{font-size:15px;font-weight:var(--semibold);letter-spacing:.1em;opacity:.9}.pcard .cname .l{text-transform:uppercase;letter-spacing:.08em;opacity:.65;font-size:10px}.pcard .cname .v{font-size:15px;font-weight:var(--semibold);margin-top:2px}.transaction-item{border-bottom:1px solid var(--gray-line);align-items:center;gap:12px;padding:14px 0;display:flex}.transaction-item:last-child{border-bottom:none}.transaction-icon{border-radius:var(--r-md);background:var(--gray);width:40px;height:40px;color:var(--gray-mid);flex-shrink:0;justify-content:center;align-items:center;display:flex}.transaction-icon.credit{background:var(--bg-green);color:var(--green)}.transaction-icon.debit{background:var(--bg-red);color:var(--red)}.transaction-icon.cashback{color:var(--pink);background:#c585b326}.transaction-details{flex:1;min-width:0}.transaction-name{font-size:var(--text-14);font-weight:var(--semibold);color:var(--black);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.transaction-meta{font-size:var(--text-12);font-weight:var(--medium);color:var(--secondary);margin-top:2px}.transaction-amount{font-size:var(--text-14);font-weight:var(--semibold);white-space:nowrap;flex-shrink:0}.transaction-amount.credit{color:var(--green)}.transaction-amount.debit{color:var(--red)}.transaction-amount.neutral{color:var(--secondary)}.list-item{border-bottom:1px solid var(--gray-line);align-items:center;gap:12px;padding:12px 0;display:flex}.list-item:last-child{border-bottom:none}.list-item-title{font-size:var(--text-14);font-weight:var(--semibold);color:var(--black)}.list-item-sub{font-size:var(--text-12);font-weight:var(--medium);color:var(--secondary);margin-top:2px}.list-item-right{flex-shrink:0;align-items:center;gap:10px;margin-left:auto;display:flex}.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--white);border:1px solid var(--stroke);border-radius:var(--r-lg);box-shadow:var(--shadow-md);width:100%;max-width:400px;padding:32px 28px}.auth-logo{justify-content:center;margin-bottom:28px;display:flex}.auth-logo img{width:auto;height:28px}.auth-heading{font-size:var(--text-24);font-weight:var(--semibold);color:var(--black);letter-spacing:-1px;margin-bottom:6px}.auth-subheading{font-size:var(--text-14);font-weight:var(--medium);color:var(--secondary);line-height:var(--lh-body);margin-bottom:24px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-footer{text-align:center;font-size:var(--text-14);font-weight:var(--medium);color:var(--secondary);margin-top:18px}.surface-bg{background:var(--bg)}.surface-white{background:var(--white)}.surface-accent{background:var(--accent)}.surface-black{background:var(--black);color:var(--white)}.surface-green{background:var(--green);color:var(--white)}.grid2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=880px){.grid3,.grid4{grid-template-columns:1fr 1fr}}@media (width<=560px){.grid2,.grid3,.grid4{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.w-full{width:100%}.hidden{display:none}.min-w-0{min-width:0}.cursor-pointer{cursor:pointer}.relative{position:relative}.absolute{position:absolute}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}@media (width<=768px){.sidebar{z-index:300;width:260px;height:100vh;transition:left .25s;position:fixed;top:0;left:-100%}.sidebar.open{left:0}.topbar{padding:0 16px}.page-content{padding:16px}.page-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:1fr 1fr}.modal{border-radius:var(--r-lg) var(--r-lg) 0 0;max-width:100%}.modal-overlay{align-items:flex-end;padding:0}.auth-card{border-radius:var(--r-card);padding:24px 20px}.portal-body{padding:16px}.toast-container{bottom:70px;left:16px;right:16px}.toast{max-width:100%}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media print{.sidebar,.topbar,.portal-bottom-nav,.btn,.toast-container{display:none!important}.app-main,.dashboard-main,.page-content{width:100%;padding:0}}:root{--color-bg:#faf4f0;--color-black:#000;--color-white:#fff;--color-primary:#ae7aff;--color-primary-dark:#8b55e0;--color-yellow:#fae8a4;--color-red:#e99898;--color-green:#98e9ab;--color-grey:#5f646d;--color-grey-light:#e8e3de;--color-grey-mid:#c4bfb9;--shadow-sm:4px 4px 0px 0px var(--color-black);--shadow-md:6px 6px 0px 0px var(--color-black);--shadow-lg:8px 8px 0px 0px var(--color-black);--shadow-xl:10px 10px 0px 0px var(--color-black);--shadow-inset:inset 2px 2px 0px 0px #00000026;--border:2px solid var(--color-black);--border-thick:3px solid var(--color-black);--border-disabled:2px solid var(--color-grey-mid);--border-radius:0px;--border-radius-sm:2px;--font-family:"Roboto Flex", system-ui, sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:1.875rem;--text-3xl:2.25rem;--text-4xl:3rem;--text-5xl:3.75rem;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--weight-extrabold:800;--weight-black:900;--font-display:font-variation-settings: "wdth" 110, "opsz" 72;--font-ui:font-variation-settings: "wdth" 100, "opsz" 24;--font-label:font-variation-settings: "wdth" 95, "opsz" 14;--font-condensed:font-variation-settings: "wdth" 80, "opsz" 20;--leading-tight:1.15;--leading-snug:1.3;--leading-normal:1.5;--leading-loose:1.7;--tracking-tight:-.03em;--tracking-normal:0em;--tracking-wide:.04em;--tracking-wider:.08em;--tracking-widest:.12em;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--sidebar-width:260px;--sidebar-collapsed:72px;--topbar-height:64px;--content-max:1200px;--card-padding:var(--space-6);--transition-fast:80ms ease;--transition-base:.15s ease;--transition-slow:.25s ease;--z-below:-1;--z-base:0;--z-raised:10;--z-dropdown:100;--z-sticky:200;--z-overlay:300;--z-modal:400;--z-toast:500}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-weight:var(--weight-regular);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-black);background-color:var(--color-bg);font-variation-settings:"wdth" 100, "opsz" 16}img,video,svg{max-width:100%;display:block}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit}ul,ol{list-style:none}:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.text-display-lg{font-size:var(--text-5xl);font-weight:var(--weight-black);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);font-variation-settings:"wdth" 115, "opsz" 144}.text-display{font-size:var(--text-4xl);font-weight:var(--weight-extrabold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);font-variation-settings:"wdth" 110, "opsz" 72}.text-h1{font-size:var(--text-3xl);font-weight:var(--weight-bold);line-height:var(--leading-snug);letter-spacing:var(--tracking-tight);font-variation-settings:"wdth" 105, "opsz" 36}.text-h2{font-size:var(--text-2xl);font-weight:var(--weight-bold);line-height:var(--leading-snug);font-variation-settings:"wdth" 100, "opsz" 30}.text-h3{font-size:var(--text-xl);font-weight:var(--weight-semibold);line-height:var(--leading-snug);font-variation-settings:"wdth" 100, "opsz" 24}.text-h4{font-size:var(--text-lg);font-weight:var(--weight-semibold);line-height:var(--leading-snug);font-variation-settings:"wdth" 100, "opsz" 20}.text-label-lg{font-size:var(--text-sm);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;font-variation-settings:"wdth" 92, "opsz" 14}.text-label{font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-widest);text-transform:uppercase;font-variation-settings:"wdth" 90, "opsz" 12}.text-body-lg{font-size:var(--text-md);line-height:var(--leading-normal);font-variation-settings:"wdth" 100, "opsz" 18}.text-body{font-size:var(--text-base);line-height:var(--leading-normal);font-variation-settings:"wdth" 100, "opsz" 16}.text-body-sm{font-size:var(--text-sm);line-height:var(--leading-normal);font-variation-settings:"wdth" 100, "opsz" 14}.text-caption{font-size:var(--text-xs);line-height:var(--leading-snug);color:var(--color-grey);font-variation-settings:"wdth" 100, "opsz" 12}.text-grey{color:var(--color-grey)}.text-black{color:var(--color-black)}.text-primary{color:var(--color-primary)}.text-success{color:#2d8b45}.text-danger{color:#c0392b}.text-warning{color:#8a6700}.font-bold{font-weight:var(--weight-bold)}.font-semibold{font-weight:var(--weight-semibold)}.font-medium{font-weight:var(--weight-medium)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.text-mono{font-family:Roboto Mono,Courier New,monospace;font-size:.9em}.icon{letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;vertical-align:middle;justify-content:center;align-items:center;font-family:Material Icons;font-size:24px;font-style:normal;font-weight:400;line-height:1;display:inline-flex}.icon-outlined{letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;vertical-align:middle;justify-content:center;align-items:center;font-family:Material Icons Outlined;font-size:24px;font-style:normal;font-weight:400;line-height:1;display:inline-flex}.icon-round{letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;vertical-align:middle;align-items:center;font-family:Material Icons Round;font-size:24px;font-style:normal;font-weight:400;line-height:1;display:inline-flex}.icon-xs{width:16px;height:16px;font-size:16px}.icon-sm{width:20px;height:20px;font-size:20px}.icon-md{width:24px;height:24px;font-size:24px}.icon-lg{width:32px;height:32px;font-size:32px}.icon-xl{width:40px;height:40px;font-size:40px}.icon-2xl{width:48px;height:48px;font-size:48px}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border:var(--border);font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wider);text-transform:uppercase;font-variation-settings:"wdth" 95, "opsz" 14;cursor:pointer;transition:box-shadow var(--transition-fast), transform var(--transition-fast), background-color var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;line-height:1;text-decoration:none;display:inline-flex;position:relative}.btn:active{transform:translate(4px,4px);box-shadow:0 0 #0000!important}.btn-primary{background-color:var(--color-primary);color:var(--color-black);box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-secondary{background-color:var(--color-white);color:var(--color-black);box-shadow:var(--shadow-md)}.btn-secondary:hover:not(:disabled){background-color:var(--color-grey-light)}.btn-ghost{color:var(--color-black);box-shadow:var(--shadow-sm);background-color:#0000}.btn-ghost:hover:not(:disabled){background-color:var(--color-grey-light)}.btn-black{background-color:var(--color-black);color:var(--color-white);box-shadow:var(--shadow-md)}.btn-black:hover:not(:disabled){background-color:#1a1a1a}.btn-success{background-color:var(--color-green);color:var(--color-black);box-shadow:var(--shadow-md)}.btn-success:hover:not(:disabled){background-color:#7bd68e}.btn-danger{background-color:var(--color-red);color:var(--color-black);box-shadow:var(--shadow-md)}.btn-danger:hover:not(:disabled){background-color:#de8080}.btn-warning{background-color:var(--color-yellow);color:var(--color-black);box-shadow:var(--shadow-md)}.btn-warning:hover:not(:disabled){background-color:#f0d880}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs);gap:var(--space-1)}.btn-sm:active{transform:translate(3px,3px)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-md);gap:var(--space-3)}.btn-xl{padding:var(--space-5) var(--space-10);font-size:var(--text-lg);gap:var(--space-3)}.btn-icon{padding:var(--space-3);aspect-ratio:1}.btn-icon.btn-sm{padding:var(--space-2)}.btn:disabled,.btn[aria-disabled=true]{background-color:var(--color-grey-light);color:var(--color-grey);border-color:var(--color-grey-mid);box-shadow:none;cursor:not-allowed;transform:none!important}.btn-full{width:100%}.input-group{gap:var(--space-2);flex-direction:column;display:flex}.input-label{font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--color-black);font-variation-settings:"wdth" 90, "opsz" 12}.input-label .required{color:var(--color-primary);margin-left:var(--space-1)}.input{width:100%;padding:var(--space-3) var(--space-4);border:var(--border);background-color:var(--color-white);color:var(--color-black);font-family:var(--font-family);font-size:var(--text-base);font-weight:var(--weight-medium);font-variation-settings:"wdth" 100, "opsz" 16;line-height:var(--leading-snug);transition:background-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base);appearance:none}.input::placeholder{color:var(--color-grey);font-weight:var(--weight-regular)}.input:focus{background-color:var(--color-black);color:var(--color-white);box-shadow:var(--shadow-sm);outline:none}.input:focus::placeholder{color:#888}.input:hover:not(:focus):not(:disabled){box-shadow:2px 2px 0px 0px var(--color-black)}.input:disabled{background-color:var(--color-grey-light);color:var(--color-grey);border-color:var(--color-grey-mid);cursor:not-allowed}.input.input-error{border-color:var(--color-red);box-shadow:3px 3px 0px 0px var(--color-red)}.input.input-success{border-color:var(--color-green)}.input-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.input-lg{padding:var(--space-4) var(--space-5);font-size:var(--text-md)}textarea.input{resize:vertical;min-height:120px}select.input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23000'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-10);cursor:pointer;background-size:20px}select.input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E")}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper .input{padding-left:var(--space-10)}.input-wrapper .input-icon-left{left:var(--space-3);color:var(--color-grey);pointer-events:none;transition:color var(--transition-base);font-size:20px;position:absolute}.input-wrapper:focus-within .input-icon-left{color:var(--color-white)}.input-wrapper .input-icon-right{right:var(--space-3);color:var(--color-grey);cursor:pointer;transition:color var(--transition-base);font-size:20px;position:absolute}.input-wrapper:focus-within .input-icon-right{color:var(--color-white)}.input-wrapper .input-icon-right~.input{padding-right:var(--space-10)}.input-hint{font-size:var(--text-xs);color:var(--color-grey);margin-top:var(--space-1)}.input-hint.error{color:#c0392b;font-weight:var(--weight-medium)}.checkbox-group{align-items:flex-start;gap:var(--space-3);cursor:pointer;display:flex}.checkbox-group input[type=checkbox]{appearance:none;border:var(--border);background-color:var(--color-white);cursor:pointer;width:20px;min-width:20px;height:20px;transition:background-color var(--transition-base);margin-top:1px;position:relative}.checkbox-group input[type=checkbox]:checked{background-color:var(--color-black)}.checkbox-group input[type=checkbox]:checked:after{content:"";border:2px solid var(--color-white);border-top:none;border-left:none;width:6px;height:10px;position:absolute;top:2px;left:5px;transform:rotate(45deg)}.checkbox-group input[type=checkbox]:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.checkbox-label{font-size:var(--text-sm);font-weight:var(--weight-medium);line-height:var(--leading-snug);padding-top:1px}.radio-group{align-items:center;gap:var(--space-3);cursor:pointer;display:flex}.radio-group input[type=radio]{appearance:none;border:var(--border);background-color:var(--color-white);cursor:pointer;width:20px;min-width:20px;height:20px;transition:background-color var(--transition-base);border-radius:50%;position:relative}.radio-group input[type=radio]:checked{background-color:var(--color-black)}.radio-group input[type=radio]:checked:after{content:"";background-color:var(--color-primary);border-radius:50%;width:8px;height:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.toggle{align-items:center;gap:var(--space-3);cursor:pointer;display:flex}.toggle-track{background-color:var(--color-grey-light);border:var(--border);cursor:pointer;width:44px;height:24px;transition:background-color var(--transition-base);flex-shrink:0;position:relative}.toggle-thumb{background-color:var(--color-black);width:16px;height:16px;transition:transform var(--transition-base);position:absolute;top:2px;left:2px}.toggle input:checked~.toggle-track{background-color:var(--color-primary)}.toggle input:checked~.toggle-track .toggle-thumb{transform:translate(20px)}.toggle input{opacity:0;width:0;height:0;position:absolute}.card{background-color:var(--color-white);border:var(--border);box-shadow:var(--shadow-md);padding:var(--card-padding);position:relative}.card-hoverable{cursor:pointer;transition:box-shadow var(--transition-base), transform var(--transition-base)}.card-hoverable:hover{box-shadow:var(--shadow-lg);transform:translate(-2px,-2px)}.card-hoverable:active{box-shadow:var(--shadow-sm);transform:translate(2px,2px)}.card-cream{background-color:var(--color-bg)}.card-purple{background-color:var(--color-primary)}.card-black{background-color:var(--color-black);color:var(--color-white)}.card-yellow{background-color:var(--color-yellow)}.card-green{background-color:var(--color-green)}.card-red{background-color:var(--color-red)}.card-header{padding-bottom:var(--space-4);border-bottom:var(--border);margin-bottom:var(--space-4);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.card-footer{padding-top:var(--space-4);border-top:var(--border);margin-top:var(--space-4);align-items:center;gap:var(--space-3);display:flex}.card-stat{gap:var(--space-2);flex-direction:column;display:flex}.card-stat-label{font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--color-grey);font-variation-settings:"wdth" 90, "opsz" 12}.card-stat-value{font-size:var(--text-3xl);font-weight:var(--weight-black);letter-spacing:var(--tracking-tight);font-variation-settings:"wdth" 105, "opsz" 36;line-height:1}.card-stat-delta{font-size:var(--text-sm);font-weight:var(--weight-semibold);align-items:center;gap:var(--space-1);display:flex}.card-stat-delta.positive{color:#2d8b45}.card-stat-delta.negative{color:#c0392b}.badge{align-items:center;gap:var(--space-1);padding:3px var(--space-3);border:1.5px solid var(--color-black);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;white-space:nowrap;font-variation-settings:"wdth" 90, "opsz" 12;display:inline-flex}.badge:before{content:"";background-color:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.badge.no-dot:before{display:none}.badge-default{background-color:var(--color-grey-light);color:var(--color-black)}.badge-primary{background-color:var(--color-primary);color:var(--color-black)}.badge-success{background-color:var(--color-green);color:var(--color-black)}.badge-danger{background-color:var(--color-red);color:var(--color-black)}.badge-warning{background-color:var(--color-yellow);color:var(--color-black)}.badge-black{background-color:var(--color-black);color:var(--color-white);border-color:var(--color-black)}.badge-black:before{background-color:var(--color-white)}.table-wrapper{border:var(--border);width:100%;box-shadow:var(--shadow-md);background-color:var(--color-white);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-widest);text-transform:uppercase;font-variation-settings:"wdth" 90, "opsz" 12;background-color:var(--color-black);color:var(--color-white);white-space:nowrap;border-right:1px solid #222}.table th:last-child{border-right:none}.table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border-top:1.5px solid var(--color-grey-light);font-variation-settings:"wdth" 100, "opsz" 14;vertical-align:middle}.table tbody tr:hover td{background-color:#f5eee9}.table tbody tr:first-child td{border-top:none}.table-striped tbody tr:nth-child(2n) td{background-color:#f8f2ed}.modal-backdrop{z-index:var(--z-modal);padding:var(--space-4);background-color:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background-color:var(--color-white);border:var(--border-thick);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;animation:modal-in var(--transition-slow) ease;position:relative;overflow-y:auto}@keyframes modal-in{0%{opacity:0;transform:translate(-4px,-8px)}to{opacity:1;transform:translate(0)}}.modal-sm{max-width:380px}.modal-lg{max-width:720px}.modal-xl{max-width:960px}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:var(--border);justify-content:space-between;align-items:center;gap:var(--space-4);background-color:var(--color-black);color:var(--color-white);display:flex}.modal-title{font-size:var(--text-lg);font-weight:var(--weight-bold);font-variation-settings:"wdth" 100, "opsz" 20}.modal-close{width:32px;height:32px;color:var(--color-white);cursor:pointer;transition:background-color var(--transition-base);background:0 0;border:1.5px solid #fff6;flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal-close:hover{background-color:#ffffff1a}.modal-body{padding:var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6);border-top:var(--border);justify-content:flex-end;align-items:center;gap:var(--space-3);display:flex}.alert{padding:var(--space-4) var(--space-5);border:var(--border);align-items:flex-start;gap:var(--space-3);font-size:var(--text-sm);font-weight:var(--weight-medium);display:flex}.alert-icon{flex-shrink:0;margin-top:1px;font-size:20px}.alert-content{flex:1}.alert-title{font-weight:var(--weight-bold);margin-bottom:var(--space-1);font-size:var(--text-sm)}.alert-info{background-color:#e8f4fd;border-left:4px solid #2196f3}.alert-success{background-color:var(--color-green);border-left:4px solid #2d8b45}.alert-warning{background-color:var(--color-yellow);border-left:4px solid #f59e0b}.alert-danger{background-color:var(--color-red);border-left:4px solid #c0392b}.toast-container{bottom:var(--space-6);right:var(--space-6);z-index:var(--z-toast);gap:var(--space-3);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{pointer-events:auto;background-color:var(--color-black);color:var(--color-white);border:var(--border);box-shadow:var(--shadow-md);padding:var(--space-3) var(--space-5);align-items:center;gap:var(--space-3);font-size:var(--text-sm);font-weight:var(--weight-semibold);min-width:280px;max-width:420px;animation:.2s toast-in;display:flex}@keyframes toast-in{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.toast-success{background-color:var(--color-green);color:var(--color-black)}.toast-danger{background-color:var(--color-red);color:var(--color-black)}.toast-warning{background-color:var(--color-yellow);color:var(--color-black)}.sidebar{width:var(--sidebar-width);background-color:var(--color-black);border-right:var(--border);flex-direction:column;flex-shrink:0;min-height:100vh;display:flex;position:sticky;top:0}.sidebar-logo{padding:var(--space-5) var(--space-6);align-items:center;gap:var(--space-3);border-bottom:1px solid #ffffff1a;display:flex}.sidebar-logo-text{font-size:var(--text-xl);font-weight:var(--weight-black);color:var(--color-white);letter-spacing:var(--tracking-tight);font-variation-settings:"wdth" 110, "opsz" 24}.sidebar-logo-text span{color:var(--color-primary)}.sidebar-nav{padding:var(--space-4) 0;flex:1}.sidebar-section-label{padding:var(--space-3) var(--space-6) var(--space-2);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:#ffffff59;font-variation-settings:"wdth" 90, "opsz" 12}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:#ffffffa6;cursor:pointer;transition:color var(--transition-base), background-color var(--transition-base), padding-left var(--transition-base);font-variation-settings:"wdth" 100, "opsz" 14;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{color:var(--color-white);background-color:#ffffff0f}.sidebar-link.active{color:var(--color-black);background-color:var(--color-primary);padding-left:calc(var(--space-6) + 4px)}.sidebar-link.active:before{content:"";background-color:var(--color-black);width:4px;position:absolute;top:0;bottom:0;left:0}.sidebar-link .icon,.sidebar-link .icon-outlined{flex-shrink:0;font-size:20px}.sidebar-footer{padding:var(--space-4) var(--space-6);border-top:1px solid #ffffff1a}.topbar{height:var(--topbar-height);background-color:var(--color-bg);border-bottom:var(--border);padding:0 var(--space-6);z-index:var(--z-sticky);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:var(--space-4);display:flex}.topbar-right{align-items:center;gap:var(--space-3);display:flex}.topbar-title{font-size:var(--text-lg);font-weight:var(--weight-bold);font-variation-settings:"wdth" 100, "opsz" 20}.tab-list{border-bottom:var(--border);-ms-overflow-style:none;scrollbar-width:none;background-color:#0000;gap:0;display:flex;overflow-x:auto}.tab-list::-webkit-scrollbar{display:none}.tab-item{padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;font-variation-settings:"wdth" 95, "opsz" 14;cursor:pointer;color:var(--color-grey);white-space:nowrap;transition:color var(--transition-base), border-color var(--transition-base);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px}.tab-item:hover{color:var(--color-black)}.tab-item.active{color:var(--color-black);border-bottom-color:var(--color-primary)}.breadcrumbs{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-grey);display:flex}.breadcrumbs a{color:var(--color-grey);font-weight:var(--weight-medium);transition:color var(--transition-base);text-decoration:none}.breadcrumbs a:hover{color:var(--color-black)}.breadcrumbs-sep{color:var(--color-grey-mid);font-size:16px}.breadcrumbs .current{color:var(--color-black);font-weight:var(--weight-semibold)}.app-shell{background-color:var(--color-bg);min-height:100vh;display:flex}.app-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.page-content{padding:var(--space-6) var(--space-8);max-width:var(--content-max);flex:1;width:100%}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-title{font-size:var(--text-2xl);font-weight:var(--weight-black);letter-spacing:var(--tracking-tight);font-variation-settings:"wdth" 105, "opsz" 30}.page-subtitle{font-size:var(--text-base);color:var(--color-grey);margin-top:var(--space-1)}.grid-2{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.auth-page{background-color:var(--color-bg);min-height:100vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex}.auth-card{background-color:var(--color-white);border:var(--border-thick);width:100%;max-width:420px;box-shadow:var(--shadow-xl);padding:var(--space-8)}.auth-logo{margin-bottom:var(--space-8);text-align:center}.auth-title{font-size:var(--text-2xl);font-weight:var(--weight-black);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-2);font-variation-settings:"wdth" 110, "opsz" 30}.auth-subtitle{font-size:var(--text-sm);color:var(--color-grey)}.auth-form{gap:var(--space-4);margin-top:var(--space-6);flex-direction:column;display:flex}.auth-divider{align-items:center;gap:var(--space-4);margin:var(--space-2) 0;color:var(--color-grey);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wider);font-weight:var(--weight-bold);display:flex}.auth-divider:before,.auth-divider:after{content:"";background-color:var(--color-grey-light);flex:1;height:1.5px}.stack{flex-direction:column;display:flex}.stack-2{gap:var(--space-2)}.stack-3{gap:var(--space-3)}.stack-4{gap:var(--space-4)}.stack-6{gap:var(--space-6)}.stack-8{gap:var(--space-8)}.row{align-items:center;display:flex}.row-2{gap:var(--space-2)}.row-3{gap:var(--space-3)}.row-4{gap:var(--space-4)}.row-6{gap:var(--space-6)}.row-between{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.divider{background-color:var(--color-black);height:2px;margin:var(--space-6) 0;border:none}.divider-light{background-color:var(--color-grey-light);height:1.5px;margin:var(--space-4) 0;border:none}.empty-state{text-align:center;padding:var(--space-16) var(--space-8);justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.empty-state-icon{color:var(--color-grey-mid);margin-bottom:var(--space-2);font-size:48px}.empty-state-title{font-size:var(--text-xl);font-weight:var(--weight-bold);font-variation-settings:"wdth" 100, "opsz" 24}.empty-state-body{font-size:var(--text-base);color:var(--color-grey);max-width:360px}.spinner{border:3px solid var(--color-grey-light);border-top-color:var(--color-black);border-radius:50%;flex-shrink:0;width:24px;height:24px;animation:.7s linear infinite spin}.spinner-sm{border-width:2px;width:16px;height:16px}.spinner-lg{border-width:4px;width:40px;height:40px}.spinner-purple{border-top-color:var(--color-primary)}.loading-screen{background-color:var(--color-bg);justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;min-height:100vh;display:flex}.avatar{border:var(--border);font-weight:var(--weight-bold);font-variation-settings:"wdth" 100, "opsz" 14;text-transform:uppercase;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-md{width:40px;height:40px;font-size:var(--text-sm)}.avatar-lg{width:56px;height:56px;font-size:var(--text-lg)}.avatar-xl{width:72px;height:72px;font-size:var(--text-xl)}.avatar-purple{background-color:var(--color-primary);color:var(--color-black)}.avatar-black{background-color:var(--color-black);color:var(--color-white)}.avatar-cream{background-color:var(--color-bg);color:var(--color-black)}.dropdown{display:inline-block;position:relative}.dropdown-menu{top:calc(100% + var(--space-2));background-color:var(--color-white);border:var(--border);box-shadow:var(--shadow-md);min-width:180px;z-index:var(--z-dropdown);padding:var(--space-2) 0;animation:.12s dropdown-in;position:absolute;left:0}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu-right{left:auto;right:0}.dropdown-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-black);cursor:pointer;transition:background-color var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;display:flex}.dropdown-item:hover{background-color:var(--color-grey-light)}.dropdown-item.danger{color:#c0392b}.dropdown-item.danger:hover{background-color:var(--color-red);color:var(--color-black)}.dropdown-separator{background-color:var(--color-grey-light);height:1.5px;margin:var(--space-2) 0}.progress-bar-track{background-color:var(--color-grey-light);border:var(--border);width:100%;height:12px;overflow:hidden}.progress-bar-fill{background-color:var(--color-primary);height:100%;transition:width var(--transition-slow)}.progress-bar-fill.success{background-color:var(--color-green)}.progress-bar-fill.danger{background-color:var(--color-red)}.steps{margin-bottom:var(--space-8);align-items:center;gap:0;display:flex}.step{flex:1;align-items:center;display:flex}.step:last-child{flex:0}.step-circle{border:var(--border-thick);width:36px;height:36px;font-size:var(--text-sm);font-weight:var(--weight-black);background-color:var(--color-white);font-variation-settings:"wdth" 100, "opsz" 14;z-index:1;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.step.active .step-circle{background-color:var(--color-primary);box-shadow:var(--shadow-sm)}.step.complete .step-circle{background-color:var(--color-black);color:var(--color-white)}.step-line{background-color:var(--color-grey-light);flex:1;height:3px;margin:0 -1px}.step.complete .step-line{background-color:var(--color-black)}.step-label{font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-grey);margin-top:var(--space-2);white-space:nowrap;font-variation-settings:"wdth" 90, "opsz" 12}.step.active .step-label,.step.complete .step-label{color:var(--color-black)}.balance-display{gap:var(--space-1);flex-direction:column;display:flex}.balance-currency{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--color-grey);letter-spacing:var(--tracking-wide);font-variation-settings:"wdth" 95, "opsz" 20}.balance-amount{font-size:var(--text-5xl);font-weight:var(--weight-black);letter-spacing:var(--tracking-tight);font-variation-settings:"wdth" 112, "opsz" 144;line-height:1}.balance-cents{font-size:var(--text-3xl);font-weight:var(--weight-extrabold);vertical-align:top;margin-top:var(--space-2);font-variation-settings:"wdth" 100, "opsz" 36}.balance-label{font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--color-grey);font-variation-settings:"wdth" 90, "opsz" 12}.campaign-card{background-color:var(--color-white);border:var(--border-thick);box-shadow:var(--shadow-lg);transition:box-shadow var(--transition-base), transform var(--transition-base);overflow:hidden}.campaign-card:hover{box-shadow:var(--shadow-xl);transform:translate(-2px,-2px)}.campaign-card-header{padding:var(--space-5) var(--space-6);background-color:var(--color-primary);border-bottom:var(--border-thick);justify-content:space-between;align-items:center;display:flex}.campaign-card-name{font-size:var(--text-lg);font-weight:var(--weight-black);font-variation-settings:"wdth" 105, "opsz" 20}.campaign-card-body{padding:var(--space-6)}.campaign-card-footer{padding:var(--space-4) var(--space-6);border-top:var(--border);background-color:var(--color-bg);align-items:center;gap:var(--space-3);display:flex}.search-wrapper{align-items:center;display:flex;position:relative}.search-input{padding-left:var(--space-10);padding-right:var(--space-10)}.search-icon{left:var(--space-3);color:var(--color-grey);pointer-events:none;transition:color var(--transition-base);font-size:20px;position:absolute}.search-wrapper:focus-within .search-icon{color:var(--color-white)}.search-clear{right:var(--space-3);cursor:pointer;color:var(--color-grey);transition:color var(--transition-base);background:0 0;border:none;align-items:center;padding:2px;font-size:18px;display:flex;position:absolute}.search-wrapper:focus-within .search-clear{color:var(--color-white)}.pagination{align-items:center;gap:var(--space-2);display:flex}.pagination-btn{border:var(--border);background-color:var(--color-white);width:36px;height:36px;font-size:var(--text-sm);font-weight:var(--weight-bold);cursor:pointer;transition:background-color var(--transition-base), box-shadow var(--transition-fast), transform var(--transition-fast);justify-content:center;align-items:center;display:flex}.pagination-btn:hover:not(:disabled){box-shadow:var(--shadow-sm);transform:translate(-2px,-2px)}.pagination-btn:active:not(:disabled){box-shadow:none;transform:translate(2px,2px)}.pagination-btn.active{background-color:var(--color-black);color:var(--color-white)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}@media (width<=1280px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=1024px){.sidebar{width:var(--sidebar-collapsed)}.sidebar-logo-text,.sidebar-section-label,.sidebar-link span{display:none}.sidebar-link{padding:var(--space-3);justify-content:center}.sidebar-link.active{padding-left:var(--space-3)}.sidebar-link.active:before{display:none}.page-content{padding:var(--space-4) var(--space-5)}.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){:root{--text-5xl:2.5rem;--text-4xl:2rem;--text-3xl:1.75rem;--text-2xl:1.5rem}.app-shell{flex-direction:column}.sidebar{border-right:none;border-top:var(--border);width:100%;min-height:auto;z-index:var(--z-sticky);flex-direction:row;padding:0;position:fixed;top:auto;bottom:0}.sidebar-logo,.sidebar-section-label,.sidebar-footer{display:none}.sidebar-nav{flex-direction:row;width:100%;padding:0;display:flex;overflow-x:auto}.sidebar-link{gap:var(--space-1);padding:var(--space-2) var(--space-3);border-right:none;flex-direction:column;flex:1;justify-content:center;min-width:64px;font-size:10px}.sidebar-link span{display:block!important}.app-main{padding-bottom:72px}.page-content{padding:var(--space-4)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.auth-card{padding:var(--space-5)}.modal-backdrop{align-items:flex-end}.modal{max-height:85vh;animation:modal-up var(--transition-slow) ease;border-bottom:none;border-left:none;border-right:none}@keyframes modal-up{0%{opacity:.5;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.toast-container{bottom:80px;right:var(--space-4);left:var(--space-4)}.toast{min-width:auto;max-width:100%}}@media (width<=480px){.btn{padding:var(--space-3) var(--space-4)}.btn-lg{padding:var(--space-3) var(--space-5);font-size:var(--text-base)}.page-header{flex-direction:column;align-items:flex-start}}@media print{.sidebar,.topbar,.btn,.toast-container{display:none!important}.app-main{padding:0}.card{box-shadow:none;border:1px solid #ccc}body{background:#fff}}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-link{top:-100%;left:var(--space-4);background-color:var(--color-black);color:var(--color-white);padding:var(--space-3) var(--space-5);font-weight:var(--weight-bold);z-index:var(--z-toast);border:var(--border);box-shadow:var(--shadow-md);position:absolute}.skip-link:focus{top:var(--space-4)}@media (forced-colors:active){.btn,.input,.card,.badge{border:2px solid buttontext}.btn:focus-visible,.input:focus-visible{outline:3px solid highlight}}
