@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+HK:wght@400;500;700&family=Poppins:wght@400;500;600;700&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Noto Sans HK,Poppins,-apple-system,BlinkMacSystemFont,sans-serif;background-color:#FAF8F5;color:#5A4E42;line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:Poppins,Noto Sans HK,sans-serif;font-weight:600;line-height:1.3}.sidebar-desktop{display:flex}.mobile-only,.mobile-topbar{display:none}.desktop-only{display:block}.app-shell{display:flex;min-height:100vh}.app-main{flex:1;min-width:0;display:flex;flex-direction:column}@media (max-width:767px){.app-shell{display:block}.app-main{width:100%;min-height:100vh}.sidebar-desktop{display:none!important}.mobile-only,.mobile-topbar{display:flex!important}.desktop-only{display:none!important}.dashboard-bottom-grid{grid-template-columns:1fr!important}.dashboard-header{flex-direction:column!important}.dashboard-header-actions{width:100%;display:flex}.dashboard-header-actions a{flex:1;justify-content:center}.page-container{padding:1rem!important}}.card{background:#ffffff;border-radius:1rem;border:1px solid #d9ccba;box-shadow:0 2px 8px 0 rgb(0 0 0/.06),0 1px 2px 0 rgb(0 0 0/.04);transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:0 8px 24px 0 rgb(0 0 0/.1),0 2px 6px 0 rgb(0 0 0/.06)}.card-premium{background:#ffffff;border-radius:1rem;border:1px solid #d9ccba;box-shadow:0 4px 16px 0 rgb(0 0 0/.08),0 1px 4px 0 rgb(0 0 0/.04);transition:box-shadow .25s ease,transform .25s ease}.card-premium:hover{box-shadow:0 12px 32px 0 rgb(35 74 58/.12),0 4px 8px 0 rgb(0 0 0/.06);transform:translateY(-2px)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;background:#234A3A;color:#ffffff;font-family:Poppins,sans-serif;font-weight:500;font-size:.875rem;border-radius:.625rem;border:none;cursor:pointer;transition:background .2s ease,box-shadow .2s ease,transform .1s ease;box-shadow:0 2px 6px 0 rgb(35 74 58/.3);text-decoration:none}.btn-primary:hover{background:#1A3829;box-shadow:0 4px 12px 0 rgb(35 74 58/.4)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;background:#EBE3D5;color:#5A4E42;font-family:Poppins,sans-serif;font-weight:500;font-size:.875rem;border-radius:.625rem;border:1px solid #d9ccba;cursor:pointer;transition:background .2s ease,transform .1s ease;text-decoration:none}.btn-secondary:hover{background:#D9CCBA}.btn-secondary:active{transform:scale(.97)}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background:transparent;color:#7D6E5D;font-size:.875rem;font-weight:500;border-radius:.5rem;border:none;cursor:pointer;transition:background .2s ease,color .2s ease;text-decoration:none}.btn-ghost:hover{background:#F5F1EB;color:#234A3A}.input{width:100%;padding:.625rem 1rem;background:#ffffff;border:1.5px solid #d9ccba;border-radius:.625rem;font-size:.9375rem;color:#5A4E42;font-family:Noto Sans HK,sans-serif;transition:border-color .2s ease,box-shadow .2s ease;outline:none}.input:focus{border-color:#2D5F4C;box-shadow:0 0 0 3px rgb(45 95 76/.12)}.input::placeholder{color:#B8A896}.input-premium{width:100%;padding:.75rem 1rem;background:#FAF8F5;border:1.5px solid #d9ccba;border-radius:.75rem;font-size:.9375rem;color:#5A4E42;font-family:Noto Sans HK,sans-serif;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;outline:none}.input-premium:focus{border-color:#2D5F4C;background:#ffffff;box-shadow:0 0 0 3px rgb(45 95 76/.12)}.input-premium::placeholder{color:#B8A896}.label{display:block;font-size:.8125rem;color:#7D6E5D;margin-bottom:.375rem;letter-spacing:.01em}.badge,.label{font-weight:600}.badge{display:inline-flex;align-items:center;padding:.2rem .625rem;border-radius:999px;font-size:.75rem;letter-spacing:.02em}.badge-success{background:#D4E9DF;color:#1A3829}.badge-warning{background:#FEF3C7;color:#92400E}.badge-danger{background:#FEE2E2;color:#991B1B}.badge-neutral{background:#EBE3D5;color:#5A4E42}.badge-info{background:#DBEAFE;color:#1E40AF}.financial-number{font-family:Poppins,monospace;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.section-title{font-size:1.25rem;font-weight:700;color:#5A4E42;font-family:Poppins,sans-serif}.section-subtitle{font-size:.8125rem;color:#9A8A78;margin-top:.125rem}.alert-error{background:#FEF2F2;border:1px solid #fecaca;border-radius:.625rem;color:#991B1B}.alert-error,.alert-success{padding:.75rem 1rem;font-size:.875rem}.alert-success{background:#F0FDF4;border:1px solid #bbf7d0;border-radius:.625rem;color:#166534}.alert-warning{padding:.75rem 1rem;background:#FFFBEB;border:1px solid #fde68a;border-radius:.625rem;color:#92400E;font-size:.875rem}.skeleton{background:linear-gradient(90deg,#EBE3D5 25%,#F5F1EB 50%,#EBE3D5 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:.5rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.progress-bar{width:100%;height:8px;background:#EBE3D5;border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#2D5F4C,#234A3A);border-radius:999px;transition:width .8s cubic-bezier(.4,0,.2,1)}.progress-fill.warning{background:linear-gradient(90deg,#F59E0B,#D97706)}.progress-fill.danger{background:linear-gradient(90deg,#EF4444,#DC2626)}.stat-card{background:#ffffff;border-radius:1rem;border:1px solid #d9ccba;padding:1.5rem;box-shadow:0 2px 8px 0 rgb(0 0 0/.06);transition:box-shadow .2s ease,transform .2s ease}.stat-card:hover{box-shadow:0 8px 24px 0 rgb(0 0 0/.1);transform:translateY(-2px)}.stat-label{font-size:.75rem;font-weight:600;color:#9A8A78;text-transform:uppercase;letter-spacing:.06em}.stat-value{font-size:1.875rem;font-weight:700;color:#5A4E42;font-family:Poppins,sans-serif;letter-spacing:-.03em;line-height:1.2;margin-top:.375rem}.stat-change{font-size:.8125rem;font-weight:500;margin-top:.5rem}.stat-change.positive{color:#2D5F4C}.stat-change.negative{color:#DC2626}.table-container{overflow-x:auto;border-radius:1rem;border:1px solid #d9ccba;box-shadow:0 2px 8px 0 rgb(0 0 0/.06)}table.data-table{width:100%;border-collapse:collapse;background:#ffffff}table.data-table thead{background:#FAF8F5;border-bottom:1px solid #ebe3d5}table.data-table th{padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:700;color:#9A8A78;text-transform:uppercase;letter-spacing:.06em}table.data-table td{padding:1rem;border-bottom:1px solid #f5f1eb;font-size:.9rem;color:#5A4E42}table.data-table tbody tr:last-child td{border-bottom:none}table.data-table tbody tr:hover td{background:#FAF8F5}.modal-overlay{position:fixed;inset:0;background:rgb(0 0 0/.4);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem;animation:fadeIn .2s ease}.modal-content{background:#ffffff;border-radius:1.25rem;box-shadow:0 24px 48px 0 rgb(0 0 0/.2);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .25s ease}.modal-header{padding:1.5rem 1.5rem 0;display:flex;align-items:center;justify-content:space-between}.modal-body{padding:1.25rem 1.5rem}.modal-footer{padding:0 1.5rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-up{animation:slideUp .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.hover-lift{transition:transform .2s ease,box-shadow .2s ease}.hover-lift:hover{transform:translateY(-3px);box-shadow:0 12px 28px 0 rgb(0 0 0/.12)}.text-income{color:#2D5F4C}.text-expense{color:#DC2626}.text-transfer{color:#3B82F6}.text-muted{color:#9A8A78}.text-heading{color:#5A4E42}.text-forest{color:#234A3A}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#F5F1EB}::-webkit-scrollbar-thumb{background:#D9CCBA;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#B8A896}@keyframes slideInRight{0%{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes slideInLeft{0%{transform:translateX(-20px);opacity:0}to{transform:translateX(0);opacity:1}}.animate-slide-in-right{animation:slideInRight .3s ease-out}.animate-slide-in-left{animation:slideInLeft .3s ease-out}