*{box-sizing:border-box;margin:0;padding:0}:root{--space-3xs:clamp(.3125rem,.3125rem + 0vw,.3125rem);--space-2xs:clamp(.5625rem,.5369rem + .1136vw,.625rem);--space-xs:clamp(.875rem,.8494rem + .1136vw,.9375rem);--space-s:clamp(1.125rem,1.0739rem + .2273vw,1.25rem);--space-m:clamp(1.6875rem,1.6108rem + .3409vw,1.875rem);--space-l:clamp(2.25rem,2.1477rem + .4545vw,2.5rem);--space-xl:clamp(3.375rem,3.2216rem + .6818vw,3.75rem);--space-2xl:clamp(4.5rem,4.2955rem + .9091vw,5rem);--space-3xl:clamp(6.75rem,6.4432rem + 1.3636vw,7.5rem);--space-3xs-2xs:clamp(.3125rem,.1847rem + .5682vw,.625rem);--space-2xs-xs:clamp(.5625rem,.4091rem + .6818vw,.9375rem);--space-xs-s:clamp(.875rem,.7216rem + .6818vw,1.25rem);--space-s-m:clamp(1.125rem,.8182rem + 1.3636vw,1.875rem);--space-m-l:clamp(1.6875rem,1.3551rem + 1.4773vw,2.5rem);--space-l-xl:clamp(2.25rem,1.6364rem + 2.7273vw,3.75rem);--space-xl-2xl:clamp(3.375rem,2.7102rem + 2.9545vw,5rem);--space-2xl-3xl:clamp(4.5rem,3.2727rem + 5.4545vw,7.5rem);--space-s-l:clamp(1.125rem,.5625rem + 2.5vw,2.5rem);--space-inline-compact:var(--space-3xs-2xs);--space-inline-cozy:var(--space-2xs-xs);--space-inline-comfortable:var(--space-xs-s);--space-inline-roomy:var(--space-s-m);--space-inline-generous:var(--space-m-l);--space-stack-tight:var(--space-3xs-2xs);--space-stack-compact:var(--space-2xs-xs);--space-stack-cozy:var(--space-xs-s);--space-stack-spacious:var(--space-s-m);--space-stack-generous:var(--space-m-l);--surface-padding-sm:var(--space-2xs-xs);--surface-padding-md:var(--space-xs-s);--surface-padding-lg:var(--space-s-m);--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--text-primary:#e2e8f0;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--accent-primary:#667eea;--accent-secondary:#764ba2;--border-color:#334155;--error-color:#ff6b6b;--success-color:#10b981}html,body{color:var(--text-primary);background:var(--bg-primary);min-height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}:is(html,body) ::selection{background:var(--accent-primary);color:#fff}html.dark,body.dark{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}body{background-attachment:fixed}:root{--safe-top:env(safe-area-inset-top);--safe-right:env(safe-area-inset-right);--safe-bottom:env(safe-area-inset-bottom);--safe-left:env(safe-area-inset-left)}html,body{background-color:var(--bg-primary)}.navbar{padding-top:calc(.75rem + var(--safe-top))}.toast-container,.bottom-safe-area,.mobile-nav{padding-bottom:calc(1rem + var(--safe-bottom))}main{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:max(4rem,env(safe-area-inset-bottom))}footer{text-align:center;position:fixed;bottom:1rem;left:50%;translate:-50%}footer.card{width:max-content;max-width:90vw;margin:unset;background-color:#1e293b66;border-bottom-right-radius:0;border-bottom-left-radius:0;padding:.6rem 1.2rem .2rem;bottom:-1px}@media (max-width:519px){footer [role=separator]{display:block}}@media (min-width:520px){footer [role=separator]:after{content:" ";background-color:var(--border-color);border-radius:2rem;width:.2em;height:.75em;margin:0 .5em;display:inline-block}}@media (max-width:768px){main{overflow-x:hidden}}.container{max-width:1200px;padding:var(--surface-padding-sm);margin:0 auto}@media (min-width:769px){.container{padding:var(--surface-padding-lg)}}.card{background:var(--bg-secondary);padding:var(--surface-padding-md);border:1px solid var(--border-color);border-radius:12px;transition:all .2s;box-shadow:0 4px 16px #0000004d}@media (min-width:769px){.card{padding:var(--surface-padding-lg)}}.btn{padding-block:var(--space-stack-compact);padding-inline:var(--space-inline-comfortable);cursor:pointer;touch-action:manipulation;border:none;border-radius:8px;justify-content:center;align-items:center;min-height:40px;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .1s ease-in-out;display:inline-flex}.btn:not(:disabled):hover{scale:1.02}.btn:active{scale:.98}.btn:disabled{filter:saturate(.8)brightness(.8);cursor:not-allowed}.btn-lg{padding-block:var(--space-stack-cozy);padding-inline:var(--space-inline-roomy);border-radius:12px;font-size:1rem}.btn-sm{padding-block:var(--space-stack-tight);padding-inline:var(--space-inline-comfortable);min-height:36px;font-size:.85rem}.btn-xs{padding-block:var(--space-3xs);padding-inline:var(--space-inline-compact);border-radius:4px;font-size:.7rem}.btn-icon{border-radius:999px;gap:0;width:2.5rem;min-width:0;height:2.5rem;min-height:0;padding:0;font-size:1.25rem;line-height:1}.btn-icon span,.btn-icon svg,.btn-icon iconify-icon{pointer-events:none}.btn-jumbo{width:100%;min-height:48px;padding-block:var(--space-stack-compact);padding-inline:var(--space-inline-comfortable);font-size:1rem;font-weight:600}.btn-primary,.btn-auth{background:linear-gradient(165deg,var(--accent-primary)30%,var(--accent-secondary)80%);color:#fff;background-size:150% 150%}:is(.btn-primary,.btn-auth):not(:disabled):hover{background-position:50% 75%;transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}:is(.btn-primary,.btn-auth):disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:not(:disabled):hover{background:var(--bg-secondary);border-color:var(--accent-primary);transform:none}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);border:1px solid #dc2626;transition:all .3s}.btn-danger:not(:disabled):hover{background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%);border-color:#b91c1c;box-shadow:0 4px 12px #ef444466}.btn-warning{color:#fff;background:linear-gradient(135deg,#efad44 0%,#dc9c26 100%);border:1px solid #dc9326;transition:all .3s}.btn-warning:not(:disabled):hover{background:linear-gradient(135deg,#dc7e26 0%,#b9851c 100%);border-color:#b98c1c;box-shadow:0 4px 12px #efb64466}.btn-success{background:var(--success-color);color:#fff}.btn-success:not(:disabled):hover{background:#0f9667}.btn.small{padding-block:var(--space-stack-tight);padding-inline:var(--space-inline-comfortable);min-height:32px;font-size:.8rem}.btn-text{padding:unset;background:unset;border:unset;cursor:pointer;min-height:unset;display:inline}.form-group+.form-group{margin-block-start:var(--space-stack-spacious)}.form-label,.form-group label{color:#6e6e6e;font-weight:600;display:block}.form-input,.form-group input,.form-group textarea,.form-group select{width:100%;padding-block:var(--space-stack-compact);padding-inline:var(--space-inline-comfortable);background:#2a415ee6;border:1px solid #e2e8f0;border-radius:12px;min-height:44px;font-size:1rem;transition:all .3s}.form-input:focus,.form-group :is(textarea,select,input:not([type=checkbox],[type=radio])):focus{border-color:#667eea;outline:none;transition:all .2s;box-shadow:0 0 0 2px #667eea}.form-group+.btn{margin-block-start:var(--space-stack-tight)}.input-group{display:flex}[dir=ltr] .input-group :is(.form-input,input,select):not(:first-child){border-left:unset;border-top-left-radius:0;border-bottom-left-radius:0}[dir=ltr] .input-group :is(.form-input,input,select):not(:last-child){border-right-color:#e2e8f066;border-top-right-radius:0;border-bottom-right-radius:0}[dir=rtl] .input-group :is(.form-input,input,select):not(:first-child){border-right:unset;border-top-right-radius:0;border-bottom-right-radius:0}[dir=rtl] .input-group :is(.form-input,input,select):not(:last-child){border-left-color:#e2e8f066;border-top-left-radius:0;border-bottom-left-radius:0}label.btn-secondary:has(input:checked){background:var(--bg-secondary);border-color:var(--accent-primary)}.code-input-container{gap:var(--space-inline-cozy);margin:var(--space-stack-tight)auto 0;justify-content:center;width:min(100%,24rem);display:flex}.form-group .code-input-field{text-align:center;text-transform:uppercase;border:2px solid var(--border-color,#334155);background:var(--bg-tertiary,#1f2937);min-width:52px;max-width:72px;height:3.25rem;color:var(--text-primary,#e2e8f0);-webkit-text-fill-color:var(--text-primary,#e2e8f0);letter-spacing:.08em;caret-color:var(--accent-primary,#667eea);border-radius:10px;outline:none;flex:52px;padding:.25rem 0;font-size:clamp(1.1rem,5vw,1.35rem);font-weight:600;line-height:1.25;transition:border-color .2s,box-shadow .2s}.code-input-field:focus{border-color:var(--accent-primary,#667eea);box-shadow:0 0 0 2px #667eea59}.code-input-field:disabled{cursor:not-allowed;opacity:.55;background:#1f2937bf}@media (max-width:520px){.code-input-container{gap:var(--space-inline-compact);width:min(100%,20rem)}.form-group .code-input-field{letter-spacing:.06em;min-width:46px;height:2.8rem;padding:calc(var(--space-3xs)*.64)0;flex:46px;font-size:clamp(1rem,8vw,1.2rem)}}.validation-message{margin-top:var(--space-stack-compact);padding-block:var(--space-stack-compact);padding-inline:var(--space-inline-cozy);text-align:center;border-radius:8px;font-size:.95rem;font-weight:500;transition:all .3s;animation:.3s ease-in fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.validation-validating{color:#1976d2;background-color:#e3f2fd;border:1px solid #bbdefb}.validation-validating .validation-spinner{animation:1.5s ease-in-out infinite pulse;display:inline-block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.validation-valid{color:#2e7d32;background-color:#e8f5e8;border:1px solid #c8e6c9;box-shadow:0 2px 4px #2e7d321a}.validation-expired{color:#f57c00;background-color:#fff3e0;border:1px solid #ffcc02;box-shadow:0 2px 4px #f57c001a}.validation-invalid{color:#d32f2f;background-color:#ffebee;border:1px solid #ffcdd2;box-shadow:0 2px 4px #d32f2f1a}.validation-text-small{margin-bottom:var(--space-stack-tight);font-size:12px;font-weight:500}.validation-text-valid{color:#2e7d32}.validation-text-invalid,.validation-text-expired{color:#d32f2f}.validation-text-validating{color:#666}.btn.checker{gap:var(--space-inline-compact);margin:unset;color:unset;min-height:20x;justify-content:flex-start;display:flex}.btn.checker input{align-self:center;width:1em;height:1em}.btn.checker iconify-icon{opacity:.15;font-size:5rem;transition:all .2s;inset-block-end:-.15em;inset-inline-end:-.1em}.btn.checker:has(input:checked) iconify-icon{opacity:.4}.input-group .input-auto{width:auto}.form-textarea{resize:vertical;min-height:100px}.form-group .hint{margin-top:var(--space-3xs);color:var(--text-muted);font-size:.875rem;display:block}.form-group .hint strong{color:var(--text-primary)}.form-group .split-info{margin-top:var(--space-stack-tight);padding:var(--space-inline-compact);color:var(--accent-primary);border-left:3px solid var(--accent-primary);background:#667eea1a;border-radius:8px;font-size:.875rem;display:block}.member-count{color:var(--text-muted);background:#667eea26;border-radius:12px;margin-left:.5rem;padding:.25rem .5rem;font-size:.75rem}.group-balance-summary{text-align:center;padding:1rem}.group-balance-summary .balance-amount{flex-direction:column;align-items:center;display:flex}.group-balance-summary .amount{margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.group-balance-summary .amount.debt{color:var(--error-color)}.group-balance-summary .amount.credit{color:var(--success-color)}.group-balance-summary .balance-description{color:var(--text-muted);font-size:.875rem}.group-balance-summary .member-preview{color:var(--text-secondary);font-size:.875rem}.group-balance-summary .member-name{font-weight:500}.group-balance-summary .more-members{color:var(--text-muted);font-style:italic}.group-details-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;margin:1.5rem 0;padding:1.5rem}.group-details-card .group-header{border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:.75rem}.group-details-card .group-header h3{color:var(--text-primary);margin:0}.members-list{flex-direction:column;gap:.75rem;margin-bottom:1.5rem;display:flex}.member-item{background:var(--bg-tertiary);border-radius:12px;justify-content:space-between;align-items:center;padding:.75rem;transition:all .2s;display:flex}.member-item:hover{transform:translateY(-1px)}.member-info{align-items:center;gap:.75rem;display:flex}.member-avatar{object-fit:cover;border-radius:50%;width:40px;height:40px}.member-avatar-placeholder{background:var(--accent-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.125rem;font-weight:700;display:flex}.member-name{color:var(--text-primary);font-weight:500}.you-badge{color:var(--accent-primary);font-size:.75rem;font-weight:600}.bank-available-badge{opacity:.8;margin-left:.25rem;font-size:.75rem}.settlement-note{border-left:3px solid var(--accent-primary);background:#3b82f61a;border-radius:6px;margin-top:.5rem;padding:.75rem;font-size:.9rem}.group-details-card .group-balance-summary{text-align:center;border-top:1px solid var(--border-color);padding-top:1rem}.balance-display{flex-direction:column;align-items:center;gap:.5rem;display:flex}.balance-amount{font-size:2rem;font-weight:700}.balance-amount.debt{color:var(--error-color)}.balance-amount.credit{color:var(--success-color)}.balance-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.favorite-star{cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;color:#94a3b8;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:8px;right:8px}.favorite-star:hover{color:#fbbf24;background:#000c;transform:scale(1.1)}.favorite-star:disabled{opacity:.6;cursor:not-allowed}.favorite-star.favorited{color:#fbbf24;background:#fbbf2433;border:1px solid #fbbf2466}.favorite-star.favorited:hover{color:#f59e0b;background:#fbbf244d}.star-icon{justify-content:center;align-items:center;display:flex}.star-svg{filter:drop-shadow(0 1px 2px #0000004d);transition:all .3s cubic-bezier(.4,0,.2,1)}.star-svg.outline{color:#94a3b8}.star-svg.filled{color:#fbbf24;animation:.4s cubic-bezier(.68,-.55,.265,1.55) starFill}.favorite-star:hover .star-svg.outline{color:#fbbf24;transform:scale(1.1)}.favorite-star:hover .star-svg.filled{color:#f59e0b;transform:scale(1.1)}.star-path{stroke-linejoin:round;stroke-linecap:round}@keyframes starFill{0%{opacity:.8;transform:scale(.8)rotate(-10deg)}50%{opacity:1;transform:scale(1.2)rotate(5deg)}to{opacity:1;transform:scale(1)rotate(0)}}.delete-group-button{cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;color:#ef4444;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:8px;right:48px}.delete-group-button:hover{color:#dc2626;background:#ef444433;transform:scale(1.1)}.delete-group-button:disabled{opacity:.6;cursor:not-allowed}.trash-icon{justify-content:center;align-items:center;display:flex}.trash-svg{filter:drop-shadow(0 1px 2px #0000004d);transition:all .2s}.delete-group-button:hover .trash-svg{transform:scale(1.1)}.shared-balance.card{position:relative}.user-dropdown{width:100%;position:relative}.user-dropdown-trigger{cursor:pointer;background:#2a415ee6;border:1px solid #e2e8f0;border-radius:12px;justify-content:space-between;align-items:center;width:100%;min-height:44px;padding:.875rem 1rem;transition:all .3s;display:flex}.user-dropdown-clear{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;width:24px;height:24px;margin-left:auto;margin-right:.5rem;padding:.25rem;font-size:1.25rem;transition:all .2s;display:flex}.user-dropdown-clear:hover{background:var(--bg-tertiary);color:var(--text-primary)}.user-dropdown-clear:focus{outline:2px solid var(--accent-primary);outline-offset:1px}.user-dropdown-trigger:hover{border-color:#667eea}.navbar[aria-expanded=true] .user-dropdown-trigger{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.user-dropdown-selected{flex:1;align-items:center;gap:.75rem;display:flex}.user-dropdown-text{color:var(--text-primary);font-size:1rem}.user-dropdown-placeholder{color:var(--text-muted);font-size:1rem}.user-dropdown-arrow{color:var(--text-muted);margin-left:.5rem;font-size:.75rem;transition:transform .2s}.user-dropdown-arrow.up{transform:rotate(180deg)}.user-dropdown-menu{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#2a415ef2;border:1px solid #e2e8f0;border-radius:12px;margin-top:.25rem;position:absolute;top:100%;left:0;right:0;box-shadow:0 4px 12px #00000026}.user-dropdown-option{cursor:pointer;border-bottom:1px solid #e2e8f01a;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:background-color .2s;display:flex}.user-dropdown-option:last-child{border-bottom:none}.user-dropdown-option:hover{background-color:#667eea1a}.user-dropdown-option.selected{background-color:#667eea33}.user-dropdown-option.focused{outline-offset:-2px;background-color:#667eea26;outline:2px solid #667eea80}.user-dropdown-option:first-child{border-top-left-radius:12px;border-top-right-radius:12px}.user-dropdown-option:last-child{border-bottom-right-radius:12px;border-bottom-left-radius:12px}@media (max-width:768px){.user-dropdown-selected{gap:.5rem}.user-dropdown-text{font-size:.9rem}.user-dropdown-option{gap:.5rem;padding:.875rem .75rem}.user-dropdown-menu{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}.navbar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding-block:var(--space-stack-compact);padding-inline:var(--space-inline-comfortable);z-index:1000;position:sticky;top:0;box-shadow:0 1px 3px #0000004d}.navbar .container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0;display:flex;position:relative}.navbar-brand{text-align:left;flex:1}.navbar-brand a{color:var(--accent-primary);font-size:1.7rem;font-weight:700;text-decoration:none}.mobile-menu-button{cursor:pointer;color:#667eea;padding:var(--space-inline-compact);background:0 0;border:none;border-radius:8px;font-size:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:none;position:relative;overflow:hidden}.mobile-menu-button:hover{background:#667eea1a;transform:scale(1.02)}.mobile-menu-button span{transition:transform .3s cubic-bezier(.4,0,.2,1);display:inline-block}.navbar-links{gap:var(--space-inline-roomy);align-items:center;margin:0;padding:0;list-style:none;display:flex}.navbar-links li a{color:#cbd5e1;padding-block:var(--space-stack-tight);padding-inline:var(--space-inline-comfortable);border-radius:8px;font-weight:500;text-decoration:none;transition:all .3s}.navbar-links li a:hover{color:#667eea;background:#667eea1a}.navbar-links li a.active{color:#fff;background:#667eea;font-weight:600}.navbar-user{align-items:center;gap:var(--space-inline-comfortable);display:flex}.user-profile-button{align-items:center;gap:var(--space-inline-compact);padding-block:var(--space-stack-tight);padding-inline:var(--space-inline-cozy);cursor:pointer;color:#cbd5e1;background:#33415580;border:1px solid #334155;border-radius:8px;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.user-profile-button:hover{background:#334155cc;border-color:#475569}.user-profile-button .username{color:#cbd5e1}.mobile-user-profile-button{align-items:center;gap:var(--space-inline-cozy);padding:var(--surface-padding-md);cursor:pointer;color:#cbd5e1;text-align:left;background:#33415580;border:1px solid #334155;border-radius:8px;width:100%;min-height:56px;font-size:1rem;font-weight:500;transition:all .3s;display:flex;position:relative;top:1rem}.mobile-user-profile-button:hover{background:#334155cc;border-color:#475569;transform:translate(4px)}.mobile-user-profile-button:active{transform:translate(2px)}.logout-button{color:#fff;padding-block:var(--space-stack-tight);padding-inline:var(--space-inline-comfortable);cursor:pointer;background:linear-gradient(135deg,#ff6b6b 0%,#ee5a52 100%);border:none;border-radius:8px;font-weight:500;transition:all .3s}.logout-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff6b6b4d}.mobile-nav-header{padding:var(--surface-padding-md)var(--surface-padding-md)var(--space-inline-cozy)var(--surface-padding-md);background:#3341554d;border-bottom:1px solid #334155;justify-content:space-between;align-items:center;display:flex}.mobile-nav-header .title{font-size:1.1rem;font-weight:600}.mobile-user-info{padding:0 var(--surface-padding-md)var(--surface-padding-md)var(--surface-padding-md);margin-top:var(--space-stack-tight);color:#cbd5e1;border-top:1px solid #334155;font-weight:500}.mobile-menu-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0006;transition:all .3s cubic-bezier(.4,0,.2,1);position:fixed;inset:0}.navbar:not([aria-expanded=true]) .mobile-menu-backdrop{opacity:0;visibility:hidden;pointer-events:none}@media (max-width:768px){.navbar-content{--t-init-delay:.1s;--t-stagger:75ms;--t-duration:.4s;z-index:1001;background:#1e293b;border-bottom:1px solid #334155;border-bottom-right-radius:16px;border-bottom-left-radius:16px;max-height:60vh;transition:all .3s cubic-bezier(.4,0,.2,1),max-height .5s cubic-bezier(.4,0,.2,1) 50ms;display:block;position:absolute;top:100%;left:0;right:0;overflow:hidden;box-shadow:0 8px 25px #0006,0 4px 12px #0000004d,0 2px 6px #0003}.navbar:not([aria-expanded=true]) .navbar-content{opacity:0;pointer-events:none;visibility:hidden;max-height:0}.mobile-menu-button{display:block!important}.navbar[aria-expanded=true] .mobile-menu-button span{transform:rotate(180deg)}.navbar-links{padding:var(--surface-padding-md);gap:var(--space-inline-compact);flex-direction:column}.navbar-links li{width:100%}.navbar-links li:first-child{--i:1}.navbar-links li:nth-child(2){--i:2}.navbar-links li:nth-child(3){--i:3}.navbar-links li:nth-child(4){--i:4}.navbar-links li:nth-child(5){--i:5}.navbar-links li:nth-child(6){--i:6}.navbar-links li:nth-child(7){--i:7}.navbar-links li:nth-child(8){--i:8}.navbar-links li:nth-child(9){--i:9}.navbar-links li:nth-child(10){--i:10}.navbar-user{--i:calc(var(--links) + 1)}.navbar-links li,.navbar-user{transition:all var(--t-duration)cubic-bezier(.4,0,.2,1);transition-delay:calc(var(--t-init-delay) + var(--i,0)*var(--t-stagger))}.navbar:not([aria-expanded=true]) :is(.navbar-links li,.navbar-user){opacity:0;transform:translateY(-10px)}.navbar-links li a{width:100%;padding:var(--space-inline-comfortable);font-size:1rem;display:block}.navbar-user{margin:0 var(--surface-padding-md)var(--surface-padding-md);padding:var(--surface-padding-md);flex-wrap:wrap}.user-profile-button{padding:var(--surface-padding-md);flex:1}.logout-button{margin-inline-start:auto}.user-avater{--size:36px}}@media (min-width:769px){.navbar-content{align-items:center;gap:var(--space-inline-generous);display:flex}.mobile-menu-button,.mobile-nav-header{display:none}.user-profile-button .user-avatar{margin:calc(-1*var(--space-inline-cozy))0;border:inherit;margin-inline-start:calc(-1*var(--space-inline-comfortable))}.mobile-menu-backdrop{display:none}.expense-cell.actions{flex-direction:column}}.page-header{margin-bottom:var(--space-stack-cozy);padding-block:var(--space-stack-compact);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:var(--space-inline-cozy);flex-wrap:wrap;padding-inline:0;display:flex}.page-header h1{color:var(--text-primary);margin:0;font-size:1.4rem;font-weight:700}.page-header .entity-info{margin-inline-end:auto;line-height:1.1}.page-header .entity-info .subtitle{color:#666;font-size:.8em}.value-with-action{align-items:center;gap:.5em;display:flex}.value-with-action .btn-text{transition:opacity .2s}.value-with-action:not(:hover) .btn-text{opacity:.2}.balance-summary{background:var(--bg-secondary);padding:var(--surface-padding-md);margin-bottom:var(--space-stack-cozy);border:1px solid var(--border-color);border-radius:12px}.balance-summary h2{color:var(--text-primary);margin:0 0 var(--space-stack-tight)0;font-size:1rem;font-weight:600}.balance-amount{color:var(--accent-primary);font-size:1.1rem;font-weight:700}.debt-overview{justify-content:space-between;align-items:center;gap:var(--space-inline-comfortable);width:100%;display:flex}.user-section{flex-direction:column;flex-shrink:0;align-items:center;gap:.75rem;display:flex}.user-avatar{width:var(--size,45px);height:var(--size,45px);font-weight:700;font-size:calc(var(--size,40px)*.4);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;overflow:hidden;box-shadow:0 2px 5px #0000001a}.user-avatar.-initials{color:#fff;background-color:#3b82f6}.user-avatar-container{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:.5rem;transition:all .3s;display:flex}.user-avatar-container.in-debt{background:#ef444426;border:2px solid #ef444466;box-shadow:0 4px 12px #ef444433}.user-avatar-container.in-credit{background:#22c55e26;border:2px solid #22c55e66;box-shadow:0 4px 12px #22c55e33}.user-name{color:var(--text-primary);text-align:center;word-wrap:break-word;max-width:120px;font-size:1rem;font-weight:600}.user-section .user-avatar-container.in-credit+.user-name{color:#22c55e}.user-section .user-avatar-container.in-debt+.user-name{color:#ef4444}.debt-line-container{flex-direction:column;flex:1;align-items:stretch;gap:1rem;min-width:200px;display:flex}.debt-line-container:not(:has(.settled-indicator)){margin-block-start:2rem}.debt-line{background:var(--border-color);border-radius:8px;width:100%;height:12px;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a,0 0 20px #667eea4d,0 0 40px #667eea1a}.center-marker{background:var(--text-secondary);z-index:2;border-radius:3px;width:3px;height:18px;position:absolute;top:-3px;left:50%;transform:translate(-50%);box-shadow:0 2px 6px #0000004d}.settled-indicator{color:#fff;z-index:2;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;justify-content:center;place-self:center;align-items:center;width:28px;height:28px;font-size:1rem;font-weight:700;display:flex;box-shadow:0 4px 12px #22c55e66}.amount-display{color:var(--accent-primary);text-align:center;text-shadow:0 2px 4px #0000001a;align-items:center;font-size:.9rem;font-weight:500;display:flex}.amount-display .badge{background:linear-gradient(135deg,#667eea26,#764ba226);border:1px solid #667eea4d;border-radius:8px;padding:.5rem 1rem}.amount-display.debt{color:#ef4444;text-shadow:0 2px 4px #ef44444d}.amount-display.credit{color:#22c55e;text-shadow:0 2px 4px #22c55e4d}.amount-display .bar{background:#64748b1a;border:1px solid #64748b33;border-radius:8px;flex:1;height:1em;transition:all .8s cubic-bezier(.4,0,.2,1);display:flex}.amount-display .bar.credit{flex-direction:row-reverse}:is(.amount-display.debt .bar.debt,.amount-display.credit .bar.credit):before{content:" ";width:calc(var(--amount)/var(--max-amount)*100%);border-radius:inherit;height:100%;display:block}.amount-display .bar:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.amount-display .bar:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.amount-display .bar.credit:before{background:linear-gradient(90deg,#22c55e,#16a34a);box-shadow:0 0 8px #22c55ecc,0 0 16px #22c55e99,0 0 32px #22c55e66,0 0 48px #22c55e33,0 0 64px #22c55e1a,inset 0 1px 2px #ffffff4d}.amount-display .bar.debt:before{background:linear-gradient(90deg,#ef4444,#dc2626);box-shadow:0 0 8px #ef4444cc,0 0 16px #ef444499,0 0 32px #ef444466,0 0 48px #ef444433,0 0 64px #ef44441a,inset 0 1px 2px #ffffff4d}.amount-display.primary-amount{font-size:1.1rem;font-weight:600}.amount-display:not(.primary-amount){opacity:.8;margin:0 2rem}.amount-display:not(.primary-amount) .badge{background:#64748b1a;border:1px solid #64748b33;border-radius:6px;padding:.3rem .7rem}.split-preview{background:#22c55e1a;border:1px solid #22c55e33;border-radius:6px;margin-top:.5rem;padding:.75rem}.split-info{color:var(--text-secondary);font-size:.875rem;display:block}.split-options,.who-paid-section{flex-direction:column;display:flex}.who-paid-section{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-top:1rem;padding:1rem}.who-paid-section label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;display:block}.currency-options{border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:8px;flex-direction:column;gap:.75rem;max-height:400px;margin:1rem 0;padding:1rem;display:flex;overflow-y:auto}.currency-search-input{border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);border-radius:6px;padding:.75rem;font-size:.9rem}.currency-search-input:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 2px #667eea33}.currency-option{text-align:left;border:1px solid var(--border-color);background:var(--bg-tertiary);border-radius:8px;flex-direction:column;justify-content:center;gap:.5rem;min-height:80px;padding:1rem;transition:all .2s;display:flex}.currency-option:hover{background:var(--bg-secondary);border-color:var(--accent-primary);transform:translateY(-1px)}.currency-info{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.currency-code{color:var(--text-primary);min-width:50px;font-size:1.1rem;font-weight:600}.currency-amount{color:var(--accent-primary);text-align:right;flex:1;font-size:1.25rem;font-weight:700}.debt-breakdown{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-top:1.5rem;padding:1rem}.debt-breakdown h4{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.9rem;font-weight:600}.debt-list{flex-direction:column;gap:.5rem;display:flex}.debt-item{background:var(--bg-secondary);border-radius:6px;justify-content:space-between;align-items:center;padding:.5rem;font-size:.9rem;display:flex}.debt-currency{color:var(--accent-primary);font-weight:600}.debt-amount{color:var(--text-primary);font-weight:500}.loading-message{color:var(--text-secondary);justify-content:center;align-items:center;padding:2rem;font-style:italic;display:flex}.debt-indicator-wrapper{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;width:100%;padding:1rem;box-shadow:0 4px 12px #0000000d}.two-person-settle-section{justify-content:center;width:100%;margin-top:1.5rem;display:flex}.settle-actions{flex-direction:column;align-items:center;gap:.75rem;display:flex}.settle-btn-two-person{text-align:center;border-radius:10px;min-width:200px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.settle-btn-two-person:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea4d}@media (max-width:768px){.shared-balance.card{padding:1rem;overflow:hidden}.debt-overview{grid-template-columns:repeat(var(--user-count),minmax(80px,1fr));flex-direction:column;gap:.5rem;display:grid}.user-section{order:1;gap:.5rem;min-width:80px}.debt-line-container{grid-column:1/span var(--user-count);order:2;place-self:center;width:60vw}.user-name{font-size:.8rem}.debt-line{width:100%;height:10px}.center-marker{width:4px;height:14px;top:-2px}.group-balance-summary .amount{font-size:1.25rem}}.page-header .actions{align-items:center;gap:.75rem;margin-inline-start:auto;display:flex}@media (max-width:768px){.page-header .actions{flex-wrap:wrap;justify-content:center;gap:.5rem}.page-header .actions .btn{min-height:36px;padding:.5rem .85rem;font-size:.85rem}}.shared-balances-grid{gap:1.5rem;display:grid}.shared-balance.single-member{opacity:.8;border-color:#475569}.shared-balance.single-member:hover{opacity:1}.member-count.solo{color:#9ca3af;background:#9ca3af33;font-size:.7rem}.single-member-toggle{border-top:1px solid #334155;justify-content:center;margin-top:1.5rem;padding-top:1rem;display:flex}.single-member-toggle button{color:#94a3b8;background:0 0;border:1px solid #475569;font-size:.875rem;transition:all .2s;transform:scale(1)}.single-member-toggle button:hover{color:#e2e8f0;background:#64748b1a;border-color:#64748b;transform:scale(1.02)}.single-member-toggle button:active{transition:all .1s;transform:scale(.98)}a.shared-balance{-webkit-text-decoration:initial;text-decoration:initial}.shared-balance.card{cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:16px;flex-direction:column;gap:1rem;padding:1.5rem;transition:all .3s;display:flex;box-shadow:0 4px 16px #0000004d}.shared-balance.card .card-header{margin:0}.shared-balance.card .card-header h3{color:#e2e8f0;margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.shared-balance.card .other-user{color:#94a3b8;margin:0;font-size:.85rem}.shared-balance.card .balance-info{text-align:center;background:#334155;border-radius:12px;flex-direction:column;align-items:center;padding:1rem;display:flex}.shared-balance.card .balance-info.balance-owe{background:#ff6b6b1a;border:1px solid #ff6b6b33}.shared-balance.card .balance-info.balance-owed{background:#22c55e1a;border:1px solid #22c55e33}.shared-balance.card .balance-info.balance-even{background:#667eea1a;border:1px solid #667eea33}.shared-balance.card.balance-info .label{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem;font-size:.8rem}.shared-balance.card .balance-info .amount{font-size:1.25rem;font-weight:700}.balance-info.balance-owe .amount{color:#ff6b6b}.balance-info.balance-owed .amount{color:#22c55e}.balance-info.balance-even .amount{color:#667eea}.shared-balance.card .card-footer{justify-content:space-between;align-items:center;margin:0;display:flex}.shared-balance.card .card-footer small{color:#64748b;font-size:.75rem}@media (max-width:768px){.shared-balances-grid{gap:1rem}.shared-balance.card .card-footer{flex-direction:column;align-items:stretch;gap:.75rem}.shared-balance.card .card-footer small{text-align:center}}body:has(.modal-overlay:not([aria-hidden=true])){overflow:hidden}.modal-overlay{--transition-duration:.15s;--modal-inline-padding:var(--space-inline-generous);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;padding:var(--space-stack-generous);transition:opacity var(--transition-duration)ease-in-out;background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay[aria-hidden=true]{opacity:0;pointer-events:none;visibility:hidden}.modal{--space:var(--space-inline-generous);background:var(--bg-secondary);width:min(600px,calc(100vw - 2*var(--modal-inline-padding)));border:1px solid var(--border-color);max-width:100%;max-height:85vh;transition:all var(--transition-duration)ease-in-out;border-radius:16px;flex-direction:column;margin-inline:auto;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000080}.modal-handle{cursor:grab;background:#ffffff4d;border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:8px auto 4px;transition:background .2s;display:none;position:relative}.modal-handle:before{content:"";cursor:grab;width:100vw;height:40px;position:absolute;top:-16px;left:50%;transform:translate(-50%)}.modal-handle:active{cursor:grabbing;background:#ffffff80}@media (max-width:768px){.modal-handle{display:block}.modal-header{cursor:grab}.modal-header:active{cursor:grabbing}}.modal-overlay[aria-hidden=true] .modal{scale:.9;transform:translateY(var(--space-inline-generous))}@media (max-width:768px){.modal-overlay[aria-hidden=true] .modal{transform:translateY(100%)}.modal-overlay.-centered{align-items:center;padding:1rem}.modal-overlay.-centered .modal{border-radius:16px;max-height:min(85vh,600px)}.modal-overlay.-centered[aria-hidden=true] .modal{opacity:0;transform:translateY(20px)}}.modal-content{padding:calc(var(--space)/2)var(--space);-webkit-overflow-scrolling:touch;flex:auto;overflow:hidden auto}.modal-content:last-child{padding-block-end:var(--space)}.modal-header{padding:var(--space)var(--space)calc(var(--space)/2);justify-content:space-between;align-items:flex-start;gap:var(--space-inline-roomy);display:flex}.modal-header h2{color:var(--text-primary);flex:1;margin:0;font-size:1.5rem;font-weight:600}.modal.-confirm .modal-header{border-bottom:1px solid var(--border-color)}.modal .btn-close{color:#94a3b8;cursor:pointer;background:#334155cc;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;min-width:36px;height:36px;min-height:36px;margin:0;padding:0;font-size:1.5rem;line-height:1;transition:all .2s;display:flex}.modal .btn-close iconify-icon{font-size:1.25rem}.modal .btn-close:hover{color:#e2e8f0;background:#334155}.form-actions{gap:var(--space-inline-comfortable);margin-top:var(--space-inline-generous);display:flex}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-inline-comfortable);padding:calc(var(--space)/2)var(--space)var(--space);border-top:1px solid var(--border-color);flex-wrap:wrap;display:flex}.modal-footer .error-message{margin:0}.modal.-confirm .modal-footer{border-top:unset}.modal-footer .info-text{color:var(--text-secondary);margin-right:auto;font-size:.9rem}.export-format-group{gap:var(--space-inline-cozy);flex-direction:column;display:flex}.export-format-group .form-label{color:var(--text-secondary);font-weight:600}.export-options{gap:.75rem;display:grid}.export-option{cursor:pointer;background:#1e293b99;border:1px solid #94a3b833;border-radius:14px;align-items:flex-start;gap:.9rem;padding:.85rem 1rem;transition:transform .18s,border-color .18s,background .18s;display:flex;position:relative}.export-option:hover{border-color:#94a3b866;transform:translateY(-1px)}.export-option.is-selected{border-color:var(--accent-primary);background:linear-gradient(135deg,#667eea26,#764ba22e);box-shadow:0 12px 24px #667eea26}.export-option__check{border:2px solid #94a3b8b3;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;margin-top:.15rem;transition:border-color .18s,background .18s,box-shadow .18s;display:inline-flex}.export-option.is-selected .export-option__check{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));box-shadow:0 0 0 4px #667eea40}.export-option__copy{flex-direction:column;gap:.25rem;display:flex}.export-option__title{color:var(--text-primary);font-weight:600}.export-option__subtitle{color:var(--text-muted);font-size:.875rem}.export-note{color:var(--text-muted);margin-top:1.25rem;font-size:.85rem}.no-data{text-align:center;color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;min-height:50vh;padding:3rem 1rem;font-size:1.1rem;font-weight:500;display:flex}.no-data h3{color:#e2e8f0;margin-bottom:1rem;font-size:1.5rem}.no-data p{color:#94a3b8;margin:0 0 2rem}.empty-actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}@media (max-width:768px){.empty-actions{flex-direction:column;width:100%;max-width:300px}.dashboard-empty{min-height:50vh;padding:2rem 1rem}.dashboard-empty h3{font-size:1.5rem}}.dashboard-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;padding:3rem 1rem;display:flex}.dashboard-empty h3{color:#e2e8f0;margin-bottom:1rem;font-size:1.75rem;font-weight:700}.dashboard-empty p{color:#94a3b8;max-width:500px;margin-bottom:2.5rem;font-size:1.1rem;line-height:1.6}.invitations-list{margin-top:2rem}.tabs{border-bottom:1px solid var(--border-color);gap:.5rem;margin-bottom:2rem;display:flex}.tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:8px 8px 0 0;padding:.75rem 1.5rem;font-weight:500;transition:all .3s}.tab:hover{background:var(--bg-secondary);color:var(--text-primary)}.tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);background:var(--bg-secondary)}.invitations-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;margin-top:1rem;display:grid}.invitation-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:all .3s;position:relative;overflow:hidden}.invitation-card:hover{border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 8px 25px #00000026}.invitation-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.invitation-status{text-transform:uppercase;color:#fff;white-space:nowrap;border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.invitation-description{color:var(--text-primary);margin-bottom:1rem;font-size:1.1rem;font-weight:600;line-height:1.4}.invitation-details{background:var(--bg-tertiary);border-radius:8px;flex-direction:column;margin-bottom:1.5rem;padding:1rem;display:flex}.invitation-details .detail{justify-content:space-between;align-items:center;font-size:.9rem;display:flex}.invitation-details .label{color:var(--text-secondary);font-weight:500}.invitation-details .value{color:var(--text-primary);font-weight:600}.invitation-actions{flex-wrap:wrap;gap:.75rem;display:flex}.empty-state{text-align:center;color:var(--text-secondary);padding:3rem 1rem}.empty-state h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.5rem}.empty-state p{margin-bottom:2rem;font-size:1.1rem;line-height:1.6}@media (max-width:768px){.invitations-grid{grid-template-columns:1fr}.invitation-header{flex-direction:column;align-items:stretch;gap:.75rem}.invitation-actions{justify-content:stretch}.invitation-actions .btn{flex:1}}.invite-code-display{text-align:center;margin:2.5rem 0}.code-box{background:var(--bg-tertiary);border:1px solid var(--accent-primary);text-align:center;border-radius:8px;margin:1rem 0;padding:1rem 1.5rem}.code-text{color:var(--accent-primary);letter-spacing:.2em;-webkit-user-select:all;user-select:all;cursor:pointer;font-family:Courier New,Monaco,monospace;font-size:1.5rem;font-weight:700}.code-actions{justify-content:center;gap:1rem;margin-top:1.5rem;display:flex}.instructions h4{color:#667eea;margin-bottom:1rem;font-size:1.1rem;font-weight:600}.instructions li{padding:.5rem 0;margin-bottom:.5rem;padding-left:1.5rem;position:relative}.instructions li:before{content:"✓";color:#51cf66;font-weight:700;position:absolute;left:0}@media (max-width:768px){.code-text{letter-spacing:.15em;font-size:1.2rem}.code-box{margin:.75rem 0;padding:.875rem 1rem}.code-actions{flex-direction:column;gap:.75rem}.page-header h1{font-size:1.3rem}.form-actions{flex-direction:column;gap:.75rem}.card-footer{flex-direction:column;align-items:flex-start;gap:.75rem}.balance-info{background:#fffc;border-radius:12px;margin:1rem 0;padding:1rem}}@media (min-width:769px){.sm-only{display:none}}.auth-container{background:var(--bg-primary);justify-content:center;align-items:center;min-height:40vh;padding:1rem;display:flex}.auth-container .card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:380px;padding:1.5rem;animation:.6s ease-out slideInUp;box-shadow:0 8px 32px #0006}.auth-title{text-align:center;color:var(--text-primary);text-shadow:0 2px 4px #0000004d;margin-bottom:1.25rem;font-size:1.4rem;font-weight:700}.btn-auth{color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;width:100%;min-height:48px;padding:.875rem 1.25rem;font-size:1rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 16px #667eea4d}.oauth-divider{color:var(--text-muted);align-items:center;gap:.75rem;margin:1rem 0 .75rem;font-size:.9rem;font-weight:600;display:flex}.oauth-divider:before,.oauth-divider:after{content:"";background:var(--border-color);flex:1;height:1px}.oauth-buttons{flex-direction:column;gap:.75rem;display:flex}.btn-auth.oauth{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:0 2px 10px #00000026}.btn-auth.oauth:hover{box-shadow:0 6px 16px #00000040}.btn-auth.oauth.google{color:#1f2937;background:#fff;border-color:#0000001a}.btn-auth.oauth.google:hover{background:#f8fafc}.btn-auth.oauth.github{color:#fff;background:#111827;border-color:#ffffff14}.btn-auth.oauth.github:hover{background:#0b1220}.auth-footer{text-align:center;padding-top:1.5rem}.auth-footer p{color:var(--text-muted);margin:0;font-size:.95rem}.auth-link{color:var(--accent-primary);font-weight:600;text-decoration:none;transition:all .3s}.auth-link:hover{color:var(--accent-secondary);text-decoration:underline}.auth-link:focus{outline-offset:2px;border-radius:4px;outline:2px solid #667eea}@media (max-width:768px){.auth-container{min-height:100vh;padding:.5rem}.auth-container .card{border-radius:12px;max-width:100%;margin:0;padding:1.5rem 1.25rem}.auth-title{margin-bottom:1.25rem;font-size:1.3rem}.btn-auth{min-height:44px;padding:.875rem;font-size:.95rem}.oauth-buttons{gap:.6rem}}.loading{text-align:center;color:var(--text-primary);padding:2rem;font-size:1.25rem;font-weight:600}.global-loading-overlay{-webkit-backdrop-filter:saturate(120%)blur(2px);backdrop-filter:saturate(120%)blur(2px);opacity:1;z-index:9999;background:#0f0f1459;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:fixed;inset:0}.global-loading-overlay[aria-hidden=true]{opacity:0;pointer-events:none}.global-loading-content{border:1px solid var(--border-color);background:#191923d9;border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 1.25rem;display:flex}.global-loading-content .loading-text{color:var(--text-secondary);font-weight:600}.page-loading{color:var(--text-secondary);justify-content:center;align-items:center;gap:.75rem;padding:2rem;display:flex}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (hover:none) and (pointer:coarse){.btn{min-height:48px;padding:1rem 1.5rem;font-size:1rem}.modal .btn-close{font-size:1.75rem}.btn-icon{width:2.25rem;height:2.25rem;min-height:0;font-size:1.1rem}.form-input,.form-group input,.form-group textarea{min-height:48px;padding:1rem;font-size:16px}.btn:active{transform:scale(.98)}.navbar-links li a{align-items:center;min-height:48px;padding:1rem 1.5rem;display:flex}}.toast-container{z-index:10000;pointer-events:none;flex-direction:column;gap:12px;display:flex;position:fixed;top:20px;right:20px}.toast{background:var(--bg-secondary);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:auto;cursor:pointer;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;min-width:300px;max-width:400px;padding:16px 20px;display:flex;position:relative;box-shadow:0 8px 32px #0003}.toast-content{flex:1;align-items:center;gap:12px;display:flex}.toast-icon{flex-shrink:0;font-size:1.2rem}.toast-message{color:var(--text-primary);font-size:.95rem;font-weight:500;line-height:1.4}.toast-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:4px;font-size:1.4rem;line-height:1;transition:all .2s}.toast-close:hover{color:var(--text-primary);background:#ffffff1a}.toast-success{background:linear-gradient(135deg,#51cf661a 0%,#51cf660d 100%);border-left:4px solid #51cf66}.toast-error{background:linear-gradient(135deg,#ff6b6b1a 0%,#ff6b6b0d 100%);border-left:4px solid #ff6b6b}.toast-info{background:linear-gradient(135deg,#667eea1a 0%,#667eea0d 100%);border-left:4px solid #667eea}@media (max-width:768px){.toast-container{top:10px;left:10px;right:10px}.toast{min-width:auto;max-width:none;padding:14px 16px}.toast-message{font-size:.9rem}}.btn:focus-visible,.form-input:focus-visible,.form-group input:focus-visible,.form-group textarea:focus-visible{outline-offset:2px;outline:3px solid #667eea}@media (max-width:768px){.modal-overlay{--modal-inline-padding:.75rem;padding:.75rem;padding-bottom:max(.75rem,env(safe-area-inset-bottom));align-items:flex-end}.modal{--space:1rem;border-bottom-right-radius:0;border-bottom-left-radius:0;width:100%;max-height:min(90vh,42rem)}.modal-header{gap:.75rem;padding:.875rem 1rem .5rem}.modal-header h2{font-size:1.25rem;font-weight:600}.modal-content{padding:.75rem 1rem}.modal-footer{padding:.5rem 1rem 1rem;padding-bottom:max(1rem,calc(.5rem + env(safe-area-inset-bottom)));gap:.625rem}.modal.-confirm .modal-footer{flex-direction:column-reverse}.modal.-confirm .modal-footer>.btn{width:100%;max-width:unset}.modal .form-group+.form-group{margin-block-start:.875rem}.modal .form-label,.modal .form-group label{margin-bottom:.375rem;font-size:.875rem}.modal .form-input,.modal .form-group input,.modal .form-group textarea,.modal .form-group select{min-height:42px;padding-block:.625rem;padding-inline:.875rem;font-size:.9375rem}.modal .form-actions{gap:.625rem;margin-top:1rem}.modal .btn{padding:.75rem 1.25rem;font-size:.9375rem}.modal .btn.checker iconify-icon{font-size:3.5rem;inset-block-end:-.25em;inset-inline-end:-.2em}}@media (max-width:480px){.modal-overlay{--modal-inline-padding:.5rem;padding:.5rem .5rem 0;padding-bottom:env(safe-area-inset-bottom)}.modal{--space:.875rem;border-radius:16px 16px 0 0;max-height:85vh}.modal-header{gap:.5rem;padding:.75rem .875rem .5rem}.modal-header h2{font-size:1.125rem;line-height:1.3}.modal .btn-close{flex-shrink:0;width:32px;min-width:32px;height:32px;min-height:32px;font-size:1.125rem}.modal .btn-close iconify-icon{font-size:1.125rem}.modal-content{padding:.625rem .875rem}.modal-footer{padding:.5rem .875rem .875rem;padding-bottom:max(.875rem,calc(.5rem + env(safe-area-inset-bottom)))}.modal .form-group+.form-group{margin-block-start:.75rem}.modal .form-label,.modal .form-group label{margin-bottom:.3125rem;font-size:.8125rem}.modal .form-input,.modal .form-group input,.modal .form-group textarea,.modal .form-group select{padding-block:.5625rem;padding-inline:.75rem;font-size:.875rem}.modal .btn{padding:.6875rem 1.125rem;font-size:.875rem}.modal .btn.checker iconify-icon{font-size:2.75rem;inset-block-end:-.2em;inset-inline-end:-.15em}}@media (max-height:720px){.modal-overlay{padding-block:1rem}}html{scroll-behavior:smooth}::selection{color:#2d3748;background:#667eea4d}::selection{color:#2d3748;background:#667eea4d}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb{background:#667eea80;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#667eeab3}@media print{.navbar,.btn{display:none!important}.container{max-width:none!important;padding:0!important}.card{break-inside:avoid;box-shadow:none!important;border:1px solid #ddd!important}}@media (prefers-contrast:high){.card{background:#fff;border:2px solid #000}.btn,.form-input,.form-group input,.form-group textarea{border:2px solid #000}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.animate__animated{animation:none!important}}.invitation-code{color:#fff;text-align:center;letter-spacing:.1em;background:#0fc2e28f;border-radius:8px;padding:.3rem .6rem;font-family:Courier New,Monaco,monospace;font-size:1rem;font-weight:700;box-shadow:0 2px 8px #667eea4d}@media (max-width:768px){.invitation-code{letter-spacing:.05em;padding:.4rem .8rem;font-size:.9rem}}.dashboard-summary{margin:2rem 0}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin:1.5rem 0;display:grid}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a}.balances-preview{gap:1rem;margin:1.5rem 0;display:grid}.balance-card.preview{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:16px;padding:1.5rem;transition:all .3s;box-shadow:0 8px 32px #0000001a}.balance-card .card-header{margin-bottom:1rem}.balance-card .card-header h3{color:#e2e8f0;margin:0 0 .25rem;font-size:1.2rem;font-weight:600}.balance-card .other-user{color:#94a3b8;margin:0;font-size:.9rem}.balance-card .balance-info{margin-bottom:1rem}.balance-card .amount{font-size:1.1rem;font-weight:600}.balance-card .amount.owe{color:#ff6b6b}.balance-card .amount.owed{color:#22c55e}.balance-card .status.settled{color:#22c55e;font-weight:600}.balance-card .recent-activity{color:#666;font-style:italic}.dashboard-container{flex-direction:column;gap:1.5rem;max-width:1200px;margin:0 auto;padding:1rem;display:flex}.dashboard-container .page-header{border:unset;justify-content:space-between;align-items:center;margin-bottom:0;display:flex}.dashboard-title{color:#e2e8f0;margin:0;font-size:2rem;font-weight:700}.stats-overview{max-width:600px;padding:1rem}@media (max-width:768px){.stats-overview{max-width:100%;padding:.75rem}.stats-grid{gap:.375rem}.stat-item{padding:.25rem}.stat-value{font-size:.8rem}.stat-label{font-size:.6rem}}.stats-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1rem;box-shadow:0 4px 16px #0000004d}.stats-header{margin-bottom:.75rem}.stats-header h3{color:#94a3b8;margin:0;font-size:.85rem;font-weight:600}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.5rem;display:grid}.stat-item{text-align:center;background:#334155;border-radius:6px;flex-direction:column;align-items:center;padding:.375rem .5rem;display:flex}.stat-item.debt{background:#ff6b6b1a}.stat-item.credit{background:#22c55e1a}.stat-value{color:#e2e8f0;margin-bottom:.1rem;font-size:.9rem;font-weight:600}.stat-item.debt .stat-value{color:#ff6b6b}.stat-item.credit .stat-value{color:#22c55e}.stat-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;font-size:.65rem;font-weight:500}.profile-image-section{flex-direction:column;align-items:center;margin-bottom:2rem;display:flex}.profile-image-container{justify-content:center;margin-bottom:1rem;display:flex}.profile-image-clickable{background:var(--bg-tertiary);border:3px solid var(--border-color);border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;transition:all .3s;display:flex;position:relative;overflow:hidden}.profile-image-clickable:hover{border-color:var(--accent-primary);transform:scale(1.02)}.profile-image-clickable:hover .profile-image-overlay{opacity:1}.profile-image{object-fit:cover;border-radius:50%;width:100%;height:100%}.profile-image-placeholder{background:linear-gradient(135deg,var(--accent-primary)0%,var(--accent-secondary)100%);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;font-size:2.5rem;font-weight:700;display:flex}.profile-image-overlay{opacity:0;background:#000000b3;border-radius:50%;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.profile-image-overlay span{color:#fff;text-align:center;padding:0 .5rem;font-size:.9rem;font-weight:600}.error-message{background:var(--error-color);color:#fff;text-align:center;border-radius:8px;margin-bottom:1rem;padding:.875rem 1rem;font-size:.9rem;font-weight:500}.success-message{background:var(--success-color);color:#fff;text-align:center;border-radius:8px;margin-bottom:1rem;padding:.875rem 1rem;font-size:.9rem;font-weight:500}@media (max-width:768px){.profile-image-clickable{width:100px;height:100px}.profile-image-placeholder{font-size:2rem}.profile-image-overlay span{font-size:.8rem}}.password-requirements{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;margin-top:1rem;padding:1rem}.password-requirements h4{color:var(--text-primary);margin-bottom:.75rem;font-size:.9rem;font-weight:600}.password-requirements ul,.password-requirements .requirement-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.password-requirements li,.password-requirements .requirement-item{align-items:center;gap:.5rem;font-size:.85rem;transition:all .3s;display:flex}.requirement-icon{border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.7rem;font-weight:700;transition:all .3s;display:inline-flex}.requirement-unmet,.requirement-item.unmet{color:#ef4444!important}.requirement-unmet .requirement-icon,.requirement-item.unmet .requirement-icon{color:#fff!important;background:#ef4444!important}.requirement-met,.requirement-item.met{color:#22c55e!important}.requirement-met .requirement-icon,.requirement-item.met .requirement-icon{color:#fff!important;background:#22c55e!important}@media (max-width:768px){.password-requirements{padding:.75rem}.password-requirements h4{font-size:.85rem}.password-requirements li,.password-requirements .requirement-item{font-size:.8rem}}.bank-account-section{border-top:1px solid var(--border-color);margin-top:2rem;padding-top:1.5rem}.bank-account-section h4{color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.bank-account-description{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem;line-height:1.4}.bank-account-section .form-group select{background:var(--bg-tertiary);border:2px solid var(--border-color);color:var(--text-primary);border-radius:8px;width:100%;padding:.875rem 1rem;font-size:.95rem;transition:all .3s}.bank-account-section .form-group select:focus{border-color:var(--accent-primary);background:var(--bg-secondary);outline:none;box-shadow:0 0 0 3px #667eea33}.bank-account-section .form-group select:disabled{opacity:.7;cursor:not-allowed}.bank-info{color:var(--accent-primary);margin-top:.5rem;font-size:.85rem;font-weight:500;display:block}.bank-account-section optgroup{color:var(--text-primary);font-weight:600}.bank-account-section option{color:var(--text-primary);background:var(--bg-secondary);padding:.5rem}@media (max-width:768px){.bank-account-section{margin-top:1.5rem;padding-top:1rem}.bank-account-section h4{font-size:1rem}.bank-account-description{font-size:.85rem}}.qr-code-modal{width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.qr-content{flex-direction:column;align-items:center;gap:1.5rem;display:flex}.payment-summary{text-align:center;width:100%}.payment-summary h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.25rem;font-weight:600}.payment-details{background:linear-gradient(135deg,var(--accent-primary)0%,var(--accent-secondary)100%);color:#fff;border-radius:12px;padding:1rem}.payment-amount{margin-bottom:.5rem;font-size:2rem;font-weight:700}.payment-description{opacity:.9;font-size:1rem}.qr-code-container{background:#fff;border-radius:16px;padding:1rem;box-shadow:0 4px 12px #0000001a}.qr-code-image{width:100%;max-width:256px;height:auto;max-height:256px;display:block}.bank-details{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;width:100%;padding:1.25rem}.bank-details h4{color:var(--text-primary);text-align:center;margin-bottom:1rem;font-size:1.1rem;font-weight:600}.bank-info-row{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.bank-info-row:last-child{border-bottom:none}.bank-info-row .label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.bank-info-row .value{color:var(--text-primary);text-align:right;flex:1;margin-left:1rem;font-size:.9rem;font-weight:600}.qr-instructions{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:100%;padding:1.25rem}.qr-instructions h4{color:var(--text-primary);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.qr-instructions ol{color:var(--text-secondary);padding-left:1.5rem;line-height:1.6}.qr-instructions li{margin-bottom:.5rem;font-size:.95rem}.qr-save-tip{color:var(--text-secondary);margin-top:.75rem;margin-bottom:0;font-size:.95rem}.qr-loading{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:3rem 2rem;display:flex}.loading-spinner{border:4px solid var(--border-color);border-top:4px solid var(--accent-primary);border-radius:50%;width:48px;height:48px;margin-bottom:1rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.qr-loading p{color:var(--text-secondary);margin:0;font-size:1rem}.qr-error{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:3rem 2rem;display:flex}.error-icon{margin-bottom:1rem;font-size:3rem}.qr-error h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.25rem;font-weight:600}.qr-error p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1rem;line-height:1.5}@media (max-width:768px){.qr-code-modal{width:95%;max-height:95vh}.payment-amount{font-size:1.75rem}.qr-code-image{max-width:200px;max-height:200px}.bank-info-row{flex-direction:column;align-items:flex-start;gap:.25rem}.bank-info-row .value{text-align:left;margin-left:0}.qr-instructions ol{padding-left:1.25rem}.qr-loading,.qr-error{padding:2rem 1rem}}.qr-payment-section{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#667eea1a 0%,#9ca3af0d 100%);border:1px solid #667eea33;border-radius:16px;margin-top:2rem;padding:1.5rem}.qr-payment-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:6px;margin-left:.75rem;padding:.5rem .75rem;font-size:.8rem;font-weight:600;transition:all .3s;box-shadow:0 2px 8px #10b9814d}.qr-payment-btn:hover{background:linear-gradient(135deg,#059669 0%,#047857 100%);transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.qr-payment-btn:active{transform:translateY(0)}.qr-payment-description{color:var(--text-secondary);margin:0;font-size:.95rem;font-weight:500}@media (max-width:768px){.qr-payment-section{margin-top:1.5rem;padding:1.25rem}.qr-payment-btn{padding:.6rem 1rem;font-size:.9rem}.qr-payment-description{font-size:.9rem}}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.section-header h2{margin:0}.section-header .section-actions{align-items:center;gap:.5rem;display:flex}.section-actions .btn{padding:0 1rem;font-size:.85rem}.expenses-sheet{background:var(--bg-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;box-shadow:0 8px 32px #0003}.expenses-header{background:linear-gradient(135deg,var(--accent-primary)0%,var(--accent-secondary)100%);color:#fff;text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600;display:grid}.expenses-header,.expense-row,.expenses-summary{grid-template-columns:2fr 3fr 1fr 1fr .8fr}.header-cell{border-right:1px solid #fff3;align-items:center;padding:.75rem;display:flex}.header-cell:last-child{border-right:none}.expenses-body{flex-direction:column;display:flex}.expense-row{border-bottom:1px solid var(--border-color);transition:background-color .2s;display:grid}.expense-row:hover{background:var(--bg-tertiary)}.expense-row:last-child{border-bottom:none}.expense-cell{border-right:1px solid var(--border-color);color:var(--text-primary);align-items:center;padding:.75rem;font-size:.85rem;display:flex}.expense-cell:last-child{border-right:none;gap:.5rem}.expense-cell.description{color:var(--text-primary);font-weight:500}.expense-cell.amount{flex-direction:column}.expense-cell.amount .expense-amount:not(:first-child){opacity:.6;font-size:.9em}.expense-breakdown{color:var(--text-primary)}.expense-breakdown .amount{color:var(--accent-primary);font-weight:600}.expense-breakdown .share>:not(:first-child){margin-inline-start:.25em}.expense-breakdown.credit .share:not(.my-share) .amount{color:var(--success-color)}.expense-breakdown.debt .share.my-share .amount{color:var(--error-color)}.expense-cell.category{color:var(--accent-primary);align-items:center;font-size:.8rem;position:relative;overflow:visible}.expense-cell.category iconify-icon{color:var(--text-secondary);opacity:.4;flex-shrink:0;font-size:2.5rem;inset-block-end:-.3rem;inset-inline-end:-.2rem}.expense-cell.date{color:var(--text-muted);font-size:.8rem}.expenses-summary{background:var(--bg-tertiary);border-top:2px solid var(--accent-primary);font-weight:600;display:grid}.summary-cell{border-right:1px solid var(--border-color);color:var(--text-secondary);align-items:center;padding:.75rem;font-size:.85rem;display:flex}.summary-cell:last-child{border-right:none}.summary-cell.amount{flex-direction:column;font-size:.9rem}.summary-cell.amount strong{color:var(--accent-primary)}.summary-cell.pagination{gap:.5rem;display:flex}.expense-cell.actions{align-items:center;gap:.5rem;display:flex}.btn-edit,.btn-delete{cursor:pointer;border:none;border-radius:6px;min-height:auto;padding:.25rem .5rem;font-size:.75rem;font-weight:500;transition:all .2s}.btn-edit{background:var(--accent-primary);color:#fff}.btn-edit:not(:disabled):hover{background:var(--accent-secondary);transform:translateY(-1px)}.btn-delete{background:var(--error-color);color:#fff}.btn-delete:not(:disabled):hover{background:#e53e3e;transform:translateY(-1px)}.empty-expenses{text-align:center;color:var(--text-muted);padding:3rem 2rem}.empty-icon{margin-bottom:1rem;font-size:3rem}.empty-expenses p{color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.empty-expenses span{color:var(--text-muted);font-size:.9rem}@media (max-width:768px){.expenses-header,.expense-row,.expenses-summary{grid-template-columns:1fr;display:block}.expenses-header{display:none}.expense-row{border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:8px;margin-bottom:.5rem;padding:.5rem;box-shadow:0 2px 8px #0000001a}.expense-cell{border:none;justify-content:space-between;align-items:center;padding:.1rem 0;display:flex}.expense-cell:before{content:attr(data-label);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;width:80px;font-size:.7rem;font-weight:600}.icon-container iconify-icon{margin-bottom:1.5rem}.expense-cell.description:before{content:"Item: "}.expense-cell.amount:before{content:"Amount: "}.expense-cell.category:before{content:"Category: "}.expense-cell.date:before{content:"Date: "}.expense-cell.actions{justify-content:flex-end;gap:.25rem}.btn-edit,.btn-delete{padding:.3rem .6rem;font-size:.7rem}.expenses-summary{text-align:center;border-radius:8px;margin-top:.75rem;padding:.75rem;display:block}.summary-cell{border:none;justify-content:center;padding:.25rem 0}.summary-cell.description,.summary-cell.amount{display:block}.summary-cell.category,.summary-cell.date,.summary-cell.actions{display:none}}.user-breakdown-modal{width:90%;max-width:500px;max-height:80vh;overflow-y:auto}.breakdown-content{padding:0}.breakdowns-list h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.1rem}.breakdown-items{flex-direction:column;gap:.75rem;display:flex}.breakdown-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem;transition:all .2s;display:flex}.breakdown-item:hover{background:var(--bg-tertiary);transform:translateY(-1px)}.breakdown-item .user-info{align-items:center;gap:.75rem;display:flex}.breakdown-item .user-avatar{object-fit:cover;border-radius:50%;width:32px;height:32px}.breakdown-item .user-avatar-placeholder{background:var(--accent-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:700;display:flex}.breakdown-item .username{color:var(--text-primary);font-weight:500}.breakdown-item .amount{font-size:1rem;font-weight:600}.breakdown-item .amount.debt{color:var(--error-color)}.breakdown-item .amount.credit{color:var(--success-color)}.no-breakdowns{text-align:center;color:var(--text-secondary);padding:2rem}.no-breakdowns p{margin:0}@media (max-width:768px){.user-breakdown-modal{width:95%;max-height:85vh}.breakdown-item{padding:.5rem}.breakdown-item .user-avatar,.breakdown-item .user-avatar-placeholder{width:28px;height:28px}.breakdown-summary .amount{font-size:1.25rem}}.group-balance-summary{flex-direction:column;align-items:center;gap:.5rem;display:flex}.group-balance-summary .balance-display{align-self:stretch}.member-item .member-info{align-items:center;gap:.75rem;width:100%;display:flex}.member-details{flex-direction:column;flex:1;gap:.25rem;display:flex}.member-balance{opacity:.9;font-size:.8rem;font-weight:500}.member-balance.debt{color:var(--error-color)}.member-balance.credit{color:var(--success-color)}.member-balance.settled{color:var(--text-muted);font-style:italic}.breakdown-loading{text-align:center;color:var(--text-muted);padding:.5rem;font-style:italic}.qr-member-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:6px;margin-left:.75rem;padding:.5rem .75rem;font-size:.8rem;font-weight:600;transition:all .3s;box-shadow:0 2px 8px #10b9814d}.qr-member-btn:hover{background:linear-gradient(135deg,#059669 0%,#047857 100%);transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.qr-member-btn:active{transform:translateY(0)}.member-item{justify-content:space-between;align-items:center;gap:1rem;display:flex}.member-item .member-info{flex:1}.sr-only{opacity:0;width:0;height:0;margin:0;padding:0;display:inline-block;position:absolute;top:0;left:0}.member-avatar-small{object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px}.member-avatar-small-placeholder{background:var(--accent-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:700;display:flex}.custom-split-item{border:1px solid var(--border-color);border-radius:.5rem;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem;padding:.75rem;display:flex}.custom-split-item .member-info{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.custom-split-item .custom-share-input{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);text-align:right;border-radius:.375rem;flex-shrink:0;padding:.5rem .75rem;font-size:.875rem;width:120px!important;min-width:120px!important;max-width:120px!important}.custom-splits{flex-direction:column;gap:.5rem;display:flex}.custom-split-item .member-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.custom-split-item .member-name .you-text{color:var(--text-secondary);font-weight:400}.custom-split-summary{background:var(--bg-tertiary);border-radius:.25rem;margin-top:.5rem;padding:.5rem}.remaining-positive{color:var(--success-color)}.remaining-negative{color:var(--error-color)}.grid-flow{grid-template-columns:repeat(auto-fit,minmax(var(--grid-unit-width,20ch),1fr));gap:.25rem;display:grid}.icon-container{position:relative;overflow:hidden}.icon-container iconify-icon{position:absolute}.join-container{max-width:500px;margin:1rem auto;padding:0 1rem}.join-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px;overflow:hidden;box-shadow:0 8px 32px #0000001a}.join-header{background:linear-gradient(135deg,var(--accent-primary)0%,var(--accent-secondary)100%);color:#fff;text-align:center;padding:1.5rem;position:relative}.join-header h1{text-shadow:0 2px 4px #0000001a;margin:0;font-size:1.5rem;font-weight:700}.join-content{padding:1.5rem}.group-preview{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:12px;margin-bottom:2rem;padding:1.5rem}.group-info h2{color:var(--text-primary);margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.group-description{color:var(--text-muted);margin:0 0 1rem;font-size:.95rem;line-height:1.5}.group-stats{justify-content:center;align-items:center;gap:1rem;display:flex}.member-count{color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:20px;padding:.25rem .75rem;font-size:.9rem;font-weight:500}.invitation-details{margin-bottom:1.5rem}.inviter-info{background-color:var(--bg-secondary);border-radius:12px;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.inviter-avatar{flex-shrink:0}.inviter-details h3{color:var(--text-primary);margin:0 0 .25rem;font-size:1.2rem;font-weight:600}.inviter-details p{color:var(--text-secondary);margin:0 0 .5rem;font-size:.95rem}.inviter-details small{color:var(--text-muted);font-size:.85rem}.current-members{margin-top:1rem}.current-members h4{color:var(--text-primary);margin:0 0 .75rem;font-size:1rem;font-weight:600}.members-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;display:grid}.member-preview{background:var(--bg-secondary);border:1px solid var(--border-primary);text-align:center;border-radius:8px;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;display:flex}.member-preview.more{background:var(--bg-secondary);border:2px dashed var(--border-secondary)}.more-indicator{background:var(--accent-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:.9rem;font-weight:600;display:flex}.member-name{color:var(--text-secondary);word-break:break-word;font-size:.85rem;font-weight:500;line-height:1.2}.join-actions{margin:1.5rem 0 .75rem}.auth-required{text-align:center}.auth-required p{color:var(--text-secondary);margin-bottom:1rem;font-size:1rem}.auth-buttons,.join-buttons{flex-direction:column;gap:.75rem;display:flex}.join-btn{justify-content:center;align-items:center;gap:.5rem;font-weight:600;transition:all .3s;display:flex;position:relative}.join-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.loading-spinner{border:2px solid #0000;border-top-color:currentColor;border-radius:50%;width:20px;height:20px;animation:1s linear infinite spin}.expired-notice,.already-member-notice{text-align:center;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:8px;margin:1rem 0;padding:1.5rem}.expired-notice p,.already-member-notice p{color:var(--text-secondary);margin:0 0 1rem;font-size:1rem}.invitation-meta{text-align:center;border-top:1px solid var(--border-secondary);margin-top:2rem;padding-top:1rem}.invitation-meta small{color:var(--text-muted);font-size:.85rem}.status-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:.5rem 1rem;font-size:.8rem;font-weight:600;position:absolute;top:1rem;right:1rem}.status-badge.expired{color:#e74c3c;background:#e74c3c33;border:1px solid #e74c3c4d}.status-badge.success{color:#27ae60;background:#27ae6033;border:1px solid #27ae604d}.group-invitation-display{flex-direction:column;gap:1.5rem;display:flex}.group-info{text-align:center;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:8px}.group-info h4{color:var(--text-primary);margin:.5rem 0;font-size:1.2rem;font-weight:600}.invitation-description{color:var(--text-secondary);margin:0;font-size:.95rem}.invite-section{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:8px;padding:1rem}.invite-section h5{color:var(--text-primary);align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem;font-weight:600;display:flex}.link-box,.code-box{background:var(--bg-primary);border:1px solid var(--border-primary);word-break:break-all;text-align:center;border-radius:6px;margin-bottom:1rem;padding:.75rem;font-family:Courier New,monospace}.link-text{color:var(--accent-primary);font-size:.9rem;font-weight:500}.code-text{color:var(--text-primary);letter-spacing:.2em;font-size:1.5rem;font-weight:700}.link-actions,.code-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.instructions{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:1rem}.instructions h5{color:var(--text-primary);margin:0 0 .75rem;font-size:1rem;font-weight:600}.instructions ul{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.6;list-style:none}.instructions li:last-child{margin-bottom:0}@media (max-width:768px){.link-actions,.code-actions{flex-direction:column}.code-text{letter-spacing:.15em;font-size:1.25rem}.link-text{font-size:.85rem}.join-container{margin:1rem auto;padding:0 .5rem}.join-header{padding:1.5rem 1rem}.join-header h1{font-size:1.5rem}.join-content{padding:1.5rem 1rem}.members-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.auth-buttons,.join-buttons{gap:.75rem}.status-badge{margin-top:1rem;display:inline-block;position:static}}.easter-egg{z-index:9999;pointer-events:none;width:100px;height:auto;transition:all .3s ease-out,left linear;position:fixed}.easter-egg.orange{--idle-x:calc(-100px);--active-x:-30px;left:var(--idle-x);top:calc(100vh - 100px*var(--ratio,1));transition:all .3s ease-out}.easter-egg.pink{--idle-y:calc(100px*var(--ratio,1)*-1);--active-y:-10px;top:var(--idle-y);left:calc((100vw - 100px)*var(--offset,.5))}.easter-egg.orange.active{left:var(--active-x);animation:1s ease-out slideInFromLeft}.easter-egg.pink.active{top:var(--active-y);animation:1s ease-out slideInFromTop}@keyframes slideInFromLeft{0%{left:var(--idle-x);transform:rotate(-10deg)}60%{left:5px;transform:rotate(5deg)}to{left:var(--active-x);transform:rotate(0)}}@keyframes slideInFromTop{0%{top:var(--idle-y);transform:rotate(-10deg)}60%{top:0%;transform:rotate(5deg)}to{top:var(--active-y);transform:rotate(0)}}.floating-add-button{background:linear-gradient(135deg,var(--accent-primary)0%,var(--accent-secondary)100%);color:#fff;cursor:pointer;z-index:999;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:all .2s;display:flex;position:fixed;bottom:80px;right:24px;box-shadow:0 4px 12px #0000004d,0 2px 4px #0003}.floating-add-button:hover{transform:scale(1.05);box-shadow:0 6px 16px #0006,0 3px 6px #0000004d}.floating-add-button:active{transform:scale(.95)}.fab-icon{font-size:28px;font-weight:300;line-height:1}@media (min-width:769px){.floating-add-button{display:none}}@media (max-width:480px){.floating-add-button{width:52px;height:52px;bottom:80px;right:20px}.fab-icon{font-size:26px}}
