:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--fg: #1a1a1a;--bg: #f5f5f5;--card-bg: #fff;--border: #e0e0e0;--muted: #666;--primary: #2563eb;--primary-fg: #fff;--positive: #16a34a;--error: #b91c1c}@media(prefers-color-scheme:dark){:root{--fg: #f5f5f5;--bg: #1a1a1a;--card-bg: #262626;--border: #404040;--muted: #a3a3a3;--primary: #3b82f6;--primary-fg: #fff;--positive: #22c55e;--error: #ef4444}}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--fg);background:var(--bg)}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit}.landing-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.landing-container{max-width:1000px;margin:0 auto;padding:0 1.25rem;width:100%}.landing-header{background:var(--card-bg);border-bottom:1px solid var(--border);padding:1rem 0;position:sticky;top:0;z-index:100}.landing-header .landing-container{display:flex;justify-content:space-between;align-items:center}.landing-logo{font-size:1.5rem;font-weight:700;margin:0;color:var(--fg);display:flex;align-items:center;gap:.4rem}.landing-logo-icon{width:1.5rem;height:1.5rem}.landing-nav{display:flex;gap:1rem;align-items:center}.landing-nav .btn-text{color:var(--primary);text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s}.landing-nav .btn-text:hover{background:var(--bg)}.landing-main{flex:1}.hero{padding:4rem 0;text-align:center}.hero h2{font-size:2.5rem;margin:0 0 1rem;color:var(--fg);line-height:1.2}.hero p{font-size:1.1rem;color:var(--muted);margin:0 0 2rem;max-width:600px;margin-left:auto;margin-right:auto}.hero-signin{font-size:.95rem;color:var(--muted);margin:1rem 0 0}.hero-signin a{color:var(--primary);text-decoration:none;font-weight:500}.hero-signin a:hover{text-decoration:underline}.btn-large{padding:1rem 2rem!important;font-size:1rem!important}.btn-primary{display:inline-block;padding:.75rem 1.25rem;background:var(--primary);color:var(--primary-fg);border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.how-it-works{padding:4rem 0;background:var(--card-bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.how-it-works h2{font-size:1.75rem;margin:0 0 2.5rem;text-align:center;color:var(--fg)}.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.step{text-align:center}.step-number{width:2.5rem;height:2.5rem;border-radius:50%;background:var(--primary);color:var(--primary-fg);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;margin-bottom:1rem}.step h3{font-size:1.1rem;margin:0 0 .5rem;color:var(--fg)}.step p{font-size:.95rem;color:var(--muted);margin:0;line-height:1.6}.why-section{padding:4rem 0}.why-section h2{font-size:1.75rem;margin:0 0 2.5rem;text-align:center;color:var(--fg)}.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.why-card--wide{grid-column:1 / -1}.why-card{padding:1.75rem;background:var(--card-bg);border:1px solid var(--border);border-radius:12px}.why-card h3{font-size:1.05rem;margin:0 0 .5rem;color:var(--fg)}.why-card p{font-size:.95rem;color:var(--muted);margin:0;line-height:1.6}.landing-footer{background:var(--card-bg);border-top:1px solid var(--border);padding:2rem 0;margin-top:2rem}.landing-footer .landing-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.footer-kofi:empty{display:none}.footer-bottom{display:flex;justify-content:space-between;align-items:center;width:100%}.landing-footer p{margin:0;font-size:.9rem;color:var(--muted)}.footer-links{display:flex;gap:1.5rem}.footer-links a{color:var(--primary);text-decoration:none;font-size:.9rem;transition:color .2s}.footer-links a:hover{text-decoration:underline}@media(max-width:640px){.hero h2{font-size:1.8rem}.hero p{font-size:1rem}.steps{grid-template-columns:1fr;gap:1.5rem}.why-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center;gap:.5rem}}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.65rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--fg);font-size:.95rem;font-weight:500;cursor:pointer;transition:background .15s}.oauth-btn:hover{background:var(--surface)}.oauth-btn:disabled{opacity:.7;cursor:not-allowed}.oauth-btn__icon{display:flex;align-items:center}.auth-page{max-width:360px;margin:0 auto;padding:2rem 1rem;min-height:100vh;display:flex;flex-direction:column;justify-content:center}.auth-page h1{font-size:1.75rem;margin:0 0 .25rem;text-align:center}.auth-tagline{color:var(--muted);text-align:center;margin:0 0 1.5rem;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-form input{padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;background:var(--bg);color:var(--fg)}.auth-form input:focus{outline:none;border-color:var(--primary)}.auth-form button{padding:.75rem 1rem;background:var(--primary);color:var(--primary-fg);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.25rem}.auth-form button:disabled{opacity:.7;cursor:not-allowed}.auth-error{color:var(--error);font-size:.9rem;margin:0 0 .25rem}.auth-switch{text-align:center;margin-top:1.5rem;font-size:.95rem;color:var(--muted)}.auth-switch a{color:var(--primary);text-decoration:none}.auth-switch a:hover{text-decoration:underline}.auth-oauth-buttons{display:flex;flex-direction:column;gap:.5rem}.auth-google{display:flex;justify-content:center}.auth-divider{display:flex;align-items:center;gap:1rem;margin:.75rem 0;color:var(--muted);font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.dev-login-panel{border:2px dashed var(--border);border-radius:10px;padding:.75rem;background:color-mix(in srgb,var(--primary) 5%,transparent)}.dev-login-header{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.5rem;text-align:center}.dev-login-users{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.dev-login-user{display:flex;align-items:center;gap:.5rem;padding:.5rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--fg);cursor:pointer;text-align:left;transition:border-color .15s}.dev-login-user:hover{border-color:var(--primary)}.dev-login-user:disabled{opacity:.6;cursor:not-allowed}.dev-login-avatar{width:2rem;height:2rem;border-radius:50%;background:var(--primary);color:var(--primary-fg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.dev-login-info{display:flex;flex-direction:column;min-width:0}.dev-login-info strong{font-size:.85rem;line-height:1.2}.dev-login-info small{font-size:.65rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-donate{display:block;text-align:center;margin-top:3rem;font-size:.8rem;color:var(--muted);text-decoration:none;opacity:.6;transition:opacity .2s}.auth-donate:hover{opacity:1;color:var(--primary)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex-shrink:0;color:#fff;font-weight:600;line-height:1}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-initials{-webkit-user-select:none;user-select:none}.expense-sets-page{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg)}.app-header h1{font-size:1.25rem;margin:0}.header-user{display:flex;align-items:center;gap:.75rem}.user-name{font-size:.9rem;color:var(--muted);max-width:120px;overflow:hidden;text-overflow:ellipsis}.dev-link{display:flex;align-items:center;color:var(--muted);padding:.25rem;border-radius:4px;transition:color .2s,background .2s}.dev-link:hover{color:var(--fg);background:var(--border)}.user-name-link{font-size:.9rem;color:var(--fg);text-decoration:none;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:.25rem .5rem;border-radius:6px;transition:background .2s}.user-name-link:hover{background:var(--border)}.sets-main{flex:1;padding:1.25rem;max-width:480px;margin:0 auto;width:100%}.sets-actions{display:flex;gap:.75rem;margin-bottom:1.25rem}.btn-primary{padding:.75rem 1.25rem;background:var(--primary);color:var(--primary-fg);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}.btn-secondary{padding:.75rem 1.25rem;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:8px;font-size:1rem;cursor:pointer}.btn-text{background:none;border:none;color:var(--primary);font-size:.9rem;cursor:pointer;padding:.25rem 0}.sets-form{padding:1.25rem;margin-bottom:1.25rem}.sets-form h2{margin:0 0 1rem;font-size:1.1rem}.sets-form input,.sets-form select{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;margin-bottom:.75rem;box-sizing:border-box}.form-error{color:var(--error);font-size:.9rem;margin:0 0 .75rem}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem}.sets-list h2{font-size:1rem;margin:0 0 .75rem;color:var(--muted)}.sets-list ul{list-style:none;padding:0;margin:0}.sets-list li{margin-bottom:.5rem}.set-card{display:block;padding:1rem 1.25rem;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;text-decoration:none;color:inherit}.set-card:hover{border-color:var(--primary)}.set-name{display:block;font-weight:600}.set-balance{display:block;font-size:.85rem;margin-top:.25rem}.set-balance.positive{color:var(--positive)}.set-balance.negative{color:var(--error)}.set-balance.settled{color:var(--muted)}.set-card-bottom{display:flex;align-items:center;gap:.5rem;margin-top:.35rem}.avatar-stack{display:flex;align-items:center}.avatar-stack-item{margin-left:-6px;border-radius:50%;box-shadow:0 0 0 2px var(--card-bg);line-height:0}.avatar-stack-item:first-child{margin-left:0}.avatar-overflow{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--border);color:var(--muted);font-size:.65rem;font-weight:600}.set-meta{font-size:.85rem;color:var(--muted)}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:8px}.muted{color:var(--muted);font-size:.95rem}.detail-page{min-height:100vh;display:flex;flex-direction:column;max-width:560px;margin:0 auto;width:100%}.btn-primary{padding:.75rem 1.25rem;background:var(--primary);color:var(--primary-fg);border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 2px 8px #0000001f}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-text{background:none;border:none;color:var(--primary);font-size:.9rem;cursor:pointer;padding:.5rem .75rem;border-radius:6px;transition:all .2s;font-weight:500}.btn-text:hover{background:var(--bg);color:var(--primary)}.btn-text.small{padding:.4rem .6rem;font-size:.8rem}.detail-page .app-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:1rem 1.25rem}.back-link{color:var(--primary);text-decoration:none;font-size:.95rem}.detail-page .app-header h1{font-size:1.1rem;margin:0;overflow:hidden;text-overflow:ellipsis}.editable-name{cursor:pointer;border-radius:4px;padding:.1rem .25rem;margin:-.1rem -.25rem;transition:background .2s}.editable-name:hover{background:var(--bg)}.rename-input{font-size:1.1rem;font-weight:700;border:1px solid var(--primary);border-radius:4px;padding:.1rem .25rem;background:var(--card-bg);color:var(--fg);outline:none;width:100%;min-width:0;box-shadow:0 0 0 2px var(--primary, rgba(52, 120, 246, .1))}.detail-share{padding:.75rem 1.25rem;background:var(--card-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.share-label{font-size:.85rem;color:var(--muted)}.share-code{font-family:monospace;font-size:.95rem;padding:.2rem .5rem;background:var(--bg);border-radius:4px}.detail-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 1.25rem}.detail-tabs button{padding:.75rem 1rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:1rem;color:var(--muted);cursor:pointer}.detail-tabs button.active{color:var(--fg);border-bottom-color:var(--primary);font-weight:600}.detail-main{flex:1;padding:1.25rem;animation:fadeIn .15s ease-out}.detail-actions{margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.add-form,.edit-form{padding:1.25rem;margin-bottom:1.25rem}.add-form h2,.edit-form h2{margin:0 0 1rem;font-size:1.1rem}.add-form input[type=text],.add-form input[type=number],.add-form input[type=date],.add-form select,.edit-form input[type=text],.edit-form input[type=number],.edit-form input[type=date],.edit-form select{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;margin-bottom:.75rem;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.add-form input[type=text]:focus,.add-form input[type=number]:focus,.add-form input[type=date]:focus,.add-form select:focus,.edit-form input[type=text]:focus,.edit-form input[type=number]:focus,.edit-form input[type=date]:focus,.edit-form select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary, rgba(52, 120, 246, .1))}.form-row{display:flex;gap:.75rem}.form-row input{flex:1}.form-row select{width:5.5rem;min-width:5.5rem;flex-shrink:0}.add-form .form-row,.edit-form .form-row{gap:.75rem;margin-bottom:.75rem}.split-fieldset{border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;background:var(--bg);transition:border-color .2s}.split-fieldset:focus-within{border-color:var(--primary)}.split-fieldset legend{font-size:.9rem;color:var(--muted);padding:0 .25rem;font-weight:500}.checkbox-label{display:flex;align-items:center;gap:.5rem;margin:.5rem 0;cursor:pointer;font-size:.95rem;transition:color .2s}.checkbox-label:hover{color:var(--primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.split-share-label{flex-wrap:nowrap}.shares-input{width:3rem;max-width:3rem;min-width:2.5rem;flex:0 0 3rem;padding:.15rem .25rem;margin-left:auto;border:1px solid var(--border);border-radius:4px;font-size:.85rem;text-align:center;background:var(--bg);color:var(--text);-moz-appearance:textfield}.shares-input::-webkit-outer-spin-button,.shares-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.shares-input:focus{outline:none;border-color:var(--primary)}.split-shortcuts{display:flex;align-items:center;gap:.4rem;margin-bottom:.4rem;font-size:.85rem}.split-label-name{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.split-amount-preview{font-size:.78rem;color:var(--muted);line-height:1}.your-balance-card{padding:1.25rem;margin-bottom:1rem}.your-balance-amount{font-size:1.5rem;font-weight:700;margin:.25rem 0 .75rem}.your-balance-amount.positive{color:var(--positive)}.your-balance-amount.negative{color:var(--error)}.your-balance-settled{color:var(--muted);margin:.25rem 0 0}.your-balance-transfers{list-style:none;padding:0;margin:0;font-size:.9rem;display:flex;flex-direction:column;gap:.3rem}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.form-actions button{padding:.65rem 1.25rem;font-size:.95rem;font-weight:500;border-radius:6px;transition:all .2s}.expense-list{list-style:none;padding:0;margin:0}.expense-item{padding:1rem 1.25rem;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem}.exp-desc{display:block;font-weight:600}.exp-amount{display:block;font-size:1.1rem;color:var(--primary)}.exp-meta{font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:.35rem}.settlement-main .card{padding:1.25rem;margin-bottom:1rem}.settlement-main h2{margin:0 0 .75rem;font-size:1rem}.all-settled-card{text-align:center;padding:2.5rem 1.25rem!important}.all-settled-check{width:3.5rem;height:3.5rem;margin:0 auto 1rem;border-radius:50%;background:var(--positive);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700}.all-settled-card h2{text-align:center;margin:0 0 .25rem;font-size:1.25rem}.all-settled-card p{color:var(--muted);margin:0;font-size:.9rem}.group-summary{text-align:center}.group-summary-total{font-size:1.75rem;font-weight:700;color:var(--fg);margin:.5rem 0 .1rem}.group-summary-label{font-size:.85rem;color:var(--muted);margin-bottom:1rem}.group-summary-list{list-style:none;padding:0;margin:0;border-top:1px solid var(--border);text-align:left}.group-summary-list li{padding:.5rem 0;display:flex;justify-content:space-between;align-items:center}.group-summary-amount{font-weight:500;color:var(--fg)}.settlement-currency{font-size:.9rem;color:var(--muted);margin:0 0 1rem}.balance-list,.transfer-list{list-style:none;padding:0;margin:0}.balance-list li{padding:.5rem 0;display:flex;justify-content:space-between;align-items:center}.balance-list .positive{color:var(--positive)}.balance-list .negative{color:var(--error)}.transfer-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 0!important;border-bottom:1px solid var(--border)}.transfer-item:last-child{border-bottom:none;padding-bottom:0!important}.transfer-item:first-child{padding-top:.5rem!important}.transfer-people{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.5rem;width:100%}.transfer-person{display:flex;align-items:center;gap:.4rem;min-width:0}.transfer-person:last-child{justify-content:flex-end}.transfer-person strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transfer-arrow{color:var(--muted);font-size:1rem;flex-shrink:0}.transfer-amounts{display:flex;flex-direction:column;align-items:center;gap:.1rem}.transfer-amount{font-size:1.05rem}.transfer-amount-converted{font-size:.8rem;color:var(--muted);font-weight:400}.btn-record{background:none;border:1px solid var(--primary);color:var(--primary);font-size:.85rem;font-weight:500;cursor:pointer;padding:.35rem 1.25rem;border-radius:6px;transition:all .2s}.btn-record:hover{background:var(--primary);color:var(--primary-fg)}.inline-record-form{width:100%;animation:slideDown .2s ease-out}.inline-record-form input[type=number],.inline-record-form input[type=date],.inline-record-form input[type=text],.inline-record-form select{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;margin-bottom:.5rem;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.inline-record-form input:focus,.inline-record-form select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary, rgba(52, 120, 246, .1))}.inline-record-form .form-row{margin-bottom:.5rem}.inline-record-form .form-row select{width:auto;min-width:80px;margin-bottom:0}.inline-record-form .form-row input{margin-bottom:0}.inline-record-form .form-actions{margin-top:.75rem;padding-top:.5rem}.transfer-other-link{display:block;text-align:center;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);width:100%;font-size:.85rem}.balance-name{display:inline-flex;align-items:center;gap:.35rem}.small{font-size:.8rem}.show-older{display:block;margin:1rem auto 0;font-size:.9rem}.people-card{padding:1.25rem;margin-bottom:1rem}.people-card h2{margin:0 0 .75rem;font-size:1rem}.share-instruction{font-size:.9rem;color:var(--muted);margin:0 0 .75rem}.share-link-section{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.75rem;background:var(--bg);border-radius:6px}.members-list{list-style:none;padding:0;margin:0}.member-item{padding:.75rem 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem}.member-item:last-child{border-bottom:none}.member-info{display:flex;flex-direction:column;gap:.25rem}.member-name{font-weight:500;font-size:1rem}.member-joined{font-size:.85rem;color:var(--muted)}.expense-header{display:flex;justify-content:space-between;align-items:center}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.1rem;padding:.5rem;opacity:.6;border-radius:6px;transition:all .2s}.btn-icon:hover{opacity:1;background:var(--border)}.edit-form{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;box-shadow:0 1px 3px #0000000d;animation:slideDown .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.expense-item--new{animation:slideDown .25s ease-out}.add-form{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;box-shadow:0 1px 3px #0000000d}.exp-conversion{display:block;font-size:.85rem;color:var(--muted);font-weight:400}.exp-rate-warning{color:var(--error);font-size:.9rem;cursor:help}.member-item-wrapper{border-bottom:1px solid var(--border)}.member-item-wrapper:last-child{border-bottom:none}.member-expense-count{font-size:.8rem;color:var(--muted)}.expense-count-link{font-size:.8rem;padding:0}.bulk-add-form{padding:.75rem 0 .75rem 3rem;border-top:1px dashed var(--border)}.bulk-add-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.bulk-date-input{margin-left:1.5rem;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.9rem;width:auto}.bulk-date-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary, rgba(52, 120, 246, .1))}.form-label{font-size:.9rem;color:var(--muted);font-weight:500;margin-bottom:.25rem;display:block}.settlement-record-list{list-style:none;padding:0;margin:0}.settlement-record-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 0;border-bottom:1px solid var(--border)}.settlement-record-item:last-child{border-bottom:none}.settlement-edit-btn{position:absolute;top:.75rem;right:0}.settlement-record-details{display:flex;flex-direction:column;align-items:center;gap:.1rem}.settlement-record-amount{font-size:1.05rem;color:var(--primary);font-weight:600}.settlement-record-meta{font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:.35rem}.btn-text-inline{background:none;border:none;color:var(--muted);font:inherit;font-size:.85rem;cursor:pointer;padding:0;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px}.btn-text-inline:hover{color:var(--primary)}.history-section{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed var(--border);animation:slideDown .2s ease-out}.history-loading{font-size:.85rem;padding:.5rem 0}.history-list{list-style:none;padding:0;margin:0}.history-entry{display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.85rem;align-items:start}.history-entry:last-child{border-bottom:none}.history-version{background:var(--bg);color:var(--muted);padding:.15rem .4rem;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.history-details{line-height:1.4;display:flex;flex-direction:column;gap:.1rem}.history-member-changes{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.15rem}.history-member-changes li{font-size:.85rem}.history-member-name{font-weight:500}.diff-added{color:var(--positive)}.diff-removed{color:var(--error)}.diff-shares{color:var(--primary)}.history-totals{font-size:.78rem}.history-meta{color:var(--muted);font-size:.8rem}.history-audit{text-align:right;color:var(--muted);font-size:.8rem;white-space:nowrap}.member-left{opacity:.6}.member-left-badge{display:inline-block;font-size:.7rem;font-weight:600;color:var(--muted);background:var(--bg);padding:.1rem .4rem;border-radius:4px;margin-left:.5rem;vertical-align:middle;text-transform:uppercase;letter-spacing:.03em}.leave-section{text-align:center}.leave-confirm-text{font-size:.9rem;color:var(--muted);margin:0 0 .5rem;line-height:1.5}.btn-leave{color:var(--error)}.btn-leave:hover{color:var(--error);background:var(--bg)}.btn-danger{padding:.65rem 1.25rem;background:var(--error);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-danger:hover:not(:disabled){filter:brightness(1.1)}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.show-deleted-toggle{text-align:right;margin-bottom:.5rem}.expense-item.deleted,.settlement-record-item.deleted{opacity:.5;background:var(--bg)}.exp-desc.deleted{text-decoration:line-through}.deleted-label{display:block;font-size:.8rem;color:var(--error);font-style:italic}.expense-actions{display:flex;align-items:center;gap:0}.btn-icon-delete{font-size:1rem}.settlement-records-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.settlement-records-header h2{margin:0}.settlement-action-btns{position:absolute;top:.75rem;right:0;display:flex;gap:0}.split-mode-toggle{display:flex;gap:1rem;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.split-mode-radio{font-size:.85rem;display:flex;align-items:center;gap:.35rem;cursor:pointer}.attendance-split-preview{padding:.25rem 0}.attendance-preview-list{list-style:none;padding:0;margin:.5rem 0 0}.attendance-preview-list li{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.9rem}.attendance-preview-list li .muted{margin-left:auto;font-size:.8rem}.attendance-preview-list li .split-amount-preview{min-width:4rem;text-align:right}.attendance-grid-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -.25rem}.attendance-grid{border-collapse:collapse;font-size:.8rem;min-width:100%}.attendance-grid th,.attendance-grid td{padding:.5rem .6rem;text-align:center;white-space:nowrap}.attendance-grid th{font-weight:600;font-size:.7rem;color:var(--muted);border-bottom:1px solid var(--border)}.attendance-name{text-align:left!important;font-weight:500;max-width:7rem;overflow:hidden;text-overflow:ellipsis}.attendance-row-shortcuts{display:flex;gap:.2rem;align-items:center;font-size:.7rem;font-weight:400;margin-top:.1rem}.attendance-cell{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:1.25rem;line-height:1;min-width:2.2rem;min-height:2.2rem;border-radius:4px;transition:background .1s}.attendance-cell:hover{background:var(--border)}.attendance-cell.present{color:var(--primary)}.attendance-cell.absent{color:var(--muted);opacity:.4}.attendance-name-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;gap:.25rem;font-weight:500;font-size:inherit;color:inherit;text-align:left;width:100%}.attendance-name-btn:hover .attendance-name-text{color:var(--primary)}.attendance-name-chevron{font-size:.5rem;color:var(--muted);flex-shrink:0}.attendance-name-btn.expanded .attendance-name-chevron{color:var(--primary)}.attendance-cell-content{display:inline-block;position:relative;line-height:1}.attendance-cell-badge{font-size:.6rem;font-weight:700;color:var(--primary);vertical-align:super;line-height:1;margin-left:1px}.attendance-detail-card{background:var(--bg);border-left:3px solid var(--primary);padding:.75rem 1rem}.attendance-detail-standalone{margin-top:.5rem;border-top:2px solid var(--primary)}.attendance-detail-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.6rem;flex-wrap:wrap}.attendance-detail-title{font-weight:600;font-size:.85rem}.attendance-detail-bulk{display:flex;align-items:center;gap:.35rem;font-size:.75rem;margin-left:auto}.attendance-bulk-btn{font-size:.75rem!important;padding:.1rem .35rem!important;border:1px solid var(--border)!important;border-radius:4px!important;background:var(--card-bg)!important;min-width:1.5rem;text-align:center}.attendance-bulk-btn:hover{border-color:var(--primary)!important;color:var(--primary)!important}.attendance-detail-days{display:flex;flex-direction:column;gap:.3rem}.attendance-day-row{display:flex;align-items:center;gap:.6rem;padding:.3rem 0;border-bottom:1px solid var(--border);font-size:.82rem}.attendance-day-row:last-child{border-bottom:none}.attendance-day-label{min-width:5.5rem;font-variant-numeric:tabular-nums;color:var(--muted)}.attendance-day-row.is-present .attendance-day-label{color:var(--fg);font-weight:500}.attendance-day-toggle{border:1px solid var(--border);border-radius:999px;padding:.2rem .6rem;font-size:.75rem;cursor:pointer;background:none;color:var(--muted);transition:all .1s;white-space:nowrap}.attendance-day-toggle.is-present{border-color:var(--primary);color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,transparent)}.attendance-day-toggle:hover{border-color:var(--primary);color:var(--primary)}.attendance-day-shares{display:flex;align-items:center;gap:.3rem;margin-left:auto}.shares-stepper-btn{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;width:1.6rem;height:1.6rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;line-height:1;color:var(--fg);padding:0;transition:border-color .1s}.shares-stepper-btn:hover{border-color:var(--primary);color:var(--primary)}.shares-stepper-value{min-width:1.25rem;text-align:center;font-weight:600;font-variant-numeric:tabular-nums}.shares-stepper-label{color:var(--muted);font-size:.75rem;min-width:2.5rem}.attendance-setup-hint{font-size:.85rem;margin:.25rem 0 .5rem}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{background:linear-gradient(90deg,var(--border) 25%,var(--card-bg) 50%,var(--border) 75%);background-size:1200px 100%;animation:shimmer 1.4s infinite linear;border-radius:4px;display:inline-block}.btn-text.copied{color:var(--positive)}.join-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.25rem;max-width:360px;margin:0 auto}.join-page h1{margin:0 0 1rem;font-size:1.5rem}.join-prompt{margin:0 0 1rem;color:var(--muted);text-align:center}.join-page .btn-primary{margin-bottom:.75rem}.join-page .btn-text{font-size:.95rem}.join-page a{text-decoration:none}.privacy-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.privacy-header{background:var(--card-bg);border-bottom:1px solid var(--border);padding:1.5rem 0}.privacy-header .privacy-container{display:flex;align-items:center;gap:1rem}.privacy-header h1{margin:0;font-size:1.5rem;color:var(--fg)}.back-link{color:var(--primary);text-decoration:none;font-size:.95rem;font-weight:500}.back-link:hover{text-decoration:underline}.privacy-container{max-width:800px;margin:0 auto;padding:0 1.25rem;width:100%}.privacy-main{flex:1;padding:2rem 0}.privacy-content{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:2rem}.privacy-content section{margin-bottom:2.5rem}.privacy-content section:last-child{margin-bottom:0}.privacy-content h2{font-size:1.3rem;margin:0 0 1rem;color:var(--fg)}.privacy-content p{margin:0 0 1rem;line-height:1.7;color:var(--fg)}.privacy-content p:last-child{margin-bottom:0}.privacy-content ul{margin:0 0 1rem;padding-left:1.5rem;color:var(--fg)}.privacy-content li{margin-bottom:.5rem;line-height:1.7}.privacy-content li:last-child{margin-bottom:0}.privacy-content strong{color:var(--primary)}.last-updated{font-size:.9rem;color:var(--muted);font-style:italic;margin:0 0 2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.privacy-footer{background:var(--card-bg);border-top:1px solid var(--border);padding:1.5rem 0;text-align:center}.privacy-footer a{color:var(--primary);text-decoration:none;font-size:.95rem}.privacy-footer a:hover{text-decoration:underline}@media(max-width:640px){.privacy-content{padding:1.5rem}.privacy-content h2{font-size:1.1rem}.privacy-header h1{font-size:1.2rem}}.profile-page{min-height:100vh;display:flex;flex-direction:column;max-width:480px;margin:0 auto;width:100%}.profile-page .app-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.profile-page .app-header h1{font-size:1.1rem;margin:0}.profile-main{flex:1;padding:1.25rem}.profile-card{padding:1.25rem}.profile-field{margin-bottom:1.25rem}.profile-field:last-of-type{margin-bottom:0}.profile-label{display:block;font-size:.85rem;font-weight:600;color:var(--muted);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.03em}.profile-value{margin:0;font-size:1rem}.profile-hint{font-size:.85rem;color:var(--muted);margin:.15rem 0 .5rem}.profile-select{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;box-sizing:border-box;background:var(--bg);color:var(--fg)}.profile-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.dev-page{min-height:100vh;display:flex;flex-direction:column}.dev-page .app-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.dev-page .app-header h1{font-size:1.1rem;margin:0}.dev-main{flex:1;padding:1.25rem;max-width:640px;margin:0 auto;width:100%}.stat-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.stat-card{padding:1rem 1.25rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-value{font-size:1.75rem;font-weight:700}.stat-label{font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.dev-section{padding:1.25rem;margin-bottom:1rem}.dev-section h2{margin:0 0 .75rem;font-size:1rem;color:var(--muted)}.activity-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border)}.activity-row:last-child{border-bottom:none}.activity-label{font-size:.9rem}.activity-value{font-size:.9rem;font-weight:600}.dev-table-wrap{overflow-x:auto}.dev-table{width:100%;border-collapse:collapse;font-size:.85rem}.dev-table th,.dev-table td{text-align:left;padding:.5rem;border-bottom:1px solid var(--border)}.dev-table th{color:var(--muted);font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.03em}.dev-table tr:last-child td{border-bottom:none}.cell-truncate{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-nowrap{white-space:nowrap}.badge{display:inline-block;padding:.15rem .4rem;background:var(--border);border-radius:4px;font-size:.75rem;font-weight:600}.dev-section-hint{font-size:.85rem;color:var(--muted);margin:0 0 .75rem}.dev-main .dev-login-users{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.dev-main .dev-login-user{display:flex;align-items:center;gap:.5rem;padding:.5rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--fg);cursor:pointer;text-align:left;transition:border-color .15s}.dev-main .dev-login-user:hover{border-color:var(--primary)}.dev-main .dev-login-user:disabled{opacity:.6;cursor:not-allowed}.dev-main .dev-login-avatar{width:2rem;height:2rem;border-radius:50%;background:var(--primary);color:var(--primary-fg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.dev-main .dev-login-info{display:flex;flex-direction:column;min-width:0}.dev-main .dev-login-info strong{font-size:.85rem;line-height:1.2}.dev-main .dev-login-info small{font-size:.65rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
