:root{font-family:Inter,system-ui,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f1f5f9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:inherit;text-decoration:none}a:hover{color:inherit}body{margin:0;min-width:320px;min-height:100vh;background:#f1f5f9}*{box-sizing:border-box}#root{width:95%;margin:2.5%;color:#0f172a}.admin-app{display:flex;flex-direction:column;gap:2rem}.admin-header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.admin-header h1{font-size:2.2rem;margin:.35rem 0 0}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:600;color:#64748b;margin:0}.header-actions{padding-top:10px;display:flex;gap:.75rem}button{border:none;padding:.6rem 1rem;border-radius:999px;background:#2563eb;color:#fff;cursor:pointer;font-weight:600}button.secondary{background:#e2e8f0;color:#0f172a}button.ghost{background:transparent;color:#334155;padding:.4rem .6rem}button.ghost.danger{color:#dc2626}.admin-layout{display:grid;grid-template-columns:180px 1fr;gap:1.5rem}.admin-layout--single{grid-template-columns:1fr}.sidebar{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#f8fafc;border-radius:1rem}.sidebar button{background:transparent;color:#475569;text-align:left;border-radius:.75rem}.sidebar button.active{background:#fff;color:#1e3a8a;box-shadow:0 6px 16px #0f172a14}.admin-content{display:flex;flex-direction:column;gap:2rem}.admin-content--center{align-items:center}.panel{background:#fff;border-radius:1.25rem;padding:1.5rem;box-shadow:0 12px 30px #0f172a0f}.card{background:#fff;border-radius:1.25rem;padding:1.5rem;box-shadow:0 12px 30px #0f172a0f;display:flex;flex-direction:column;gap:1rem}.tickets-page .ticket-card{padding:1rem;gap:.75rem}.tickets-page .ticket-detail-stack{display:flex;flex-direction:column;gap:1.5rem}.tickets-page .ticket-detail-grid{display:grid;grid-template-columns:minmax(0,35%) minmax(0,65%);gap:1.5rem;align-items:start}.ticket-chat{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem;max-height:360px;overflow-y:auto;padding-right:.25rem}.ticket-chat-row{display:flex}.ticket-chat-row.is-student{justify-content:flex-end}.ticket-chat-row.is-ta{justify-content:flex-start}.ticket-bubble{max-width:min(75%,520px);padding:.65rem .85rem;border-radius:1rem;background:#f1f5f9;color:#0f172a;display:flex;flex-direction:column;gap:.35rem;box-shadow:0 6px 16px #0f172a14}.ticket-bubble.is-ta{background:#e2e8f0}.ticket-bubble.is-student{background:#dbeafe}.ticket-author{font-size:.7rem;font-weight:600;color:#475569}.ticket-timestamp{font-size:.7rem;color:#64748b}.tickets-page .ticket-detail-grid>.stack{gap:1.5rem}.filters-card{padding:1rem 1.25rem}.filters-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.filters-form{margin-top:.75rem}.filters-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.filters-toggle{font-weight:600}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1.5rem}.panel-header h2{margin:0 0 .3rem}.panel-header p{margin:0;color:#64748b}.auth-panel{width:100%;max-width:420px}.stack{display:flex;flex-direction:column;gap:.2rem}.muted{color:#64748b;font-size:.85rem}.form{display:flex;flex-direction:column;gap:.85rem}.form label{display:flex;flex-direction:column;gap:.4rem;font-weight:600;color:#1e293b}.form input,.form select,.form textarea{padding:.6rem .75rem;border-radius:.75rem;border:1px solid #cbd5f5;font-size:.95rem;font-weight:500;color:#0f172a;background:#fff}.form textarea{min-height:110px;resize:vertical}.list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.list-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.list-row:last-child{border-bottom:none;padding-bottom:0}.ticket-list-row{cursor:pointer;border-radius:.75rem;padding:.75rem;transition:background .2s ease,box-shadow .2s ease}.ticket-list-row:hover{background:#f8fafc}.ticket-list-row.is-selected{background:#eef2ff;box-shadow:inset 0 0 0 1px #c7d2fe}@media(max-width:900px){.tickets-page .ticket-detail-grid{grid-template-columns:1fr}}table{width:100%;border-collapse:collapse;font-size:.95rem}table th{text-align:left;color:#64748b;font-weight:600;padding-bottom:.75rem}table td{padding:.75rem 0;border-top:1px solid #e2e8f0;vertical-align:top}.pill{display:inline-flex;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;background:#e2e8f0;color:#1e293b;white-space:nowrap}.pill-group{display:flex;flex-wrap:wrap;gap:.35rem}.pill.admin{background:#dbeafe;color:#1d4ed8}.pill.ta{background:#fef3c7;color:#b45309}.pill.student,.pill.active{background:#dcfce7;color:#15803d}.pill.planned{background:#e0e7ff;color:#3730a3}.pill.waiting{background:#fef3c7;color:#b45309}.pill.answered{background:#dbeafe;color:#1d4ed8}.pill.closed{background:#fee2e2;color:#b91c1c}.status{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.status.ok{background:#dcfce7;color:#15803d}.status.warning{background:#fee2e2;color:#b91c1c}.filters{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.filters label{display:flex;flex-direction:column;gap:.35rem;font-weight:600;color:#1e293b}.filters input,.filters select{padding:.55rem .75rem;border-radius:.75rem;border:1px solid #cbd5f5;font-size:.95rem;font-weight:500;color:#0f172a;background:#fff}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.charts-grid{display:grid;grid-template-rows:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.chart-card{background:#f8fafc;border-radius:1rem;padding:1rem;display:flex;flex-direction:column;gap:1rem}.chart-bars{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(24px,1fr);align-items:end;gap:.4rem;height:200px}.chart-bar{display:flex;flex-direction:column;align-items:center;gap:.4rem;height:100%}.chart-label{font-size:.7rem;color:#64748b}.chart-stack{display:flex;flex-direction:column;gap:.2rem;height:100%;width:100%;justify-content:flex-end}.chart-stack .bar{border-radius:999px}.chart-stack .bar.opened{background:#60a5fa}.chart-stack .bar.closed{background:#f87171}.chart-legend{display:flex;gap:1rem;font-size:.8rem;color:#475569}.legend-item:before{content:"";display:inline-block;width:10px;height:10px;border-radius:999px;margin-right:.4rem}.legend-item.opened:before{background:#60a5fa}.legend-item.closed:before{background:#f87171}.catalog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.catalog-card{background:#f8fafc;border-radius:1rem;padding:1rem;display:flex;flex-direction:column;gap:1rem}.catalog-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.catalog-list{display:flex;flex-direction:column;gap:.75rem}.catalog-entry{display:flex;flex-direction:column;gap:.75rem;padding:.85rem;border-radius:.9rem;border:1px solid #e2e8f0;background:#fff}.catalog-entry-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.catalog-entry-fields{display:grid;gap:.75rem}.catalog-entry-fields>div{display:flex;flex-direction:column;gap:.2rem}.field-label{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.catalog-card small{color:#64748b}.class-list{display:flex;flex-direction:column;gap:1rem}.class-card{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;padding:1rem 1.25rem;border:1px solid #e2e8f0;border-radius:1rem}.class-card h3{margin:0 0 .35rem}.class-card p{margin:0;color:#64748b}.class-meta{display:flex;align-items:center;gap:1rem}.drawer-backdrop{position:fixed;inset:0;background:#0f172a66;display:flex;justify-content:flex-end;z-index:10}.drawer{width:min(40%,100%);background:#fff;height:100%;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.drawer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.drawer-header h2{margin:.35rem 0 0}.drawer-content{display:flex;flex-direction:column;gap:1.5rem}.drawer-section h3{margin-bottom:.75rem}.drawer-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.drawer-section li{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.75rem;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:.75rem}.drawer-section li.ticket-message,.drawer-section li.ticket-attachment{grid-template-columns:1fr;align-items:flex-start}.modal-backdrop{position:fixed;inset:0;background:#0f172a66;display:flex;align-items:center;justify-content:center;z-index:15;padding:1.5rem}.modal{width:min(560px,100%);background:#fff;border-radius:1rem;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 20px 60px #0f172a33}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.modal-header h2{margin:.35rem 0 0}.modal-body{display:flex;flex-direction:column;gap:1rem}.modal-body label{display:flex;flex-direction:column;gap:.4rem;font-weight:600;color:#1e293b}.modal-checkbox{flex-direction:row;align-items:center;gap:.6rem;font-weight:500;color:#475569}.modal-checkbox input{width:16px;height:16px}.modal-body input,.modal-body select{padding:.6rem .75rem;border-radius:.75rem;border:1px solid #cbd5f5;font-size:.95rem;font-weight:500;color:#0f172a;background:#fff}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.drawer-form{display:flex;gap:.5rem}.drawer-form input{flex:1;padding:.55rem .75rem;border-radius:.75rem;border:1px solid #cbd5f5}.drawer-suggestions{margin-top:.75rem;display:flex;flex-direction:column;gap:.75rem}.suggestion-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:.75rem;border:1px dashed #cbd5f5}@media(max-width:900px){.admin-layout{grid-template-columns:1fr}.sidebar{flex-direction:row;justify-content:space-between}.class-card{flex-direction:column;align-items:flex-start}.drawer-section li,.filters-grid{grid-template-columns:1fr}}
