@import "https://fonts.googleapis.com/css2?family=Public+Sans:wght@400;500;600;700&display=swap";*{box-sizing:border-box}:root{color:#1c232b;font-family:Public Sans,Segoe UI,sans-serif;line-height:1.4}body{background:radial-gradient(circle at 10% -10%,#d5f5f0 0%,#0000 42%),radial-gradient(circle at 100% 20%,#e8edf8 0%,#0000 40%),#f6f7f3;min-height:100svh;margin:0}#root{max-width:1120px;margin:0 auto;padding:1.25rem}h1,h2,h3,p{margin:0}.app{gap:1rem;padding-bottom:8rem;display:grid}.header{text-align:center;gap:.25rem;margin-top:3rem;margin-bottom:1rem;display:grid}.header h1{font-size:clamp(1.3rem,2.5vw,2.5rem)}.header p{color:#697382}.panel{background:#fff;border:1px solid #dde2e8;border-radius:14px;width:100%;padding:1rem}.controls{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;display:grid}.field{gap:.45rem;display:grid;position:relative}.field label{font-size:.9rem;font-weight:600}.search-mode-switch{background:linear-gradient(#f9fbfc,#f2f6f7);border:1px solid #dde2e8;border-radius:12px;grid-template-columns:1fr 1fr;gap:.25rem;padding:.25rem;display:grid}.search-mode-switch button{color:#697382;cursor:pointer;background:0 0;border:0;border-radius:9px;padding:.58rem .8rem;font-weight:600;transition:background-color .2s,color .2s,box-shadow .2s}.search-mode-switch button:hover:not(:disabled){color:#1c232b}.search-mode-switch button:hover:not(:disabled).is-active{color:#fff}.search-mode-switch button.is-active{color:#fff;background:#0f766e;box-shadow:0 6px 16px -12px #0f766ecc}.search-mode-switch button:disabled{opacity:.55;cursor:not-allowed}.course-search{grid-template-columns:minmax(220px,1fr) auto;align-items:end;gap:.75rem;display:grid}.course-search button{color:#fff;cursor:pointer;background:#0f766e;border:1px solid #0000;border-radius:10px;padding:.56rem 1rem;font-weight:600}.course-search button:hover:not(:disabled){background:#0b5f58}.course-search button:disabled{opacity:.55;cursor:not-allowed}input,select,button{font:inherit}input,select{color:#1c232b;background:#fff;border:1px solid #dde2e8;border-radius:10px;padding:.58rem .7rem}input:focus,select:focus,button:focus{outline-offset:2px;outline:2px solid #26e3d5}.small-text{color:#697382;font-size:.82rem;position:absolute;top:100%}.panel-head{justify-content:space-between;align-items:baseline;margin-bottom:.75rem;display:flex}.panel-head p{color:#697382;font-size:.9rem}.professor-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;display:grid}.professor-card{text-align:left;cursor:pointer;background:#fff;border:1px solid #dde2e8;border-radius:12px;gap:.35rem;padding:.75rem;display:grid}.professor-card h3{font-size:1rem}.professor-card p{color:#697382}.professor-card .rating{color:#1c232b;font-weight:600}.professor-card:hover{border-color:#18b9ac}.professor-card.selected{border-color:#0f766e;box-shadow:0 0 0 2px #0f766e29}.professor-card.skeleton{pointer-events:none}.professor-card-head{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.rank-badge{letter-spacing:.01em;border-radius:999px;justify-content:center;align-items:center;min-width:2.2rem;padding:.18rem .45rem;font-size:.75rem;font-weight:700;display:inline-flex}.rank-badge.gold{color:#92400e;background:#fef3c7}.rank-badge.silver{color:#374151;background:#e5e7eb}.rank-badge.bronze{color:#8b4513;background:#f6d7c3}.rank-badge.top-five{color:#075985;background:#e0f2fe}.skeleton-line{background:linear-gradient(90deg,#edf1f5,#e2e7ed,#edf1f5) 0 0/200% 100%;border-radius:999px;height:.68rem;animation:1.1s linear infinite shimmer}.skeleton-title{width:72%;height:.86rem}.skeleton-short{width:50%}@keyframes shimmer{0%{background-position:0 0}to{background-position:200% 0}}.analyze-row{justify-content:flex-end;margin-top:.8rem;display:flex}.analyze-row button{color:#fff;cursor:pointer;background:#0f766e;border:1px solid #0000;border-radius:10px;padding:.56rem 1rem;font-weight:600}.analyze-row button:hover:not(:disabled){background:#0b5f58}.analyze-row button:disabled{opacity:.55;cursor:not-allowed}.analysis-dock-spacer{height:7.5rem}.bottom-dock,.bottom-result-panel{z-index:40;background:#fff;border:1px solid #dde2e8;border-radius:14px;width:min(1120px,100% - 2rem);position:fixed;bottom:1rem;left:50%;transform:translate(-50%);box-shadow:0 16px 36px -24px #1c232b73}.bottom-dock{opacity:1;grid-template-columns:1fr auto;align-items:center;gap:1rem;padding:.9rem 1rem;transition:transform .28s,opacity .28s;animation:.3s dock-rise-in;display:grid}.bottom-dock.is-exiting{opacity:0;pointer-events:none;transform:translate(-50%,140%)}@keyframes dock-rise-in{0%{opacity:0;transform:translate(-50%,110%)}to{opacity:1;transform:translate(-50%)}}.bottom-dock-text{color:#697382}.bottom-dock-analyze{color:#fff;cursor:pointer;background:#0f766e;border:1px solid #0000;border-radius:10px;padding:.56rem 1rem;font-weight:600}.bottom-dock-analyze:hover:not(:disabled){background:#0b5f58}.bottom-dock-analyze:disabled{opacity:.55;cursor:not-allowed}.bottom-result-panel{gap:.7rem;padding:.95rem 1rem 1rem;animation:.3s rise-in;display:grid}.bottom-result-panel.is-loading{grid-auto-flow:column;justify-content:flex-start;align-items:center}.bottom-inline-loading{align-items:center;gap:.6rem;display:flex}.bottom-panel-message{display:grid}.bottom-result-close{color:#697382;cursor:pointer;background:0 0;border:0;padding:.2rem;font-size:1rem;line-height:1;position:absolute;top:.55rem;right:.65rem}.bottom-result-close:hover{color:#1c232b}@keyframes rise-in{0%{opacity:0;transform:translate(-50%,110%)}to{opacity:1;transform:translate(-50%)}}.pagination{justify-content:flex-start;align-items:center;gap:.5rem;margin-top:.9rem;display:flex}.pagination button{cursor:pointer;background:#fff;border:1px solid #dde2e8;border-radius:8px;min-width:2.2rem;padding:.42rem .55rem;font-weight:700}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination-status{color:#697382;font-size:.9rem}.pagination-top{margin-bottom:.75rem}.analysis-panel{gap:.7rem;margin-top:.15rem;padding:0;display:grid}.history-toggle{color:#0f766e;cursor:pointer;background:0 0;border:0;justify-self:start;align-items:center;padding:.2rem 0;font-weight:600;line-height:0;display:inline-flex}.history-toggle:hover{color:#0b5f58}.history-toggle:focus,.history-toggle:focus-visible,.history-toggle:active{box-shadow:none;outline:none}.history-toggle-icon{font-size:2rem;line-height:1;transition:transform .25s}.history-toggle-icon.expanded{transform:rotate(180deg)}.history-expandable{opacity:0;max-height:0;transition:max-height .35s,opacity .25s;overflow:hidden}.history-expandable.expanded{opacity:1;max-height:360px}.history-panel-content{padding-top:.25rem}.history-loading{justify-content:center;align-items:center;gap:.6rem;min-height:220px;display:flex}.history-chart-wrap{width:100%;min-height:220px}.recharts-wrapper:focus,.recharts-wrapper:focus-visible,.recharts-surface:focus,.recharts-surface:focus-visible{outline:none}.analysis-metrics{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;display:grid}.metric-label{color:#697382;font-size:.8rem}.metric-value{margin-top:.22rem;font-size:1.05rem;font-weight:700}.spinner{border:3px solid #d7dddf;border-top-color:#0f766e;border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin}.spinner.large{border-width:6px;width:44px;height:44px}@keyframes spin{to{transform:rotate(360deg)}}.error{color:#b91c1c;font-weight:600}.muted,.empty-state{color:#697382}@media (width<=640px){#root{padding:.85rem}.panel{padding:.75rem}.analysis-dock-spacer{height:8.8rem}.bottom-dock{grid-template-columns:1fr}.bottom-dock-analyze{width:100%}.course-search{grid-template-columns:1fr}.course-search button{width:100%}}
