@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800;0,9..40,900;1,9..40,400&family=JetBrains+Mono:wght@400;500;600&display=swap";.sidebar{position:fixed;top:0;left:0;height:100vh;background-color:var(--color-bg-base);border-right:1px solid var(--color-border-subtle);display:flex;flex-direction:column;transition:width var(--transition-normal);z-index:100}.sidebar.open{width:260px}.sidebar.closed{width:60px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid transparent;border-image:linear-gradient(90deg,#482c7766,#8d475e66 55%,#e26d2a66) 1;min-height:60px}.sidebar-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}.logo-mark{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);transition:all var(--transition-normal);flex-shrink:0}.logo-mark:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:var(--radius-md);background:radial-gradient(circle,rgba(230,126,34,.08) 0%,transparent 70%);transition:all var(--transition-normal);pointer-events:none}.sidebar-logo:hover .logo-mark:before{top:-8px;right:-8px;bottom:-8px;left:-8px;background:radial-gradient(circle,rgba(230,126,34,.15) 0%,rgba(141,71,94,.06) 50%,transparent 80%)}img.logo-icon{width:32px;height:32px;object-fit:contain;filter:drop-shadow(0 0 6px rgba(230,126,34,.12));transition:filter var(--transition-normal)}.sidebar-logo:hover img.logo-icon{filter:drop-shadow(0 0 10px rgba(230,126,34,.25))}.logo-text{font-weight:600;font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap;letter-spacing:.01em}.logo-tdm{color:var(--color-accent-orange);font-weight:700}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:all var(--transition-fast)}.sidebar-toggle:hover{background-color:var(--color-bg-surface);color:var(--color-text-primary)}.sidebar-toggle svg{width:18px;height:18px}.sidebar.closed .sidebar-header{justify-content:center;gap:0}.sidebar.closed .sidebar-logo{justify-content:center}.sidebar.closed .sidebar-toggle{width:32px;height:32px}.sidebar-nav{flex:1;padding:var(--spacing-md) var(--spacing-sm);display:flex;flex-direction:column;gap:2px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-bg-surface) transparent}.sidebar-group{display:flex;flex-direction:column;gap:2px}.sidebar-group-divider{height:1px;margin:var(--spacing-sm) var(--spacing-md);background:var(--color-border-subtle)}.sidebar-group-label{font-family:var(--font-family-mono);font-size:9px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-secondary);padding:4px var(--spacing-md) 2px}.sidebar-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:4px var(--spacing-md) 2px;background:none;border:none;cursor:pointer;transition:opacity var(--transition-fast)}.sidebar-group-toggle:hover{opacity:.8}.sidebar-group-toggle .sidebar-group-label{padding:0}.sidebar-group-chevron{color:var(--color-text-secondary);transition:transform var(--transition-normal);flex-shrink:0}.sidebar-group-chevron.open{transform:rotate(90deg)}.sidebar-group-items{display:flex;flex-direction:column;gap:2px;overflow:hidden;transition:max-height var(--transition-normal),opacity var(--transition-normal)}.sidebar-group-items.visible{max-height:500px;opacity:1}.sidebar-group-items.collapsed{max-height:0;opacity:0;pointer-events:none}.sidebar.closed .sidebar-group-label{display:none}.sidebar.closed .sidebar-group-divider{margin:var(--spacing-xs) var(--spacing-sm)}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-md);padding:10px var(--spacing-md);min-height:44px;border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);text-decoration:none}.sidebar-link:hover{background-color:var(--color-bg-surface);color:var(--color-text-primary)}.sidebar-link.active{background-color:var(--color-bg-surface);border-left:3px solid var(--color-accent-orange);color:var(--color-text-primary)}.sidebar-link.active .sidebar-icon{color:var(--color-accent-orange)}.sidebar-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0}.sidebar-icon svg{width:20px;height:20px}.sidebar-label{white-space:nowrap;font-size:var(--font-size-sm);letter-spacing:.02em}.sidebar.closed .sidebar-link{justify-content:center;padding:var(--spacing-sm)}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid transparent;border-image:linear-gradient(90deg,#482c7766,#8d475e66 55%,#e26d2a66) 1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.sidebar-insta-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-sm);border-radius:var(--radius-sm);text-decoration:none;transition:all var(--transition-fast)}.sidebar-insta-btn:hover{background-color:#e1306c1a}.sidebar-insta-logo{width:28px;height:28px;flex-shrink:0;border-radius:6px}.sidebar-insta-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.sidebar.closed .sidebar-insta-btn{justify-content:center}.sidebar-footer-link{display:flex;align-items:center;gap:var(--spacing-md);padding:10px var(--spacing-sm);min-height:44px;border-radius:var(--radius-sm);color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast)}.sidebar-footer-link:hover{background-color:var(--color-bg-surface);color:var(--color-text-primary)}.sidebar-footer-link.active{background-color:var(--color-bg-surface);border-left:3px solid var(--color-accent-orange);color:var(--color-text-primary)}.sidebar-footer-link.active .sidebar-icon{color:var(--color-accent-orange)}.sidebar.closed .sidebar-footer-link{justify-content:center}.tenant-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.tenant-name{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.tenant-role{font-family:var(--font-family-mono);font-size:9px;color:var(--color-accent-orange);font-weight:700;letter-spacing:.15em;text-transform:uppercase}.sidebar-backdrop{display:none}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:280px;z-index:200;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0);width:280px}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0a081499;z-index:199;animation:fadeIn var(--transition-fast) ease-out}.sidebar-toggle{display:none}.sidebar-nav{padding:var(--spacing-md)}.sidebar-link{padding:12px var(--spacing-md);font-size:var(--font-size-md)}.sidebar-footer-link{padding:12px var(--spacing-md)}}@media (max-width: 389px){.sidebar,.sidebar.open{width:260px}.sidebar-link{padding:10px var(--spacing-sm);font-size:var(--font-size-sm)}.sidebar-footer-link{padding:10px var(--spacing-sm)}}.header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-bg-base);border-bottom:1px solid var(--color-border-subtle);border-top:3px solid;border-image:var(--brand-gradient-h) 1;min-height:60px}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-title{display:flex;align-items:baseline;gap:6px;margin:0}.header-title-tdm{font-size:var(--font-size-lg);font-weight:800;color:var(--color-accent-orange);letter-spacing:.02em}.header-title-app{font-size:var(--font-size-lg);font-weight:500;color:var(--color-text-secondary);letter-spacing:.01em}.header-right{display:flex;align-items:center;gap:var(--spacing-lg)}.header-clock{display:flex;flex-direction:column;align-items:flex-end;font-family:var(--font-family-mono)}.clock-time{font-size:var(--font-size-lg);font-weight:600;color:var(--color-accent-orange)}.clock-date{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.header-user{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.user-role{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:capitalize}.header-logout{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.header-hamburger{display:none;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);flex-shrink:0}.header-hamburger:hover{background-color:var(--color-bg-surface);color:var(--color-accent-orange)}.header-hamburger svg{width:22px;height:22px}@media (max-width: 768px){.header{padding:var(--spacing-sm) var(--spacing-md)}.header-hamburger{display:flex}.header-title-tdm,.header-title-app{font-size:var(--font-size-md)}.header-clock,.header-user{display:none}.header-right{gap:var(--spacing-sm)}.header-logout{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);min-width:auto}}.layout{display:flex;min-height:100vh}.layout-main{flex:1;display:flex;flex-direction:column;min-width:0;transition:margin-left var(--transition-normal)}.layout.sidebar-open .layout-main{margin-left:260px}.layout.sidebar-closed .layout-main{margin-left:60px}.layout-content{flex:1;padding:var(--spacing-lg);overflow-y:auto;background-color:var(--color-bg-base)}@media (max-width: 768px){.layout.sidebar-open .layout-main,.layout.sidebar-closed .layout-main{margin-left:0}.layout-content{padding:var(--spacing-md)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-void);padding:var(--spacing-lg);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(232,120,48,.06) 0%,rgba(141,71,94,.04) 35%,rgba(72,44,119,.03) 60%,transparent 80%);pointer-events:none;animation:ambient-breathe 6s ease-in-out infinite}@keyframes ambient-breathe{0%,to{opacity:.7;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}.login-loading{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);color:var(--color-text-muted);position:relative;z-index:1}.login-container{width:100%;max-width:420px;background-color:var(--color-bg-base);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);overflow:hidden;animation:card-arrive .5s ease-out;position:relative;z-index:1}@keyframes card-arrive{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-container:before{content:"";display:block;height:3px;background:var(--brand-gradient-h)}.login-brand{padding:40px var(--spacing-xl) 24px;display:flex;flex-direction:column;align-items:center;position:relative}.login-logo{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.login-logo img{width:120px;height:120px;object-fit:contain;position:relative;z-index:1;filter:drop-shadow(0 0 20px rgba(230,126,34,.15))}.login-logo:before{content:"";position:absolute;top:-28px;right:-28px;bottom:-28px;left:-28px;border-radius:50%;background:radial-gradient(circle,rgba(230,126,34,.12) 0%,rgba(230,126,34,.05) 45%,rgba(141,71,94,.03) 70%,transparent 100%);animation:logo-pulse 3s ease-in-out infinite}@keyframes logo-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}.login-brand-title{font-size:1.75rem;font-weight:700;letter-spacing:-.01em;margin-bottom:6px;text-align:center}.login-brand-title .brand-tdm{color:var(--color-accent-orange)}.login-brand-title .brand-app{color:var(--color-text-primary)}.login-brand-sub{font-family:var(--font-family-mono);font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-muted)}.login-divider{height:1px;margin:0 var(--spacing-xl);border:none;background:linear-gradient(90deg,transparent 0%,rgba(72,44,119,.3) 20%,rgba(141,71,94,.3) 50%,rgba(232,120,48,.3) 80%,transparent 100%)}.login-form-zone{padding:24px var(--spacing-xl) var(--spacing-xl)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.login-form .form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.login-form label{font-family:var(--font-family-mono);font-size:9px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.15em}.login-form input{padding:var(--spacing-md);font-size:var(--font-size-md)}.login-error{padding:var(--spacing-md);background-color:#c83a3a1f;border:1px solid rgba(213,69,69,.4);border-radius:var(--radius-sm);color:var(--color-accent-red);font-size:var(--font-size-sm)}.login-submit{margin-top:var(--spacing-sm);padding:var(--spacing-md);font-size:var(--font-size-md);font-weight:600}.login-submit .spinner{width:16px;height:16px;margin-right:var(--spacing-sm)}@media (max-width: 480px){.login-page{padding:var(--spacing-md);align-items:flex-start;padding-top:12vh}.login-page:before{width:400px;height:400px;top:25%}.login-brand{padding:28px var(--spacing-lg) 20px}.login-logo img{width:88px;height:88px}.login-logo:before{top:-20px;right:-20px;bottom:-20px;left:-20px}.login-brand-title{font-size:1.35rem}.login-divider{margin:0 var(--spacing-lg)}.login-form-zone{padding:20px var(--spacing-lg) var(--spacing-lg)}.login-form input{font-size:var(--font-size-sm)}}@media (max-width: 389px){.login-card{margin:var(--spacing-sm);max-width:100%}.login-form-zone{padding:var(--spacing-md)}.login-brand-title{font-size:1.2rem}.login-logo{width:100px;height:100px}}:root{--brand-purple: #482c77;--brand-purple-light: #6040a8;--brand-mauve: #8d475e;--brand-orange: #e87830;--brand-orange-light: #f08838;--brand-orange-warm: #d06838;--brand-gradient: linear-gradient(180deg, #482c77 0%, #8d475e 55%, #e87830 100%);--brand-gradient-h: linear-gradient(90deg, #482c77 0%, #8d475e 55%, #e87830 100%);--color-bg-void: #16132a;--color-bg-base: #1e1a35;--color-bg-primary: #272244;--color-bg-secondary: #302a52;--color-bg-surface: #3a3462;--color-bg-elevated: #443e72;--color-bg-hover: #504980;--color-accent-orange: #e87830;--color-accent-blue: #5a8fc8;--color-accent-green: #38b350;--color-accent-red: #d54545;--color-accent-purple: #8a5cba;--color-text-primary: #F5F3F0;--color-text-secondary: #C4BAD2;--color-text-muted: #9890A8;--color-text-disabled: #6E6688;--color-text-on-brand: #16132a;--color-border: #483f6c;--color-border-subtle: #3b345c;--color-border-strong: #5c5388;--color-border-accent: rgba(232, 120, 48, .35);--shadow-sm: 0 1px 4px rgba(10, 8, 20, .4);--shadow-md: 0 4px 12px rgba(10, 8, 20, .5);--shadow-lg: 0 12px 28px rgba(10, 8, 20, .6);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-full: 9999px;--transition-fast: .12s ease;--transition-normal: .22s ease;--font-family: "DM Sans", system-ui, sans-serif;--font-family-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--event-dm: #5a8fc8;--event-youngster: #38b350;--event-emx: #e87830;--event-training: #8a5cba;--event-wartung: #d54545;--event-sonstige: #9890A8}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-base);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-accent-orange);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--brand-orange-light)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-primary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:var(--color-bg-elevated);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-bg-hover)}*{scrollbar-width:thin;scrollbar-color:var(--color-bg-surface) var(--color-bg-primary)}::selection{background:#e26d2a4d;color:var(--color-text-primary)}:focus-visible{outline:2px solid var(--brand-orange);outline-offset:2px;border-radius:var(--radius-sm)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:10px var(--spacing-md);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-sm);transition:all var(--transition-fast);min-height:44px;min-width:44px}.btn-primary{background-color:var(--color-accent-orange);color:var(--color-text-on-brand)}.btn-primary:hover:not(:disabled){background-color:var(--brand-orange-light)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:#482c7714;border-color:var(--color-border-strong)}.btn-danger{background-color:var(--color-accent-red);color:var(--color-text-primary)}.btn-danger:hover:not(:disabled){background-color:#b53232}.btn-ghost{background:transparent;color:var(--color-text-muted)}.btn-ghost:hover:not(:disabled){background-color:var(--color-bg-surface);color:var(--color-text-secondary)}.btn-primary:active:not(:disabled){transform:scale(.97);background-color:var(--brand-orange-warm)}.btn-secondary:active:not(:disabled){transform:scale(.97)}.btn-danger:active:not(:disabled){transform:scale(.97);background-color:#b83838}.btn-ghost:active:not(:disabled){transform:scale(.97)}.btn-loading{position:relative;color:transparent!important;pointer-events:none}.btn-loading:after{content:"";position:absolute;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}input,textarea,select{font-family:inherit;font-size:inherit;padding:10px var(--spacing-md);background-color:#0a081459;border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);color:var(--color-text-primary);transition:all var(--transition-fast);min-height:44px}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--brand-orange);box-shadow:0 0 0 3px #e878302e}input::placeholder,textarea::placeholder{color:var(--color-text-disabled)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-family:var(--font-family-mono);font-size:9px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.15em}.form-group label.form-required:after{content:" *";color:var(--color-accent-red)}.form-error{font-size:var(--font-size-xs);color:var(--color-accent-red);margin:0}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-sm)}.card{background-color:var(--color-bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-lg);border:1px solid var(--color-border-subtle);transition:background-color var(--transition-fast)}.card:hover{background-color:var(--color-bg-hover)}.card-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid transparent;border-image:linear-gradient(90deg,#482c774d,#8d475e4d 55%,#e26d2a4d) 1}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-accent-green)}.text-error{color:var(--color-accent-red)}.text-warning{color:var(--color-accent-orange)}.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}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:fadeIn var(--transition-normal) ease-out}.animate-slideIn{animation:slideIn var(--transition-normal) ease-out}.spinner{width:20px;height:20px;border:2px solid var(--color-bg-surface);border-top-color:var(--brand-orange);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:var(--color-bg-void)}.loading-screen .spinner{width:40px;height:40px;border-width:3px}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B6178' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-sm) center;padding-right:var(--spacing-xl);cursor:pointer}select:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23e26d2a' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}select option{background-color:var(--color-bg-secondary);color:var(--color-text-primary);padding:var(--spacing-sm)}input[type=checkbox],input[type=radio]{width:22px;height:22px;min-height:auto;accent-color:var(--brand-orange);cursor:pointer}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:var(--color-bg-surface);border-radius:var(--radius-sm);border:none;padding:0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--brand-orange);border-radius:50%;cursor:pointer;transition:background var(--transition-fast)}input[type=range]::-webkit-slider-thumb:hover{background:var(--brand-orange-light)}input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--brand-orange);border-radius:50%;cursor:pointer;border:none}.badge{display:inline-flex;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;border-radius:99px;letter-spacing:.03em}.badge-primary{background-color:#e26d2a26;color:var(--brand-orange)}.badge-success{background-color:#2ea04326;color:var(--color-accent-green)}.badge-warning{background-color:#cf643526;color:var(--brand-orange-light)}.badge-danger{background-color:#c83a3a26;color:var(--color-accent-red)}.badge-secondary{background-color:#2a244499;color:var(--color-text-secondary)}.badge-training{background-color:#7c4dac26;color:var(--color-accent-purple)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0a0814bf;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast) ease-out}.modal{background-color:var(--color-bg-base);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:slideIn var(--transition-normal) ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid transparent;border-image:linear-gradient(90deg,#482c774d,#8d475e4d 55%,#e26d2a4d) 1}.modal-header h3{margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:var(--spacing-xs);color:var(--color-text-muted);border-radius:var(--radius-sm);font-size:var(--font-size-lg)}.modal-close:hover{color:var(--color-text-primary);background-color:var(--color-bg-surface)}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid transparent;border-image:linear-gradient(90deg,#482c774d,#8d475e4d 55%,#e26d2a4d) 1}.toast-container{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);z-index:1100;display:flex;flex-direction:column;gap:var(--spacing-sm)}.toast{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--color-bg-base);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);animation:slideIn var(--transition-normal) ease-out;min-width:280px;max-width:400px}.toast-success{border-left:3px solid var(--color-accent-green)}.toast-error{border-left:3px solid var(--color-accent-red)}.toast-warning{border-left:3px solid var(--brand-orange)}.toast-info{border-left:3px solid var(--color-accent-blue)}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-void);color:var(--color-text-primary);font-size:var(--font-size-xs);border-radius:var(--radius-sm);border:1px solid var(--color-border-subtle);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);pointer-events:none;z-index:100;margin-bottom:var(--spacing-xs)}[data-tooltip]:hover:after{opacity:1;visibility:visible}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}.table th{background-color:var(--color-bg-primary);font-family:var(--font-family-mono);font-weight:700;color:var(--color-text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.1em}.table tr:hover td{background-color:#e26d2a08}.divider{height:1px;background:linear-gradient(90deg,#482c774d,#8d475e4d 55%,#e26d2a4d);margin:var(--spacing-lg) 0}.skeleton{background:linear-gradient(90deg,var(--color-bg-surface) 25%,var(--color-bg-secondary) 50%,var(--color-bg-surface) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state-global{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-lg);text-align:center;color:var(--color-text-muted)}.empty-state-global svg{width:64px;height:64px;margin-bottom:var(--spacing-md);opacity:.4;color:var(--color-text-disabled)}.empty-state-global h4{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-secondary);margin:0 0 var(--spacing-xs) 0}.empty-state-global p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--spacing-lg) 0;max-width:320px}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-lg);text-align:center}.error-state svg{width:48px;height:48px;color:var(--color-accent-red);opacity:.6;margin-bottom:var(--spacing-md)}.error-state h4{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.error-state p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--spacing-lg) 0;max-width:360px}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0a0814bf;display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn var(--transition-fast) ease-out}.confirm-dialog{background-color:var(--color-bg-base);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-lg);max-width:380px;width:90%;animation:slideIn var(--transition-normal) ease-out}.confirm-dialog h4{font-family:var(--font-family-mono);font-size:11px;font-weight:700;color:var(--color-accent-red);text-transform:uppercase;letter-spacing:.15em;margin:0 0 var(--spacing-md) 0}.confirm-dialog p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--spacing-lg) 0;line-height:1.5}.confirm-dialog .confirm-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.skeleton-line{height:14px;margin-bottom:var(--spacing-sm);border-radius:var(--radius-sm)}.skeleton-line.short{width:40%}.skeleton-line.medium{width:65%}.skeleton-line.full{width:100%}.skeleton-card{height:80px;border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.skeleton-circle{width:40px;height:40px;border-radius:50%;flex-shrink:0}.skeleton-grid{display:grid;gap:var(--spacing-md);padding:var(--spacing-lg)}.skeleton-grid.cols-4{grid-template-columns:repeat(4,1fr)}.skeleton-grid.cols-3{grid-template-columns:repeat(3,1fr)}.skeleton-grid.cols-2{grid-template-columns:repeat(2,1fr)}.skeleton-h-24{height:24px}.skeleton-h-14{height:14px}.skeleton-h-30{height:30px}.skeleton-h-56{height:56px}.skeleton-h-72{height:72px}.skeleton-h-100{height:100px}.skeleton-h-120{height:120px}.skeleton-h-200{height:200px}.skeleton-h-320{height:320px}.skeleton-mt-8{margin-top:var(--spacing-sm)}.skeleton-mb-16{margin-bottom:var(--spacing-md)}.skeleton-w-70{width:70px}.skeleton-w-80{width:80px}.skeleton-filter-row{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.page-loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl) 0;min-height:200px}.btn-add{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);border:1px solid var(--color-accent-orange);border-radius:var(--radius-sm);background-color:#e8783026;color:var(--color-accent-orange);font-family:var(--font-family-mono);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0;min-height:44px}.btn-add:hover{background-color:var(--color-accent-orange);color:#fff}.filter-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.filter-btn{padding:var(--spacing-xs) var(--spacing-md);border:1px dashed var(--color-border);border-radius:var(--radius-sm);background:none;color:var(--color-text-secondary);font-family:var(--font-family-mono);font-size:10px;font-weight:600;letter-spacing:.08em;cursor:pointer;transition:all var(--transition-fast)}.filter-btn:hover{border-color:var(--color-accent-orange);border-style:solid;color:var(--color-accent-orange)}.filter-btn.active{background-color:#e8783026;border:1px solid var(--color-accent-orange);color:var(--color-accent-orange)}.summary-grid{display:grid;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.summary-grid.cols-3{grid-template-columns:repeat(3,1fr)}.summary-grid.cols-4{grid-template-columns:repeat(4,1fr)}.summary-grid.cols-6{grid-template-columns:repeat(6,1fr)}.summary-card{text-align:center;padding:var(--spacing-lg)}.summary-value{display:block;font-family:var(--font-family-mono);font-size:var(--font-size-2xl);font-weight:700;color:var(--color-accent-blue);margin-bottom:var(--spacing-xs)}.summary-value.warn{color:var(--color-accent-orange)}.summary-value.ok{color:var(--color-accent-green)}.summary-label{font-family:var(--font-family-mono);font-size:9px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.15em}@media (max-width: 768px){:root{--spacing-lg: 16px;--spacing-xl: 24px}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}.hide-mobile{display:none!important}.summary-grid.cols-4{grid-template-columns:repeat(2,1fr)}.summary-grid.cols-6{grid-template-columns:repeat(3,1fr)}.summary-grid.cols-3{grid-template-columns:1fr}.filter-bar{gap:var(--spacing-xs)}.filter-btn{font-size:9px;padding:var(--spacing-xs) var(--spacing-sm)}.btn-add{align-self:flex-start}.skeleton-grid.cols-4{grid-template-columns:repeat(2,1fr)}.modal{max-width:100%;width:100%;margin:var(--spacing-sm);max-height:95vh;border-radius:var(--radius-md)}.modal-overlay{align-items:flex-end;padding:0}.toast-container{left:var(--spacing-sm);right:var(--spacing-sm);bottom:var(--spacing-md)}.toast{min-width:auto;max-width:100%}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 calc(var(--spacing-md) * -1);padding:0 var(--spacing-md)}.page-header{flex-direction:column;gap:var(--spacing-sm)}.page-header-row{flex-direction:column;gap:var(--spacing-sm);align-items:stretch}}@media (max-width: 480px){:root{--spacing-lg: 12px;--spacing-xl: 20px}h1{font-size:var(--font-size-xl)}h2{font-size:var(--font-size-lg)}.btn{font-size:var(--font-size-xs);padding:8px var(--spacing-sm)}.card{padding:var(--spacing-md)}.summary-grid.cols-4,.summary-grid.cols-6{grid-template-columns:1fr;gap:var(--spacing-sm)}.summary-card{padding:var(--spacing-md)}.summary-value{font-size:var(--font-size-xl)}.skeleton-grid.cols-4,.skeleton-grid.cols-3{grid-template-columns:1fr}}@media (max-width: 389px){:root{--color-text-muted: #b0a8c4;--color-text-disabled: #8a80a4;--color-border-subtle: #4a4270;--color-border: #554c7e}.card{padding:var(--spacing-sm)}.modal-body,.modal-header,.modal-footer{padding:var(--spacing-sm) var(--spacing-md)}.modal{margin:4px;border-radius:var(--radius-sm)}.btn{font-size:11px;padding:8px 12px}.filter-btn{font-size:10px;padding:var(--spacing-xs) 10px;min-height:44px}.form-group label{font-size:10px}.summary-grid.cols-4,.summary-grid.cols-6,.summary-grid.cols-3{grid-template-columns:1fr;gap:var(--spacing-xs)}.toast{min-width:unset}.empty-state-global svg{opacity:.6}.btn:disabled{opacity:.5}.page-header{gap:var(--spacing-xs)}h1{font-size:1.1rem}h2{font-size:1rem}h3{font-size:.9rem}}@media (min-width: 769px){.hide-desktop{display:none!important}}
