.mascot[data-v-4fa46d27]{width:64px;height:80px;flex-shrink:0;animation:mascot-bob-4fa46d27 2s ease-in-out infinite}.mascot--entering[data-v-4fa46d27]{animation:mascot-enter-4fa46d27 .4s ease-out forwards}.mascot__svg[data-v-4fa46d27]{width:100%;height:100%}.mascot__arm--waving[data-v-4fa46d27]{transform-origin:72px 40px;animation:wave-4fa46d27 .6s ease-in-out 3}.mascot__arm--celebrating[data-v-4fa46d27]{transform-origin:72px 48px;transform:rotate(-45deg) translateY(-8px)}.mascot__arm--celebrating-left[data-v-4fa46d27]{transform-origin:8px 48px;transform:rotate(45deg) translateY(-8px)}.mascot--celebrating[data-v-4fa46d27]{animation:celebrate-bounce-4fa46d27 .5s ease-in-out 3}@keyframes mascot-bob-4fa46d27{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes mascot-enter-4fa46d27{0%{transform:scale(.3) rotate(-10deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}@keyframes wave-4fa46d27{0%,to{transform:rotate(0)}25%{transform:rotate(-25deg)}75%{transform:rotate(15deg)}}@keyframes celebrate-bounce-4fa46d27{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.05)}}@media (min-width: 768px){.mascot[data-v-4fa46d27]{width:80px;height:100px}}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000}.onboarding-overlay__mask{width:100%;height:100%}.onboarding-overlay__mask rect{transition:all .4s ease}.onboarding-card{position:fixed;z-index:2001;width:80vw;max-width:400px;background:var(--bg-primary, #fff);border-radius:16px;box-shadow:0 12px 40px #00000040;padding:20px;display:flex;flex-direction:column;gap:14px;animation:onboarding-card-enter .35s ease-out;transition:left .35s ease,top .35s ease}.onboarding-card--measuring{opacity:0!important;pointer-events:none!important;transition:none!important}.onboarding-card--center{top:50%!important;left:50%!important;transform:translate(-50%,-50%)}.onboarding-card__mascot{display:flex;justify-content:center}.onboarding-card--center .onboarding-card__mascot{margin-bottom:-4px}.onboarding-card__content{display:flex;flex-direction:column;gap:6px}.onboarding-card__title{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-primary, #212121);line-height:1.3}.onboarding-card__body{margin:0;font-size:.88rem;color:var(--text-secondary, #555);line-height:1.55}.onboarding-card__tip{margin:4px 0 0;font-size:.8rem;color:var(--primary-color, #0088cc);line-height:1.4;padding-top:6px;border-top:1px solid var(--border-light, #eee)}.onboarding-card__footer{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--border-light, #eee)}.onboarding-dots{display:flex;gap:5px;align-items:center}.onboarding-dot{width:7px;height:7px;border-radius:4px;background:var(--border-color, #ddd);transition:all .3s ease}.onboarding-dot--active{width:18px;background:var(--primary-color, #0088cc)}.onboarding-dot--done{background:color-mix(in srgb,var(--primary-color, #0088cc) 40%,var(--border-color, #ddd))}.onboarding-card__buttons{display:flex;justify-content:space-between;align-items:center}.onboarding-card__buttons-right{display:flex;gap:6px;align-items:center}.onboarding-btn{padding:7px 14px;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;white-space:nowrap}.onboarding-btn--primary{background:var(--primary-color, #0088cc);color:#fff}.onboarding-btn--primary:hover{background:var(--primary-hover, #006ba6)}.onboarding-btn--ghost{background:transparent;color:var(--text-secondary, #757575);padding:7px 8px}.onboarding-btn--ghost:hover{color:var(--text-primary, #212121)}.onboarding-btn--skip{background:transparent;color:var(--text-light, #9e9e9e);font-weight:400;font-size:.78rem;padding:7px 8px}.onboarding-highlight{position:relative;z-index:2003;animation:onboarding-bounce 1.2s ease-in-out infinite!important;border-radius:50%;box-shadow:0 0 0 4px var(--primary-color, #0088cc),0 0 20px #0088cc80!important;transform:scale(1.3);background:#0088cc14}@keyframes onboarding-bounce{0%,to{transform:scale(1.3);box-shadow:0 0 0 4px var(--primary-color, #0088cc),0 0 20px #0088cc80}50%{transform:scale(1.5);box-shadow:0 0 0 8px var(--primary-color, #0088cc),0 0 32px #0088ccb3}}@keyframes onboarding-card-enter{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.onboarding-card--center{animation:onboarding-card-center-enter .35s ease-out}@keyframes onboarding-card-center-enter{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.onboarding-fade-enter-active{transition:opacity .3s ease}.onboarding-fade-leave-active{transition:opacity .2s ease}.onboarding-fade-enter-from,.onboarding-fade-leave-to{opacity:0}@media (max-width: 480px){.onboarding-card{width:calc(100vw - 20px);padding:16px}.onboarding-card__title{font-size:1rem}.onboarding-card__body{font-size:.84rem}.onboarding-btn{padding:6px 10px;font-size:.78rem}}.cookie-banner[data-v-9b1a0366]{position:fixed;bottom:0;left:0;right:0;z-index:10000;background:#1e1e1ef7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1rem 1.5rem;box-shadow:0 -2px 16px #0003}.cookie-banner__content[data-v-9b1a0366]{max-width:960px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.cookie-banner__content p[data-v-9b1a0366]{color:#e0e0e0;font-size:.9rem;line-height:1.5;margin:0}.cookie-banner__content a[data-v-9b1a0366]{color:#7db8f0;text-decoration:underline}.cookie-banner__actions[data-v-9b1a0366]{display:flex;gap:.75rem;flex-shrink:0}.cookie-banner__btn[data-v-9b1a0366]{border:none;border-radius:8px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .2s}.cookie-banner__btn[data-v-9b1a0366]:hover{opacity:.85}.cookie-banner__btn--accept[data-v-9b1a0366]{background:#4a7fb5;color:#fff}.cookie-banner__btn--necessary[data-v-9b1a0366]{background:transparent;color:#ccc;border:1px solid #666}.cookie-banner-enter-active[data-v-9b1a0366],.cookie-banner-leave-active[data-v-9b1a0366]{transition:transform .3s ease,opacity .3s ease}.cookie-banner-enter-from[data-v-9b1a0366],.cookie-banner-leave-to[data-v-9b1a0366]{transform:translateY(100%);opacity:0}@media (max-width: 600px){.cookie-banner__content[data-v-9b1a0366]{flex-direction:column;text-align:center;gap:.75rem}.cookie-banner__actions[data-v-9b1a0366]{width:100%;justify-content:center}}.input-wrapper[data-v-eab4d88e]{position:relative;display:flex;align-items:center}.input-wrapper.has-toggle .form-input[data-v-eab4d88e]{padding-right:2.5rem}.toggle-password[data-v-eab4d88e]{position:absolute;right:.5rem;background:none;border:none;cursor:pointer;font-size:1.1rem;padding:.25rem;opacity:.6;line-height:1}.toggle-password[data-v-eab4d88e]:hover{opacity:1}.auth-legal-footer[data-v-f51083a9]{text-align:center;padding:.75rem 0 .25rem;font-size:.75rem}.auth-legal-footer a[data-v-f51083a9]{color:#ffffff8c;text-decoration:none;transition:color .2s}.auth-legal-footer a[data-v-f51083a9]:hover{color:#ffffffd9;text-decoration:underline}.auth-legal-footer__sep[data-v-f51083a9]{color:#ffffff40;margin:0 .4rem}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,#004a73,#0077b6 40%,#08c 60%,#54a3db);position:relative;overflow:hidden}.auth-layout:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(ellipse at 20% 50%,rgba(255,255,255,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(255,255,255,.08) 0%,transparent 50%),radial-gradient(ellipse at 50% 90%,rgba(0,0,0,.1) 0%,transparent 50%);pointer-events:none}.auth-layout:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(30deg,transparent 49.5%,rgba(255,255,255,.02) 49.5%,rgba(255,255,255,.02) 50.5%,transparent 50.5%),linear-gradient(-30deg,transparent 49.5%,rgba(255,255,255,.02) 49.5%,rgba(255,255,255,.02) 50.5%,transparent 50.5%);background-size:60px 60px;pointer-events:none}.auth-layout__center{display:flex;flex-direction:column;align-items:center;width:100%;max-width:480px;position:relative;z-index:1}.auth-card{width:100%;max-width:420px;background:#fff;border-radius:20px;box-shadow:0 25px 60px #00000040,0 8px 20px #0068a626;padding:40px 36px;position:relative;z-index:1;animation:fadeSlideUp .6s ease-out}.auth-logo{display:block;width:90px;height:auto;margin:0 auto 12px;filter:drop-shadow(0 3px 10px rgba(196,160,83,.25))}.auth-header{text-align:center;margin-bottom:32px}.auth-title{font-size:1.85rem;font-weight:300;letter-spacing:.06em;color:#1b2a4a;margin:0 0 6px}.auth-title span{font-weight:600}.auth-subtitle{color:#8892a4;font-size:.925rem;font-weight:400;margin:0}.auth-form{margin-bottom:8px}.auth-form .form-group{margin-bottom:18px}.auth-form .form-label{font-size:.8rem;font-weight:600;color:#3a4560;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.auth-form .form-input{background:#f7f8fa;border:1.5px solid #e2e5ea;border-radius:10px;padding:12px 14px;font-size:.95rem;color:#1b2a4a;transition:all .25s ease;width:100%;box-sizing:border-box}.auth-form .form-input::placeholder{color:#b0b8c8}.auth-form .form-input:focus{outline:none;border-color:#08c;background:#fff;box-shadow:0 0 0 3px #0088cc1f}.auth-form .form-input.error{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c1a}.auth-form .btn-primary{background:linear-gradient(135deg,#0077b6,#08c,#54a3db);border:none;border-radius:10px;padding:13px 24px;font-size:.95rem;font-weight:600;color:#fff;letter-spacing:.03em;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0088cc59}.auth-form .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#005f8f,#0077b6,#08c);box-shadow:0 6px 20px #0088cc73;transform:translateY(-1px)}.auth-form .btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 10px #0088cc4d}.auth-form .btn-primary:disabled{opacity:.5;cursor:not-allowed}.auth-error{color:#e74c3c;font-size:.85rem;text-align:center;margin-top:8px;padding:8px 12px;background:#e74c3c0f;border-radius:8px}.auth-secondary{margin-top:16px;padding-top:16px;border-top:1px solid #eef0f4;display:flex;flex-direction:column;align-items:center;gap:14px}.auth-link-small{color:#08c;text-decoration:none;font-size:.85rem;transition:color .25s ease}.auth-link-small:hover{color:#005f8f;text-decoration:underline}.auth-divider{display:flex;align-items:center;margin:20px 0 16px;gap:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e2e5ea}.auth-divider span{font-size:.8rem;color:#8892a4;white-space:nowrap}.auth-google-btn{display:flex;justify-content:center;margin-bottom:8px}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.auth-value-strip{text-align:center;margin-top:-8px;margin-bottom:24px;height:20px;position:relative;overflow:hidden}.auth-value-strip__text{color:#5a6a82;font-size:.82rem;font-style:italic;font-weight:400;letter-spacing:.01em;position:absolute;width:100%;left:0;opacity:0;transform:translateY(6px);transition:opacity .5s ease,transform .5s ease}.auth-value-strip__text--active{opacity:1;transform:translateY(0)}.auth-helper-text{color:#9aa3b4;font-size:.78rem;margin-top:4px;font-style:italic}.auth-features{display:flex;justify-content:center;gap:32px;margin-top:28px;position:relative;z-index:1;max-width:480px}.auth-feature-item{display:flex;flex-direction:column;align-items:center;gap:6px;color:#ffffffd9;text-align:center}.auth-feature-item__icon{width:32px;height:32px;opacity:.9}.auth-feature-item__label{font-size:.75rem;font-weight:500;letter-spacing:.02em;line-height:1.3}.auth-features--mobile{display:none}@media (max-width: 480px){.auth-layout{padding:40px 16px 16px;align-items:flex-start}.auth-card{padding:28px 22px;border-radius:16px}.auth-logo{width:70px}.auth-title{font-size:1.5rem}.auth-header{margin-bottom:24px}.auth-features{display:none}.auth-features--mobile{display:flex;justify-content:center;margin-top:20px;position:relative;z-index:1;height:50px}.auth-features--mobile .auth-feature-item{position:absolute;opacity:0;transition:opacity .5s ease}.auth-features--mobile .auth-feature-item--active{opacity:1}}.pwa-install-banner[data-v-43cedabe]{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e2e5ea;box-shadow:0 -4px 20px #0000001f;padding:16px 20px;z-index:9998;border-radius:16px 16px 0 0}.pwa-install-banner__content[data-v-43cedabe]{display:flex;align-items:center;gap:12px;margin-bottom:14px}.pwa-install-banner__icon[data-v-43cedabe]{width:40px;height:40px}.pwa-install-banner__text[data-v-43cedabe]{display:flex;flex-direction:column}.pwa-install-banner__text strong[data-v-43cedabe]{font-size:.95rem;color:#1b2a4a}.pwa-install-banner__text span[data-v-43cedabe]{font-size:.8rem;color:#8892a4}.pwa-install-banner__actions[data-v-43cedabe]{display:flex;gap:10px}.pwa-install-banner__btn[data-v-43cedabe]{flex:1;padding:10px;border-radius:10px;font-size:.9rem;font-weight:600;border:none;cursor:pointer}.pwa-install-banner__btn--install[data-v-43cedabe]{background:linear-gradient(135deg,#0077b6,#08c);color:#fff}.pwa-install-banner__btn--dismiss[data-v-43cedabe]{background:#f0f2f5;color:#5a6a82}.slide-up-enter-active[data-v-43cedabe],.slide-up-leave-active[data-v-43cedabe]{transition:transform .3s ease,opacity .3s ease}.slide-up-enter-from[data-v-43cedabe],.slide-up-leave-to[data-v-43cedabe]{transform:translateY(100%);opacity:0}.fade-enter-active[data-v-43cedabe],.fade-leave-active[data-v-43cedabe]{transition:opacity .25s ease}.fade-enter-from[data-v-43cedabe],.fade-leave-to[data-v-43cedabe]{opacity:0}.pwa-instructions-overlay[data-v-43cedabe]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.pwa-instructions-modal[data-v-43cedabe]{background:#fff;border-radius:16px;padding:32px 28px;max-width:340px;width:100%;text-align:center;position:relative}.pwa-instructions-close[data-v-43cedabe]{position:absolute;top:10px;right:14px;background:none;border:none;font-size:1.4rem;color:#8892a4;cursor:pointer}.pwa-instructions-logo[data-v-43cedabe]{width:50px;margin-bottom:12px}.pwa-instructions-modal h3[data-v-43cedabe]{font-size:1.1rem;color:#1b2a4a;margin:0 0 20px}.pwa-instructions-steps[data-v-43cedabe]{text-align:left;margin-bottom:20px}.pwa-instructions-steps p[data-v-43cedabe]{font-size:.9rem;color:#5a6a82;margin:8px 0;line-height:1.4}.pwa-instructions-ok[data-v-43cedabe]{background:linear-gradient(135deg,#0077b6,#08c);color:#fff;border:none;border-radius:10px;padding:10px 32px;font-size:.9rem;font-weight:600;cursor:pointer}:root{--primary-color: #0088cc;--primary-hover: #006ba6;--primary-light: #e3f2fd;--secondary-color: #54a3db;--success-color: #4caf50;--error-color: #f44336;--warning-color: #ff9800;--info-color: #2196f3;--gradient-primary: linear-gradient(135deg, #0088cc, #54a3db);--gradient-accent: linear-gradient(135deg, #0088cc 0%, #006ba6 100%);--shadow-primary: 0 4px 14px rgba(0, 136, 204, .25);--text-primary: #212121;--text-secondary: #757575;--text-light: #9e9e9e;--text-white: #ffffff;--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-gray: #e0e0e0;--bg-dark: #333333;--border-color: #ddd;--border-light: #eeeeee;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.12);--shadow-md: 0 4px 6px rgba(0,0,0,.1);--shadow-lg: 0 10px 20px rgba(0,0,0,.15);--shadow-xl: 0 20px 40px rgba(0,0,0,.2);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--mobile: 480px;--tablet: 768px;--desktop: 1024px;--wide: 1280px}html{transition:background-color .4s ease,color .4s ease}html *,html *:before,html *:after{transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease,color .2s ease}html .loader,html [class*=spin],html [class*=animate]{transition:none}[data-theme=coral]{--primary-color: #D4603C;--primary-hover: #B84E2D;--primary-light: #FFF0EB;--secondary-color: #FF845E;--info-color: #E8734E;--bg-secondary: #FDF6F3;--bg-gray: #F5D6C8;--border-color: #F0C9BA;--border-light: #FAE8E0;--gradient-primary: linear-gradient(135deg, #D4603C, #FF845E);--gradient-accent: linear-gradient(135deg, #FF845E 0%, #D4603C 100%);--shadow-primary: 0 4px 14px rgba(212, 96, 60, .25)}[data-theme=bubblegum]{--primary-color: #C4308F;--primary-hover: #A32576;--primary-light: #FDE8F3;--secondary-color: #F549B8;--info-color: #D83AA0;--bg-secondary: #FDF2F8;--bg-gray: #F2C4DE;--border-color: #EBBAD5;--border-light: #F8E0EE;--gradient-primary: linear-gradient(135deg, #C4308F, #F549B8);--gradient-accent: linear-gradient(135deg, #F549B8 0%, #C4308F 100%);--shadow-primary: 0 4px 14px rgba(196, 48, 143, .25)}[data-theme=jasmine]{--primary-color: #A68508;--primary-hover: #8B7007;--primary-light: #FFFAED;--secondary-color: #FFE382;--info-color: #C49E0C;--bg-secondary: #FFFCF0;--bg-gray: #F0DFA0;--border-color: #E8D590;--border-light: #F5ECC5;--gradient-primary: linear-gradient(135deg, #B8960A, #E8C200);--gradient-accent: linear-gradient(135deg, #FFE382 0%, #B8960A 100%);--shadow-primary: 0 4px 14px rgba(184, 150, 10, .25)}[data-theme=mint]{--primary-color: #1D9B7A;--primary-hover: #177D62;--primary-light: #E8FAF5;--secondary-color: #5ED4B5;--info-color: #22B88E;--bg-secondary: #F0FBF7;--bg-gray: #B8E8D8;--border-color: #A8DDC9;--border-light: #D5F0E6;--gradient-primary: linear-gradient(135deg, #1D9B7A, #5ED4B5);--gradient-accent: linear-gradient(135deg, #5ED4B5 0%, #1D9B7A 100%);--shadow-primary: 0 4px 14px rgba(29, 155, 122, .25)}[data-theme=tiffany]{--primary-color: #3D8E91;--primary-hover: #2F7275;--primary-light: #E6F5F5;--secondary-color: #7CC5C7;--info-color: #5BB5B8;--bg-secondary: #EFF9F9;--bg-gray: #B5DCDD;--border-color: #A3D2D3;--border-light: #D2ECED;--gradient-primary: linear-gradient(135deg, #3D8E91, #7CC5C7);--gradient-accent: linear-gradient(135deg, #9AD4D6 0%, #3D8E91 100%);--shadow-primary: 0 4px 14px rgba(61, 142, 145, .25)}[data-theme=periwinkle]{--primary-color: #7B68C8;--primary-hover: #6453A8;--primary-light: #F0ECF9;--secondary-color: #A899E0;--info-color: #8E7DD6;--bg-secondary: #F5F2FC;--bg-gray: #CFC4EB;--border-color: #C2B5E3;--border-light: #E0D8F2;--gradient-primary: linear-gradient(135deg, #7B68C8, #A899E0);--gradient-accent: linear-gradient(135deg, #C9BBF4 0%, #7B68C8 100%);--shadow-primary: 0 4px 14px rgba(123, 104, 200, .25)}.grecaptcha-badge{visibility:hidden!important}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:1rem;line-height:1.5;color:var(--text-primary);background-color:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-hover)}ul,ol{list-style:none}img{max-width:100%;height:auto}button,input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.container-sm{max-width:600px}.container-xs{max-width:400px}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.header{background-color:var(--bg-primary);box-shadow:var(--shadow-sm);padding:var(--spacing-md) 0;border-bottom:2px solid var(--primary-light)}.header-content{display:flex;align-items:center;justify-content:space-between}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--text-primary)}.form-input{width:100%;padding:10px var(--spacing-md);font-size:1rem;border:1.5px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-primary);transition:all var(--transition-base)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.form-input.error{border-color:var(--error-color)}.form-input:disabled{background-color:var(--bg-gray);cursor:not-allowed;opacity:.6}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:.875rem}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:1.125rem}.btn-danger{background-color:var(--error-color);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(.9);transform:translateY(-1px)}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){filter:brightness(.9);transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{margin-right:var(--spacing-xs);vertical-align:middle}.btn-group{display:flex;gap:var(--spacing-sm)}.btn-icon-sm{width:32px;height:32px;padding:0;border:none;background-color:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-icon-sm:hover:not(:disabled){background-color:var(--bg-secondary);color:var(--primary-color)}.btn-icon-sm:active{transform:scale(.95)}.btn-icon-sm--danger:hover{color:var(--error-color)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:400px;width:100%;box-shadow:var(--shadow-xl);max-height:90vh;overflow-y:auto}.modal-content h3{margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-size:1.25rem}.modal-content p{margin:0 0 var(--spacing-md) 0;color:var(--text-secondary)}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.modal-content--small{max-width:300px}@media (max-width: 768px){.modal-content{margin:var(--spacing-md);padding:var(--spacing-lg)}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl)}.loading-text{color:var(--text-secondary);font-size:.9rem}.data-table{width:100%;background-color:var(--bg-primary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table__wrapper{overflow-x:auto}.data-table table{width:100%;border-collapse:collapse}.data-table th{padding:var(--spacing-md);text-align:left;font-weight:600;color:var(--text-secondary);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-light)}.data-table td{padding:var(--spacing-md);border-bottom:1px solid var(--border-light)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background-color:var(--bg-secondary)}.table-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.table-action-btn{padding:var(--spacing-xs) var(--spacing-sm);border:none;background-color:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.table-action-btn:hover{background-color:var(--bg-secondary);color:var(--primary-color)}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0}.stat-label{color:var(--text-secondary);font-size:.9rem}.stat-value{font-weight:600;color:var(--text-primary)}.stats-container{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.pagination{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap}.pagination__info{color:var(--text-secondary);font-size:.875rem}.pagination__controls{display:flex;align-items:center;gap:var(--spacing-sm)}.pagination__button{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 var(--spacing-sm);border:1px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.pagination__button:hover:not(:disabled){background-color:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color)}.pagination__button:disabled{opacity:.5;cursor:not-allowed}.pagination__button--active{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.pagination__button--active:hover{background-color:var(--primary-hover);border-color:var(--primary-hover);color:#fff}.pagination__nav{font-weight:400;padding:0 var(--spacing-md);gap:var(--spacing-xs)}.pagination__nav svg{width:16px;height:16px}.pagination__ellipsis{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.pagination__per-page{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:.875rem}.pagination__per-page select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;cursor:pointer}.pagination--centered{justify-content:center}.pagination--centered .pagination__info{position:absolute;left:0}.pagination--compact .pagination__button{min-width:32px;height:32px;font-size:.8125rem}.pagination--simple .pagination__controls{gap:var(--spacing-md)}.pagination--loading{opacity:.6;pointer-events:none}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.pagination[data-animating=true]{animation:pageFadeIn .2s ease-out}@media (max-width: 768px){.pagination{flex-direction:column;gap:var(--spacing-md)}.pagination__info{order:2;text-align:center}.pagination__controls{order:1}.pagination__per-page{order:3;width:100%;justify-content:center}.pagination__button:not(.pagination__nav):not(.pagination__button--active){display:none}.pagination__button--active,.pagination__button--active+.pagination__button,.pagination__button--active+.pagination__ellipsis+.pagination__button{display:inline-flex}}@media (prefers-color-scheme: dark){.pagination__button{background-color:var(--bg-dark);border-color:var(--border-dark)}.pagination__button:hover:not(:disabled){background-color:var(--bg-dark-hover)}}.profile-layout{min-height:100vh;background-color:var(--bg-secondary)}.profile-container{margin:0 auto;padding:var(--spacing-lg)}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--border-light)}.stat-card{text-align:center}.stat-card__value{font-size:2rem;font-weight:700;color:var(--primary-color)}.stat-card__label{color:var(--text-secondary);font-size:.9rem}.profile-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-lg);border:1px solid var(--border-light)}.profile-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.profile-section__title{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.info-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.info-item{display:flex;justify-content:space-between;align-items:center}.info-item__label{color:var(--text-secondary);font-weight:500}.info-item__value{color:var(--text-primary);font-weight:600}.status-badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:500}.status-badge--active{background-color:var(--success-color);color:#fff}.status-badge--inactive{background-color:var(--error-color);color:#fff}.status-badge--pending{background-color:var(--warning-color);color:#fff}@media (max-width: 768px){.profile-stats{grid-template-columns:repeat(2,1fr)}}.user-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-light);border-left:3px solid transparent;transition:all .25s ease;cursor:pointer}.user-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px);border-left-color:var(--primary-color);background-color:var(--primary-light)}.user-avatar{width:48px;height:48px;border-radius:50%;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0;font-size:.95rem;letter-spacing:.5px;box-shadow:var(--shadow-primary)}.user-info{flex:1}.user-name{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.user-telegram,.user-username{margin:4px 0 0;font-size:.9rem;color:var(--text-secondary)}.label{font-weight:500}.user-actions{display:flex;gap:var(--spacing-sm)}.btn-icon{width:36px;height:36px;border:none;background-color:var(--primary-light);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--primary-color);transition:all .25s ease}.btn-icon:hover{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-primary);transform:scale(1.05)}.family-actions{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.family-actions--vertical{flex-direction:column}.family-actions--vertical .btn{width:100%}.families-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.family-card{background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-light);padding:var(--spacing-md);transition:all var(--transition-base)}.family-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-sm)}.family-card--simple{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg)}.family-header{flex:1}.family-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.family-name{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.family-meta{display:flex;align-items:center;gap:var(--spacing-md)}.member-count{color:var(--text-secondary);font-size:.9rem}.rol-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:.8125rem;font-weight:500}.rol-badge--admin{background-color:var(--primary-color);color:#fff}.rol-badge--miembro{background-color:var(--bg-gray);color:var(--text-primary)}.family-actions-simple{display:flex;gap:var(--spacing-sm);align-items:center}.family-actions-simple .btn{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.family-actions-simple .btn svg{margin:0}.family-details-modal{display:flex;flex-direction:column;gap:var(--spacing-lg)}.detail-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.detail-section h4{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.detail-item{display:flex;align-items:center;gap:var(--spacing-sm)}.detail-label{color:var(--text-secondary);font-size:.875rem;min-width:140px}.detail-value{color:var(--text-primary);font-weight:500;flex:1}.detail-value.code{font-family:monospace;background-color:var(--bg-primary);padding:4px 12px;border-radius:4px}.code-container{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.invitation-code-display{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0}.code-box{font-size:1.5rem;font-family:monospace;font-weight:700;letter-spacing:2px;padding:var(--spacing-lg);background-color:var(--bg-secondary);border:2px dashed var(--primary-color);border-radius:var(--radius-md);color:var(--primary-color)}.invitation-instructions{text-align:center;margin-top:var(--spacing-md)}.members-list{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-sm)}.member-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.member-info{display:flex;flex-direction:column}.member-name{font-weight:500;color:var(--text-primary)}.member-username{font-size:.875rem;color:var(--text-secondary)}.modal-content--large{max-width:600px}@media (max-width: 768px){.family-card--simple{flex-direction:column;gap:var(--spacing-md);align-items:stretch}.family-actions-simple{justify-content:space-between}.family-actions-simple .btn{flex:1;justify-content:center}.detail-item{flex-direction:column;align-items:flex-start}.code-container{width:100%}}.members-list::-webkit-scrollbar{width:6px}.members-list::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.members-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.members-list::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.budget-container{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.budget-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.budget-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.budget-stat{text-align:center;padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.budget-stat-label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.budget-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.budget-stat-value--positive{color:var(--success-color)}.budget-stat-value--negative{color:var(--error-color)}.budget-progress{margin:var(--spacing-lg) 0}.budget-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.budget-progress-label{font-size:.875rem;color:var(--text-secondary)}.budget-progress-percentage{font-size:.875rem;font-weight:600}.budget-progress-bar{width:100%;height:24px;background-color:var(--bg-secondary);border-radius:12px;overflow:hidden;position:relative}.budget-progress-fill{height:100%;background-color:var(--success-color);transition:width .3s ease,background-color .3s ease;position:relative;overflow:hidden}.budget-progress-fill:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:linear-gradient(45deg,rgba(255,255,255,.1) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.1) 50%,rgba(255,255,255,.1) 75%,transparent 75%,transparent);background-size:40px 40px;animation:budget-progress-stripes 1s linear infinite}@keyframes budget-progress-stripes{0%{background-position:0 0}to{background-position:40px 40px}}.budget-progress-fill--warning{background-color:var(--warning-color)}.budget-progress-fill--danger{background-color:var(--error-color)}.budget-recent-expenses{margin-top:var(--spacing-lg)}.budget-recent-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.budget-recent-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.budget-expense-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.budget-expense-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.budget-expense-item:hover{background-color:var(--bg-gray)}.budget-expense-info{display:flex;flex-direction:column}.budget-expense-name{font-weight:500;color:var(--text-primary)}.budget-expense-date{font-size:.75rem;color:var(--text-secondary)}.budget-expense-amount{font-weight:600;color:var(--text-primary)}.budget-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.budget-action-btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);background-color:var(--bg-primary);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.budget-action-btn:hover{background-color:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color)}.budget-empty{text-align:center;padding:var(--spacing-xl);background-color:var(--bg-secondary);border-radius:var(--radius-md);border:2px dashed var(--border-color)}.budget-empty-icon{font-size:3rem;margin-bottom:var(--spacing-md);opacity:.3}.budget-empty-text{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.budget-modal-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.budget-modal-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.budget-alert{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--warning-light);border:1px solid var(--warning-color);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.budget-alert-icon{flex-shrink:0;width:24px;height:24px;color:var(--warning-color)}.budget-alert-content{flex:1}.budget-alert-title{font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.budget-alert-message{font-size:.875rem;color:var(--text-secondary)}@media (max-width: 768px){.budget-stats{grid-template-columns:repeat(2,1fr)}.budget-modal-row{grid-template-columns:1fr}.budget-actions{flex-direction:column}.budget-expense-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}}@keyframes budget-update{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.budget-stat-value[data-updating=true]{animation:budget-update .3s ease-out}.budget-tooltip{position:relative;display:inline-block}.budget-tooltip:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--text-primary);color:var(--bg-primary);font-size:.75rem;border-radius:var(--radius-sm);white-space:nowrap;margin-bottom:var(--spacing-xs);z-index:10}.budget-tooltip:hover:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--text-primary);margin-bottom:-6px;z-index:10}.ticket-row{cursor:pointer;transition:background-color var(--transition-fast);-webkit-user-select:none;user-select:none}.ticket-row:hover{background-color:var(--bg-secondary)}.ticket-row--expanded{background-color:#0088cc0d;font-weight:500}.ticket-row--expanded:hover{background-color:#0088cc14}.ticket-familia{text-align:center}.familia-badge{display:inline-block;padding:2px 12px;background-color:var(--bg-secondary);border-radius:12px;font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.familia-badge--editable{cursor:pointer;transition:all var(--transition-fast);position:relative;padding-right:22px;-webkit-user-select:none;user-select:none}.familia-badge--editable:hover{background-color:var(--bg-gray);color:var(--primary-color);transform:translateY(-1px);box-shadow:var(--shadow-xs)}.edit-icon{position:absolute;right:6px;top:50%;transform:translateY(-50%);opacity:.6;transition:opacity var(--transition-fast)}.familia-badge--editable:hover .edit-icon{opacity:1}.select-familia-inline{min-width:120px;padding:4px 8px;font-size:.8125rem;border:2px solid var(--primary-color);border-radius:6px;background-color:var(--bg-primary);cursor:pointer;outline:none;box-shadow:0 0 0 3px #08c3}.saving-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fffffff2;padding:4px;border-radius:4px;z-index:10}.mini-loader{width:16px;height:16px;border:2px solid var(--bg-gray);border-top-color:var(--primary-color);border-radius:50%;animation:spin .6s linear infinite}.ticket-details-row{background-color:var(--bg-secondary);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.ticket-details-cell{padding:0;border-top:2px solid var(--primary-color)}.ticket-products{padding:var(--spacing-lg)}.products-container{background:var(--bg-primary);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.products-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.products-header h5{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.products-header-controls{display:flex;align-items:center;gap:var(--spacing-lg)}.familia-selector{display:flex;align-items:center;gap:var(--spacing-sm)}.familia-selector label{font-weight:500;color:var(--text-secondary);margin:0;line-height:1}.select-familia{padding:6px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);margin:0;height:32px;display:flex;align-items:center}.select-familia:hover{border-color:var(--primary-color)}.select-familia:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #08c3}.products-header-controls .btn{height:32px;display:inline-flex;align-items:center;padding:0 var(--spacing-md)}.products-table{width:100%;border-collapse:collapse;font-size:.9rem}.products-table th{text-align:left;padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid var(--border-color);font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.products-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-light);vertical-align:middle}.product-row{transition:background-color var(--transition-fast)}.product-row:hover{background-color:#00000005}.editable-cell{cursor:pointer;position:relative}.editable-cell:hover .editable-value{background-color:#0088cc0d;border-radius:var(--radius-sm);padding:2px 6px;margin:-2px -6px}.editable-value{display:inline-block;transition:all var(--transition-fast)}.input-inline{width:100%;padding:4px 8px;border:2px solid var(--primary-color);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;background-color:var(--bg-primary);box-shadow:0 0 0 3px #08c3;transition:all var(--transition-fast)}.input-inline:focus{outline:none}.input-inline.input-number,.text-center{text-align:center}.product-actions{display:flex;gap:var(--spacing-xs);justify-content:center}.btn-delete:hover{background-color:#f443361a;color:var(--error-color)}.total-row{font-weight:600;background-color:var(--bg-secondary);border-top:2px solid var(--border-color)}.total-row td{padding:var(--spacing-md);border:none}.ticket-total-value{font-size:1.25rem;color:var(--primary-color);font-weight:700}.category-badge{display:inline-block;padding:4px 12px;background-color:var(--bg-gray);border-radius:12px;font-size:.75rem;font-weight:500;color:var(--text-secondary);letter-spacing:.3px}.category-badge.editable-value{cursor:pointer}.subtotal{font-weight:600;color:var(--text-primary);text-align:right;font-size:.95rem}.products-loading{padding:var(--spacing-xl);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.products-loading .loader{width:32px;height:32px;border-width:3px}.modal-content--medium{max-width:500px}.modal-content--small{max-width:400px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.ticket-number{font-weight:600;color:var(--primary-color)}.tickets-filters{display:flex;gap:8px;padding:8px 12px;flex-wrap:wrap}.filter-btn{padding:4px 12px;border:1px solid #ddd;border-radius:16px;background:#fff;font-size:.8rem;cursor:pointer;transition:all .2s}.filter-btn:hover{background:#f5f5f5}.filter-btn.active{background:var(--primary-color, #1976d2);color:#fff;border-color:var(--primary-color, #1976d2)}.filter-btn--personal.active{background:#2e7d32;border-color:#2e7d32}.filter-btn--trabajo.active{background:#1565c0;border-color:#1565c0}.ticket-contexto .badge{font-size:.75rem;padding:2px 8px;border-radius:10px;white-space:nowrap}.ticket-contexto .badge--personal{background:#e8f5e9;color:#2e7d32}.ticket-contexto .badge--trabajo{background:#e3f2fd;color:#1565c0}.ticket-total{font-weight:600;text-align:right;font-size:1rem}.tickets-filter-label{font-size:.9rem;color:var(--primary-color);font-weight:500;font-style:italic}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.ticket-total-value.updating{animation:pulse .5s ease-out}@media (max-width: 768px){.products-table th:nth-child(4),.products-table td:nth-child(4){display:none}.products-table{font-size:.8125rem}.form-row{grid-template-columns:1fr}.products-header{flex-direction:column;gap:var(--spacing-md)}.products-header-controls{width:100%;flex-direction:column;gap:var(--spacing-sm)}.familia-selector,.select-familia{width:100%}.input-inline{font-size:.8125rem;padding:4px 6px}.product-actions{gap:2px}.btn-icon-sm{width:28px;height:28px}.btn-icon-sm svg{width:12px;height:12px}.ticket-products{padding:var(--spacing-md)}.products-container{padding:var(--spacing-sm)}}@media (hover: hover){.ticket-row:hover{background-color:var(--bg-secondary)}.editable-cell:hover .editable-value{text-decoration:underline;text-decoration-style:dotted;text-underline-offset:4px}}@media print{.product-actions,.products-header button,.familia-selector{display:none!important}.ticket-row--expanded{background-color:#fff!important}.products-table{border:1px solid #000}}.budget-section{margin-bottom:var(--spacing-lg)}.budget-loading{padding:var(--spacing-lg);text-align:center}.budget-empty{text-align:center;padding:var(--spacing-lg)}.budget-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.budget-content{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-md);background-color:var(--bg-primary)}.budget-content--collapsed{gap:0}.budget-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.budget-header__left,.budget-header__actions{display:flex;align-items:center;gap:var(--spacing-sm)}.btn-toggle{color:var(--text-secondary);cursor:pointer}.btn-toggle:hover{color:var(--primary-color)}.budget-name{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.budget-tag{font-size:.7rem;font-weight:500;padding:2px 8px;border-radius:var(--radius-full);background-color:var(--primary-light);color:var(--primary-color)}.budget-percentage{font-size:.875rem;font-weight:700}.budget-inline-progress{flex:1;display:flex;flex-direction:column;gap:2px;margin:0 var(--spacing-md);min-width:80px}.budget-inline-labels{position:relative;height:14px;width:100%;display:flex}.budget-inline-label{position:absolute;top:0;font-size:.65rem;font-weight:700;text-align:center;white-space:nowrap;line-height:14px}.budget-inline-label--remaining{color:var(--text-secondary)!important;font-weight:600;font-size:.6rem;text-align:right}.budget-inline-bar{width:100%;height:12px;background-color:var(--bg-secondary);border-radius:6px;overflow:hidden;position:relative}.budget-inline-segment{position:absolute;height:100%;transition:width .3s ease;border-right:1px solid rgba(255,255,255,.4)}.budget-inline-segment:first-child{border-top-left-radius:6px;border-bottom-left-radius:6px}.budget-inline-segment:last-child{border-right:none}.budget-stats{display:flex;flex-direction:column;gap:var(--spacing-md)}.budget-amounts{display:flex;justify-content:space-between;gap:var(--spacing-md)}.budget-stat{display:flex;flex-direction:column;align-items:center;flex:1}.budget-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.budget-value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.budget-progress{margin-top:var(--spacing-sm)}.progress-bar{width:100%;height:24px;background-color:var(--bg-secondary);border-radius:12px;overflow:hidden;position:relative}.progress-segments{height:100%;position:relative;display:flex}.progress-segment{position:absolute;height:100%;transition:width .3s ease;border-right:1px solid rgba(255,255,255,.2)}.progress-segment:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}.progress-segment:last-child{border-right:none}.progress-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:10px}.progress-success{background-color:var(--success-color)}.progress-warning{background-color:var(--warning-color)}.progress-danger{background-color:var(--error-color)}.progress-text{text-align:center;margin-top:var(--spacing-xs);font-size:.875rem;color:var(--text-secondary)}.budget-breakdown{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.breakdown-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.breakdown-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-lighter)}.breakdown-item:last-child{border-bottom:none}.breakdown-user{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem}.breakdown-color-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.breakdown-name{flex:1;font-weight:600;color:var(--text-primary)}.breakdown-amount{font-weight:600;color:var(--text-primary)}.breakdown-percentage{font-size:.75rem;color:var(--text-secondary)}.breakdown-bar-container{display:flex;flex-direction:column;gap:4px}.breakdown-bar{width:100%;height:8px;background-color:var(--bg-secondary);border-radius:4px;overflow:hidden}.breakdown-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.breakdown-bar-label{font-size:.7rem;color:var(--text-tertiary);font-style:italic}.btn-add-budget{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px dashed var(--border-color);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .25s ease}.btn-add-budget:hover{border-color:var(--primary-color);color:var(--primary-color);background-color:var(--primary-light)}@media (max-width: 768px){.budget-amounts{flex-direction:column}.budget-stat{flex-direction:row;justify-content:space-between}}.add-method-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-light)}.tab-button{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.tab-button:hover{color:var(--text-primary)}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.text-sm{font-size:.875rem}.add-members-content form{display:flex;flex-direction:column;gap:var(--spacing-md)}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.family-actions--vertical{margin-top:var(--spacing-md)}.modal-action-buttons{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--border-light);margin-top:var(--spacing-lg);flex-wrap:wrap}.modal-action-buttons .btn{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.modal-action-buttons svg{flex-shrink:0}.role-container{display:flex;align-items:center}.editable-role{cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:all .2s ease;position:relative}.editable-role:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.edit-icon{opacity:0;transition:opacity .2s ease;margin-left:2px}.editable-role:hover .edit-icon{opacity:.7}.role-editor{display:flex;gap:8px;align-items:center}.role-select{padding:4px 8px;border-radius:4px;border:1px solid #e5e7eb;background:#fff;font-size:.875rem;min-width:100px;color:var(--text-primary)}.role-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f61a}.btn-role-action{width:24px;height:24px;border-radius:4px;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:700;transition:all .2s ease}.btn-confirm{background:#10b981;color:#fff}.btn-confirm:hover:not(:disabled){background:#059669}.btn-confirm:disabled{opacity:.5;cursor:not-allowed}.btn-cancel{background:#ef4444;color:#fff}.btn-cancel:hover{background:#dc2626}.modal-content--xlarge{max-width:900px;width:90%;max-height:85vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:1.25rem;color:#111827}.btn-close{background:none;border:none;padding:4px;cursor:pointer;color:#6b7280;transition:color .2s;display:flex;align-items:center;justify-content:center}.btn-close:hover{color:#374151}.profile-header{display:flex;justify-content:flex-end;position:relative;margin-bottom:-24px;z-index:50}.profile-menu-trigger{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:background-color .15s ease,color .15s ease;-webkit-user-select:none;user-select:none}.profile-menu-trigger:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.profile-menu-trigger:active{background-color:var(--border-light)}.avatar-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 30px #0000001f,0 2px 8px #0000000f;z-index:100}.avatar-dropdown__user{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-md) var(--spacing-xs)}.avatar-dropdown__avatar-sm{width:40px;height:40px;min-width:40px;border-radius:var(--radius-full);background:var(--gradient-primary);color:var(--text-white);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700}.avatar-dropdown__info{display:flex;flex-direction:column;gap:1px;min-width:0}.avatar-dropdown__name{font-size:.95rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.avatar-dropdown__meta{font-size:.75rem;color:var(--text-secondary)}.avatar-dropdown__badges{display:flex;gap:6px;padding:var(--spacing-xs) var(--spacing-md) var(--spacing-sm);flex-wrap:wrap}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:12px;font-size:.7rem;font-weight:600;letter-spacing:.3px}.badge--role{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-primary)}.avatar-dropdown__divider{height:1px;background:var(--border-light);margin:0}.avatar-dropdown__item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:10px var(--spacing-md);border:none;background:none;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--text-primary);transition:background-color .15s ease;text-align:left}.avatar-dropdown__item:hover{background-color:var(--bg-secondary)}.avatar-dropdown__item svg{color:var(--text-secondary);flex-shrink:0}.avatar-dropdown__item:hover svg{color:var(--primary-color)}.avatar-dropdown__chevron{margin-left:auto;transition:transform .25s ease;color:var(--text-light)}.avatar-dropdown__chevron--open{transform:rotate(180deg)}.avatar-dropdown__item--danger{color:var(--error-color, #e53e3e)}.avatar-dropdown__item--danger:hover{background-color:#e53e3e0f}.avatar-dropdown__item--danger svg{color:var(--error-color, #e53e3e)}.avatar-dropdown__appearance{padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md)}@media (max-width: 480px){.avatar-dropdown{width:260px;right:-8px}.profile-menu-trigger{width:36px;height:36px}}.messages-section{display:flex;flex-direction:column;height:100vh;background-color:var(--bg-primary);border-radius:0;overflow:visible;position:relative}.messages-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-bottom:1px solid var(--border-light);flex-shrink:0;position:relative}.messages-header__avatar{width:40px;height:40px;min-width:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700}.messages-header__info{display:flex;flex-direction:column;gap:1px;min-width:0}.messages-header__name{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-header__context{font-size:.75rem;color:var(--text-secondary)}.messages-header__menu{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:background-color .15s ease,color .15s ease;flex-shrink:0}.messages-header__menu:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.messages-menu-dropdown{position:absolute;top:calc(100% + 4px);right:var(--spacing-lg);width:320px;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 30px #0000001f,0 2px 8px #0000000f;z-index:100;max-height:80vh;overflow-y:auto}.menu-dropdown__user{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-md) var(--spacing-xs)}.menu-dropdown__avatar-sm{width:40px;height:40px;min-width:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700}.menu-dropdown__info{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}.menu-dropdown__header-actions{display:flex;gap:4px;flex-shrink:0}.menu-dropdown__header-btn{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);background:none;border:none;transition:background-color .15s ease,color .15s ease}.menu-dropdown__header-btn:hover{background-color:var(--bg-tertiary, #f0f0f0);color:var(--text-primary)}.menu-dropdown__header-btn--danger:hover{color:var(--color-error, #e53e3e)}.menu-dropdown__name{font-size:.95rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-dropdown__meta{font-size:.75rem;color:var(--text-secondary)}.menu-dropdown__badges{display:flex;gap:6px;padding:var(--spacing-xs) var(--spacing-md) var(--spacing-sm);flex-wrap:wrap}.menu-dropdown__badge-role{display:inline-flex;align-items:center;padding:3px 10px;border-radius:12px;font-size:.7rem;font-weight:600;letter-spacing:.3px;background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-primary)}.menu-dropdown__divider{height:1px;background:var(--border-light);margin:0}.menu-dropdown__item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:10px var(--spacing-md);border:none;background:none;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--text-primary);transition:background-color .15s ease;text-align:left}.menu-dropdown__item:hover{background-color:var(--bg-secondary)}.menu-dropdown__item svg{color:var(--text-secondary);flex-shrink:0}.menu-dropdown__item:hover svg{color:var(--primary-color)}.menu-dropdown__chevron{margin-left:auto;transition:transform .25s ease;color:var(--text-light)}.menu-dropdown__chevron--open{transform:rotate(180deg)}.menu-dropdown__item--danger{color:var(--error-color, #e53e3e)}.menu-dropdown__item--danger:hover{background-color:#e53e3e0f}.menu-dropdown__item--danger svg{color:var(--error-color, #e53e3e)}.menu-dropdown__appearance{padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md)}.menu-dropdown__module-content{position:relative;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md);max-height:350px;overflow-y:auto;border-bottom:1px solid var(--border-light)}.menu-dropdown__pin-btn{position:absolute;top:8px;right:8px;background:none;border:none;cursor:pointer;color:#e53e3e;padding:4px;border-radius:4px;line-height:1;z-index:1;transform:rotate(20deg);opacity:.4;transition:opacity .15s ease}.menu-dropdown__pin-btn--active{opacity:1}.menu-dropdown__pin-btn:hover{background:#e53e3e1a;opacity:1}.menu-dropdown__section-label{font-size:.7rem;text-transform:uppercase;color:var(--text-light, #999);padding:8px 16px 4px;letter-spacing:.5px;font-weight:600}.menu-dropdown__check{width:16px;height:16px;border:1.5px solid var(--border-color, #ddd);border-radius:3px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.menu-dropdown__check--active{background:var(--primary-color, #1a73e8);border-color:var(--primary-color, #1a73e8);color:#fff}.dropdown-enter-active{transition:opacity .18s ease,transform .18s ease}.dropdown-leave-active{transition:opacity .12s ease,transform .12s ease}.dropdown-enter-from{opacity:0;transform:translateY(-6px) scale(.97)}.dropdown-leave-to{opacity:0;transform:translateY(-4px) scale(.98)}.expand-enter-active{transition:all .25s ease;overflow:hidden}.expand-leave-active{transition:all .2s ease;overflow:hidden}.expand-enter-from,.expand-leave-to{opacity:0;max-height:0;padding-top:0;padding-bottom:0}.expand-enter-to,.expand-leave-from{opacity:1;max-height:300px}.messages-filter-label{font-size:.85rem;color:var(--primary-color);font-weight:400;font-style:italic}.pinned-modules{position:relative;z-index:auto;padding:16px 20px;display:flex;flex-direction:column;gap:10px;align-items:flex-start}.pinned-module{position:relative;border:1px solid var(--border-light, #eee);border-radius:14px;overflow:visible;background:var(--bg-primary, #fff);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;width:100%;max-width:100%;min-width:0;transition:box-shadow .2s ease}.pinned-module:hover{box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a}.pinned-module__header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:transparent;border:none;border-bottom:1px solid var(--border-light, #eee);cursor:grab;font-weight:600;font-size:.9rem;color:var(--text-primary, #212121);letter-spacing:.01em}.pinned-module__header:active{cursor:grabbing}.pinned-module__header:hover{background:var(--bg-secondary, #f5f5f5)}.pinned-module__actions{display:flex;align-items:center;gap:8px;touch-action:manipulation}.pinned-module__chevron{transition:transform .2s ease;font-size:.75rem;color:var(--text-light)}.pinned-module__chevron--open{transform:rotate(180deg)}.pinned-module__close{font-size:1rem;color:var(--text-light, #9e9e9e);cursor:pointer;line-height:1;padding:4px;touch-action:manipulation;opacity:.5;transition:opacity .15s,color .15s}.pinned-module__close:hover{color:var(--error-color, #e53e3e);opacity:1}.pinned-module__content{padding:8px 10px;max-height:350px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin}.pinned-module__content::-webkit-scrollbar{width:4px}.pinned-module__content::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}.pinned-module__maximize{background:none;border:none;color:var(--text-light);cursor:pointer;padding:4px;min-width:24px;min-height:24px;display:flex;align-items:center;justify-content:center;line-height:1;transition:color .15s;touch-action:manipulation}.pinned-module__maximize:hover{color:var(--primary-color)}.pinned-module__resize{position:absolute;z-index:2;touch-action:none}.pinned-module__resize--s{bottom:-3px;left:8px;right:8px;height:6px;cursor:s-resize}.pinned-module__resize--e{right:-3px;top:8px;bottom:8px;width:6px;cursor:e-resize}.pinned-module__resize--w{left:-3px;top:8px;bottom:8px;width:6px;cursor:w-resize}.pinned-module__resize--se{bottom:-3px;right:-3px;width:14px;height:14px;cursor:se-resize}.pinned-module__resize--sw{bottom:-3px;left:-3px;width:14px;height:14px;cursor:sw-resize}.pinned-module--maximized{position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;border-radius:0;border:none;width:100%!important;height:100%!important;max-width:none}.pinned-module--maximized .pinned-module__content{height:calc(100% - 44px)!important;max-height:none!important}.profile-section--pinned{padding:var(--spacing-sm);box-shadow:none;border:none;border-radius:0}@media (max-width: 768px){.pinned-modules{padding:8px 12px}.pinned-module__header{padding:8px 12px;font-size:.82rem}.pinned-module__resize--s{height:12px}.pinned-module__resize--e,.pinned-module__resize--w{width:12px}.pinned-module__resize--se,.pinned-module__resize--sw{width:22px;height:22px}}@media (max-width: 480px){.pinned-modules{padding:6px 8px}}.messages-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);gap:var(--spacing-md)}.messages-container-wrapper{flex:1;min-height:0;position:relative;display:flex;flex-direction:column;overflow:hidden}.messages-container{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg-secondary);display:flex;flex-direction:column;gap:3px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:transparent}.messages-container::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.messages-container::-webkit-scrollbar-thumb:hover{background:#00000040}.scroll-sentinel-top{min-height:1px;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs) 0}.loading-more-indicator{display:flex;align-items:center;gap:var(--spacing-sm);padding:6px 16px;background:#0000000a;border-radius:16px;font-size:.8rem;color:var(--text-secondary)}.no-more-messages{padding:6px 16px;color:var(--text-light);font-size:.75rem;font-style:italic}.date-separator{display:flex;justify-content:center;padding:var(--spacing-md) 0 var(--spacing-sm)}.date-separator__pill{background:#0000000f;color:var(--text-secondary);font-size:.75rem;font-weight:500;padding:4px 14px;border-radius:12px;letter-spacing:.01em}.message-item{padding:8px 12px;border-radius:18px;max-width:75%;position:relative;word-wrap:break-word;overflow-wrap:break-word;animation:msgAppear .2s ease-out}@keyframes msgAppear{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.message-item--user{align-self:flex-end;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:18px 18px 4px;box-shadow:0 1px 3px #667eea40}.message-item--bot{align-self:flex-start;background:var(--bg-primary);color:var(--text-primary);border-radius:18px 18px 18px 4px;box-shadow:0 1px 2px #0000000f}.message-item--json{align-self:flex-start;font-family:Courier New,monospace;background:#f8f9fa;border-left:3px solid var(--warning-color);border-radius:4px;max-width:90%;overflow:hidden}.message-item--json .message-content{overflow-x:auto}.message-item--json pre{margin:0;padding:var(--spacing-xs);font-size:.7rem;line-height:1.3;white-space:pre-wrap;word-wrap:break-word;word-break:break-all}.message-item--context{align-self:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;max-width:60%;font-size:.85rem;border-radius:16px}.message-content{word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.message-text{line-height:1.45;font-size:.9rem}.message-item--user .message-text{color:#fff}.message-time{display:block;text-align:right;font-size:.65rem;opacity:.55;margin-top:2px;line-height:1}.message-item--user .message-time{color:#ffffffb3}.message-item--typing{padding:12px 16px;width:fit-content}.typing-indicator{display:flex;gap:4px;align-items:center}.typing-indicator span{width:8px;height:8px;background:var(--text-light);border-radius:50%;animation:typingDot 1.4s ease-in-out infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);gap:var(--spacing-xs)}.empty-icon{font-size:2.5rem;opacity:.25}.empty-hint{font-size:.8rem;color:var(--text-light)}.scroll-to-bottom-btn{position:absolute;bottom:16px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-light);box-shadow:0 2px 8px #0000001f;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.scroll-to-bottom-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:scale(1.08)}.chat-input-section{flex-shrink:0;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border-top:1px solid var(--border-light)}.chat-input-wrapper{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border-radius:24px;padding:4px 4px 4px 12px;border:1px solid var(--border-light);transition:border-color .2s ease}.chat-input-wrapper:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f614}.chat-input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:.9rem;padding:8px 4px;outline:none;min-width:0}.chat-input::placeholder{color:var(--text-light)}.chat-input:disabled{opacity:.5}.btn-attach{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;cursor:pointer;color:var(--text-secondary);transition:color .15s ease;flex-shrink:0}.btn-attach:hover{color:var(--primary-color)}.btn-attach.disabled{opacity:.4;pointer-events:none}.btn-mic{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;border:none;background:var(--primary-color);color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-mic:hover:not(:disabled){filter:brightness(1.1);transform:scale(1.05)}.btn-mic:disabled{opacity:.5;cursor:not-allowed}.btn-send{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;border:none;background:var(--primary-color);color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-send:hover:not(:disabled){filter:brightness(1.1);transform:scale(1.05)}.btn-send:disabled{opacity:.5;cursor:not-allowed}.recording-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px 16px;background:#ef44440f;border-radius:24px;border:1px solid rgba(239,68,68,.15)}.recording-dot{width:10px;height:10px;background:#ef4444;border-radius:50%;animation:blink 1s infinite;flex-shrink:0}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.recording-time{font-size:.9rem;font-weight:600;color:#ef4444;font-variant-numeric:tabular-nums}.recording-bar__spacer{flex:1}.btn-stop-recording{padding:6px 14px;border-radius:16px;border:1px solid rgba(239,68,68,.3);background:transparent;color:#ef4444;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-stop-recording:hover{background:#ef44441a}.btn-send-recording{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;border:none;background:#ef4444;color:#fff;cursor:pointer;transition:all .15s ease}.btn-send-recording:hover{filter:brightness(1.1)}.copy-notification{position:absolute;bottom:80px;left:50%;transform:translate(-50%);background:var(--text-primary);color:var(--bg-primary);padding:8px 20px;border-radius:20px;font-size:.8rem;font-weight:500;box-shadow:0 4px 12px #00000026;z-index:20}.loader.loader-sm{width:14px;height:14px;border-width:2px}.fade-enter-active{transition:opacity .2s ease}.fade-leave-active{transition:opacity .15s ease}.slide-fade-enter-active{transition:all .3s ease}.slide-fade-leave-active{transition:all .2s ease}.slide-fade-enter-from,.slide-fade-leave-to{opacity:0;transform:translate(-50%) translateY(10px)}@media (max-width: 768px){.messages-section{height:100vh}.messages-container{padding:var(--spacing-sm)}.message-item{max-width:88%}.message-item--json{max-width:95%}.message-item--context{max-width:85%}.chat-input-section{padding:var(--spacing-xs) var(--spacing-sm)}}@media (max-width: 480px){.messages-menu-dropdown{width:280px;right:var(--spacing-sm)}.message-item{max-width:92%;padding:6px 10px;font-size:.85rem}.chat-input{font-size:16px}}.message-buttons{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.message-btn{padding:6px 14px;border:1px solid var(--border-primary, #d0d0d0);border-radius:16px;background:var(--bg-primary, #fff);color:var(--primary-color, #6366f1);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap;line-height:1.3}.message-btn:hover:not(:disabled){background:var(--primary-color, #6366f1);color:#fff;border-color:var(--primary-color, #6366f1)}.message-btn:active:not(:disabled){transform:scale(.96)}.message-btn:disabled{opacity:.45;cursor:not-allowed}.message-btn--processing{opacity:.6;pointer-events:none}.message-btn--processing:after{content:" ..."}.message-text pre{font-family:Courier New,monospace;font-size:.85em;white-space:pre;overflow-x:auto;margin:6px 0;padding:0;background:transparent;line-height:1.4}.message-json-container{background:linear-gradient(135deg,#1e1e2e,#2d2d44);border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0003;border:1px solid rgba(255,255,255,.1);margin:var(--spacing-sm) 0}.json-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1)}.json-label{color:#fff;font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:8px}.json-copy-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:.75rem;cursor:pointer;transition:all .2s ease}.json-copy-btn:hover{background:#fff3;transform:translateY(-1px)}.json-copy-btn:active{transform:translateY(0)}.json-content{margin:0;padding:20px;background:transparent;font-family:JetBrains Mono,Fira Code,Monaco,Consolas,monospace;font-size:.85rem;line-height:1.7;color:#e0e0e0;overflow-x:auto;max-height:500px;overflow-y:auto;-moz-tab-size:2;tab-size:2;white-space:pre}.json-content::-webkit-scrollbar{width:8px;height:8px}.json-content::-webkit-scrollbar-track{background:#ffffff0d}.json-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.json-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.json-string{color:#a6e22e;font-weight:500}.json-key{color:#66d9ef;font-weight:600}.json-number{color:#fd971f;font-weight:500}.json-boolean{color:#ae81ff;font-weight:600}.json-null{color:#75715e;font-style:italic}.json-bracket{color:#999;font-weight:400}.message-item--json{background:transparent!important;border:none!important;padding:0!important;max-width:95%}.message-item--json .message-content{padding:0;max-width:100%;overflow-x:hidden!important}.copy-notification{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 24px;border-radius:24px;box-shadow:0 4px 20px #667eea66;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:8px;z-index:1000}.copy-notification svg{color:#4ade80}.slide-fade-enter-active{transition:all .3s ease-out}.slide-fade-leave-active{transition:all .3s ease-in}.slide-fade-enter-from{transform:translate(-50%) translateY(20px);opacity:0}.slide-fade-leave-to{transform:translate(-50%) translateY(-20px);opacity:0}.scroll-sentinel-top{min-height:1px;padding:var(--spacing-sm) 0}.loading-more-indicator{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);color:var(--text-secondary);font-size:.875rem}.loader-sm{width:16px;height:16px;border-width:2px}.no-more-messages{text-align:center;padding:var(--spacing-md);color:var(--text-secondary);font-size:.875rem;font-style:italic;opacity:.7}.scroll-to-bottom-btn{position:fixed;bottom:100px;right:30px;width:48px;height:48px;border-radius:var(--radius-full);background:var(--primary-color);color:#fff;border:none;box-shadow:var(--shadow-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:100}.scroll-to-bottom-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl);background:var(--primary-hover)}.scroll-to-bottom-btn:active{transform:translateY(0)}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}@media (max-width: 768px){.scroll-to-bottom-btn{bottom:80px;right:20px;width:44px;height:44px}.json-content{font-size:.7rem;padding:12px}.json-header{padding:8px 12px}.json-copy-btn span{display:none}.message-item--json{margin-right:2%;font-size:.75rem}}.messages-container{overflow-x:hidden!important;overflow-y:auto!important}.ticket-telegram-view{background:#e8f5e9;border-radius:12px;padding:16px;font-family:system-ui;line-height:1.6;max-width:95%;margin:8px 0}.ticket-telegram-view .ticket-header{margin-bottom:12px;font-weight:500}.ticket-telegram-view .ticket-products{margin:12px 0;white-space:pre-line}.ticket-telegram-view .ticket-total{margin-top:12px;padding-top:8px;border-top:1px solid #c8e6c9;font-weight:600}.tickets-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-lg)}.tickets-container{position:relative;max-height:600px;overflow-y:auto;overflow-x:hidden}.tickets-container--small{max-height:400px}.tickets-container--large{max-height:800px}.tickets-table{width:100%;position:relative}.tickets-table thead{position:sticky;top:0;z-index:10;background-color:var(--bg-secondary)}.tickets-table thead th{background-color:var(--bg-secondary);box-shadow:0 2px 2px -1px #0000001a}.tickets-container::-webkit-scrollbar{width:8px}.tickets-container::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:var(--radius-sm)}.tickets-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-sm)}.tickets-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.tickets-footer{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.tickets-empty{text-align:center;padding:var(--spacing-xxl) var(--spacing-lg);color:var(--text-secondary)}.tickets-empty__icon{font-size:3rem;opacity:.3;margin-bottom:var(--spacing-md)}.tickets-empty__text{font-size:1.1rem;margin:0}.tickets-loading{display:flex;justify-content:center;align-items:center;min-height:300px}.tickets-filters{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-wrap:wrap}.tickets-filter{display:flex;align-items:center;gap:var(--spacing-sm)}.tickets-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);color:var(--text-secondary);font-size:.875rem}@media (max-width: 768px){.tickets-container{max-height:400px}.tickets-info{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.tickets-filters{flex-direction:column;width:100%}.tickets-filter{width:100%}}.select-all-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;color:var(--text-secondary);cursor:pointer}.select-all-checkbox{cursor:pointer}.product-checkbox{width:18px;height:18px;cursor:pointer;flex-shrink:0}.product-actions{display:flex;align-items:center;gap:var(--spacing-md)}.btn-sm:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.section-actions{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.select-all-label{justify-content:center}.product-item{flex-wrap:wrap}.product-actions{width:100%;justify-content:space-between}}.expense-summary{padding:0}.expense-breakdown{display:flex;flex-direction:column;gap:var(--spacing-sm)}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);margin-bottom:var(--spacing-sm);background-color:var(--bg-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative;border:2px solid transparent}.breakdown-item--clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.breakdown-item--clickable:hover{transform:translate(4px);box-shadow:var(--shadow-sm);background-color:var(--bg-gray)}.breakdown-item--active{border-color:var(--primary-color);background-color:#0088cc0d}.breakdown-item--active:hover{transform:translate(4px);box-shadow:0 4px 12px #08c3;background-color:#0088cc14}.breakdown-header{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.breakdown-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--transition-fast)}.breakdown-icon.personal{background-color:#2196f31a;color:#2196f3}.breakdown-icon.family{background-color:#4caf501a;color:#4caf50}.breakdown-icon.family--active{background-color:#0088cc26;color:var(--primary-color);transform:scale(1.1)}.breakdown-item--clickable:hover .breakdown-icon{transform:scale(1.05)}.breakdown-item--active:hover .breakdown-icon{transform:scale(1.15)}.breakdown-info{flex:1}.breakdown-name{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.active-badge{display:inline-flex;align-items:center;padding:2px 8px;background-color:var(--primary-color);color:#fff;font-size:.75rem;font-weight:500;border-radius:12px;letter-spacing:.5px}.breakdown-amount{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:4px}.amount-value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.amount-percentage{font-size:.875rem;color:var(--text-secondary);font-weight:500}.breakdown-item--active .amount-value{color:var(--primary-color)}@media (max-width: 768px){.breakdown-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.breakdown-header{width:100%}.breakdown-amount{width:100%;flex-direction:row;justify-content:space-between;align-items:center}.active-badge{font-size:.7rem;padding:1px 6px}}.product-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-light)}.product-item:last-child{border-bottom:none}.product-checkbox{width:18px;height:18px;cursor:pointer}.product-label{flex:1;cursor:pointer;display:flex;align-items:center;gap:var(--spacing-sm)}.product-name{color:var(--text-primary)}.product-quantity{font-size:.875rem;color:var(--text-secondary)}.product-price{font-weight:600;color:var(--text-primary);font-size:.95rem}.product-list{padding:var(--spacing-md)}@media (max-width: 768px){.product-item{flex-wrap:wrap}.product-price{width:100%;text-align:right;margin-top:var(--spacing-xs)}}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-subtitle{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.section-actions{display:flex;gap:var(--spacing-sm)}.section-content{padding:var(--spacing-md)}@media (max-width: 768px){.section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.section-actions{width:100%;justify-content:flex-end}}.login-container{width:100%;max-width:400px;background-color:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-xl);border:1px solid rgba(255,255,255,.3)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-title{font-size:2rem;color:var(--primary-color);margin-bottom:var(--spacing-sm);font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:1rem}.login-form{margin-bottom:var(--spacing-lg)}.login-help{padding-top:var(--spacing-lg);border-top:1px solid var(--border-light)}.main-content{padding:var(--spacing-xl) 0;min-height:calc(100vh - 80px);background-color:var(--bg-secondary)}.header-title{margin:0;font-size:1.5rem;color:var(--text-primary)}.header-subtitle{margin:4px 0 0;color:var(--text-secondary);font-size:.9rem}.dashboard-controls{display:grid;grid-template-columns:auto 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);align-items:start}.stats-card{background:var(--gradient-primary);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-primary);text-align:center;min-width:150px}.stats-number{font-size:2.5rem;font-weight:700;color:#fff;margin:0}.stats-label{margin:8px 0 0;color:#ffffffd9;font-size:.9rem}.search-box{background-color:var(--bg-primary);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.users-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-lg);border:1px solid var(--border-light)}.section-title{margin:0 0 var(--spacing-lg) 0;font-size:1.25rem;color:var(--text-primary)}.users-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.empty-message{color:var(--text-secondary);font-size:1rem}@media (max-width: 768px){.dashboard-controls{grid-template-columns:1fr}.stats-card{width:100%}.header-content{flex-direction:column;align-items:start;gap:var(--spacing-md)}}.m-0{margin:0}.m-1{margin:var(--spacing-xs)}.m-2{margin:var(--spacing-sm)}.m-3{margin:var(--spacing-md)}.m-4{margin:var(--spacing-lg)}.m-5{margin:var(--spacing-xl)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-5{margin-top:var(--spacing-xl)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mb-5{margin-bottom:var(--spacing-xl)}.p-0{padding:0}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.p-5{padding:var(--spacing-xl)}.d-none{display:none}.d-block{display:block}.d-grid{display:grid}.flex-column{flex-direction:column}.flex-wrap{flex-wrap:wrap}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.align-center{align-items:center}.gap-1{gap:var(--spacing-xs)}.gap-3{gap:var(--spacing-md)}.gap-4{gap:var(--spacing-lg)}.text-right{text-align:right}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.fw-normal{font-weight:400}.fw-medium{font-weight:500}.fw-semibold{font-weight:600}.fw-bold{font-weight:700}.show-mobile{display:none}.hide-mobile{display:block}@media (max-width: 768px){.show-mobile{display:block}.hide-mobile{display:none}}.no-details{text-align:center;color:var(--text-secondary);padding:var(--spacing-md)}.text-warning{color:var(--warning-color);font-weight:500}.text-info{color:var(--info-color)}.text-danger{color:var(--error-color)}.state-message{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);text-align:center}.state-message--empty{color:var(--text-secondary)}.state-message--loading{color:var(--primary-color)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary)}.empty-state p:first-child{font-size:1.1rem;margin-bottom:var(--spacing-sm)}#app{min-height:100vh}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px var(--spacing-lg);font-size:.9375rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-decoration:none;letter-spacing:.01em}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-2px);box-shadow:var(--shadow-primary),var(--shadow-md)}.btn-primary:active:not(:disabled){transform:translateY(0);filter:brightness(.95)}.btn-secondary{background-color:var(--primary-light);color:var(--primary-color);border:1.5px solid var(--primary-color)}.btn-secondary:hover:not(:disabled){background-color:var(--primary-color);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-block{width:100%}.card{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-lg);transition:box-shadow var(--transition-fast)}.text-center{text-align:center}.text-error{color:var(--error-color)}.text-success{color:var(--success-color)}.text-warning{color:var(--warning-color)}.text-muted{color:var(--text-secondary)}.message{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.message-error{background-color:#ffebee;color:var(--error-color);border:1px solid #ffcdd2}.loader{display:inline-block;width:20px;height:20px;border:3px solid var(--bg-gray);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.d-flex{display:flex}.gap-2{gap:var(--spacing-sm)}.mt-4{margin-top:var(--spacing-lg)}
