*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#080c14;--bg-secondary:#0f172a;--bg-card:#0f172a99;--border-subtle:#ffffff0d;--border-card:#ffffff14;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#64748b;--accent-warm:#f97316;--accent-cool:#38bdf8;--accent-green:#10b981;--accent-red:#ef4444;--radius-sm:12px;--radius-md:16px;--radius-lg:24px}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5;overflow-x:hidden}.ambient{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.ambient-orb{filter:blur(120px);opacity:.12;border-radius:50%;animation:25s ease-in-out infinite drift;position:absolute}.ambient-orb--1{background:var(--accent-warm);width:600px;height:600px;animation-delay:0s;top:-10%;right:-5%}.ambient-orb--2{background:var(--accent-cool);width:500px;height:500px;animation-delay:-8s;bottom:-10%;left:-5%}.ambient-orb--3{opacity:.06;background:#8b5cf6;width:400px;height:400px;animation-delay:-16s;top:30%;left:30%}@keyframes drift{0%,to{transform:translate(0)scale(1)}33%{transform:translate(40px,-30px)scale(1.08)}66%{transform:translate(-30px,20px)scale(.92)}}.noise{z-index:1;pointer-events:none;opacity:.02;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");position:fixed;inset:0}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff05}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-container{z-index:2;flex-direction:column;min-height:100vh;display:flex;position:relative}.tv-layout{grid-template-rows:auto 1fr auto;gap:30px;width:100%;max-width:1600px;min-height:100vh;margin:0 auto;padding:40px;display:grid}.tv-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding-bottom:20px;display:flex}.tv-header__left{flex-direction:column;gap:8px;display:flex}.school-badge{color:var(--accent-cool);text-transform:uppercase;letter-spacing:.05em;background:#38bdf81a;border:1px solid #38bdf826;border-radius:100px;align-items:center;gap:8px;width:fit-content;padding:6px 16px;font-size:.8rem;font-weight:700;display:inline-flex}.school-badge__dot{background:var(--accent-cool);border-radius:50%;width:6px;height:6px;animation:2s infinite blink}.tv-header__title{letter-spacing:-.03em;background:linear-gradient(135deg,#fff 0%,#cbd5e1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:2.2rem;font-weight:800}.tv-header__clock{text-align:right;flex-direction:column;gap:4px;display:flex}.clock-time{font-variant-numeric:tabular-nums;font-size:2.5rem;font-weight:800;line-height:1}.clock-date{color:var(--text-muted);font-size:.95rem;font-weight:500}.tv-grid{grid-template-columns:1fr 1.2fr;gap:30px;display:grid}.tv-grid__left{flex-direction:column;gap:24px;display:flex}.tv-grid__right{flex-direction:column;display:flex}.metrics-row{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.metric-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);flex-direction:column;gap:16px;padding:24px;display:flex;position:relative;overflow:hidden}.metric-card__header{justify-content:space-between;align-items:center;display:flex}.metric-card__title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.metric-card__icon{opacity:.8;font-size:1.5rem}.metric-card__value{font-variant-numeric:tabular-nums;font-size:3.5rem;font-weight:800;line-height:1}.metric-card--temp .metric-card__value{color:var(--accent-warm)}.metric-card--hum .metric-card__value{color:var(--accent-cool)}.metric-card__unit{opacity:.7;font-size:.4em;font-weight:500}.metric-card__progress-track{background:#ffffff0d;border-radius:100px;height:6px;overflow:hidden}.metric-card__progress-fill{border-radius:100px;width:0%;height:100%;transition:width 1s cubic-bezier(.34,1.56,.64,1)}.metric-card--temp .metric-card__progress-fill{background:linear-gradient(90deg, var(--accent-warm), #ef4444)}.metric-card--hum .metric-card__progress-fill{background:linear-gradient(90deg, var(--accent-cool), #818cf8)}.info-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);padding:24px}.info-card__title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px;font-size:.85rem;font-weight:600}.comfort-status{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.comfort-status__label{font-size:1.1rem;font-weight:700}.comfort-status__badge{border-radius:100px;align-items:center;gap:6px;padding:4px 12px;font-size:.75rem;font-weight:700;display:inline-flex}.comfort-status__dot{border-radius:50%;width:6px;height:6px}.comfort--otimo{color:var(--accent-green);background:#10b9811a;border:1px solid #10b98126}.comfort--otimo .comfort-status__dot{background:var(--accent-green)}.comfort--bom{color:var(--accent-cool);background:#38bdf81a;border:1px solid #38bdf826}.comfort--bom .comfort-status__dot{background:var(--accent-cool)}.comfort--alerta{color:var(--accent-warm);background:#f973161a;border:1px solid #f9731626}.comfort--alerta .comfort-status__dot{background:var(--accent-warm)}.comfort--critico{color:var(--accent-red);background:#ef44441a;border:1px solid #ef444426}.comfort--critico .comfort-status__dot{background:var(--accent-red)}.comfort-bar{background:#ffffff0a;border-radius:100px;height:8px;margin-bottom:8px;position:relative;overflow:hidden}.comfort-bar__gradient{opacity:.35;background:linear-gradient(90deg,#38bdf8 0%,#10b981 35%,#fbbf24 65%,#f97316 85%,#ef4444 100%);position:absolute;inset:0}.comfort-bar__indicator{background:#fff;border-radius:50%;width:14px;height:14px;transition:left 1s cubic-bezier(.22,1,.36,1);position:absolute;top:-3px;box-shadow:0 0 10px #ffffff80}.comfort-labels{color:var(--text-muted);justify-content:space-between;font-size:.65rem;font-weight:600;display:flex}.weather-row{justify-content:space-between;align-items:center;gap:20px;display:flex}.weather-info{align-items:center;gap:16px;display:flex}.weather-icon{border-radius:var(--radius-sm);border:1px solid var(--border-card);background:#ffffff08;justify-content:center;align-items:center;width:64px;height:64px;font-size:2.8rem;display:flex}.weather-temp{font-size:2rem;font-weight:800}.weather-city{color:var(--text-secondary);font-size:.95rem;font-weight:600}.weather-desc{color:var(--text-muted);font-size:.8rem}.weather-details{text-align:right;flex-direction:column;gap:6px;display:flex}.weather-detail-item{color:var(--text-secondary);font-size:.8rem}.weather-detail-item span{color:var(--text-muted);font-weight:500}.carousel-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);flex-direction:column;flex:1;padding:32px;display:flex;position:relative;overflow:hidden}.carousel-card__header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:14px;display:flex}.carousel-title{text-transform:uppercase;letter-spacing:.05em;color:var(--accent-cool);align-items:center;gap:10px;font-size:1rem;font-weight:700;display:flex}.carousel-indicators{gap:6px;display:flex}.carousel-dot{background:#ffffff1a;border-radius:50%;width:8px;height:8px;transition:all .3s}.carousel-dot--active{background:var(--accent-cool);border-radius:100px;width:20px}.carousel-content{flex-direction:column;flex:1;justify-content:center;min-height:200px;display:flex;position:relative}.carousel-item{flex-direction:column;gap:16px;animation:.6s cubic-bezier(.22,1,.36,1) slideIn;display:flex}.carousel-item__title{letter-spacing:-.02em;color:#fff;font-size:1.8rem;font-weight:800;line-height:1.2}.carousel-item__text{color:var(--text-secondary);font-size:1.1rem;line-height:1.6}@keyframes slideIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.tv-footer{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(20px);justify-content:space-between;align-items:center;padding:16px 28px;display:flex}.status-indicator{align-items:center;gap:10px;display:flex}.status-indicator__dot{background:var(--text-muted);border-radius:50%;width:10px;height:10px;transition:background .3s,box-shadow .3s}.status-indicator__dot--online{background:var(--accent-green);animation:2s infinite alternate pulse-green;box-shadow:0 0 10px #10b98180}.status-indicator__text{color:var(--text-secondary);font-size:.85rem;font-weight:600}.footer-credit{color:var(--text-muted);font-size:.8rem;font-weight:500}@keyframes pulse-green{0%{opacity:1;transform:scale(1)}to{opacity:.8;transform:scale(1.15)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.admin-layout{z-index:10;width:100%;max-width:800px;margin:40px auto;padding:0 20px;position:relative}.admin-header{justify-content:space-between;align-items:center;margin-bottom:30px;display:flex}.admin-header__title{align-items:center;gap:10px;font-size:1.8rem;font-weight:800;display:flex}.btn-back{border:1px solid var(--border-card);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:#ffffff08;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-back:hover{color:#fff;background:#ffffff14}.admin-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);flex-direction:column;gap:24px;padding:30px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.8rem;font-weight:700}.input-field{border:1px solid var(--border-card);border-radius:var(--radius-sm);color:#fff;background:#ffffff08;padding:12px 16px;font-family:inherit;font-size:.95rem;transition:all .2s}.input-field:focus{border-color:var(--accent-cool);background:#ffffff0f;outline:none;box-shadow:0 0 10px #38bdf826}.electives-editor{border-top:1px solid var(--border-subtle);padding-top:24px}.electives-editor__header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.electives-editor__title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.9rem;font-weight:700}.btn-add{color:var(--accent-cool);border-radius:var(--radius-sm);cursor:pointer;background:#38bdf81a;border:1px solid #38bdf826;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:700;transition:all .2s;display:inline-flex}.btn-add:hover{background:#38bdf833}.electives-list{flex-direction:column;gap:16px;display:flex}.elective-item-form{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:#ffffff05;flex-direction:column;gap:12px;padding:16px;display:flex;position:relative}.btn-remove{color:var(--accent-red);cursor:pointer;opacity:.7;background:0 0;border:none;transition:opacity .2s;position:absolute;top:12px;right:12px}.btn-remove:hover{opacity:1}.btn-save{background:linear-gradient(135deg, var(--accent-cool) 0%, #6366f1 100%);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:10px;margin-top:12px;padding:14px 24px;font-size:1rem;font-weight:700;transition:all .3s;display:flex;box-shadow:0 4px 15px #38bdf833}.btn-save:hover{transform:translateY(-2px);box-shadow:0 6px 20px #38bdf84d}.btn-save:active{transform:translateY(0)}.btn-save:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.alert-toast{border-radius:var(--radius-sm);z-index:100;align-items:center;gap:10px;padding:12px 24px;font-size:.9rem;font-weight:600;animation:.3s slideUp;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 10px 25px #0003}.alert-toast--success{background:var(--accent-green);color:#fff}.alert-toast--error{background:var(--accent-red);color:#fff}@media (width<=1024px){.tv-grid{grid-template-columns:1fr}.tv-layout{padding:20px}}
