*,:before,:after{box-sizing:border-box}html,body{max-width:100vw;overflow-x:hidden}html,body,#root{height:100%}#root{max-width:100vw;overflow-x:hidden}body{color:#111827;-webkit-font-smoothing:antialiased;background-color:#f3f4f6;margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-root{background-color:#f3f4f6;max-width:100vw;min-height:100vh;display:flex;overflow-x:hidden}.app-sidebar{color:#e5e7eb;background-color:#0f172a;border-right:1px solid #1f2937;flex-direction:column;width:260px;padding:24px 16px;display:none}.app-sidebar-brand{align-items:center;gap:8px;margin-bottom:28px;padding:0 8px;display:flex}.app-sidebar-logo{color:#fff;background-color:#0f766e;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.app-sidebar-title{letter-spacing:-.02em;color:#f9fafb;font-size:14px;font-weight:600}.app-sidebar-subtitle{color:#9ca3af;font-size:11px}.app-sidebar-nav{flex:1}.app-sidebar-nav button{width:100%;color:inherit;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:22px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:10px 14px;font-size:13px;transition:background-color .2s,color .2s;display:flex}.app-sidebar-nav button.is-active{color:#fff;background-color:#0f766e}.app-sidebar-nav button:not(.is-active):hover{background-color:#94a3b833}.app-sidebar-nav button.app-sidebar-footer-btn{justify-content:flex-start;margin-bottom:4px}.app-sidebar-user-block{border-top:1px solid #1f2937;align-items:flex-start;gap:10px;margin-top:auto;margin-bottom:12px;padding-top:14px;display:flex}.app-sidebar-user-avatar{color:#5eead4;background:#0f766e59;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.app-sidebar-user-text{flex:1;min-width:0}.app-sidebar-user-name{color:#f9fafb;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;line-height:1.35;overflow:hidden}.app-sidebar-user-email{color:#9ca3af;word-break:break-word;margin-top:2px;font-size:11px}.app-sidebar-signout-btn{color:#e5e7eb;text-align:left;cursor:pointer;background:0 0;border:1px solid #374151;border-radius:22px;width:100%;margin-top:8px;padding:10px 14px;font-size:13px;transition:background-color .15s}.app-sidebar-signout-btn:hover{background:#94a3b81f}.app-sidebar-footer{color:#6b7280;border-top:1px solid #1f2937;margin-top:0;padding-top:12px;font-size:11px}.app-sidebar-footer-row{align-items:center;gap:10px;width:100%;display:flex}.app-sidebar-footer-row .app-sidebar-footer-btn{flex:1;min-width:0}@keyframes highlightFadeMaint{0%{background-color:#ccfbf1}to{background-color:#0000}}@keyframes highlightFadePayment{0%{background-color:#d1fae5}to{background-color:#0000}}.realtime-highlight--maint{animation:2s ease-out forwards highlightFadeMaint}.realtime-highlight--payment{animation:2s ease-out forwards highlightFadePayment}@keyframes bellPulseRealtime{0%,to{transform:scale(1)}25%{transform:scale(1.06)rotate(-4deg)}75%{transform:scale(1.06)rotate(4deg)}}.notifications-bell-btn--pulse{animation:.55s ease-in-out 2 bellPulseRealtime}.app-sidebar-footer-btn{width:100%;color:inherit;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:22px;align-items:center;gap:8px;margin-bottom:0;padding:10px 14px;font-size:13px;transition:background-color .2s,color .15s;display:flex}.app-sidebar-footer-btn.is-active{color:#fff;background-color:#0f766e}.app-sidebar-footer-btn:not(.is-active):hover{background-color:#94a3b833}.app-sidebar-nav-icon{flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.app-main{flex-direction:column;flex:1;min-width:0;display:flex}@media (width<=1024px){.app-main{width:100%;max-width:100vw;overflow-x:hidden}}.app-topbar{background-color:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;box-shadow:0 1px 2px #0f172a0a}.app-topbar-left{align-items:center;gap:8px;display:flex}.app-topbar-brand-text{flex-direction:column;align-items:flex-start;gap:0;min-width:0;display:flex}.app-topbar-user-name{color:#6b7280;text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:11px;font-weight:500;line-height:1.3;overflow:hidden}.app-topbar-logo{color:#fff;background-color:#0f766e;border-radius:9px;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.app-topbar-title{letter-spacing:-.02em;font-size:14px;font-weight:600}.app-topbar select{color:#111827;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;padding:4px 8px;font-size:12px}.app-content-wrapper{flex:1;min-width:0;overflow:hidden auto}.app-content-inner{max-width:1120px;margin:0 auto;padding:24px 16px 32px}@media (width<=768px){.app-content-inner{box-sizing:border-box;width:100%;max-width:100vw;padding:16px 16px 32px}.app-content-inner>*{min-width:0;max-width:100%}.app-page-header h1{font-size:20px}.app-page-header p{font-size:12px}}.app-page-header h1{letter-spacing:-.03em;color:#111827;margin:0;font-size:22px;font-weight:600}.app-page-header p{color:#6b7280;margin:4px 0 0;font-size:13px}.card{background-color:#fff;border:1px solid #e5e7eb;border-radius:14px;min-width:0;max-width:100%;overflow:hidden;box-shadow:0 8px 20px #0f172a08}.section-title,.section-subtitle,.mobile-card-value,.mobile-card-label{word-wrap:break-word;overflow-wrap:break-word}.card-padding{padding:16px}@media (width>=640px){.card-padding{padding:20px}}.section-title{color:#111827;font-size:16px;font-weight:600}.section-subtitle{color:#6b7280;margin-top:2px;font-size:13px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;gap:16px;min-width:0;max-width:100%;display:grid}@media (width>=769px){.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.dashboard-welcome{color:#111827;margin-bottom:4px;font-size:21px;font-weight:400;line-height:1.35}.dashboard-welcome-date{color:#6b7280;margin-bottom:16px;font-size:14px}.dashboard-middle{grid-template-columns:1fr;align-items:stretch;gap:20px;display:grid}@media (width>=769px){.dashboard-middle{grid-template-columns:1.5fr 1fr}}.dashboard-top-row,.dashboard-middle,.dashboard-bottom-row{min-width:0;max-width:100%}.dashboard-top-row{grid-template-columns:1fr;align-items:stretch;gap:20px;display:grid}@media (width>=769px){.dashboard-top-row{grid-template-columns:1fr 1fr;min-height:340px}}@media (width>=1025px){.dashboard-top-row{grid-template-columns:30fr 35fr 35fr;min-height:340px}}.dashboard-bottom-row{grid-template-columns:1fr;align-items:stretch;gap:20px;display:grid}@media (width>=769px){.dashboard-bottom-row{grid-template-columns:1fr 1fr;min-height:380px}}.badge{border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.badge-green{composes:badge;color:#166534;background-color:#ecfdf3;border:1px solid #bbf7d0}.badge-yellow{composes:badge;color:#854d0e;background-color:#fefce8;border:1px solid #facc15}.badge-red{composes:badge;color:#b91c1c;background-color:#fef2f2;border:1px solid #fecaca}.badge-gray{composes:badge;color:#374151;background-color:#f9fafb;border:1px solid #e5e7eb}.badge-orange{composes:badge;color:#c2410c;background-color:#fff7ed;border:1px solid #fed7aa}.badge-amber{composes:badge;color:#b45309;background-color:#fffbeb;border:1px solid #fde68a}.table-wrapper{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;max-width:100%;overflow:hidden}@media (width<=768px){.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.table-wrapper table{min-width:max-content}}table{border-collapse:collapse;width:100%;font-size:12px}thead{background-color:#f3f4f6}th,td{text-align:left;padding:8px 10px}th{color:#4b5563;font-weight:500}tbody tr:nth-child(2n){background-color:#fff}tbody tr:nth-child(odd){background-color:#f9fafb}tbody tr:hover{background-color:#eef2ff}.rent-payments-table th,.rent-payments-table td{vertical-align:middle}.rent-payments-table .payment-action-buttons{flex-direction:column;align-items:center;gap:6px;display:flex}.rent-payment-detail-row{background-color:#f9fafb}.rent-payment-detail-row td{border-top:none;padding-top:12px;padding-bottom:12px}.btn,.btn-primary,.btn-secondary,.btn-destructive,.btn-muted{cursor:pointer;border:none;border-radius:22px;justify-content:center;align-items:center;padding:10px 20px;font-size:14px;font-weight:500;text-decoration:none;transition:background-color .2s,border-color .2s,color .2s,opacity .2s;display:inline-flex}.btn:disabled,.btn-primary:disabled,.btn-secondary:disabled,.btn-destructive:disabled,.btn-muted:disabled{opacity:.5;cursor:not-allowed}.btn-sm,.btn-primary.btn-sm,.btn-secondary.btn-sm,.btn-destructive.btn-sm,.btn-muted.btn-sm{padding:6px 14px;font-size:13px}.btn-lg,.btn-primary.btn-lg,.btn-secondary.btn-lg,.btn-destructive.btn-lg,.btn-muted.btn-lg{padding:12px 24px;font-size:15px}.btn,.btn-primary{color:#fff;background-color:#0f766e;border:none}.btn:hover:not(:disabled),.btn-primary:hover:not(:disabled){background-color:#0d5c55}.btn-secondary{color:#111827;background-color:#e5e7eb;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background-color:#d1d5db}.btn-destructive{color:#fff;background-color:#dc2626;border:none}.btn-destructive:hover:not(:disabled){background-color:#b91c1c}.btn-muted{color:#6b7280;background-color:#0000;border:1px solid #d1d5db}.btn-muted:hover:not(:disabled){background-color:#f9fafb}.btn-archive-outline{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:8px;align-items:center;gap:6px;padding:6px 10px;font-size:13px;font-weight:500;display:inline-flex}.btn-archive-outline:hover:not(:disabled){color:#4b5563;background:#f9fafb}.btn-archive-outline:disabled{opacity:.5;cursor:not-allowed}.btn-archive-tenant-danger{color:#b91c1c;cursor:pointer;background:0 0;border:1px solid #dc2626;border-radius:8px;justify-content:center;align-items:center;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn-archive-tenant-danger:hover:not(:disabled){color:#991b1b;background:#fef2f2}.btn-archive-tenant-danger:disabled{opacity:.5;cursor:not-allowed}.tenants-archived-footer-link{color:#6b7280;text-underline-offset:3px;cursor:pointer;background:0 0;border:none;margin:0;padding:0;font-size:13px;text-decoration:underline;display:inline}.tenants-archived-footer-link:hover{color:#374151}.btn-ghost{cursor:pointer;color:#111827;background-color:#e5e7eb;border:1px solid #d1d5db;border-radius:22px;justify-content:center;align-items:center;padding:10px 20px;font-size:14px;font-weight:500;transition:background-color .2s,border-color .2s,color .2s;display:inline-flex}.btn-ghost:hover:not(:disabled){background-color:#d1d5db}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.btn-pill{border-radius:999px}.btn-icon-danger{color:#dc2626;cursor:pointer;background-color:#0000;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:background-color .2s,color .2s;display:inline-flex}.btn-icon-danger:hover{color:#b91c1c;background-color:#fef2f2}.btn-icon-edit{color:#d97706;cursor:pointer;background-color:#0000;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:background-color .2s,color .2s,opacity .2s;display:inline-flex}.btn-icon-edit:hover{color:#b45309;opacity:.9;background-color:#fffbeb}.maint-quick-complete-btn{color:#16a34a;cursor:pointer;background-color:#dcfce7;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:background-color .2s,color .2s,transform .15s;display:inline-flex}.maint-quick-complete-btn:hover{color:#15803d;background-color:#bbf7d0}.maint-quick-complete-btn:active{transform:scale(.96)}.maint-show-completed-row{flex-wrap:wrap;align-items:center;gap:10px 20px;margin-bottom:4px;display:flex}.maint-show-completed-label{color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;display:inline-flex}.maint-hidden-completed-hint .maint-show-completed-link{color:#0f766e;font-size:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-weight:500;text-decoration:underline}.maint-hidden-completed-hint .maint-show-completed-link:hover{color:#0d9488}.btn-icon-record{color:#16a34a;cursor:pointer;background-color:#0000;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:background-color .2s,color .2s;display:inline-flex}.btn-icon-record:hover{color:#15803d;background-color:#f0fdf4}.btn-icon-request{color:#0f766e;cursor:pointer;background-color:#0000;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:background-color .2s,color .2s;display:inline-flex}.btn-icon-request:hover{color:#0d5c56;background-color:#ecfdf5}.btn-icon-request--muted{color:#9ca3af;opacity:.6;cursor:pointer;background-color:#0000}.btn-icon-request--muted:hover{color:#9ca3af;opacity:.85;background-color:#0000}.btn-icon-check{color:#059669;cursor:pointer;background-color:#0000;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:background-color .2s,color .2s,opacity .2s;display:inline-flex}.btn-icon-check:hover{color:#047857;opacity:.9;background-color:#ecfdf5}.btn-icon-calendar{color:#6b7280;cursor:pointer;background-color:#0000;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:background-color .2s,color .2s,opacity .2s;display:inline-flex}.btn-icon-calendar:hover{color:#4b5563;opacity:.9;background-color:#f9fafb}.field{flex-direction:column;gap:4px;font-size:12px;display:flex}.field-label{color:#4b5563}.field-input,.field-select,.field-text{color:#111827;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;padding:6px 8px;font-size:12px}@media (width<=768px){.field-input,.field-select,.field-text{min-height:44px;padding:10px 12px}.field-text{min-height:80px}.btn,.btn-primary,.btn-secondary,.btn-destructive,.btn-muted,.btn-ghost{min-height:44px}.btn-sm,.btn-primary.btn-sm,.btn-secondary.btn-sm,.btn-destructive.btn-sm,.btn-muted.btn-sm{min-height:44px;padding:10px 16px}}.field-text{resize:vertical;min-height:72px}.payment-action-cell{vertical-align:middle;min-width:170px}.payment-action-mark-paid{cursor:pointer;text-align:center;color:#fff;background-color:#0f766e;border:none;border-radius:22px;width:100%;min-width:140px;padding:10px 16px;font-size:13px;font-weight:500;transition:background-color .2s}.payment-action-mark-paid:hover:not(:disabled){background-color:#0d5c55}.payment-action-stack{flex-direction:column;gap:6px;width:fit-content;display:flex}.payment-action-stack.paid-stack{width:140px}.payment-action-stack.partial-stack{width:160px}.payment-action-stack .payment-action-btn{cursor:pointer;text-align:center;border-radius:22px;width:100%;padding:8px 12px;font-size:13px;font-weight:500;transition:background-color .2s,border-color .2s}.payment-action-stack .payment-action-btn:disabled{opacity:.5;cursor:not-allowed}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.space-y-2,.space-y-3,.space-y-4,.space-y-6{min-width:0}.space-y-2>*+*{margin-top:8px}.space-y-3>*+*{margin-top:12px}.space-y-4>*+*{margin-top:16px}.space-y-6>*+*{margin-top:24px}.text-xs{font-size:11px}.text-sm{font-size:13px}.text-muted{color:#6b7280}.link-teal{color:#0f766e;font-weight:500;text-decoration:none}.link-teal:hover{text-decoration:underline}.checkbox-label{color:#374151;cursor:pointer;align-items:center;gap:8px;font-size:12px;display:flex}.expense-category-badge{border-radius:6px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.expense-recurring-badge{color:#0f766e;background-color:#0f766e1f;border-radius:6px;align-items:center;gap:4px;padding:2px 6px;font-size:10px;font-weight:500;display:inline-flex}.text-right{text-align:right}@media (width<=768px){.hide-on-mobile{display:none!important}}@media (width>=769px){.show-on-mobile-only{display:none!important}}@media (width<=768px){.show-on-mobile-only{display:block}.table-wrapper.table-cards-mobile table{display:none}.table-cards-mobile .table-mobile-cards{flex-direction:column;gap:12px;display:flex}}@media (width>=769px){.table-cards-mobile .table-mobile-cards{display:none}}.mobile-table-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:10px;min-width:0;max-width:100%;padding:14px 16px;box-shadow:0 1px 3px #0000000d}.table-mobile-cards{min-width:0;max-width:100%}.mobile-table-card .mobile-card-row{justify-content:space-between;align-items:center;gap:12px;min-width:0;margin-bottom:8px;display:flex}.mobile-table-card .mobile-card-row:last-child{margin-bottom:0}.mobile-table-card .mobile-card-field{flex-direction:column;gap:2px;margin-bottom:8px;display:flex}.mobile-table-card .mobile-card-field:last-of-type{margin-bottom:0}.mobile-table-card .mobile-card-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:11px}.mobile-table-card .mobile-card-value{color:#111827;word-wrap:break-word;min-width:0;font-size:13px;font-weight:500}.mobile-table-card .mobile-card-value.text-muted{color:#6b7280}.mobile-table-card .mobile-card-actions{border-top:1px solid #e5e7eb;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;display:flex}.month-year-nav{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.month-year-nav-label{margin:0;display:inline-flex}.month-year-nav-select{color:#111827;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;min-width:0;padding:10px 12px;font-size:14px;line-height:1.25}.month-year-nav-select:focus{border-color:#0f766e;outline:none;box-shadow:0 0 0 3px #0f766e26}.btn-teal-outline-pill{color:#0f766e;cursor:pointer;background:0 0;border:1px solid #0f766e;border-radius:999px;justify-content:center;align-items:center;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.btn-teal-outline-pill:hover:not(:disabled){background:#0f766e14}.btn-teal-outline-pill.btn-sm{padding:8px 14px;font-size:13px}.auth-card--signup{border-left:4px solid #0f766e;box-shadow:0 4px 24px #0f766e14}.auth-card--login{border-left:4px solid #0000}.tenant-portal-landlord-name{color:#111827;margin:0 0 8px;font-size:17px;font-weight:600}.tenant-portal-landlord-email a{color:#0f766e;text-decoration:none}.tenant-portal-landlord-email a:hover{text-decoration:underline}.calendar-nav--month-dropdowns{flex-wrap:wrap;width:100%}.calendar-month-year-nav{flex:auto;min-width:0}@media (width<=768px){.rent-payments-month-nav{flex-direction:column;align-items:stretch}.rent-payments-month-nav .btn-teal-outline-pill{justify-content:center;width:100%}.rent-payments-month-nav .month-year-nav-label,.rent-payments-month-nav .month-year-nav-select{width:100%}}img,canvas,svg{max-width:100%;height:auto}@media (width<=768px){body{line-height:1.5}}.field-input.is-invalid,.field-select.is-invalid,.field-text.is-invalid{border-color:#dc2626;box-shadow:0 0 0 1px #dc2626}.field-error{color:#dc2626;margin-top:2px;font-size:11px}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield}.modal-overlay{z-index:1000;background-color:#0f172a66;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-content,.modal-container{background-color:#fff;border:1px solid #e5e7eb;border-radius:14px;flex-direction:column;width:100%;min-width:320px;max-width:480px;min-height:0;max-height:min(90vh,100vh - 48px);display:flex;overflow:hidden;box-shadow:0 20px 40px #0f172a26}.modal-content .modal-form{flex-direction:column;flex:1;min-height:0;display:flex}.modal-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{color:#111827;margin:0;font-size:16px;font-weight:600}.modal-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:20px;line-height:1;transition:color .15s,background-color .15s;display:flex}.modal-close:hover{color:#111827;background-color:#f3f4f6}.modal-body{-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:16px 20px;overflow-y:auto}.modal-footer{background-color:#fff;border-top:1px solid #e5e7eb;border-radius:0 0 14px 14px;flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;align-items:center;gap:8px;padding:12px 20px;display:flex}.modal-content--feedback{width:100%;max-width:440px}.feedback-modal-footer{justify-content:flex-end}.feedback-textarea{resize:vertical;min-height:96px}.feedback-type-seg{flex-direction:column;gap:8px;display:flex}.feedback-type-seg__btn{color:#111827;text-align:left;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;font-size:13px;transition:border-color .15s,background-color .15s;display:flex}.feedback-type-seg__btn:hover{background:#f9fafb;border-color:#cbd5e1}.feedback-type-seg__btn.is-active{color:#0f766e;background:#ecfdf5;border-color:#0f766e}.feedback-type-seg__btn-title{font-size:14px;font-weight:600}.feedback-type-seg__btn-hint{color:#64748b;font-size:12px;font-weight:400}.feedback-type-seg__btn.is-active .feedback-type-seg__btn-hint{color:#0f766e;opacity:.9}.feedback-modal-success{text-align:center;padding-bottom:8px}.feedback-modal-success-icon{justify-content:center;margin-bottom:12px;display:flex}.feedback-modal-success-text{color:#334155;margin:0;font-size:15px;line-height:1.5}.feedback-fab{z-index:1300;color:#fff;cursor:pointer;background-color:#0f766e;border:none;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;transition:background-color .15s,box-shadow .15s,transform .12s;display:inline-flex;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 14px #0f172a2e}.feedback-fab:hover{background-color:#0d5c55;box-shadow:0 6px 18px #0f172a3d}.feedback-fab:active{transform:scale(.98)}.feedback-fab__icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}@media (width<=768px){.feedback-fab{bottom:calc(72px + env(safe-area-inset-bottom,0px));border-radius:50%;width:56px;height:56px;padding:0;right:16px}.feedback-fab__label{display:none}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.welcome-modal-overlay{z-index:12000;background-color:#0f172a80;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.welcome-modal-panel{background:#fff;border:1px solid #e5e7eb;border-radius:16px;width:100%;max-width:520px;padding:28px 28px 24px;box-shadow:0 24px 48px #0f172a2e}.welcome-modal-brand{letter-spacing:-.02em;justify-content:center;align-items:center;gap:10px;margin-bottom:20px;font-size:18px;font-weight:700;display:flex}.welcome-modal-logo{color:#0f766e;background:#0f766e1f;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:800;display:inline-flex}.welcome-modal-heading{color:#111827;text-align:center;margin:0 0 8px;font-size:22px;font-weight:700;line-height:1.25}.welcome-modal-sub{color:#6b7280;text-align:center;margin:0 0 24px;font-size:14px;line-height:1.5}.welcome-modal-steps{flex-direction:column;gap:12px;margin:0 0 24px;padding:0;list-style:none;display:flex}.welcome-modal-step{text-align:left;background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;gap:14px;padding:14px 16px;display:flex}.welcome-modal-step--current{background:#0f766e0f;border-color:#0f766e;box-shadow:0 0 0 1px #0f766e26}.welcome-modal-step--muted{opacity:.72}.welcome-modal-step-icon{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.welcome-modal-step--current .welcome-modal-step-icon{background:#ffffffe6;border-color:#0f766e59}.welcome-modal-step-title{color:#111827;margin-bottom:4px;font-size:15px;font-weight:600}.welcome-modal-step-desc{color:#6b7280;margin:0;font-size:13px;line-height:1.45}.welcome-modal-step--muted .welcome-modal-step-title{color:#4b5563}.welcome-modal-step--muted .welcome-modal-step-desc{color:#9ca3af}.welcome-modal-cta{justify-content:center;width:100%}.welcome-modal-footnote{text-align:center;color:#9ca3af;margin:12px 0 0;font-size:12px}.page-empty-state-wrap{background:#fafafa;border:1px solid #e5e7eb;border-radius:12px}.modal-overlay--import{z-index:1100;align-items:center;padding:16px}.modal-content--import{flex-direction:column;width:100%;max-width:min(960px,100%);min-height:min(90vh,840px);max-height:calc(100vh - 32px);display:flex;overflow:hidden}.expense-import-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.expense-import-step-indicator{color:#0f766e;font-size:13px;font-weight:600}.expense-import-body{flex:1;min-height:0;padding:20px 24px 24px;overflow-y:auto}.expense-import-step{max-width:720px;margin:0 auto}.expense-import-heading{color:#111827;margin:0 0 8px;font-size:1.25rem;font-weight:600}.expense-import-subtitle{margin:0 0 20px}.expense-import-dropzone{text-align:center;cursor:pointer;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px;padding:40px 24px;transition:border-color .15s,background .15s}.expense-import-dropzone:hover{background:#f0fdfa;border-color:#0f766e}.expense-import-dropzone-icon{color:#94a3b8;margin-bottom:12px}.expense-import-dropzone-text{color:#334155;margin:0 0 8px;font-size:15px}.expense-import-file-meta{margin-top:16px;font-size:14px}.expense-import-hint{margin-top:16px}.expense-import-banner.warning{color:#92400e;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;margin-bottom:16px;padding:12px 14px;font-size:14px}.expense-import-preview-wrap{margin-bottom:20px}.expense-import-table-wrap{border:1px solid #e5e7eb;border-radius:8px;overflow-x:auto}.expense-import-preview-table{border-collapse:collapse;width:100%;font-size:12px}.expense-import-preview-table th,.expense-import-preview-table td{text-align:left;text-overflow:ellipsis;border-bottom:1px solid #f3f4f6;max-width:180px;padding:8px 10px;overflow:hidden}.expense-import-preview-table th{background:#f9fafb;font-weight:600}.expense-import-mapping-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:20px;display:grid}.expense-import-field .field-label{margin-bottom:6px;display:block}.expense-import-amount-format{border:none;margin:0 0 24px;padding:0}.expense-import-amount-format legend{margin-bottom:10px}.expense-import-radio{cursor:pointer;align-items:center;gap:8px;margin-bottom:8px;font-size:14px;display:flex}.expense-import-footer-btns{flex-wrap:wrap;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:8px;display:flex}.expense-import-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px;display:flex}.expense-import-checkbox{cursor:pointer;align-items:center;gap:8px;font-size:14px;display:flex}.expense-import-filters{flex-wrap:wrap;gap:8px;display:flex}.btn-filter-chip{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:999px;padding:6px 12px;font-size:13px}.btn-filter-chip.is-active{color:#0f766e;background:#ecfdf5;border-color:#0f766e;font-weight:600}.expense-import-apply-prop{align-items:center;gap:8px;margin-left:auto;display:flex}.expense-import-review-wrap{max-height:min(50vh,420px)}.expense-import-review-table{border-collapse:collapse;width:100%;font-size:13px}.expense-import-review-table th,.expense-import-review-table td{vertical-align:top;border-bottom:1px solid #f3f4f6;padding:8px 10px}.expense-import-review-table th.th-check{width:36px}.expense-import-review-table tr.is-warning{background:#fffbeb}.field-select--sm{min-width:140px;padding:6px 8px;font-size:12px}.expense-import-desc{word-break:break-word;max-width:220px}.expense-import-suggested-badge{text-transform:uppercase;letter-spacing:.04em;color:#64748b;margin-left:6px;font-size:10px;font-weight:600;display:inline-block}.expense-import-dup-badge{white-space:nowrap;font-size:11px}.expense-import-summary-bar{background:#f9fafb;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;padding:12px 14px;font-size:14px;display:flex}.expense-import-summary-list{margin:0 0 24px;padding-left:1.25rem;font-size:15px;line-height:1.7}.expense-import-go{min-width:200px}.expense-import-progress-bar{background:#e5e7eb;border-radius:999px;height:10px;margin:16px 0 8px;overflow:hidden}.expense-import-progress-fill{background:linear-gradient(90deg,#0f766e,#14b8a6);height:100%;transition:width .2s}.expense-import-success{text-align:center;padding:16px 8px 8px}.expense-import-success-icon{margin-bottom:12px}.expense-import-failures{text-align:left;max-width:480px;margin-top:20px;margin-left:auto;margin-right:auto}.expense-import-failures ul{color:#b91c1c;font-size:13px}.expense-import-trigger.btn-secondary{font-weight:500}@media (width<=768px){.modal-overlay--import{align-items:stretch;padding:0}.modal-content--import{border-radius:0;max-width:none;min-height:100vh;max-height:100vh}.modal-overlay{padding:max(12px, env(safe-area-inset-top,0px)) 12px max(12px, env(safe-area-inset-bottom,0px)) 12px;justify-content:center;align-items:center}.modal-content,.modal-container{border-radius:14px;width:100%;min-width:0;max-width:none;height:auto;min-height:0;max-height:min(90vh,100dvh - 24px);position:relative;top:auto;left:auto}.modal-close{width:44px;min-width:44px;height:44px;min-height:44px}}@media (width>=1025px){.app-sidebar{display:flex}.app-topbar{display:none}}@media (width<=1024px){.app-sidebar{display:none}.app-topbar{display:flex}}.app-sidebar-overlay{z-index:1100;pointer-events:none;visibility:hidden;transition:visibility .2s;position:fixed;inset:0}.app-sidebar-overlay.is-open{pointer-events:auto;visibility:visible}.app-sidebar-backdrop{opacity:0;background-color:#0f172a80;transition:opacity .25s;position:absolute;inset:0}.app-sidebar-overlay.is-open .app-sidebar-backdrop{opacity:1}.app-sidebar-drawer{color:#e5e7eb;background-color:#0f172a;flex-direction:column;width:280px;max-width:85vw;height:100%;padding:24px 16px;transition:transform .25s;display:flex;position:absolute;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #0003}.app-sidebar-overlay.is-open .app-sidebar-drawer{transform:translate(0)}.app-sidebar-drawer .app-sidebar-nav button,.app-sidebar-drawer .app-sidebar-footer-btn{min-height:44px}.app-hamburger-btn{color:#0f766e;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:44px;min-width:44px;height:44px;min-height:44px;padding:0;transition:background-color .15s;display:flex}.app-hamburger-btn:hover{background-color:#0f766e1a}.app-hamburger-btn svg{width:24px;height:24px}.app-sidebar-drawer-close{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:24px;line-height:1;transition:color .15s,background-color .15s;display:flex;position:absolute;top:16px;right:16px}.app-sidebar-drawer-close:hover{color:#fff;background-color:#ffffff1a}.app-mobile-bottom-nav{display:none}@media (width<=768px){.app-hamburger-btn{display:none!important}.app-topbar{justify-content:center}.app-topbar-left{flex:1;justify-content:center;min-width:0}.app-content-wrapper{padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.app-mobile-bottom-nav{z-index:1200;box-sizing:border-box;min-height:calc(62px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background-color:#fff;border-top:1px solid #e5e7eb;justify-content:center;align-items:flex-end;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #0f172a0f}.app-mobile-bottom-nav-inner{box-sizing:border-box;grid-template-columns:1fr 1fr 1fr 1fr 1fr;align-items:end;width:100%;max-width:520px;margin:0 auto;padding:0 4px 6px;display:grid}.app-mobile-nav-item{cursor:pointer;color:#9ca3af;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;justify-content:flex-end;align-items:center;gap:4px;min-height:48px;padding:4px 2px 8px;display:flex}.app-mobile-nav-item.is-active{color:#0f766e}.app-mobile-nav-item-icon{justify-content:center;align-items:center;height:26px;display:flex}.app-mobile-nav-item-label{color:#9ca3af;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:11px;font-weight:500;line-height:1.1;overflow:hidden}.app-mobile-nav-item.is-active .app-mobile-nav-item-label{color:#0f766e}.app-mobile-nav-fab-wrap{pointer-events:none;flex-direction:column;justify-content:flex-start;align-items:center;padding-bottom:2px;display:flex}.app-mobile-nav-fab{pointer-events:auto;color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background-color:#0f766e;border:none;border-radius:50%;justify-content:center;align-items:center;width:54px;min-width:54px;height:54px;min-height:54px;margin-top:-22px;margin-bottom:2px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 14px #0f766e66}.app-mobile-nav-fab:active{transform:scale(.96)}}.mobile-nav-sheet-root{display:none}@media (width<=768px){.mobile-nav-sheet-root{z-index:1250;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.mobile-nav-sheet-backdrop{cursor:pointer;opacity:0;-webkit-tap-highlight-color:transparent;background-color:#0f172a85;border:none;margin:0;padding:0;transition:opacity .28s;display:block;position:absolute;inset:0}.mobile-nav-sheet-backdrop.is-open{opacity:1}.mobile-nav-sheet-panel{z-index:1;width:100%;max-width:100%;max-height:min(88vh,640px);padding:8px 0 calc(16px + env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch;background-color:#fff;border-radius:18px 18px 0 0;transition:transform .3s cubic-bezier(.32,.72,0,1);position:relative;overflow-y:auto;transform:translateY(100%);box-shadow:0 -8px 32px #0f172a1f}.mobile-nav-sheet-panel.is-open{transform:translateY(0)}.mobile-nav-sheet-handle{background-color:#e5e7eb;border-radius:999px;flex-shrink:0;width:40px;height:5px;margin:4px auto 16px}.mobile-nav-sheet-action{text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-bottom:1px solid #f3f4f6;align-items:center;gap:16px;width:100%;padding:16px 20px;display:flex}.mobile-nav-sheet-action:active{background-color:#f9fafb}.mobile-nav-sheet-action-icon{background-color:#0f766e1a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.mobile-nav-sheet-action-text{flex-direction:column;gap:4px;min-width:0;display:flex}.mobile-nav-sheet-action-title{color:#111827;font-size:16px;font-weight:700}.mobile-nav-sheet-action-sub{color:#6b7280;font-size:13px;line-height:1.35}.mobile-nav-sheet-cancel{color:#9ca3af;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:12px;width:calc(100% - 32px);margin:12px 16px 0;padding:14px 16px;font-size:16px;font-weight:600;display:block}.mobile-nav-sheet-cancel:active{background-color:#f3f4f6}.mobile-nav-more-list{flex-direction:column;gap:4px;padding:0 8px 8px;display:flex}.mobile-nav-more-row{text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:12px;align-items:center;gap:16px;width:100%;min-height:52px;padding:12px 16px;display:flex}.mobile-nav-more-row:active{background-color:#f3f4f6}.mobile-nav-more-row.is-active{background-color:#0f766e1a}.mobile-nav-more-label{color:#111827;font-size:16px;font-weight:600}.mobile-nav-more-row.is-active .mobile-nav-more-label{color:#0f766e}.mobile-nav-more-icon{flex-shrink:0;justify-content:center;align-items:center;width:40px;display:flex}}.reports-page{flex-direction:column;gap:20px;display:flex}.reports-type-selector{background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;align-self:flex-start;gap:0;padding:4px;display:flex}.reports-type-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:500;transition:background-color .15s,color .15s}.reports-type-btn:hover{color:#111827;background-color:#ffffffb3}.reports-type-btn.is-active{color:#0f766e;background-color:#fff;box-shadow:0 1px 2px #0000000d}.reports-filter-bar{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:12px;padding:12px 16px;display:flex;box-shadow:0 1px 2px #0f172a0a}.reports-filters{flex-wrap:wrap;flex:1;align-items:flex-end;gap:12px;display:flex}@media (width<=768px){.reports-filter-bar{flex-direction:column;align-items:stretch}.reports-filters{flex-direction:column}.reports-filter-group{width:100%}.reports-filter-select,.reports-filter-input{width:100%;min-width:0}.reports-actions{flex-direction:column}.reports-actions button{width:100%;min-height:44px}}.reports-filter-group{flex-direction:column;gap:4px;display:flex}.reports-filter-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:500}.reports-filter-select,.reports-filter-input{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;min-width:120px;padding:6px 10px;font-size:12px}.reports-filter-custom-dates{align-items:center;gap:8px;margin-top:4px;display:flex}.reports-actions{align-items:center;gap:8px;display:flex}.reports-export-btn{color:#fff!important;background-color:#0f766e!important;border-color:#0f766e!important}.reports-print-btn{color:#111827!important;background-color:#e5e7eb!important;border:1px solid #d1d5db!important}.reports-print-btn:hover{background-color:#d1d5db!important}.reports-export-wrapper{position:relative}.reports-export-dropdown{z-index:50;background:#fff;border:1px solid #e5e7eb;border-radius:8px;min-width:180px;margin-top:4px;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 4px 12px #0000001a}.reports-export-dropdown button{text-align:left;cursor:pointer;color:#111827;background:0 0;border:none;width:100%;padding:8px 12px;font-size:12px;display:block}.reports-export-dropdown button:hover{background-color:#f3f4f6}.reports-export-overlay{z-index:40;position:fixed;inset:0}.reports-content{flex-direction:column;gap:24px;display:flex}.reports-card{break-inside:avoid}.reports-empty{text-align:center;color:#6b7280;background-color:#f9fafb;border:1px dashed #e5e7eb;border-radius:8px;padding:24px;font-size:13px}.reports-summary-row{font-weight:600;background-color:#f3f4f6!important}.reports-summary-row td{padding:10px!important}.reports-category-subtotal{font-weight:500;background-color:#f9fafb!important}.reports-top-categories{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:16px;display:grid}.reports-stat-card{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:12px}.reports-stat-label{color:#6b7280;margin-bottom:4px;font-size:11px}.reports-stat-value{color:#111827;font-size:14px;font-weight:600}.settings-page{flex-direction:column;gap:24px;display:flex}.settings-card{margin:0}.settings-card--teal-header{padding:0;overflow:hidden}.settings-section-header{color:#fff;background-color:#0f766e;border-radius:14px 14px 0 0;align-items:center;margin:0;padding:12px 16px;display:flex}.settings-section-header__title{color:#fff;letter-spacing:-.02em;margin:0;font-size:16px;font-weight:600}.settings-section-body{padding:20px}.settings-card--teal-header.settings-card-danger{border-left:none}.settings-card--teal-header.settings-card-danger .settings-section-body{border-left:3px solid #dc2626}.settings-card .section-title{margin-bottom:16px}.settings-form{max-width:400px}.settings-divider{background-color:#e5e7eb;border:none;height:1px;margin:20px 0 16px}.settings-subheading{color:#374151;margin:0 0 12px;font-size:14px;font-weight:600}.settings-info-grid{flex-direction:column;gap:16px;max-width:480px;display:flex}.settings-info-row{grid-template-columns:1fr;align-items:start;gap:4px;display:grid}@media (width>=400px){.settings-info-row{grid-template-columns:120px 1fr;gap:12px}}.settings-info-row .field-label{color:#6b7280;flex-shrink:0}.settings-message{margin-top:6px;font-size:12px}.settings-message-success{color:#059669}.settings-message-error{color:#dc2626}.badge-teal{color:#0f766e;background-color:#0f766e1f;border:1px solid #0f766e4d;border-radius:999px;align-items:center;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.settings-card-danger{border-left:3px solid #dc2626}.section-title-danger{color:#b91c1c}.settings-stripe-connect-btn{align-items:center;gap:8px;display:inline-flex;background-color:#0f766e!important;border-color:#0f766e!important}.settings-stripe-connect-btn:hover:not(:disabled){background-color:#0c6a63!important;border-color:#0c6a63!important}.settings-stripe-connect-icon{opacity:.95;display:inline-flex}.settings-stripe-connected{align-items:center;gap:10px;display:flex}.settings-stripe-check{color:#059669;background:#0596691f;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.settings-stripe-connected-label{color:#111827;font-weight:600}.settings-stripe-disconnect{color:#6b7280;cursor:pointer;background:0 0;border:none;width:fit-content;padding:0;font-size:13px;text-decoration:underline}.settings-stripe-disconnect:hover:not(:disabled){color:#374151}.settings-stripe-disconnect:disabled{opacity:.6;cursor:not-allowed}.app-stripe-oauth-banner{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 16px;font-size:14px;line-height:1.45;display:flex}.app-stripe-oauth-banner--success{color:#065f46;background-color:#ecfdf5}.app-stripe-oauth-banner--error{color:#991b1b;background-color:#fef2f2}.app-stripe-oauth-banner-text{flex:1;min-width:0}.app-stripe-oauth-banner-dismiss{cursor:pointer;color:inherit;opacity:.7;background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:22px;line-height:1}.app-stripe-oauth-banner-dismiss:hover{opacity:1}.receipt-dropzone{cursor:pointer;background-color:#f9fafb;border:2px dashed #d1d5db;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:24px 16px;transition:border-color .15s,background-color .15s;display:flex}.receipt-dropzone:hover,.receipt-dropzone.is-dragging{background-color:#0f766e0a;border-color:#0f766e66}.receipt-dropzone.is-invalid{border-color:#dc2626}.receipt-dropzone-icon{opacity:.6;font-size:20px}.receipt-dropzone-text{color:#6b7280;font-size:13px}.receipt-dropzone-hint{color:#9ca3af;font-size:11px}.expenses-payment-accounts-banner{color:#1e3a5f;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;flex-wrap:wrap;align-items:flex-start;gap:12px;padding:12px 14px;font-size:14px;line-height:1.45;display:flex}.expenses-payment-accounts-banner__icon{color:#2563eb;flex-shrink:0;margin-top:1px}.expenses-payment-accounts-banner__text{flex:1;min-width:min(100%,240px);margin:0}.expenses-payment-accounts-banner__cta{color:#0f766e;cursor:pointer;text-underline-offset:2px;background:0 0;border:none;flex-shrink:0;padding:0;font-size:14px;font-weight:600;text-decoration:underline}.expenses-payment-accounts-banner__cta:hover{color:#0d5c55}.expenses-payment-accounts-banner__dismiss{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;width:32px;height:32px;margin:-4px -6px -4px 0;font-size:20px;line-height:1}.expenses-payment-accounts-banner__dismiss:hover{color:#334155;background:#ffffffb3}.expense-account-helper{line-height:1.4}.expense-account-settings-link{font:inherit;font-size:inherit;color:#0f766e;cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;text-decoration:underline}.expense-account-settings-link:hover{color:#0d5c55}.receipt-upload-preview{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:12px;padding:12px;display:flex}.receipt-preview-pdf,.receipt-preview-existing{color:#374151;align-items:center;gap:8px;font-size:13px;display:flex}.receipt-preview-icon{font-size:18px}.receipt-preview-filename{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.receipt-preview-image{flex:1;min-width:0}.receipt-preview-image img{object-fit:contain;border-radius:6px;max-width:120px;max-height:80px}.receipt-replace-btn,.receipt-remove-btn{flex-shrink:0;font-size:12px}.receipt-indicator-btn{color:#0f766ecc;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:color .15s,background-color .15s;display:inline-flex}.receipt-indicator-btn:hover{color:#0f766e;background-color:#0f766e1a}.receipt-viewer-modal{max-width:560px}.receipt-viewer-body{text-align:center;flex-direction:column;align-items:center;display:flex}.receipt-viewer-image img{object-fit:contain;border-radius:8px;max-width:100%;max-height:70vh}.receipt-viewer-pdf{padding:24px 0}.calendar-page{box-sizing:border-box;width:100%;min-width:0;max-width:1200px;overflow:hidden}.calendar-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.calendar-nav{align-items:center;gap:8px;display:flex}.calendar-title{text-align:center;min-width:200px;margin:0;font-size:18px;font-weight:600}.calendar-view-toggles{gap:4px;display:flex}.calendar-view-btn{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:22px;padding:8px 18px;font-size:13px;font-weight:500;transition:all .2s}.calendar-view-btn:hover{color:#111827;background:#f9fafb}.calendar-view-btn.is-active{color:#fff;background:#0f766e;border-color:#0f766e}.calendar-filters{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.calendar-filter-btn.is-active{color:#0f766e;background:#0f766e1f;border-color:#0f766e}.calendar-legend{color:#6b7280;flex-wrap:wrap;gap:16px;margin-bottom:16px;font-size:11px;display:flex}.cal-legend-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.cal-legend-rent-due{background:#0f766e4d;border:1px solid #0f766e}.cal-legend-rent-paid{background:#166534}.cal-legend-rent-partial{background:#166534;border:2px dashed #dc2626}.cal-legend-completed{background:#d1fae5;border:1px solid #059669}.calendar-month-grid{box-sizing:border-box;background:#fff;border:1px solid #e5e7eb;border-radius:14px;grid-template-columns:repeat(7,minmax(0,1fr));width:100%;min-width:0;max-width:100%;display:grid;overflow:hidden}.calendar-weekdays{grid-column:1/-1;grid-template-columns:subgrid;color:#4b5563;text-transform:uppercase;background:#f9fafb;border-bottom:1px solid #e5e7eb;min-width:0;font-size:11px;font-weight:600;display:grid}.cal-weekday{text-align:center;text-overflow:ellipsis;box-sizing:border-box;min-width:0;padding:8px 4px;overflow:hidden}.cal-weekday.is-weekend{background:#00000005}.calendar-week-row{grid-column:1/-1;grid-template-columns:subgrid;border-bottom:1px solid #e5e7eb;min-width:0;min-height:100px;display:grid}@supports not (grid-template-columns:subgrid){.calendar-weekdays,.calendar-week-row{grid-template-columns:repeat(7,minmax(0,1fr))}}.calendar-week-row:last-child{border-bottom:none}.calendar-day-cell{cursor:pointer;box-sizing:border-box;border-right:1px solid #e5e7eb;flex-direction:column;align-items:stretch;min-width:0;max-width:100%;min-height:96px;padding:6px;display:flex;overflow:hidden}.calendar-event-dot-mobile{display:none}@media (width<=768px){.calendar-day-cell{min-height:64px;padding:3px 2px}.cal-weekday{padding:6px 2px;font-size:10px}.calendar-day-num{width:22px;height:22px;font-size:12px}.calendar-event-dot-mobile{cursor:pointer;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin:2px auto 0;display:block}.calendar-day-cell.has-events .calendar-day-events .calendar-event-pill,.calendar-day-cell.has-events .calendar-day-events .calendar-more-btn{display:none}.calendar-week-grid-mobile .calendar-week-header,.calendar-week-grid-mobile .calendar-week-body{grid-template-columns:repeat(3,1fr)}}.calendar-day-cell:last-child{border-right:none}.calendar-day-cell.other-month{background:#fafafa}.calendar-day-cell.other-month .calendar-day-num{color:#9ca3af}.calendar-day-cell.is-weekend{background:#00000003}.calendar-day-num{color:#374151;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;margin-bottom:4px;font-size:13px;font-weight:500;display:flex}.calendar-day-num.is-today{color:#0f766e;background:#0f766e26}.calendar-day-events{box-sizing:border-box;flex-direction:column;flex:1;gap:2px;width:100%;min-width:0;max-width:100%;min-height:0;display:flex;overflow:hidden}.calendar-event-pill{white-space:nowrap;text-overflow:ellipsis;cursor:pointer;box-sizing:border-box;border-radius:999px;flex-shrink:0;width:100%;min-width:0;max-width:100%;padding:2px 6px;font-size:12px;transition:opacity .15s;overflow:hidden}.calendar-event-pill:hover{opacity:.9}.calendar-event-pill.is-completed,.calendar-week-event.is-completed{align-items:center;gap:4px;display:flex}.cal-event-check{flex-shrink:0;font-size:11px;font-weight:700;line-height:1}.cal-event-strike{text-decoration:line-through}.calendar-more-btn{color:#6b7280;cursor:pointer;text-align:left;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box;background:#f3f4f6;border:none;border-radius:4px;min-width:0;max-width:100%;padding:2px 4px;font-size:10px;overflow:hidden}.calendar-day-popup-overlay{z-index:1000;background:#0f172a4d;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.calendar-day-popup{background:#fff;border:1px solid #e5e7eb;border-radius:14px;width:100%;max-width:360px;padding:20px;box-shadow:0 20px 40px #00000026}.calendar-day-popup-overlay--desktop{min-height:100%;padding:max(16px, env(safe-area-inset-top)) 20px max(24px, env(safe-area-inset-bottom)) 20px;-webkit-overflow-scrolling:touch;justify-content:center;align-items:center;overflow-y:auto}.calendar-day-popup-desktop-box{-webkit-overflow-scrolling:touch;flex-shrink:0;width:100%;max-width:400px;max-height:min(85vh,100dvh - 32px);margin:auto;overflow-y:auto}.calendar-day-sheet-root{z-index:1250;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.calendar-day-sheet-backdrop{cursor:pointer;opacity:0;-webkit-tap-highlight-color:transparent;background-color:#0f172a85;border:none;margin:0;padding:0;transition:opacity .28s;display:block;position:absolute;inset:0}.calendar-day-sheet-root.is-open .calendar-day-sheet-backdrop{opacity:1}.calendar-day-sheet-panel{z-index:1;width:100%;max-width:520px;max-height:min(88vh, calc(100dvh - 24px - env(safe-area-inset-bottom,0px)));margin-bottom:max(20px, env(safe-area-inset-bottom,0px));background-color:#fff;border-radius:18px 18px 0 0;flex-direction:column;min-height:0;margin-left:auto;margin-right:auto;transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;position:relative;transform:translateY(100%);box-shadow:0 -8px 32px #0f172a1f}@media (width<=768px){.calendar-day-sheet-root .calendar-day-sheet-panel{max-width:none;max-height:min(88vh, calc(100dvh - 62px - env(safe-area-inset-bottom,0px) - 12px));margin-bottom:calc(62px + env(safe-area-inset-bottom,0px))}}.calendar-day-sheet-root.is-open .calendar-day-sheet-panel{transform:translateY(0)}.calendar-day-sheet-root .mobile-nav-sheet-handle{flex-shrink:0;margin:8px auto 4px}.calendar-day-sheet-scroll{-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:0 16px 16px;overflow-y:auto}.calendar-day-sheet-heading{color:#111827;text-align:center;margin:0 0 16px;padding-top:4px;font-size:18px;font-weight:700;line-height:1.25}.calendar-day-sheet-section-label{text-transform:uppercase;letter-spacing:.06em;color:#6b7280;margin:0 0 10px;font-size:12px;font-weight:600}.calendar-day-sheet-events{margin-bottom:16px}.calendar-day-sheet-actions{gap:10px}.calendar-day-sheet-action-row{box-sizing:border-box;width:100%;min-height:48px;border-radius:12px!important;padding:14px 16px!important}.calendar-add-option-calendar-icon{color:#0f766e;background:#0f766e1a;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.calendar-add-option-calendar-icon svg{width:20px;height:20px}.calendar-quick-sheet-date-heading{color:#0f766e;text-align:center;margin:0 0 16px;padding-top:4px;font-size:18px;font-weight:700;line-height:1.25}.calendar-quick-sheet-actions{flex-direction:column;gap:10px;display:flex}.calendar-quick-sheet-row{box-sizing:border-box;cursor:pointer;text-align:left;color:#111827;background:#fff;border:1px solid #e5e7eb;border-radius:14px;align-items:center;gap:14px;width:100%;min-height:52px;padding:12px 16px;font-size:15px;font-weight:600;transition:background .15s,border-color .15s,box-shadow .15s;display:flex}.calendar-quick-sheet-row:hover{background:#f0fdfa;border-color:#99f6e4}.calendar-quick-sheet-row:active{background:#ecfdf5}.calendar-quick-sheet-row-icon{flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.calendar-quick-sheet-cancel{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:12px;width:100%;min-height:48px;margin-top:14px;padding:12px;font-size:15px;font-weight:600;transition:background .15s,color .15s}.calendar-quick-sheet-cancel:hover{color:#6b7280;background:#f3f4f6}.calendar-day-popup-desktop-box .calendar-day-sheet-heading{color:#111827;margin:0 0 12px;font-size:17px;font-weight:700}.calendar-day-popup-desktop-box .calendar-day-sheet-section-label{text-transform:uppercase;letter-spacing:.06em;color:#6b7280;margin:0 0 8px;font-size:12px;font-weight:600}.calendar-day-popup-desktop-box .calendar-day-sheet-actions{gap:8px}.calendar-day-popup-title{color:#374151;margin:0 0 16px;font-size:14px;font-weight:500}.calendar-day-popup-options{flex-direction:column;gap:8px;display:flex}.calendar-add-option{text-align:left;color:#111827;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:22px;padding:12px 20px;font-size:13px;transition:background .15s,border-color .15s}.calendar-add-option:hover{background:#f9fafb;border-color:#0f766e}.calendar-add-option-with-icon{align-items:center;gap:12px;display:flex}.calendar-add-option-dollar{color:#0f766e;background:#0f766e1f;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.calendar-add-option-with-icon-text{text-align:left;font-weight:600;line-height:1.35}.calendar-add-option-back{color:#6b7280;border-style:dashed;font-weight:500}.quick-record-payment-overlay{z-index:1400;background:#fff;transition:transform .32s cubic-bezier(.32,.72,0,1);position:fixed;inset:0;transform:translate(100%)}.quick-record-payment-overlay.is-open{transform:translate(0)}.quick-record-payment-panel{height:100%;min-height:0;padding-top:env(safe-area-inset-top,0px);flex-direction:column;display:flex}.quick-record-payment-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;grid-template-columns:48px 1fr 48px;align-items:center;padding:8px 8px 12px;display:grid}.quick-record-payment-back{color:#0f766e;cursor:pointer;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.quick-record-payment-back:hover{background:#0f766e14}.quick-record-payment-title{text-align:center;color:#111827;margin:0;font-size:17px;font-weight:600}.quick-record-payment-header-spacer{width:44px}.quick-record-payment-body{-webkit-overflow-scrolling:touch;flex:1;padding:16px 16px 24px;overflow-y:auto}.quick-record-section{margin-bottom:24px}.quick-record-section-label{text-transform:uppercase;letter-spacing:.06em;color:#6b7280;margin:0 0 10px;font-size:12px;font-weight:600}.quick-record-tenant-list{flex-direction:column;gap:10px;max-height:min(42vh,320px);display:flex;overflow-y:auto}.quick-record-tenant-card{text-align:left;cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:12px;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px;transition:border-color .15s,box-shadow .15s;display:flex}.quick-record-tenant-card.is-selected{border-color:#0f766e;box-shadow:0 0 0 1px #0f766e33}.quick-record-tenant-name{color:#111827;font-size:16px;font-weight:700}.quick-record-tenant-meta{color:#9ca3af;margin-top:4px;font-size:13px}.quick-record-tenant-expected{color:#4b5563;margin-top:6px;font-size:13px}.quick-record-status-badge{text-align:right;border-radius:8px;flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;max-width:46%;padding:6px 10px;font-size:11px;font-weight:600;display:flex}.quick-record-status-label{text-transform:uppercase;letter-spacing:.04em}.quick-record-status-sub{opacity:.95;font-size:11px;font-weight:500}.quick-record-status-badge--unpaid{color:#b91c1c;background:#fef2f2}.quick-record-status-badge--partial{color:#b45309;background:#fffbeb}.quick-record-status-badge--paid{color:#047857;background:#ecfdf5}.quick-record-month-nav{justify-content:center;align-items:center;gap:16px;display:flex}.quick-record-month-label{color:#111827;text-align:center;min-width:168px;font-size:16px;font-weight:600}.quick-record-month-btn{min-width:44px}.quick-record-method-pills{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:8px;padding-bottom:6px;display:flex;overflow-x:auto}.quick-record-method-pill{color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:999px;flex-shrink:0;padding:10px 14px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s,color .15s}.quick-record-method-pill.is-active{color:#0f766e;background:#0f766e1f;border-color:#0f766e}.quick-record-warn{margin-top:8px;font-size:13px;line-height:1.4}.quick-record-warn--amber{color:#b45309;background:#fffbeb;border-radius:8px;padding:10px 12px}.quick-record-warn--info{color:#1d4ed8;background:#eff6ff;border-radius:8px;padding:10px 12px}.quick-record-footer{padding:12px 16px calc(16px + env(safe-area-inset-bottom,0px));background:#fff;border-top:1px solid #e5e7eb;flex-shrink:0}.quick-record-submit{width:100%}.quick-record-success-banner{top:calc(12px + env(safe-area-inset-top,0px));z-index:1410;color:#fff;text-align:center;background:#059669;border-radius:12px;padding:14px 16px;font-weight:600;animation:.2s quick-record-fade-in;position:fixed;left:16px;right:16px;box-shadow:0 8px 24px #05966959}@keyframes quick-record-fade-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.calendar-week-grid{background:#fff;border:1px solid #e5e7eb;border-radius:14px;min-width:0;max-width:100%;overflow:hidden}.calendar-week-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;grid-template-columns:repeat(7,1fr);font-size:12px;display:grid}.cal-week-col-header{text-align:center;padding:12px}.cal-week-col-header.is-weekend{background:#00000005}.cal-week-dayname{color:#6b7280;font-weight:500}.cal-week-date{color:#111827;margin-top:4px;font-size:18px;font-weight:600}.cal-week-date.is-today{color:#0f766e}.calendar-week-body{grid-template-columns:repeat(7,1fr);min-height:300px;display:grid}.cal-week-col{border-right:1px solid #e5e7eb;flex-direction:column;gap:6px;padding:8px;display:flex}.cal-week-col:last-child{border-right:none}.cal-week-col.is-weekend{background:#00000003}.calendar-week-event{cursor:pointer;text-overflow:ellipsis;border-radius:8px;min-width:0;max-width:100%;padding:8px 10px;font-size:12px;overflow:hidden}.calendar-week-event:not(.is-completed){white-space:nowrap}.calendar-week-event.is-completed{white-space:normal}.calendar-agenda{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:20px}.calendar-agenda-day{margin-bottom:24px}.calendar-agenda-day:last-child{margin-bottom:0}.calendar-agenda-date-heading{color:#374151;border-bottom:1px solid #e5e7eb;margin-bottom:12px;padding-bottom:6px;font-size:14px;font-weight:600}.calendar-agenda-event{cursor:pointer;border-radius:999px;align-items:flex-start;gap:10px;margin-bottom:6px;padding:8px 12px;transition:opacity .15s;display:flex}.calendar-agenda-event:hover{opacity:.9}.cal-agenda-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.cal-agenda-label{color:#111827;flex-wrap:wrap;flex:1;align-items:center;gap:6px;min-width:0;font-size:13px;font-weight:500;display:flex;overflow:hidden}.cal-agenda-completed-badge{text-transform:uppercase;letter-spacing:.03em;color:#047857;white-space:nowrap;background:#0596691f;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.cal-agenda-meta{color:#6b7280;margin-top:2px;font-size:11px}.calendar-agenda-empty{text-align:center;color:#6b7280;padding:48px 24px;font-size:14px}.calendar-detail-row{justify-content:space-between;gap:16px;padding:6px 0;font-size:13px;display:flex}.calendar-detail-row .field-label{color:#6b7280;flex-shrink:0}@media print{.app-root[data-section=Reports] .app-sidebar,.app-root[data-section=Reports] .app-topbar,.app-root[data-section=Reports] .reports-type-selector,.app-root[data-section=Reports] #reports-filter-bar,.app-root[data-section=Reports] .reports-export-overlay,.app-root[data-section=Reports] .app-page-header{display:none!important}.app-root[data-section=Reports] .app-content-inner{max-width:none;padding:0}.app-root[data-section=Reports] .reports-page{gap:0}.app-root[data-section=Reports] .print-report{page-break-before:always;page-break-after:always;box-shadow:none}.app-root[data-section=Reports] .print-report:first-of-type{page-break-before:auto}}.landing-page{background-color:#fff;min-height:100vh}.landing-nav{z-index:100;background-color:#111827;padding:16px 24px;position:fixed;top:0;left:0;right:0}.landing-nav-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.landing-logo{align-items:center;gap:10px;display:flex}.landing-logo-icon{color:#fff;background-color:#0f766e;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.landing-logo span{color:#fff;letter-spacing:-.02em;font-size:18px;font-weight:600}.landing-nav-actions{align-items:center;gap:12px;display:flex}.landing-btn-outline{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff80;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:background-color .2s,border-color .2s}.landing-btn-outline:hover{background-color:#ffffff14;border-color:#fffc}.landing-btn-teal{color:#fff;cursor:pointer;background-color:#0f766e;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:background-color .2s}.landing-btn-teal:hover{background-color:#0d5c55}.landing-btn-lg{padding:14px 28px;font-size:16px}@media (width<=768px){.landing-nav-login{display:none}}.landing-hero{color:#fff;text-align:center;background-color:#111827;padding:120px 24px 80px}.landing-hero-inner{max-width:720px;margin:0 auto}.landing-hero-headline{letter-spacing:-.03em;margin:0 0 24px;font-size:clamp(32px,5vw,56px);font-weight:700;line-height:1.15}.landing-hero-subtitle{color:#9ca3af;margin:0 0 32px;font-size:clamp(16px,2vw,20px);line-height:1.6}.landing-hero-buttons{flex-wrap:wrap;justify-content:center;gap:16px;margin-bottom:20px;display:flex}.landing-hero-reassurance{color:#6b7280;margin:0 0 56px;font-size:14px}.landing-hero-mockup{max-width:900px;margin:0 auto}.landing-mockup-frame{background-color:#1f2937;border:1px solid #374151;border-radius:12px;min-height:320px;display:flex;overflow:hidden}.landing-mockup-sidebar{background-color:#0f172a;flex-direction:column;gap:6px;width:56px;padding:12px 8px;display:flex}.landing-mockup-nav-item{background-color:#374151;border-radius:4px;height:8px}.landing-mockup-nav-item:first-child{background-color:#0f766e}.landing-mockup-main{background-color:#f9fafb;flex-direction:column;flex:1;gap:16px;padding:20px;display:flex}.landing-mockup-stats{gap:12px;display:flex}.landing-mockup-stat{background-color:#e5e7eb;border-radius:8px;flex:1;height:48px}.landing-mockup-content{flex:1;gap:16px;min-height:0;display:flex}.landing-mockup-chart{opacity:.6;background-color:#0f766e;border-radius:50%;width:140px;min-width:140px;height:140px}.landing-mockup-panels{flex-direction:column;flex:1;gap:12px;display:flex}.landing-mockup-panel{background-color:#e5e7eb;border-radius:8px;flex:1}.landing-mockup-bottom{gap:12px;display:flex}.landing-mockup-bottom-panel{opacity:.4;background-color:#0f766e;border-radius:8px;flex:1;height:60px}@media (width<=768px){.landing-hero-mockup{display:none}}.landing-features{background-color:#fff;padding:80px 24px}.landing-section-inner{max-width:1100px;margin:0 auto}.landing-section-title{text-align:center;color:#111827;letter-spacing:-.02em;margin:0 0 48px;font-size:32px;font-weight:700}.landing-features-grid{grid-template-columns:repeat(4,1fr);gap:32px;display:grid}@media (width<=1024px){.landing-features-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.landing-features-grid{grid-template-columns:1fr;gap:24px}.landing-section-title{margin-bottom:32px;font-size:26px}}.landing-feature-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:28px 24px}.landing-feature-icon{margin-bottom:16px}.landing-feature-title{color:#111827;margin:0 0 8px;font-size:17px;font-weight:600}.landing-feature-desc{color:#6b7280;margin:0;font-size:15px;line-height:1.5}.landing-origin{background-color:#fff;padding:80px 24px}.landing-origin-card{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;max-width:640px;margin:0 auto;padding:32px 40px}.landing-origin-card p{color:#374151;margin:0;font-size:17px;line-height:1.65}.landing-coming-soon{background-color:#f3f4f6;padding:80px 24px}.landing-coming-subtitle{text-align:center;color:#6b7280;margin:-24px 0 32px;font-size:17px}.landing-coming-list{flex-direction:column;gap:20px;max-width:640px;margin:0 auto;display:flex}.landing-coming-item{background-color:#fff;border-left:4px solid #0f766e;border-radius:8px;padding:20px 24px;box-shadow:0 1px 3px #0000000d}.landing-coming-title{color:#111827;margin:0 0 6px;font-size:16px;font-weight:600}.landing-coming-desc{color:#6b7280;margin:0;font-size:15px;line-height:1.5}.landing-cta{text-align:center;background-color:#111827;padding:80px 24px}.landing-cta-inner{max-width:560px;margin:0 auto}.landing-cta-headline{color:#fff;letter-spacing:-.02em;margin:0 0 16px;font-size:32px;font-weight:700}.landing-cta-subtitle{color:#9ca3af;margin:0 0 32px;font-size:18px;line-height:1.5}.landing-cta-reassurance{color:#6b7280;margin:16px 0 0;font-size:14px}.landing-footer{background-color:#0f172a;padding:24px}.landing-footer-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.landing-footer-brand{color:#fff;font-size:14px;font-weight:600}.landing-footer-email{color:#9ca3af;font-size:14px;transition:color .2s}.landing-footer-email:hover{color:#fff}.tenant-detail-card{padding-top:0}@media (width>=640px){.tenant-detail-card{padding-top:0}}.tenant-detail-section-header{color:#fff;background-color:#14b8a6;border-radius:14px 14px 0 0;justify-content:space-between;align-items:flex-start;gap:12px;margin:0 -16px 12px;padding:8px 12px;display:flex}@media (width>=640px){.tenant-detail-section-header{margin:0 -20px 14px;padding:8px 12px}}.tenant-detail-section-header__main{flex:1;min-width:0}.tenant-detail-section-header__title{color:#fff;letter-spacing:-.02em;font-size:16px;font-weight:700}.tenant-detail-section-header__subtitle{color:#ffffffeb;margin-top:2px;font-size:13px}.tenant-detail-header-edit.btn-icon-edit{color:#fff;flex-shrink:0;min-width:44px;min-height:44px;margin:-4px -6px -4px 0}.tenant-detail-header-edit.btn-icon-edit:hover{color:#fff;background-color:#ffffff1f}.tenant-detail-deposit-held-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.tenant-detail-deposit-held-line{color:#374151;flex:1;min-width:min(100%,220px);margin:0;font-size:13px;line-height:1.4}.tenant-detail-deposit-return-btn{flex-shrink:0}.tenant-detail-deposit-box-title{margin-bottom:0}.tenant-detail-panel-section-header{box-sizing:border-box;color:#0f766e;letter-spacing:.08em;text-transform:uppercase;text-align:left;background-color:#f3f4f6;border:none;border-bottom:1px solid #e5e7eb;width:100%;margin:0;padding:12px 14px;font-size:.75rem;font-weight:700;line-height:1.35;display:block}@media (width>=640px){.tenant-detail-panel-section-header{padding:12px 16px}}.tenant-payment-sections{margin-top:4px}.tenant-payment-accordion-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.tenant-payment-section-header{cursor:pointer;text-align:left;letter-spacing:-.02em;color:#0f766e;background-color:#f3f4f6;border:none;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:12px 14px;font-size:15px;font-weight:700;transition:background-color .15s,color .15s;display:flex}@media (width>=640px){.tenant-payment-section-header{padding:12px 16px}}.tenant-payment-section-header:hover{color:#0f766e;background-color:#e5e7eb}.tenant-payment-section-title{color:#0f766e;flex-wrap:wrap;align-items:baseline;gap:6px;display:flex}.tenant-payment-section-count{color:#6b7280;font-size:13px;font-weight:500}.tenant-payment-section-body{background:#fafafa;border-top:none;padding:12px}.tenant-payment-empty{margin:0;padding:12px 8px}.tenant-payment-toggle-icon{color:#fff;flex-shrink:0;width:20px;height:20px;position:relative}.tenant-payment-section-header .tenant-payment-toggle-icon{color:#0f766e}.tenant-payment-toggle-icon svg{transition:opacity .2s,transform .2s;position:absolute;top:0;left:0}.tenant-payment-toggle-minus{opacity:0;transform:scale(.85)}.tenant-payment-toggle-icon.is-expanded .tenant-payment-toggle-minus{opacity:1;transform:scale(1)}.tenant-payment-toggle-icon.is-expanded .tenant-payment-toggle-plus{opacity:0;transform:scale(.85)}.tenant-payment-table tbody tr.tenant-payment-row-alt{background-color:#f3f4f6a6}.tenant-payment-table tbody tr.tenant-payment-main-row:hover{background-color:#f3f4f6!important}.tenant-payment-row-chevron{transition:transform .2s;transform:rotate(0)}.tenant-payment-row-chevron--open{transform:rotate(90deg)}.payment-amount-hint{margin-top:10px;font-size:13px;line-height:1.45}.payment-amount-hint--amber{color:#b45309;background:#fbbf241f;border:1px solid #fbbf2459;border-radius:8px;padding:8px 10px}.payment-amount-hint--exact{color:#047857;align-items:center;gap:6px;margin-top:10px;font-weight:500;display:flex}.tenants-page{padding-bottom:8px}.tenant-list-property-sections{flex-direction:column;gap:10px;display:flex}.tenant-list-property-block{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.tenant-list-property-header{cursor:pointer;text-align:left;letter-spacing:-.02em;color:#fff;background-color:#0f766e;border:none;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:8px 12px;font-size:14px;font-weight:600;transition:background-color .15s;display:flex}.tenant-list-property-header:hover{color:#fff;background-color:#0c6a63}.tenant-list-property-header-text{flex:1;min-width:0}.tenant-list-property-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px 12px;width:100%;display:flex}.tenant-list-property-name{color:#fff;letter-spacing:-.02em;flex:1;min-width:0;font-size:14px;font-weight:600}.tenant-list-property-count-inline{color:#ffffffeb;white-space:nowrap;flex-shrink:0;font-size:13px;font-weight:500}.tenant-list-property-chevron{color:#fff;flex-shrink:0;transition:transform .2s;display:inline-flex}.tenant-list-property-chevron--open{transform:rotate(180deg)}.tenant-list-property-body{background:#fafafa;border-top:1px solid #e5e7eb;padding:8px 8px 12px}.vendors-trade-sections{flex-direction:column;gap:10px;display:flex}.vendors-trade-block{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.vendors-trade-header{color:#fff;cursor:pointer;text-align:left;text-transform:uppercase;letter-spacing:.08em;background-color:#0f766e;border:none;justify-content:space-between;align-items:center;gap:12px;width:100%;margin:0;padding:8px 12px;font-size:12px;font-weight:600;transition:background-color .15s;display:flex}.vendors-trade-header:hover{color:#fff;background-color:#0c6a63}.vendors-trade-header-text{flex:1;min-width:0}.vendors-trade-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px 12px;width:100%;display:flex}.vendors-trade-header-title{color:#fff;letter-spacing:.08em;flex:1;min-width:0;font-size:12px;font-weight:600}.vendors-trade-header-count{color:#ffffffeb;white-space:nowrap;flex-shrink:0;font-size:11px;font-weight:500}.vendors-trade-body{background:#fafafa;border-top:1px solid #e5e7eb;padding:8px 8px 12px}.tenant-list-card-grid{flex-direction:column;gap:8px;display:flex}@media (width>=640px){.tenant-list-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}}@media (width>=1024px){.tenant-list-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}}.tenant-list-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-left:3px solid #0000;border-radius:12px;padding:12px 12px 44px;transition:box-shadow .2s,border-color .2s;position:relative;box-shadow:0 1px 2px #0000000a}.tenant-list-card:hover{box-shadow:0 8px 20px #0f172a14}.tenant-list-card--attention{border-left-color:#f59e0ba6}.tenant-list-card--selected{background-color:#ecfdf5;border:2px solid #0f766e;border-left-width:5px;box-shadow:0 4px 18px #0f766e38}.card.property-grid-card{border-left:3px solid #0000;transition:background-color .2s,box-shadow .2s,border-color .2s}.card.property-grid-card:hover:not(.property-grid-card--selected){box-shadow:0 8px 20px #0f172a14}.card.property-grid-card--selected{background-color:#ecfdf5;border:2px solid #0f766e;border-left-width:5px;box-shadow:0 4px 18px #0f766e38}button.property-tenant-name-link{font:inherit;color:#0f766e;cursor:pointer;text-align:left;background:0 0;border:none;margin:0;padding:0;text-decoration:none}button.property-tenant-name-link:hover{text-underline-offset:2px;text-decoration:underline}.property-add-tenant-footer{border-top:1px solid #e5e7eb;margin-top:20px;padding-top:16px}.tenant-list-card-header-row{margin-bottom:6px}.tenant-list-card-title-wrap{flex-wrap:wrap;align-items:center;gap:4px 8px;width:100%;min-width:0;display:flex}.tenant-list-card-name{color:#111827;font-size:15px;font-weight:700}.tenant-list-card-unit{font-size:13px;font-weight:500}.tenant-list-card-badge-inline{flex-shrink:0;align-items:center;margin-left:auto;display:inline-flex}.tenant-list-card-badge-inline .badge{padding:1px 6px;font-size:10px;line-height:1.25}.tenant-list-card-lines{color:#374151;flex-direction:column;gap:3px;font-size:13px;display:flex}.tenant-list-card-line{word-break:break-word}.tenant-list-card-meta{font-size:13px;line-height:1.35}.tenant-list-card-deposit-line{line-height:1.35}.tenant-list-card-contact-row{color:#374151;flex-wrap:wrap;align-items:baseline;gap:4px 6px;font-size:13px;line-height:1.35;display:flex}.tenant-list-card-contact-sep{color:#9ca3af;-webkit-user-select:none;user-select:none}.tenant-list-card-link{color:#0d9488;align-items:center;gap:6px;text-decoration:none;display:inline-flex}.tenant-list-card-link:hover{text-decoration:underline}.tenant-list-card-icon{color:#6b7280;flex-shrink:0}.tenant-list-card-footer{justify-content:flex-end;align-items:center;gap:8px;display:flex;position:absolute;bottom:8px;left:12px;right:12px}.tenants-archived-footer{text-align:center;margin-top:8px;margin-bottom:0;padding:0}.tax-summary-page{box-sizing:border-box;width:100%;min-width:0;max-width:900px;margin:0 auto;overflow:hidden}.tax-summary-screen-title{letter-spacing:-.02em;color:#111827;margin:0 0 4px;font-size:22px;font-weight:700}.tax-summary-screen-subtitle{margin:0 0 20px}.tax-summary-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px;display:flex}.tax-summary-filters{flex-wrap:wrap;gap:16px;display:flex}.tax-summary-field{flex-direction:column;gap:4px;min-width:160px;display:flex}.tax-summary-field--block{width:100%;max-width:360px}.tax-summary-field-label{text-transform:uppercase;letter-spacing:.06em;color:#6b7280;font-size:12px;font-weight:600}.tax-summary-print-btn{flex-shrink:0}.tax-summary-document{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px 28px;box-shadow:0 1px 3px #0000000f}.tax-summary-section{margin-bottom:28px}.tax-summary-section:last-of-type{margin-bottom:0}.tax-summary-section-title{text-transform:uppercase;letter-spacing:.08em;color:#374151;border-bottom:2px solid #111827;margin:0 0 12px;padding-bottom:8px;font-size:14px;font-weight:700}.tax-summary-section-note{margin:-4px 0 12px}.tax-summary-table{border-collapse:collapse;width:100%;font-size:14px}.tax-summary-table td{vertical-align:top;border-bottom:1px solid #e5e7eb;padding:10px 12px}.tax-summary-table td:first-child{color:#374151;width:58%}.tax-summary-table td:last-child{text-align:right;font-variant-numeric:tabular-nums}.tax-summary-table--summary td{border-bottom:1px solid #e5e7eb}.tax-summary-table--summary .tax-summary-net-row td{border-bottom:none;padding-top:16px;font-size:16px}.tax-summary-amount{color:#111827;font-weight:600}.tax-summary-amount--income{color:#166534;font-weight:700}.tax-summary-amount--muted{color:#4b5563;text-align:right;font-size:13px;font-weight:500}.tax-summary-amount--profit{color:#166534}.tax-summary-amount--loss{color:#b91c1c}.tax-summary-mileage-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:16px 18px}.tax-summary-mileage-input{max-width:200px}.tax-summary-mileage-result{color:#111827;margin:12px 0 0;font-size:15px}.tax-summary-summary-box{background:#f9fafb;border:1px solid #d1d5db;border-radius:10px;margin-top:8px;padding:20px 22px}.tax-summary-disclaimer{max-width:52rem;margin:16px 0 0;line-height:1.5}.print-only{display:none!important}.tax-summary-footer-print{color:#6b7280;text-align:center;border-top:1px solid #d1d5db;margin-top:32px;padding-top:16px;font-size:11px}@media print{@page{margin:.6in}body{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#fff!important}.print-only{display:block!important}.app-root .app-sidebar,.app-root .app-sidebar-overlay,.app-root .app-topbar,.app-root .app-mobile-bottom-nav,.tax-summary-no-print{display:none!important}.app-main,.app-content-wrapper{margin:0!important;padding:0!important}.app-content-inner{max-width:none!important;padding:0!important}.tax-summary-page{max-width:none;overflow:visible}.tax-summary-document{box-shadow:none;border:none;border-radius:0;padding:0}.tax-summary-print-header{border-bottom:2px solid #111827;margin-bottom:20px;padding-bottom:12px}.tax-summary-print-title{color:#000;margin:0 0 8px;font-size:20pt;font-weight:700}.tax-summary-print-meta{color:#000;margin:0;font-size:12pt}.tax-summary-print-sep{color:#6b7280}.tax-summary-section-title{color:#000;border-bottom-color:#000}.tax-summary-summary-box{border:1px solid #000;background:#fff!important}.tax-summary-mileage-card{border:1px solid #ccc;background:#fff!important}.tax-summary-footer-print{page-break-inside:avoid;margin-top:40px;display:block!important}}.customization-item-list{border:1px solid #e5e7eb;border-radius:8px;margin:0 0 16px;padding:0;list-style:none;overflow:hidden}.customization-item-row{background:#fafafa;border-bottom:1px solid #f3f4f6;align-items:center;gap:10px;padding:10px 12px;display:flex}.customization-item-row:last-child{border-bottom:none}.customization-drag{opacity:.5;flex-shrink:0}.customization-item-label{flex:1;font-size:14px}.customization-item-actions{align-items:center;gap:4px;display:flex}.btn-icon-muted{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;min-width:32px;height:32px;padding:0 8px;font-size:14px;line-height:1}.btn-icon-muted:hover:not(:disabled){color:#111827;background:#f3f4f6}.btn-icon-muted:disabled{opacity:.35;cursor:not-allowed}.customization-add-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.customization-add-row .field-input{flex:1;min-width:180px}.customization-summary-row{border-bottom:1px solid #f3f4f6;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 0;display:flex}.customization-summary-row:last-of-type{border-bottom:none}.customization-summary-name{color:#111827;flex:1;min-width:140px;font-size:14px;font-weight:600}.customization-summary-count{text-align:center;min-width:4.5rem;font-size:14px}.btn-manage-teal-outline.btn-secondary{color:#0f766e;background-color:#fff;border:1px solid #0f766e}.btn-manage-teal-outline.btn-secondary:hover:not(:disabled){color:#0d5c55;background-color:#ecfdf5;border-color:#0d5c55}.modal-content--settings-manage{max-width:500px}.tenant-portal{background:#f3f4f6;flex-direction:column;min-height:100vh;display:flex}.tenant-portal-body{flex-direction:column;flex:1;min-height:0;display:flex}.tenant-portal--loading{justify-content:center;align-items:center;padding:48px;display:flex}.tenant-portal-header{color:#fff;z-index:20;background:#0f766e;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.tenant-portal-brand{align-items:center;gap:10px;display:flex}.tenant-portal-logo{background:#fff3;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.tenant-portal-title{font-size:18px;font-weight:700}.tenant-portal-user-btn{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:14px;font-weight:500;display:inline-flex}.tenant-portal-user-menu{position:relative}.tenant-portal-dropdown{z-index:30;background:#fff;border:1px solid #e5e7eb;border-radius:8px;min-width:160px;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0000001f}.tenant-portal-dropdown button{text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:10px 14px;font-size:14px}.tenant-portal-dropdown button:hover{background:#f9fafb}.tenant-portal-sidebar{display:none}@media (width>=769px){.tenant-portal-body{flex-direction:row;align-items:stretch}.tenant-portal-sidebar{background:#fff;border-right:1px solid #e5e7eb;flex-direction:column;gap:4px;width:220px;min-height:calc(100vh - 60px);padding:16px 0;display:flex}.tenant-portal-sidebar button{text-align:left;cursor:pointer;color:#374151;background:0 0;border:none;align-items:center;gap:10px;padding:12px 20px;font-size:15px;display:flex}.tenant-portal-sidebar button:hover{background:#f3f4f6}.tenant-portal-sidebar button.is-active{color:#0f766e;background:#ecfdf5;font-weight:600}.tenant-portal-main{flex:1;min-width:0;max-width:960px;padding:24px}.tenant-portal .tenant-portal-mobile-nav{display:none!important}}.tenant-portal-main{flex:1;padding:16px}@media (width<=768px){.tenant-portal-main{padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.tenant-portal .tenant-portal-mobile-nav-inner{grid-template-columns:repeat(4,1fr);max-width:480px}.tenant-portal .tenant-portal-mobile-nav .app-mobile-nav-item-icon svg{width:24px;height:24px}}.tenant-portal-h1{color:#111827;margin:0 0 8px;font-size:22px;font-weight:700}.tenant-portal-h2{color:#111827;margin:0 0 8px;font-size:16px;font-weight:600}.tenant-portal-card{margin-bottom:0}.tenant-portal-kv{border-bottom:1px solid #f3f4f6;justify-content:space-between;gap:12px;padding:6px 0;font-size:14px;display:flex}.tenant-portal-kv:last-child{border-bottom:none}.tenant-portal-list{margin:0;padding:0;list-style:none}.tenant-portal-list li{border-bottom:1px solid #f3f4f6;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 0;font-size:14px;display:flex}.tenant-portal-table{width:100%;font-size:14px}.tenant-portal-table th,.tenant-portal-table td{text-align:left;padding:10px 8px}.tenant-portal-maint-list{margin:0;padding:0;list-style:none}.tenant-portal-maint-list .tenant-maint-li{border-bottom:1px solid #f3f4f6;border-left:3px solid #0000;border-radius:0 8px 8px 0;padding:12px 12px 12px 14px}.tenant-portal-maint-list .tenant-maint-li--resolved{background:linear-gradient(90deg,#16a34a1a 0%,#fff0 72px);border-left-color:#16a34a}.tenant-portal-maint-list .tenant-maint-li:hover{background:#fafafa}.tenant-portal-maint-list .tenant-maint-li--resolved:hover{background:linear-gradient(90deg,#16a34a1f 0%,#fafafa 72px)}.tenant-invite-to-portal-btn{align-items:center;font-weight:600;display:inline-flex;color:#0f766e!important;background:#fff!important;border:2px solid #0f766e!important}.tenant-invite-to-portal-btn:hover{background:#ecfdf5!important}.tenant-invite-sent-row{flex-wrap:wrap;align-items:center;gap:10px 16px;display:flex}.tenant-invite-inline{flex-wrap:wrap;align-items:center;gap:6px;display:inline-flex}.app-sidebar-brand.app-sidebar-brand-row{flex-direction:row;justify-content:space-between;align-items:flex-start}.app-sidebar-brand-main{align-items:center;gap:8px;min-width:0;display:flex}.app-sidebar-bell-wrap{flex-shrink:0}.app-sidebar-bell-wrap .notifications-bell-btn{color:#e5e7eb}.app-sidebar-bell-wrap .notifications-bell-btn:hover{color:#fff;background:#94a3b833}.app-topbar-right{align-items:center;gap:8px;display:flex}.notifications-bell-root{position:relative}.notifications-bell-btn{color:#0f766e;cursor:pointer;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;padding:0;transition:background-color .15s;display:flex;position:relative}.notifications-bell-btn:hover{background:#ecfdf5}.notifications-bell-badge{color:#fff;text-align:center;background:#dc2626;border-radius:999px;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;line-height:18px;position:absolute;top:4px;right:4px}.notifications-backdrop{z-index:1240;background:#0f172a59;position:fixed;inset:0}.notifications-panel{z-index:1250;background:#fff;border:1px solid #e5e7eb;border-radius:14px;flex-direction:column;max-height:min(70vh,520px);display:flex;overflow:hidden;box-shadow:0 20px 40px #0f172a26}.notifications-panel--desktop{width:380px;max-width:calc(100vw - 16px);position:fixed}.notifications-panel--mobile{max-height:min(85vh,640px);margin-bottom:env(safe-area-inset-bottom,0px);border-radius:18px 18px 0 0;position:fixed;bottom:0;left:0;right:0}.notifications-panel-header{border-bottom:1px solid #e5e7eb;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.notifications-panel-title{color:#111827;margin:0;font-size:16px;font-weight:600}.notifications-panel-header-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px 16px;display:flex}.notifications-clear-all{color:#6b7280;cursor:pointer;background:0 0;border:none;padding:4px 0;font-size:13px;font-weight:600}.notifications-clear-all:hover{color:#374151;text-decoration:underline}.notifications-mark-all{color:#0f766e;cursor:pointer;background:0 0;border:none;padding:4px 0;font-size:13px;font-weight:600}.notifications-mark-all:hover{text-decoration:underline}.notifications-panel-body{-webkit-overflow-scrolling:touch;flex:1;min-height:0;overflow-y:auto}.notifications-panel-footer{border-top:1px solid #f3f4f6;flex-shrink:0;padding:10px 16px 16px}.notifications-panel-footer--more{padding:8px 16px 12px}.notifications-panel-more-hint{color:#9ca3af;text-align:center;margin:0;font-size:12px}.notifications-empty{text-align:center;padding:32px 20px}.notifications-empty-text{color:#6b7280;margin:12px 0 0;font-size:14px}.notifications-list{margin:0;padding:0;list-style:none}.notifications-row-outer{background:#fff;border-bottom:1px solid #f3f4f6;align-items:stretch;display:flex}.notifications-row-outer:last-child{border-bottom:none}.notifications-row{text-align:left;cursor:pointer;background:0 0;border:none;flex:1;align-items:flex-start;gap:10px;min-width:0;padding:12px 8px 12px 16px;transition:background .12s;display:flex}.notifications-row:hover{background:#f9fafb}.notifications-row-dismiss{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-left:1px solid #0000;flex-shrink:0;justify-content:center;align-self:stretch;align-items:center;width:44px;min-width:44px;min-height:44px;padding:0;transition:color .12s,background .12s;display:flex}.notifications-row-dismiss:hover{color:#4b5563;background:#f3f4f6}.notifications-row-outer:has(.notifications-row.is-unread){background:#f0fdfa}.notifications-row-outer:has(.notifications-row.is-unread) .notifications-row:hover{background:#ecfdf5d9}.notifications-unread-dot{background:#2563eb;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.notifications-type-icon{background:#f3f4f6;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.notifications-type-icon--maint{background:#fff7ed}.notifications-type-icon--pay{background:#f0fdf4}.notifications-type-icon--lease{background:#fffbeb}.notifications-type-icon--overdue{background:#fef2f2}.notifications-row-title{color:#111827;font-size:14px;font-weight:600}.notifications-row-message{color:#6b7280;margin-top:4px;font-size:13px;line-height:1.4}.notifications-row-time{color:#9ca3af;margin-top:6px;font-size:11px}.notifications-settings-list{max-height:360px;margin:0;padding:0;list-style:none;overflow-y:auto}.notifications-settings-row{text-align:left;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #f3f4f6;gap:10px;width:100%;padding:12px 0;display:flex}.notifications-settings-row:hover{background:#fafafa}.notifications-settings-row.is-unread{background:#f0fdfa}.maint-detail-title-btn{font:inherit;color:inherit;cursor:pointer;text-align:left;background:0 0;border:none;margin:0;padding:0}.maint-detail-title-btn:hover{text-decoration:underline}.maint-photo-list-badge{color:#6b7280;align-items:center;gap:3px;font-size:11px;font-weight:500;display:inline-flex}.tenant-maint-detail-btn{text-align:left;width:100%;font:inherit;color:inherit;cursor:pointer;background:0 0;border:none;margin:0;padding:8px 0;display:block}.tenant-maint-detail-btn:hover{background:0 0}.tenant-maint-status-badge{border-radius:8px;align-items:center;gap:5px;padding:6px 12px;font-size:13px;font-weight:700;line-height:1.2;display:inline-flex}.tenant-maint-status-badge--resolved{color:#fff;background-color:#16a34a;border:none;box-shadow:0 1px 2px #16a34a59}.maint-photo-upload{margin-top:8px}.maint-photo-drop{text-align:center;cursor:pointer;background:#fafafa;border:2px dashed #d1d5db;border-radius:10px;padding:16px;transition:border-color .15s,background .15s}.maint-photo-drop.is-drag{background:#f0fdfa;border-color:#0f766e}.maint-photo-drop.is-disabled{opacity:.55;cursor:not-allowed}.maint-photo-drop-icon{color:#6b7280;justify-content:center;margin-bottom:8px;display:flex}.maint-photo-drop-text{flex-direction:column;gap:4px;display:flex}.maint-photo-mobile-actions{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:12px;display:flex}.maint-photo-count,.maint-photo-error{margin-top:8px}.maint-photo-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px;display:grid}.maint-photo-thumb-wrap{position:relative}.maint-photo-thumb{aspect-ratio:1;background:#e5e7eb;border-radius:8px;position:relative;overflow:hidden}.maint-photo-thumb img{object-fit:cover;width:100%;height:100%;display:block}.maint-photo-placeholder{background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb) 0 0/200% 100%;width:100%;height:100%;animation:1.2s ease-in-out infinite maint-shimmer}@keyframes maint-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.maint-photo-spinner{background:#ffffff80;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.maint-photo-spinner-dot{border:3px solid #e5e7eb;border-top-color:#0f766e;border-radius:50%;width:28px;height:28px;animation:.7s linear infinite maint-spin}@keyframes maint-spin{to{transform:rotate(360deg)}}.maint-photo-remove{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;padding:0;font-size:18px;line-height:1;display:flex;position:absolute;top:4px;right:4px;box-shadow:0 1px 3px #0003}.maint-photo-remove:disabled{opacity:.5;cursor:not-allowed}.maint-photo-display-heading{align-items:center;gap:8px;margin:0 0 8px;font-size:14px;font-weight:600;display:flex}.maint-photo-display-heading--after{flex-wrap:wrap;gap:8px}.maint-photo-after-badge{font-size:11px;font-weight:600}.maint-photo-display-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.maint-photo-display-thumb-wrap{flex-direction:column;align-items:stretch;gap:4px;display:flex;position:relative}.maint-photo-source-badge{text-align:center;text-overflow:ellipsis;white-space:nowrap;border-radius:4px;max-width:100%;padding:2px 6px;font-size:10px;font-weight:600;line-height:1.2;overflow:hidden}.maint-photo-source-badge--tenant{color:#0f766e;background:#ecfdf5;border:1px solid #99f6e4}.maint-photo-source-badge--you{color:#9ca3af;background:#f3f4f6;border:1px solid #e5e7eb;font-weight:500}.maint-photo-display-thumb{aspect-ratio:1;cursor:zoom-in;background:#e5e7eb;border:none;border-radius:8px;width:100%;padding:0;display:block;overflow:hidden}.maint-photo-display-thumb img{object-fit:cover;width:100%;height:100%}.maint-photo-display-skeleton{background:#e5e7eb;width:100%;height:100%;min-height:80px}.maint-photo-lightbox{z-index:10050;background:#000000e6;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.maint-photo-lightbox--mobile{padding:0}.maint-photo-lightbox-close{z-index:10051;color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:8px;width:44px;height:44px;font-size:28px;line-height:1;position:fixed;top:12px;right:12px}.maint-photo-lightbox-img{object-fit:contain;max-width:100%;max-height:100vh}
