@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Sora:wght@500;600;700;800&display=swap";:root{color-scheme:light;--bg: #f5efe6;--bg2: #fbf7f1;--bg3: #efe7dc;--card: rgba(255, 255, 255, .72);--card-strong: #ffffff;--text: #17212d;--text-inverse: #ffffff;--muted: #657082;--muted2: #8b95a3;--border: rgba(23, 33, 45, .08);--border2: rgba(23, 33, 45, .12);--border3: rgba(23, 33, 45, .18);--primary: #0f766e;--primary-hover: #115e59;--primary-light: #0f9488;--primary-dim: rgba(15, 118, 110, .12);--primary-glow: rgba(15, 118, 110, .22);--success: #15803d;--success-dim: rgba(21, 128, 61, .12);--danger: #c2410c;--danger-hover: #ea580c;--danger-dim: rgba(194, 65, 12, .12);--warning: #b45309;--warning-dim: rgba(180, 83, 9, .12);--info: #0f766e;--info-dim: rgba(15, 118, 110, .12);--radius: 16px;--radius-lg: 22px;--shadow-sm: 0 12px 30px rgba(23, 33, 45, .08);--shadow-md: 0 24px 60px rgba(23, 33, 45, .12);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--overlay-bg: rgba(23, 33, 45, .42);--overlay-blur: 6px}[data-theme=dark]{color-scheme:dark;--bg: #0a0e14;--bg2: #0d1117;--bg3: #151b23;--card: rgba(22, 27, 34, .88);--card-strong: #161b22;--text: #e6edf3;--text-inverse: #0a0e14;--muted: #8b949e;--muted2: #6e7681;--border: rgba(240, 246, 252, .08);--border2: rgba(240, 246, 252, .12);--border3: rgba(240, 246, 252, .18);--primary: #3fb950;--primary-hover: #2ea043;--primary-light: #3fb950;--primary-dim: rgba(63, 185, 80, .15);--primary-glow: rgba(63, 185, 80, .25);--success: #3fb950;--success-dim: rgba(63, 185, 80, .15);--danger: #f85149;--danger-hover: #da3633;--danger-dim: rgba(248, 81, 73, .15);--warning: #d29922;--warning-dim: rgba(210, 153, 34, .15);--info: #58a6ff;--info-dim: rgba(88, 166, 255, .15);--shadow-sm: 0 12px 30px rgba(0, 0, 0, .32);--shadow-md: 0 24px 60px rgba(0, 0, 0, .48);--overlay-bg: rgba(0, 0, 0, .6);--overlay-blur: 6px}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Manrope,sans-serif;background:radial-gradient(circle at top left,rgba(15,118,110,.14),transparent 34%),radial-gradient(circle at top right,rgba(244,171,17,.12),transparent 26%),linear-gradient(180deg,#f9f4eb,#f4ede4 45%,#f3ede6);color:var(--text);letter-spacing:-.01em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color var(--transition-slow),color var(--transition-slow)}[data-theme=dark] body{background:radial-gradient(circle at top left,rgba(63,185,80,.08),transparent 34%),radial-gradient(circle at top right,rgba(210,153,34,.06),transparent 26%),linear-gradient(180deg,#0d1117,#0a0e14 45%,#05080c)}body:before,body:after{content:"";position:fixed;inset:auto;pointer-events:none;z-index:0;border-radius:999px;filter:blur(36px);opacity:.55}body:before{width:320px;height:320px;top:-110px;left:-120px;background:var(--primary-dim)}body:after{width:420px;height:420px;right:-160px;bottom:-180px;background:var(--warning-dim)}#root{position:relative;z-index:1}h1,h2,h3,h4,.font-syne,.metric,.metric-label,.metric-sub,.topbar-title,.topbar-sub,.due-amount,.due-name,.ai-title{font-family:Sora,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none}.auth-layout{min-height:100vh;display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,470px);gap:28px;align-items:center;justify-content:center;max-width:1320px;margin:0 auto;padding:32px}.auth-hero{position:relative;padding:28px 18px 28px 0;display:flex;flex-direction:column;gap:18px;max-width:680px}.auth-hero:before{content:"";position:absolute;inset:8px 22% auto auto;width:180px;height:180px;border-radius:50%;background:var(--primary-dim);filter:blur(10px);z-index:-1}.auth-hero-badge{display:inline-flex;width:fit-content;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#ffffffb3;border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;box-shadow:var(--shadow-sm)}.auth-hero h1{margin:0;font-size:clamp(2.6rem,5vw,4.9rem);line-height:.95;letter-spacing:-.06em;max-width:12ch}.auth-hero p{margin:0;max-width:58ch;color:var(--muted);font-size:1.05rem;line-height:1.75}.auth-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:6px}.auth-point{padding:16px;border-radius:18px;background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.auth-point strong{display:block;font-size:14px;margin-bottom:6px;color:var(--text)}.auth-point span{color:var(--muted);font-size:13px;line-height:1.5}.auth-card{width:100%;max-width:460px;justify-self:end}.dashboard-layout{position:relative;z-index:1;max-width:1480px;margin:0 auto;padding:28px 28px 40px;display:flex;flex-direction:column;gap:22px}.topbar{position:sticky;top:18px;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-radius:20px;background:#ffffffb8;border:1px solid var(--border);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.topbar-brand{display:flex;align-items:center;gap:14px}.topbar-logo{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--primary),var(--primary-light));color:var(--text-inverse);font-weight:800;box-shadow:0 18px 36px var(--primary-glow)}.topbar-title{font-size:16px;font-weight:700;letter-spacing:-.03em}.topbar-sub{margin-top:4px;font-size:12px;color:var(--muted)}.hero-strip{position:relative;overflow:hidden;display:flex;justify-content:space-between;align-items:flex-end;gap:18px;padding:28px;border-radius:28px;background:linear-gradient(135deg,var(--primary),var(--success));color:var(--text-inverse);box-shadow:var(--shadow-md)}.hero-strip:before,.hero-strip:after{content:"";position:absolute;border-radius:50%;pointer-events:none}.hero-strip:before{width:220px;height:220px;top:-100px;right:12%;background:#ffffff1f;filter:blur(8px)}.hero-strip:after{width:300px;height:300px;bottom:-170px;right:-80px;background:#ffffff14;filter:blur(14px)}.hero-strip h1{margin:0 0 10px;font-size:clamp(2rem,4vw,3.8rem);line-height:.98;letter-spacing:-.06em}.hero-strip p{margin:0;max-width:54ch;color:#ffffffe6;font-size:1.02rem;line-height:1.65}.due-pill{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 14px;border-radius:999px;background:#ffffff29;border:1px solid rgba(255,255,255,.18);color:var(--text-inverse);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.content-grid{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(320px,.95fr);gap:18px;align-items:start}.left-column,.right-column{min-width:0}.stack{display:flex;flex-direction:column;gap:12px}.stack-lg{display:flex;flex-direction:column;gap:18px}.sticky{position:sticky;top:98px}.card{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.card:hover{transform:translateY(-2px);border-color:var(--primary-dim);box-shadow:var(--shadow-md)}[data-theme=dark] .card:hover{border-color:var(--primary-dim)}.card:before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--primary-dim),transparent);opacity:.6}.card-header{padding:18px 20px 0}.card-header h2{margin:0;font-size:18px;line-height:1.15;letter-spacing:-.04em}.card-header p{margin:6px 0 0;font-size:13px;color:var(--muted)}.card-content{padding:18px 20px 20px}.card.stat-violet,.card.stat-green,.card.stat-red,.card.stat-amber{border-top-width:3px}.card.stat-violet{border-top-color:var(--primary)}.card.stat-green{border-top-color:var(--success)}.card.stat-red{border-top-color:var(--danger)}.card.stat-amber{border-top-color:var(--warning)}.metric{font-size:34px;font-weight:800;letter-spacing:-.06em;line-height:1;margin-bottom:6px}.card.stat-violet .metric{color:var(--primary)}.card.stat-green .metric{color:var(--success)}.card.stat-red .metric{color:var(--danger)}.card.stat-amber .metric{color:var(--warning)}.metric-label{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:10px}.metric-sub{font-size:12px;color:var(--muted)}.metric-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:14px;background:var(--card);border:1px solid var(--border)}.card.stat-violet .metric-icon{background:var(--primary-dim)}.card.stat-green .metric-icon{background:var(--success-dim)}.card.stat-red .metric-icon{background:var(--danger-dim)}.card.stat-amber .metric-icon{background:var(--warning-dim)}.btn{min-height:42px;padding:10px 16px;border-radius:14px;border:1px solid transparent;font-weight:700;font-size:13px;cursor:pointer;font-family:Sora,sans-serif;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);line-height:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:before{opacity:1}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn:disabled{cursor:not-allowed;opacity:.55;transform:none;box-shadow:none}.btn:disabled:before{opacity:0}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:var(--text-inverse);border-color:var(--primary-dim);box-shadow:0 14px 28px var(--primary-glow)}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-hover),var(--primary));box-shadow:0 18px 34px var(--primary-glow)}.btn-ghost{background:var(--card);color:var(--muted);border-color:var(--border2)}.btn-ghost:hover{background:var(--card-strong);color:var(--text);border-color:var(--primary-dim)}.btn-danger{background:linear-gradient(135deg,var(--danger),var(--danger-hover));color:var(--text-inverse);border-color:var(--danger-dim);box-shadow:0 14px 28px var(--danger-dim)}.btn-danger:hover{background:linear-gradient(135deg,var(--danger-hover),var(--danger));box-shadow:0 18px 34px var(--danger-dim)}.btn-full{width:100%;text-align:center}.input-block{display:flex;flex-direction:column;gap:8px}.input-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;font-weight:700}.input{width:100%;min-height:46px;padding:11px 14px;border-radius:14px;border:1px solid var(--border2);background:var(--card);color:var(--text);font-size:14px;font-family:Manrope,sans-serif;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),transform var(--transition-fast);outline:none;box-shadow:inset 0 1px #ffffff1a}[data-theme=dark] .input{box-shadow:inset 0 1px #ffffff0d}.input::placeholder{color:var(--muted2)}.input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-dim);background:var(--card-strong);transform:translateY(-1px)}[data-theme=dark] .input:focus{background:var(--card-strong);border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-dim)}.input:invalid:not(:placeholder-shown){border-color:var(--danger)}.input:invalid:not(:placeholder-shown):focus{box-shadow:0 0 0 4px var(--danger-dim)}textarea.input{min-height:110px;resize:vertical}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23657082' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}select.input option{background:var(--card-strong);color:var(--text)}[data-theme=dark] select.input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238b949e' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}.input-row{display:flex;gap:10px}.input-row .input{flex:1}.form-row-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.banner{padding:12px 14px;border-radius:14px;font-size:13px;border:1px solid transparent}.banner.error{background:var(--danger-dim);color:var(--danger);border-color:var(--danger-dim)}.banner.success{background:var(--success-dim);color:var(--success);border-color:var(--success-dim)}.banner.warning{background:var(--warning-dim);color:var(--warning);border-color:var(--warning-dim)}.empty-state{text-align:center;padding:32px 20px;color:var(--muted);font-size:13px;border-radius:18px;background:var(--card);border:1px dashed var(--border2)}.empty-icon{font-size:26px;margin-bottom:8px;opacity:.45}.expense-list{list-style:none;padding:0;margin:0}.expense-item{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 18px;border-radius:18px;background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast)}.expense-item+.expense-item{margin-top:12px}.expense-item:hover{transform:translateY(-2px);border-color:var(--primary-dim);box-shadow:var(--shadow-md);background:var(--card-strong)}.expense-item:active{transform:translateY(0)}[data-theme=dark] .expense-item{box-shadow:0 8px 22px #0003}[data-theme=dark] .expense-item:hover{background:var(--card-strong);border-color:var(--primary-dim);box-shadow:0 16px 32px #0006}.expense-icon{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;background:var(--primary-dim);border:1px solid var(--primary-dim)}.expense-info{flex:1;min-width:0}.expense-title{font-size:15px;font-weight:700;line-height:1.25;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-meta{margin-top:4px;font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:4px;align-items:center}.expense-amount{font-size:15px;font-weight:800;text-align:right;flex-shrink:0;letter-spacing:-.03em}.expense-amount.debit{color:var(--danger)}.expense-amount.credit{color:var(--success)}.expense-share{font-size:11px;color:var(--muted);text-align:right;margin-top:4px}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.chip{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:var(--card);border:1px solid var(--border2);color:var(--muted);font-size:12px;transition:transform var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast)}.chip:hover{border-color:var(--primary-dim);color:var(--text);transform:translateY(-1px);box-shadow:var(--shadow-sm)}[data-theme=dark] .chip:hover{box-shadow:0 4px 12px #0000004d}.chip span{cursor:pointer;opacity:.64;transition:opacity var(--transition-fast),color var(--transition-fast)}.chip span:hover{opacity:1;color:var(--danger);transform:scale(1.1)}.chip.primary,[data-theme=dark] .chip.primary{background:var(--primary-dim);border-color:var(--primary-dim);color:var(--primary)}.chips button.chip{cursor:pointer;font-family:Manrope,sans-serif;-webkit-appearance:none;-moz-appearance:none;appearance:none}.chips button.chip.primary{background:var(--primary-dim);border-color:#0f766e33;color:var(--primary)}.chips button.chip:hover:not(.primary){border-color:var(--border3);color:var(--text)}.group-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:18px;cursor:pointer;transition:transform var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast)}.group-card:hover{transform:translateY(-2px);border-color:var(--primary-dim);background:var(--card-strong);box-shadow:var(--shadow-sm)}.group-card:active{transform:translateY(0)}[data-theme=dark] .group-card{background:var(--card)}[data-theme=dark] .group-card:hover{background:var(--card-strong);border-color:var(--primary-dim);box-shadow:0 8px 24px #0000004d}.group-emoji{width:40px;height:40px;border-radius:14px;background:var(--primary-dim);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.group-name{font-size:14px;font-weight:700;color:var(--text)}.group-meta{font-size:11px;color:var(--muted);margin-top:2px}.group-description{font-size:12px;color:var(--muted2);margin-top:4px;font-style:italic;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.due-item{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}.due-item:last-child{border-bottom:none}.due-avatar{width:36px;height:36px;border-radius:50%;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--danger-dim);border:1px solid var(--danger-dim);color:var(--danger)}.due-name{flex:1;font-size:13px;font-weight:700;color:var(--text)}.due-direction{font-size:11px;color:var(--muted);margin-top:1px}.due-amount{font-size:14px;font-weight:800}.due-amount.owe{color:var(--danger)}.due-amount.owed{color:var(--success)}.quick-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.quick-actions-panel{display:flex;flex-direction:column;gap:12px}.quick-actions-hints{display:flex;flex-wrap:wrap;gap:8px}.group-setup-preview{border-radius:16px;border:1px dashed var(--border2);padding:12px 14px;background:var(--card)}.group-setup-preview-title{font-weight:800;font-size:15px;color:var(--text)}.group-setup-preview-meta{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px}.group-detail-head{display:flex;align-items:center;gap:8px}.group-expense-row{display:flex;justify-content:space-between;gap:10px;border-radius:14px;padding:10px 12px;border:1px solid var(--border);background:var(--card)}.settle-row{margin-top:10px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(var(--overlay-blur));backdrop-filter:blur(var(--overlay-blur));z-index:60;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease-out}.modal-shell{width:min(760px,100%);max-height:calc(100vh - 40px);overflow:auto;border-radius:24px;border:1px solid var(--border2);background:var(--card-strong);box-shadow:var(--shadow-md);animation:slideUp .3s ease-out;transform-origin:center}.modal-overlay.closing .modal-shell{animation:slideDown .2s ease-in forwards}.modal-overlay.closing{animation:fadeOut .2s ease-in forwards}.modal-header{position:sticky;top:0;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border);background:var(--card-strong);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2}.modal-header h2{margin:0;font-size:20px;letter-spacing:-.03em}.modal-header p{margin:6px 0 0;font-size:13px;color:var(--muted)}.modal-body{padding:12px}.quick-chip{padding:8px 12px;background:var(--card);border:1px solid var(--border);border-radius:999px;font-size:11px;color:var(--muted);cursor:pointer;transition:transform var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast);text-align:left}.quick-chip:hover{transform:translateY(-1px);border-color:var(--primary-dim);color:var(--text);background:var(--card-strong)}.ai-response{margin-top:16px;padding:14px 16px;border-radius:16px;background:var(--primary-dim);border:1px solid var(--primary-dim);color:var(--text);line-height:1.7;box-shadow:inset 0 1px #ffffff1a}.ai-response p{margin:0;font-size:13px}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;border:1px solid transparent;letter-spacing:.03em}.badge-violet{background:var(--primary-dim);color:var(--primary);border-color:var(--primary-dim)}.badge-green{background:var(--success-dim);color:var(--success);border-color:var(--success-dim)}.badge-red{background:var(--danger-dim);color:var(--danger);border-color:var(--danger-dim)}.badge-amber{background:var(--warning-dim);color:var(--warning);border-color:var(--warning-dim)}.muted{color:var(--muted)}.text-sm{font-size:12px}.font-syne{font-family:Sora,sans-serif}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideDown{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(20px) scale(.95)}}.auth-card,.hero-strip,.topbar,.stats-grid .card,.content-grid .card{animation:fadeUp .42s ease both}.stats-grid .card:nth-child(1){animation-delay:.04s}.stats-grid .card:nth-child(2){animation-delay:.08s}.stats-grid .card:nth-child(3){animation-delay:.12s}.stats-grid .card:nth-child(4){animation-delay:.16s}.content-grid .card:nth-child(1){animation-delay:.18s}.content-grid .card:nth-child(2){animation-delay:.24s}@media(max-width:1180px){.auth-layout{grid-template-columns:1fr;gap:22px}.auth-hero{padding-right:0;max-width:760px}.auth-card{justify-self:stretch;max-width:none}}@media(max-width:980px){.dashboard-layout{padding:18px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.content-grid{grid-template-columns:1fr}.sticky{position:static}.topbar{flex-wrap:wrap}.topbar-brand{flex:1;min-width:200px}}@media(max-width:768px){.dashboard-layout{padding:14px}.topbar,.hero-strip{flex-direction:column;align-items:flex-start;gap:12px}.hero-strip{padding:22px}.hero-strip p{max-width:none}.due-pill{align-self:flex-start}.form-row-grid,.auth-points{grid-template-columns:1fr}.expense-item{align-items:flex-start;flex-direction:column}.expense-amount,.expense-share{text-align:left}.modal-shell{width:100%;max-height:calc(100vh - 18px);border-radius:18px}.modal-header{padding:14px 16px}.modal-body{padding:10px}.card-header,.card-content{padding:14px 16px}.stats-grid{gap:12px}.content-grid{gap:14px}}@media(max-width:520px){.auth-layout{padding:18px}.auth-hero h1{font-size:clamp(2.1rem,12vw,3.4rem)}.stats-grid{grid-template-columns:1fr}.card-header,.card-content{padding-left:14px;padding-right:14px}.topbar{padding:12px}.topbar-logo{width:36px;height:36px;font-size:14px}.topbar-title{font-size:14px}.topbar-sub{font-size:11px}.hero-strip{padding:18px}.hero-strip h1{font-size:clamp(1.8rem,8vw,2.8rem)}.btn{min-height:38px;padding:8px 14px;font-size:12px}.input{min-height:42px;padding:10px 12px;font-size:13px}.metric{font-size:28px}.expense-item{padding:14px}.group-card{padding:12px 14px}.toast-container{left:12px;right:12px;top:12px;max-width:none}.toast{padding:12px 14px;font-size:13px}}@media(max-width:380px){.dashboard-layout{padding:12px}.auth-hero h1{font-size:clamp(1.6rem,10vw,2.4rem)}.stats-grid .card{min-height:100px}.btn{min-height:36px;padding:7px 12px;font-size:11px}.input{min-height:40px;padding:9px 11px;font-size:12px}}@media(hover:none)and (pointer:coarse){.btn:hover,.card:hover,.expense-item:hover,.group-card:hover,.chip:hover,.toast:hover{transform:none}.btn{min-height:44px;min-width:44px}.input{min-height:48px}.theme-toggle{width:44px;height:44px;min-width:44px;min-height:44px}}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:420px;pointer-events:none}.toast{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:var(--radius);font-size:14px;line-height:1.5;box-shadow:var(--shadow-md);animation:slideIn .3s ease-out;pointer-events:auto;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:transform var(--transition-base),opacity var(--transition-base)}.toast:hover{transform:translate(-4px)}.toast-exit{animation:slideOut .3s ease-in forwards}.toast-success{background:var(--success);color:var(--text-inverse);border:1px solid var(--success)}.toast-error{background:var(--danger);color:var(--text-inverse);border:1px solid var(--danger)}.toast-warning{background:var(--warning);color:var(--text-inverse);border:1px solid var(--warning)}.toast-info{background:var(--info);color:var(--text-inverse);border:1px solid var(--info)}[data-theme=dark] .toast-success{background:var(--success);border-color:var(--success)}[data-theme=dark] .toast-error{background:var(--danger);border-color:var(--danger)}[data-theme=dark] .toast-warning{background:var(--warning);border-color:var(--warning)}[data-theme=dark] .toast-info{background:var(--info);border-color:var(--info)}.toast-content{flex:1;word-break:break-word}.toast-close{flex-shrink:0;margin-left:12px;background:none;border:none;color:currentColor;font-size:24px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity var(--transition-fast);line-height:1}.toast-close:hover{opacity:1}@keyframes slideIn{0%{transform:translate(420px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(420px);opacity:0}}.skeleton{background:var(--bg2);position:relative;overflow:hidden;border-radius:8px}[data-theme=dark] .skeleton{background:var(--bg3)}.skeleton:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transform:translate(-100%);animation:shimmer 1.5s infinite}[data-theme=dark] .skeleton:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent)}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skeleton-text{height:1em;margin-bottom:.5em}.skeleton-text-sm{height:.8em;width:60%}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-card{height:80px;border-radius:var(--radius)}.skeleton-button{height:42px;width:120px;border-radius:14px}@media(max-width:520px){.toast-container{left:12px;right:12px;top:12px;max-width:none}}
