:root{--color-primary: hsl(30, 85%, 55%);--color-primary-light: hsl(30, 85%, 65%);--color-primary-dark: hsl(30, 85%, 45%);--color-success: hsl(160, 60%, 45%);--color-warning: hsl(45, 90%, 50%);--color-error: hsl(0, 70%, 55%);--grey-50: hsl(30, 8%, 98%);--grey-100: hsl(30, 8%, 96%);--grey-200: hsl(30, 6%, 90%);--grey-300: hsl(30, 6%, 82%);--grey-400: hsl(30, 5%, 64%);--grey-500: hsl(30, 5%, 46%);--grey-600: hsl(30, 6%, 32%);--grey-700: hsl(30, 8%, 22%);--grey-800: hsl(30, 10%, 14%);--grey-900: hsl(30, 12%, 9%);--color-background: var(--grey-900);--color-surface: var(--grey-800);--color-surface-elevated: var(--grey-700);--color-border: var(--grey-700);--color-border-subtle: var(--grey-800);--color-text: var(--grey-200);--color-text-muted: var(--grey-400);--color-text-strong: var(--grey-50);--balance-negative: hsl(0, 70%, 60%);--balance-zero: var(--grey-400);--balance-positive: hsl(160, 60%, 50%);--shadow-sm: 0 1px 2px hsl(30, 10%, 5%, .3);--shadow-md: 0 4px 6px hsl(30, 10%, 5%, .4);--shadow-lg: 0 10px 15px hsl(30, 10%, 5%, .5);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-2xl: 32px;--touch-target: 44px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:1.5;color:var(--color-text);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-light)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;appearance:textfield}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}#root{min-height:100dvh;display:flex;flex-direction:column}.loading-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.page{padding:var(--space-md);color:var(--color-text)}.layout{min-height:100dvh;display:flex;flex-direction:column}.layout__main{flex:1;display:flex;flex-direction:column;padding-bottom:72px}.nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;padding:var(--space-sm) var(--space-md);padding-bottom:max(var(--space-sm),env(safe-area-inset-bottom));background-color:var(--color-surface);border-top:1px solid var(--color-border-subtle)}.nav__item{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:64px;padding:var(--space-xs);color:var(--color-text-muted);text-decoration:none;border-radius:var(--radius-md);transition:color var(--transition-fast)}.nav__item:hover{color:var(--color-text)}.nav__icon{width:24px;height:24px}.nav__label{font-size:var(--font-size-xs)}.nav__item--active{color:var(--color-primary)}.nav__item--active:hover{color:var(--color-primary-light)}.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);border-radius:var(--radius-md);font-weight:500;transition:background-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);cursor:pointer;border:none;text-decoration:none;white-space:nowrap}.button:active:not(:disabled){transform:scale(.98)}.button:disabled{opacity:.5;cursor:not-allowed}.button__content{display:inline-flex;align-items:center;gap:var(--space-sm)}.button__spinner{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:button-spin .6s linear infinite}@keyframes button-spin{to{transform:rotate(360deg)}}.button--primary{background-color:var(--color-primary);color:var(--grey-900)}.button--primary:hover:not(:disabled){background-color:var(--color-primary-light)}.button--secondary{background-color:var(--color-surface-elevated);color:var(--color-text);border:1px solid var(--color-border)}.button--secondary:hover:not(:disabled){background-color:var(--grey-600)}.button--ghost{background-color:transparent;color:var(--color-text)}.button--ghost:hover:not(:disabled){background-color:var(--color-surface)}.button--danger{background-color:var(--color-error);color:#fff}.button--danger:hover:not(:disabled){background-color:#c32222}.button--sm{min-height:32px;padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm)}.button--md{min-height:var(--touch-target);padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-md)}.button--lg{min-height:52px;padding:var(--space-md) var(--space-xl);font-size:var(--font-size-lg)}.button--full-width{width:100%}.button--loading .button__content{opacity:.7}.input{display:flex;flex-direction:column;gap:var(--space-xs)}.input__label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text)}.input__field{min-height:var(--touch-target);padding:var(--space-sm) var(--space-md);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--font-size-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input__field::placeholder{color:var(--color-text-muted)}.input__field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #ee8c2b33}.input__field:disabled{opacity:.5;cursor:not-allowed}.input__field--textarea{min-height:100px;resize:vertical}.input__field--select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a39e97' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;padding-right:calc(var(--space-md) * 2 + 16px);cursor:pointer}.input__hint{font-size:var(--font-size-xs);color:var(--color-text-muted)}.input__error{font-size:var(--font-size-xs);color:var(--color-error)}.input--error .input__field{border-color:var(--color-error)}.input--error .input__field:focus{box-shadow:0 0 0 2px #dd3c3c33}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);overflow:hidden}.card__header{padding:var(--space-md);border-bottom:1px solid var(--color-border-subtle)}.card__title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-strong);margin:0}.card__content{padding:var(--space-md)}.card__footer{padding:var(--space-md);border-top:1px solid var(--color-border-subtle);display:flex;gap:var(--space-sm);justify-content:flex-end}.card--default{border:1px solid var(--color-border-subtle)}.card--elevated{box-shadow:var(--shadow-md)}.card--interactive{border:1px solid var(--color-border-subtle);cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast)}.card--interactive:hover{border-color:var(--color-primary)}.card--interactive:active{transform:scale(.99)}.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-md);background-color:#1a1714cc;backdrop-filter:blur(4px);animation:modal-fade-in .2s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal__dialog{width:100%;max-width:480px;max-height:calc(100dvh - var(--space-xl) * 2);display:flex;flex-direction:column;background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:modal-slide-up .2s ease;outline:none}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-bottom:1px solid var(--color-border-subtle)}.modal__title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-strong);margin:0}.modal__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.modal__close:hover{color:var(--color-text);background-color:var(--color-surface-elevated)}.modal__content{flex:1;overflow-y:auto;padding:var(--space-md)}.modal__footer{display:flex;gap:var(--space-sm);justify-content:flex-end;padding:var(--space-md);border-top:1px solid var(--color-border-subtle)}@media(max-width:480px){.modal{padding:0;align-items:flex-end}.modal__dialog{max-width:none;max-height:90dvh;border-bottom-left-radius:0;border-bottom-right-radius:0;animation:modal-slide-up-mobile .3s ease}@keyframes modal-slide-up-mobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}}.login{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--space-md);background:linear-gradient(135deg,var(--grey-900) 0%,hsl(30,15%,12%) 100%)}.login__form{width:100%;max-width:360px;display:flex;flex-direction:column;gap:var(--space-lg)}.login__header{text-align:center;margin-bottom:var(--space-md)}.login__title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-xs);letter-spacing:-.02em}.login__subtitle{font-size:var(--font-size-md);color:var(--color-text-muted);margin:0}.login__field{display:flex;flex-direction:column;gap:var(--space-xs)}.login__input{min-height:var(--touch-target);padding:var(--space-md);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--font-size-lg);text-align:center;letter-spacing:.1em;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.login__input::placeholder{color:var(--color-text-muted);letter-spacing:normal}.login__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #ee8c2b26}.login__error{padding:var(--space-sm) var(--space-md);background-color:#dd3c3c1a;border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);text-align:center}.dashboard{flex:1;display:flex;flex-direction:column;padding:var(--space-md);padding-bottom:calc(var(--space-md) + 80px);overflow-y:auto}.dashboard__header{margin-bottom:var(--space-lg)}.dashboard__title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong);margin:0}.dashboard__content{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard__stats{display:flex;flex-direction:column;gap:var(--space-md)}.dashboard__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);color:var(--color-text-muted)}.dashboard__actions{position:fixed;bottom:0;left:0;right:0;padding:var(--space-md);background:linear-gradient(to top,var(--color-background) 60%,transparent)}.dashboard__primary-action{display:block;max-width:400px;margin:0 auto}.dashboard__skeleton{display:flex;flex-direction:column;gap:var(--space-md)}.dashboard__skeleton-card{height:120px;background:var(--color-surface);border-radius:var(--radius-lg);animation:skeleton-pulse 1.5s ease-in-out infinite}.stat-card{padding:var(--space-md);background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg)}.stat-card__title{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-md)}.stat-card__content{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.stat-card__item{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-card__value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong)}.stat-card__item--earnings .stat-card__value{color:var(--color-primary)}.stat-card__label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:center}.total-card{padding:var(--space-lg);background:linear-gradient(135deg,var(--color-surface-elevated),var(--color-surface));border:1px solid var(--color-border);border-radius:var(--radius-lg)}.total-card__title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text);margin:0 0 var(--space-lg);text-align:center}.total-card__content{display:flex;flex-direction:column;gap:var(--space-md)}.total-card__item{display:flex;justify-content:space-between;align-items:baseline;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border-subtle)}.total-card__item:last-child{border-bottom:none;padding-bottom:0}.total-card__value{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-strong)}.total-card__item--earnings .total-card__value{color:var(--color-primary)}.total-card__label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.students-page{flex:1;display:flex;flex-direction:column;padding:var(--space-md);padding-bottom:calc(var(--space-md) + 80px);overflow-y:auto}.students-page__pull-indicator{display:flex;align-items:center;justify-content:center;overflow:hidden;transition:height .2s ease-out}.students-page__pull-indicator--refreshing{height:50px!important}.students-page__pull-icon{width:24px;height:24px;color:var(--color-primary);transition:transform .3s ease}.students-page__pull-icon--spinning{animation:spin 1s linear infinite}.students-page__refresh-btn{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);color:var(--color-text-muted);background-color:transparent;border-radius:var(--radius-full);transition:color var(--transition-fast),background-color var(--transition-fast)}.students-page__refresh-btn:hover{color:var(--color-text);background-color:var(--color-surface)}.students-page__refresh-btn:disabled{opacity:.5;cursor:not-allowed}.students-page__refresh-btn svg{width:20px;height:20px}.students-page__refresh-icon--spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.students-page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.students-page__title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong);margin:0}.students-page__link{font-size:var(--font-size-sm);color:var(--color-text-muted)}.students-page__link:hover{color:var(--color-primary)}.students-page__header-actions{display:flex;align-items:center;gap:var(--space-md)}.students-page__add-btn{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);color:var(--color-primary);background-color:transparent;border-radius:var(--radius-full);transition:background-color var(--transition-fast)}.students-page__add-btn:hover{background-color:var(--color-surface)}.students-page__add-btn svg{width:24px;height:24px}.students-page__list{display:flex;flex-direction:column;gap:var(--space-sm)}.students-page__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);color:var(--color-text-muted)}.students-page__actions{position:fixed;bottom:0;left:0;right:0;padding:var(--space-md);background:linear-gradient(to top,var(--color-background) 60%,transparent)}.students-page__primary-action{display:block;max-width:400px;margin:0 auto}.students-page__skeleton{display:flex;flex-direction:column;gap:var(--space-sm)}.students-page__skeleton-card{height:72px;background:var(--color-surface);border-radius:var(--radius-lg);animation:skeleton-pulse 1.5s ease-in-out infinite}.student-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);text-decoration:none;transition:border-color var(--transition-fast),transform var(--transition-fast)}.student-card:hover{border-color:var(--color-primary)}.student-card:active{transform:scale(.99)}.student-card__name{font-size:var(--font-size-md);font-weight:500;color:var(--color-text)}.student-card__balance{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.student-card__lessons{font-size:var(--font-size-md);font-weight:600}.student-card__euros{font-size:var(--font-size-xs);color:var(--color-text-muted)}.student-card__balance--negative .student-card__lessons{color:var(--balance-negative)}.student-card__balance--zero .student-card__lessons{color:var(--balance-zero)}.student-card__balance--positive .student-card__lessons{color:var(--balance-positive)}.add-student-form{display:flex;flex-direction:column;gap:var(--space-md)}.add-student-form__error{padding:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-error);background-color:#dd3c3c1a;border-radius:var(--radius-sm)}.add-student-form__actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-sm)}.add-lesson{flex:1;display:flex;flex-direction:column;padding:var(--space-md);padding-bottom:calc(var(--space-md) + 80px)}.add-lesson__header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.add-lesson__back{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);color:var(--color-text-muted);transition:color var(--transition-fast)}.add-lesson__back:hover{color:var(--color-primary)}.add-lesson__title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong);margin:0}.add-lesson__form{display:flex;flex-direction:column;gap:var(--space-lg);max-width:480px}.add-lesson__actions{position:fixed;bottom:72px;left:0;right:0;padding:var(--space-md);padding-bottom:var(--space-lg);background:linear-gradient(to top,var(--color-background) 80%,transparent)}.add-lesson__submit{display:block;max-width:400px;margin:0 auto}.autocomplete{position:relative}.autocomplete__dropdown{position:absolute;top:calc(100% + var(--space-xs));left:0;right:0;max-height:280px;overflow-y:auto;background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100}.autocomplete__option{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:var(--touch-target);padding:var(--space-sm) var(--space-md);text-align:left;color:var(--color-text);background:none;border:none;cursor:pointer;transition:background-color var(--transition-fast)}.autocomplete__option:hover,.autocomplete__option--focused{background-color:var(--color-surface)}.autocomplete__option:active{background-color:var(--grey-600)}.autocomplete__option-name{font-weight:500}.autocomplete__option-balance{font-size:var(--font-size-sm);color:var(--color-text-muted)}.autocomplete__option-balance--negative{color:var(--balance-negative)}.autocomplete__option-balance--positive{color:var(--balance-positive)}.autocomplete__empty{padding:var(--space-md);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.add-lesson input[type=date]{color-scheme:dark}.add-lesson input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7) sepia(1) saturate(.5) hue-rotate(-20deg);cursor:pointer}.add-payment{flex:1;display:flex;flex-direction:column;padding:var(--space-md);padding-bottom:calc(var(--space-md) + 80px)}.add-payment__header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.add-payment__back{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);color:var(--color-text-muted);transition:color var(--transition-fast)}.add-payment__back:hover{color:var(--color-primary)}.add-payment__title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong);margin:0}.add-payment__form{display:flex;flex-direction:column;gap:var(--space-lg);max-width:480px}.add-payment__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.add-payment__actions{position:fixed;bottom:72px;left:0;right:0;padding:var(--space-md);padding-bottom:var(--space-lg);background:linear-gradient(to top,var(--color-background) 80%,transparent)}.add-payment__submit{display:block;max-width:400px;margin:0 auto}.add-payment input[type=date]{color-scheme:dark}.add-payment input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7) sepia(1) saturate(.5) hue-rotate(-20deg);cursor:pointer}.add-payment input[type=number]{-moz-appearance:textfield}.add-payment input[type=number]::-webkit-inner-spin-button,.add-payment input[type=number]::-webkit-outer-spin-button{opacity:1;height:32px}.add-payment .autocomplete{position:relative}.add-payment .autocomplete__dropdown{position:absolute;top:calc(100% + var(--space-xs));left:0;right:0;max-height:280px;overflow-y:auto;background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100}.add-payment .autocomplete__option{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:var(--touch-target);padding:var(--space-sm) var(--space-md);text-align:left;color:var(--color-text);background:none;border:none;cursor:pointer;transition:background-color var(--transition-fast)}.add-payment .autocomplete__option:hover,.add-payment .autocomplete__option--focused{background-color:var(--color-surface)}.add-payment .autocomplete__option:active{background-color:var(--grey-600)}.add-payment .autocomplete__option-name{font-weight:500}.add-payment .autocomplete__option-balance{font-size:var(--font-size-sm);color:var(--color-text-muted)}.add-payment .autocomplete__option-balance--negative{color:var(--balance-negative)}.add-payment .autocomplete__option-balance--positive{color:var(--balance-positive)}.add-payment .autocomplete__empty{padding:var(--space-md);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.student-detail{flex:1;display:flex;flex-direction:column;padding:var(--space-md);padding-bottom:var(--space-xl)}.student-detail__header{margin-bottom:var(--space-lg)}.student-detail__header-top{display:flex;align-items:center;gap:var(--space-sm)}.student-detail__back{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);margin-left:calc(-1 * var(--space-sm));color:var(--color-text-muted);border-radius:var(--radius-md);transition:color var(--transition-fast),background-color var(--transition-fast)}.student-detail__back:hover{color:var(--color-text);background-color:var(--color-surface)}.student-detail__name{flex:1;font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong);margin:0}.student-detail__edit{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);color:var(--color-text-muted);border-radius:var(--radius-md);transition:color var(--transition-fast),background-color var(--transition-fast)}.student-detail__edit:hover{color:var(--color-primary);background-color:var(--color-surface)}.student-detail__inactive-badge{display:inline-block;margin-top:var(--space-xs);padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs);color:var(--color-text-muted);background-color:var(--color-surface);border-radius:var(--radius-full)}.student-detail__stats{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);margin-bottom:var(--space-lg);background-color:var(--color-surface);border-radius:var(--radius-lg)}.student-detail__balance{display:flex;flex-direction:column;gap:2px}.student-detail__balance-lessons{font-size:var(--font-size-lg);font-weight:700}.student-detail__balance-euros{font-size:var(--font-size-sm);color:var(--color-text-muted)}.student-detail__balance--negative .student-detail__balance-lessons{color:var(--balance-negative)}.student-detail__balance--zero .student-detail__balance-lessons{color:var(--balance-zero)}.student-detail__balance--positive .student-detail__balance-lessons{color:var(--balance-positive)}.student-detail__price{font-size:var(--font-size-md);color:var(--color-text-muted)}.student-detail__actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm);margin-bottom:var(--space-lg)}.student-detail__action{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);min-height:var(--touch-target);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);text-decoration:none;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.student-detail__action:hover{border-color:var(--color-primary);background-color:var(--color-surface-elevated)}.student-detail__section{margin-bottom:var(--space-lg)}.student-detail__section-title{display:flex;align-items:baseline;gap:var(--space-xs);font-size:var(--font-size-md);font-weight:600;color:var(--color-text);margin:0 0 var(--space-md)}.student-detail__section-count{font-size:var(--font-size-sm);font-weight:400;color:var(--color-text-muted)}.student-detail__list{display:flex;flex-direction:column;gap:var(--space-xs)}.student-detail__empty{color:var(--color-text-muted);font-size:var(--font-size-sm)}.student-detail__error{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--color-text-muted)}.student-detail__skeleton{display:flex;flex-direction:column;gap:var(--space-lg)}.student-detail__skeleton-header{height:40px;background:var(--color-surface);border-radius:var(--radius-md);animation:skeleton-pulse 1.5s ease-in-out infinite}.student-detail__skeleton-stats{height:80px;background:var(--color-surface);border-radius:var(--radius-lg);animation:skeleton-pulse 1.5s ease-in-out infinite}.student-detail__skeleton-section{height:120px;background:var(--color-surface);border-radius:var(--radius-lg);animation:skeleton-pulse 1.5s ease-in-out infinite}.lesson-item{padding:var(--space-sm) var(--space-md);background-color:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle)}.lesson-item--expandable{cursor:pointer;transition:border-color var(--transition-fast)}.lesson-item--expandable:hover{border-color:var(--color-border)}.lesson-item--expandable:focus{outline:2px solid var(--color-primary);outline-offset:2px}.lesson-item__header{display:flex;align-items:center;justify-content:space-between}.lesson-item__info{display:flex;align-items:center;gap:var(--space-md)}.lesson-item__date{font-size:var(--font-size-sm);color:var(--color-text)}.lesson-item__subject{font-size:var(--font-size-sm);color:var(--color-primary)}.lesson-item__chevron{color:var(--color-text-muted);transition:transform var(--transition-fast)}.lesson-item__chevron--expanded{transform:rotate(180deg)}.lesson-item__notes{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-xs);line-height:1.4}.lesson-item__notes--expanded{color:var(--color-text);white-space:pre-wrap}.payment-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background-color:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle)}.payment-item__info{display:flex;flex-direction:column;gap:2px}.payment-item__date{font-size:var(--font-size-sm);color:var(--color-text)}.payment-item__lessons{font-size:var(--font-size-sm);color:var(--balance-positive)}.payment-item__free{color:var(--color-text-muted)}.payment-item__amount{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.payment-item__euros{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.payment-item__type{font-size:var(--font-size-xs);color:var(--color-primary)}.edit-student-form{display:flex;flex-direction:column;gap:var(--space-md)}.edit-student-form__error{padding:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-error);background-color:#dd3c3c1a;border-radius:var(--radius-sm)}.checkbox-field{display:flex;align-items:center;gap:var(--space-sm);min-height:var(--touch-target);cursor:pointer;font-size:var(--font-size-md);color:var(--color-text)}.checkbox-field input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-primary);cursor:pointer}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.settings{flex:1;display:flex;flex-direction:column;padding:var(--space-md)}.settings__header{margin-bottom:var(--space-lg)}.settings__title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong);margin:0}.settings__content{display:flex;flex-direction:column;gap:var(--space-xl)}.settings__section{display:flex;flex-direction:column;gap:var(--space-md)}.settings__section-title{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0}.settings__nav{display:flex;flex-direction:column;gap:var(--space-xs)}.settings__nav-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);text-decoration:none;color:inherit;min-height:var(--touch-target);transition:border-color var(--transition-fast),background-color var(--transition-fast)}.settings__nav-item:hover{border-color:var(--color-primary);background-color:var(--color-surface-elevated)}.settings__nav-item:active{transform:scale(.99)}.settings__nav-icon{flex-shrink:0;width:24px;height:24px;color:var(--color-primary)}.settings__nav-icon svg{width:100%;height:100%}.settings__nav-content{flex:1;display:flex;flex-direction:column;gap:2px}.settings__nav-label{font-size:var(--font-size-md);font-weight:500;color:var(--color-text)}.settings__nav-hint{font-size:var(--font-size-sm);color:var(--color-text-muted)}.settings__nav-arrow{flex-shrink:0;width:20px;height:20px;color:var(--color-text-muted)}.settings__logout{padding-top:var(--space-md)}.subjects{flex:1;display:flex;flex-direction:column;padding:var(--space-md)}.subjects__header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.subjects__back{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);margin-left:calc(-1 * var(--space-sm));color:var(--color-text-muted);border-radius:var(--radius-full);transition:color var(--transition-fast),background-color var(--transition-fast)}.subjects__back:hover{color:var(--color-text);background-color:var(--color-surface)}.subjects__back svg{width:24px;height:24px}.subjects__title{flex:1;font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong);margin:0}.subjects__add-btn{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);color:var(--color-primary);background-color:transparent;border-radius:var(--radius-full);transition:background-color var(--transition-fast)}.subjects__add-btn:hover{background-color:var(--color-surface)}.subjects__add-btn svg{width:24px;height:24px}.subjects__list{display:flex;flex-direction:column;gap:var(--space-xs)}.subjects__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);color:var(--color-text-muted)}.subjects__hint{margin-top:var(--space-lg);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted)}.subjects__skeleton{display:flex;flex-direction:column;gap:var(--space-xs)}.subjects__skeleton-item{height:56px;background:var(--color-surface);border-radius:var(--radius-lg);animation:skeleton-pulse 1.5s ease-in-out infinite}.subjects__form{display:flex;flex-direction:column;gap:var(--space-lg)}.subjects__form-actions{display:flex;justify-content:flex-end;gap:var(--space-sm)}.subject-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);min-height:var(--touch-target);cursor:grab;transition:border-color var(--transition-fast),background-color var(--transition-fast),opacity var(--transition-fast),transform var(--transition-fast)}.subject-item:active{cursor:grabbing}.subject-item:hover{border-color:var(--color-border)}.subject-item__drag-handle{flex-shrink:0;width:20px;height:20px;color:var(--color-text-muted)}.subject-item__drag-handle svg{width:100%;height:100%}.subject-item__content{flex:1;display:flex;align-items:center;gap:var(--space-sm)}.subject-item__name{font-size:var(--font-size-md);font-weight:500;color:var(--color-text)}.subject-item__badge{font-size:var(--font-size-xs);padding:2px 8px;background-color:var(--color-surface-elevated);color:var(--color-text-muted);border-radius:var(--radius-full)}.subject-item__actions{display:flex;gap:var(--space-xs)}.subject-item__action{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--color-text-muted);border-radius:var(--radius-md);transition:color var(--transition-fast),background-color var(--transition-fast)}.subject-item__action:hover{color:var(--color-text);background-color:var(--color-surface-elevated)}.subject-item__action svg{width:18px;height:18px}.subject-item--inactive{opacity:.6}.subject-item--inactive .subject-item__name{color:var(--color-text-muted)}.subject-item--dragging{opacity:.5;transform:scale(.98)}.subject-item--drop-target{border-color:var(--color-primary);background-color:var(--color-surface-elevated)}.inactive-students{flex:1;display:flex;flex-direction:column;padding:var(--space-md)}.inactive-students__header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.inactive-students__back{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);margin-left:calc(-1 * var(--space-sm));color:var(--color-text-muted);border-radius:var(--radius-full);transition:color var(--transition-fast),background-color var(--transition-fast)}.inactive-students__back:hover{color:var(--color-text);background-color:var(--color-surface)}.inactive-students__back svg{width:24px;height:24px}.inactive-students__title{flex:1;font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong);margin:0}.inactive-students__list{display:flex;flex-direction:column;gap:var(--space-sm)}.inactive-students__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);color:var(--color-text-muted)}.inactive-students__hint{margin-top:var(--space-lg);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted)}.inactive-students__skeleton{display:flex;flex-direction:column;gap:var(--space-sm)}.inactive-students__skeleton-card{height:72px;background:var(--color-surface);border-radius:var(--radius-lg);animation:skeleton-pulse 1.5s ease-in-out infinite}.inactive-students__confirm{margin-bottom:var(--space-lg)}.inactive-students__confirm p{margin:0;color:var(--color-text)}.inactive-students__confirm-hint{margin-top:var(--space-sm)!important;font-size:var(--font-size-sm);color:var(--color-text-muted)!important}.inactive-students__confirm-actions{display:flex;justify-content:flex-end;gap:var(--space-sm)}.inactive-student-card{display:flex;align-items:center;background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);transition:border-color var(--transition-fast)}.inactive-student-card:hover{border-color:var(--color-border)}.inactive-student-card__content{flex:1;display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);text-decoration:none;color:inherit;min-height:var(--touch-target)}.inactive-student-card__name{font-size:var(--font-size-md);font-weight:500;color:var(--color-text-muted)}.inactive-student-card__balance{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.inactive-student-card__lessons{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-muted)}.inactive-student-card__euros{font-size:var(--font-size-xs);color:var(--color-text-muted)}.inactive-student-card__reactivate{display:flex;align-items:center;justify-content:center;width:var(--touch-target);height:var(--touch-target);margin-right:var(--space-sm);color:var(--color-text-muted);border-radius:var(--radius-md);transition:color var(--transition-fast),background-color var(--transition-fast)}.inactive-student-card__reactivate:hover{color:var(--color-success);background-color:var(--color-surface-elevated)}.inactive-student-card__reactivate svg{width:20px;height:20px}
