@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap";:root{--primary: #B85450;--primary-dark: #8C3D39;--gold: #D4A853;--income: #4CAF82;--expense: #E05A5A;--sidebar-bg: #1A1A2E;--sidebar-text: #C8BFB8;--sidebar-active: #B85450;--bg: #F4EDE4;--bg-card: #FFFFFF;--text: #1C1C1E;--text-muted: #7A7068;--border: #E8E0D5;--radius: 14px;--radius-sm: 8px;--shadow: 0 2px 16px rgba(0,0,0,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);--sidebar-w: 240px;--header-h: 56px;--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:inherit}input,select,textarea{font-family:inherit}ul{list-style:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;transition:transform var(--transition)}.sidebar__brand{display:flex;align-items:center;gap:12px;padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar__logo{width:40px;height:40px;background:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar__logo-mark{font-family:Cormorant Garamond,serif;font-size:22px;font-weight:700;color:#fff}.sidebar__brand-name{font-family:Cormorant Garamond,serif;font-size:17px;font-weight:600;color:#fff;display:block;line-height:1.2}.sidebar__brand-tagline{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--sidebar-text);opacity:.6}.sidebar__nav{flex:1;padding:16px 12px}.sidebar__nav-list{display:flex;flex-direction:column;gap:4px}.sidebar__nav-link{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);color:var(--sidebar-text);font-size:14px;font-weight:400;transition:background var(--transition),color var(--transition)}.sidebar__nav-link:hover{background:rgba(255,255,255,.06);color:#fff}.sidebar__nav-link--active{background:rgba(184,84,80,.2);color:#fff;font-weight:500}.sidebar__nav-link--active .sidebar__nav-icon{color:var(--primary)}.sidebar__nav-icon{font-size:18px;width:22px;text-align:center}.sidebar__footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.06)}.sidebar__version{font-size:11px;color:var(--sidebar-text);opacity:.4}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-h);background:var(--sidebar-bg);align-items:center;padding:0 16px;gap:16px;z-index:300}.mobile-header__toggle{display:flex;flex-direction:column;gap:5px;padding:4px}.mobile-header__toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:var(--transition)}.mobile-header__title{font-family:Cormorant Garamond,serif;font-size:18px;color:#fff;font-weight:600}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.5);z-index:190;opacity:0;transition:opacity var(--transition)}.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh;overflow-x:hidden}.page{padding:32px;max-width:1200px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px}.page-title{font-family:Cormorant Garamond,serif;font-size:32px;font-weight:600;color:var(--text);line-height:1.2}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:4px}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;transition:all var(--transition);white-space:nowrap}.btn--primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #b854504d}.btn--primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px #b8545066}.btn--ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn--ghost:hover{background:var(--bg);border-color:var(--primary);color:var(--primary)}.btn--danger{background:var(--expense);color:#fff}.btn--danger:hover{background:#c44444}.btn--sm{padding:6px 14px;font-size:12px}.btn-back{background:none;color:var(--text-muted);font-size:13px;margin-bottom:6px;padding:0;display:inline-flex;align-items:center;gap:4px;transition:color var(--transition)}.btn-back:hover{color:var(--primary)}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:20px;overflow:hidden}.card__header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px 0}.card__title{font-family:Cormorant Garamond,serif;font-size:20px;font-weight:600}.card__link{font-size:13px;color:var(--primary)}.card__link:hover{text-decoration:underline}.card__body{padding:16px 24px 20px}.card--budget{padding:16px 24px}.card--firebase{border:1px dashed var(--border);background:linear-gradient(135deg,#fff 0%,#faf6f0 100%)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow);border:1px solid var(--border);border-left:4px solid transparent;transition:transform var(--transition),box-shadow var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card--income{border-left-color:var(--income)}.stat-card--expense{border-left-color:var(--expense)}.stat-card--profit,.stat-card--projects{border-left-color:var(--gold)}.stat-card--loss{border-left-color:var(--expense)}.stat-card__icon{font-size:24px;width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--bg);flex-shrink:0}.stat-card--income .stat-card__icon{background:rgba(76,175,130,.1);color:var(--income)}.stat-card--expense .stat-card__icon{background:rgba(224,90,90,.1);color:var(--expense)}.stat-card--profit .stat-card__icon,.stat-card--projects .stat-card__icon{background:rgba(212,168,83,.1);color:var(--gold)}.stat-card__label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stat-card__value{font-family:Cormorant Garamond,serif;font-size:26px;font-weight:600;color:var(--text);line-height:1}.stat-card__sub{font-size:11px;color:var(--text-muted);margin-top:2px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.project-row{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition);border-radius:6px;padding:12px 6px}.project-row:last-child{border-bottom:none}.project-row:hover{background:var(--bg)}.project-row__name{font-size:14px;font-weight:500}.project-row__client{font-size:12px;color:var(--text-muted)}.project-row__profit{font-size:14px;font-weight:600;margin-bottom:4px;text-align:right}.project-row__progress{width:80px}.txn-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.txn-row:last-child{border-bottom:none}.txn-row__indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.txn-row--income .txn-row__indicator{background:var(--income)}.txn-row--expense .txn-row__indicator{background:var(--expense)}.txn-row__info{flex:1;min-width:0}.txn-row__desc{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.txn-row__meta{font-size:11px;color:var(--text-muted)}.txn-row__amount{font-size:13px;font-weight:600;white-space:nowrap}.txn-row__amount--income{color:var(--income)}.txn-row__amount--expense{color:var(--expense)}.progress-bar{height:6px;background:var(--border);border-radius:99px;overflow:hidden}.progress-bar--lg{height:10px;margin-top:8px}.progress-bar__fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--gold));border-radius:99px;transition:width .6s ease}.progress-bar__fill--over{background:var(--expense)}.budget-header,.budget-label{display:flex;justify-content:space-between;font-size:13px;color:var(--text-muted);margin-bottom:6px}.status-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status--active{background:rgba(76,175,130,.1);color:var(--income)}.status--completed{background:rgba(91,141,217,.1);color:#5b8dd9}.status--onhold{background:rgba(212,168,83,.1);color:var(--gold)}.filter-tabs{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}.filter-tabs--inline{margin-bottom:0}.filter-tab{padding:6px 16px;border-radius:99px;font-size:13px;color:var(--text-muted);border:1px solid var(--border);background:transparent;transition:all var(--transition)}.filter-tab:hover{border-color:var(--primary);color:var(--primary)}.filter-tab--active{background:var(--primary);color:#fff;border-color:var(--primary)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.project-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition)}.project-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.project-card__header{padding:20px 20px 16px;background:linear-gradient(135deg,#fff 0%,var(--bg) 100%);border-bottom:1px solid var(--border)}.project-card__status-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.project-card__actions{display:flex;gap:6px;opacity:0;transition:opacity var(--transition)}.project-card:hover .project-card__actions{opacity:1}.project-card__action{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;background:var(--bg);color:var(--text-muted);transition:all var(--transition)}.project-card__action--edit:hover{background:rgba(212,168,83,.2);color:var(--gold)}.project-card__action--delete:hover{background:rgba(224,90,90,.1);color:var(--expense)}.project-card__name{font-family:Cormorant Garamond,serif;font-size:20px;font-weight:600;margin-bottom:4px}.project-card__client{font-size:13px;color:var(--text-muted)}.project-card__stats{display:grid;grid-template-columns:repeat(3,1fr);padding:16px 20px;gap:12px}.project-card__stat{text-align:center}.project-card__stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);display:block;margin-bottom:4px}.project-card__stat-value{font-family:Cormorant Garamond,serif;font-size:18px;font-weight:600}.project-card__budget{padding:0 20px 16px}.project-card__dates{padding:0 20px 14px;font-size:12px;color:var(--text-muted)}.income-color{color:var(--income)}.expense-color{color:var(--expense)}.positive{color:var(--income)}.negative{color:var(--expense)}.text-right{text-align:right}.project-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}.meta-chip{font-size:12px;background:var(--bg);border:1px solid var(--border);border-radius:99px;padding:3px 10px;color:var(--text-muted)}.txn-table{width:100%}.txn-table__head{display:grid;grid-template-columns:110px 1fr 1fr 130px 80px;padding:8px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:2px solid var(--border)}.txn-table__row{display:grid;grid-template-columns:110px 1fr 1fr 130px 80px;padding:12px;border-bottom:1px solid var(--border);align-items:center;transition:background var(--transition)}.txn-table__row:hover{background:var(--bg)}.txn-table__row:last-child{border-bottom:none}.txn-table__date{font-size:13px;color:var(--text-muted)}.txn-table__desc{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.txn-table__amount{font-size:14px;font-weight:600}.txn-table__amount--income{color:var(--income)}.txn-table__amount--expense{color:var(--expense)}.txn-table__actions{display:flex;gap:6px;justify-content:flex-end}.txn-action{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;background:var(--bg);color:var(--text-muted);transition:all var(--transition)}.txn-action--edit:hover{background:rgba(212,168,83,.2);color:var(--gold)}.txn-action--delete:hover{background:rgba(224,90,90,.1);color:var(--expense)}.category-chip{display:inline-flex;padding:2px 10px;border-radius:99px;font-size:11px;font-weight:500}.category-chip--income{background:rgba(76,175,130,.1);color:var(--income)}.category-chip--expense{background:rgba(224,90,90,.1);color:var(--expense)}.form{display:flex;flex-direction:column;gap:16px}.form--disabled{opacity:.5;pointer-events:none;margin-top:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.form-input{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);font-size:14px;color:var(--text);transition:border-color var(--transition),box-shadow var(--transition);outline:none;width:100%}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #b854501a}.form-textarea{resize:vertical;min-height:80px}.toggle-group{display:flex;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.toggle-btn{flex:1;padding:10px;font-size:13px;font-weight:500;color:var(--text-muted);background:var(--bg);transition:all var(--transition)}.toggle-btn--active.toggle-btn:first-child{background:rgba(76,175,130,.1);color:var(--income)}.toggle-btn--active.toggle-btn:last-child{background:rgba(224,90,90,.1);color:var(--expense)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .25s ease}.modal-overlay--visible{opacity:1}.modal-overlay--hiding{opacity:0;pointer-events:none}.modal{background:#fff;border-radius:16px;width:100%;max-width:560px;box-shadow:var(--shadow-lg);transform:translateY(20px);transition:transform .25s ease;overflow:hidden}.modal-overlay--visible .modal{transform:translateY(0)}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal__title{font-family:Cormorant Garamond,serif;font-size:22px;font-weight:600}.modal__close{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:var(--bg);transition:all var(--transition);font-size:14px}.modal__close:hover{background:var(--border);color:var(--text)}.modal__body{padding:20px 24px;max-height:65vh;overflow-y:auto}.modal__footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);background:var(--bg)}.modal-open{overflow:hidden}.confirm-message{font-size:15px;line-height:1.6;color:var(--text)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:900;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:10px;background:var(--text);color:#fff;font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);min-width:240px;transform:translate(120%);transition:transform .35s cubic-bezier(.34,1.56,.64,1)}.toast--visible{transform:translate(0)}.toast--hiding{transform:translate(120%);transition:transform .3s ease}.toast--success{background:#2D6A4F}.toast--error{background:#9B2335}.toast--warning{background:#7A5C1E}.toast--info{background:#1A3A5C}.toast__icon{font-size:16px}.reports-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.chart-container{position:relative;height:280px;width:100%}.chart-container--sm{height:200px}.chart-legend{display:flex;gap:16px;justify-content:center;margin-top:12px;flex-wrap:wrap}.chart-legend__item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.chart-legend__dot{width:10px;height:10px;border-radius:50%}.breakdown-list{margin-top:16px;display:flex;flex-direction:column;gap:8px}.breakdown-row{display:flex;align-items:center;gap:8px;font-size:13px}.breakdown-row__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.breakdown-row__label{flex:1;color:var(--text)}.breakdown-row__pct{color:var(--text-muted);min-width:36px;text-align:right}.breakdown-row__amount{font-weight:600;min-width:90px;text-align:right}.summary-table{width:100%}.summary-table__head{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;padding:8px 0;border-bottom:2px solid var(--border);font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.summary-table__row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;padding:12px 0;border-bottom:1px solid var(--border);font-size:14px}.summary-table__row:last-child{border-bottom:none}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.data-actions{display:flex;flex-direction:column;gap:16px}.data-action-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;background:var(--bg);border-radius:var(--radius-sm)}.data-action-title{font-weight:500;font-size:14px;margin-bottom:4px}.data-action-desc{font-size:13px;color:var(--text-muted)}.category-list{display:flex;flex-direction:column;gap:4px}.category-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:var(--radius-sm);background:var(--bg)}.category-item__name{font-size:13px}.category-item__delete{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-muted);transition:all var(--transition)}.category-item__delete:hover{background:rgba(224,90,90,.1);color:var(--expense)}.firebase-placeholder{display:flex;align-items:flex-start;gap:16px;padding:16px;background:linear-gradient(135deg,rgba(184,84,80,.05),rgba(212,168,83,.05));border-radius:var(--radius-sm);margin-bottom:20px}.firebase-placeholder__icon{font-size:32px;flex-shrink:0}.firebase-placeholder h3{font-family:Cormorant Garamond,serif;font-size:18px;margin-bottom:4px}.firebase-placeholder p{font-size:13px;color:var(--text-muted);line-height:1.6}.empty-state{text-align:center;padding:32px 20px;color:var(--text-muted)}.empty-state p{font-size:14px;margin-bottom:12px}.empty-state--full{grid-column:1/-1;padding:80px 20px}.empty-state__icon{font-size:40px;margin-bottom:16px;opacity:.3}.empty-state h3{font-family:Cormorant Garamond,serif;font-size:22px;color:var(--text);margin-bottom:8px}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:var(--text-muted)}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:20px}.login-card{background:var(--bg-card);padding:48px;border-radius:24px;box-shadow:var(--shadow-lg);text-align:center;max-width:400px;width:100%;border:1px solid var(--border)}.login-logo{width:64px;height:64px;background:var(--primary);border-radius:16px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center}.login-logo__mark{font-family:Cormorant Garamond,serif;font-size:36px;font-weight:700;color:#fff}.login-title{font-family:Cormorant Garamond,serif;font-size:32px;font-weight:600;color:var(--text);margin-bottom:4px}.login-subtitle{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:40px}.login-btn{width:100%;display:flex;justify-content:center;align-items:center;gap:12px;padding:14px;font-size:15px;background:#fff;color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow)}.login-btn:hover{background:#fafafa;transform:translateY(-1px);box-shadow:var(--shadow-lg);border-color:#ddd}@media (max-width: 900px){.dashboard-grid,.reports-grid,.settings-grid{grid-template-columns:1fr}.txn-table__head,.txn-table__row{grid-template-columns:90px 1fr 100px 60px}.txn-table__head span:nth-child(3),.txn-table__row span:nth-child(3){display:none}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-overlay--visible{opacity:1}.mobile-header{display:flex}.main-content{margin-left:0;padding-top:var(--header-h)}.page{padding:20px 16px}.page-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:1fr 1fr}.form-row,.projects-grid{grid-template-columns:1fr}.txn-table__head,.txn-table__row{grid-template-columns:80px 1fr 90px 52px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.filter-tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}.toast-container{bottom:16px;right:16px;left:16px}.toast{min-width:unset;width:100%}}
