@import url(https://fonts.googleapis.com/css2?family=Comfortaa:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&family=Outfit:wght@400;500;600;700&display=swap);:root{--primary-gradient:linear-gradient(135deg,#2563eb,#1d4ed8);--primary-color:#2563eb;--primary-dark:#1d4ed8;--primary-light:#93c5fd;--secondary-gradient:linear-gradient(135deg,#a855f7,#9333ea);--secondary-color:#a855f7;--accent-gradient:linear-gradient(135deg,#22d3ee,#06b6d4);--accent-color:#22d3ee;--success-gradient:linear-gradient(135deg,#10b981,#34d399);--success-color:#10b981;--error-gradient:linear-gradient(135deg,#ef4444,#f87171);--error-color:#ef4444;--warning-gradient:linear-gradient(135deg,#f59e0b,#fbbf24);--warning-color:#f59e0b;--bg-gradient:linear-gradient(135deg,#2563eb,#3b82f6);--bg-light:#f8fafc;--bg-card:#fff;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #2563eb0d;--shadow-md:0 4px 6px -1px #2563eb1a,0 2px 4px -1px #2563eb0f;--shadow-lg:0 10px 15px -3px #2563eb1a,0 4px 6px -2px #2563eb0d;--shadow-xl:0 20px 25px -5px #2563eb1a,0 10px 10px -5px #2563eb0a;--shadow-2xl:0 25px 50px -12px #2563eb40;--shadow-glow:0 0 40px #2563eb66;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:0.15s ease;--transition-normal:0.3s ease;--transition-slow:0.5s ease}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;background:var(--bg-light);color:#0f172a;color:var(--text-primary);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:var(--primary-gradient);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#1d4ed8;background:var(--primary-dark)}::selection{background:#2563eb4d;color:#0f172a;color:var(--text-primary)}a{color:#2563eb;color:var(--primary-color);text-decoration:none;transition:.15s ease;transition:var(--transition-fast)}a:hover{color:#1d4ed8;color:var(--primary-dark)}h1,h2,h3,h4,h5,h6{color:#0f172a;color:var(--text-primary);font-weight:700;line-height:1.3}.text-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#1d4ed8);background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text}.bg-gradient-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:var(--primary-gradient)}.bg-gradient-secondary{background:linear-gradient(135deg,#a855f7,#9333ea);background:var(--secondary-gradient)}.glass-effect{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffff40;border:1px solid #ffffff2e}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.animate-fadeIn{animation:fadeIn .5s ease forwards}.animate-slideUp{animation:slideUp .6s ease forwards}.animate-pulse{animation:pulse 2s infinite}.animate-float{animation:float 3s ease-in-out infinite}.modal-overlay{align-items:center!important;background-color:#0009!important;bottom:0!important;display:flex!important;justify-content:center!important;left:0!important;overflow-y:auto;position:fixed!important;right:0!important;top:0!important;z-index:9999!important}.modal-overlay .modal-content{background:#fff;background:var(--bg-card);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #2563eb40;box-shadow:var(--shadow-2xl);max-height:90vh;overflow-y:auto;position:relative;z-index:10000}body.modal-open{overflow:hidden}.App{background:var(--bg-light)}.App,.auth-page{min-height:100vh}.auth-page{align-items:center;background:var(--primary-gradient);display:flex;justify-content:center;overflow:hidden;padding:20px;position:relative}.auth-page:before{animation:float 6s ease-in-out infinite;background:#ffffff1a;height:600px;right:-200px;top:-200px;width:600px}.auth-page:after,.auth-page:before{border-radius:50%;content:"";position:absolute}.auth-page:after{animation:float 8s ease-in-out infinite reverse;background:#ffffff14;bottom:-150px;height:400px;left:-150px;width:400px}.auth-container{animation:slideUp .6s ease forwards;max-width:440px;width:100%;z-index:10}.auth-card{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #ffffff80;border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl),var(--shadow-glow);padding:48px 40px}.auth-logo{margin-bottom:32px;text-align:center}.auth-logo-icon{animation:float 3s ease-in-out infinite;display:block;font-size:56px;margin-bottom:12px}.auth-logo-text{-webkit-text-fill-color:#0000;background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text;font-family:Outfit,sans-serif;font-size:52px;font-weight:600;letter-spacing:1px;text-transform:lowercase}.auth-title{color:var(--text-primary);font-size:24px;font-weight:600;margin-bottom:8px;text-align:center}.auth-subtitle{color:var(--text-secondary);font-size:15px;margin-bottom:32px;text-align:center}.form-group{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-input,.form-label{color:var(--text-primary)}.form-input{background:#f8fafc;border:2px solid var(--border-color);border-radius:var(--radius-md);font-family:inherit;font-size:15px;padding:14px 18px;transition:var(--transition-normal);width:100%}.form-input:focus{background-color:#fff;border-color:var(--primary-color);box-shadow:0 0 0 4px #667eea26;outline:none}.form-input::placeholder{color:var(--text-muted)}.form-input.error{border-color:var(--error-color)}.form-input.error:focus{box-shadow:0 0 0 4px #eb334926}select.form-input{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");cursor:pointer;min-height:44px;padding-right:42px}select.form-input,select.form-input:focus{background-position:right 14px center;background-repeat:no-repeat;background-size:16px 16px}select.form-input:focus{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236366f1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:inherit;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:14px 28px;text-decoration:none;transition:var(--transition-normal)}.btn-primary{background:var(--primary-gradient);box-shadow:0 4px 15px #6366f166;color:#fff}.btn-primary:hover{box-shadow:0 8px 25px #6366f180;color:#fff;filter:brightness(1.1);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{cursor:not-allowed;opacity:.7;transform:none}.btn-secondary{background:#fff;border:2px solid var(--border-color);color:var(--primary-color)}.btn-secondary:hover{background:#667eea0d;border-color:var(--primary-color)}.btn-success{background:var(--success-gradient);box-shadow:0 4px 15px #10b98166;color:#fff}.btn-success:hover{box-shadow:0 8px 25px #10b98180;color:#fff;filter:brightness(1.1);transform:translateY(-2px)}.btn-danger{background:var(--error-gradient);box-shadow:0 4px 15px #eb334966;color:#fff}.btn-block{width:100%}.btn-lg{font-size:16px;padding:16px 32px}.btn-sm{font-size:14px;padding:10px 20px}.alert{--legacy-alert-accent:var(--primary-color);--legacy-alert-border:#2563eb33;--legacy-alert-icon-bg:#2563eb1a;align-items:center;animation:fadeIn .3s ease;background:radial-gradient(circle at 100% 0,#2563eb0f 0,#0000 55%),linear-gradient(180deg,#fffffffa,#fff);border:1px solid var(--legacy-alert-border);border-radius:14px;box-shadow:0 10px 22px -18px #0f172a47;color:var(--text-primary);display:flex;font-size:14px;font-weight:500;gap:10px;margin-bottom:20px;overflow:hidden;padding:12px 14px;position:relative}.alert:before{background:var(--legacy-alert-accent);border-radius:999px;bottom:8px;content:"";left:0;position:absolute;top:8px;width:4px}.alert>i:first-child{align-items:center;background:var(--legacy-alert-icon-bg);border-radius:10px;color:var(--legacy-alert-accent);display:inline-flex;flex-shrink:0;height:34px;justify-content:center;margin-left:4px;width:34px}.alert button{border-radius:10px}.alert-error{--legacy-alert-accent:var(--error-color);--legacy-alert-border:#ef444433;--legacy-alert-icon-bg:#ef44441a;background:radial-gradient(circle at 100% 0,#ef444414 0,#0000 55%),linear-gradient(180deg,#fffffffa,#fff)}.alert-success{--legacy-alert-accent:var(--success-color);--legacy-alert-border:#10b98133;--legacy-alert-icon-bg:#10b9811a;background:radial-gradient(circle at 100% 0,#10b98114 0,#0000 55%),linear-gradient(180deg,#fffffffa,#fff)}.alert-warning{--legacy-alert-accent:var(--warning-color);--legacy-alert-border:#f59e0b38;--legacy-alert-icon-bg:#f59e0b1f;background:radial-gradient(circle at 100% 0,#f59e0b1a 0,#0000 55%),linear-gradient(180deg,#fffffffa,#fff)}.alert-danger{--legacy-alert-accent:var(--error-color);--legacy-alert-border:#ef444433;--legacy-alert-icon-bg:#ef44441a;background:radial-gradient(circle at 100% 0,#ef444414 0,#0000 55%),linear-gradient(180deg,#fffffffa,#fff)}.alert-info{--legacy-alert-accent:var(--primary-color);--legacy-alert-border:#2563eb33;--legacy-alert-icon-bg:#2563eb1f;background:radial-gradient(circle at 100% 0,#2563eb14 0,#0000 55%),linear-gradient(180deg,#fffffffa,#fff)}.auth-footer{border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:14px;margin-top:24px;padding-top:24px;text-align:center}.auth-footer a{color:var(--primary-color);font-weight:600}.auth-footer a:hover{text-decoration:underline}.divider{align-items:center;color:var(--text-muted);display:flex;font-size:13px;margin:24px 0}.divider:after,.divider:before{background:var(--border-color);content:"";flex:1 1;height:1px}.divider span{padding:0 16px}.navbar-custom{background:var(--primary-gradient)!important;box-shadow:0 4px 20px #667eea4d;padding:12px 0;position:relative;z-index:1000}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 24px}.navbar-brand-custom{align-items:center;color:#fff!important;display:flex;font-family:Outfit,sans-serif;font-size:28px;font-weight:600;gap:10px;letter-spacing:1px;text-transform:lowercase}.navbar-brand-icon{color:#fff;font-size:24px}.navbar-toggle{background:#ffffff26;border:1px solid #ffffff4d;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:none;font-size:20px;height:44px;transition:var(--transition-fast);width:44px}.navbar-toggle:hover{background:#ffffff40}.navbar-menu{align-items:center;display:flex;gap:24px}.navbar-user-mobile{display:none}.navbar-user-desktop{align-items:center;color:#fff;display:flex;gap:12px}.user-name-desktop{font-size:14px;font-weight:500}.navbar-overlay{display:none}.nav-link-custom{border-radius:var(--radius-sm);color:#ffffffe6!important;font-weight:500;padding:8px 16px!important;text-decoration:none;transition:var(--transition-fast)}.nav-link-custom:hover{background:#ffffff26;color:#fff!important}.nav-link-custom.active{background:#fff3;color:#fff!important}.user-info{color:#fff;gap:12px}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:#fff3;border-radius:50%;flex-shrink:0;font-size:14px;font-weight:600;height:36px;justify-content:center;width:36px}.btn-logout{background:#ffffff26;border:1px solid #ffffff4d;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:var(--transition-fast)}.btn-logout:hover{background:#ffffff40}@media (max-width:768px){.navbar-toggle{align-items:center;display:flex;justify-content:center}.navbar-menu{align-items:stretch;background:linear-gradient(180deg,#667eea,#764ba2);box-shadow:-5px 0 30px #0000004d;flex-direction:column;gap:8px;height:100vh;justify-content:flex-start;padding:80px 24px 24px;position:fixed;right:-100%;top:0;transition:right .3s ease;width:280px;z-index:1001}.navbar-menu.open{right:0}.navbar-overlay{background:#00000080;display:block;height:100%;left:0;position:fixed;top:0;width:100%;z-index:999}.navbar-user-desktop{display:none}.navbar-user-mobile{border-top:1px solid #fff3;display:flex;flex-direction:column;gap:16px;margin-top:auto;padding-top:24px}.user-info-mobile{align-items:center;color:#fff;display:flex;font-weight:500;gap:12px}.btn-logout-mobile{background:#ffffff26;border:1px solid #ffffff4d;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:14px 20px;text-align:center;transition:var(--transition-fast);width:100%}.btn-logout-mobile:hover{background:#ffffff40}.nav-link-custom{font-size:16px;padding:14px 16px!important}}.page-container{margin:0 auto;max-width:1200px;padding:32px 24px}.page-header{flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:32px}.page-header,.page-title{align-items:center;display:flex}.page-title{color:var(--text-primary);font-size:28px;font-weight:700;gap:12px}.page-title-icon{color:var(--primary-color);font-size:28px}.card-modern{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;transition:var(--transition-normal)}.card-modern:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-modern-body{padding:24px}.card-modern-header{background:#f8fafc;border-bottom:1px solid var(--border-color);font-weight:600;padding:20px 24px}.group-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);color:inherit!important;cursor:pointer;display:block;height:100%;padding:24px;text-decoration:none!important;transition:var(--transition-normal)}.group-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-xl);transform:translateY(-6px)}.group-card-icon{align-items:center;background:var(--primary-gradient);border-radius:var(--radius-md);color:#fff;display:flex;font-size:22px;height:48px;justify-content:center;margin-bottom:16px;width:48px}.group-card-title{color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:8px}.group-card-description{color:var(--text-secondary);font-size:14px;line-height:1.5;margin-bottom:16px}.group-card-meta{align-items:center;color:var(--text-muted);display:flex;font-size:13px;gap:16px}.group-card-meta-item{align-items:center;display:flex;gap:6px}.empty-state{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:60px 40px;text-align:center}.empty-state-icon{-webkit-text-fill-color:#0000;background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text;font-size:56px;margin-bottom:20px}.empty-state-title{color:var(--text-primary);font-size:20px;font-weight:600;margin-bottom:8px}.empty-state-text{color:var(--text-secondary);margin-bottom:24px}.balance-positive{color:var(--success-color)!important;font-weight:600}.balance-negative{color:var(--error-color)!important;font-weight:600}.balance-neutral{color:var(--text-muted)}.balance-card{align-items:center;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:12px;padding:16px 20px;transition:var(--transition-fast)}.balance-card:hover{box-shadow:var(--shadow-md)}.balance-user{gap:12px}.balance-avatar,.balance-user{align-items:center;display:flex}.balance-avatar{background:var(--primary-gradient);border-radius:50%;color:#fff;font-size:14px;font-weight:600;height:40px;justify-content:center;width:40px}.balance-amount{font-size:18px;font-weight:700}.expense-item{align-items:center;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:12px;padding:16px 20px;transition:var(--transition-fast)}.expense-item:hover{box-shadow:var(--shadow-md);transform:translateX(4px)}.expense-info{gap:16px}.expense-icon,.expense-info{align-items:center;display:flex}.expense-icon{background:var(--accent-gradient);border-radius:var(--radius-sm);color:#fff;font-size:18px;height:44px;justify-content:center;width:44px}.expense-details h4{font-size:15px;font-weight:600;margin-bottom:4px}.expense-details span{color:var(--text-muted);font-size:13px}.expense-amount{text-align:right}.expense-amount .value{color:var(--text-primary);font-size:18px;font-weight:700}.expense-amount .date{color:var(--text-muted);font-size:12px}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.loading-text{color:var(--text-secondary);font-size:14px;margin-top:16px}.modal-modern .modal-content{border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-2xl)}.modal-modern .modal-header{border-bottom:1px solid var(--border-color);padding:20px 24px}.modal-modern .modal-body{padding:24px}.modal-modern .modal-footer{border-top:1px solid var(--border-color);padding:16px 24px}.modal-overlay{align-items:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideUp .3s ease;background:#fff;background:var(--bg-primary,#fff);border-radius:16px;border-radius:var(--radius-lg,16px);box-shadow:var(--shadow-2xl);max-height:90vh;max-width:500px;overflow:auto;width:100%}@media (max-width:768px){.auth-card{padding:32px 24px}.auth-logo-icon{font-size:48px}.auth-logo-text{font-size:28px}.page-container{padding:20px 16px}.page-header{align-items:flex-start;flex-direction:column}.page-title{font-size:24px}.group-card{padding:20px}.expense-item{align-items:flex-start;flex-direction:column;gap:12px}.expense-amount{align-items:center;display:flex;justify-content:space-between;text-align:left;width:100%}}@media (max-width:480px){.auth-page:after,.auth-page:before{display:none}.btn{padding:12px 20px}.form-input{padding:12px 14px}}.app-alert{--app-alert-accent:var(--primary-color);--app-alert-soft-bg:#2563eb0f;--app-alert-border:#2563eb2e;--app-alert-icon-bg:#2563eb1f;--app-alert-text:var(--text-primary);--app-alert-muted:var(--text-secondary);align-items:flex-start;background:linear-gradient(180deg,#fffffffa,#fff);border:1px solid var(--app-alert-border);border-radius:14px;box-shadow:0 10px 22px -18px #0f172a47;color:var(--app-alert-text);display:flex;gap:12px;padding:12px 14px;position:relative}.app-alert:before{background:var(--app-alert-accent);border-radius:999px;bottom:10px;content:"";left:0;position:absolute;top:10px;width:4px}.app-alert__icon{align-items:center;background:var(--app-alert-icon-bg);border-radius:10px;color:var(--app-alert-accent);display:flex;flex-shrink:0;font-size:16px;height:34px;justify-content:center;margin-left:4px;width:34px}.app-alert__content{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.app-alert__title{color:var(--app-alert-text);font-size:13px;font-weight:800;line-height:1.25}.app-alert__message{color:var(--app-alert-text);font-size:14px;line-height:1.35;overflow-wrap:anywhere}.app-alert__close,.app-alert__message small{color:var(--app-alert-muted)}.app-alert__close{align-items:center;background:#0000;border:none;border-radius:10px;cursor:pointer;display:inline-flex;flex-shrink:0;height:30px;justify-content:center;transition:var(--transition-fast);width:30px}.app-alert__close:hover{background:#0f172a0d;color:var(--app-alert-text)}.app-alert__close:focus-visible{outline:2px solid #2563eb47;outline-offset:2px}.app-alert--error{--app-alert-accent:var(--error-color);--app-alert-soft-bg:#ef44440f;--app-alert-border:#ef444433;--app-alert-icon-bg:#ef44441a}.app-alert--success{--app-alert-accent:var(--success-color);--app-alert-soft-bg:#10b9810f;--app-alert-border:#10b98133;--app-alert-icon-bg:#10b9811a}.app-alert--warning{--app-alert-accent:var(--warning-color);--app-alert-soft-bg:#f59e0b14;--app-alert-border:#f59e0b38;--app-alert-icon-bg:#f59e0b1f}.app-alert--info{--app-alert-accent:var(--primary-color);--app-alert-soft-bg:#2563eb14;--app-alert-border:#2563eb33;--app-alert-icon-bg:#2563eb1f}.app-alert--error,.app-alert--info,.app-alert--success,.app-alert--warning{background:radial-gradient(circle at 100% 0,var(--app-alert-soft-bg) 0,#0000 55%),linear-gradient(180deg,#fffffffa 0,#fff 100%)}@media (max-width:640px){.app-alert{gap:10px;padding:11px 12px}.app-alert__icon{border-radius:9px;font-size:14px;height:30px;width:30px}.app-alert__message{font-size:13px}}@media (prefers-reduced-motion:reduce){.app-alert__close{transition:none}}.confirm-dialog-overlay{align-items:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0f172a80;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:11000}.confirm-dialog{grid-gap:14px;animation:fadeIn .18s ease-out;background:#fffffffa;border:1px solid #94a3b833;border-radius:20px;box-shadow:0 30px 60px -35px #0f172a73;display:grid;gap:14px;max-width:460px;padding:18px;width:100%}.confirm-dialog__icon{align-items:center;background:#2563eb1a;border:1px solid #2563eb29;border-radius:16px;color:var(--primary-color);display:flex;font-size:22px;height:52px;justify-content:center;width:52px}.confirm-dialog__content{grid-gap:6px;display:grid;gap:6px}.confirm-dialog__title{color:var(--text-primary);font-size:18px;line-height:1.2;margin:0}.confirm-dialog__message{color:var(--text-secondary);font-size:14px;line-height:1.45;margin:0}.confirm-dialog__actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.confirm-dialog__button{font-size:14px;min-height:42px;min-width:132px;padding:10px 14px}.confirm-dialog--danger .confirm-dialog__icon{background:#ef444414;border-color:#ef444429;color:var(--error-color)}.confirm-dialog--warning .confirm-dialog__icon{background:#f59e0b1a;border-color:#f59e0b2e;color:var(--warning-color)}.confirm-dialog--info .confirm-dialog__icon{background:#2563eb1a;border-color:#2563eb29;color:var(--primary-color)}@media (max-width:640px){.confirm-dialog{border-radius:16px;gap:12px;padding:16px}.confirm-dialog__icon{border-radius:14px;font-size:20px;height:46px;width:46px}.confirm-dialog__title{font-size:16px}.confirm-dialog__message{font-size:13px}.confirm-dialog__actions{align-items:stretch;flex-direction:column-reverse}.confirm-dialog__button{min-width:0;width:100%}}@media (prefers-reduced-motion:reduce){.confirm-dialog{animation:none}}.group-detail-page{padding-top:24px}.group-detail-alert{border-radius:var(--radius-md)}.group-detail-alert .app-alert__close{color:#065f46cc}.group-detail-alert .app-alert__close:hover{background:#10b9811f;color:#065f46}.group-detail-alert .app-alert__close:focus-visible{outline-color:#10b98159}.group-detail-backlink{align-items:center;color:var(--text-secondary);display:inline-flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:16px;width:-webkit-fit-content;width:fit-content}.group-detail-backlink:hover{color:var(--primary-color)}.group-hero{grid-gap:20px;background:#fffffff5;border:1px solid #0f172a0f;border-radius:var(--radius-xl);box-shadow:0 24px 44px -28px #0f172a38,0 12px 20px -18px #2563eb33,inset 0 1px 0 #ffffffe6;display:grid;gap:20px;grid-template-columns:minmax(0,1fr) 360px;margin-bottom:18px;overflow:hidden;padding:20px;position:relative}.group-hero:before{background:#2563eb12;filter:blur(6px);height:220px;right:-50px;top:-60px;width:220px}.group-hero:after,.group-hero:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.group-hero:after{background:#22d3ee14;bottom:-70px;filter:blur(10px);height:180px;left:-40px;width:180px}.group-hero__actions,.group-hero__main{position:relative;z-index:1}.group-hero__title-row{align-items:center;display:flex;gap:14px}.group-hero__icon{align-items:center;background:linear-gradient(135deg,#2563eb26,#22d3ee26);border:1px solid #2563eb1f;border-radius:16px;box-shadow:inset 0 1px 0 #fff9;color:var(--primary-color);display:flex;font-size:24px;height:56px;justify-content:center;width:56px}.group-hero__title-block{min-width:0}.group-hero__eyebrow{align-items:center;color:var(--text-muted);display:inline-flex;font-size:12px;font-weight:700;letter-spacing:.08em;margin-bottom:2px;text-transform:uppercase}.group-hero__title{color:var(--text-primary);font-size:clamp(1.5rem,2vw,2rem);line-height:1.1;margin:0;overflow-wrap:anywhere}.group-hero__description{color:var(--text-secondary);margin:14px 0 0;max-width:70ch}.group-hero__chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.group-chip{align-items:center;background:#2563eb0f;border:1px solid #2563eb1a;border-radius:var(--radius-full);color:var(--text-secondary);display:inline-flex;font-size:12px;font-weight:600;gap:7px;padding:7px 10px}.group-chip i{color:var(--primary-color)}.group-chip--warning{background:#f59e0b14;border-color:#f59e0b2e;color:#92400e}.group-chip--warning i{color:var(--warning-color)}.group-hero__notice{grid-gap:12px;align-items:center;background:linear-gradient(135deg,#ef444414,#f59e0b14);border:1px solid #ef44442e;border-radius:var(--radius-md);color:inherit;display:grid;gap:12px;grid-template-columns:auto 1fr auto;margin-top:16px;padding:12px 14px;text-decoration:none;transition:var(--transition-fast)}.group-hero__notice:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.group-hero__notice-icon{align-items:center;background:linear-gradient(135deg,#f97316,#ef4444);border-radius:10px;color:#fff;display:flex;height:36px;justify-content:center;width:36px}.group-hero__notice-content{display:flex;flex-direction:column;gap:2px;min-width:0}.group-hero__notice-content strong{color:var(--text-primary);font-size:14px}.group-hero__notice-content span{color:var(--text-secondary);font-size:12px}.group-hero__actions{grid-gap:10px;align-content:start;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#fffc;border:1px solid #2563eb1f;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr));padding:12px}.group-hero__action{align-items:center;display:inline-flex!important;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-height:44px;white-space:nowrap;width:100%}.group-hero__action--strong{grid-column:1/-1}.group-metrics{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:18px}.group-metric-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:block;min-height:118px;overflow:hidden;padding:16px;position:relative}.group-metric-card:after{background:#2563eb0d;border-radius:50%;content:"";height:92px;pointer-events:none;right:-18px;width:92px}.group-metric-card:after,.group-metric-card__icon{position:absolute;top:50%;transform:translateY(-50%)}.group-metric-card__icon{align-items:center;background:var(--primary-gradient);border-radius:16px;box-shadow:var(--shadow-sm);color:#fff;display:flex;font-size:24px;height:62px;justify-content:center;right:14px;width:62px;z-index:1}.group-metric-card__icon--secondary{background:var(--secondary-gradient)}.group-metric-card__icon--accent{background:var(--accent-gradient)}.group-metric-card__icon--success{background:var(--success-gradient)}.group-metric-card__content{display:flex;flex-direction:column;justify-content:center;min-height:86px;min-width:0;padding-right:86px;position:relative;z-index:1}.group-metric-card__label{color:var(--text-muted);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.group-metric-card__value{color:var(--text-primary);font-size:24px;line-height:1.1;margin-top:4px}.group-metric-card__value--compact{font-size:17px}.group-metric-card__hint{color:var(--text-secondary);font-size:12px;line-height:1.35;margin-top:6px;overflow:hidden;text-overflow:ellipsis}.group-tabs{background:#ffffffe6;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;gap:8px;margin-bottom:16px;overflow-x:auto;padding:6px;scrollbar-width:thin}.group-tab{align-items:center;background:#0000;border:none;border-radius:12px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:14px;font-weight:700;gap:8px;padding:10px 12px;transition:var(--transition-fast);white-space:nowrap}.group-tab:hover{background:#2563eb0f;color:var(--primary-color)}.group-tab.is-active{background:#2563eb1a;box-shadow:inset 0 0 0 1px #2563eb1f;color:var(--primary-color)}.group-tab:focus-visible{outline:2px solid #2563eb59;outline-offset:2px}.group-tab__badge{align-items:center;background:#0f172a0f;border-radius:var(--radius-full);color:inherit;display:inline-flex;font-size:12px;font-weight:700;height:22px;justify-content:center;min-width:22px;padding:0 6px}.group-tab.is-active .group-tab__badge{background:#2563eb26}.group-content-shell{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:18px}.group-tab-panel{min-height:200px}.group-panel__header{align-items:flex-start;border-bottom:1px solid #94a3b833;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px;padding-bottom:14px}.group-panel__title{color:var(--text-primary);font-size:18px;line-height:1.2;margin:0}.group-panel__subtitle{color:var(--text-secondary);font-size:14px;margin:6px 0 0;max-width:70ch}.group-panel__header-meta{align-items:flex-end;background:var(--bg-light);border:1px solid #94a3b833;border-radius:12px;display:flex;flex-direction:column;flex-shrink:0;gap:1px;min-width:120px;padding:10px 12px}.group-panel__header-meta span{color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.group-panel__header-meta strong{color:var(--text-primary);font-size:16px;line-height:1.2}.group-list-stack{grid-gap:12px;display:grid;gap:12px}.group-empty-state{background:radial-gradient(circle at top right,#2563eb0d,#0000 45%),#fff;border:1px dashed #94a3b859;box-shadow:none;padding:48px 28px}.group-expense-row{align-items:center;border-radius:14px;margin-bottom:0;padding:14px 16px}.group-expense-row:hover{transform:translateY(-2px)}.group-expense-row__main{flex:1 1;min-width:0}.group-expense-row__icon{flex-shrink:0}.group-expense-row .expense-details{min-width:0}.group-expense-row .expense-details h4{margin-bottom:2px;overflow-wrap:anywhere}.group-expense-row__meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.group-expense-row__meta span{align-items:center;background:var(--bg-light);border-radius:var(--radius-full);color:var(--text-secondary);display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:4px 8px}.group-expense-row__side{align-items:center;display:flex;gap:12px}.group-expense-row__amount{background:var(--bg-light);border:1px solid #94a3b82e;border-radius:12px;min-width:150px;padding:8px 10px}.group-expense-row__amount .value{font-size:17px}.group-expense-row__amount .date{color:var(--text-secondary);font-weight:500}.group-expense-row__actions{display:flex;gap:8px}.group-icon-btn{align-items:center;background:#fff;border:1px solid var(--border-color);border-radius:10px;color:var(--primary-color);cursor:pointer;display:inline-flex;height:38px;justify-content:center;transition:var(--transition-fast);width:38px}.group-icon-btn:hover{border-color:#2563eb40;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.group-icon-btn:disabled{cursor:not-allowed;opacity:.55;transform:none}.group-icon-btn--danger{color:var(--error-color)}.group-icon-btn--danger:hover{background:#ef44440a;border-color:#ef444440}.group-invite-row,.group-member-row{border-radius:14px;margin-bottom:0;padding:14px 16px}.group-member-row__main{gap:12px;width:100%}.group-member-row__details{flex:1 1;min-width:0}.group-member-row__name{align-items:center;color:var(--text-primary);display:flex;flex-wrap:wrap;font-weight:700;gap:6px;line-height:1.2;overflow-wrap:anywhere}.group-member-row__email{color:var(--text-muted);font-size:13px;margin-top:4px;overflow-wrap:anywhere}.group-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:10px;font-weight:800;height:20px;justify-content:center;letter-spacing:.04em;padding:0 8px}.group-badge--owner{background:#2563eb1f;color:var(--primary-dark)}.group-badge--self{background:#94a3b833;color:var(--text-secondary)}.group-badge--pending{background:#f59e0b24;color:#92400e}.group-row-action{align-items:center;display:inline-flex!important;font-size:13px!important;gap:6px;justify-content:center;padding:7px 12px!important;white-space:nowrap}.group-row-action--icon{padding:0!important;width:38px}.group-invite-row__avatar{background:var(--warning-gradient)!important}.group-invite-row__meta{color:var(--text-secondary);font-size:12px;margin-top:4px}@media (max-width:1100px){.group-hero{grid-template-columns:1fr}.group-hero__actions{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:900px){.group-detail-page{padding-top:8px}.group-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.group-content-shell{border-radius:var(--radius-lg);padding:14px}.group-panel__header{align-items:stretch;flex-direction:column}.group-panel__header-meta{align-items:flex-start;min-width:0}}@media (max-width:640px){.group-hero{border-radius:var(--radius-lg);padding:16px}.group-hero__title-row{align-items:flex-start}.group-hero__icon{font-size:20px;height:48px;width:48px}.group-hero__description{font-size:14px}.group-hero__actions{grid-template-columns:1fr;padding:10px}.group-hero__action,.group-hero__action--strong{grid-column:auto}.group-metrics{grid-template-columns:1fr}.group-metric-card{min-height:110px}.group-metric-card:after{height:78px;right:-16px;width:78px}.group-metric-card__icon{border-radius:14px;font-size:22px;height:54px;right:12px;width:54px}.group-metric-card__content{min-height:78px;padding-right:76px}.group-tabs{gap:6px;padding:4px}.group-tab{font-size:13px;padding:9px 10px}.group-expense-row{align-items:flex-start}.group-expense-row__side{gap:10px;justify-content:space-between;width:100%}.group-expense-row__amount{flex:1 1;min-width:0;text-align:left}.group-member-row__main{flex-wrap:wrap}.group-row-action{width:100%}.group-row-action--icon{width:38px}.group-invite-row .group-row-action{margin-left:auto;min-width:110px;width:auto}.group-empty-state{padding:36px 18px}}@media (prefers-reduced-motion:reduce){.group-detail-alert .app-alert__close,.group-hero__notice,.group-icon-btn,.group-tab{transition:none}.group-expense-row:hover,.group-hero__notice:hover,.group-icon-btn:hover{transform:none}}.balance-page{padding-top:12px}.balance-hero{background:#fffffff5;border:1px solid #0f172a0f;border-radius:var(--radius-xl);box-shadow:0 20px 42px -28px #0f172a33,0 12px 20px -18px #2563eb29,inset 0 1px 0 #ffffffe6;margin-bottom:18px;overflow:hidden;padding:18px 20px;position:relative}.balance-hero:before{background:#2563eb0f;filter:blur(6px);height:160px;right:-36px;top:-42px;width:160px}.balance-hero:after,.balance-hero:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.balance-hero:after{background:#22d3ee14;bottom:-46px;filter:blur(8px);height:120px;left:-24px;width:120px}.balance-backlink{align-items:center;color:var(--text-secondary);display:inline-flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:14px;position:relative;width:-webkit-fit-content;width:fit-content;z-index:1}.balance-backlink:hover{color:var(--primary-color)}.balance-hero__title-row{align-items:center;display:flex;gap:14px;position:relative;z-index:1}.balance-hero__icon{align-items:center;background:linear-gradient(135deg,#2563eb24,#22d3ee24);border:1px solid #2563eb1f;border-radius:16px;color:var(--primary-color);display:flex;font-size:24px;height:54px;justify-content:center;width:54px}.balance-hero__title-block{min-width:0}.balance-hero__eyebrow{color:var(--text-muted);display:inline-flex;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.balance-hero__title{color:var(--text-primary);font-size:clamp(1.5rem,2vw,1.95rem);line-height:1.1;margin:2px 0 0}.balance-hero__description{color:var(--text-secondary);margin:12px 0 0;max-width:74ch;position:relative;z-index:1}.balance-hero__chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;position:relative;z-index:1}.balance-hero__chip{align-items:center;background:#2563eb0f;border:1px solid #2563eb1a;border-radius:var(--radius-full);color:var(--text-secondary);display:inline-flex;font-size:12px;font-weight:600;gap:7px;padding:7px 10px}.balance-hero__chip i{color:var(--primary-color)}.balance-settled-banner{grid-gap:14px;align-items:center;background:radial-gradient(circle at 100% 0,#10b9811f,#0000 55%),linear-gradient(180deg,#fffffffa,#fff);border:1px solid #10b98133;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:grid;gap:14px;grid-template-columns:auto 1fr;margin-bottom:18px;padding:16px 18px}.balance-settled-banner__icon{align-items:center;background:#10b9811a;border:1px solid #10b98129;border-radius:16px;color:var(--success-color);display:flex;font-size:24px;height:54px;justify-content:center;width:54px}.balance-settled-banner__title{color:var(--text-primary);font-size:18px;margin:0}.balance-settled-banner__text{color:var(--text-secondary);font-size:14px;margin:4px 0 0}.balance-help-alert{margin-bottom:18px}.balance-metrics-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:16px}.balance-metric-card{align-items:flex-start;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;gap:14px;min-height:118px;padding:16px}.balance-metric-card__icon{align-items:center;border-radius:16px;color:#fff;display:flex;flex-shrink:0;font-size:24px;height:56px;justify-content:center;width:56px}.balance-metric-card__icon--success{background:var(--success-gradient)}.balance-metric-card__icon--danger{background:var(--error-gradient)}.balance-metric-card__icon--primary{background:var(--primary-gradient)}.balance-metric-card__icon--secondary{background:var(--secondary-gradient)}.balance-metric-card__content{display:flex;flex-direction:column;min-width:0}.balance-metric-card__label{color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.balance-metric-card__value{color:var(--text-primary);font-size:22px;line-height:1.1;margin-top:4px}.balance-metric-card__hint{color:var(--text-secondary);font-size:12px;line-height:1.35;margin-top:6px}.balance-user-spotlight{grid-gap:14px;align-items:center;background:#fff;border:1px solid #94a3b833;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:grid;gap:14px;grid-template-columns:auto 1fr auto;margin-bottom:16px;padding:16px}.balance-user-spotlight__avatar{align-items:center;background:var(--primary-gradient);border-radius:14px;color:#fff;display:flex;font-weight:700;height:48px;justify-content:center;width:48px}.balance-user-spotlight__content{min-width:0}.balance-user-spotlight__eyebrow{color:var(--text-muted);display:inline-flex;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.balance-user-spotlight__title{color:var(--text-primary);font-size:17px;line-height:1.2;margin:4px 0 0}.balance-user-spotlight__description{color:var(--text-secondary);font-size:13px;margin:4px 0 0}.balance-user-spotlight__amount{align-items:flex-end;display:flex;flex-direction:column;gap:6px;text-align:right}.balance-user-spotlight__amount strong{font-size:22px;line-height:1}.balance-user-spotlight__badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:11px;font-weight:800;height:22px;justify-content:center;letter-spacing:.04em;padding:0 9px}.balance-user-spotlight__badge--positive{background:#10b9811a;color:#047857}.balance-user-spotlight__badge--negative{background:#ef44441a;color:#b91c1c}.balance-user-spotlight__badge--neutral{background:#94a3b826;color:var(--text-secondary)}.balance-user-spotlight--positive{border-color:#10b9812e}.balance-user-spotlight--positive .balance-user-spotlight__avatar{background:var(--success-gradient)}.balance-user-spotlight--positive .balance-user-spotlight__amount strong{color:var(--success-color)}.balance-user-spotlight--negative{border-color:#ef44442e}.balance-user-spotlight--negative .balance-user-spotlight__avatar{background:var(--error-gradient)}.balance-user-spotlight--negative .balance-user-spotlight__amount strong{color:var(--error-color)}.balance-user-spotlight--neutral .balance-user-spotlight__amount strong{color:var(--text-secondary)}.balance-section-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:16px;padding:18px}.balance-section-card__header{align-items:flex-start;border-bottom:1px solid #94a3b82e;display:flex;gap:12px;justify-content:space-between;margin-bottom:14px;padding-bottom:12px}.balance-section-card__title{color:var(--text-primary);font-size:18px;line-height:1.2;margin:0}.balance-section-card__subtitle{color:var(--text-secondary);font-size:14px;margin:6px 0 0}.balance-section-card__meta{align-items:flex-end;background:var(--bg-light);border:1px solid #94a3b82e;border-radius:12px;display:flex;flex-direction:column;min-width:140px;padding:10px 12px}.balance-section-card__meta span{color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.balance-section-card__meta strong{color:var(--text-primary);font-size:16px}.balance-empty-inline{align-items:center;background:#f8fafccc;border:1px dashed #94a3b859;border-radius:var(--radius-lg);color:var(--text-secondary);display:flex;gap:10px;justify-content:center;min-height:92px;padding:14px;text-align:center}.balance-empty-inline--success{background:#10b9810d;border-color:#10b98138;color:#047857}.balance-member-list{grid-gap:10px;display:grid;gap:10px}.balance-member-row{align-items:center;background:#fff;border:1px solid var(--border-color);border-radius:14px;display:flex;gap:14px;justify-content:space-between;padding:14px;transition:var(--transition-fast)}.balance-member-row:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.balance-member-row.is-current-user{background:radial-gradient(circle at 100% 0,#2563eb0d,#0000 55%),#fff;box-shadow:inset 0 0 0 1px #2563eb24}.balance-member-row--positive{border-left:4px solid #10b981cc}.balance-member-row--negative{border-left:4px solid #ef4444cc}.balance-member-row--neutral{border-left:4px solid #94a3b8b3}.balance-member-row__main{align-items:center;display:flex;flex:1 1;gap:12px;min-width:0}.balance-member-row__avatar{align-items:center;border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:42px;justify-content:center;width:42px}.balance-member-row__avatar--positive{background:var(--success-gradient)}.balance-member-row__avatar--negative{background:var(--error-gradient)}.balance-member-row__avatar--neutral{background:linear-gradient(135deg,#64748b,#94a3b8)}.balance-member-row__info{min-width:0}.balance-member-row__name{align-items:center;color:var(--text-primary);display:flex;flex-wrap:wrap;font-weight:700;gap:6px;line-height:1.2}.balance-member-row__tag{align-items:center;background:#2563eb1a;border-radius:var(--radius-full);color:var(--primary-dark);display:inline-flex;font-size:10px;font-weight:800;height:20px;justify-content:center;padding:0 8px}.balance-member-row__description{color:var(--text-secondary);font-size:13px;line-height:1.35;margin-top:4px}.balance-member-row__summary{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:5px;text-align:right}.balance-member-row__badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:11px;font-weight:800;gap:5px;height:22px;padding:0 8px}.balance-member-row__badge--positive{background:#10b9811a;color:#047857}.balance-member-row__badge--negative{background:#ef44441a;color:#b91c1c}.balance-member-row__badge--neutral{background:#94a3b829;color:var(--text-secondary)}.balance-member-row__amount{color:var(--text-primary);font-size:18px;font-weight:700;line-height:1}.balance-member-row__amount--positive{color:var(--success-color)}.balance-member-row__amount--negative{color:var(--error-color)}.balance-member-row__amount--neutral{color:#64748b}.balance-member-row__amount-label{color:var(--text-muted);font-size:12px}.balance-transaction-list{grid-gap:12px;display:grid;gap:12px}.balance-transaction-card{background:radial-gradient(circle at 100% 0,#2563eb0d,#0000 58%),#fff;border:1px solid #2563eb1f;border-radius:14px;padding:14px}.balance-transaction-card--debt{background:radial-gradient(circle at 100% 0,#ef444412,#0000 58%),#fff;border-color:#ef44442e}.balance-transaction-card--credit{background:radial-gradient(circle at 100% 0,#10b98112,#0000 58%),#fff;border-color:#10b9812e}.balance-transaction-card__top{align-items:center;display:flex;gap:10px;justify-content:space-between}.balance-transaction-card__badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:11px;font-weight:800;height:24px;letter-spacing:.04em;padding:0 10px}.balance-transaction-card__badge--debt{background:#ef44441a;color:#b91c1c}.balance-transaction-card__badge--credit{background:#10b9811a;color:#047857}.balance-transaction-card__badge--neutral{background:#2563eb1a;color:var(--primary-dark)}.balance-transaction-card__amount{background:var(--primary-gradient);border-radius:var(--radius-full);box-shadow:0 2px 8px #2563eb38;color:#fff;font-size:14px;font-weight:700;padding:7px 12px}.balance-transaction-card__sentence{color:var(--text-primary);font-size:14px;line-height:1.4;margin-top:10px}.balance-transaction-card__sentence strong{color:inherit}.balance-transaction-card__flow{grid-gap:10px;align-items:center;background:#f8fafccc;border:1px solid #94a3b824;border-radius:12px;display:grid;gap:10px;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);margin-top:12px;padding:10px}.balance-transaction-card__arrow{align-items:center;background:#fff;border:1px solid #94a3b82e;border-radius:50%;color:var(--text-muted);display:flex;font-size:12px;height:28px;justify-content:center;width:28px}.balance-transaction-party{align-items:center;display:flex;gap:10px;min-width:0}.balance-transaction-party--right{justify-content:flex-end}.balance-transaction-party__avatar{align-items:center;border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:38px;justify-content:center;width:38px}.balance-transaction-party__avatar--debt{background:var(--error-gradient)}.balance-transaction-party__avatar--credit{background:var(--success-gradient)}.balance-transaction-party__label{display:flex;flex-direction:column;min-width:0}.balance-transaction-party__label--right{align-items:flex-end;text-align:right}.balance-transaction-party__role{color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.balance-transaction-party__label strong{color:var(--text-primary);font-size:14px;line-height:1.2;overflow-wrap:anywhere}.balance-transaction-card__actions{display:flex;justify-content:flex-end;margin-top:12px}.balance-transaction-card__pay-btn{font-size:14px;min-height:42px;padding:10px 14px}.balance-page__footer{margin-top:24px;text-align:center}@media (max-width:1024px){.balance-metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:768px){.balance-page{padding-top:6px}.balance-hero{border-radius:var(--radius-lg);padding:16px}.balance-user-spotlight{align-items:flex-start;grid-template-columns:auto 1fr}.balance-user-spotlight__amount{align-items:flex-start;border-top:1px solid #94a3b829;grid-column:1/-1;padding-top:6px;text-align:left;width:100%}.balance-section-card{border-radius:var(--radius-lg);padding:14px}.balance-section-card__header{align-items:stretch;flex-direction:column}.balance-section-card__meta{align-items:flex-start;min-width:0}.balance-member-row{align-items:stretch;flex-direction:column}.balance-member-row__summary{align-items:flex-start;border-top:1px solid #94a3b824;padding-top:10px;text-align:left}.balance-transaction-card__flow{gap:10px;grid-template-columns:1fr}.balance-transaction-card__arrow{justify-self:center;transform:rotate(90deg)}.balance-transaction-party--right{justify-content:flex-start}.balance-transaction-party__label--right{align-items:flex-start;text-align:left}.balance-transaction-card__actions{justify-content:stretch}.balance-transaction-card__pay-btn{width:100%}}@media (max-width:560px){.balance-metrics-grid{grid-template-columns:1fr}.balance-metric-card{min-height:110px;padding:14px}.balance-metric-card__icon{border-radius:14px;font-size:21px;height:50px;width:50px}.balance-hero__title-row{align-items:flex-start}.balance-hero__icon{border-radius:14px;font-size:20px;height:48px;width:48px}.balance-settled-banner{grid-template-columns:1fr;text-align:left}.balance-settled-banner__icon{border-radius:14px;height:48px;width:48px}.balance-transaction-card__top{flex-wrap:wrap}}@media (prefers-reduced-motion:reduce){.balance-backlink,.balance-member-row{transition:none}.balance-member-row:hover{transform:none}}.payment-share-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh;padding:20px}.share-header{animation:fadeIn .6s ease-out;color:#fff;margin-bottom:30px;text-align:center}.app-logo{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:10px}.logo-icon{animation:bounce 2s infinite;font-size:48px}.logo-text{font-size:32px;font-weight:700;letter-spacing:1px}.app-tagline{font-size:16px;margin:0;opacity:.9}.payment-card{animation:slideUp .6s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;margin-bottom:30px;max-width:500px;padding:30px;width:100%}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:20px;padding:8px 16px}.status-paid{background-color:#d4edda;color:#155724}.status-pending{background-color:#fff3cd;color:#856404}.status-cancelled{background-color:#f8d7da;color:#721c24}.status-icon{font-size:16px}.payment-header{border-bottom:2px solid #f0f0f0;margin-bottom:30px;padding-bottom:20px;text-align:center}.payment-amount{color:#667eea;font-size:48px;font-weight:700;margin:0}.platform-fee{color:#666;font-size:14px;margin:5px 0 0}.payment-details{display:flex;flex-direction:column;gap:15px}.detail-row{align-items:flex-start;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:10px 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#666;flex-shrink:0;font-weight:600;margin-right:15px}.detail-value{color:#333;text-align:right;word-break:break-word}.privacy-hint{color:#999;font-size:12px;font-style:italic}.manual-status{background:#e7f3ff;border-left:4px solid #2196f3;border-radius:4px;margin-top:15px;padding:12px}.manual-badge{color:#0d47a1;font-size:14px;font-weight:500;margin:0}.cta-section{animation:slideUp .8s ease-out;background:#fff;border-radius:20px;box-shadow:0 10px 30px #0003;margin-bottom:20px;max-width:500px;padding:30px;text-align:center;width:100%}.cta-section h3{color:#333;font-size:24px;margin:0 0 10px}.cta-section p{color:#666;margin:0 0 20px}.btn-download{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:30px;box-shadow:0 4px 15px #667eea66;color:#fff;display:inline-flex;font-size:16px;font-weight:700;gap:10px;padding:15px 30px;text-decoration:none;transition:transform .3s ease,box-shadow .3s ease}.btn-download:hover{box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}.btn-icon{font-size:20px}.share-footer{color:#fff;font-size:14px;max-width:500px;opacity:.8;text-align:center;width:100%}.privacy-info{align-items:center;display:flex;font-size:12px;gap:5px;justify-content:center;margin-top:10px}.privacy-icon{font-size:14px}.error-container{animation:slideUp .6s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;text-align:center}.error-icon{font-size:64px;margin-bottom:20px}.error-container h2{color:#333;margin:0 0 10px}.error-container p{color:#666;margin:0 0 20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (max-width:600px){.cta-section,.payment-card{padding:20px}.payment-amount{font-size:36px}.logo-text{font-size:24px}.logo-icon{font-size:36px}}
/*# sourceMappingURL=main.e656dc4a.css.map*/