@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-black: #000000;--color-dark-blue: #2F4550;--color-medium-blue: #586F7C;--color-light-blue: #B8DBD9;--color-off-white: #F4F4F9;--color-success: #16A34A;--color-success-dark: #128A38;--color-warning: #F59E0B;--color-error: #DC2626;--color-error-dark: #B91C1C;--color-info: #2563EB;--color-info-dark: #1D4ED8;--bg-primary: #FFFFFF;--bg-secondary: var(--color-off-white);--bg-tertiary: var(--color-light-blue);--text-primary: var(--color-black);--text-secondary: var(--color-dark-blue);--text-tertiary: var(--color-medium-blue);--text-inverse: #FFFFFF;--border-color: var(--color-medium-blue);--border-color-light: var(--color-light-blue);--font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-size-h1: clamp(28px, 5vw, 40px);--font-size-h2: clamp(22px, 4vw, 32px);--font-size-h3: clamp(18px, 3vw, 24px);--font-size-body: clamp(16px, 2vw, 18px);--font-size-small: clamp(14px, 1.5vw, 16px);--font-size-tiny: 12px;--line-height-heading: 1.2;--line-height-tight: 1.4;--line-height-text: 1.6;--line-height-loose: 1.8;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-2xs: 4px;--spacing-xs: 8px;--spacing-sm: 16px;--spacing-md: 24px;--spacing-lg: 32px;--spacing-xl: 48px;--spacing-2xl: 64px;--container-max-width: 1400px;--container-padding-mobile: var(--spacing-sm);--container-padding-tablet: var(--spacing-md);--container-padding-desktop: var(--spacing-lg);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 50%;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 4px 8px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .16);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .2);--min-touch-target: 44px;--recommended-touch-target: 48px;--touch-spacing: 8px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 1000;--z-modal: 1001;--z-tooltip: 1100;--breakpoint-sm: 480px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1440px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-body);line-height:var(--line-height-text);color:var(--text-primary);background:var(--bg-primary);overflow-x:hidden;min-height:100vh}:focus-visible{outline:3px solid var(--color-info);outline-offset:3px;border-radius:var(--radius-sm)}:focus:not(:focus-visible){outline:none}a{color:var(--color-info);text-decoration:underline;text-underline-offset:3px;transition:color var(--transition-base)}a:hover{color:var(--color-info-dark)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-heading);color:var(--text-primary);margin-bottom:var(--spacing-sm)}h1{font-size:var(--font-size-h1)}h2{font-size:var(--font-size-h2)}h3{font-size:var(--font-size-h3)}img{max-width:100%;height:auto;display:block}button{font-family:inherit;font-size:inherit;line-height:inherit;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent}input,textarea,select{font-family:inherit;font-size:16px}ul,ol{list-style:none}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-black);color:#fff;padding:12px 16px;z-index:var(--z-tooltip);text-decoration:none;font-weight:var(--font-weight-semibold)}.skip-link:focus{top:0}.btn{min-height:var(--recommended-touch-target);padding:14px 32px;font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);border-radius:var(--radius-lg);border:3px solid;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:all var(--transition-base)}.btn-primary{background:var(--color-success);color:#fff;border-color:var(--color-success)}@media(hover:hover)and (pointer:fine){.btn-primary:hover{background:var(--color-success-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}}.btn-primary:active{transform:scale(.97);box-shadow:var(--shadow-sm)}.btn-primary:focus-visible{outline:3px solid var(--color-info);outline-offset:3px}.btn-secondary{background:var(--color-error);color:#fff;border-color:var(--color-error)}@media(hover:hover)and (pointer:fine){.btn-secondary:hover{background:var(--color-error-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}}.btn-secondary:active{transform:scale(.97);box-shadow:var(--shadow-sm)}.btn-tertiary{background:var(--color-light-blue);color:var(--color-dark-blue);border-color:var(--color-medium-blue)}@media(hover:hover)and (pointer:fine){.btn-tertiary:hover{background:var(--color-medium-blue);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}}.btn-tertiary:active{transform:scale(.97)}.btn-ghost{background:transparent;color:var(--color-dark-blue);border-color:var(--color-medium-blue);border-width:2px}@media(hover:hover)and (pointer:fine){.btn-ghost:hover{background:var(--color-off-white)}}.btn:disabled,.btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none;transform:none}.btn.loading{position:relative;color:transparent;pointer-events:none}.btn.loading:after{content:"";position:absolute;width:20px;height:20px;border:3px solid white;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-small{min-height:var(--min-touch-target);padding:10px 20px;font-size:var(--font-size-small)}.btn-large{min-height:56px;padding:18px 40px;font-size:18px}.btn-full{width:100%}@media(min-width:768px){.btn-full{width:auto}}.label{display:block;margin-bottom:var(--spacing-xs);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--text-secondary)}.label.required:after{content:" *";color:var(--color-error)}.input,.textarea,.select{min-height:var(--recommended-touch-target);width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);font-size:16px;font-family:var(--font-family);color:var(--text-primary);transition:all var(--transition-base)}.input:focus,.textarea:focus,.select:focus{border-color:var(--color-info);outline:0;box-shadow:0 0 0 3px #2563eb1a}.input.error,.textarea.error,.select.error{border-color:var(--color-error);background:#fef2f2}.input.error:focus,.textarea.error:focus,.select.error:focus{box-shadow:0 0 0 3px #dc26261a}.input:disabled,.textarea:disabled,.select:disabled{opacity:.5;background:var(--bg-secondary);cursor:not-allowed}.textarea{min-height:120px;resize:vertical;line-height:var(--line-height-text)}.select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23586F7C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:44px}.error-message{color:var(--color-error);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);margin-top:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-xs)}.error-message:before{content:"⚠";font-size:18px;flex-shrink:0}.helper-text{font-size:var(--font-size-small);color:var(--text-tertiary);margin-top:var(--spacing-xs)}.checkbox,.radio{position:relative;display:inline-flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;min-height:var(--min-touch-target);padding:var(--spacing-xs) 0}.checkbox input[type=checkbox],.radio input[type=radio]{width:24px;height:24px;border:2px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer}.radio input[type=radio]{border-radius:var(--radius-full)}.checkbox input[type=checkbox]:checked,.radio input[type=radio]:checked{background:var(--color-success);border-color:var(--color-success)}.checkbox input[type=checkbox]:focus-visible,.radio input[type=radio]:focus-visible{outline:3px solid var(--color-info);outline-offset:2px}.form-group{margin-bottom:var(--spacing-md)}.form-row{display:flex;flex-direction:column;gap:var(--spacing-md)}@media(min-width:768px){.form-row{flex-direction:row}.form-row .form-group{flex:1;margin-bottom:0}}.search-wrapper{position:relative}.search-input{padding-left:44px}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-tertiary);pointer-events:none}.mt-2xs{margin-top:var(--spacing-2xs)}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-2xs{margin-bottom:var(--spacing-2xs)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.p-2xs{padding:var(--spacing-2xs)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.block{display:block}.inline-block{display:inline-block}.hidden{display:none}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-stretch{align-items:stretch}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-regular{font-weight:var(--font-weight-regular)}.text-medium{font-weight:var(--font-weight-medium)}.text-semibold{font-weight:var(--font-weight-semibold)}.text-bold{font-weight:var(--font-weight-bold)}.text-small{font-size:var(--font-size-small)}.text-body{font-size:var(--font-size-body)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}.w-full{width:100%}.w-auto{width:auto}.w-fit{width:fit-content}@media(max-width:767px){.mobile-hidden{display:none!important}}.desktop-only{display:none}@media(min-width:768px){.desktop-only{display:block}.desktop-flex{display:flex}}@media(min-width:768px){.mobile-only{display:none!important}}.container{width:100%;max-width:var(--container-max-width);margin:0 auto;padding:var(--container-padding-mobile)}@media(min-width:768px){.container{padding:var(--container-padding-tablet)}}@media(min-width:1024px){.container{padding:var(--container-padding-desktop)}}.card{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}@media(hover:hover)and (pointer:fine){.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}}.divider{height:2px;background:var(--border-color-light);margin:var(--spacing-lg) 0;border:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}#root{min-height:100vh;display:flex;flex-direction:column}main{flex:1}.skip-to-content{position:absolute;top:-100px;left:0;background:var(--color-black);color:#fff;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;font-weight:var(--font-weight-semibold);z-index:var(--z-tooltip);border-radius:0 0 var(--radius-md) 0}.skip-to-content:focus{top:0}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s,transform .3s}.page-exit{opacity:1}.page-exit-active{opacity:0;transition:opacity .3s}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-light-blue);border-top-color:var(--color-info);border-radius:50%;animation:spin .8s linear infinite;margin:var(--spacing-xl) auto}.alert{padding:var(--spacing-md);border-left:6px solid;border-radius:var(--radius-md);display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.alert-success{background:#f0fdf4;border-color:var(--color-success);color:#166534}.alert-warning{background:#fffbeb;border-color:var(--color-warning);color:#92400e}.alert-error{background:#fef2f2;border-color:var(--color-error);color:#991b1b}.alert-info{background:#eff6ff;border-color:var(--color-info);color:#1e40af}.alert-icon{font-size:24px;flex-shrink:0}.alert-content{flex:1}.alert-title{font-weight:var(--font-weight-semibold);margin-bottom:4px}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:16px;font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}.badge-primary{background:var(--color-info);color:#fff}.badge-success{background:var(--color-success);color:#fff}.badge-warning{background:var(--color-warning);color:#fff}.badge-neutral{background:var(--color-light-blue);color:var(--color-dark-blue)}.no-results{padding:var(--spacing-xl);text-align:center;color:var(--text-tertiary);font-size:var(--font-size-body);background:var(--bg-secondary);border:2px solid var(--border-color-light);border-radius:var(--radius-lg);margin:var(--spacing-md) 0}.no-results-icon{font-size:48px;margin-bottom:var(--spacing-sm);opacity:.5}.no-results-title{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.no-results-text{color:var(--text-tertiary)}.skeleton{background:linear-gradient(90deg,var(--color-off-white) 0%,var(--color-light-blue) 50%,var(--color-off-white) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-text{height:16px;margin-bottom:var(--spacing-xs)}.skeleton-title{height:24px;width:60%;margin-bottom:var(--spacing-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media print{body{background:#fff}.no-print,button,.btn{display:none!important}*{box-shadow:none!important;text-shadow:none!important}}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.app-main{flex:1;padding-top:80px}.header{position:fixed;top:0;left:0;right:0;background:var(--bg-primary);border-bottom:2px solid var(--border-color-light);box-shadow:var(--shadow-sm);z-index:var(--z-fixed)}.header-content{max-width:var(--container-max-width);margin:0 auto;padding:var(--spacing-sm) var(--spacing-md);display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}@media(min-width:768px){.header-content{padding:var(--spacing-sm) var(--spacing-lg)}}.header-logo{display:flex;align-items:center;gap:var(--spacing-sm)}.header-logo img{width:40px;height:40px}.header-logo h1{font-size:clamp(20px,3vw,28px);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0;line-height:1}@media(max-width:767px){.header-logo h1{display:none}}.header-nav{display:flex;align-items:center;gap:var(--spacing-xs)}@media(min-width:768px){.header-nav{gap:var(--spacing-sm)}}.nav-link{min-height:var(--recommended-touch-target);padding:10px 16px;font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);text-decoration:none;color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:2px solid transparent;background:transparent;transition:all var(--transition-base);position:relative}@media(min-width:768px){.nav-link{padding:12px 20px;font-size:var(--font-size-body)}}@media(hover:hover)and (pointer:fine){.nav-link:hover{color:var(--color-info);background:#2563eb1a;border-color:#2563eb33;transform:translateY(-1px)}}.nav-link.active,.nav-link[aria-current=page]{color:#fff;font-weight:var(--font-weight-semibold);background:var(--color-info);border-color:var(--color-info);box-shadow:0 2px 8px #2563eb4d}.nav-link.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--color-info);border-radius:3px 3px 0 0;opacity:0}.nav-link:active{transform:scale(.97)}.nav-link:focus-visible{outline:3px solid var(--color-info);outline-offset:3px}@media(prefers-reduced-motion:reduce){.nav-link,.header-nav{transition:none}}.stundenplan-container{padding:var(--spacing-md);max-width:2400px;margin:0 auto;min-height:calc(100vh - 80px)}@media(max-width:767px){.stundenplan-container{padding-bottom:80px}}@media(min-width:768px){.stundenplan-container{padding:var(--spacing-lg)}}@media(min-width:1024px){.stundenplan-container{padding:var(--spacing-xl) var(--spacing-lg)}}.stundenplan-container h2{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--spacing-lg)}.day-nav{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}@media(max-width:767px){.day-nav{position:fixed;bottom:0;left:0;right:0;margin:0;border-radius:0;border-left:none;border-right:none;border-bottom:none;z-index:var(--z-fixed);box-shadow:0 -2px 8px #0000001a;padding:var(--spacing-sm) var(--spacing-md)}}.day-nav-button{min-height:var(--recommended-touch-target);min-width:120px;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-info);color:#fff;border:2px solid var(--color-info);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;flex-shrink:0}@media(max-width:479px){.day-nav-button{min-width:100px;padding:var(--spacing-sm);font-size:var(--font-size-small)}}.day-nav-button:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-secondary);color:var(--text-tertiary);border-color:var(--border-color)}@media(hover:hover){.day-nav-button:not(:disabled):hover{background:#1d4ed8;border-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}}.day-nav-button:active:not(:disabled){transform:scale(.98)}.day-nav-info{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-body);text-align:center;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-state{padding:var(--spacing-xl);text-align:center;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--radius-lg);margin:var(--spacing-lg) 0}.empty-state p{font-size:var(--font-size-h3);color:var(--text-secondary);margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-semibold)}.empty-hint{font-size:var(--font-size-body);color:var(--text-tertiary);margin-top:var(--spacing-sm);font-weight:var(--font-weight-regular)!important}.grid-header{display:grid;grid-template-columns:60px repeat(var(--visible-days, 7),1fr);gap:0;border:2px solid var(--border-color);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:var(--bg-tertiary);position:sticky;top:80px;z-index:100}@media(max-width:639px){.grid-header{grid-template-columns:60px 1fr}}@media(min-width:640px)and (max-width:1023px){.grid-header{grid-template-columns:60px repeat(3,1fr)}}@media(min-width:1024px)and (max-width:1439px){.grid-header{grid-template-columns:60px repeat(5,1fr)}}.time-column-header{border-right:2px solid var(--border-color);background:var(--color-medium-blue)}.day-header{text-align:center;padding:var(--spacing-sm);border-right:2px solid var(--border-color)}.day-header:last-child{border-right:none}.day-name{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-body);margin-bottom:4px}.day-number{font-size:var(--font-size-small);color:var(--text-secondary)}.today-number{background:var(--color-info);color:#fff;padding:4px 8px;border-radius:var(--radius-full);display:inline-block;font-weight:var(--font-weight-semibold)}.grid-container{display:grid;grid-template-columns:60px repeat(var(--visible-days, 7),1fr);gap:0;border:2px solid var(--border-color);border-radius:0 0 var(--radius-lg) var(--radius-lg);background:var(--bg-primary);position:relative;min-height:1200px}@media(max-width:639px){.grid-container{grid-template-columns:60px 1fr}}@media(min-width:640px)and (max-width:1023px){.grid-container{grid-template-columns:60px repeat(3,1fr)}}@media(min-width:1024px)and (max-width:1439px){.grid-container{grid-template-columns:60px repeat(5,1fr)}}.time-column{border-right:2px solid var(--border-color);background:var(--bg-secondary)}.time-label{height:80px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--text-secondary);border-bottom:1px solid var(--border-color-light)}.time-label:last-child{border-bottom:none}.day-column{position:relative;border-right:1px solid var(--border-color-light)}.day-column:last-child{border-right:none}.hour-cell{height:80px;border-bottom:1px solid var(--border-color-light)}.hour-cell:last-child{border-bottom:none}.event-card{position:absolute;background:#fff;border:2px solid;border-radius:var(--radius-md);padding:var(--spacing-sm);padding-left:12px;cursor:pointer;overflow:hidden;transition:all var(--transition-base);box-shadow:0 2px 4px #0000001a,0 1px 2px #0000000f;margin:4px}.event-card:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;z-index:10;border-width:3px;padding-left:11px}.event-card:focus-visible{outline:3px solid var(--color-info);outline-offset:2px;z-index:10}.event-time{font-size:11px;font-weight:var(--font-weight-semibold);margin-bottom:4px;opacity:.95;letter-spacing:.02em}.event-title{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);line-height:1.3;word-wrap:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;color:var(--text-primary)}@media(max-width:767px){.grid-header,.grid-container{font-size:var(--font-size-small)}.time-label{font-size:11px}.event-card{padding:4px}.event-time{font-size:10px}.event-title{font-size:11px}}@media(prefers-reduced-motion:reduce){.event-card:hover,.day-nav-button:hover{transform:none}}.modal-backdrop{position:fixed;inset:0;background:#2f4550cc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);animation:fadeIn .3s ease;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{position:relative;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;background:var(--bg-primary);border:3px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:var(--z-modal);animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border-radius:calc(var(--radius-xl) - 3px) calc(var(--radius-xl) - 3px) 0 0;border-bottom:2px solid var(--border-color-light);position:sticky;top:0;z-index:10}.modal-title{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0;line-height:var(--line-height-heading);flex:1;padding-right:var(--spacing-md)}.modal-close{width:var(--min-touch-target);height:var(--min-touch-target);min-width:var(--min-touch-target);min-height:var(--min-touch-target);border:2px solid var(--border-color);border-radius:var(--radius-full);background:var(--bg-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-secondary);transition:all var(--transition-base);flex-shrink:0}@media(hover:hover)and (pointer:fine){.modal-close:hover{background:var(--color-error);color:#fff;border-color:var(--color-error);transform:rotate(90deg)}}.modal-close:active{transform:scale(.9)}.modal-close:focus-visible{outline:3px solid var(--color-info);outline-offset:3px}.modal-body{padding:var(--spacing-lg)}@media(max-width:767px){.modal-body{padding:var(--spacing-md)}}.modal-section{margin-bottom:var(--spacing-lg)}.modal-section:last-child{margin-bottom:0}.modal-section h3{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--text-secondary);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:2px solid var(--border-color-light)}.modal-section p,.modal-section div{color:var(--text-primary);font-size:var(--font-size-body);line-height:var(--line-height-text);margin-bottom:var(--spacing-sm)}.modal-section strong{font-weight:var(--font-weight-semibold);color:var(--text-secondary)}.info-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}@media(min-width:480px){.info-grid{grid-template-columns:repeat(2,1fr)}}.info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-item-full{grid-column:1 / -1}.info-label{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--text-primary)}.degrees-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.modal-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:2px solid var(--border-color-light);background:var(--bg-secondary);border-radius:0 0 calc(var(--radius-xl) - 3px) calc(var(--radius-xl) - 3px);display:flex;gap:var(--spacing-sm);justify-content:flex-end;position:sticky;bottom:0}.modal-footer .btn-primary{min-width:140px;padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);background:var(--color-info);color:#fff;border:2px solid var(--color-info);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}@media(hover:hover){.modal-footer .btn-primary:hover{background:#1d4ed8;border-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}}.modal-footer .btn-primary:active{transform:scale(.98)}.modal-footer .btn-primary:focus-visible{outline:3px solid var(--color-info);outline-offset:3px}@media(max-width:767px){.modal-footer{flex-direction:column;padding:var(--spacing-md)}.modal-footer button{width:100%}}body.modal-open{overflow:hidden}@media(prefers-reduced-motion:reduce){.modal-backdrop,.modal{animation:none}.modal-close:hover{transform:none}}.module-item{display:flex;flex-direction:column;height:100%;border:3px solid var(--border-color);border-radius:var(--radius-xl);background:var(--bg-primary);box-shadow:var(--shadow-xl);transition:all var(--transition-base);overflow:hidden;position:relative}.module-item.selected{background:var(--bg-primary);border-color:var(--color-info);box-shadow:0 0 0 3px #3b82f633,var(--shadow-xl)}@media(hover:hover){.module-item:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:translateY(-1px)}.module-item.selected:hover{box-shadow:0 0 0 3px #3b82f64d,0 20px 25px -5px #0000001a}}.module-header{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border-bottom:2px solid var(--border-color-light);position:sticky;top:0;z-index:1}.module-title{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0;line-height:var(--line-height-heading)}.module-body{padding:var(--spacing-lg);flex:1;display:flex;flex-direction:column}@media(max-width:767px){.module-body{padding:var(--spacing-md)}}.module-item .info-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);flex:1}@media(min-width:480px){.module-item .info-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.modules-list-items .module-item .info-grid{grid-template-columns:repeat(2,1fr)}}.module-item .info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.module-item .info-item-full{grid-column:1 / -1}.module-item .info-label{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.module-item .info-value{font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--text-primary)}.module-item .degrees-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.module-item .overlap-error-message{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:#fef3c7;border-left:4px solid var(--color-warning);border-radius:var(--radius-sm);color:#92400e;font-size:var(--font-size-small);font-weight:var(--font-weight-medium);display:flex;align-items:center;gap:var(--spacing-xs)}.module-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:2px solid var(--border-color-light);background:var(--bg-secondary);display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:auto}.module-item .btn-primary{min-width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);transition:all var(--transition-base)}.module-item:not(.selected) .btn-primary{background:var(--color-success);color:#fff;border:2px solid var(--color-success)}.module-item.selected .btn-primary{background:var(--color-error);color:#fff;border:2px solid var(--color-error)}@media(hover:hover){.module-item:not(.selected) .btn-primary:hover{background:#059669;border-color:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.module-item.selected .btn-primary:hover{background:#dc2626;border-color:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}}.module-item .btn-primary:active{transform:scale(.98)}@media(max-width:767px){.module-header{padding:var(--spacing-sm) var(--spacing-md)}.module-footer{padding:var(--spacing-md);flex-direction:column}.module-footer .btn-primary{width:100%}}@media(prefers-reduced-motion:reduce){.module-item,.module-item:hover{transform:none}}.modules-container{padding:var(--spacing-md);max-width:var(--container-max-width);margin:0 auto;background-color:var(--bg-secondary);min-height:calc(100vh - 80px)}@media(min-width:768px){.modules-container{padding:var(--spacing-lg)}}@media(min-width:1024px){.modules-container{padding:var(--spacing-xl) var(--spacing-lg)}}.modules-container h2{margin-bottom:var(--spacing-md);color:var(--text-primary);font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold)}.modules-container h3{margin:var(--spacing-lg) 0 var(--spacing-md) 0;color:var(--text-secondary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold)}.overlap-warning{border:2px solid var(--color-warning);background-color:#fef3c7;padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-sm) 0;border-radius:var(--radius-md);color:#92400e;font-size:var(--font-size-body);font-weight:var(--font-weight-medium);line-height:var(--line-height-text);display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm);box-shadow:0 2px 4px #f59e0b1a}.overlap-warning:before{content:"⚠";font-size:24px;flex-shrink:0}.close-warning{min-height:var(--min-touch-target);min-width:var(--min-touch-target);padding:var(--spacing-xs);border:none;cursor:pointer;background:transparent;font-size:24px;color:#92400e;border-radius:var(--radius-sm);transition:all var(--transition-base);display:flex;align-items:center;justify-content:center}@media(hover:hover)and (pointer:fine){.close-warning:hover{background-color:#f59e0b33}}.close-warning:active{transform:scale(.95)}.close-warning:focus-visible{outline:3px solid var(--color-warning);outline-offset:2px}.filter-section{border:2px solid var(--border-color);padding:var(--spacing-md);margin:var(--spacing-md) 0;border-radius:var(--radius-lg);background:var(--bg-primary);box-shadow:var(--shadow-sm)}@media(min-width:768px){.filter-section{padding:var(--spacing-lg)}}.filter-group{margin:var(--spacing-sm) 0}.filter-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-semibold);color:var(--text-secondary);font-size:var(--font-size-small)}.filter-group input,.filter-group select{min-height:var(--recommended-touch-target);width:100%;padding:12px var(--spacing-sm);border:2px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);font-size:16px;font-family:var(--font-family);color:var(--text-primary);transition:all var(--transition-base)}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:var(--color-info);box-shadow:0 0 0 3px #2563eb1a}.filter-group input::placeholder{color:var(--text-tertiary);opacity:.8}.modules-list-items{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);margin-top:var(--spacing-md)}@media(min-width:768px){.modules-list-items{grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}}@media(min-width:1400px){.modules-list-items{grid-template-columns:repeat(3,1fr)}}.no-results{padding:var(--spacing-xl);text-align:center;color:var(--text-tertiary);font-size:var(--font-size-body);background:var(--bg-secondary);border:2px solid var(--border-color-light);border-radius:var(--radius-lg);margin:var(--spacing-md) 0;box-shadow:var(--shadow-sm)}.no-results:before{content:"🔍";display:block;font-size:48px;margin-bottom:var(--spacing-sm);opacity:.5}.selected-modules-title{margin-top:var(--spacing-xl);margin-bottom:var(--spacing-md);font-size:var(--font-size-h3);color:var(--text-primary)}.remove-all-button{min-height:var(--recommended-touch-target);padding:14px var(--spacing-lg);width:100%;background-color:var(--color-error);color:#fff;border:3px solid var(--color-error);border-radius:var(--radius-lg);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;margin-bottom:var(--spacing-md);transition:all var(--transition-base);box-shadow:0 2px 4px #dc262633}@media(min-width:768px){.remove-all-button{width:auto;min-width:200px}}@media(hover:hover)and (pointer:fine){.remove-all-button:hover{background-color:var(--color-error-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}}.remove-all-button:active{transform:scale(.97)}.remove-all-button:focus-visible{outline:3px solid var(--color-info);outline-offset:3px}.remove-all-button:active{transform:translateY(0)}.selected-modules-container{background-color:#fff;padding:var(--spacing-md);border-radius:6px;border:2px solid var(--color-medium-blue);box-shadow:0 2px 4px #2f455014}.selected-module-item{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:10px;background-color:var(--color-off-white);border:2px solid var(--color-light-blue);border-radius:6px;box-shadow:0 2px 4px #2f45500f;transition:all .2s}.selected-module-item:hover{box-shadow:0 4px 8px #2f45501f;transform:translateY(-1px);border-color:var(--color-medium-blue);background-color:#fff}.selected-module-item:last-child{margin-bottom:0}.selected-module-item strong{display:block;margin-bottom:var(--spacing-xs);color:var(--color-dark-blue);font-size:var(--font-size-body);font-weight:600}.module-info{font-size:var(--font-size-body);color:var(--color-dark-blue);line-height:var(--line-height-text)}@media(max-width:768px){.modules-container,.filter-section{padding:var(--spacing-sm)}}
