:root{--bg-main: #f6f6f6;--card-bg: #ffffff;--input-bg: #f4f4f4;--text-main: #111111;--text-muted: #5f5f5f;--border: #d7d7d7;--shadow-soft: 0 8px 24px rgba(0, 0, 0, .06);font-family:Manrope,Segoe UI,sans-serif;color:var(--text-main);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;width:100%;min-height:100svh;overflow-x:hidden}body{background:radial-gradient(circle at top,#fff,#f1f1f1 75%)}.app-shell{min-height:100svh;display:flex;align-items:center;justify-content:center;padding:18px}.login-card,.phone-frame{width:min(100%,420px);border:1px solid var(--border);background:var(--card-bg);border-radius:24px;padding:24px 20px;box-shadow:var(--shadow-soft)}.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;margin:0 0 8px;color:var(--text-muted);font-weight:600}h1{margin:0 0 8px;font-size:clamp(1.9rem,7vw,2.2rem);letter-spacing:-.04em}.subtitle{margin:0 0 24px;color:var(--text-muted);font-size:.95rem}.login-form{display:grid;gap:12px}.login-form label{font-size:.82rem;color:var(--text-muted);font-weight:600}.login-form input{width:100%;box-sizing:border-box;border-radius:14px;border:1px solid var(--border);background:var(--input-bg);color:var(--text-main);padding:14px 13px;font-size:1rem;transition:border-color .16s ease,background-color .16s ease}.login-form input::placeholder{color:#7c7c7c}.login-form input:focus-visible{outline:none;border-color:#000;background:#fff}.login-form button{margin-top:8px;width:100%;border:1px solid #000;border-radius:14px;padding:14px;font-size:1rem;font-weight:700;color:#fff;background:#000;cursor:pointer;transition:transform .12s ease,opacity .12s ease}.login-form button:active{transform:translateY(1px)}.login-form button:hover{opacity:.9}.form-error{margin:12px 2px 0;font-size:.82rem;color:#9f2323}.dashboard-shell{align-items:stretch;padding:0}.phone-frame{min-height:100svh;border-radius:0;border-left:none;border-right:none;border-top:none;box-shadow:none;padding:16px 14px 84px;position:relative;overflow-x:hidden}.top-header{margin-bottom:14px}.top-header h1{font-size:1.7rem}.pwa-install-card{margin-bottom:12px;border:1px solid var(--border);border-radius:14px;padding:10px 11px;background:#fff;display:grid;gap:8px}.pwa-install-title{margin:0;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-muted)}.pwa-install-hint{margin:0;font-size:.82rem;color:var(--text-muted)}.home-grid{display:grid;gap:10px}.panel{border:1px solid var(--border);border-radius:18px;background:#fff;padding:14px}.panel-primary{background:#0f0f0f;color:#fff;border-color:#0f0f0f}.panel-title{margin:0;font-size:.78rem;text-transform:uppercase;letter-spacing:.11em;font-weight:700;color:var(--text-muted)}.panel-primary .panel-title{color:#cfcfcf}.stay-state{margin:6px 0 0;font-size:1.2rem;font-weight:800}.stay-timer{margin:4px 0 14px;font-size:.9rem;color:#d0d0d0}.primary-action{width:100%;border:1px solid #fff;color:#111;background:#fff;border-radius:12px;padding:13px;font-size:.96rem;font-weight:700}.summary-row{margin-top:10px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.summary-row div{border:1px solid var(--border);border-radius:12px;text-align:center;padding:10px 6px;background:#fcfcfc}.summary-number{display:block;font-weight:800;font-size:1.02rem}.summary-label{display:block;font-size:.72rem;color:var(--text-muted);margin-top:3px}.trend{margin-top:12px;display:flex;gap:6px;height:74px;align-items:flex-end}.trend-bar{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;border:none;cursor:pointer;padding:0;border-radius:6px 6px 3px 3px;background:linear-gradient(180deg,#222,#7d7d7d)}.trend-bar:focus-visible{outline:2px solid #111;outline-offset:2px}.trend-hint{margin:8px 0 0;border:1px solid var(--border);border-radius:10px;padding:7px 9px;font-size:.78rem;color:var(--text-muted);background:#fafafa}.latest-bill-row{align-items:flex-start}.latest-bill-meta{display:grid;justify-items:end;gap:6px;flex-shrink:0;min-width:0}.latest-bill-status{max-width:100%;overflow-wrap:anywhere;word-break:break-word}.panel-headline{display:flex;justify-content:space-between;align-items:center;gap:8px}.ghost-button{border:1px solid var(--border);background:#fff;color:var(--text-main);border-radius:10px;padding:6px 9px;font-size:.78rem;font-weight:600}.event-list{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:8px}.event-list li{border:1px solid var(--border);border-radius:12px;padding:10px 11px;display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:.88rem}.event-list small{color:var(--text-muted)}.bill-preview{margin-top:10px;display:grid;gap:3px}.bill-preview p{margin:0 0 4px;font-weight:700}.bill-preview small{color:var(--text-muted)}.tab-content-grid{display:grid;gap:10px;min-width:0}.chip-row{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.chip{border:1px solid var(--border);background:#fff;border-radius:999px;padding:7px 11px;font-size:.78rem;font-weight:600;color:#444}.chip.active{border-color:#111;color:#111}.custom-range{margin-top:10px;display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:end}.custom-range label{display:grid;gap:4px;font-size:.76rem;color:var(--text-muted)}.custom-range input{border:1px solid var(--border);border-radius:10px;padding:8px;background:#fff}.history-list,.bill-list,.roommate-list{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:8px}.history-list li,.bill-list li,.roommate-list li{border:1px solid var(--border);border-radius:12px;padding:10px 11px;display:flex;justify-content:space-between;align-items:center;gap:8px;min-width:0}.empty-state{border:1px dashed var(--border);border-radius:12px;padding:12px;font-size:.86rem;color:var(--text-muted);justify-content:center}.history-list strong,.bill-list strong{font-size:.9rem}.history-list p,.bill-list p{margin:2px 0;color:var(--text-muted);font-size:.84rem}.history-list small,.bill-list small,.roommate-list small{color:var(--text-muted);font-size:.78rem}.history-meta{display:grid;justify-items:end;gap:4px;font-size:.82rem;flex-shrink:0}.alert-badge{border:1px solid #111;border-radius:999px;padding:2px 7px;color:#111;background:#fff}.bill-list li .status-tag{margin-top:0}.stats-visual-grid{margin-top:10px;display:grid;gap:10px}.pie-card{border:1px solid var(--border);border-radius:14px;padding:12px;background:linear-gradient(180deg,#fff,#f8f8f8)}.pie-wrap{display:grid;place-items:center}.pie-chart{width:min(210px,70vw);aspect-ratio:1;border-radius:999px;display:grid;place-items:center;animation:pie-sweep .7s ease both}.pie-hole{width:58%;aspect-ratio:1;border-radius:999px;background:#fff;border:1px solid var(--border);display:grid;place-items:center;text-align:center;padding:8px}.pie-hole strong{font-size:1rem}.pie-hole small{color:var(--text-muted);font-size:.75rem}.pie-caption{margin:10px 0 0;text-align:center;font-size:.78rem;color:var(--text-muted)}.stats-list li{display:grid;gap:8px}.stats-entry-head{display:flex;justify-content:space-between;align-items:center;gap:10px}.stats-label-line{display:flex;align-items:center;gap:8px}.stats-dot{width:10px;height:10px;border-radius:999px;border:1px solid #fff;box-shadow:0 0 0 1px #0003;flex-shrink:0}.stats-bar-track{width:100%;height:8px;border-radius:999px;background:#ececec;overflow:hidden}.stats-bar-fill{height:100%;border-radius:999px;display:block;animation:bar-grow .5s ease both}@keyframes pie-sweep{0%{transform:scale(.9);opacity:.3}to{transform:scale(1);opacity:1}}@keyframes bar-grow{0%{width:0;opacity:.2}to{opacity:1}}.bill-row{padding:0}.bill-row-button{width:100%;border:none;background:transparent;text-align:left;padding:10px 11px;display:flex;justify-content:space-between;align-items:center;gap:8px}.bill-row.active{border-color:#111;background:#fafafa}.detail-grid{margin-top:10px;display:grid;gap:8px}.detail-grid p{margin:0;border:1px solid var(--border);border-radius:12px;padding:10px 11px;font-size:.88rem}.bill-form-grid{margin-top:10px;display:grid;gap:8px}.bill-action-grid{margin-top:8px;display:grid;gap:8px}.bill-action{border:1px solid var(--border);border-radius:12px;padding:10px;background:#fff;display:flex;align-items:center;gap:10px;font-weight:700}.bill-action svg{width:18px;height:18px;fill:#111;flex-shrink:0}.bill-form-grid label{display:grid;gap:4px;font-size:.78rem;color:var(--text-muted)}.bill-form-grid input,.bill-form-grid select{border:1px solid var(--border);border-radius:10px;padding:9px;background:#fff;color:var(--text-main)}.bill-fixed-preview{margin:4px 0 0;font-size:.84rem;font-weight:700}.bill-options{border:1px solid var(--border);border-radius:10px;padding:8px;display:grid;gap:8px}.bill-form-grid label.option-toggle{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-main)}.bill-form-grid label.option-toggle input{margin:0;width:16px;height:16px;flex-shrink:0}.bill-form-grid label.option-toggle span{line-height:1.25}.upload-subtitle{margin:0}.upload-error,.upload-warning{margin:0;border:1px solid #e7bbbb;border-radius:10px;padding:8px 10px;font-size:.8rem;color:#9f2323;background:#fff}.bill-extraction-card{margin-top:12px;border:1px solid var(--border);border-radius:12px;padding:10px;display:grid;gap:8px;background:#fcfcfc}.primary-inline{border:1px solid #111;color:#fff;background:#111;border-radius:12px;padding:10px;font-weight:700}.status-tag{margin-top:6px;width:fit-content;border:1px solid #111;border-radius:999px;padding:3px 8px;color:#111;background:#fff}.tab-placeholder{border:1px solid var(--border);border-radius:18px;padding:18px 16px;background:#fff}.tab-placeholder h2{margin:0;font-size:1.2rem}.tab-placeholder p{margin-top:8px;color:var(--text-muted)}.bottom-nav{position:fixed;bottom:0;left:0;width:100%;border-top:1px solid var(--border);background:#fffffff5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;grid-template-columns:repeat(4,1fr);padding:8px 8px calc(8px + env(safe-area-inset-bottom,0px));gap:6px}.developer-credit{margin:20px 0 0;text-align:center;font-size:.7rem;font-weight:600;letter-spacing:.02em;color:var(--text-muted);transform:translateY(10px)}.tab{border:1px solid transparent;background:transparent;border-radius:12px;padding:10px 6px;font-size:.8rem;font-weight:600;color:#555}.tab.active{border-color:#111;color:#111;background:#f8f8f8}.toast{position:fixed;left:50%;bottom:84px;transform:translate(-50%);background:#111;color:#fff;margin:0;border-radius:999px;padding:9px 14px;font-size:.84rem;white-space:nowrap}.api-error{position:fixed;left:50%;bottom:48px;transform:translate(-50%);margin:0;color:#9f2323;background:#fff;border:1px solid #e2a5a5;border-radius:10px;padding:7px 10px;font-size:.78rem}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:40}.correction-drawer{position:fixed;left:0;right:0;bottom:0;max-height:78svh;overflow:auto;background:#fff;border-top:1px solid var(--border);border-radius:18px 18px 0 0;padding:14px 14px calc(18px + env(safe-area-inset-bottom,0px));z-index:50}.drawer-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px}.drawer-header h2{margin:0;font-size:1.02rem}.correction-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.correction-list li{border:1px solid var(--border);border-radius:12px;padding:10px;display:grid;gap:10px}.correction-meta{display:grid;gap:3px}.correction-meta strong{font-size:.92rem}.correction-meta small{color:var(--text-muted);font-size:.8rem}.correction-form{display:grid;gap:8px}.correction-form label{display:grid;gap:4px;font-size:.78rem;color:var(--text-muted)}.correction-form input{border:1px solid var(--border);border-radius:10px;padding:8px;background:#fff}.correction-actions{display:flex;gap:8px;justify-content:flex-end}.ghost-button.danger{border-color:#e7bbbb;color:#9f2323;background:#fff}@media (max-width: 430px){.panel-headline{flex-wrap:wrap;align-items:flex-start}.custom-range{grid-template-columns:1fr}.custom-range .ghost-button{width:100%}.history-list li,.latest-bill-row{flex-direction:column;align-items:flex-start}.latest-bill-meta{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px}.history-meta{display:flex;align-items:center;justify-content:space-between;width:100%}.correction-actions{width:100%;justify-content:stretch}.correction-actions .ghost-button{flex:1}}@media (min-width: 768px){.app-shell{padding:28px}.login-card,.phone-frame{border-radius:28px;padding:30px}.dashboard-shell{align-items:center;padding:18px}.phone-frame{min-height:88svh;border:1px solid var(--border);box-shadow:var(--shadow-soft);padding:18px 16px 86px}.bottom-nav{width:min(420px,100%);left:50%;transform:translate(-50%);border-left:1px solid var(--border);border-right:1px solid var(--border);border-radius:14px 14px 0 0}.correction-drawer{width:min(420px,100%);left:50%;transform:translate(-50%);border:1px solid var(--border);border-bottom:none}}
