*{box-sizing:border-box;margin:0;padding:0}:root{--utcn-blue: #003366;--utcn-blue-light: #004080;--utcn-blue-dark: #002244;--utcn-accent: #0066cc;--utcn-red: #C8102E;--utcn-gold: #DAAA00;--white: #ffffff;--gray-50: #f8f9fa;--gray-100: #e9ecef;--gray-200: #dee2e6;--gray-300: #ced4da;--gray-600: #6c757d;--gray-800: #343a40;--success: #28a745;--danger: #dc3545;--warning: #fd7e14}body{font-family:Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--gray-100);min-height:100vh;color:var(--gray-800)}.app{min-height:100vh;display:flex;flex-direction:column}.top-bar{background:var(--utcn-blue-dark);color:var(--white);font-size:.85rem}.top-bar-content{max-width:1400px;margin:0 auto;padding:8px 24px;display:flex;justify-content:space-between}.clock{font-family:SF Mono,Monaco,monospace}.header{background:var(--utcn-blue);color:var(--white);box-shadow:0 2px 8px #00000026}.header-content{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:12px}.logo-icon{font-size:2rem}.logo-text h1{font-size:1.5rem;font-weight:600}.subtitle{font-size:.9rem;opacity:.85}.nav{display:flex;gap:8px}.nav-btn{padding:10px 20px;background:#ffffff1a;border:none;border-radius:6px;color:var(--white);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.nav-btn:hover{background:#fff3}.nav-btn.active{background:var(--white);color:var(--utcn-blue)}.date-bar{background:var(--utcn-blue-light);color:var(--white);text-align:center;padding:8px;font-size:.9rem;text-transform:capitalize}.main{flex:1;max-width:1400px;margin:0 auto;padding:24px;width:100%}.footer{background:var(--utcn-blue-dark);color:#fffc;text-align:center;padding:16px;font-size:.85rem}.footer-note{opacity:.7;margin-top:4px}.schedule-container,.departures-container,.admin-container{background:var(--white);border-radius:12px;box-shadow:0 2px 12px #00000014;overflow:hidden}.toolbar{background:var(--gray-50);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--gray-200);flex-wrap:wrap;gap:12px}.toolbar h2{font-size:1.25rem;color:var(--utcn-blue);margin-right:16px}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:12px}.view-toggle{display:flex;gap:4px}.view-toggle button{padding:6px 14px;border:1px solid var(--gray-300);background:var(--white);font-size:.85rem;cursor:pointer}.view-toggle button:first-child{border-radius:4px 0 0 4px}.view-toggle button:last-child{border-radius:0 4px 4px 0}.view-toggle button:not(:first-child):not(:last-child){border-radius:0}.view-toggle button.active{background:var(--utcn-blue);color:var(--white);border-color:var(--utcn-blue)}.week-navigation{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 20px;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.week-label{font-size:1rem;font-weight:600;color:var(--utcn-blue);min-width:250px;text-align:center}.btn-nav{padding:8px 16px;background:var(--white);border:1px solid var(--gray-300);border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-nav:hover{background:var(--utcn-blue);color:var(--white);border-color:var(--utcn-blue)}.btn-today{padding:8px 12px;background:var(--utcn-accent);color:var(--white);border:none;border-radius:6px;font-size:.85rem;cursor:pointer}.btn-today:hover{background:var(--utcn-blue)}.btn-refresh{padding:8px 16px;background:var(--utcn-blue);color:var(--white);border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background .2s}.btn-refresh:hover{background:var(--utcn-blue-dark)}.btn-refresh:disabled{opacity:.6;cursor:not-allowed}.filters-bar{padding:12px 20px;background:var(--white);border-bottom:1px solid var(--gray-200);display:flex;gap:16px;flex-wrap:wrap;align-items:center}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-size:.85rem;color:var(--gray-600);font-weight:500}.filter-group input,.filter-group select{padding:8px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:.9rem;min-width:140px}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:var(--utcn-accent);box-shadow:0 0 0 3px #0066cc26}.btn-clear{padding:8px 12px;background:var(--gray-200);border:none;border-radius:6px;font-size:.85rem;cursor:pointer}.calendar-select{background:var(--white);cursor:pointer;min-width:180px}.calendar-select:hover{border-color:var(--utcn-accent)}.search-group{flex:0 0 auto}.search-wrapper{position:relative}.search-input{min-width:200px}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--white);border:1px solid var(--gray-300);border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 12px #00000026;z-index:100;max-height:250px;overflow-y:auto}.suggestion-item{padding:10px 12px;font-size:.9rem;cursor:pointer;border-bottom:1px solid var(--gray-100)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:var(--gray-50);color:var(--utcn-blue)}.calendar-legend-container{padding:12px 20px;background:var(--gray-50);border-bottom:1px solid var(--gray-200);display:flex;align-items:center;gap:12px}.legend-title{font-weight:600;color:var(--gray-600);font-size:.85rem;white-space:nowrap;flex-shrink:0}.calendar-search-input{padding:6px 10px;border:1px solid var(--gray-300);border-radius:4px;font-size:.85rem;width:150px;flex-shrink:0}.calendar-search-input:focus{outline:none;border-color:var(--utcn-accent)}.calendar-legend{display:flex;align-items:center;gap:12px;overflow-x:auto;padding:4px 0;flex:1;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}.calendar-legend::-webkit-scrollbar{height:6px}.calendar-legend::-webkit-scrollbar-track{background:transparent}.calendar-legend::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.calendar-legend::-webkit-scrollbar-thumb:hover{background:var(--gray-600)}.legend-item{display:flex;align-items:center;gap:6px;font-size:.85rem;white-space:nowrap;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .15s}.legend-item:hover{background:var(--gray-200)}.legend-item input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--utcn-blue)}.legend-name{max-width:150px;overflow:hidden;text-overflow:ellipsis}.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.legend-actions{display:flex;gap:4px;flex-shrink:0}.btn-legend{padding:4px 8px;font-size:.75rem;background:var(--gray-200);border:none;border-radius:4px;cursor:pointer;transition:background .15s}.btn-legend:hover{background:var(--gray-300)}.schedule-grid{padding:20px}.day-section{margin-bottom:24px}.day-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--utcn-blue);color:var(--white);border-radius:8px 8px 0 0}.day-header h3{font-size:1rem;text-transform:capitalize}.event-count{font-size:.85rem;opacity:.85}.events-table{border:1px solid var(--gray-200);border-top:none;border-radius:0 0 8px 8px;overflow-x:auto;-webkit-overflow-scrolling:touch;position:relative}.events-table-inner{min-width:1000px}.table-header{display:grid;grid-template-columns:85px .8fr 130px 180px 100px 80px;gap:12px;padding:10px 16px;background:var(--gray-100);font-size:.8rem;font-weight:600;color:var(--gray-600);text-transform:uppercase}.table-row{display:grid;grid-template-columns:85px .8fr 130px 180px 100px 80px;gap:12px;padding:12px 16px;border-top:1px solid var(--gray-200);border-left:4px solid var(--utcn-blue);transition:background .15s}.table-row:hover{background:var(--gray-50)}.col-time{font-family:SF Mono,Monaco,monospace;font-size:.9rem;color:var(--utcn-blue)}.col-time small{display:block;color:var(--gray-600);font-size:.8rem}.col-title strong{display:block;color:var(--gray-800)}.col-title small{color:var(--gray-600);font-size:.85rem}.col-location,.col-professor{color:var(--gray-600);font-size:.9rem}.col-title{min-width:0}.col-title .event-title{white-space:normal;word-break:break-word}.event-meta{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.departures-grid{padding:20px;display:grid;gap:24px}.departure-section{padding:0}.section-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--utcn-blue);color:var(--white);border-radius:8px 8px 0 0}.section-header h3{font-size:1rem}.departure-board{background:var(--gray-800);border-radius:0 0 8px 8px;overflow-x:auto;-webkit-overflow-scrolling:touch;position:relative}.board-header{display:grid;grid-template-columns:85px .8fr 130px 180px 100px 80px;gap:12px;padding:10px 16px;background:var(--gray-600);color:var(--gray-200);font-size:.75rem;text-transform:uppercase;font-weight:600;min-width:1000px}.board-row{display:grid;grid-template-columns:85px .8fr 130px 180px 100px 80px;gap:12px;padding:12px 16px;color:var(--gray-100);border-top:1px solid var(--gray-600);border-left:4px solid var(--utcn-blue);transition:background .15s;min-width:1000px}.board-row:hover{background:#ffffff0d}.board-row .col-time{color:#ffc107;font-family:SF Mono,Monaco,monospace}.board-row .col-event .event-title{font-weight:500}.board-row .col-event .event-meta{display:block;color:var(--gray-300);font-size:.85rem}.board-row .col-room{color:#60a5fa}.board-row .col-prof{color:var(--gray-200)}.board-row .col-group{color:var(--gray-300)}.board-row .col-status{font-size:.85rem}.board-row.status-active{background:#28a74526}.board-row.status-active .col-status{color:var(--success);font-weight:600}.board-row.status-finished{background:#6c757d26}.board-row.status-finished .col-status{color:var(--gray-600)}.board-row.status-soon{background:#fd7e1426}.board-row.status-soon .col-status{color:var(--warning)}.board-row.status-upcoming .col-status{color:#60a5fa}.events-table:after,.departure-board:after{content:"";position:absolute;right:0;top:0;width:48px;height:100%;pointer-events:none;background:linear-gradient(to right,#fff0,#0000000f);mix-blend-mode:normal;transition:opacity .2s ease}@media (min-width: 600px){.events-table:after,.departure-board:after{opacity:.4}}@media (max-width: 599px){.events-table:after,.departure-board:after{opacity:.8}}.events-table::-webkit-scrollbar{height:8px}.events-table::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.departure-board::-webkit-scrollbar{height:8px}.departure-board::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.no-events{padding:32px;text-align:center;color:var(--gray-600);background:var(--gray-50);border:1px solid var(--gray-200);border-top:none;border-radius:0 0 8px 8px}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:0}.admin-section{padding:20px;border-bottom:1px solid var(--gray-200)}.admin-section:last-child{border-bottom:none}.admin-section .section-header{margin:-20px -20px 16px;border-radius:0}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.stat-card{background:var(--gray-50);padding:16px;border-radius:8px;text-align:center;border:1px solid var(--gray-200)}.stat-value{font-size:1.75rem;font-weight:700;color:var(--utcn-blue)}.stat-label{font-size:.85rem;color:var(--gray-600)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;animation:pulse 1.5s infinite}.status-badge.importing{background:#fff3cd;color:#856404}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.periodic-status{background:var(--gray-50);padding:8px 12px;border-radius:6px;margin-bottom:12px;border:1px solid var(--gray-200)}.periodic-status small{color:var(--gray-600);font-size:.8rem}.section-header{display:flex;justify-content:space-between;align-items:center}.calendar-list,.events-list-admin{margin-bottom:16px}.calendar-item,.event-item-admin{display:flex;align-items:center;gap:12px;padding:12px;background:var(--gray-50);border-radius:6px;margin-bottom:8px;border:1px solid var(--gray-200)}.calendar-color{width:16px;height:16px;border-radius:50%;flex-shrink:0}.calendar-info,.event-info-admin{flex:1;min-width:0}.calendar-info strong,.event-info-admin strong{display:block;font-size:.95rem}.calendar-info small,.event-info-admin small{color:var(--gray-600);font-size:.8rem;word-break:break-all}.form-add{background:var(--gray-50);padding:16px;border-radius:8px;border:1px solid var(--gray-200)}.form-add h4{font-size:.95rem;color:var(--gray-800);margin-bottom:12px}.form-add input{width:100%;padding:10px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:.9rem;margin-bottom:10px}.form-add input:focus{outline:none;border-color:var(--utcn-accent)}.form-row{display:flex;gap:8px}.form-row input{flex:1}.color-picker{margin-bottom:12px}.color-picker label{display:block;font-size:.85rem;color:var(--gray-600);margin-bottom:8px}.color-options{display:flex;gap:8px;flex-wrap:wrap}.color-btn{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .15s}.color-btn:hover{transform:scale(1.15)}.color-btn.active{border-color:var(--gray-800);box-shadow:0 0 0 2px var(--white)}.calendar-color-picker{display:flex;gap:4px;flex-wrap:wrap;margin-right:12px}.color-btn-sm{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .15s;padding:0}.color-btn-sm:hover{transform:scale(1.2)}.color-btn-sm.active{border-color:var(--gray-800);box-shadow:0 0 0 2px var(--white)}.btn-primary{width:100%;padding:12px;background:var(--utcn-blue);color:var(--white);border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-primary:hover{background:var(--utcn-blue-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-full{width:100%}.btn-danger-sm{padding:6px 10px;background:var(--danger);color:var(--white);border:none;border-radius:4px;font-size:.8rem;cursor:pointer}.btn-danger-sm:hover{background:#c82333}.alert{padding:12px 16px;border-radius:6px;margin:16px 20px;font-size:.9rem}.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.alert-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.empty-state,.loading-state{padding:48px 24px;text-align:center;color:var(--gray-600)}.empty-icon{font-size:3rem;margin-bottom:16px}.empty-state h3{color:var(--gray-800);margin-bottom:8px}.spinner{width:40px;height:40px;border:4px solid var(--gray-200);border-top-color:var(--utcn-blue);border-radius:50%;margin:0 auto 16px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.status-bar{padding:12px 20px;background:var(--gray-50);border-top:1px solid var(--gray-200);font-size:.85rem;color:var(--gray-600);display:flex;justify-content:center;gap:12px}.text-muted{color:var(--gray-600);font-size:.9rem}@media (max-width: 1024px){.main{padding:16px}.week-label{min-width:200px;font-size:.9rem}.table-header,.table-row{grid-template-columns:90px 1fr 120px 120px}}@media (max-width: 768px){.top-bar-content{flex-direction:column;gap:4px;text-align:center;padding:6px 16px}.header-content{flex-direction:column;gap:12px;text-align:center;padding:12px 16px}.logo-text h1{font-size:1.25rem}.subtitle{font-size:.8rem}.nav{flex-wrap:wrap;justify-content:center;gap:6px}.nav-btn{padding:8px 14px;font-size:.85rem}.main{padding:12px}.toolbar{flex-direction:column;padding:12px 16px}.toolbar h2{font-size:1.1rem;margin-right:0;margin-bottom:8px}.toolbar-left,.toolbar-right{width:100%;justify-content:center}.view-toggle{flex-wrap:wrap}.week-navigation{flex-wrap:wrap;padding:10px 16px;gap:10px}.week-label{min-width:100%;order:-1}.btn-nav{padding:6px 12px;font-size:.85rem}.filters-bar{flex-direction:column;align-items:stretch;padding:12px 16px}.filter-group{flex-direction:column;align-items:stretch}.filter-group input,.filter-group select{width:100%;min-width:unset}.search-wrapper{width:100%}.search-input{width:100%;min-width:unset}.calendar-legend-container{flex-direction:column;align-items:stretch;gap:8px}.legend-title{text-align:center}.calendar-legend{justify-content:flex-start}.legend-actions{justify-content:center}.schedule-grid{padding:12px}.day-section{margin-bottom:16px}.table-header,.table-row{grid-template-columns:70px minmax(120px,1fr) 110px 160px 90px 70px;font-size:.85rem;padding:10px 12px}.departures-grid{padding:12px}.board-header,.board-row{grid-template-columns:65px minmax(120px,1fr) 110px 140px 90px 70px;font-size:.8rem;padding:10px 12px}.board-row .col-status{display:none}.admin-grid{grid-template-columns:1fr}.admin-section{padding:16px}.stats-grid{grid-template-columns:1fr}.stat-card{padding:12px}.stat-value{font-size:1.5rem}.form-row{flex-direction:column}.alert{margin:12px}}@media (max-width: 480px){.top-bar{font-size:.75rem}.header-content{padding:10px 12px}.logo-text h1{font-size:1.1rem}.subtitle{display:none}.nav-btn{padding:6px 10px;font-size:.8rem}.main{padding:8px}.toolbar{padding:10px 12px}.toolbar h2{font-size:1rem}.view-toggle button{padding:5px 10px;font-size:.75rem}.btn-refresh{padding:6px 12px;font-size:.8rem}.week-navigation{padding:8px 12px}.btn-nav{padding:5px 10px;font-size:.8rem}.btn-today{padding:5px 10px;font-size:.75rem}.filters-bar{padding:10px 12px;gap:10px}.schedule-grid,.departures-grid{padding:8px}.day-header{padding:10px 12px}.day-header h3{font-size:.9rem}.table-header,.table-row{grid-template-columns:80px minmax(100px,1fr) 90px 120px 80px;padding:8px 10px}.col-time,.col-location,.col-professor{font-size:.8rem}.section-header{padding:10px 12px}.section-header h3{font-size:.9rem}.board-header,.board-row{grid-template-columns:55px minmax(100px,1fr) 60px 100px 70px;padding:8px 10px}.board-header{font-size:.65rem}.admin-section{padding:12px}.admin-section .section-header{margin:-12px -12px 12px}.form-add{padding:12px}.form-add input{padding:8px 10px}.btn-primary{padding:10px;font-size:.85rem}.empty-state,.loading-state{padding:32px 16px}.empty-icon{font-size:2rem}.footer{padding:12px;font-size:.8rem}}
