.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background-color:var(--color-bg-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-normal);overflow:hidden}.sidebar--collapsed{width:var(--sidebar-width-collapsed)}.sidebar__logo{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-md);border-bottom:1px solid var(--color-border);min-height:80px}.sidebar__logo-icon{flex-shrink:0;filter:drop-shadow(0 2px 8px rgba(28,184,202,.3))}.sidebar__logo-icon--upload{position:relative;cursor:pointer;border-radius:var(--radius-full);overflow:hidden}.sidebar__logo-img{width:42px;height:42px;border-radius:var(--radius-full);object-fit:cover}.sidebar__logo-camera{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000080;color:#fff;opacity:0;transition:opacity .15s;border-radius:var(--radius-full)}.sidebar__logo-icon--upload:hover .sidebar__logo-camera{opacity:1}.sidebar__user-initials{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:var(--color-primary);color:#fff;font-size:13px;font-weight:var(--weight-semibold);border-radius:var(--radius-full)}.sidebar__upload-spinner{width:42px;height:42px;border-radius:var(--radius-full);border:3px solid rgba(255,255,255,.2);border-top-color:#fff;animation:spin .7s linear infinite}.sidebar__upload-spinner--sm{width:100%;height:100%;border-width:2px}.sidebar__logo-text{font-size:var(--font-lg);font-weight:var(--weight-extrabold);color:#fff;letter-spacing:.1em;white-space:nowrap}.sidebar__nav{flex:1;padding:var(--space-md) var(--space-sm);overflow-y:auto;overflow-x:hidden}.sidebar__nav-list{display:flex;flex-direction:column;gap:2px}.sidebar__nav-link{position:relative;display:flex;align-items:center;gap:var(--space-sm);padding:10px 12px;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-md);font-weight:var(--weight-medium);transition:all var(--transition-fast);white-space:nowrap;overflow:hidden;text-decoration:none}.sidebar__nav-link:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar__nav-link--active{background:var(--color-primary-dim);color:var(--color-primary);font-weight:var(--weight-semibold)}.sidebar__nav-link--active:hover{background:var(--color-primary-dim);color:var(--color-primary)}.sidebar__nav-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px}.sidebar__nav-label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar__nav-arrow{flex-shrink:0;opacity:.4;transition:opacity var(--transition-fast)}.sidebar__nav-link:hover .sidebar__nav-arrow{opacity:.7}.sidebar__nav-link--active .sidebar__nav-arrow{opacity:1;color:var(--color-primary)}.sidebar__nav-indicator{position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--color-primary);border-radius:var(--radius-full) 0 0 var(--radius-full)}.sidebar__user{position:relative;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);border-top:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast);border-radius:0}.sidebar__user:hover{background:var(--color-bg-hover)}.sidebar__user-avatar{flex-shrink:0;position:relative;width:36px;height:36px;border-radius:var(--radius-full);overflow:hidden;border:2px solid var(--color-primary-border)}.sidebar__user-avatar--upload{cursor:pointer}.sidebar__avatar-camera{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000080;color:#fff;opacity:0;transition:opacity .15s;border-radius:var(--radius-full)}.sidebar__user-avatar--upload:hover .sidebar__avatar-camera{opacity:1}.sidebar__user-avatar-img{width:100%;height:100%;object-fit:cover}.sidebar__user-info{flex:1;overflow:hidden}.sidebar__user-name{display:block;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-role{display:block;font-size:var(--font-xs);color:var(--color-text-muted);white-space:nowrap}.sidebar__user-menu{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);color:var(--color-text-muted);transition:color var(--transition-fast)}.sidebar__user-menu:hover{color:var(--color-text-primary)}.sidebar__user-menu--open{color:var(--color-text-primary);background:#ffffff14}.sidebar__user-dropdown{margin:0 8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);overflow:hidden}.sidebar__user-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;font-size:13px;color:#a8c4ae;transition:background var(--transition-fast),color var(--transition-fast)}.sidebar__user-dropdown-item:hover{background:#ffffff0f;color:#edf2ee}.sidebar__user-dropdown-item--danger:hover{background:#dc3c3c26;color:#f08080}[data-theme=light] .sidebar{background-color:var(--color-bg-sidebar);border-right-color:#ffffff1a}[data-theme=light] .sidebar__logo{border-bottom-color:#ffffff1a}[data-theme=light] .sidebar__nav-link{color:#ffffffa6}[data-theme=light] .sidebar__nav-link:hover{background:#ffffff14;color:#fff}[data-theme=light] .sidebar__nav-link--active{background:#1aadbe2e;color:#fff}[data-theme=light] .sidebar__user{border-top-color:#ffffff1a}[data-theme=light] .sidebar__user-name{color:#fff}[data-theme=light] .sidebar__user-role{color:#ffffff8c}[data-theme=light] .sidebar__user-menu{color:#ffffff80}@media (max-width: 1024px){.sidebar{transform:translate(-100%);transition:transform var(--transition-normal),width var(--transition-normal)}.sidebar--mobile-open{transform:translate(0)}.sidebar--collapsed{width:var(--sidebar-width)}}.header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:var(--color-bg-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-xl);z-index:90;transition:left var(--transition-normal);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header--sidebar-collapsed{left:var(--sidebar-width-collapsed)}.header__left{display:flex;align-items:center;gap:var(--space-md)}.header__menu-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);flex-shrink:0}.header__menu-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.header__title{font-size:var(--font-2xl);font-weight:var(--weight-bold);color:var(--color-text-primary);letter-spacing:-.02em}.header__right{display:flex;align-items:center;gap:var(--space-md)}.header__theme-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);color:var(--color-text-secondary);border:1px solid var(--color-border);background:var(--color-bg-surface);transition:all var(--transition-fast)}.header__theme-btn:hover{border-color:var(--color-border-hover);color:var(--color-primary);background:var(--color-primary-dim)}.header__notif-wrap{position:relative}.header__notif-btn{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);border:none;background:none;cursor:pointer}.header__notif-btn:hover,.header__notif-btn--open{background:var(--color-bg-hover);color:var(--color-text-primary)}.header__notif-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 3px;background:var(--color-danger);color:#fff;font-size:9px;font-weight:var(--weight-bold);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;border:2px solid var(--color-bg-base)}.header__notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:300px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 12px 32px #0000004d;z-index:100;overflow:hidden;animation:dropIn .15s cubic-bezier(.16,1,.3,1)}.header__notif-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 10px;border-bottom:1px solid var(--color-border)}.header__notif-title{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--color-text-primary)}.header__notif-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;background:var(--color-danger);color:#fff;font-size:10px;font-weight:var(--weight-bold);border-radius:var(--radius-full)}.header__notif-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:28px 16px;color:var(--color-text-muted);font-size:var(--font-sm)}.header__notif-list{display:flex;flex-direction:column;max-height:320px;overflow-y:auto}.header__notif-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border:none;background:none;cursor:pointer;text-align:left;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);width:100%}.header__notif-item:last-child{border-bottom:none}.header__notif-item:hover{background:var(--color-bg-hover)}.header__notif-icon{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.header__notif-item--expiring .header__notif-icon{background:var(--color-warning-bg);color:var(--color-warning)}.header__notif-item--overdue .header__notif-icon{background:var(--color-danger-bg);color:var(--color-danger)}.header__notif-body{display:flex;flex-direction:column;gap:2px;min-width:0}.header__notif-item-title{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header__notif-item-sub{font-size:var(--font-xs);color:var(--color-text-muted)}.header__admin{position:relative}.header__admin-btn{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 6px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.header__admin-btn:hover{border-color:var(--color-border-hover);background:var(--color-bg-hover)}.header__admin-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}.header__admin-initials{width:28px;height:28px;border-radius:50%;background:var(--color-primary);color:#0d1510;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header__admin-name{font-size:13px;font-weight:600;color:var(--color-text-primary);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__admin-chevron{color:var(--color-text-muted);transition:transform .2s;flex-shrink:0}.header__admin-chevron--open{transform:rotate(180deg)}.header__admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.header__admin-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 12px 32px #0000004d;z-index:100;overflow:hidden;animation:dropIn .15s cubic-bezier(.16,1,.3,1)}@keyframes dropIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.header__admin-info{padding:12px 14px;display:flex;flex-direction:column;gap:2px}.header__admin-info-name{font-size:13px;font-weight:700;color:var(--color-text-primary)}.header__admin-info-email{font-size:11px;color:var(--color-text-muted)}.header__admin-divider{height:1px;background:var(--color-border);margin:0}.header__admin-item{width:100%;display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:500;color:var(--color-text-secondary);font-family:inherit;background:none;border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);text-align:left}.header__admin-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.header__admin-item--danger{color:var(--color-danger)}.header__admin-item--danger:hover{background:color-mix(in srgb,var(--color-danger) 10%,transparent);color:var(--color-danger)}@media (max-width: 1024px){.header{left:0;padding:0 var(--space-md)}}@media (max-width: 640px){.header__title{font-size:var(--font-xl)}.header__brand-name{display:none}}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast-card{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid transparent;box-shadow:var(--shadow-lg);font-size:var(--font-md);font-weight:var(--weight-medium);min-width:280px;max-width:400px;pointer-events:all;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);opacity:0;transform:translate(20px);transition:opacity .26s cubic-bezier(.4,0,.2,1),transform .26s cubic-bezier(.4,0,.2,1)}.toast-card--visible{opacity:1;transform:translate(0)}.toast-card--success{background:color-mix(in srgb,var(--color-bg-elevated) 92%,var(--color-success));border-color:var(--color-green-border);color:var(--color-text-primary)}.toast-card--error{background:color-mix(in srgb,var(--color-bg-elevated) 92%,var(--color-danger));border-color:#e0555540;color:var(--color-text-primary)}.toast-card--warning{background:color-mix(in srgb,var(--color-bg-elevated) 92%,var(--color-warning));border-color:#e8a83840;color:var(--color-text-primary)}.toast-card--info{background:color-mix(in srgb,var(--color-bg-elevated) 92%,var(--color-primary));border-color:var(--color-primary-border);color:var(--color-text-primary)}.toast-card__icon{flex-shrink:0;display:flex}.toast-card--success .toast-card__icon{color:var(--color-success)}.toast-card--error .toast-card__icon{color:var(--color-danger)}.toast-card--warning .toast-card__icon{color:var(--color-warning)}.toast-card--info .toast-card__icon{color:var(--color-primary)}.toast-card__message{flex:1;line-height:1.4}.toast-card__close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--radius-xs);background:none;border:none;cursor:pointer;color:var(--color-text-muted);transition:color var(--transition-fast),background var(--transition-fast);margin-left:4px}.toast-card__close:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}@media (max-width: 480px){.toast-container{bottom:16px;right:16px;left:16px}.toast-card{min-width:unset;max-width:unset;width:100%}}.layout{display:flex;min-height:100vh;background:var(--color-bg-base)}.layout__body{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-normal)}.layout--sidebar-collapsed .layout__body{margin-left:var(--sidebar-width-collapsed)}.layout__main{flex:1;margin-top:var(--header-height);overflow-x:hidden}.layout__content{padding:var(--space-xl);max-width:var(--content-max-width);width:100%}.layout__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;animation:fadeIn var(--transition-fast) both}@media (max-width: 1280px){.layout__content{padding:var(--space-lg)}}@media (max-width: 1024px){.layout__body,.layout--sidebar-collapsed .layout__body{margin-left:0}}@media (max-width: 768px){.layout__content{padding:var(--space-md)}}@media (max-width: 480px){.layout__content{padding:var(--space-sm)}}.login-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0b1a12;position:relative;overflow:hidden}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.login-bg__orb{position:absolute;border-radius:50%;filter:blur(100px)}.login-bg__orb--1{width:600px;height:600px;background:radial-gradient(circle,#1aadb840 0%,transparent 70%);top:-200px;right:-150px;animation:orbFloat 14s ease-in-out infinite}.login-bg__orb--2{width:500px;height:500px;background:radial-gradient(circle,#2e7d4f30 0%,transparent 70%);bottom:-150px;left:-100px;animation:orbFloat 18s ease-in-out infinite reverse}@keyframes orbFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-24px) scale(1.04)}}.login-card{position:relative;z-index:1;width:100%;max-width:420px;margin:24px;background:#0f1c14d9;border:1px solid rgba(26,173,190,.18);border-radius:24px;padding:48px 40px 40px;box-shadow:0 0 0 1px #ffffff08,0 32px 80px #0009,0 0 60px #1aadbe0f;animation:cardIn .45s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}@keyframes cardIn{0%{opacity:0;transform:translateY(28px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card__header{text-align:center;margin-bottom:36px}.login-card__icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,#1aadb8,#2e7d4f);border-radius:18px;margin-bottom:20px;box-shadow:0 8px 24px #1aadbe59}.login-card__icon svg{width:32px;height:32px;fill:#fff}.login-card__logo{display:block;font-size:28px;font-weight:900;letter-spacing:.14em;color:#fff;text-shadow:0 0 40px rgba(26,173,190,.4)}.login-card__subtitle{margin-top:8px;font-size:13px;color:#ffffff73;letter-spacing:.06em}.login-card__divider{height:1px;background:linear-gradient(to right,transparent,rgba(26,173,190,.25),transparent);margin-bottom:28px}.login-form{display:flex;flex-direction:column;gap:20px}.login-form__field{display:flex;flex-direction:column;gap:8px}.login-form__label{font-size:11px;font-weight:700;color:#ffffff80;letter-spacing:.1em;text-transform:uppercase}.login-form__input{width:100%;padding:13px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:15px;font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s;box-sizing:border-box}.login-form__input::placeholder{color:#fff3}.login-form__input:focus{outline:none;border-color:#1aadb8;background:#1aadbe14;box-shadow:0 0 0 3px #1aadbe26}.login-form__input--pass{padding-right:48px}.login-form__pass-wrap{position:relative}.login-form__eye{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#ffffff59;padding:2px;display:flex;align-items:center;transition:color .2s}.login-form__eye:hover{color:#ffffffb3}.login-form__submit{margin-top:8px;padding:14px;background:linear-gradient(135deg,#1aadb8,#148a94);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;letter-spacing:.04em;transition:opacity .2s,transform .15s,box-shadow .2s;display:flex;align-items:center;justify-content:center;min-height:50px;box-shadow:0 4px 20px #1aadbe59}.login-form__submit:hover:not(:disabled){opacity:.92;transform:translateY(-2px);box-shadow:0 8px 28px #1aadbe73}.login-form__submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-form__spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.login-card__footer{margin-top:24px;text-align:center}.login-card__link{font-size:13px;color:#ffffff59;text-decoration:none;transition:color .2s}.login-card__link:hover{color:#1aadb8}.setup-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0b1a12;position:relative;overflow:hidden;padding:24px;box-sizing:border-box}.setup-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.setup-bg__orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15}.setup-bg__orb--1{width:480px;height:480px;background:#4caf6a;top:-140px;left:-100px;animation:setupOrbFloat 14s ease-in-out infinite}.setup-bg__orb--2{width:380px;height:380px;background:#1aadb8;bottom:-100px;right:-60px;animation:setupOrbFloat 18s ease-in-out infinite reverse}@keyframes setupOrbFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-24px)}}.setup-card{position:relative;z-index:1;width:100%;max-width:440px;background:#0f1c14d9;border:1px solid rgba(26,173,190,.18);border-radius:24px;padding:40px 36px 36px;box-shadow:0 0 0 1px #ffffff08,0 32px 80px #0009,0 0 60px #1aadbe0f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:setupCardIn .4s cubic-bezier(.16,1,.3,1)}@keyframes setupCardIn{0%{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.setup-card__header{text-align:center;margin-bottom:28px}.setup-card__logo{display:inline-block;font-size:22px;font-weight:900;letter-spacing:.12em;color:#fff;text-shadow:0 0 40px rgba(26,173,190,.4);margin-bottom:12px}.setup-card__title{font-size:20px;font-weight:700;color:#fff;margin:0 0 8px}.setup-card__desc{font-size:13px;color:#ffffff73;line-height:1.5;margin:0}.setup-form{display:flex;flex-direction:column;gap:18px}.setup-form__field{display:flex;flex-direction:column;gap:7px}.setup-form__label{font-size:11px;font-weight:700;color:#ffffff80;letter-spacing:.1em;text-transform:uppercase}.setup-form__input{width:100%;padding:13px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:15px;font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s;box-sizing:border-box}.setup-form__input::placeholder{color:#fff3}.setup-form__input:focus{outline:none;border-color:#1aadb8;background:#1aadbe14;box-shadow:0 0 0 3px #1aadbe26}.setup-form__submit{margin-top:8px;padding:14px;background:linear-gradient(135deg,#1aadb8,#148a94);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;display:flex;align-items:center;justify-content:center;min-height:50px;box-shadow:0 4px 20px #1aadbe59}.setup-form__submit:hover:not(:disabled){opacity:.92;transform:translateY(-2px);box-shadow:0 8px 28px #1aadbe73}.setup-form__submit:disabled{opacity:.5;cursor:not-allowed}.setup-form__spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:setupSpin .7s linear infinite}@keyframes setupSpin{to{transform:rotate(360deg)}}.fp-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0b1a12;position:relative;overflow:hidden;padding:24px;box-sizing:border-box}.fp-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.fp-bg__orb{position:absolute;border-radius:50%;filter:blur(100px)}.fp-bg__orb--1{width:500px;height:500px;background:radial-gradient(circle,#1aadb840 0%,transparent 70%);top:-150px;left:50%;transform:translate(-50%);animation:orbFloat 14s ease-in-out infinite}@keyframes orbFloat{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-20px)}}.fp-card{position:relative;z-index:1;width:100%;max-width:400px;background:#0f1c14d9;border:1px solid rgba(26,173,190,.18);border-radius:24px;padding:36px 36px 40px;box-shadow:0 0 0 1px #ffffff08,0 32px 80px #0009,0 0 60px #1aadbe0f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:fpCardIn .4s cubic-bezier(.16,1,.3,1)}@keyframes fpCardIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.fp-card__back{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#fff6;text-decoration:none;transition:color .2s;margin-bottom:24px}.fp-card__back:hover{color:#1aadb8}.fp-card__header{text-align:center;margin-bottom:8px}.fp-card__logo{display:block;font-size:22px;font-weight:900;letter-spacing:.14em;color:#fff;text-shadow:0 0 40px rgba(26,173,190,.4);margin-bottom:10px}.fp-card__title{font-size:18px;font-weight:700;color:#fff;margin:0}.fp-card__desc{font-size:13px;color:#ffffff73;text-align:center;line-height:1.6;margin:14px 0 24px}.fp-form{display:flex;flex-direction:column;gap:18px}.fp-form__field{display:flex;flex-direction:column;gap:8px}.fp-form__label{font-size:11px;font-weight:700;color:#ffffff80;letter-spacing:.1em;text-transform:uppercase}.fp-form__input{width:100%;padding:13px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:15px;font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s;box-sizing:border-box}.fp-form__input::placeholder{color:#fff3}.fp-form__input:focus{outline:none;border-color:#1aadb8;background:#1aadbe14;box-shadow:0 0 0 3px #1aadbe26}.fp-form__submit{margin-top:4px;padding:14px;background:linear-gradient(135deg,#1aadb8,#148a94);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;display:flex;align-items:center;justify-content:center;min-height:50px;box-shadow:0 4px 20px #1aadbe59}.fp-form__submit:hover:not(:disabled){opacity:.92;transform:translateY(-2px);box-shadow:0 8px 28px #1aadbe73}.fp-form__submit:disabled{opacity:.5;cursor:not-allowed}.fp-form__spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.fp-sent{text-align:center;padding:8px 0}.fp-sent__icon{width:60px;height:60px;border-radius:50%;background:#1aadbe26;border:1px solid rgba(26,173,190,.3);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#1aadb8}.fp-sent__title{font-size:18px;font-weight:700;color:#fff;margin:0 0 10px}.fp-sent__desc{font-size:13px;color:#ffffff80;line-height:1.6;margin:0 0 28px}.fp-sent__desc strong{color:#fffc}.fp-sent__btn{display:inline-block;padding:12px 28px;background:linear-gradient(135deg,#1aadb8,#148a94);color:#fff;border-radius:12px;font-size:14px;font-weight:700;text-decoration:none;transition:opacity .2s;box-shadow:0 4px 20px #1aadbe59}.fp-sent__btn:hover{opacity:.88}.rp-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0b1a12;position:relative;overflow:hidden;padding:24px;box-sizing:border-box}.rp-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.rp-bg__orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.18}.rp-bg__orb--1{width:480px;height:480px;background:#4caf6a;bottom:-160px;right:-100px}.rp-card{position:relative;z-index:1;width:100%;max-width:400px;background:#0f1c14d9;border:1px solid rgba(26,173,190,.18);border-radius:24px;padding:40px 36px 36px;box-shadow:0 0 0 1px #ffffff08,0 32px 80px #0009,0 0 60px #1aadbe0f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:rpCardIn .35s cubic-bezier(.16,1,.3,1)}@keyframes rpCardIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.rp-card__header{text-align:center;margin-bottom:8px}.rp-card__logo{display:inline-block;font-size:20px;font-weight:900;letter-spacing:.12em;color:#fff;text-shadow:0 0 40px rgba(26,173,190,.4);margin-bottom:10px}.rp-card__title{font-size:18px;font-weight:700;color:#fff;margin:0}.rp-card__desc{font-size:13px;color:#ffffff73;text-align:center;line-height:1.5;margin:12px 0 24px}.rp-form{display:flex;flex-direction:column;gap:18px}.rp-form__field{display:flex;flex-direction:column;gap:7px}.rp-form__label{font-size:11px;font-weight:700;color:#ffffff80;letter-spacing:.1em;text-transform:uppercase}.rp-form__input{width:100%;padding:13px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:15px;font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s;box-sizing:border-box}.rp-form__input::placeholder{color:#fff3}.rp-form__input:focus{outline:none;border-color:#4caf6a;background:#4caf6a14;box-shadow:0 0 0 3px #4caf6a26}.rp-form__submit{margin-top:4px;padding:14px;background:linear-gradient(135deg,#4caf6a,#3a9055);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;display:flex;align-items:center;justify-content:center;min-height:50px;box-shadow:0 4px 20px #4caf6a59}.rp-form__submit:hover:not(:disabled){opacity:.92;transform:translateY(-2px);box-shadow:0 8px 28px #4caf6a73}.rp-form__submit:disabled{opacity:.5;cursor:not-allowed}.rp-form__spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:rpSpin .7s linear infinite}@keyframes rpSpin{to{transform:rotate(360deg)}}.rp-done{text-align:center;padding:8px 0}.rp-done__icon{width:60px;height:60px;border-radius:50%;background:#4caf6a26;border:1px solid rgba(76,175,106,.3);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#4caf6a}.rp-done__title{font-size:18px;font-weight:700;color:#fff;margin:0 0 10px}.rp-done__desc{font-size:13px;color:#ffffff80;margin:0 0 28px;line-height:1.6}.rp-done__btn{display:inline-block;padding:12px 28px;background:linear-gradient(135deg,#4caf6a,#3a9055);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;text-decoration:none;transition:opacity .2s;box-shadow:0 4px 20px #4caf6a59}.rp-done__btn:hover{opacity:.88}.rp-invalid{text-align:center;padding:12px 0}.rp-invalid__msg{font-size:14px;color:#ffffff73;margin:0 0 20px}.rp-invalid__btn{display:inline-block;padding:12px 24px;background:#ffffff0f;color:#fff;border-radius:12px;font-size:14px;font-weight:600;text-decoration:none;border:1px solid rgba(26,173,190,.18);transition:border-color .2s,color .2s}.rp-invalid__btn:hover{border-color:#1aadb8;color:#1aadb8}.stats-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm);transition:all var(--transition-normal);animation:fadeIn var(--transition-slow) both}.stats-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stats-card__top{display:flex;align-items:center;gap:var(--space-sm)}.stats-card__icon{width:42px;height:42px;border-radius:var(--radius-md);background:color-mix(in srgb,var(--accent) 15%,transparent);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.stats-card__label{font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary)}.stats-card__value{font-size:var(--font-3xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);letter-spacing:-.03em;line-height:1}.stats-card__footer{display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap}.stats-card__trend{display:inline-flex;align-items:center;gap:3px;font-size:var(--font-sm);font-weight:var(--weight-semibold)}.stats-card__trend--up{color:var(--color-success)}.stats-card__trend--down{color:var(--color-danger)}.stats-card__sublabel,.stats-card__trend-label{font-size:var(--font-sm);color:var(--color-text-muted)}@media (max-width: 480px){.stats-card__value{font-size:var(--font-2xl)}}.weekly-schedule{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);animation:fadeIn var(--transition-slow) both}.weekly-schedule__header{display:flex;align-items:center;justify-content:space-between}.weekly-schedule__title{font-size:var(--font-lg);font-weight:var(--weight-bold);color:var(--color-text-primary)}.weekly-schedule__link{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-primary);transition:opacity var(--transition-fast);background:none;border:none;cursor:pointer}.weekly-schedule__link:hover{opacity:.75}.weekly-schedule__wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.weekly-schedule__table{width:100%;min-width:580px;border-collapse:separate;border-spacing:0 2px;table-layout:fixed}.weekly-schedule__th{padding:6px 4px;font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--color-text-muted);text-align:center;letter-spacing:.04em}.weekly-schedule__th--time{width:52px;text-align:left;padding-left:4px}.weekly-schedule__time{font-size:var(--font-xs);color:var(--color-text-muted);font-weight:var(--weight-medium);padding:3px 4px;white-space:nowrap;vertical-align:middle;font-variant-numeric:tabular-nums}.weekly-schedule__cell{padding:2px 3px;vertical-align:top;height:36px}.weekly-schedule__block{width:100%;height:100%;min-height:30px;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2px 3px;font-size:8px;font-weight:var(--weight-bold);color:#fff;text-align:center;letter-spacing:.01em;line-height:1.2;transition:filter var(--transition-fast);cursor:default}.weekly-schedule__block:hover{filter:brightness(1.15)}.weekly-schedule__cell--special{vertical-align:middle}.weekly-schedule__special-block{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-sm);font-size:var(--font-xs);color:var(--color-text-secondary);font-weight:var(--weight-medium);text-align:center;line-height:1.4;height:100%;min-height:80px}.weekly-schedule__legend{display:flex;flex-wrap:wrap;gap:var(--space-md);padding-top:var(--space-sm);border-top:1px solid var(--color-border)}.weekly-schedule__legend-item{display:flex;align-items:center;gap:6px}.weekly-schedule__legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.weekly-schedule__legend-name{font-size:var(--font-xs);color:var(--color-text-secondary);font-weight:var(--weight-medium)}.weekly-schedule__edit-btn{display:flex;align-items:center;gap:5px;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-primary);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:var(--radius-md);transition:background var(--transition-fast)}.weekly-schedule__edit-btn:hover{background:var(--color-bg-hover)}.weekly-schedule__edit-actions{display:flex;gap:6px}.weekly-schedule__cell-edit{width:100%;height:100%}.weekly-schedule__block--edit{cursor:pointer;border:none;font-size:8px;font-weight:var(--weight-bold);color:#fff;width:100%;min-height:30px;border-radius:var(--radius-sm);transition:filter var(--transition-fast),opacity var(--transition-fast)}.weekly-schedule__block--edit:hover{filter:brightness(1.15)}.weekly-schedule__block--empty{background:var(--color-bg-elevated);border:1px dashed var(--color-border);color:var(--color-text-muted);opacity:.7}.weekly-schedule__block--empty:hover{filter:none;opacity:1;border-color:var(--color-primary);color:var(--color-primary)}.weekly-schedule__popover{position:absolute;top:calc(100% + 4px);left:0;z-index:200;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:160px;max-height:220px;overflow-y:auto;padding:4px}.weekly-schedule__popover-item{display:block;width:100%;text-align:left;padding:7px 10px;border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--color-text-primary);border:none;background:none;cursor:pointer;transition:background var(--transition-fast);border-left:3px solid transparent}.weekly-schedule__popover-item:hover{background:var(--color-bg-hover)}.weekly-schedule__popover-item--clear{color:var(--color-text-muted);font-style:italic}.weekly-schedule__remove-time{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);color:var(--color-danger);background:none;border:none;cursor:pointer;opacity:.5;transition:opacity var(--transition-fast)}.weekly-schedule__remove-time:hover{opacity:1}.weekly-schedule__add-time{padding-top:4px}.weekly-schedule__add-time-btn{display:flex;align-items:center;gap:5px;font-size:var(--font-sm);color:var(--color-primary);background:none;border:1px dashed var(--color-primary);border-radius:var(--radius-md);padding:6px 12px;cursor:pointer;opacity:.7;transition:opacity var(--transition-fast)}.weekly-schedule__add-time-btn:hover{opacity:1}.weekly-schedule__add-time-row{display:flex;align-items:center;gap:8px}.weekly-schedule__time-input{padding:5px 8px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-input);color:var(--color-text-primary);font-size:var(--font-sm)}.weekly-schedule__mobile{display:none}@media (max-width: 640px){.weekly-schedule__wrapper{display:none}.weekly-schedule__mobile{display:flex;flex-direction:column;gap:var(--space-sm)}.weekly-schedule__day-tabs{display:flex;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.weekly-schedule__day-tabs::-webkit-scrollbar{display:none}.weekly-schedule__day-tab{flex-shrink:0;padding:6px 12px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-secondary);font-size:var(--font-sm);font-weight:var(--weight-semibold);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.weekly-schedule__day-tab--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.weekly-schedule__day-slots{display:flex;flex-direction:column;gap:4px}.weekly-schedule__day-row{display:flex;align-items:center;gap:var(--space-md);padding:8px var(--space-sm);background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border)}.weekly-schedule__day-time{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-muted);font-variant-numeric:tabular-nums;width:44px;flex-shrink:0}.weekly-schedule__day-block{padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:var(--weight-semibold)}.weekly-schedule__day-free{font-size:var(--font-sm);color:var(--color-text-muted)}.weekly-schedule__day-empty{font-size:var(--font-sm);color:var(--color-text-muted);text-align:center;padding:var(--space-lg)}}@media (max-width: 768px){.weekly-schedule__legend{gap:var(--space-sm)}}.expirations{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);animation:fadeIn var(--transition-slow) .1s both}.expirations__header{display:flex;align-items:center;justify-content:space-between}.expirations__title{font-size:var(--font-lg);font-weight:var(--weight-bold);color:var(--color-text-primary)}.expirations__link{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-teal);background:none;border:none;cursor:pointer;transition:opacity var(--transition-fast)}.expirations__link:hover{opacity:.75}.expirations__list{display:flex;flex-direction:column;gap:2px}.expiration-item{display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-xs);border-radius:var(--radius-md);transition:background var(--transition-fast)}.expiration-item:hover{background:var(--color-bg-hover)}.expiration-item__avatar{flex-shrink:0;width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-teal-dim);border:1px solid var(--color-teal-border);display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:var(--weight-bold);color:var(--color-teal)}.expiration-item__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.expiration-item__name{font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expiration-item__date{font-size:var(--font-xs);color:var(--color-text-muted)}.expiration-item__right{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.expiration-item__amount{font-size:var(--font-md);font-weight:var(--weight-bold);color:var(--color-text-primary);white-space:nowrap}.expiration-item__menu{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-sm);color:var(--color-text-muted);transition:all var(--transition-fast)}.expiration-item__menu:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.expiration-item__days{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-warning);background:var(--color-warning-bg, rgba(234, 179, 8, .1));padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap}.expiration-item__days--urgent{color:var(--color-danger);background:var(--color-danger-bg)}.expirations__empty{padding:24px 0;text-align:center;color:var(--color-text-muted);font-size:var(--font-sm)}.expiration-item--skeleton{pointer-events:none}.activity-chart{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);animation:fadeIn var(--transition-slow) .2s both}.activity-chart__header{display:flex;align-items:center;justify-content:space-between}.activity-chart__title{font-size:var(--font-lg);font-weight:var(--weight-bold);color:var(--color-text-primary)}.activity-chart__link{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-teal);background:none;border:none;cursor:pointer;transition:opacity var(--transition-fast)}.activity-chart__link:hover{opacity:.75}.activity-chart__body{display:flex;gap:var(--space-lg);align-items:center}.activity-chart__donut{position:relative;flex-shrink:0;width:180px;height:180px}.activity-chart__donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.activity-chart__donut-value{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);line-height:1}.activity-chart__donut-label{font-size:var(--font-xs);color:var(--color-text-muted);font-weight:var(--weight-medium);margin-top:2px}.activity-chart__legend{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.activity-chart__legend-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.activity-chart__legend-left{display:flex;align-items:center;gap:8px;min-width:0}.activity-chart__legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.activity-chart__legend-name{font-size:var(--font-sm);color:var(--color-text-primary);font-weight:var(--weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-chart__legend-right{display:flex;align-items:center;gap:4px;flex-shrink:0}.activity-chart__legend-count{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--color-text-primary)}.activity-chart__legend-pct{font-size:var(--font-xs);color:var(--color-text-muted)}.activity-chart__tooltip{display:flex;align-items:center;gap:6px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 10px;font-size:var(--font-sm);color:var(--color-text-primary);box-shadow:var(--shadow-md)}.activity-chart__tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}@media (max-width: 480px){.activity-chart__body{flex-direction:column}.activity-chart__donut{width:160px;height:160px;align-self:center}}.dashboard{display:flex;flex-direction:column;gap:var(--space-xl)}.dashboard__welcome{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.dashboard__welcome-left{display:flex;align-items:center}.dashboard__greeting{display:flex;align-items:center;gap:var(--space-md)}.dashboard__greeting-wave{font-size:28px;animation:waveHand 1.5s ease-in-out}@keyframes waveHand{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-10deg)}}.dashboard__greeting-title{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);letter-spacing:-.02em}.dashboard__greeting-sub{font-size:var(--font-md);color:var(--color-text-secondary);margin-top:2px}.dashboard__welcome-right{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.dashboard__date-pill{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-sm);color:var(--color-text-secondary);font-weight:var(--weight-medium)}.dashboard__new-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;background:var(--color-primary);color:#fff;font-size:var(--font-md);font-weight:var(--weight-semibold);border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 14px var(--color-primary-glow)}.dashboard__new-btn:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.dashboard__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}.dashboard__grid{display:grid;grid-template-columns:1fr 360px;gap:var(--space-lg);align-items:start}.dashboard__col-main{display:flex;flex-direction:column;gap:var(--space-lg);min-width:0}.dashboard__col-side{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard__banner{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);background:linear-gradient(135deg,#25d3661f,#25d3660f);border:1px solid rgba(37,211,102,.2);border-radius:var(--radius-lg);animation:fadeIn var(--transition-slow) .3s both}.dashboard__banner-icon{flex-shrink:0}.dashboard__banner-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.dashboard__banner-text strong{font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.dashboard__banner-text span{font-size:var(--font-sm);color:var(--color-text-secondary)}.dashboard__banner-cta{flex-shrink:0;padding:8px 16px;background:#fff;color:#0d0d12;font-size:var(--font-sm);font-weight:var(--weight-semibold);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.dashboard__banner-cta:hover{background:#f0f0f0;transform:translateY(-1px)}.dashboard__banner-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);color:var(--color-text-muted);border:none;cursor:pointer;transition:all var(--transition-fast)}.dashboard__banner-close:hover{background:#ffffff14;color:var(--color-text-primary)}@media (max-width: 1280px){.dashboard__grid{grid-template-columns:1fr 320px}}@media (max-width: 1100px){.dashboard__stats{grid-template-columns:repeat(2,1fr)}.dashboard__grid{grid-template-columns:1fr}.dashboard__col-side{display:grid;grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard__welcome{flex-direction:column;align-items:flex-start}.dashboard__banner{flex-wrap:wrap;padding:var(--space-md)}.dashboard__banner-cta{width:100%;text-align:center}}@media (max-width: 640px){.dashboard__stats{grid-template-columns:1fr 1fr}.dashboard__col-side{grid-template-columns:1fr}.dashboard__greeting-title{font-size:var(--font-xl)}}@media (max-width: 480px){.dashboard__stats{grid-template-columns:1fr}}.avatar{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-weight:var(--weight-bold);flex-shrink:0;-webkit-user-select:none;user-select:none}.avatar--sm{width:28px;height:28px;font-size:var(--font-xs)}.avatar--md{width:36px;height:36px;font-size:var(--font-sm)}.avatar--lg{width:48px;height:48px;font-size:var(--font-md)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000a6;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);overflow-y:auto;animation:overlayIn .18s ease}.modal{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 0 0 1px var(--glass-border);display:flex;flex-direction:column;max-height:calc(100vh - var(--space-lg) * 2);width:100%;flex-shrink:0;animation:modalIn .22s cubic-bezier(.34,1.56,.64,1);overflow:hidden}@keyframes modalIn{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal--sm{max-width:400px}.modal--md{max-width:560px}.modal--lg{max-width:720px}.modal--xl{max-width:900px}.modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal__title{font-size:var(--font-xl);font-weight:var(--weight-bold);color:var(--color-text-primary);letter-spacing:-.01em}.modal__subtitle{font-size:var(--font-sm);color:var(--color-text-muted);margin-top:3px}.modal__close{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg-surface);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.modal__close:hover{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}.modal__body{padding:var(--space-xl);overflow-y:auto;flex:1;min-height:0}.modal__footer{padding:var(--space-md) var(--space-xl);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);flex-shrink:0}.modal-form{display:flex;flex-direction:column;gap:var(--space-md)}.modal-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.modal-form__row--3{grid-template-columns:1fr 1fr 1fr}.modal-form__group{display:flex;flex-direction:column;gap:6px}.modal-form__label{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-secondary);letter-spacing:.02em}.modal-form__label--required:after{content:" *";color:var(--color-danger)}.modal-form__input,.modal-form__select,.modal-form__textarea{padding:9px 12px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-md);font-family:var(--font-family);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.modal-form__input::placeholder,.modal-form__textarea::placeholder{color:var(--color-text-muted)}.modal-form__input:focus,.modal-form__select:focus,.modal-form__textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-dim)}.modal-form__input--error,.modal-form__select--error{border-color:var(--color-danger)}.modal-form__input--error:focus,.modal-form__select--error:focus{box-shadow:0 0 0 3px var(--color-danger-bg)}.modal-form__error{font-size:var(--font-xs);color:var(--color-danger);margin-top:2px}.modal-form__textarea{resize:vertical;min-height:80px}.modal-form__select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.modal-form__hint{font-size:var(--font-xs);color:var(--color-text-muted)}.modal-form__section-title{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-xs)}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-full);font-size:var(--font-md);font-weight:var(--weight-semibold);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn--primary{background:var(--color-primary);color:#fff;box-shadow:0 2px 12px var(--color-primary-glow)}.btn--primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-glow)}.btn--ghost{background:transparent;color:var(--color-text-secondary);border-color:var(--color-border)}.btn--ghost:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary)}.btn--danger{background:var(--color-danger-bg);color:var(--color-danger);border-color:transparent}.btn--danger:hover:not(:disabled){background:var(--color-danger);color:#fff}.btn--sm{padding:6px 12px;font-size:var(--font-sm)}.btn--icon{padding:6px 8px}@media (max-width: 768px){.modal-overlay{padding:12px 8px;align-items:flex-start}.modal{max-height:none;width:100%;margin:auto}.modal--sm,.modal--md,.modal--lg,.modal--xl{max-width:100%}.modal-form__row,.modal-form__row--3{grid-template-columns:1fr}}.modal-form__plan-buttons{display:flex;gap:8px;margin-bottom:12px}.plan-btn{flex:1;padding:8px 0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-muted);font-size:var(--font-sm);cursor:pointer;transition:all .15s}.plan-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.plan-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600}.student-modal__actions{position:sticky;bottom:0;display:flex;flex-direction:column;gap:8px;padding:12px 0 4px;border-top:1px solid var(--color-border);margin-top:12px;background:var(--color-bg-elevated);z-index:1}.student-modal__actions-btns{display:flex;justify-content:flex-end;gap:10px}.student-modal__error-summary{font-size:var(--font-sm);color:var(--color-danger);background:var(--color-danger-bg);border:1px solid var(--color-danger);border-radius:var(--radius-md);padding:8px 12px}.student-modal__activities{display:flex;flex-wrap:wrap;gap:8px}.student-modal__activity-chip{padding:6px 14px;border-radius:999px;border:1px solid var(--chip-color, var(--color-border));background:transparent;color:var(--chip-color, var(--color-text-secondary));font-size:var(--font-sm);cursor:pointer;transition:all .15s}.student-modal__activity-chip:hover{background:color-mix(in srgb,var(--chip-color, #888) 15%,transparent)}.student-modal__activity-chip--active{background:color-mix(in srgb,var(--chip-color, #888) 20%,transparent);font-weight:600}.student-modal__api-error{background:var(--color-danger-bg);border:1px solid var(--color-danger);color:var(--color-danger);padding:10px 14px;border-radius:var(--radius-md);font-size:var(--font-sm)}.student-detail{display:flex;flex-direction:column;height:100%;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.student-detail__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--color-border);flex-shrink:0;flex-wrap:wrap}.student-detail__identity{display:flex;align-items:center;gap:var(--space-md)}.student-detail__name{font-size:var(--font-xl);font-weight:var(--weight-bold);color:var(--color-text-primary);margin-bottom:4px}.student-detail__actions{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.student-detail__close{width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg-surface);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.student-detail__close:hover{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}.student-detail__banner{display:flex;align-items:center;gap:8px;padding:8px var(--space-lg);font-size:var(--font-sm);font-weight:var(--weight-semibold);flex-shrink:0}.student-detail__banner--warning{background:var(--color-warning-bg);color:var(--color-warning)}.student-detail__banner--danger{background:var(--color-danger-bg);color:var(--color-danger)}.student-detail__tabs{display:flex;border-bottom:1px solid var(--color-border);padding:0 var(--space-lg);flex-shrink:0}.student-detail__tab{padding:12px 16px;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-muted);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition-fast)}.student-detail__tab:hover{color:var(--color-text-secondary)}.student-detail__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.student-detail__content{padding:var(--space-lg);overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:var(--space-md)}.student-detail__section-title{font-size:var(--font-xs);font-weight:var(--weight-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.student-detail__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.student-detail__field{display:flex;align-items:flex-start;gap:8px;color:var(--color-text-muted)}.student-detail__field-label{display:block;font-size:var(--font-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.student-detail__field-value{display:block;font-size:var(--font-sm);color:var(--color-text-primary);font-weight:var(--weight-medium)}.student-detail__physical{display:flex;gap:var(--space-lg)}.student-detail__stat{display:flex;flex-direction:column;align-items:center;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);flex:1}.student-detail__stat-val{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-primary)}.student-detail__stat-label{font-size:var(--font-xs);color:var(--color-text-muted);margin-top:2px}.student-detail__notes{font-size:var(--font-sm);color:var(--color-text-secondary);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);line-height:1.6}.student-detail__activity-list{display:flex;flex-direction:column;gap:6px}.student-detail__activity-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.student-detail__activity-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.student-detail__activity-name{flex:1;font-size:var(--font-sm);color:var(--color-text-primary);font-weight:var(--weight-medium)}.student-detail__activity-remove{width:22px;height:22px;border-radius:var(--radius-sm);border:none;background:var(--color-danger-bg);color:var(--color-danger);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.student-detail__activity-remove:hover{background:var(--color-danger);color:#fff}.student-detail__activity-add{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.student-detail__activity-add:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-dim)}.student-detail__payments{display:flex;flex-direction:column;gap:6px}.student-detail__payment-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);gap:var(--space-md)}.student-detail__payment-period{display:block;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.student-detail__payment-method{display:block;font-size:var(--font-xs);color:var(--color-text-muted)}.student-detail__payment-right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.student-detail__payment-amount{font-size:var(--font-md);font-weight:var(--weight-bold);color:var(--color-text-primary)}.student-detail__empty{font-size:var(--font-sm);color:var(--color-text-muted);font-style:italic}.student-detail__empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-2xl);color:var(--color-text-muted);text-align:center}.student-detail__error{background:var(--color-danger-bg);border:1px solid var(--color-danger);color:var(--color-danger);padding:8px 12px;border-radius:var(--radius-md);font-size:var(--font-sm)}.wa-sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0009;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);animation:overlayIn .15s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.wa-sheet__modal{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 48px #0006;animation:waModalIn .2s cubic-bezier(.34,1.56,.64,1)}@keyframes waModalIn{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.wa-sheet__header{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--color-border);flex-shrink:0}.wa-sheet__icon{color:#25d366;margin-top:2px;flex-shrink:0}.wa-sheet__header-text{flex:1}.wa-sheet__title{font-size:var(--font-lg);font-weight:var(--weight-bold);color:var(--color-text-primary)}.wa-sheet__student{font-size:var(--font-sm);color:var(--color-text-muted);margin-top:2px}.wa-sheet__body{flex:1;overflow-y:auto;padding:var(--space-lg) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-md)}.wa-templates{display:flex;flex-direction:column;gap:6px}.wa-template-btn{text-align:left;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-surface);color:var(--color-text-secondary);font-size:var(--font-sm);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);line-height:1.5;word-break:break-word}.wa-template-btn:hover{border-color:#25d366;color:var(--color-text-primary)}.wa-template-btn--active{border-color:#25d366;background:#25d36614;color:var(--color-text-primary);font-weight:var(--weight-medium)}.wa-sheet__custom{width:100%;padding:10px 12px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-md);font-family:var(--font-family);resize:vertical;outline:none;transition:border-color var(--transition-fast)}.wa-sheet__custom:focus{border-color:#25d366}.wa-sheet__custom::placeholder{color:var(--color-text-muted)}.wa-sheet__preview{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.wa-sheet__preview-label{display:block;font-size:var(--font-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.wa-sheet__preview-text{font-size:var(--font-sm);color:var(--color-text-primary);line-height:1.6}.wa-sheet__footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);border-top:1px solid var(--color-border);flex-shrink:0}.btn--wa{background:#25d366;color:#fff;border-color:transparent}.btn--wa:hover:not(:disabled){background:#1ebe5d;transform:translateY(-1px)}.btn--wa:disabled{opacity:.55;cursor:not-allowed}@media (max-width: 640px){.student-detail__grid{grid-template-columns:1fr}.student-detail__physical{flex-wrap:wrap}}.renew-expired-notice{margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-warning-bg, rgba(255, 165, 0, .1));color:var(--color-warning);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:var(--weight-medium)}.renew-field{display:flex;flex-direction:column;gap:var(--space-xs)}.renew-field__label{display:flex;align-items:center;gap:5px;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-secondary)}.renew-duration-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-xs)}.renew-duration-btn{padding:8px 4px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated);color:var(--color-text-secondary);font-size:var(--font-sm);font-weight:var(--weight-medium);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);text-align:center}.renew-duration-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.renew-duration-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse);font-weight:var(--weight-bold)}.renew-preview{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-primary-muted, rgba(26, 173, 190, .2))}.renew-preview__label{font-size:var(--font-sm);color:var(--color-text-muted)}.renew-preview__date{font-size:var(--font-md);font-weight:var(--weight-bold);color:var(--color-primary)}.renew-method-group{display:flex;gap:var(--space-xs)}.renew-method-btn{flex:1;padding:8px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated);color:var(--color-text-secondary);font-size:var(--font-sm);font-weight:var(--weight-medium);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);text-align:center}.renew-method-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.renew-method-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse);font-weight:var(--weight-bold)}.renew-plan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-xs)}.renew-plan-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 8px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family);text-align:center}.renew-plan-btn:hover{border-color:var(--color-primary)}.renew-plan-btn--active{background:var(--color-primary);border-color:var(--color-primary)}.renew-plan-btn__name{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.renew-plan-btn__price{font-size:var(--font-md);font-weight:var(--weight-bold);color:var(--color-primary)}.renew-plan-btn__months{font-size:var(--font-xs);color:var(--color-text-muted)}.renew-plan-btn--active .renew-plan-btn__name,.renew-plan-btn--active .renew-plan-btn__price,.renew-plan-btn--active .renew-plan-btn__months{color:var(--color-text-inverse)}.renew-spin{animation:renewSpin .7s linear infinite}@keyframes renewSpin{to{transform:rotate(360deg)}}@media (max-width: 480px){.renew-duration-grid{grid-template-columns:repeat(3,1fr)}.renew-plan-grid{grid-template-columns:repeat(2,1fr)}}.students-page{display:flex;flex-direction:column;gap:var(--space-lg)}.students-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.students-page__title{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);letter-spacing:-.02em}.students-page__subtitle{font-size:var(--font-md);color:var(--color-text-secondary);margin-top:4px}.students-page__new-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--color-primary);color:#fff;font-size:var(--font-md);font-weight:var(--weight-semibold);border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 12px var(--color-primary-glow)}.students-page__new-btn:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.students-page__new-btn:disabled{opacity:.5;cursor:not-allowed}.students-page__refresh-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.students-page__refresh-btn:hover{border-color:var(--color-border-hover);color:var(--color-text-primary);transform:rotate(45deg)}.students-page__filters{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.students-page__search{position:relative;flex:1;min-width:220px;max-width:400px}.students-page__search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.students-page__search-input{width:100%;padding:9px 36px 9px 38px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-md);transition:border-color var(--transition-fast);outline:none}.students-page__search-input::placeholder{color:var(--color-text-muted)}.students-page__search-input:focus{border-color:var(--color-primary)}.students-page__search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:18px;height:18px;border:none;background:none;color:var(--color-text-muted);cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center}.students-page__search-clear:hover{color:var(--color-text-primary)}.students-page__status-tabs{display:flex;gap:4px;background:var(--color-bg-surface);border:1px solid var(--color-border);padding:4px;border-radius:var(--radius-md);flex-wrap:wrap}.students-page__status-tab{padding:5px 12px;border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;background:none;white-space:nowrap}.students-page__status-tab--active{background:var(--color-primary);color:#fff;font-weight:var(--weight-semibold)}.students-page__error{background:var(--color-danger-bg);border:1px solid var(--color-danger);color:var(--color-danger);padding:10px 16px;border-radius:var(--radius-md);font-size:var(--font-sm)}.students-page__layout{display:flex;gap:var(--space-lg);min-height:400px}.students-page__layout--split .students-page__table-wrap{flex:1;min-width:0}.students-page__detail{width:380px;flex-shrink:0;animation:slideIn .22s cubic-bezier(.34,1.2,.64,1)}@keyframes slideIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.students-page__table-wrap{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto;flex:1}.students-page__loading{display:flex;flex-direction:column;gap:1px;padding:var(--space-sm)}.students-page__skeleton-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md)}.students-page__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-3xl) var(--space-2xl);text-align:center;color:var(--color-text-muted)}.students-page__empty p{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--color-text-secondary);margin-top:var(--space-sm)}.students-page__empty span{font-size:var(--font-md);max-width:320px}.students-table{width:100%;min-width:640px;border-collapse:collapse}.students-table thead tr{border-bottom:1px solid var(--color-border)}.students-table th{padding:11px 16px;font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--color-text-muted);text-align:left;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}.students-table__row{border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);cursor:pointer}.students-table__row:last-child{border-bottom:none}.students-table__row:hover{background:var(--color-bg-hover)}.students-table__row--selected{background:var(--color-bg-active)!important}.students-table td{padding:12px 16px;vertical-align:middle}.students-table__student{display:flex;align-items:center;gap:var(--space-sm)}.students-table__name{display:block;font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.students-table__email{display:block;font-size:var(--font-xs);color:var(--color-text-muted);margin-top:2px}.students-table__phone{font-size:var(--font-sm);color:var(--color-text-secondary);white-space:nowrap}.students-table__activities{display:flex;flex-wrap:wrap;gap:4px}.students-table__activity-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-semibold);white-space:nowrap}.students-table__activity-more{display:inline-flex;align-items:center;padding:2px 7px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-semibold);background:var(--color-bg-elevated);color:var(--color-text-muted);border:1px solid var(--color-border)}.students-table__no-activity{font-size:var(--font-xs);color:var(--color-text-muted);font-style:italic}.students-table__expiry{display:flex;align-items:center;gap:6px}.students-table__date{font-size:var(--font-sm);color:var(--color-text-secondary);white-space:nowrap}.students-table__expiry-badge{padding:2px 7px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-bold)}.students-table__expiry-badge--warning{background:var(--color-warning-bg);color:var(--color-warning)}.students-table__expiry-badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}.students-table__row-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast);white-space:nowrap}.students-table__row:hover .students-table__row-actions{opacity:1}.students-table th:last-child,.students-table td:last-child{width:1px;white-space:nowrap}@media (max-width: 900px){.students-page__layout--split{flex-direction:column}.students-page__detail{width:100%}}@media (max-width: 700px){.students-page__detail{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;width:100%!important;height:100%;overflow-y:auto;border-radius:0;animation:slideUp .22s cubic-bezier(.34,1.2,.64,1)}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}}@media (max-width: 640px){.students-page__search{max-width:100%}.students-page__filters{flex-direction:column;align-items:stretch}}@media (max-width: 600px){.students-page__table-wrap{overflow-x:visible}.students-table{display:block;min-width:0;width:100%}.students-table thead{display:none}.students-table tbody{display:block}.students-table__row{display:grid;grid-template-columns:1fr auto;gap:4px 10px;padding:12px 14px;border-radius:0;border-bottom:1px solid var(--color-border)}.students-table td{display:block;padding:0;vertical-align:top}.students-table td:nth-child(1){grid-column:1;grid-row:1}.students-table td:nth-child(2){display:none}.students-table td:nth-child(3){grid-column:1 / -1;grid-row:2;padding-top:4px}.students-table td:nth-child(4){grid-column:1;grid-row:3;padding-top:2px}.students-table td:nth-child(5){grid-column:2;grid-row:1;text-align:right;align-self:start}.students-table td:nth-child(6){grid-column:1 / -1;grid-row:4;padding-top:6px}.students-table__row-actions{opacity:1;justify-content:flex-end;gap:6px}.students-table__row-actions .btn--ghost,.students-table__row-actions .btn--danger{display:none}}.activity-modal__error{background:var(--color-danger-bg);border:1px solid var(--color-danger);color:var(--color-danger);padding:10px 14px;border-radius:var(--radius-md);font-size:var(--font-sm)}.activity-modal__colors{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.activity-modal__color-btn{width:26px;height:26px;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);outline:none}.activity-modal__color-btn:hover{transform:scale(1.2)}.activity-modal__color-btn--active{border-color:var(--color-text-primary);transform:scale(1.15);box-shadow:0 0 0 2px var(--color-bg-elevated)}.activity-modal__color-custom{width:26px;height:26px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:none;cursor:pointer;padding:0}.activity-modal__color-preview{margin-top:6px}.activity-modal__color-preview span{display:inline-block;padding:3px 12px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-semibold)}.modal-form__section-title{display:flex;align-items:center;justify-content:space-between}.activity-modal__add-slot{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);border:1px solid var(--color-primary);background:var(--color-primary-dim);color:var(--color-primary);font-size:var(--font-xs);font-weight:var(--weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.activity-modal__add-slot:hover{background:var(--color-primary);color:#fff}.activity-modal__slots{display:flex;flex-direction:column;gap:8px}.activity-modal__slot{display:flex;align-items:center;gap:8px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px}.activity-modal__slot-day{flex:1;min-width:0}.activity-modal__slot-time{width:100px;flex-shrink:0}.activity-modal__slot-dur{width:70px;flex-shrink:0}.activity-modal__slot-unit{font-size:var(--font-xs);color:var(--color-text-muted);flex-shrink:0}.activity-modal__slot-remove{width:22px;height:22px;border-radius:var(--radius-sm);border:none;background:var(--color-danger-bg);color:var(--color-danger);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.activity-modal__slot-remove:hover{background:var(--color-danger);color:#fff}@media (max-width: 480px){.activity-modal__slot{flex-wrap:wrap}.activity-modal__slot-time,.activity-modal__slot-dur{width:auto;flex:1}}.cronograma{display:flex;flex-direction:column;gap:var(--space-md)}.cronograma__empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-3xl);text-align:center;color:var(--color-text-muted)}.cronograma__empty p{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--color-text-secondary)}.cronograma__empty span{font-size:var(--font-md);max-width:380px}.cronograma__empty-btn{display:inline-flex;align-items:center;gap:6px;margin-top:var(--space-sm);padding:9px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-full);font-size:var(--font-md);font-weight:var(--weight-semibold);font-family:var(--font-family);cursor:pointer;transition:background var(--transition-fast)}.cronograma__empty-btn:hover{background:var(--color-primary-dark)}.cronograma__scroll{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.cronograma__table{width:100%;border-collapse:collapse;min-width:640px}.cronograma__th-time{width:72px;min-width:72px;padding:12px 10px;background:var(--color-bg-elevated);font-size:10px;font-weight:800;letter-spacing:.12em;color:var(--color-text-muted);text-align:center;font-style:italic;border-bottom:2px solid var(--color-border)}.cronograma__th-day{padding:10px 14px;background:var(--color-bg-elevated);font-size:11px;font-weight:800;letter-spacing:.08em;color:var(--color-text-primary);text-transform:uppercase;border-bottom:2px solid var(--color-border);border-left:1px solid var(--color-border);text-align:center}.cronograma__th-day-label{display:block}.cronograma__th-add{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg-base);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);opacity:0;vertical-align:middle;margin-left:6px}.cronograma__th-day:hover .cronograma__th-add{opacity:1}.cronograma__th-add:hover{background:var(--color-primary-dim);border-color:var(--color-primary);color:var(--color-primary)}.cronograma__td-time{padding:10px 8px;font-size:13px;font-weight:700;font-style:italic;color:var(--color-text-secondary);text-align:center;background:var(--color-bg-surface);border-bottom:1px solid var(--color-border);vertical-align:top;white-space:nowrap}.cronograma__td{padding:6px 8px;border-bottom:1px solid var(--color-border);border-left:1px solid var(--color-border);vertical-align:top;min-width:130px}.cronograma__block{padding:7px 9px 6px;border-radius:var(--radius-sm);margin-bottom:4px;display:flex;flex-direction:column;gap:2px}.cronograma__block-name{font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;line-height:1.2}.cronograma__block-prof{font-size:10px;color:var(--color-text-secondary)}.cronograma__block-routine{display:flex;align-items:center;gap:3px;font-size:9px;color:var(--color-text-muted)}.cronograma__block-footer{display:flex;align-items:center;justify-content:space-between;margin-top:3px}.cronograma__block-time{font-size:9px;color:var(--color-text-muted)}.cronograma__block-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--transition-fast)}.cronograma__block:hover .cronograma__block-actions{opacity:1}.cronograma__block-btn{width:20px;height:20px;border-radius:4px;border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--color-bg-surface);color:var(--color-text-secondary);transition:all var(--transition-fast)}.cronograma__block-btn:hover{background:var(--color-primary-dim);border-color:var(--color-primary);color:var(--color-primary)}.cronograma__block-btn--del:hover{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}.cronograma__cell-add{width:100%;padding:3px 0;border-radius:var(--radius-sm);border:1px dashed var(--color-border);background:transparent;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:all var(--transition-fast);font-family:var(--font-family)}.cronograma__td:hover .cronograma__cell-add{opacity:1}.cronograma__cell-add:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-dim)}@media (max-width: 640px){.cronograma__th-day{padding:8px 6px;font-size:10px}.cronograma__td{min-width:100px;padding:4px 5px}.cronograma__block-name{font-size:10px}.cronograma__th-time,.cronograma__td-time{width:52px;min-width:52px;font-size:11px;padding:8px 4px}}.class-modal__form{display:flex;flex-direction:column;gap:16px}.class-modal__row{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap}.class-modal__field{display:flex;flex-direction:column;gap:6px}.class-modal__field--grow{flex:1;min-width:140px}.class-modal__label{font-size:11px;font-weight:700;color:var(--color-text-muted);letter-spacing:.08em;text-transform:uppercase}.class-modal__input{padding:10px 12px;background:var(--color-bg-input, rgba(255,255,255,.05));border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-sm);font-family:var(--font-family);transition:border-color .2s,box-shadow .2s;box-sizing:border-box;width:100%}.class-modal__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1aadbe26}.class-modal__input--time{width:110px}.class-modal__input--sm{width:90px}.class-modal__textarea{resize:vertical;min-height:72px}.class-modal__colors{display:flex;gap:6px;flex-wrap:wrap;padding-top:4px}.class-modal__color-dot{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s;padding:0}.class-modal__color-dot:hover{transform:scale(1.2)}.class-modal__color-dot--active{border-color:#fff;box-shadow:0 0 0 2px var(--color-primary);transform:scale(1.15)}.class-modal__spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:classSpin .7s linear infinite}@keyframes classSpin{to{transform:rotate(360deg)}}.activities-page{display:flex;flex-direction:column;gap:var(--space-lg)}.activities-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.activities-page__title{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);letter-spacing:-.02em}.activities-page__subtitle{font-size:var(--font-md);color:var(--color-text-secondary);margin-top:4px}.activities-page__new-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--color-primary);color:#fff;font-size:var(--font-md);font-weight:var(--weight-semibold);border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 12px var(--color-primary-glow)}.activities-page__new-btn:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.activities-page__new-btn:disabled{opacity:.5;cursor:not-allowed}.activities-page__refresh-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.activities-page__refresh-btn:hover{border-color:var(--color-border-hover);color:var(--color-text-primary)}.activities-page__error{background:var(--color-danger-bg);border:1px solid var(--color-danger);color:var(--color-danger);padding:10px 16px;border-radius:var(--radius-md);font-size:var(--font-sm)}.activities-page__empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-3xl);text-align:center;color:var(--color-text-muted)}.activities-page__empty p{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--color-text-secondary)}.activities-page__empty span{font-size:var(--font-md);max-width:300px}.activities-page__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md)}.activity-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-normal)}.activity-card:hover{border-color:var(--color-border-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.activity-card--skeleton{pointer-events:none}.activity-card__accent{height:4px}.activity-card__body{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg)}.activity-card__icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-card__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.activity-card__name{font-size:var(--font-md);font-weight:var(--weight-bold);color:var(--color-text-primary)}.activity-card__desc{font-size:var(--font-xs);color:var(--color-text-muted)}.activity-card__schedule{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.activity-card__schedule-chip{padding:2px 7px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-medium);background:var(--color-bg-elevated);color:var(--color-text-secondary);border:1px solid var(--color-border)}.activity-card__schedule-chip--more{background:var(--color-primary-dim);color:var(--color-primary);border-color:var(--color-primary-border)}.activity-card__right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-sm);flex-shrink:0}.activity-card__students{display:flex;align-items:center;gap:4px}.activity-card__count{font-size:var(--font-lg);font-weight:var(--weight-extrabold);color:var(--color-text-primary);line-height:1}.activity-card__actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.activity-card:hover .activity-card__actions{opacity:1}.activity-card__action-btn{width:26px;height:26px;border-radius:var(--radius-sm);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.activity-card__action-btn--edit{background:var(--color-bg-elevated);color:var(--color-text-secondary)}.activity-card__action-btn--edit:hover{background:var(--color-primary-dim);border-color:var(--color-primary);color:var(--color-primary)}.activity-card__action-btn--delete{background:var(--color-bg-elevated);color:var(--color-text-secondary)}.activity-card__action-btn--delete:hover{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}.activities-page__tabs{display:flex;gap:4px;border-bottom:1px solid var(--color-border)}.activities-page__tab{display:flex;align-items:center;gap:6px;padding:10px 18px;border:none;background:none;font-size:var(--font-sm);font-weight:600;font-family:var(--font-family);color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap}.activities-page__tab:hover{color:var(--color-text-primary)}.activities-page__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.activities-page__tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;font-size:10px;font-weight:700;background:#1aadbe26;color:var(--color-primary)}.activities-page__loading{display:flex;justify-content:center;padding:80px 0}.activities-page__spinner{width:32px;height:32px;border-radius:50%;border:3px solid var(--color-border);border-top-color:var(--color-primary);animation:actSpin .7s linear infinite}@keyframes actSpin{to{transform:rotate(360deg)}}@media (max-width: 480px){.activities-page__grid{grid-template-columns:1fr}.activities-page__tab{padding:8px 12px;font-size:12px}}.payment-modal__error{background:var(--color-danger-bg);border:1px solid var(--color-danger);color:var(--color-danger);padding:10px 14px;border-radius:var(--radius-md);font-size:var(--font-sm)}.payment-modal__autocomplete{position:relative}.payment-modal__search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none;z-index:1}.payment-modal__search-input{padding-left:34px!important;padding-right:34px!important}.payment-modal__check-icon{position:absolute;right:11px;top:50%;transform:translateY(-50%);color:var(--color-success);pointer-events:none}.payment-modal__search-spinner{position:absolute;right:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite;pointer-events:none}@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}.payment-modal__selected{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--color-bg-surface);border:1px solid var(--color-success);border-radius:var(--radius-md)}.payment-modal__selected-name{flex:1;font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.payment-modal__selected-clear{background:none;border:none;font-size:var(--font-xs);color:var(--color-text-muted);cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);transition:color var(--transition-fast);white-space:nowrap}.payment-modal__selected-clear:hover{color:var(--color-danger)}.payment-modal__results{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated);overflow:hidden;max-height:240px;overflow-y:auto}.payment-modal__results-msg{padding:12px 14px;font-size:var(--font-sm);color:var(--color-text-muted);text-align:center}.payment-modal__result-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast);text-align:left}.payment-modal__result-item:last-child{border-bottom:none}.payment-modal__result-item:hover,.payment-modal__result-item--selected{background:var(--color-primary-dim)}.payment-modal__dropdown-name{display:block;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.payment-modal__dropdown-email{display:block;font-size:var(--font-xs);color:var(--color-text-muted)}.payment-modal__dropdown-status{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;background:#ef44441a;color:#ef4444;white-space:nowrap;flex-shrink:0}.payment-modal__type-toggle{display:flex;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:4px}.payment-modal__type-btn{flex:1;padding:9px 0;background:none;border:none;font-size:var(--font-sm);font-weight:var(--weight-semibold);font-family:var(--font-family);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.payment-modal__type-btn+.payment-modal__type-btn{border-left:1px solid var(--color-border)}.payment-modal__type-btn--active{background:var(--color-primary);color:#fff}.payment-modal__type-btn--partial.payment-modal__type-btn--active{background:#f59e0b}.payment-modal__balance{background:#f59e0b14;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-md);padding:12px 14px}.payment-modal__balance-row{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-sm);font-weight:600;color:var(--color-text-secondary)}.payment-modal__balance-amount{font-size:18px;font-weight:700;color:#f59e0b}.payment-modal__paid-toggle{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;gap:6px}.payment-modal__toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary);-webkit-user-select:none;user-select:none}.payment-modal__toggle-input{display:none}.payment-modal__toggle-track{width:36px;height:20px;border-radius:var(--radius-full);background:var(--color-border);position:relative;flex-shrink:0;transition:background var(--transition-fast)}.payment-modal__toggle-input:checked+.payment-modal__toggle-track{background:var(--color-success)}.payment-modal__toggle-thumb{position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:var(--radius-full);background:#fff;transition:transform var(--transition-fast);box-shadow:var(--shadow-xs)}.payment-modal__toggle-input:checked+.payment-modal__toggle-track .payment-modal__toggle-thumb{transform:translate(16px)}.payments-page{display:flex;flex-direction:column;gap:var(--space-lg)}.payments-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.payments-page__title{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);letter-spacing:-.02em}.payments-page__subtitle{font-size:var(--font-md);color:var(--color-text-secondary);margin-top:4px}.payments-page__new-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--color-primary);color:#fff;font-size:var(--font-md);font-weight:var(--weight-semibold);border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 12px var(--color-primary-glow)}.payments-page__new-btn:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.payments-page__refresh-btn,.payments-page__chart-toggle{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.payments-page__refresh-btn:hover{color:var(--color-text-primary);border-color:var(--color-border-hover)}.payments-page__chart-toggle--active{background:var(--color-primary-dim);border-color:var(--color-primary);color:var(--color-primary)}.payments-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-md)}.payments-stat{display:flex;align-items:center;gap:var(--space-md);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal)}.payments-stat:hover{border-color:var(--color-border-hover);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.payments-stat__icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.payments-stat--success .payments-stat__icon{background:var(--color-success-bg);color:var(--color-success)}.payments-stat--warning .payments-stat__icon{background:var(--color-warning-bg);color:var(--color-warning)}.payments-stat--danger .payments-stat__icon{background:var(--color-danger-bg);color:var(--color-danger)}.payments-stat--primary .payments-stat__icon{background:var(--color-primary-dim);color:var(--color-primary)}.payments-stat__body{display:flex;flex-direction:column}.payments-stat__value{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);line-height:1.1}.payments-stat__label{font-size:var(--font-sm);color:var(--color-text-muted);margin-top:3px}.payments-chart-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);animation:fadeIn var(--transition-normal) both}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.payments-chart-card__header{display:flex;align-items:center;gap:8px;font-size:var(--font-md);font-weight:var(--weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-md)}.payments-upcoming{background:var(--color-bg-surface);border:1px solid var(--color-warning-bg);border-left:3px solid var(--color-warning);border-radius:var(--radius-lg);overflow:hidden}.payments-upcoming__header{display:flex;align-items:center;gap:8px;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-warning-bg)}.payments-upcoming__title{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--color-warning);display:flex;align-items:center;gap:6px}.payments-upcoming__count{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:var(--radius-full);background:var(--color-warning);color:#fff;font-size:var(--font-xs);font-weight:var(--weight-bold)}.payments-upcoming__list{display:flex;flex-direction:column}.payments-upcoming__item{display:flex;align-items:center;gap:var(--space-md);padding:10px var(--space-lg);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.payments-upcoming__item:last-child{border-bottom:none}.payments-upcoming__item:hover{background:var(--color-bg-hover)}.payments-upcoming__info{flex:1;min-width:0}.payments-upcoming__name{display:block;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.payments-upcoming__date{display:block;font-size:var(--font-xs);color:var(--color-text-muted)}.payments-upcoming__days{padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-bold);background:var(--color-warning-bg);color:var(--color-warning);flex-shrink:0}.payments-upcoming__days--urgent{background:var(--color-danger-bg);color:var(--color-danger)}.payments-page__filters{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.payments-page__status-tabs{display:flex;gap:4px;background:var(--color-bg-surface);border:1px solid var(--color-border);padding:4px;border-radius:var(--radius-md);flex-wrap:wrap}.payments-page__status-tab{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;background:none;white-space:nowrap}.payments-page__status-tab--active{background:var(--color-primary);color:#fff;font-weight:var(--weight-semibold)}.payments-page__tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--color-danger);color:#fff;font-size:10px;font-weight:var(--weight-bold)}.payments-page__tab-badge--warning{background:var(--color-warning)}.payments-page__status-tab--active .payments-page__tab-badge{background:#ffffff4d}.payments-page__month-filter{display:flex;align-items:center;gap:6px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:6px 10px}.payments-page__month-input{background:none;border:none;color:var(--color-text-primary);font-size:var(--font-sm);cursor:pointer;outline:none;font-family:var(--font-family)}.payments-page__clear-month{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:16px;line-height:1;padding:0 2px}.payments-page__clear-month:hover{color:var(--color-danger)}.payments-page__table-wrap{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto}.payments-page__loading{display:flex;flex-direction:column;gap:1px;padding:var(--space-sm)}.payments-page__skeleton-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md)}.payments-page__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-3xl) var(--space-2xl);text-align:center;color:var(--color-text-muted)}.payments-page__empty p{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--color-text-secondary)}.payments-page__empty span{font-size:var(--font-md);max-width:320px}.payments-table{width:100%;min-width:700px;border-collapse:collapse}.payments-table thead tr{border-bottom:1px solid var(--color-border)}.payments-table th{padding:11px 16px;font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--color-text-muted);text-align:left;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}.payments-table__row{border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.payments-table__row:last-child{border-bottom:none}.payments-table__row:hover{background:var(--color-bg-hover)}.payments-table td{padding:12px 16px;vertical-align:middle}.payments-table__student{display:flex;align-items:center;gap:10px}.payments-table__name{display:block;font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.payments-table__email{display:block;font-size:var(--font-xs);color:var(--color-text-muted)}.payments-table__period{font-size:var(--font-sm);color:var(--color-text-secondary);white-space:nowrap}.payments-table__amount{font-size:var(--font-md);font-weight:var(--weight-bold);color:var(--color-text-primary);white-space:nowrap}.payments-table__partial{display:flex;flex-direction:column;gap:2px;margin-top:3px}.payments-table__partial-badge{display:inline-block;font-size:10px;font-weight:700;padding:1px 5px;border-radius:3px;background:#f59e0b26;color:#f59e0b;width:fit-content}.payments-table__partial-balance{font-size:11px;font-weight:600;color:#f59e0b}.payments-table__partial-promise{font-size:11px;color:var(--color-text-muted);font-weight:400}.payments-table__method{display:inline-block;padding:2px 9px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-semibold);background:var(--color-bg-elevated);color:var(--color-text-secondary);border:1px solid var(--color-border);white-space:nowrap}.payments-table__date{font-size:var(--font-sm);color:var(--color-text-secondary);white-space:nowrap}.payments-table__actions{display:flex;align-items:center;gap:6px;opacity:0;transition:opacity var(--transition-fast)}.payments-table__row:hover .payments-table__actions{opacity:1}.payments-table__pay-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-bold);background:var(--color-success-bg);color:var(--color-success);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.payments-table__pay-btn:hover:not(:disabled){background:var(--color-success);color:#fff}.payments-table__pay-btn:disabled{opacity:.6;cursor:not-allowed}.payments-table__paying{width:10px;height:10px;border-radius:var(--radius-full);border:2px solid var(--color-success);border-top-color:transparent;animation:spin .7s linear infinite;display:inline-block}.payments-table__delete-btn{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:none;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.payments-table__delete-btn:hover{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}@media (max-width: 640px){.payments-stats{grid-template-columns:1fr 1fr}.payments-page__filters{flex-direction:column;align-items:stretch}}@media (max-width: 400px){.payments-stats{grid-template-columns:1fr}}@media (max-width: 600px){.payments-page__table-wrap{overflow-x:visible}.payments-table{display:block;min-width:0;width:100%}.payments-table thead{display:none}.payments-table tbody{display:block}.payments-table__row{display:grid;grid-template-columns:1fr auto;gap:4px 10px;padding:12px 14px;border-bottom:1px solid var(--color-border)}.payments-table td{display:block;padding:0;vertical-align:top}.payments-table td:nth-child(1){grid-column:1;grid-row:1}.payments-table td:nth-child(2){grid-column:1;grid-row:2}.payments-table td:nth-child(3){grid-column:2;grid-row:1;text-align:right;align-self:start}.payments-table td:nth-child(4){grid-column:2;grid-row:2;text-align:right}.payments-table td:nth-child(5){grid-column:1;grid-row:3}.payments-table td:nth-child(6){grid-column:2;grid-row:3;text-align:right;align-self:center}.payments-table td:nth-child(7){grid-column:1 / -1;grid-row:4;padding-top:8px}.payments-table__actions{opacity:1;justify-content:flex-end}.payments-table__period{font-size:var(--font-xs)}}.reports-page{display:flex;flex-direction:column;gap:var(--space-xl);animation:pageEnter .3s ease both}.reports-page__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.reports-page__title{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);letter-spacing:-.02em}.reports-page__subtitle{font-size:var(--font-md);color:var(--color-text-secondary);margin-top:2px}.reports-page__actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.rpt-error{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--color-danger-bg);border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-md)}.rpt-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}.rpt-kpi{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:box-shadow var(--transition-normal)}.rpt-kpi:hover{box-shadow:var(--shadow-md)}.rpt-kpi__icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.rpt-kpi--teal .rpt-kpi__icon{background:var(--color-primary-dim);color:var(--color-primary)}.rpt-kpi--green .rpt-kpi__icon{background:var(--color-green-dim);color:var(--color-green)}.rpt-kpi--warning .rpt-kpi__icon{background:var(--color-warning-bg);color:var(--color-warning)}.rpt-kpi--danger .rpt-kpi__icon{background:var(--color-danger-bg);color:var(--color-danger)}.rpt-kpi--teal{border-left:3px solid var(--color-primary)}.rpt-kpi--green{border-left:3px solid var(--color-green)}.rpt-kpi--warning{border-left:3px solid var(--color-warning)}.rpt-kpi--danger{border-left:3px solid var(--color-danger)}.rpt-kpi__body{display:flex;flex-direction:column;gap:2px;min-width:0}.rpt-kpi__label{font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.rpt-kpi__value{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);letter-spacing:-.02em;line-height:1.1}.rpt-kpi__sub{font-size:var(--font-xs);color:var(--color-text-muted);margin-top:2px}.rpt-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.rpt-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.rpt-card__head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.rpt-card__title{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.rpt-card__badge{font-size:var(--font-xs);font-weight:var(--weight-medium);color:var(--color-text-muted);background:var(--color-bg-elevated);padding:3px 8px;border-radius:var(--radius-full);white-space:nowrap}.rpt-right-col{display:flex;flex-direction:column;gap:var(--space-md)}.rpt-bar-list{display:flex;flex-direction:column;gap:var(--space-sm)}.rpt-bar-row{display:grid;grid-template-columns:140px 1fr auto;align-items:center;gap:var(--space-sm)}.rpt-bar-row__name{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-sm);color:var(--color-text-secondary);min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.rpt-bar-row__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.rpt-bar-row__track{height:6px;background:var(--color-bg-elevated);border-radius:var(--radius-full);overflow:hidden}.rpt-bar-row__fill{height:100%;border-radius:var(--radius-full);transition:width .6s cubic-bezier(.34,1.56,.64,1);min-width:2px}.rpt-bar-row__count,.rpt-bar-row__pct{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-primary);text-align:right;min-width:24px}.rpt-bar-row:has(.rpt-bar-row__amount){grid-template-columns:120px 1fr 36px 72px}.rpt-bar-row__amount{font-size:var(--font-xs);color:var(--color-text-muted);text-align:right;white-space:nowrap}.rpt-summary__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}.rpt-sum-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-md);background:var(--color-bg-elevated);border-radius:var(--radius-md)}.rpt-sum-stat__value{font-size:var(--font-3xl);font-weight:var(--weight-extrabold);letter-spacing:-.03em;line-height:1}.rpt-sum-stat__label{font-size:var(--font-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.rpt-tooltip{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px;display:flex;flex-direction:column;gap:2px;box-shadow:var(--shadow-md)}.rpt-tooltip__label{font-size:var(--font-xs);color:var(--color-text-muted)}.rpt-tooltip__value{font-size:var(--font-md);font-weight:var(--weight-bold);color:var(--color-text-primary)}.spin{animation:spinOnce .7s linear infinite}@keyframes spinOnce{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.rpt-empty{font-size:var(--font-sm);color:var(--color-text-muted);text-align:center;padding:var(--space-lg) 0}.rpt-empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-3xl) var(--space-2xl);color:var(--color-text-muted);text-align:center}.rpt-empty-state p{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--color-text-secondary)}.rpt-empty-state span{font-size:var(--font-md);max-width:360px}.rpt-skeleton{display:flex;flex-direction:column;gap:var(--space-xl);animation:pulse 1.5s ease-in-out infinite}.rpt-skeleton__kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}.rpt-skeleton__kpi{height:96px;background:var(--color-bg-surface);border-radius:var(--radius-lg)}.rpt-skeleton__charts-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.rpt-skeleton__chart{height:300px;background:var(--color-bg-surface);border-radius:var(--radius-lg)}.rpt-skeleton__chart-col{display:flex;flex-direction:column;gap:var(--space-md)}.rpt-skeleton__chart-half{flex:1;background:var(--color-bg-surface);border-radius:var(--radius-lg)}@media (max-width: 1100px){.rpt-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.rpt-charts-grid,.rpt-skeleton__charts-row{grid-template-columns:1fr}}@media (max-width: 600px){.reports-page__header{flex-direction:column;align-items:flex-start}.rpt-kpi-grid{grid-template-columns:1fr 1fr}.rpt-summary__grid{grid-template-columns:repeat(2,1fr)}.rpt-skeleton__kpi-row{grid-template-columns:1fr 1fr}.rpt-bar-row{grid-template-columns:110px 1fr auto}.rpt-bar-row:has(.rpt-bar-row__amount){grid-template-columns:100px 1fr auto}.rpt-bar-row__amount{display:none}}@media (max-width: 480px){.rpt-kpi-grid,.rpt-summary__grid{grid-template-columns:1fr 1fr}.reports-page__header{gap:8px}.reports-page__header>div:last-child{flex-wrap:wrap;gap:6px}}@media print{.reports-page__actions{display:none}.rpt-card{break-inside:avoid;border:1px solid #ddd}.rpt-kpi,.rpt-charts-grid{break-inside:avoid}body{background:#fff!important;color:#111!important}}.week-calendar{position:relative}.week-calendar__grid{display:flex;gap:0;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto;-webkit-overflow-scrolling:touch}.week-calendar__time-col{flex-shrink:0;width:52px;border-right:1px solid var(--color-border)}.week-calendar__time-header{height:44px;border-bottom:1px solid var(--color-border)}.week-calendar__time-slot{height:48px;display:flex;align-items:flex-start;padding-top:4px;padding-right:8px;justify-content:flex-end;font-size:10px;color:var(--color-text-muted);font-variant-numeric:tabular-nums;border-bottom:1px solid var(--color-border)}.week-calendar__day-col{flex:1;min-width:110px;border-right:1px solid var(--color-border)}.week-calendar__day-col:last-child{border-right:none}.week-calendar__day-header{height:44px;display:flex;align-items:center;justify-content:space-between;padding:0 10px;border-bottom:1px solid var(--color-border);background:var(--color-bg-elevated)}.week-calendar__day-name{font-size:var(--font-xs);font-weight:var(--weight-bold);color:var(--color-text-primary);letter-spacing:.04em}.week-calendar__day-count{font-size:10px;color:var(--color-text-muted);background:var(--color-bg-hover);border-radius:10px;padding:1px 6px}.week-calendar__day-body{position:relative;height:816px}.week-calendar__hour-line{height:48px;border-bottom:1px solid var(--color-border);opacity:.4}.week-calendar__block{position:absolute;left:4px;right:4px;border-radius:var(--radius-sm);border-left:3px solid;padding:4px 6px;cursor:pointer;transition:filter var(--transition-fast),transform var(--transition-fast);z-index:1}.week-calendar__block:hover{filter:brightness(1.15);transform:scaleX(1.01);z-index:10}.week-calendar__block--open{z-index:300}.week-calendar__block--cancelled{opacity:.5;filter:grayscale(.6)}.week-calendar__block-name{font-size:11px;font-weight:var(--weight-bold);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.week-calendar__block-meta,.week-calendar__block-instructor{display:flex;align-items:center;gap:3px;font-size:9px;color:var(--color-text-muted);margin-top:2px;white-space:nowrap;overflow:hidden}.week-calendar__block-status{display:inline-block;font-size:8px;font-weight:var(--weight-bold);color:var(--color-danger);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.week-calendar__tooltip{position:absolute;top:calc(100% + 4px);left:0;z-index:200;width:220px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden}.week-calendar__tooltip-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 8px;border-top:3px solid;border-bottom:1px solid var(--color-border);background:var(--color-bg-surface)}.week-calendar__tooltip-name{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--color-text-primary)}.week-calendar__tooltip-actions{display:flex;gap:4px}.week-calendar__tooltip-actions button{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-sm);background:var(--color-bg-hover);border:none;cursor:pointer;color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.week-calendar__tooltip-actions button:hover{background:var(--color-primary);color:#fff}.week-calendar__tooltip-delete:hover{background:var(--color-danger)!important;color:#fff!important}.week-calendar__tooltip-body{padding:8px 12px 10px;display:flex;flex-direction:column;gap:5px}.week-calendar__tooltip-row{display:flex;justify-content:space-between;align-items:center;font-size:11px}.week-calendar__tooltip-row span:first-child{color:var(--color-text-muted)}.week-calendar__tooltip-row span:last-child{color:var(--color-text-primary);font-weight:var(--weight-medium);text-align:right}.week-calendar__tooltip-notes{font-size:11px;color:var(--color-text-secondary);font-style:italic;border-top:1px solid var(--color-border);padding-top:5px;margin-top:2px}.week-calendar__status{font-size:10px;font-weight:var(--weight-semibold);padding:1px 6px;border-radius:10px}.week-calendar__status--active{background:#4caf6a26;color:#4caf6a}.week-calendar__status--cancelled{background:#ef444426;color:#ef4444}.week-calendar__status--suspended{background:#f59e0b26;color:#f59e0b}.week-calendar__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150}.week-calendar__mobile{display:none}@media (max-width: 768px){.week-calendar__grid{display:none}.week-calendar__mobile{display:flex;flex-direction:column;gap:6px}.week-calendar__mobile-day{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.week-calendar__mobile-header{display:flex;align-items:center;gap:8px;width:100%;padding:14px 16px;background:none;border:none;cursor:pointer;text-align:left}.week-calendar__mobile-dayname{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--color-text-primary);flex:1}.week-calendar__mobile-count{font-size:var(--font-xs);color:var(--color-text-muted)}.week-calendar__mobile-chevron{color:var(--color-text-muted);transition:transform var(--transition-fast);flex-shrink:0}.week-calendar__mobile-chevron--open{transform:rotate(180deg)}.week-calendar__mobile-classes{border-top:1px solid var(--color-border);padding:8px;display:flex;flex-direction:column;gap:6px}.week-calendar__mobile-empty{font-size:var(--font-sm);color:var(--color-text-muted);text-align:center;padding:12px}.week-calendar__mobile-card{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--color-bg-elevated);border-radius:var(--radius-sm);border-left:3px solid}.week-calendar__mobile-card-info{flex:1;display:flex;flex-direction:column;gap:2px}.week-calendar__mobile-card-name{font-size:var(--font-sm);font-weight:var(--weight-semibold)}.week-calendar__mobile-card-time{font-size:var(--font-xs);color:var(--color-text-muted)}.week-calendar__mobile-card-actions{display:flex;gap:4px}.week-calendar__mobile-card-actions button{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);background:var(--color-bg-hover);border:none;cursor:pointer;color:var(--color-text-secondary)}}.instructor-modal__form{display:flex;flex-direction:column;gap:16px}.instructor-modal__row{display:flex;gap:12px}.instructor-modal__field{display:flex;flex-direction:column;gap:6px}.instructor-modal__field--grow{flex:1;min-width:0}.instructor-modal__label{font-size:11px;font-weight:700;color:var(--color-text-muted);letter-spacing:.08em;text-transform:uppercase}.instructor-modal__input{padding:10px 12px;background:var(--color-bg-input, rgba(255,255,255,.05));border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-sm);font-family:var(--font-family);transition:border-color .2s,box-shadow .2s;box-sizing:border-box;width:100%}.instructor-modal__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1aadbe26}.instructor-modal__toggle{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.instructor-modal__toggle input{display:none}.instructor-modal__toggle-track{width:40px;height:22px;border-radius:11px;background:var(--color-bg-elevated);border:1px solid var(--color-border);position:relative;transition:background .2s,border-color .2s;flex-shrink:0}.instructor-modal__toggle-track:after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:var(--color-text-muted);top:2px;left:2px;transition:transform .2s,background .2s}.instructor-modal__toggle input:checked+.instructor-modal__toggle-track{background:var(--color-primary);border-color:var(--color-primary)}.instructor-modal__toggle input:checked+.instructor-modal__toggle-track:after{transform:translate(18px);background:#fff}.instructor-modal__toggle-label{font-size:var(--font-sm);color:var(--color-text-secondary)}.instructor-modal__spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:instSpin .7s linear infinite}@keyframes instSpin{to{transform:rotate(360deg)}}.instructor-modal__textarea{resize:vertical;min-height:72px}.ip-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;animation:ipFadeIn .2s ease}@keyframes ipFadeIn{0%{opacity:0}to{opacity:1}}.ip{position:fixed;top:0;right:0;bottom:0;width:440px;max-width:100vw;background:var(--color-bg-surface);border-left:1px solid var(--color-border);z-index:201;display:flex;flex-direction:column;overflow:hidden;animation:ipSlideIn .25s cubic-bezier(.4,0,.2,1)}@keyframes ipSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ip__header{display:flex;align-items:center;gap:14px;padding:20px 20px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.ip__header-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}.ip__header-info{flex:1;min-width:0}.ip__header-name{font-size:16px;font-weight:700;color:var(--color-text-primary);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ip__header-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ip__specialty{font-size:12px;color:var(--color-primary);font-weight:600}.ip__status{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;letter-spacing:.04em}.ip__status--active{background:#4caf6a26;color:#4caf6a}.ip__status--inactive{background:var(--color-bg-elevated);color:var(--color-text-muted)}.ip__rate{font-size:11px;color:var(--color-text-muted);background:var(--color-bg-elevated);padding:2px 8px;border-radius:10px}.ip__header-actions{display:flex;gap:6px;flex-shrink:0}.ip__btn-icon{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s}.ip__btn-icon:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.ip__loading{display:flex;justify-content:center;padding:60px 0;flex:1}.ip__spinner{width:28px;height:28px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:ipSpin .7s linear infinite}@keyframes ipSpin{to{transform:rotate(360deg)}}.ip__stats{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--color-border);flex-shrink:0}.ip__stat{display:flex;flex-direction:column;align-items:center;gap:3px;padding:14px 8px;color:var(--color-text-muted);border-right:1px solid var(--color-border)}.ip__stat:last-child{border-right:none}.ip__stat-value{font-size:18px;font-weight:700;color:var(--color-text-primary);line-height:1}.ip__stat-label{font-size:10px;text-align:center;color:var(--color-text-muted)}.ip__tabs{display:flex;border-bottom:1px solid var(--color-border);flex-shrink:0;padding:0 4px}.ip__tab{flex:1;padding:10px 6px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:12px;font-weight:600;color:var(--color-text-muted);font-family:var(--font-family);cursor:pointer;transition:color .15s,border-color .15s}.ip__tab:hover{color:var(--color-text-primary)}.ip__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.ip__body{flex:1;overflow-y:auto;padding:16px 20px;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.ip__section-list{display:flex;flex-direction:column;gap:20px}.ip__section{display:flex;flex-direction:column;gap:8px}.ip__section-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.ip__section-title{font-size:11px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;display:block}.ip__section-sub{font-size:11px;color:var(--color-primary);margin-left:8px}.ip__empty-text{font-size:13px;color:var(--color-text-muted);margin:0;padding:8px 0}.ip__class-list{display:flex;flex-direction:column;gap:6px}.ip__class-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border)}.ip__class-dot{width:8px;height:8px;border-radius:50%;margin-top:4px;flex-shrink:0}.ip__class-name{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 2px}.ip__class-time{font-size:11px;color:var(--color-text-muted);margin:0}.ip__info-list{display:flex;flex-direction:column;gap:8px}.ip__info-row{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--color-text-secondary)}.ip__info-row svg{flex-shrink:0;margin-top:2px;color:var(--color-text-muted)}.ip__info-row--notes{align-items:flex-start}.ip__cronograma{display:flex;flex-direction:column;gap:4px}.ip__cron-day{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border)}.ip__cron-day--empty{opacity:.5}.ip__cron-day-label{font-size:11px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;width:28px;flex-shrink:0;padding-top:2px}.ip__cron-classes{flex:1;display:flex;flex-direction:column;gap:4px}.ip__cron-free{font-size:12px;color:var(--color-text-muted)}.ip__cron-class{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;border-left:3px solid var(--color-primary);background:#1aadbe0f;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.ip__cron-class-name{font-size:12px;font-weight:600;color:var(--color-text-primary)}.ip__cron-class-time{font-size:11px;color:var(--color-text-muted)}.ip__action-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-elevated);color:var(--color-primary);font-size:12px;font-weight:600;font-family:var(--font-family);cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.ip__action-btn:hover{border-color:var(--color-primary);background:#1aadbe0f}.ip__inline-form{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:14px;display:flex;flex-direction:column;gap:10px}.ip__form-row{display:flex;gap:10px}.ip__form-field{display:flex;flex-direction:column;gap:4px;flex:1}.ip__form-field label{font-size:10px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.ip__form-field input,.ip__form-field select{padding:8px 10px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:13px;font-family:var(--font-family);transition:border-color .15s}.ip__form-field input:focus,.ip__form-field select:focus{outline:none;border-color:var(--color-primary)}.ip__form-field select option{background:var(--color-bg-surface)}.ip__submit-btn{align-self:flex-end;padding:8px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--font-family);cursor:pointer;display:flex;align-items:center;gap:6px;transition:opacity .15s}.ip__submit-btn:hover:not(:disabled){opacity:.88}.ip__submit-btn:disabled{opacity:.5;cursor:not-allowed}.ip__btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:ipSpin .7s linear infinite}.ip__pay-list{display:flex;flex-direction:column;gap:6px}.ip__pay-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border)}.ip__pay-left{display:flex;flex-direction:column;gap:2px;min-width:0}.ip__pay-period{font-size:13px;font-weight:600;color:var(--color-text-primary)}.ip__pay-meta{font-size:11px;color:var(--color-text-muted)}.ip__pay-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.ip__pay-amount{font-size:14px;font-weight:700;color:#4caf6a}.ip__pay-date{font-size:10px;color:var(--color-text-muted)}.ip__sub-list{display:flex;flex-direction:column;gap:6px}.ip__sub-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--color-bg-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border)}.ip__sub-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;white-space:nowrap;flex-shrink:0;margin-top:1px}.ip__sub-badge--in{background:#4caf6a26;color:#4caf6a}.ip__sub-badge--out{background:#ef44441f;color:#ef4444}.ip__sub-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.ip__sub-class{font-size:13px;font-weight:600;color:var(--color-text-primary)}.ip__sub-detail{font-size:11px;color:var(--color-text-muted)}.ip__sub-notes{font-size:11px;color:var(--color-text-muted);font-style:italic}.ip__sub-arrow{color:var(--color-text-muted);flex-shrink:0;margin-top:2px}@media (max-width: 480px){.ip{width:100vw}.ip__stats{grid-template-columns:repeat(2,1fr)}.ip__stat:nth-child(2){border-right:none}}.routine-modal__form{display:flex;flex-direction:column;gap:14px}.routine-modal__row{display:flex;gap:10px;flex-wrap:wrap}.routine-modal__field{display:flex;flex-direction:column;gap:5px;min-width:0}.routine-modal__field--grow{flex:1}.routine-modal__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.routine-modal__input{padding:8px 10px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-sm);font-family:var(--font-family);outline:none;width:100%;transition:border-color .15s}.routine-modal__input:focus{border-color:var(--color-primary)}.routine-modal__input--sm{width:90px}.routine-modal__blocks-header{display:flex;align-items:center;justify-content:space-between;padding:4px 0 2px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-top:1px solid var(--color-border);margin-top:4px}.routine-modal__block-name{flex:1;background:none;border:none;font-size:var(--font-sm);font-weight:600;color:var(--color-text-primary);font-family:var(--font-family);outline:none}.routine-modal__block-text{width:100%;padding:10px 12px;background:var(--color-bg-surface);border:none;color:var(--color-text-primary);font-size:13px;font-family:var(--font-family);line-height:1.6;resize:vertical;box-sizing:border-box;outline:none}.routine-modal__block-text:focus{background:var(--color-bg-elevated)}.modal-btn{padding:9px 20px;border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:600;font-family:var(--font-family);border:1px solid transparent;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}.modal-btn:disabled{opacity:.5;cursor:not-allowed}.modal-btn--ghost{background:transparent;border-color:var(--color-border);color:var(--color-text-secondary)}.modal-btn--ghost:hover:not(:disabled){background:var(--color-bg-hover)}.modal-btn--primary{background:var(--color-primary);color:#fff}.modal-btn--primary:hover:not(:disabled){background:var(--color-primary-dark)}.routine-modal__spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.schedule-page{display:flex;flex-direction:column;gap:var(--space-lg);animation:fadeIn var(--transition-slow) both}.schedule-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.schedule-page__title{font-size:var(--font-2xl);font-weight:var(--weight-bold);color:var(--color-text-primary);margin:0}.schedule-page__subtitle{font-size:var(--font-sm);color:var(--color-text-muted);margin:4px 0 0}.schedule-page__add-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:var(--weight-semibold);font-family:var(--font-family);cursor:pointer;transition:opacity var(--transition-fast),transform var(--transition-fast);box-shadow:0 4px 16px #1aadbe4d;white-space:nowrap}.schedule-page__add-btn:hover{opacity:.9;transform:translateY(-1px)}.schedule-page__tabs{display:flex;gap:4px;border-bottom:1px solid var(--color-border);padding-bottom:0}.schedule-page__tab{display:flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-muted);font-family:var(--font-family);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.schedule-page__tab:hover{color:var(--color-text-primary)}.schedule-page__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.schedule-page__tab-badge{background:var(--color-primary);color:#fff;font-size:10px;font-weight:var(--weight-bold);border-radius:10px;padding:0 5px;min-width:16px;text-align:center}.schedule-page__loading{display:flex;justify-content:center;padding:80px 0}.schedule-page__spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}.schedule-instructors{display:flex;flex-direction:column;gap:var(--space-md)}.schedule-instructors__toolbar{display:flex;align-items:center;justify-content:space-between}.schedule-instructors__count{font-size:var(--font-sm);color:var(--color-text-muted);margin:0}.schedule-instructors__add{display:flex;align-items:center;gap:5px;padding:7px 14px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-primary);font-family:var(--font-family);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.schedule-instructors__add:hover{border-color:var(--color-primary);background:#1aadbe0f}.schedule-instructors__empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:60px 0;color:var(--color-text-muted);text-align:center}.schedule-instructors__empty p{margin:0;font-size:var(--font-sm)}.schedule-instructors__empty button{padding:8px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:var(--weight-semibold);font-family:var(--font-family);cursor:pointer}.schedule-instructors__grid{display:flex;flex-direction:column;gap:8px}.instructor-card{display:flex;align-items:center;gap:var(--space-md);padding:14px 18px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.instructor-card:hover{border-color:#1aadbe66}.instructor-card--selected{border-color:var(--color-primary);background:#1aadbe0d}.instructor-card--inactive{opacity:.6}.instructor-card__avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));display:flex;align-items:center;justify-content:center;font-size:var(--font-lg);font-weight:var(--weight-bold);color:#fff;flex-shrink:0}.instructor-card__info{flex:1;min-width:0}.instructor-card__name{font-size:var(--font-base);font-weight:var(--weight-semibold);color:var(--color-text-primary);margin:0 0 2px}.instructor-card__specialty{font-size:var(--font-sm);color:var(--color-primary);margin:0 0 4px}.instructor-card__meta{display:flex;gap:12px;flex-wrap:wrap}.instructor-card__meta span{font-size:var(--font-xs);color:var(--color-text-muted)}.instructor-card__right{display:flex;align-items:center;gap:var(--space-md);flex-shrink:0}.instructor-card__classes{font-size:var(--font-xs);color:var(--color-text-muted);background:var(--color-bg-elevated);border-radius:10px;padding:2px 8px}.instructor-card__badge{font-size:10px;font-weight:var(--weight-semibold);color:var(--color-text-muted);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:10px;padding:1px 8px}.instructor-card__actions{display:flex;gap:6px}.instructor-card__actions button{padding:5px 12px;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:var(--weight-semibold);font-family:var(--font-family);cursor:pointer;border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.instructor-card__actions button:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.instructor-card__delete:hover{background:var(--color-danger)!important;border-color:var(--color-danger)!important}@media (max-width: 640px){.schedule-page__add-btn span{display:none}.instructor-card{flex-wrap:wrap;gap:var(--space-sm)}.instructor-card__right{width:100%;justify-content:flex-end}}.routines-tab{display:flex;flex-direction:column;gap:14px}.routines-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.routines-filters{display:flex;gap:8px;flex-wrap:wrap}.routines-search{padding:8px 12px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-sm);font-family:var(--font-family);width:200px}.routines-search:focus{outline:none;border-color:var(--color-primary)}.routines-select{padding:8px 12px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-sm);font-family:var(--font-family)}.routines-select:focus{outline:none;border-color:var(--color-primary)}.routines-add-btn{display:flex;align-items:center;gap:5px;padding:8px 14px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-primary);font-size:var(--font-sm);font-weight:600;font-family:var(--font-family);cursor:pointer;white-space:nowrap;transition:background .15s}.routines-add-btn:hover{border-color:var(--color-primary);background:#1aadbe0f}.routines-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 0;color:var(--color-text-muted);text-align:center}.routines-empty p{margin:0;font-size:var(--font-sm)}.routines-empty button{padding:8px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;font-family:var(--font-family);cursor:pointer}.routines-list{display:flex;flex-direction:column;gap:8px}.routine-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.routine-card__header{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;transition:background .12s}.routine-card__header:hover{background:var(--color-bg-elevated)}.routine-card__left{display:flex;align-items:flex-start;gap:10px;flex:1;min-width:0}.routine-card__diff{flex-shrink:0;font-size:10px;font-weight:700;padding:2px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.routine-card__name{margin:0;font-size:var(--font-base);font-weight:600;color:var(--color-text-primary)}.routine-card__meta{margin:3px 0 0;font-size:12px;color:var(--color-text-muted)}.routine-card__instructor{font-weight:600;color:var(--color-text-secondary)}.routine-card__desc{margin:4px 0 0;font-size:12px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.routine-card__right{display:flex;align-items:center;gap:6px;flex-shrink:0;color:var(--color-text-muted)}.routine-card__action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:none;cursor:pointer;color:var(--color-text-muted);transition:background .12s,color .12s}.routine-card__action-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.routine-card__action-btn--del:hover{background:var(--color-danger);border-color:var(--color-danger)}.routine-card__body{padding:14px 16px 16px;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:12px}.routine-block__name{margin:0 0 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary)}.routine-block__text{margin:0;padding:8px 10px;font-family:var(--font-family);font-size:13px;line-height:1.65;color:var(--color-text-secondary);white-space:pre-wrap;background:var(--color-bg-elevated);border-radius:var(--radius-sm)}.routine-modal{max-width:680px}.routine-modal__blocks-header{display:flex;align-items:center;justify-content:space-between;padding:4px 0 2px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-top:1px solid var(--color-border)}.routine-modal__add-block{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--color-primary);font-size:12px;font-weight:600;font-family:var(--font-family);cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm)}.routine-modal__add-block:hover{background:#1aadbe14}.routine-modal__blocks{display:flex;flex-direction:column;gap:10px}.routine-modal__block{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.routine-modal__block-header{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--color-bg-surface);border-bottom:1px solid var(--color-border)}.routine-modal__grip{color:var(--color-text-muted);flex-shrink:0}.routine-modal__block-name{flex:1;background:none;border:none;font-size:var(--font-sm);font-weight:600;color:var(--color-text-primary);font-family:var(--font-family)}.routine-modal__block-name:focus{outline:none}.routine-modal__del-block{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:2px;display:flex;align-items:center;transition:color .12s}.routine-modal__del-block:hover{color:var(--color-danger)}.routine-modal__block-text{width:100%;padding:10px 12px;background:var(--color-bg-surface);border:none;border-top:1px solid var(--color-border);color:var(--color-text-primary);font-size:13px;font-family:var(--font-family);line-height:1.6;resize:vertical;box-sizing:border-box}.routine-modal__block-text:focus{outline:none;background:var(--color-bg-elevated)}.routine-modal__block-text::placeholder{color:var(--color-text-muted)}.settings-page{display:flex;flex-direction:column;gap:var(--space-xl);animation:pageEnter .3s ease both}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.settings-page__header{display:flex;flex-direction:column;gap:4px}.settings-page__title{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);letter-spacing:-.02em}.settings-page__subtitle{font-size:var(--font-md);color:var(--color-text-secondary)}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.stt-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.stt-card--full{grid-column:1 / -1}.stt-card__head{display:flex;align-items:center;gap:var(--space-sm)}.stt-card__icon{flex-shrink:0}.stt-card__icon--teal{color:var(--color-primary)}.stt-card__icon--green{color:var(--color-green)}.stt-card__icon--warning{color:var(--color-warning)}.stt-card__title{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--color-text-primary);flex:1}.stt-badge{font-size:var(--font-xs);font-weight:var(--weight-semibold);padding:2px 8px;border-radius:var(--radius-full)}.stt-badge--green{background:var(--color-green-dim);color:var(--color-green);border:1px solid var(--color-green-border)}.stt-form{display:flex;flex-direction:column;gap:var(--space-md)}.stt-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.stt-field{display:flex;flex-direction:column;gap:var(--space-xs)}.stt-field__label{display:flex;align-items:center;gap:5px;font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.stt-field__input{padding:9px var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-md);font-family:var(--font-family);transition:border-color var(--transition-fast);outline:none}.stt-field__input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-dim)}.stt-field__input::placeholder{color:var(--color-text-muted)}.stt-form__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-md);padding-top:var(--space-xs)}.stt-form__saved{display:flex;align-items:center;gap:5px;font-size:var(--font-sm);color:var(--color-success);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translate(4px)}to{opacity:1;transform:translate(0)}}.stt-theme-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.stt-theme-btn{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-lg) var(--space-md);background:var(--color-bg-elevated);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition-normal),box-shadow var(--transition-normal);color:var(--color-text-secondary);font-size:var(--font-md);font-weight:var(--weight-medium);font-family:var(--font-family)}.stt-theme-btn:hover{border-color:var(--color-border-hover)}.stt-theme-btn--active{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-dim);color:var(--color-text-primary)}.stt-theme-btn__sub{font-size:var(--font-xs);color:var(--color-text-muted)}.stt-theme-btn__check{position:absolute;top:10px;right:10px;width:18px;height:18px;background:var(--color-primary);color:var(--color-text-inverse);border-radius:50%;display:flex;align-items:center;justify-content:center}.stt-cron-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.stt-cron{padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-elevated);display:flex;flex-direction:column;gap:var(--space-xs)}.stt-cron--teal{border-left:3px solid var(--color-primary)}.stt-cron--green{border-left:3px solid var(--color-green)}.stt-cron--warning{border-left:3px solid var(--color-warning)}.stt-cron__header{display:flex;align-items:center;gap:var(--space-xs)}.stt-cron__dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;animation:cronPulse 2s ease-in-out infinite}.stt-cron--teal .stt-cron__dot{background:var(--color-primary)}.stt-cron--green .stt-cron__dot{background:var(--color-green)}.stt-cron--warning .stt-cron__dot{background:var(--color-warning)}@keyframes cronPulse{0%,to{opacity:1}50%{opacity:.4}}.stt-cron__label{font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.stt-cron__desc{font-size:var(--font-sm);color:var(--color-text-secondary);line-height:1.5}.stt-cron__schedule{display:flex;align-items:center;gap:5px;font-size:var(--font-xs);color:var(--color-text-muted);margin-top:var(--space-xs)}.stt-maintenance{display:flex;flex-direction:column;gap:var(--space-md)}.stt-maintenance__info{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);background:var(--color-warning-bg);border:1px solid rgba(232,168,56,.2);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-sm);line-height:1.5}.stt-maintenance__info svg{color:var(--color-warning);flex-shrink:0;margin-top:1px}.stt-maintenance__info strong{color:var(--color-text-primary);font-weight:var(--weight-semibold)}.stt-collapse-btn{display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-md);font-family:var(--font-family);font-weight:var(--weight-medium);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast);width:fit-content}.stt-collapse-btn:hover{border-color:var(--color-border-hover);color:var(--color-text-primary)}.stt-candidates{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.stt-candidates__loading,.stt-candidates__empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-2xl);color:var(--color-text-muted);text-align:center}.stt-candidates__loading{flex-direction:row;justify-content:center;padding:var(--space-lg);font-size:var(--font-md)}.stt-candidates__empty svg{color:var(--color-success)}.stt-candidates__empty p{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--color-text-secondary)}.stt-candidates__empty span{font-size:var(--font-md);max-width:360px}.stt-candidates__result{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--color-success-bg);color:var(--color-success);font-size:var(--font-sm);font-weight:var(--weight-medium);border-bottom:1px solid var(--color-border)}.stt-candidates__toolbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border)}.stt-select-all{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-sm);color:var(--color-text-secondary);background:none;border:none;cursor:pointer;font-family:var(--font-family);padding:0;transition:color var(--transition-fast)}.stt-select-all:hover{color:var(--color-text-primary)}.stt-candidates__list{display:flex;flex-direction:column}.stt-candidate-row{display:grid;grid-template-columns:36px 1fr auto;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast)}.stt-candidate-row:last-child{border-bottom:none}.stt-candidate-row:hover{background:var(--color-bg-hover)}.stt-candidate-row--selected{background:var(--color-danger-bg)}.stt-candidate-row__check{color:var(--color-text-muted);display:flex}.stt-candidate-row--selected .stt-candidate-row__check{color:var(--color-danger)}.stt-candidate-row__info{display:flex;flex-direction:column;gap:2px}.stt-candidate-row__name{font-size:var(--font-md);font-weight:var(--weight-medium);color:var(--color-text-primary)}.stt-candidate-row__email{font-size:var(--font-sm);color:var(--color-text-muted)}.stt-candidate-row__days{font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--color-danger);background:var(--color-danger-bg);padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap}.stt-logo-row{display:flex;align-items:center;gap:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.stt-logo-preview{position:relative;width:72px;height:72px;border-radius:var(--radius-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.stt-logo-preview__img{width:100%;height:100%;object-fit:cover}.stt-logo-preview__placeholder{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.stt-logo-preview__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff}.stt-logo-info{display:flex;flex-direction:column;gap:4px}.stt-logo-info__label{font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.stt-logo-info__hint{font-size:var(--font-sm);color:var(--color-text-muted);margin-bottom:4px}.stt-upload-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--color-primary-dim);color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:var(--weight-semibold);font-family:var(--font-family);cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast);width:fit-content}.stt-upload-btn:hover:not(:disabled){background:var(--color-primary);color:var(--color-text-inverse)}.stt-upload-btn:disabled{opacity:.45;cursor:not-allowed}.stt-upload-btn--green{background:var(--color-green-dim);color:var(--color-green);border-color:var(--color-green)}.stt-upload-btn--green:hover:not(:disabled){background:var(--color-green);color:var(--color-text-inverse)}.stt-avatar-row{display:flex;align-items:center;gap:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.stt-avatar-preview{position:relative;width:64px;height:64px;border-radius:50%;background:var(--color-primary);flex-shrink:0;overflow:hidden}.stt-avatar-preview__img{width:100%;height:100%;object-fit:cover}.stt-avatar-preview__initials{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#0d1510}.stt-avatar-preview__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff}.stt-avatar-info{display:flex;flex-direction:column;gap:4px}.stt-avatar-info__label{font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.stt-avatar-info__hint{font-size:var(--font-sm);color:var(--color-text-muted);margin-bottom:4px}.stt-field__input--readonly{background:var(--color-bg-base);color:var(--color-text-muted);cursor:default;opacity:.7}.stt-field__pass-wrap{position:relative}.stt-field__input--pass{padding-right:40px}.stt-field__eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:2px;display:flex;align-items:center;transition:color var(--transition-fast)}.stt-field__eye:hover{color:var(--color-text-secondary)}.spin{animation:spinAnim .7s linear infinite}@keyframes spinAnim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stt-plans-layout{display:grid;grid-template-columns:1fr 340px;gap:var(--space-xl);align-items:start}.stt-plans-list{display:flex;flex-direction:column;gap:var(--space-xs);min-height:80px}.stt-plans-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-2xl) var(--space-lg);color:var(--color-text-muted);text-align:center;border:1px dashed var(--color-border);border-radius:var(--radius-md)}.stt-plans-empty p{font-size:var(--font-md);color:var(--color-text-secondary)}.stt-plans-empty span{font-size:var(--font-sm)}.stt-plan-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated);transition:border-color var(--transition-fast)}.stt-plan-row--editing{border-color:var(--color-primary);background:var(--color-primary-muted, rgba(26, 173, 190, .06))}.stt-plan-row__info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.stt-plan-row__name{font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.stt-plan-row__meta{font-size:var(--font-sm);color:var(--color-text-muted)}.stt-plan-row__price{font-size:var(--font-lg);font-weight:var(--weight-bold);color:var(--color-primary);white-space:nowrap}.stt-plan-row__actions{display:flex;gap:var(--space-xs)}.stt-plan-btn{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg-input);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.stt-plan-btn--edit:hover{border-color:var(--color-primary);color:var(--color-primary)}.stt-plan-btn--delete:hover{border-color:var(--color-danger);color:var(--color-danger)}.stt-plan-form{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated)}.stt-plan-form__title{font-size:var(--font-md);font-weight:var(--weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.stt-plan-form__footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border)}.stt-smtp-hint{font-size:var(--font-md);color:var(--color-text-muted);margin-bottom:var(--space-lg);line-height:1.5}.stt-field--narrow{max-width:140px}.stt-smtp-test{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-sm)}.stt-smtp-test__label{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-secondary)}.stt-smtp-test__row{display:flex;gap:var(--space-sm);align-items:center}.stt-smtp-test__row .stt-field__input{flex:1;min-width:0}@media (max-width: 900px){.settings-grid,.stt-cron-grid{grid-template-columns:1fr}}@media (max-width: 600px){.stt-form__row,.stt-theme-row{grid-template-columns:1fr}.stt-candidates__toolbar{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.stt-field--narrow{max-width:100%}.stt-smtp-test__row{flex-direction:column;align-items:stretch}.stt-plans-layout{grid-template-columns:1fr}}.store-page{display:flex;flex-direction:column;gap:var(--space-lg);animation:fadeIn var(--transition-slow) both}.store-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.store-page__title{font-size:var(--font-2xl);font-weight:var(--weight-bold);color:var(--color-text-primary);margin:0}.store-page__subtitle{font-size:var(--font-sm);color:var(--color-text-muted);margin:4px 0 0}.store-page__header-actions{display:flex;gap:10px;flex-wrap:wrap}.store-page__btn-primary{display:flex;align-items:center;gap:6px;padding:10px 18px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:var(--weight-semibold);font-family:var(--font-family);cursor:pointer;transition:opacity .15s,transform .15s;box-shadow:0 4px 16px #1aadbe4d}.store-page__btn-primary:hover{opacity:.9;transform:translateY(-1px)}.store-page__btn-outline{display:flex;align-items:center;gap:6px;padding:10px 18px;background:var(--color-bg-elevated);color:var(--color-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:var(--weight-semibold);font-family:var(--font-family);cursor:pointer;transition:background .15s,border-color .15s}.store-page__btn-outline:hover{border-color:var(--color-primary);background:#1aadbe0f}.store-stats{display:flex;gap:10px;flex-wrap:wrap}.store-stat{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);flex:1;min-width:130px}.store-stat--clickable{cursor:pointer;transition:border-color .15s}.store-stat--clickable:hover{border-color:var(--color-primary)}.store-stat--alert{border-color:#ef44444d;background:#ef44440a}.store-stat__icon{color:var(--color-text-muted);flex-shrink:0}.store-stat__icon--green{color:#4caf6a}.store-stat__icon--orange{color:#f59e0b}.store-stat__icon--red{color:#ef4444}.store-stat>div{display:flex;flex-direction:column;gap:1px}.store-stat__value{font-size:18px;font-weight:700;color:var(--color-text-primary);line-height:1}.store-stat__value--green{color:#4caf6a}.store-stat__value--orange{color:#f59e0b}.store-stat__value--red{color:#ef4444}.store-stat__label{font-size:11px;color:var(--color-text-muted)}.store-alert{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);font-size:13px;color:#ef4444}.store-alert svg{flex-shrink:0;margin-top:1px}.store-alert strong{font-weight:700}.store-tabs{display:flex;gap:4px;border-bottom:1px solid var(--color-border)}.store-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-muted);font-family:var(--font-family);cursor:pointer;transition:color .15s,border-color .15s}.store-tab:hover{color:var(--color-text-primary)}.store-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.store-tab__badge{background:var(--color-primary);color:#fff;font-size:10px;font-weight:700;border-radius:10px;padding:0 5px;min-width:16px;text-align:center}.store-loading{display:flex;justify-content:center;padding:80px 0}.store-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:storeSpin .7s linear infinite}@keyframes storeSpin{to{transform:rotate(360deg)}}.store-products__toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 0 4px}.store-products__search{flex:1;min-width:200px;padding:8px 12px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-sm);font-family:var(--font-family)}.store-products__search:focus{outline:none;border-color:var(--color-primary)}.store-products__filter{padding:8px 12px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-sm);font-family:var(--font-family);cursor:pointer}.store-products__filter:focus{outline:none}.store-products__filter option{background:var(--color-bg-surface)}.store-products__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;padding:4px 0}.store-product-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .15s,transform .15s}.store-product-card:hover{border-color:#1aadbe66;transform:translateY(-2px)}.store-product-card--low-stock{border-color:#ef444459}.store-product-card__img{width:100%;aspect-ratio:1;object-fit:cover;background:var(--color-bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:40px}.store-product-card__img img{width:100%;height:100%;object-fit:cover}.store-product-card__body{padding:12px 14px;display:flex;flex-direction:column;gap:4px}.store-product-card__name{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--color-text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.store-product-card__meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.store-product-card__cat{font-size:10px;color:var(--color-primary);font-weight:600}.store-product-card__size{font-size:10px;color:var(--color-text-muted);background:var(--color-bg-elevated);border-radius:4px;padding:1px 5px}.store-product-card__prices{display:flex;align-items:center;gap:8px;margin-top:2px}.store-product-card__price{font-size:15px;font-weight:700;color:var(--color-text-primary)}.store-product-card__cost{font-size:11px;color:var(--color-text-muted);text-decoration:line-through}.store-product-card__stock{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.store-product-card__stock-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.store-product-card__stock-badge--ok{background:#4caf6a26;color:#4caf6a}.store-product-card__stock-badge--low{background:#ef44441f;color:#ef4444}.store-product-card__stock-badge--zero{background:#6464641a;color:var(--color-text-muted)}.store-product-card__actions{display:flex;gap:4px;margin-top:8px}.store-product-card__actions button{flex:1;padding:6px 0;border-radius:var(--radius-sm);font-size:11px;font-weight:600;font-family:var(--font-family);cursor:pointer;border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-secondary);transition:background .15s,color .15s}.store-product-card__actions button:hover,.store-product-card__actions button.sell{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.store-product-card__actions button.sell:hover{opacity:.85}.store-product-card__actions button.del:hover{background:var(--color-danger);border-color:var(--color-danger)}.store-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 0;color:var(--color-text-muted);text-align:center}.store-empty p{margin:0;font-size:var(--font-sm)}.store-empty button{padding:8px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;font-family:var(--font-family);cursor:pointer}.store-list__toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 0 4px;flex-wrap:wrap}.store-list__filters{display:flex;gap:8px;flex-wrap:wrap}.store-list__search{padding:8px 12px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-sm);font-family:var(--font-family);width:200px}.store-list__search:focus{outline:none;border-color:var(--color-primary)}.store-list__filter-btn{padding:7px 12px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-muted);font-size:12px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:background .15s,color .15s}.store-list__filter-btn--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.store-list__add{display:flex;align-items:center;gap:5px;padding:8px 14px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-primary);font-size:var(--font-sm);font-weight:600;font-family:var(--font-family);cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.store-list__add:hover{border-color:var(--color-primary);background:#1aadbe0f}.store-table{width:100%;border-collapse:collapse}.store-table th{text-align:left;padding:10px 12px;font-size:10px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border)}.store-table td{padding:12px;font-size:13px;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border)}.store-table tr:last-child td{border-bottom:none}.store-table tr:hover td{background:#ffffff05}.store-badge{display:inline-flex;align-items:center;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px}.store-badge--paid{background:#4caf6a26;color:#4caf6a}.store-badge--pending{background:#f59e0b26;color:#f59e0b}.store-badge--partial{background:#6366f126;color:#6366f1}.store-badge--arrived{background:#1aadbe26;color:var(--color-primary)}.store-badge--delivered{background:#4caf6a26;color:#4caf6a}.store-badge--cancelled{background:var(--color-bg-elevated);color:var(--color-text-muted)}.store-action-btn{padding:4px 10px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;font-family:var(--font-family);cursor:pointer;border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-secondary);transition:background .15s}.store-action-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.store-action-btn--danger:hover{background:var(--color-danger);border-color:var(--color-danger)}@media (max-width: 768px){.store-stats{gap:8px}.store-stat{min-width:100px;padding:10px 12px}.store-stat__value{font-size:15px}.store-products__grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.store-table{display:block;overflow-x:auto}.store-toolbar{flex-wrap:wrap;gap:8px}.store-toolbar .store-tabs{order:2;width:100%;overflow-x:auto}.store-toolbar>button{order:1;margin-left:auto}}@media (max-width: 480px){.store-stats{grid-template-columns:1fr 1fr}.store-stat{min-width:unset}.store-products__grid{grid-template-columns:1fr 1fr}.store-filters{flex-direction:column;gap:8px}.store-filters input,.store-filters select{width:100%}.store-modal{max-height:95vh;margin:8px;width:calc(100% - 16px)}}.store-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s both}.store-modal{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0006;animation:slideUp .2s both}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.store-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.store-modal__header h3{margin:0;font-size:var(--font-lg);font-weight:var(--weight-bold);color:var(--color-text-primary)}.store-modal__close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:color .15s}.store-modal__close:hover{color:var(--color-text-primary)}.store-modal__body{display:flex;flex-direction:column;gap:14px;padding:20px 24px 24px}.store-modal__row{display:flex;gap:12px;flex-wrap:wrap}.store-modal__field{display:flex;flex-direction:column;gap:5px;flex:1;min-width:100px}.store-modal__field--wide{flex:2;min-width:180px}.store-modal__field label{font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.store-modal__field input,.store-modal__field select{padding:9px 12px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-sm);font-family:var(--font-family);transition:border-color .15s}.store-modal__field input:focus,.store-modal__field select:focus{outline:none;border-color:var(--color-primary)}.store-modal__input-prefix{display:flex;align-items:center;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:border-color .15s}.store-modal__input-prefix:focus-within{border-color:var(--color-primary)}.store-modal__input-prefix span{padding:0 8px;color:var(--color-text-muted);font-size:var(--font-sm);font-weight:600;background:var(--color-bg-surface);border-right:1px solid var(--color-border);line-height:38px}.store-modal__input-prefix input{border:none;border-radius:0;flex:1}.store-modal__input-prefix input:focus{outline:none;border:none}.store-modal__field--total{justify-content:flex-end}.store-modal__total{padding:9px 12px;font-size:var(--font-base);font-weight:700;color:var(--color-primary);background:#1aadbe0f;border:1px solid rgba(26,173,190,.2);border-radius:var(--radius-md);text-align:right}.store-modal__field--margin{flex:0 0 80px;min-width:60px;justify-content:flex-end}.store-modal__margin{padding:9px 12px;font-size:var(--font-sm);font-weight:700;border-radius:var(--radius-md);text-align:center}.store-modal__margin--pos{background:#4caf6a1a;color:#4caf6a}.store-modal__margin--neg{background:#ef44441a;color:var(--color-danger)}.store-modal__toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:var(--font-sm);color:var(--color-text-secondary);padding:9px 0}.store-modal__image-row{display:flex;gap:16px;align-items:center}.store-modal__image-box{width:80px;height:80px;border-radius:var(--radius-md);border:1px dashed var(--color-border);background:var(--color-bg-elevated);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;color:var(--color-text-muted);font-size:10px;position:relative;overflow:hidden;transition:border-color .15s;flex-shrink:0}.store-modal__image-box:hover{border-color:var(--color-primary)}.store-modal__image-box img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md)}.store-modal__image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;color:#fff}.store-modal__image-box:hover .store-modal__image-overlay{opacity:1}.store-modal__image-info{display:flex;flex-direction:column;gap:4px}.store-modal__image-info p{margin:0;font-size:var(--font-sm);color:var(--color-text-secondary)}.store-modal__remove-img{background:none;border:none;padding:0;font-size:11px;color:var(--color-danger);cursor:pointer;font-family:var(--font-family)}.store-modal__remove-img:hover{text-decoration:underline}.store-modal__actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px;border-top:1px solid var(--color-border);margin-top:4px}.store-modal__btn-cancel{padding:9px 18px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:none;color:var(--color-text-secondary);font-size:var(--font-sm);font-weight:600;font-family:var(--font-family);cursor:pointer;transition:background .15s}.store-modal__btn-cancel:hover{background:var(--color-bg-elevated)}.store-modal__btn-save{padding:9px 20px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;font-size:var(--font-sm);font-weight:600;font-family:var(--font-family);cursor:pointer;transition:opacity .15s}.store-modal__btn-save:hover{opacity:.88}.caja-page{display:flex;flex-direction:column;gap:var(--space-lg);animation:fadeIn var(--transition-slow) both}.caja-header{display:flex;align-items:flex-start;justify-content:space-between}.caja-title{font-size:var(--font-2xl);font-weight:var(--weight-bold);color:var(--color-text-primary);margin:0}.caja-subtitle{font-size:var(--font-sm);color:var(--color-text-muted);margin:4px 0 0}.caja-period-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.caja-period-btns{display:flex;gap:6px}.caja-period-btn{padding:7px 16px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-muted);font-size:12px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:background .15s,color .15s}.caja-period-btn--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.caja-period-custom{display:flex;align-items:center;gap:8px}.caja-period-custom input{padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-elevated);color:var(--color-text-primary);font-size:12px;font-family:var(--font-family)}.caja-period-custom input:focus{outline:none;border-color:var(--color-primary)}.caja-period-custom span{color:var(--color-text-muted);font-size:12px}.caja-period-label{font-size:12px;color:var(--color-text-muted);margin-left:auto}.caja-balance-row{display:flex;gap:12px;align-items:stretch;flex-wrap:wrap}.caja-balance{display:flex;align-items:center;gap:14px;padding:20px 28px;border-radius:var(--radius-lg);border:1px solid;flex:1;min-width:200px}.caja-balance--pos{background:linear-gradient(135deg,#4caf6a1a,#4caf6a08);border-color:#4caf6a4d}.caja-balance--neg{background:linear-gradient(135deg,#ef444414,#ef444405);border-color:#ef444440}.caja-balance__icon{flex-shrink:0}.caja-balance--pos .caja-balance__icon{color:#4caf6a}.caja-balance--neg .caja-balance__icon{color:var(--color-danger)}.caja-balance>div{display:flex;flex-direction:column;gap:3px}.caja-balance__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.caja-balance__value{font-size:32px;font-weight:var(--weight-bold);line-height:1}.caja-balance--pos .caja-balance__value{color:#4caf6a}.caja-balance--neg .caja-balance__value{color:var(--color-danger)}.caja-balance-detail{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex:1;min-width:200px}.caja-bd-item{display:flex;flex-direction:column;gap:4px;flex:1}.caja-bd-item--in svg{color:#4caf6a}.caja-bd-item--out svg{color:var(--color-danger)}.caja-bd-label{font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:5px}.caja-bd-label svg{flex-shrink:0}.caja-bd-value{font-size:20px;font-weight:700}.caja-bd-item--in .caja-bd-value{color:#4caf6a}.caja-bd-item--out .caja-bd-value{color:var(--color-danger)}.caja-bd-sep{font-size:22px;color:var(--color-text-muted);font-weight:300;flex-shrink:0}.caja-stats{display:flex;gap:12px;flex-wrap:wrap}.caja-stat{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex:1;min-width:140px}.caja-stat--main{background:linear-gradient(135deg,#1aadbe14,#1aadbe08);border-color:#1aadbe40}.caja-stat--pending{background:linear-gradient(135deg,#f59e0b14,#f59e0b05);border-color:#f59e0b33}.caja-stat--expense{background:linear-gradient(135deg,#ef444412,#ef444405);border-color:#ef444433}.caja-stat__icon{color:var(--color-text-muted);flex-shrink:0}.caja-stat__icon--blue{color:#6366f1}.caja-stat__icon--green{color:#4caf6a}.caja-stat__icon--orange{color:#f59e0b}.caja-stat__icon--red{color:var(--color-danger)}.caja-stat--main .caja-stat__icon{color:var(--color-primary)}.caja-stat>div{display:flex;flex-direction:column;gap:2px}.caja-stat__value{font-size:22px;font-weight:var(--weight-bold);color:var(--color-text-primary);line-height:1}.caja-stat--main .caja-stat__value{color:var(--color-primary);font-size:26px}.caja-stat__value--blue{color:#6366f1}.caja-stat__value--green{color:#4caf6a}.caja-stat__value--orange{color:#f59e0b}.caja-stat__value--red{color:var(--color-danger)}.caja-stat__label{font-size:11px;color:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.caja-methods{display:flex;gap:12px;flex-wrap:wrap}.caja-method{flex:1;min-width:140px;display:flex;flex-direction:column;gap:6px;padding:14px 16px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.caja-method__icon{display:flex;align-items:center;color:var(--color-text-muted)}.caja-method__label{font-size:11px;color:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.caja-method__amount{font-size:18px;font-weight:var(--weight-bold);color:var(--color-text-primary)}.caja-method__bar{height:3px;background:var(--color-border);border-radius:2px;overflow:hidden}.caja-method__fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .4s ease;min-width:2px}.caja-tabs{display:flex;gap:4px;border-bottom:1px solid var(--color-border);padding-bottom:0}.caja-tab{display:flex;align-items:center;gap:6px;padding:10px 18px;border:none;background:none;font-size:var(--font-sm);font-weight:600;font-family:var(--font-family);color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.caja-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.caja-tab__badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;font-size:10px;font-weight:700;background:#1aadbe26;color:var(--color-primary)}.caja-tab__badge--orange{background:#f59e0b26;color:#f59e0b}.caja-tab__badge--red{background:#ef44441f;color:var(--color-danger)}.caja-tab--red{color:var(--color-danger)!important;border-bottom-color:var(--color-danger)!important}.caja-list{display:flex;flex-direction:column;gap:2px}.caja-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:background .12s}.caja-item:hover{background:var(--color-bg-elevated)}.caja-source{flex-shrink:0;font-size:10px;font-weight:700;padding:2px 7px;border-radius:8px;text-transform:uppercase;letter-spacing:.04em}.caja-source--gym{background:#6366f11f;color:#6366f1}.caja-source--tienda{background:#4caf6a1f;color:#4caf6a}.caja-source--instructor{background:#ef44441a;color:var(--color-danger)}.caja-item__desc{flex:1;font-size:13px;color:var(--color-text-primary);font-weight:500;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.caja-item__meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.caja-item__method{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--color-text-muted)}.caja-item__date{font-size:11px;color:var(--color-text-muted)}.caja-item__right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;min-width:90px}.caja-item__amount{font-size:14px;font-weight:700;color:var(--color-text-primary)}.caja-item__amount--out{color:var(--color-danger)}.caja-item--egreso{border-left:3px solid rgba(239,68,68,.3)}.caja-status{font-size:10px;font-weight:700;padding:1px 6px;border-radius:8px}.caja-status--paid{background:#4caf6a1f;color:#4caf6a}.caja-status--pending{background:#f59e0b1f;color:#f59e0b}.caja-status--overdue{background:#ef44441f;color:var(--color-danger)}.caja-status--partial{background:#6366f11f;color:#6366f1}.caja-empty{display:flex;align-items:center;justify-content:center;padding:48px 0;color:var(--color-text-muted);font-size:var(--font-sm)}.caja-empty p{margin:0}.caja-loading{display:flex;justify-content:center;padding:60px 0}@media (max-width: 640px){.caja-stats{gap:8px}.caja-stat{min-width:120px;padding:12px 14px}.caja-stat__value{font-size:18px}.caja-stat--main .caja-stat__value{font-size:20px}.caja-methods{gap:8px}.caja-item{flex-wrap:wrap;gap:8px}.caja-item__desc{min-width:100%}}@media (max-width: 480px){.caja-stats{grid-template-columns:1fr 1fr}.caja-stat{min-width:unset}.caja-stat--main{grid-column:span 2}.caja-methods{grid-template-columns:1fr 1fr}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-base);padding:var(--space-xl)}.error-boundary__card{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-2xl) var(--space-3xl);background:var(--color-bg-surface);border:1px solid var(--color-danger);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:480px;width:100%;text-align:center}.error-boundary__icon{width:72px;height:72px;background:var(--color-danger-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-danger);margin-bottom:var(--space-xs)}.error-boundary__title{font-size:var(--font-2xl);font-weight:var(--weight-extrabold);color:var(--color-text-primary);letter-spacing:-.02em}.error-boundary__desc{font-size:var(--font-md);color:var(--color-text-secondary)}.error-boundary__code{display:block;padding:var(--space-sm) var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--color-danger);font-family:Courier New,monospace;word-break:break-word;text-align:left;width:100%}.error-boundary__btn{display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-lg);background:var(--color-primary);color:var(--color-text-inverse);border:none;border-radius:var(--radius-md);font-size:var(--font-md);font-weight:var(--weight-semibold);font-family:var(--font-family);cursor:pointer;margin-top:var(--space-sm);transition:background var(--transition-fast)}.error-boundary__btn:hover{background:var(--color-primary-dark)}:root{--color-logo-bg: #1B5738;--color-logo-teal: #1AADBE;--color-logo-green: #4CAF6A;--color-primary: #1AADBE;--color-primary-dark: #148A99;--color-primary-dim: rgba(26, 173, 190, .1);--color-primary-glow: rgba(26, 173, 190, .18);--color-primary-border: rgba(26, 173, 190, .22);--color-green: #4CAF6A;--color-green-dark: #3A8A52;--color-green-dim: rgba(76, 175, 106, .1);--color-green-border: rgba(76, 175, 106, .22);--color-success: #4CAF6A;--color-success-bg: rgba(76, 175, 106, .1);--color-warning: #E8A838;--color-warning-bg: rgba(232, 168, 56, .1);--color-danger: #E05555;--color-danger-bg: rgba(224, 85, 85, .1);--color-info: #1AADBE;--color-info-bg: rgba(26, 173, 190, .1);--activity-musculacion: #4CAF82;--activity-funcional: #26B5A0;--activity-strong: #8B5CF6;--activity-zumba: #E91E8C;--activity-acrobacia-a: #F97316;--activity-acrobacia-k: #D4A017;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-xs: 11px;--font-sm: 12px;--font-base: 13px;--font-md: 14px;--font-lg: 16px;--font-xl: 18px;--font-2xl: 22px;--font-3xl: 28px;--font-4xl: 36px;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-extrabold: 800;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--shadow-xs: 0 1px 4px rgba(0, 0, 0, .12);--shadow-sm: 0 2px 10px rgba(0, 0, 0, .14);--shadow-md: 0 4px 24px rgba(0, 0, 0, .16);--shadow-lg: 0 8px 48px rgba(0, 0, 0, .18);--shadow-glow: 0 0 20px rgba(26, 173, 190, .18);--shadow-glow-green: 0 0 20px rgba(76, 175, 106, .18);--shadow-glow-strong: 0 0 36px rgba(26, 173, 190, .26);--transition-fast: .12s cubic-bezier(.4, 0, .2, 1);--transition-normal: .22s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 256px;--sidebar-width-collapsed: 72px;--header-height: 64px;--content-max-width: 1440px}:root,[data-theme=dark]{--color-scheme: dark;--color-bg-base: #111916;--color-bg-sidebar: #0C1410;--color-bg-surface: #172018;--color-bg-elevated: #1E2B1F;--color-bg-hover: rgba(255, 255, 255, .04);--color-bg-active: rgba(26, 173, 190, .09);--glass-bg: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .07);--glass-blur: blur(16px);--color-text-primary: #EDF2EE;--color-text-secondary: #7A9A86;--color-text-muted: #4A6A55;--color-text-inverse: #111916;--color-text-on-sidebar:#EDF2EE;--color-border: rgba(255, 255, 255, .07);--color-border-hover: rgba(26, 173, 190, .28);--color-border-focus: rgba(26, 173, 190, .45);--shadow-xs: 0 1px 4px rgba(0, 0, 0, .35);--shadow-sm: 0 2px 10px rgba(0, 0, 0, .4);--shadow-md: 0 4px 24px rgba(0, 0, 0, .45);--shadow-lg: 0 8px 48px rgba(0, 0, 0, .55)}[data-theme=light]{--color-scheme: light;--color-bg-base: #EEF4F0;--color-bg-sidebar: #1A5236;--color-bg-surface: #FFFFFF;--color-bg-elevated: #F5F9F6;--color-bg-hover: rgba(26, 173, 190, .05);--color-bg-active: rgba(26, 173, 190, .08);--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(0, 0, 0, .06);--glass-blur: blur(16px);--color-text-primary: #1A2C20;--color-text-secondary: #4A7055;--color-text-muted: #7A9E87;--color-text-inverse: #FFFFFF;--color-text-on-sidebar:#EDF2EE;--color-border: rgba(0, 0, 0, .08);--color-border-hover: rgba(26, 173, 190, .35);--color-border-focus: rgba(26, 173, 190, .5);--shadow-xs: 0 1px 4px rgba(0, 0, 0, .06);--shadow-sm: 0 2px 10px rgba(0, 0, 0, .08);--shadow-md: 0 4px 24px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 48px rgba(0, 0, 0, .12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-base);color:var(--color-text-primary);background-color:var(--color-bg-base);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}img,svg,video{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{cursor:pointer;border:none;background:none}table{border-collapse:collapse}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#fff3}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}html{color-scheme:var(--color-scheme, dark)}body,.layout__body,.layout__main,.card,.header,.sidebar{transition:background-color var(--transition-normal),border-color var(--transition-normal),color var(--transition-normal)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-semibold);letter-spacing:.02em;text-transform:uppercase}.status-badge--active{background:var(--color-success-bg);color:var(--color-success)}.status-badge--inactive{background:var(--color-warning-bg);color:var(--color-warning)}.status-badge--archived{background:#ffffff0d;color:var(--color-text-muted)}.status-badge--overdue{background:var(--color-danger-bg);color:var(--color-danger)}.page-enter{animation:fadeIn var(--transition-normal) both}.divider{height:1px;background:var(--color-border);margin:var(--space-md) 0}.skeleton{background:linear-gradient(90deg,#ffffff0a,#ffffff14,#ffffff0a);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes skeletonShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.trend-up{color:var(--color-success);font-weight:var(--weight-semibold);font-size:var(--font-sm)}.trend-down{color:var(--color-danger);font-weight:var(--weight-semibold);font-size:var(--font-sm)}
