@import"https://fonts.googleapis.com/css2?family=Fraunces:wght@400;600;700&family=IBM+Plex+Sans:wght@400;500;600&display=swap";:root{--bg: #fefcf7;--ink: #171717;--muted: #5b5a57;--accent: #ff6b4d;--accent-strong: #c73925;--accent-soft: #ff9a72;--accent-2: #2fb6ae;--surface: linear-gradient(160deg, rgba(255, 255, 255, .96), rgba(249, 246, 240, .86));--surface-solid: #ffffff;--surface-2: rgba(238, 232, 224, .85);--card-bg: linear-gradient(160deg, rgba(255, 255, 255, .98), rgba(251, 247, 242, .86));--line: rgba(15, 23, 42, .12);--shadow: 0 24px 50px rgba(15, 23, 42, .16);--shadow-soft: 0 10px 20px rgba(15, 23, 42, .08);--glow: 0 1px 0 rgba(255, 255, 255, .9) inset;--glass-border: rgba(255, 255, 255, .98);--notice-bg: rgba(63, 182, 178, .15);--notice-ink: #1f5c58;--error-bg: rgba(239, 68, 68, .16);--error-ink: #b42318;--font-display: "Fraunces", "Times New Roman", serif;--font-body: "IBM Plex Sans", "Segoe UI", sans-serif;color-scheme:light}:root[data-theme=dark]{--bg: #0f1319;--ink: #f8fafc;--muted: #b9b5b0;--accent: #ff8a6f;--accent-strong: #ff6d54;--accent-soft: #ffb096;--accent-2: #5fe1d7;--surface: linear-gradient(160deg, rgba(26, 30, 36, .9), rgba(18, 22, 28, .86));--surface-solid: rgba(17, 24, 35, .95);--surface-2: rgba(33, 37, 43, .78);--card-bg: linear-gradient(160deg, rgba(28, 32, 38, .92), rgba(18, 22, 28, .86));--line: rgba(148, 163, 184, .24);--shadow: 0 28px 60px rgba(2, 6, 23, .6);--shadow-soft: 0 14px 26px rgba(2, 6, 23, .45);--glow: 0 1px 0 rgba(255, 255, 255, .08) inset;--glass-border: rgba(255, 255, 255, .14);--notice-bg: rgba(79, 209, 197, .2);--notice-ink: #bffcf2;--error-bg: rgba(239, 68, 68, .2);--error-ink: #fecaca;color-scheme:dark}*{box-sizing:border-box}html,body{width:100%}body{margin:0;font-family:var(--font-body);font-size:14px;color:var(--ink);background:radial-gradient(circle at 12% 10%,rgba(255,107,77,.16),transparent 54%),radial-gradient(circle at 88% 16%,rgba(231,178,107,.16),transparent 50%),linear-gradient(180deg,var(--bg) 0%,#fbf7f1 100%);min-height:100vh;overflow-x:hidden;line-height:1.55}html[data-theme=dark] body{background:radial-gradient(circle at 10% 16%,rgba(255,138,111,.16),transparent 52%),radial-gradient(circle at 88% 8%,rgba(95,225,215,.14),transparent 45%),linear-gradient(180deg,var(--bg) 0%,#0b0f14 100%)}#root{min-height:100vh}img,svg{max-width:100%;height:auto}a{color:inherit;text-decoration:none}.app{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;padding:16px 20px 10px;margin-bottom:12px;border-bottom:1px solid rgba(148,163,184,.2);background:linear-gradient(140deg,#ffffffdb,#f7f9fcb3);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}html[data-theme=dark] .topbar{border-bottom:1px solid rgba(148,163,184,.16);background:linear-gradient(140deg,#111822e6,#0c121ad1)}.topbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.button.nav-toggle{display:none;width:36px;height:32px;padding:0;border-radius:10px;justify-content:center}.button.theme-toggle{width:36px;height:32px;padding:0;border-radius:10px;justify-content:center}.theme-icon{width:16px;height:16px;display:block}.nav-toggle-icon{width:16px;height:2px;border-radius:999px;background:currentColor;box-shadow:0 -5px 0 currentColor,0 5px 0 currentColor;transition:transform .2s ease,box-shadow .2s ease}.nav-toggle[aria-expanded=true] .nav-toggle-icon{transform:rotate(90deg);box-shadow:0 0 0 currentColor,0 0 0 currentColor}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.brand{display:flex;align-items:center;gap:16px}.brand-mark{width:40px;height:40px;border-radius:16px 6px;background:linear-gradient(135deg,var(--accent),var(--accent-soft));box-shadow:0 10px 24px #2563eb59}.brand h1{font-family:var(--font-display);font-size:24px;margin:0}.shell{flex:1;padding:0 20px 40px;width:100%;max-width:100%;margin:0 auto}.layout{display:grid;grid-template-columns:180px minmax(0,1fr);gap:14px}.content{display:grid;gap:14px;min-width:0}.nav{background:var(--surface);border-radius:16px;padding:10px;border:1px solid var(--glass-border);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);display:grid;gap:4px;align-self:start;position:sticky;top:16px;overflow:hidden}.nav.is-collapsed{display:grid}.nav-link{padding:7px 10px;border-radius:10px;font-weight:600;font-size:12px;color:var(--ink);display:block;transition:background .2s ease,transform .2s ease,box-shadow .2s ease}.nav-link:hover:not(.disabled){background:#ff6b4d24;transform:translateY(-1px);box-shadow:var(--glow)}.nav-link.active{background:#ff6b4d33;color:var(--accent-strong)}.nav-link.disabled{opacity:.5;cursor:not-allowed}.nav:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(140deg,rgba(255,255,255,.7),rgba(255,255,255,.18) 55%,transparent 70%);opacity:.65;pointer-events:none}html[data-theme=dark] .nav:before{background:linear-gradient(140deg,rgba(255,255,255,.18),rgba(255,255,255,.05) 55%,transparent 70%);opacity:.75}.nav>*{position:relative;z-index:1}.nav-section{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:8px 10px 4px}.hero{display:grid;gap:10px;padding:20px;background:var(--surface);border-radius:20px;border:1px solid var(--glass-border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);position:relative;overflow:hidden}.hero:after{content:"";position:absolute;right:-80px;top:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,77,.18),transparent 65%)}.auth-shell{padding-top:20px}.auth-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:18px;align-items:start}.auth-hero{padding:22px;background:var(--surface);border-radius:24px;border:1px solid var(--glass-border);box-shadow:var(--shadow);position:relative;overflow:hidden}.auth-hero:after{content:"";position:absolute;right:-60px;top:-80px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,77,.25),transparent 65%)}.auth-badge{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.auth-title{font-family:var(--font-display);font-size:28px;margin:8px 0 6px}.auth-sub{color:var(--muted);line-height:1.5;font-size:13px;max-width:520px}.auth-points{display:grid;gap:12px;margin-top:18px}.auth-point{display:grid;gap:4px;padding:12px 14px;background:var(--surface-solid);border-radius:14px;border:1px solid var(--line);box-shadow:inset 0 1px 2px #0f172a0d}.auth-point strong{font-size:13px}.auth-point span{font-size:11px;color:var(--muted)}.auth-card{padding:18px;border-radius:22px;border:1px solid var(--glass-border);background:var(--surface);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%)}.auth-tabs{display:flex;gap:8px;background:var(--surface-solid);border:1px solid var(--line);padding:6px;border-radius:999px}.auth-tab{flex:1;border:none;background:transparent;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer}.auth-tab.active{background:#ff6b4d2e;color:var(--accent-strong);border:1px solid rgba(255,107,77,.3)}.auth-body{padding:12px 4px 4px;display:grid;gap:8px}.auth-body h3{font-family:var(--font-display);font-size:18px;margin:6px 0 0}.auth-note{font-size:11px;color:var(--muted);margin-bottom:4px}.hero-title{font-family:var(--font-display);font-size:26px;margin:0}.hero-sub{color:var(--muted);max-width:520px;line-height:1.5;font-size:13px}.grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:14px;min-width:0}.panel{background:var(--surface);border-radius:18px;padding:16px;border:1px solid var(--glass-border);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);min-width:0;position:relative;overflow:hidden}.panel h2{font-family:var(--font-display);margin:0 0 10px;font-size:18px}.panel-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:10px}.badge{padding:4px 8px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);font-size:10px;color:var(--muted);box-shadow:var(--glow)}.card-list{display:grid;gap:8px}.card{padding:12px;border-radius:14px;border:1px solid var(--glass-border);background:var(--card-bg);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);display:grid;gap:8px;min-width:0;position:relative;overflow:hidden}.panel:before,.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(140deg,rgba(255,255,255,.9),rgba(255,255,255,.2) 55%,transparent 70%);opacity:.7;pointer-events:none}html[data-theme=dark] .panel:before,html[data-theme=dark] .card:before{background:linear-gradient(140deg,rgba(255,255,255,.18),rgba(255,255,255,.05) 55%,transparent 70%);opacity:.75}.panel:after,.card:after{content:"";position:absolute;left:0;right:0;top:1px;height:1px;background:#ffffffbf;opacity:.9;pointer-events:none}html[data-theme=dark] .panel:after,html[data-theme=dark] .card:after{background:#ffffff29;opacity:.7}.panel>*,.card>*{position:relative;z-index:1}a.card{cursor:pointer}.card-row{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:flex-start}.card-row>*{min-width:0}.card-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:flex-end}.input-inline{min-width:120px;width:160px;max-width:100%}.card-title{font-weight:600;font-size:14px}.card-meta{font-size:11px;color:var(--muted);display:flex;gap:8px;align-items:center;flex-wrap:wrap;overflow-wrap:anywhere}.report-block{margin-top:16px}.report-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin:12px 0}.report-header{display:grid;gap:6px;margin-bottom:8px}.report-header-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.report-header h2{margin:0;font-family:var(--font-display);font-size:18px}.report-filters .field{flex:1;min-width:160px}.report-filters select{padding:6px 10px;font-size:11px;border-radius:12px}.report-download{align-self:flex-end}.stat-pill{background:var(--surface-solid);border:1px solid var(--line);border-radius:14px;padding:10px 12px;display:flex;flex-direction:column;gap:4px;box-shadow:inset 0 1px 2px #0f172a0f}.stat-pill span{font-size:11px;color:var(--muted)}.stat-pill strong{font-size:14px;color:var(--ink)}.report-bar{position:relative;height:12px;border-radius:999px;background:#94a3b833;border:1px solid var(--line);overflow:hidden;margin:8px 0 6px}.report-bar-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#ff775ce6,#ffa07be6)}.report-bar-owed{position:absolute;right:0;top:0;bottom:0;background:#ef444459}.report-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:14px}.chart-card{display:grid;gap:10px;align-items:center}.donut-wrap{display:flex;align-items:center;gap:12px}.donut{width:110px;height:110px;transform:rotate(-90deg)}.donut-track{fill:none;stroke:#94a3b833;stroke-width:10}.donut-value{fill:none;stroke:#ff775ce6;stroke-width:10;stroke-linecap:round}.donut-value.is-owed{stroke:#ef4444cc}.donut-text{display:grid;gap:4px}.donut-text strong{font-size:20px;color:var(--ink)}.donut-text span{font-size:11px;color:var(--muted)}.debt-bar{margin-top:8px;height:8px;border-radius:999px;background:#94a3b833;overflow:hidden;border:1px solid var(--line)}.debt-bar span{display:block;height:100%;background:linear-gradient(90deg,#ff775cb3,#ffa07be6)}.debt-list{display:grid;gap:10px;margin-top:10px}.debt-row{display:grid;gap:6px}.debt-label{display:flex;justify-content:space-between;font-size:11px;color:var(--muted)}.debt-label strong{color:var(--ink);font-size:12px}.debt-track{height:8px;background:#94a3b833;border:1px solid var(--line);border-radius:999px;overflow:hidden}.debt-track span{display:block;height:100%;background:linear-gradient(90deg,#ff775cb3,#ffa07be6)}.status{padding:4px 10px;border-radius:999px;font-size:12px;background:#ff6b4d2e;color:var(--accent-strong);border:1px solid rgba(255,107,77,.24)}.status.neutral{background:#94a3b833;color:var(--muted);border-color:#94a3b866}.form{display:grid;gap:12px}.field{display:grid;gap:6px;min-width:0}.field.inline-field{flex:1 1 180px;min-width:180px}label{font-size:11px;color:var(--muted)}input,select,textarea{padding:8px 10px;border-radius:10px;border:1px solid var(--line);background:var(--surface-solid);font-family:var(--font-body);font-size:12px;line-height:1.2;color:var(--ink);width:100%;box-shadow:inset 0 1px 2px #0f172a14}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:28px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 20 20' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 8l4 4 4-4'/></svg>");background-repeat:no-repeat;background-position:right 10px center;background-size:12px}input:focus,select:focus,textarea:focus{outline:2px solid rgba(255,107,77,.25);border-color:transparent}textarea{resize:vertical}.button{padding:7px 12px;border-radius:999px;border:none;background:linear-gradient(140deg,var(--accent),var(--accent-soft));color:#fff;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.button.secondary{background:var(--surface-solid);color:var(--accent-strong);border:1px solid rgba(255,107,77,.2);box-shadow:var(--glow)}.button.ghost{background:transparent;border:1px dashed rgba(255,107,77,.35);color:var(--accent-strong)}.button:disabled{opacity:.6;cursor:not-allowed}.button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 30px #ff6b4d40}.button.secondary:hover:not(:disabled){box-shadow:0 12px 24px #ff6b4d33}.theme-toggle{padding:6px 10px;font-size:11px}.inline{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.check-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.check-row input[type=checkbox]{width:16px;height:16px;padding:0;border-radius:4px;border:1px solid var(--line);background:var(--surface-solid);box-shadow:none;accent-color:var(--accent)}.helper{font-size:11px;color:var(--muted);overflow-wrap:anywhere}.notice{padding:8px 12px;background:var(--notice-bg);border-radius:14px;color:var(--notice-ink);font-size:11px}.error{padding:8px 12px;background:var(--error-bg);color:var(--error-ink);border-radius:12px;font-size:11px}.fade-in{animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1100px){.shell{padding:0 16px 36px}}@media (max-width: 980px){.grid,.auth-grid,.layout{grid-template-columns:1fr}.nav{position:static;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));padding:6px;gap:4px}.nav.is-collapsed{display:none}.nav.is-open{display:grid}.topbar,.shell{padding:14px}.nav-link{padding:6px 8px;font-size:11px}.nav-section{font-size:9px;padding:6px 8px 2px}.button.nav-toggle{display:inline-flex}}@media (max-width: 720px){.inline{flex-direction:column;align-items:stretch}.inline>*{width:100%}.field.inline-field{min-width:100%}.panel-header{align-items:flex-start}.card-actions{align-items:stretch}}@media (max-width: 640px){.topbar{padding:8px 8px 6px;gap:8px}.topbar-actions{gap:4px}.button{padding:6px 10px;font-size:10px}.button.nav-toggle,.button.theme-toggle{width:30px;height:28px}.auth-title,.hero-title{font-size:20px}.brand h1{font-size:17px}.shell{padding:0 6px 18px}.nav{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));padding:6px}.nav-link{padding:6px 8px;font-size:11px}.nav-section{font-size:9px}.panel{padding:8px;border-radius:14px}.panel h2{font-size:15px;margin-bottom:0}.panel-header{gap:6px;margin-bottom:2px}.report-panel{padding-top:6px}.report-header{gap:4px;margin-bottom:6px}.report-header-top{gap:6px}.form{gap:8px}.card{padding:10px;border-radius:14px}.card-title{font-size:12px}.badge{font-size:9px;padding:3px 6px}.field{gap:2px}label{font-size:10px;line-height:1.2}input,select,textarea{padding:6px 9px;font-size:11px;border-radius:10px}select{height:36px;padding-right:26px;background-position:right 8px center}.helper,.notice,.error{font-size:10px}.report-stats,.report-charts{grid-template-columns:1fr}.report-filters{gap:4px;margin-top:-10px}.report-header .report-filters{margin-top:0;gap:6px}.report-header .report-filters label{margin-bottom:0}.report-download{width:100%}.report-filters .field{min-width:100%;gap:0}.report-filters label{margin-bottom:2px}.report-filters select{padding:6px 10px;font-size:11px}}.dashboard{display:grid;gap:14px}.dash-hero{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:12px;padding:20px;border-radius:20px;border:1px solid var(--glass-border);background:linear-gradient(135deg,#ffffffeb,#f0f7ffb3);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px) saturate(140%);backdrop-filter:blur(20px) saturate(140%);position:relative;overflow:hidden}html[data-theme=dark] .dash-hero{background:linear-gradient(135deg,#1e2836e6,#121924d9)}.dash-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(140deg,rgba(255,255,255,.75),rgba(255,255,255,.18) 55%,transparent 70%);opacity:.65;pointer-events:none}html[data-theme=dark] .dash-hero:before{background:linear-gradient(140deg,rgba(255,255,255,.2),rgba(255,255,255,.06) 55%,transparent 70%);opacity:.75}.dash-hero:after{content:"";position:absolute;right:-80px;top:-80px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,77,.18),transparent 65%)}.dash-kicker{text-transform:uppercase;letter-spacing:.08em;font-size:10px;color:var(--muted);margin:0 0 6px}.dash-title{font-family:var(--font-display);font-size:26px;margin:0 0 6px}.dash-sub{color:var(--muted);margin:0;max-width:520px;font-size:13px}.dash-hero>*{position:relative;z-index:1}.dash-actions-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.action-card{padding:14px 16px;border-radius:16px;border:1px solid var(--glass-border);background:var(--card-bg);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);display:grid;gap:6px;position:relative;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.action-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(140deg,rgba(255,255,255,.85),rgba(255,255,255,.2) 55%,transparent 70%);opacity:.65;pointer-events:none}html[data-theme=dark] .action-card:before{background:linear-gradient(140deg,rgba(255,255,255,.18),rgba(255,255,255,.06) 55%,transparent 70%);opacity:.75}.action-card:hover{transform:translateY(-2px);box-shadow:0 16px 30px #ff6b4d38}.action-card>*{position:relative;z-index:1}.action-title{font-weight:600;font-size:14px;color:var(--ink)}.action-sub{font-size:12px;color:var(--muted)}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.stat-card{padding:12px 14px;border-radius:16px;border:1px solid var(--glass-border);background:var(--card-bg);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);display:grid;gap:4px;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(140deg,rgba(255,255,255,.8),rgba(255,255,255,.15) 55%,transparent 70%);opacity:.6;pointer-events:none}html[data-theme=dark] .stat-card:before{background:linear-gradient(140deg,rgba(255,255,255,.18),rgba(255,255,255,.05) 55%,transparent 70%);opacity:.7}.stat-card>*{position:relative;z-index:1}.stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.stat-value{font-size:20px;font-weight:700;color:var(--ink)}.stat-hint{font-size:11px;color:var(--muted)}@media (max-width: 980px){.dash-hero{grid-template-columns:1fr}.dash-actions-grid,.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.dash-actions-grid,.stat-grid{grid-template-columns:1fr}}
