@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap";:root{--bg: #0f1117;--bg-card: #1a1d27;--bg-input: #22263a;--bg-hover: #252940;--border: #2d3250;--border-light: #3a3f60;--text: #e8eaf6;--text-muted: #7b82a8;--text-dim: #4a5080;--accent: #6366f1;--accent-hover: #7c7fff;--accent-dim: rgba(99,102,241,.12);--positive: #34d399;--negative: #f87171;--positive-bg: #0d2f24;--negative-bg: #2d1515;--danger: #ef4444;--warning: #f59e0b;--header-bg: rgba(15,17,23,.92);--modal-bg: rgba(0,0,0,.65);--radius-sm: 6px;--radius: 12px;--radius-lg: 18px;--radius-xl: 24px;--shadow: 0 4px 24px rgba(0,0,0,.4);--shadow-lg: 0 8px 40px rgba(0,0,0,.6);--transition: .2s cubic-bezier(.4,0,.2,1);--font: "Inter", system-ui, sans-serif;--font-mono: "DM Mono", "Fira Code", monospace;--max-width: 480px;--page-pad: 20px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}@media (prefers-color-scheme: light){:root{--bg: #f4f5fb;--bg-card: #ffffff;--bg-input: #eef0f8;--bg-hover: #e4e6f4;--border: #dde0f0;--border-light: #c8cce4;--text: #1a1d2e;--text-muted: #6b70a0;--text-dim: #a0a4c4;--accent: #4f52d8;--accent-hover: #6366f1;--accent-dim: rgba(79,82,216,.1);--positive: #059669;--negative: #dc2626;--positive-bg: #d1fae5;--negative-bg: #fee2e2;--danger: #dc2626;--header-bg: rgba(244,245,251,.92);--modal-bg: rgba(0,0,0,.4);--shadow: 0 2px 16px rgba(0,0,0,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.14)}}html[data-theme=dark]{--bg: #0f1117;--bg-card: #1a1d27;--bg-input: #22263a;--bg-hover: #252940;--border: #2d3250;--border-light: #3a3f60;--text: #e8eaf6;--text-muted: #7b82a8;--text-dim: #4a5080;--accent: #6366f1;--accent-hover: #7c7fff;--accent-dim: rgba(99,102,241,.12);--positive: #34d399;--negative: #f87171;--positive-bg: #0d2f24;--negative-bg: #2d1515;--danger: #ef4444;--header-bg: rgba(15,17,23,.92);--modal-bg: rgba(0,0,0,.65);--shadow: 0 4px 24px rgba(0,0,0,.4);--shadow-lg: 0 8px 40px rgba(0,0,0,.6)}html[data-theme=light]{--bg: #f4f5fb;--bg-card: #ffffff;--bg-input: #eef0f8;--bg-hover: #e4e6f4;--border: #dde0f0;--border-light: #c8cce4;--text: #1a1d2e;--text-muted: #6b70a0;--text-dim: #a0a4c4;--accent: #4f52d8;--accent-hover: #6366f1;--accent-dim: rgba(79,82,216,.1);--positive: #059669;--negative: #dc2626;--positive-bg: #d1fae5;--negative-bg: #fee2e2;--danger: #dc2626;--header-bg: rgba(244,245,251,.92);--modal-bg: rgba(0,0,0,.4);--shadow: 0 2px 16px rgba(0,0,0,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.14)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;overflow-x:hidden}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;overflow-x:hidden;overscroll-behavior:none;-webkit-overflow-scrolling:touch}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit;-webkit-tap-highlight-color:transparent}input,select,textarea{font:inherit;color:inherit}img{max-width:100%;display:block}#app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;width:100%;max-width:100vw;overflow-x:hidden}.theme-toggle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);color:var(--text-muted);transition:background var(--transition),color var(--transition);flex-shrink:0}.theme-toggle:hover{background:var(--bg-hover);color:var(--text)}#toast-container{position:fixed;bottom:calc(24px + var(--safe-bottom));left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:9999;pointer-events:none;width:min(calc(100vw - 32px),400px)}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);opacity:0;transform:translateY(12px);transition:opacity var(--transition),transform var(--transition);pointer-events:auto}.toast--visible{opacity:1;transform:translateY(0)}.toast--success{border-color:var(--positive)}.toast--error{border-color:var(--negative)}.toast__icon{font-size:14px;flex-shrink:0}.toast--success .toast__icon{color:var(--positive)}.toast--error .toast__icon{color:var(--negative)}.toast__msg{font-size:14px;font-weight:500}.page-loading{flex:1;display:flex;align-items:center;justify-content:center}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-error{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--text-muted);padding:var(--page-pad);text-align:center}.auth-page{flex:1;display:flex;align-items:center;justify-content:center;padding:calc(24px + var(--safe-top)) var(--page-pad) calc(24px + var(--safe-bottom));min-height:100dvh}.auth-card{width:100%;max-width:400px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px 32px;box-shadow:var(--shadow)}.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:32px}.auth-logo__icon{width:40px;height:40px;background:var(--accent);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;flex-shrink:0}.auth-logo__name{font-size:22px;font-weight:700;letter-spacing:-.02em}.auth-title{font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:6px}.auth-subtitle{color:var(--text-muted);font-size:14px;margin-bottom:28px}.auth-links{margin-top:20px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--text-muted);flex-wrap:wrap}.auth-links__sep{opacity:.4}.page{max-width:var(--max-width);margin:0 auto;width:100%;padding-left:max(var(--page-pad),var(--safe-left));padding-right:max(var(--page-pad),var(--safe-right));padding-bottom:calc(100px + var(--safe-bottom));flex:1;overflow-x:hidden}.page-header{display:flex;align-items:center;justify-content:space-between;padding-top:calc(12px + var(--safe-top));padding-bottom:12px;position:sticky;top:0;background:var(--header-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:100;margin-left:calc(-1*max(var(--page-pad),var(--safe-left)));margin-right:calc(-1*max(var(--page-pad),var(--safe-right)));padding-left:max(var(--page-pad),var(--safe-left));padding-right:max(var(--page-pad),var(--safe-right))}.page-header__center{flex:1;text-align:center;padding:0 8px;min-width:0}.page-header__left,.page-header__right{display:flex;align-items:center;gap:4px;flex-shrink:0}.page-title{font-size:18px;font-weight:700;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:var(--radius);font-size:14px;font-weight:600;transition:background var(--transition),opacity var(--transition),transform var(--transition);white-space:nowrap;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;min-height:44px}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover:not(:disabled){background:var(--accent-hover)}.btn--ghost{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}.btn--ghost:hover:not(:disabled){background:var(--bg-hover)}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover:not(:disabled){opacity:.85}.btn--full{width:100%}.btn--sm{padding:7px 14px;font-size:13px;border-radius:var(--radius-sm);min-height:36px}.icon-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);color:var(--text-muted);transition:background var(--transition),color var(--transition);position:relative;flex-shrink:0;-webkit-tap-highlight-color:transparent}.icon-btn:hover{background:var(--bg-hover);color:var(--text)}.icon-btn:active{background:var(--bg-hover);transform:scale(.93)}.link-btn{color:var(--accent);font-size:inherit;background:none;border:none;cursor:pointer;padding:4px 0;-webkit-tap-highlight-color:transparent}.link-btn:hover{text-decoration:underline}.badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;background:var(--negative);color:#fff;font-size:10px;font-weight:700;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px}.badge--owner,.badge--you{position:static;font-size:11px;font-weight:600;border-radius:999px;padding:2px 8px;height:auto}.badge--owner{background:var(--accent-dim);color:var(--accent)}.badge--you{background:var(--positive-bg);color:var(--positive)}.form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:var(--text-muted);letter-spacing:.02em;text-transform:uppercase}.optional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-dim)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],select,textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-size:16px;color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition);width:100%;min-width:0;-moz-appearance:none;appearance:none;-webkit-appearance:none}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}input.input--disabled{opacity:.5;cursor:not-allowed}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237b82a8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}textarea{resize:vertical;min-height:72px}.form-hint{font-size:12px;color:var(--text-dim);margin-top:4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-actions{display:flex;flex-direction:column;gap:10px;padding-top:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-bg);display:flex;align-items:flex-end;justify-content:center;z-index:1000;opacity:0;transition:opacity var(--transition);overflow:hidden}.modal-overlay--visible{opacity:1}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:28px 24px;padding-bottom:calc(32px + var(--safe-bottom));width:100%;max-width:480px;max-height:92dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translateY(40px);transition:transform var(--transition)}.modal-overlay--visible .modal{transform:translateY(0)}@media (min-width: 520px){.modal-overlay{align-items:center;padding:24px}.modal{border-radius:var(--radius-xl);padding-bottom:28px;transform:translateY(12px);max-height:88dvh}}.modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal__header h2{font-size:18px;font-weight:700}.modal__close{font-size:16px;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:8px;margin:-8px;border-radius:var(--radius-sm);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.modal__close:hover{color:var(--text)}.modal--confirm{padding:32px 24px 28px}.modal__msg{font-size:16px;margin-bottom:24px;line-height:1.5}.modal__actions{display:flex;gap:10px;justify-content:flex-end}.dropdown{position:fixed;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:500;min-width:200px;opacity:0;transform:scale(.95) translateY(-4px);transition:opacity var(--transition),transform var(--transition);transform-origin:top right;overflow:hidden}.dropdown--visible{opacity:1;transform:scale(1) translateY(0)}.dropdown__item{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;font-size:14px;font-weight:500;text-align:left;transition:background var(--transition);min-height:48px}.dropdown__item:hover{background:var(--bg-hover)}.dropdown__item--danger{color:var(--danger)}.tabs{display:flex;gap:4px;background:var(--bg-input);border-radius:var(--radius);padding:4px;margin-bottom:20px}.tab{flex:1;padding:9px 8px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--text-muted);transition:background var(--transition),color var(--transition);text-align:center;min-height:38px;-webkit-tap-highlight-color:transparent}.tab:hover{color:var(--text)}.tab--active{background:var(--bg-card);color:var(--text);box-shadow:0 1px 4px #00000026}.dashboard-actions{display:flex;gap:10px;margin-bottom:24px;flex-wrap:wrap}.groups-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}.group-card{display:flex;align-items:center;gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:background var(--transition),border-color var(--transition);min-width:0;-webkit-tap-highlight-color:transparent}.group-card:hover{background:var(--bg-hover);border-color:var(--border-light)}.group-card:active{transform:scale(.99)}.group-card__avatar{width:44px;height:44px;border-radius:var(--radius);background:var(--accent-dim);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.group-card__info{flex:1;min-width:0}.group-card__name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-card__desc{font-size:13px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-card__arrow{color:var(--text-dim);flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 24px;gap:12px}.empty-state__icon{font-size:48px;margin-bottom:4px}.empty-state h2{font-size:18px;font-weight:700}.empty-state p{font-size:14px;color:var(--text-muted);max-width:280px;line-height:1.5}.section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:12px}.expense-date-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);padding:14px 0 6px}.expense-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:opacity var(--transition);min-width:0;-webkit-tap-highlight-color:transparent}.expense-row:last-child{border-bottom:none}.expense-row:hover{opacity:.75}.expense-row:active{opacity:.6}.expense-row__cat{width:42px;height:42px;background:var(--bg-input);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.expense-row__info{flex:1;min-width:0}.expense-row__title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-row__meta{font-size:12px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-row__amount{font-family:var(--font-mono);font-size:14px;font-weight:500;flex-shrink:0}.expense-search-bar{margin-bottom:4px}.expense-search-bar input{padding:10px 14px;font-size:15px}.balance-banner{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-radius:var(--radius-lg);margin-bottom:20px;gap:8px}.balance-banner--positive{background:var(--positive-bg);border:1px solid rgba(52,211,153,.2)}.balance-banner--negative{background:var(--negative-bg);border:1px solid rgba(248,113,113,.2)}.balance-banner--settled{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted)}.balance-banner__label{font-size:13px;font-weight:500;color:var(--text-muted)}.balance-banner--positive .balance-banner__label{color:var(--positive);opacity:.8}.balance-banner--negative .balance-banner__label{color:var(--negative);opacity:.8}.balance-banner__amount{font-family:var(--font-mono);font-size:22px;font-weight:500}.balance-banner--positive .balance-banner__amount{color:var(--positive)}.balance-banner--negative .balance-banner__amount{color:var(--negative)}.balances-list{display:flex;flex-direction:column;gap:2px;margin-bottom:28px}.balance-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border);font-size:14px;min-width:0;gap:8px}.balance-row:last-child{border-bottom:none}.balance-row__name{font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.balance-row__amount{font-family:var(--font-mono);font-weight:600;flex-shrink:0}.amount--positive{color:var(--positive)}.amount--negative{color:var(--negative)}.settled-msg{text-align:center;color:var(--positive);font-size:15px;font-weight:600;padding:32px 0}.settlements-section{margin-top:24px}.settlement-suggestion{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.settlement-suggestion:last-child{border-bottom:none}.settlement-suggestion__info{display:flex;align-items:center;gap:8px;font-size:14px;flex-wrap:wrap;min-width:0;flex:1}.settlement-suggestion__arrow{color:var(--text-muted);flex-shrink:0}.settlement-suggestion__amount{font-family:var(--font-mono);font-weight:600;color:var(--accent);flex-shrink:0}.settlement-history-row{display:flex;gap:12px;align-items:center;padding:10px 0;font-size:13px;border-bottom:1px solid var(--border);color:var(--text-muted);flex-wrap:wrap}.settlement-history-row:last-child{border-bottom:none}.settlement-date{margin-left:auto;flex-shrink:0}.invite-code-box{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:20px;min-width:0}.invite-code-box__label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;flex-shrink:0}.invite-code-box__code{font-family:var(--font-mono);font-size:18px;font-weight:500;letter-spacing:.12em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.members-list{display:flex;flex-direction:column;gap:10px}.member-card{display:flex;align-items:flex-start;gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;min-width:0}.member-card__avatar{width:42px;height:42px;border-radius:50%;background:var(--bg-input);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0;overflow:hidden}.member-card__info{flex:1;min-width:0}.member-card__name{font-size:14px;font-weight:600;display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0}.household-members{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.household-tag{font-size:12px;background:var(--bg-input);color:var(--text-muted);border-radius:999px;padding:3px 10px}.hm-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.hm-input{flex:2;min-width:80px}.hm-input--weight{flex:1;min-width:60px;max-width:72px}.hm-select{flex:1.5;min-width:80px}.expense-form{margin-top:8px}.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.category-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;background:var(--bg-input);border:1.5px solid transparent;border-radius:var(--radius);font-size:11px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all var(--transition);text-align:center;-webkit-tap-highlight-color:transparent;min-height:64px}.category-btn:hover{background:var(--bg-hover);color:var(--text)}.category-btn--selected{border-color:var(--accent);background:var(--accent-dim);color:var(--text)}.category-btn span:first-child{font-size:20px}.split-method-tabs{display:flex;gap:8px}.split-tab{flex:1;padding:10px;background:var(--bg-input);border:1.5px solid transparent;border-radius:var(--radius);font-size:13px;font-weight:600;color:var(--text-muted);transition:all var(--transition);text-align:center;min-height:44px;-webkit-tap-highlight-color:transparent}.split-tab:hover{color:var(--text)}.split-tab--active{border-color:var(--accent);background:var(--accent-dim);color:var(--text)}.participant-check{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;min-height:48px;-webkit-tap-highlight-color:transparent}.participant-check:last-child{border-bottom:none}.participant-check input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent);flex-shrink:0;cursor:pointer}.participant-check__name{flex:1;font-size:14px;font-weight:500;min-width:0}.participant-check__name em{font-style:normal;color:var(--text-muted);font-size:12px}.custom-amount-input{width:88px!important;padding:6px 10px!important;font-size:14px!important;text-align:right;flex-shrink:0}.split-preview{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.split-preview:empty{display:none}.split-preview__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:10px 14px 6px}.split-preview__row{display:flex;justify-content:space-between;padding:7px 14px;font-size:13px;border-top:1px solid var(--border);gap:8px}.split-preview__row span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.split-preview__warning{padding:12px 14px;font-size:13px;color:var(--warning)}.file-upload-label{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-input);border:1px dashed var(--border-light);border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background var(--transition),color var(--transition);min-height:48px}.file-upload-label:hover{background:var(--bg-hover);color:var(--text)}.photo-previews,.existing-photos{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.photo-thumb{position:relative;width:80px;height:80px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);flex-shrink:0}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-thumb__remove{position:absolute;top:4px;right:4px;width:22px;height:22px;background:#000000b3;color:#fff;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none}.expense-detail{padding-top:8px}.expense-detail__hero{text-align:center;padding:24px 16px 32px}.expense-detail__icon{font-size:48px;margin-bottom:12px}.expense-detail__amount{font-family:var(--font-mono);font-size:36px;font-weight:500;margin-bottom:8px;letter-spacing:-.02em;word-break:break-all}.expense-detail__title{font-size:20px;font-weight:700;margin-bottom:6px}.expense-detail__meta{font-size:13px;color:var(--text-muted)}.expense-detail__section{border-top:1px solid var(--border);padding:16px 0}.expense-detail__section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:8px}.expense-detail__value{font-size:15px;font-weight:500}.expense-detail__desc{font-size:14px;color:var(--text-muted);line-height:1.6}.participants-breakdown{display:flex;flex-direction:column;gap:6px}.participant-breakdown-row{display:flex;justify-content:space-between;font-size:14px;padding:4px 0;gap:8px;min-width:0}.participant-breakdown-row span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-gallery{display:flex;flex-wrap:wrap;gap:10px}.photo-gallery__thumb{width:100px;height:100px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);flex-shrink:0}.photo-gallery__thumb img{width:100%;height:100%;object-fit:cover;transition:opacity var(--transition)}.photo-gallery__thumb:hover img{opacity:.85}.profile-content{padding:16px 0;display:flex;flex-direction:column;gap:24px}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;gap:12px}.profile-avatar{width:84px;height:84px;border-radius:50%;background:var(--bg-input);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;overflow:hidden;border:2px solid var(--border);flex-shrink:0}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-section-divider{border:none;border-top:1px solid var(--border)}.notifications-list{display:flex;flex-direction:column;padding-top:8px}.notif-row{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--border);cursor:default;min-width:0}.notif-row[data-group-id]{cursor:pointer;-webkit-tap-highlight-color:transparent}.notif-row[data-group-id]:hover{opacity:.8}.notif-row[data-group-id]:active{opacity:.6}.notif-row:last-child{border-bottom:none}.notif-row--unread{position:relative}.notif-row--unread:before{content:"";position:absolute;left:calc(-1*max(var(--page-pad),var(--safe-left)));top:0;bottom:0;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.notif-row__icon{font-size:22px;flex-shrink:0;padding-top:2px}.notif-row__content{flex:1;min-width:0}.notif-row__title{font-size:14px;font-weight:600}.notif-row__body{font-size:13px;color:var(--text-muted);margin-top:2px}.notif-row__time{font-size:12px;color:var(--text-dim);margin-top:4px}.fab{position:fixed;bottom:calc(24px + var(--safe-bottom));right:max(24px,var(--safe-right));width:56px;height:56px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px #6366f173;transition:background var(--transition),transform var(--transition);z-index:200;-webkit-tap-highlight-color:transparent}.fab:hover{background:var(--accent-hover);transform:scale(1.06)}.fab:active{transform:scale(.93)}@media (min-width: 520px){.fab{right:calc(50% - 216px)}}.dashboard-section{margin-top:12px}@media (max-width: 380px){:root{--page-pad: 14px}.form-row{grid-template-columns:1fr}.auth-card{padding:28px 18px}.category-grid{grid-template-columns:repeat(3,1fr)}.invite-code-box__code{font-size:15px;letter-spacing:.08em}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
