:root{--mango: #f5a623;--mango-dark: #d98a12;--ink: #1f2430;--muted: #6b7280;--bg: #f7f8fa;--card: #ffffff;--border: #e5e7eb;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink)}a{color:var(--mango-dark);text-decoration:none}.app-header{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1.5rem;background:var(--card);border-bottom:1px solid var(--border)}.app-header .brand{font-weight:800;font-size:1.3rem;letter-spacing:-.02em;color:var(--ink)}.app-header nav{display:flex;gap:1rem}.header-right{margin-left:auto;display:flex;align-items:center;gap:1rem}.user-name{font-size:.9rem}.account-menu{position:relative}.burger{font-size:1.1rem;line-height:1;padding:.3rem .55rem}.account-menu-dropdown{position:absolute;right:0;top:calc(100% + .4rem);min-width:9rem;background:var(--card);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #1f24301f;display:flex;flex-direction:column;padding:.3rem;z-index:20}.account-menu-dropdown a,.account-menu-dropdown button{text-align:left;border:none;background:none;padding:.5rem .6rem;border-radius:6px;color:var(--ink);font:inherit}.account-menu-dropdown a:hover,.account-menu-dropdown button:hover{background:var(--bg)}.app-main{max-width:960px;margin:0 auto;padding:1.5rem}.card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1.25rem}.muted{color:var(--muted)}.accent{color:var(--mango)}.login-card{max-width:400px;margin:4rem auto;text-align:center;border:none;position:relative;background:linear-gradient(var(--card),var(--card)) padding-box,linear-gradient(135deg,var(--mango),var(--mango-dark) 45%,#ffcf7a 100%) border-box;border:2px solid transparent;box-shadow:0 10px 30px #d98a122e}.login-wordmark{margin:.25rem 0 0;font-size:2.4rem;letter-spacing:-.02em;color:var(--ink)}.login-tagline{margin:.25rem 0 .5rem;color:var(--muted);font-size:.95rem;font-weight:500}.google-signin{position:relative;display:inline-block;margin-top:1rem;line-height:0}.google-signin-glyph{position:absolute;top:50%;left:50%;width:20px;height:20px;transform:translate(-50%,-50%);pointer-events:none}.error{color:#c62828;font-size:.85rem}button{cursor:pointer;border:1px solid var(--border);background:var(--card);border-radius:6px;padding:.3rem .6rem;font:inherit}button:hover{border-color:var(--mango)}input,select{font:inherit;padding:.3rem .5rem;border:1px solid var(--border);border-radius:6px;background:var(--card)}.project-switcher,.project-create{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.project-create .currency{width:4rem;text-transform:uppercase}.project-create .fy{display:flex;align-items:center;gap:.3rem;font-size:.85rem;color:var(--muted)}.project-create .fy input[type=number]{width:3.5rem}.category-list{list-style:none;padding:0;margin:1rem 0;display:flex;flex-direction:column;gap:.5rem}.category-list li{display:flex;align-items:center;gap:.6rem}.category-list input[type=color]{width:2.2rem;height:2.2rem;padding:0;border-radius:6px}.category-list .cat-name{flex:1;max-width:20rem}.badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:.05rem .5rem}button.danger{color:#c62828}button.danger:hover{border-color:#c62828}.category-add{display:flex;align-items:center;gap:.5rem;margin-top:1rem;border-top:1px solid var(--border);padding-top:1rem}.category-add input[type=color]{width:2.2rem;height:2.2rem;padding:0}.txn-form,.txn-filters{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin:1rem 0}.txn-filters{border-top:1px solid var(--border);padding-top:1rem;font-size:.9rem}.txn-form .txn-amount{width:7rem}.txn-filter-date{display:flex;align-items:center;gap:.3rem;color:var(--muted)}.txn-table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:.9rem}.txn-table th,.txn-table td{text-align:left;padding:.5rem .6rem;border-bottom:1px solid var(--border);vertical-align:top}.txn-table th.num,.txn-table td.num{text-align:right;white-space:nowrap}.txn-table td.income{color:#2e7d32}.txn-table td.expense{color:#c62828}.txn-table tfoot td{border-bottom:none;border-top:2px solid var(--border)}.txn-note{font-size:.8rem;margin-top:.15rem}.cat-tag{display:inline-flex;align-items:center;gap:.4rem}.cat-dot{width:.7rem;height:.7rem;border-radius:50%;display:inline-block}.txn-actions{display:flex;gap:.4rem;align-items:center;justify-content:flex-end;white-space:nowrap}.receipt-toggle{border-radius:8px;padding:.25rem .5rem;line-height:1}.txn-edit-btn{padding:.25rem .6rem}.txn-editing td{background:#f5a6230f;vertical-align:top}.txn-editing input,.txn-editing select{width:100%}.txn-edit-note{margin-top:.35rem}.txn-edit-amount{display:flex;gap:.4rem;align-items:center}.txn-edit-amount select{flex:none;width:auto}.receipt-toggle.is-open{border-color:var(--mango);background:#f5a6231f}.receipts-row td{background:var(--bg)}.receipts{display:flex;flex-direction:column;gap:.6rem;padding:.25rem .25rem .5rem}.receipt-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.receipt-item{display:flex;align-items:center;gap:.6rem}.receipt-item a{display:inline-flex;align-items:center;gap:.4rem;font-weight:500}.receipt-clip{font-size:.9em}.receipt-size{font-size:.8rem}.receipt-remove{margin-left:auto;font-size:.8rem;padding:.15rem .5rem}.receipt-upload{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--muted);cursor:pointer;width:fit-content}.receipt-upload input[type=file]{max-width:16rem}.journey{display:flex;flex-direction:column;gap:1.25rem}.journey-hero{text-align:center;background:linear-gradient(var(--card),var(--card)) padding-box,linear-gradient(135deg,var(--mango),var(--mango-dark) 45%,#ffcf7a 100%) border-box;border:2px solid transparent;box-shadow:0 10px 30px #d98a1226}.journey-emoji{font-size:2.5rem}.journey-title{margin:.5rem 0 .25rem;font-size:1.8rem}.brand-two-tone{color:var(--ink);font-weight:800}.journey-lede{color:var(--muted);max-width:34rem;margin:0 auto .5rem}.journey-steps{text-align:left;max-width:30rem;margin:1rem auto 0;color:var(--ink);line-height:1.6}.project-create-form{display:flex;flex-direction:column;gap:.75rem;max-width:24rem;margin-top:1rem}.project-create-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--muted)}.project-create-form .fy-inputs{display:flex;gap:.4rem}.project-create-form .fy-inputs input[type=number]{width:4rem}.project-create-form .currency{width:5rem;text-transform:uppercase}.project-create-actions{display:flex;gap:.5rem;margin-top:.25rem}.project-create-panel{border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1rem;background:var(--bg)}.projects-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}.project-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:1rem;margin-top:1rem}.project-kpi-card{display:flex;flex-direction:column;gap:.5rem;align-items:stretch;text-align:left;cursor:pointer;padding:1.1rem}.project-kpi-card:hover{border-color:var(--mango);box-shadow:0 4px 14px #1f243014}.project-kpi-card.is-selected{border-color:var(--mango);box-shadow:0 0 0 1px var(--mango)}.project-kpi-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.project-kpi-name{font-weight:700;font-size:1.05rem;color:var(--ink)}.project-kpi-meta{font-size:.78rem}.project-kpi-net{display:flex;flex-direction:column;gap:.1rem;margin-top:.35rem;font-size:1.6rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--ink)}.project-kpi-net.positive{color:#15803d}.project-kpi-net.negative{color:#b91c1c}.project-kpi-net-label{font-size:.72rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.project-kpi-split{display:flex;gap:.75rem;margin-top:.35rem;border-top:1px solid var(--border);padding-top:.6rem}.project-kpi-stat{flex:1;display:flex;flex-direction:column;gap:.1rem;font-weight:600;font-variant-numeric:tabular-nums}.project-kpi-stat.income{color:#15803d}.project-kpi-stat.expense{color:#b91c1c}.project-kpi-stat-label{font-size:.72rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.project-new-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;min-height:11rem;cursor:pointer;border:2px dashed var(--border);background:transparent;box-shadow:none;color:var(--muted)}.project-new-card:hover{border-color:var(--mango);color:var(--mango-dark)}.project-new-plus{font-size:2rem;line-height:1;font-weight:300}.project-new-label{font-weight:600}button{transition:border-color .15s ease,background .15s ease,box-shadow .15s ease,transform .05s ease}button:active{transform:translateY(1px)}button:focus-visible{outline:none;box-shadow:0 0 0 3px #f5a62359}.btn-primary{border:1px solid transparent;color:#fff;font-weight:600;padding:.5rem 1rem;border-radius:8px;background:linear-gradient(135deg,var(--mango),var(--mango-dark));box-shadow:0 1px 2px #d98a1259}.btn-primary:hover{border-color:transparent;filter:brightness(1.05);box-shadow:0 3px 10px #d98a1259}.btn-primary:disabled{opacity:.6;cursor:default;box-shadow:none;filter:none}.btn-ghost{border-radius:8px;padding:.5rem .9rem;color:var(--ink);background:var(--card)}.btn-toggle{display:inline-flex;align-items:center;gap:.4rem;border-radius:8px;padding:.5rem .9rem;font-weight:600;color:var(--mango-dark);background:var(--card)}.btn-toggle .chevron{display:inline-block;transition:transform .2s ease;font-size:.9em;line-height:1}.btn-toggle.is-open .chevron{transform:rotate(90deg)}.fy-picker{display:inline-flex;align-items:stretch;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--card);width:fit-content}.fy-picker:focus-within{border-color:var(--mango);box-shadow:0 0 0 3px #f5a6232e}.fy-picker select,.fy-picker input{border:none;border-radius:0;background:transparent;padding:.5rem .7rem;color:var(--ink);font-weight:600;-webkit-appearance:none;-moz-appearance:none;appearance:none}.fy-picker select:focus,.fy-picker input:focus{outline:none}.fy-picker .fy-day{width:3.5rem;text-align:center;border-right:1px solid var(--border);-moz-appearance:textfield}.fy-picker .fy-day::-webkit-outer-spin-button,.fy-picker .fy-day::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.fy-picker .fy-month{padding-right:1.8rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236b7280' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}.page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:.9rem 1.25rem;border-radius:14px;background:var(--card);border:1.5px solid #f3d9b0;color:var(--ink);box-shadow:0 2px 8px #d98a120f}.page-header-titles{display:flex;flex-direction:column;gap:.1rem;min-width:0}.page-header-project{font-size:1.4rem;font-weight:700;letter-spacing:-.01em;color:var(--ink)}.page-header-page{font-size:.85rem;color:var(--muted)}.page-header-switch{position:relative;margin-left:auto;display:flex;align-items:center}.page-header-switch select{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.page-header-chev{font-size:1.1rem;color:var(--mango-dark);padding:.35rem .5rem;border-radius:8px;transition:background .15s ease}.page-header-switch:hover .page-header-chev{background:#d98a121f}.dashboard-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.dashboard-head-titles{display:flex;flex-direction:column;gap:.15rem}.fy-dates{font-size:.82rem;color:var(--muted);font-variant-numeric:tabular-nums}.year-picker{display:inline-flex;align-items:center;gap:.25rem;border:1px solid var(--border);border-radius:999px;padding:.15rem .3rem;background:var(--card)}.year-picker span{min-width:3.5rem;text-align:center;font-weight:600;font-variant-numeric:tabular-nums}.year-picker button{border:none;background:none;padding:.2rem .55rem;border-radius:999px;font-size:1.1rem;line-height:1;color:var(--muted)}.year-picker button:hover{background:var(--bg);color:var(--ink)}.pnl-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin:1.25rem 0}.pnl-card{display:flex;flex-direction:column;gap:.35rem;padding:1rem 1.1rem;border-radius:12px;border:1px solid var(--border);background:var(--card)}.pnl-card.income{border-color:#16a34a40;background:linear-gradient(180deg,rgba(22,163,74,.06),transparent)}.pnl-card.expense{border-color:#c6282838;background:linear-gradient(180deg,rgba(198,40,40,.06),transparent)}.pnl-card.net.positive{border-color:#f5a62366;background:linear-gradient(180deg,rgba(245,166,35,.1),transparent)}.pnl-card.net.negative{border-color:#c628284d;background:linear-gradient(180deg,rgba(198,40,40,.1),transparent)}.pnl-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.pnl-value{font-size:1.5rem;font-weight:700;font-variant-numeric:tabular-nums}.pnl-card.net.negative .pnl-value{color:#c62828}.breakdown-title{margin:1.5rem 0 .5rem}.breakdown{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}.breakdown-row{display:grid;grid-template-columns:minmax(8rem,1fr) minmax(6rem,2fr) auto;align-items:center;gap:1rem;padding:.6rem 0;border-bottom:1px solid var(--border)}.breakdown-row:last-child{border-bottom:none}.breakdown-name{display:flex;align-items:center;gap:.5rem;font-weight:500}.breakdown-bars{display:flex;flex-direction:column;gap:3px}.breakdown-bars .bar{height:8px;border-radius:999px;min-width:2px}.breakdown-bars .bar.income{background:#16a34a}.breakdown-bars .bar.expense{background:#c62828}.breakdown-net{font-variant-numeric:tabular-nums;font-weight:600;text-align:right}.breakdown-net.positive{color:#16a34a}.breakdown-net.negative{color:#c62828}.month-breakdown .breakdown-name{font-variant-numeric:tabular-nums;color:var(--muted);font-weight:500}
