:root{color-scheme:light;--bg: #f4f1ea;--bg-soft: #fffaf1;--ink: #1f1b16;--muted: #6d645b;--accent: #0f7b6c;--accent-dark: #0b5c52;--outline: rgba(31, 27, 22, .12);--card: #ffffff;--shadow: 0 16px 45px rgba(31, 27, 22, .12);--radius: 18px;font-family:Space Grotesk,Segoe UI,Apple SD Gothic Neo,sans-serif}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top,#fef8ef 0%,var(--bg) 45%,#efe7db 100%);color:var(--ink);min-height:100vh}a{color:inherit;text-decoration:none}h1,h2,h3{margin:0 0 8px}p{margin:0 0 12px}button,input{font:inherit}select{font:inherit;padding:12px 14px;border-radius:12px;border:1px solid var(--outline);background:#fff}.page-shell{padding:32px 6vw 64px}.page-shell.mobile{max-width:840px;margin:0 auto}.page-shell.admin{max-width:1100px;margin:0 auto}.top-bar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;align-items:center;margin-bottom:24px}.top-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:12px;margin-bottom:8px;color:var(--muted)}.subtitle{color:var(--muted)}.mobile-menu-button{display:none}@media (min-width: 721px){.mobile-menu-button{display:none!important}}.nav-strip{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}.nav-pill{padding:8px 16px;border-radius:999px;background:var(--bg-soft);border:1px solid var(--outline);font-weight:500}.nav-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.content{display:flex;flex-direction:column;gap:20px}.card{background:var(--card);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);border:1px solid rgba(31,27,22,.06)}.card.highlight{background:linear-gradient(140deg,#f0f8f6,#fff)}.card-header{margin-bottom:16px}.section-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.section-actions{display:flex;gap:8px;flex-wrap:wrap}.inline-form{border:1px solid var(--outline);border-radius:16px;padding:16px;margin-bottom:16px;background:#fff}.assignment-panel{background:linear-gradient(135deg,#f7fbfa,#fff);border:1px solid rgba(15,123,108,.18);box-shadow:0 18px 40px #0f7b6c14}.assignment-panel .assignment-grid{display:grid;grid-template-columns:minmax(240px,320px) minmax(280px,1fr);gap:18px;align-items:start}.approver-field{align-self:stretch}.approver-select-row{display:flex;gap:10px;align-items:center}.assignment-selected{grid-column:1 / -1;display:grid;grid-template-columns:minmax(240px,320px) minmax(280px,1fr);gap:18px;padding:12px;border-radius:12px;background:#f9fdfa;border:1px dashed rgba(15,123,108,.2)}.selected-block{display:flex;flex-direction:column;gap:8px}.approver-selected{display:flex;flex-wrap:wrap;gap:8px;min-height:44px}.approver-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid rgba(15,123,108,.18);box-shadow:0 8px 18px #0f7b6c14;font-weight:500}.approver-pill em{font-style:normal;color:var(--muted)}.approver-pill button{border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;padding:0 2px}.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.admin-home-card{display:flex;flex-direction:column;gap:12px}.admin-home-link{align-self:flex-end}.stack{display:flex;flex-direction:column;gap:20px}.download-callout{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;background:#f0f8f6;border:1px solid rgba(15,123,108,.18)}.download-link{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:999px;background:var(--accent);color:#fff;font-weight:600;border:1px solid transparent;box-shadow:0 10px 20px #0f7b6c38;transition:transform .2s ease,box-shadow .2s ease}.download-link:hover{transform:translateY(-1px);box-shadow:0 12px 24px #0f7b6c47}.download-link:active{transform:translateY(0);box-shadow:0 8px 16px #0f7b6c33}.bulk-upload-form{display:grid;gap:18px;margin-top:16px}.bulk-upload-field{display:grid;gap:10px}.field-label{font-weight:600}.file-picker{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;border:1px solid var(--outline);background:#fff;cursor:pointer}.file-input{position:absolute;opacity:0;width:1px;height:1px}.file-button{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:10px;background:var(--ink);color:#fff;font-weight:600;white-space:nowrap}.file-name{color:var(--muted);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-picker:focus-within{border-color:#0f7b6c80;box-shadow:0 0 0 3px #0f7b6c1f}.bulk-upload-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.checkbox-pill{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;border:1px solid var(--outline);background:#fff;font-weight:500}.checkbox-pill input{width:18px;height:18px;accent-color:var(--accent)}.bulk-upload-actions .primary{min-width:180px}.mobile-card{transition:transform .2s ease,box-shadow .2s ease}.mobile-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px #1f1b162e}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.attachment-list{display:grid;gap:8px}.attachment-row{display:flex;gap:8px;align-items:center;flex-wrap:nowrap;min-width:0}.attachment-input{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px}.icon-button.attachment-picker{border-radius:10px;width:36px;height:36px;flex:0 0 auto}.attachment-filename{flex:1 1 auto;min-width:0;font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-actions{display:flex;gap:8px;flex:0 0 auto}.icon-button.attachment-add,.icon-button.attachment-remove,.icon-button.attachment-view{width:36px;height:36px;border-radius:10px}.icon-button.attachment-remove{border-color:#c0392b73;color:#c0392b}.attachment-existing-icon{opacity:.6;cursor:default;pointer-events:none}.field input{padding:12px 14px;border-radius:12px;border:1px solid var(--outline);background:#fff}.field textarea{padding:12px 14px;border-radius:12px;border:1px solid var(--outline);background:#fff;resize:vertical}.memo-input{min-height:96px;line-height:1.4}.field.checkbox{flex-direction:row;align-items:center;gap:10px}.form-grid{display:grid;gap:12px 16px;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));align-items:end}.form-grid.inline-grid{grid-template-columns:minmax(0,1fr) minmax(0,140px);align-items:center}.form-grid.accountant-form{grid-template-columns:minmax(280px,1fr) auto;align-items:center}.form-grid.accountant-form .field input{height:48px}.form-actions{display:flex;gap:12px;align-items:center;align-self:end}.form-grid.accountant-form .form-actions button{height:48px}.primary{padding:12px 18px;border-radius:12px;background:var(--accent);color:#fff;border:none;font-weight:600;cursor:pointer}.primary.danger{background:#c0392b}.primary:disabled{opacity:.65;cursor:default}.ghost{padding:10px 14px;border-radius:12px;background:transparent;border:1px solid var(--outline);cursor:pointer;color:var(--ink)}.ghost.danger{border-color:#c0392b73;color:#c0392b}.muted{color:var(--muted)}.error{color:#c0392b}.success{color:#1b7a4e}.negative{color:#c0392b;font-weight:600}.role-badge{padding:6px 10px;border-radius:999px;background:#f0eee9;border:1px solid var(--outline);font-size:12px}.user-email{font-size:13px;color:var(--muted)}.upload-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:16px}.upload-drop{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:20px;border-radius:16px;border:1px dashed var(--outline);min-height:160px;cursor:pointer;text-align:center}.upload-drop input{display:none}.upload-preview{border-radius:16px;border:1px solid var(--outline);min-height:160px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#faf8f3}.upload-preview img{width:100%;height:100%;object-fit:cover}.segmented{display:inline-flex;gap:8px;background:#f1ece3;padding:6px;border-radius:999px;align-self:flex-start}.segmented-item{border:none;background:transparent;padding:10px 18px;border-radius:999px;cursor:pointer;font-weight:600;color:var(--muted)}.segmented-item.active{background:var(--accent);color:#fff}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.chip{padding:6px 10px;border-radius:999px;background:#f4efe6;border:1px solid var(--outline);font-size:12px}.ledger-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.ledger-grid{display:grid;gap:14px}.ledger-card{display:flex;flex-direction:column;gap:12px;padding:16px;border-radius:16px;border:1px solid var(--outline);background:#fff}.ledger-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.ledger-card-title-link{color:inherit;text-decoration:none;flex:1}.ledger-card-body{display:grid;gap:12px;color:inherit;text-decoration:none}.ledger-return-button{padding:8px 12px;border-radius:999px;font-size:12px;white-space:nowrap;border-color:#c0392b73;color:#c0392b;background:#c0392b14}.ledger-card-title{font-size:16px;font-weight:600;line-height:1.4}.ledger-card-meta{display:flex;justify-content:space-between;gap:12px;font-size:13px;color:var(--muted)}.ledger-bar-line{display:grid;gap:6px}.bar-track{position:relative;height:10px;background:#efe9df;border-radius:999px;overflow:hidden}.bar-track.no-budget{background:transparent}.bar-fill{position:absolute;height:100%;top:0;left:0}.bar-fill.income{background:#1b7a4e}.bar-fill.expense{background:#c0392b;opacity:.7}.bar-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--muted)}.detail-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.detail-summary{display:flex;flex-wrap:wrap;gap:10px 16px;margin-top:10px;font-size:13px;color:#111;font-weight:600}.detail-controls{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-bottom:16px}.detail-controls .field{flex:1;min-width:220px;margin-bottom:0}.detail-controls .field input{height:48px}.icon-button.sort-toggle{height:48px;width:48px;padding:0;border-radius:12px;align-self:flex-end}.detail-list{display:grid;gap:12px}.detail-card{border:1px solid var(--outline);border-radius:14px;padding:14px;background:#fff;display:grid;gap:10px}.detail-card-head{display:flex;justify-content:space-between;gap:12px;align-items:center}.detail-type{display:inline-block;margin-bottom:6px;font-size:12px;color:var(--muted)}.detail-card-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.detail-card-body>div:last-child{text-align:right}.badge{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;margin-bottom:6px}.badge.income{background:#1b7a4e1f;color:#1b7a4e}.badge.expense{background:#c0392b1f;color:#c0392b}.detail-card-actions{display:flex;gap:8px;justify-content:flex-end}.expand-button{width:30px;height:30px;border-radius:999px;border:1px solid var(--outline);background:#fff;cursor:pointer;font-weight:700}.expand-button.open{background:var(--accent);color:#fff;border-color:var(--accent)}.detail-row{background:#fbf8f2}.detail-cell{font-size:13px;color:var(--muted);border-bottom:1px solid var(--outline)}.detail-title{font-weight:600;color:var(--ink)}.detail-actions{display:flex;gap:6px;justify-content:flex-end}.detail-actions.decision-actions{flex-wrap:nowrap;align-items:center}.detail-actions.decision-actions .decision-note{min-width:0}.detail-actions.decision-actions button{padding:8px 12px;font-size:13px}.icon-button{width:28px;height:28px;border-radius:8px;border:1px solid var(--outline);background:transparent;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer}.icon-button svg{width:16px;height:16px}.icon-button:disabled{opacity:.4;cursor:default}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0c0873;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal{width:min(680px,92vw);background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:18px}.modal-header,.modal-footer{display:flex;justify-content:space-between;align-items:center;gap:10px}.modal-body{margin:16px 0;display:flex;justify-content:center;align-items:center;min-height:240px}.receipt-image{max-width:100%;max-height:60vh;border-radius:12px;border:1px solid var(--outline)}.receipt-pdf{width:100%;height:60vh;border:1px solid var(--outline);border-radius:12px}.pagination{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap;margin-top:12px}.page-button{min-width:36px;text-align:center}.page-button.active{background:var(--ink);color:#fff;border-color:transparent}@media (max-width: 720px){.detail-actions{flex-direction:column;align-items:flex-start}.detail-actions.decision-actions{flex-direction:row;align-items:center}}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:14px}.table th,.table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--outline)}.table th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.table-actions{display:flex;gap:8px}.result-box{margin-top:16px;padding:12px;border-radius:12px;background:#f6fbf9;border:1px solid #d6ece4}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-page .card{text-align:left}.login-hero{display:flex;justify-content:center;margin-bottom:12px}.login-hero-image{width:52px;height:52px;border-radius:14px;object-fit:cover;background:#fff;padding:0;box-shadow:0 12px 30px #1f1b162e;border:1px solid rgba(31,27,22,.08)}.login-page .card h1,.login-page .card .muted{text-align:center}.login-page .field span{text-align:left}.login-page .primary{display:block;margin:0 auto}.login-reset-link{display:block;margin-top:10px;text-align:center;color:#0f766e;font-weight:600;text-decoration:underline;background:none;border:none;cursor:pointer}.login-reset-link[aria-disabled=true]{opacity:.6;cursor:not-allowed;text-decoration:none}.center{text-align:center}@media (max-width: 720px){.page-shell{padding:24px 18px 48px}.top-bar{align-items:center}.top-bar h1{font-size:28px}.eyebrow,.subtitle,.top-actions{display:none}.mobile-menu-button{display:inline-flex}.nav-strip{display:none}}.mobile-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0c0866;display:flex;justify-content:flex-end;z-index:40}.mobile-menu{width:min(280px,80vw);background:#fff;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow)}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center}.mobile-menu-body{display:flex;flex-direction:column;gap:12px}.mobile-menu-nav{display:flex;flex-direction:column;gap:8px}.mobile-menu-link{padding:10px 12px;border-radius:10px;background:#f6f4f1;color:inherit;text-decoration:none;font-weight:600}.mobile-menu-link.active{background:var(--accent);color:#fff}.menu-identity{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
