:root{--ucla-blue:#2774ae;--ucla-blue-light:#5296d5;--ucla-blue-dark:#005587;--ucla-gold:#ffd100;--ucla-gold-light:#ffeb7f;--bg-color:#f5f7fa;--surface:#fff;--border-color:#e2e8f0;--text-primary:#1e293b;--text-secondary:#64748b;--danger:#ef4444}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5}.app-container{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{background-color:var(--ucla-blue);color:#fff;z-index:10;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;box-shadow:0 2px 4px #0000001a}.brand{align-items:center;gap:.75rem;display:flex}.brand h1{color:var(--ucla-gold);font-size:1.5rem;font-weight:700}.brand-icon{color:var(--ucla-gold)}.subtitle{opacity:.9;font-size:.9rem}.header-actions{align-items:center;display:flex}.header-btn{background-color:var(--ucla-gold);color:var(--ucla-blue-dark);cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:background-color .2s,transform .1s;box-shadow:0 2px 4px #0000001a}.header-btn:hover{background-color:var(--ucla-gold-light);transform:translateY(-1px)}.header-btn:active{transform:translateY(1px)}.sidebar-action-btn{background-color:var(--ucla-blue-dark);color:#fff;letter-spacing:.3px;cursor:pointer;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.6rem 1rem;font-size:.85rem;font-weight:500;transition:all .2s;display:flex;box-shadow:0 2px 5px #0000000d}.sidebar-action-btn:hover{background-color:var(--ucla-blue);transform:translateY(-1px);box-shadow:0 4px 8px #0000001a}.sidebar-action-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.text-action-btn{color:var(--ucla-blue);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:.35rem;padding:.25rem .5rem;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.text-action-btn:hover{color:var(--ucla-blue-dark)}.text-action-btn:active{transform:scale(.98)}.category-accordion{background-color:var(--surface);border:1px solid var(--border-color);border-radius:8px;margin-bottom:.75rem;overflow:hidden;box-shadow:0 1px 2px #00000008}.category-header{cursor:pointer;background-color:#f8fafc;border-bottom:1px solid #0000;align-items:center;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s,border-color .2s;display:flex}.category-header:hover{background-color:#f1f5f9}.category-accordion:has(.category-content) .category-header{border-bottom-color:var(--border-color)}.category-title{color:var(--text-primary);white-space:normal;flex-grow:1;font-size:.95rem;font-weight:600;line-height:1.2}.category-count{color:var(--text-secondary);white-space:nowrap;background-color:#e2e8f0;border-radius:12px;flex-shrink:0;padding:.15rem .5rem;font-size:.75rem;font-weight:500}.category-icon{color:var(--text-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.category-icon svg{transition:transform .3s}.category-icon.open svg{transform:rotate(90deg)}.category-content{background-color:var(--surface);flex-direction:column;gap:.5rem;min-height:2rem;padding:.75rem;display:flex}.empty-category-msg{text-align:center;color:var(--text-secondary);border:1px dashed var(--border-color);background:#f8fafc;border-radius:6px;padding:1rem;font-size:.85rem;font-style:italic}.main-content{flex-direction:row;flex:1;display:flex;overflow:hidden}.sidebar{background-color:var(--surface);flex-direction:column;height:100%;display:flex}.resizer{background-color:var(--border-color);cursor:col-resize;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:4px;width:5px;height:100%;transition:background-color .2s;display:flex}.resizer-dot{background-color:var(--text-secondary);opacity:.5;border-radius:50%;width:3px;height:3px;transition:opacity .2s,background-color .2s}.resizer:hover,.resizer:active{background-color:var(--ucla-blue-light)}.resizer:hover .resizer-dot,.resizer:active .resizer-dot{opacity:1;background-color:#fff}.horizontal-resizer{background-color:var(--border-color);cursor:row-resize;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:center;align-items:center;height:6px;transition:background-color .2s;display:flex}.horizontal-resizer:hover,.horizontal-resizer:active{background-color:var(--ucla-blue-light)}.horizontal-resizer-line{background-color:var(--text-secondary);opacity:.4;border-radius:2px;width:30px;height:2px;transition:opacity .2s,background-color .2s}.horizontal-resizer:hover .horizontal-resizer-line,.horizontal-resizer:active .horizontal-resizer-line{opacity:1;background-color:#fff}.sidebar-header{border-bottom:1px solid var(--border-color);padding:1rem}.sidebar-header h2{font-size:1.2rem;font-weight:600}.search-container{border-bottom:1px solid var(--border-color);padding:1rem;position:relative}.search-icon{color:var(--text-secondary);position:absolute;top:50%;left:1.5rem;transform:translateY(-50%)}.search-input{border:1px solid var(--border-color);border-radius:6px;outline:none;width:100%;padding:.5rem .5rem .5rem 2.5rem;font-size:.9rem;transition:border-color .2s}.search-input:focus{border-color:var(--ucla-blue)}.sidebar-course-list{flex-direction:column;flex:1;gap:.75rem;padding:1rem;display:flex;overflow-y:auto}.planner-grid{flex-direction:column;flex:1;gap:2rem;padding:2rem;display:flex;overflow:hidden auto}.year-row{background-color:var(--surface);border-radius:8px;flex-direction:column;flex-shrink:0;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000001a}.year-label-container{background-color:var(--text-primary);color:#fff;padding:.75rem 1.5rem}.year-label{font-size:1.1rem;font-weight:600}.quarters-container{background-color:var(--border-color);flex-grow:1;grid-template-columns:repeat(4,1fr);gap:1px;display:grid}.quarter-column{background-color:var(--surface);flex-direction:column;height:100%;min-height:250px;display:flex}.quarter-fall .quarter-header{border-top:3px solid #f97316}.quarter-winter .quarter-header{border-top:3px solid #0ea5e9}.quarter-spring .quarter-header{border-top:3px solid #22c55e}.quarter-summer .quarter-header{border-top:3px solid #eab308}.quarter-header{border-bottom:1px solid var(--border-color);background-color:#f8fafc;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.quarter-header h3{color:var(--text-primary);font-size:.95rem;font-weight:600}.unit-count{color:var(--text-secondary);background-color:#e2e8f0;border-radius:12px;padding:.2rem .6rem;font-size:.8rem;font-weight:500}.quarter-content{flex-direction:column;flex-grow:1;gap:.5rem;min-height:150px;padding:.75rem;transition:background-color .2s;display:flex}.quarter-content.dragging-over{background-color:var(--ucla-blue-light);opacity:.1;background-color:#2774ae0d}.empty-placeholder{height:100%;color:var(--text-secondary);border:1px dashed var(--border-color);border-radius:6px;justify-content:center;align-items:center;margin:.25rem 0;font-size:.85rem;display:flex}.course-card,.sidebar-course-card{border:1px solid var(--ucla-blue-light);-webkit-user-select:none;user-select:none;border-left:4px solid var(--ucla-gold);background-color:#fff;border-radius:6px;padding:.75rem;transition:box-shadow .2s,transform .1s;box-shadow:0 1px 2px #0000000d}.course-card:hover,.sidebar-course-card:hover{box-shadow:0 4px 6px #00000014}.course-card.dragging{z-index:100;transform:rotate(2deg)scale(1.02);box-shadow:0 8px 16px #0000001a}.planned-course{opacity:.5;background-color:#f8fafc}.planned-course .course-card-header strong,.planned-course .course-card-title{color:var(--text-secondary);text-decoration:line-through}.course-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.25rem;display:flex}.course-card-header strong{color:var(--ucla-blue-dark);font-size:.9rem}.course-warning{cursor:pointer;justify-content:center;align-items:center;display:flex;position:relative}.course-warning:after{content:attr(data-title);background-color:var(--text-primary);color:#fff;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;z-index:10;border-radius:4px;margin-bottom:6px;padding:.4rem .6rem;font-size:.75rem;font-weight:400;transition:opacity .2s,visibility .2s;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #00000026}.course-warning:before{content:"";border-style:solid;border-width:6px 6px 0;border-color:var(--text-primary) transparent transparent transparent;opacity:0;visibility:hidden;pointer-events:none;z-index:10;transition:opacity .2s,visibility .2s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.course-warning:hover:after,.course-warning:hover:before{opacity:1;visibility:visible}.unit-warning{cursor:pointer;justify-content:center;align-items:center;display:flex;position:relative}.unit-warning:after{content:attr(data-title);background-color:var(--danger);color:#fff;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;z-index:10;border-radius:4px;margin-bottom:6px;padding:.4rem .6rem;font-size:.75rem;font-weight:500;transition:opacity .2s,visibility .2s;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #00000026}.unit-warning:before{content:"";border-style:solid;border-width:6px 6px 0;border-color:var(--danger) transparent transparent transparent;opacity:0;visibility:hidden;pointer-events:none;z-index:10;transition:opacity .2s,visibility .2s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.unit-warning:hover:after,.unit-warning:hover:before{opacity:1;visibility:visible}.units-exceeded{color:var(--danger)!important;background-color:#fee2e2!important}.course-card-actions{align-items:center;gap:.25rem;display:flex}.expand-btn,.remove-course-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0 2px;display:flex}.expand-btn:hover{color:var(--text-primary)}.expand-btn svg{transition:transform .3s}.expand-btn.expanded svg{transform:rotate(180deg)}.remove-course-btn{font-size:1.2rem;line-height:1}.remove-course-btn:hover{color:var(--danger);background-color:#fee2e2}.course-card-expanded{border-top:1px solid var(--border-color);margin-top:.75rem;padding-top:.75rem}.course-card-title{color:var(--text-primary);margin-bottom:.5rem;font-size:.8rem;line-height:1.3}.course-card-offered{color:var(--ucla-blue);align-items:center;gap:.35rem;font-size:.75rem;display:flex}.offered-pills{flex-wrap:wrap;gap:.25rem;display:flex}.offered-pill{color:#fff;border-radius:4px;padding:.1rem .4rem;font-size:.7rem;font-weight:600}.offered-fall{background-color:#f97316}.offered-winter{background-color:#0ea5e9}.offered-spring{background-color:#22c55e}.offered-summer{background-color:#eab308}.course-card-units{color:var(--text-secondary);font-size:.75rem;font-weight:500}.sidebar-course-card{border-left-color:var(--ucla-blue)}.sidebar-course-card.dragging{box-shadow:0 6px 12px #0000001a}.quick-add-btn{color:var(--ucla-blue);text-align:center;cursor:pointer;background-color:#2774ae0d;border:1px dashed #0000;border-radius:6px;margin-top:.5rem;padding:.5rem;font-size:.8rem;font-weight:600;transition:all .2s}.quick-add-btn:hover{border-color:var(--ucla-blue);background-color:#2774ae1a}.quick-search-overlay{border:1px solid var(--border-color);z-index:100;background-color:#fff;border-radius:8px;padding:.5rem;animation:.2s slideDown;position:absolute;top:0;left:0;right:0;box-shadow:0 4px 20px #00000026}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.quick-search-input-wrapper{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;align-items:center;margin-bottom:.5rem;padding:.4rem .6rem;display:flex}.quick-search-icon{color:var(--text-secondary);margin-right:.4rem}.quick-search-input{width:100%;color:var(--text-primary);background:0 0;border:none;outline:none;font-size:.85rem}.quick-search-close{color:var(--text-secondary);cursor:pointer;margin-left:.4rem}.quick-search-close:hover{color:var(--error-color)}.quick-search-results{flex-direction:column;gap:.25rem;max-height:200px;display:flex;overflow-y:auto}.quick-search-item{cursor:pointer;border-radius:6px;padding:.5rem;font-size:.8rem;transition:background-color .2s}.quick-search-item:hover{background-color:#2774ae1a}.quick-search-item-title{color:var(--text-secondary);font-size:.75rem}.quick-search-item.empty{color:var(--text-secondary);text-align:center;pointer-events:none;font-style:italic}.login-container{background:0 0;justify-content:center;align-items:center;min-height:auto;padding:0;display:flex}.login-box{background:var(--surface);border-radius:12px;width:600px;max-width:900px;padding:2rem 3rem;box-shadow:0 10px 40px #00000026}.login-title{color:var(--ucla-blue);text-align:center;margin-bottom:.5rem;font-size:2rem;font-weight:700}.login-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-modal{position:relative}.close-modal-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;font-size:1.5rem;position:absolute;top:.5rem;right:.5rem}.header-btn.btn-login{background:var(--ucla-gold);color:var(--ucla-blue-dark)}.login-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:2rem;font-size:.95rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-primary);margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.form-group input{border:1px solid var(--border-color);border-radius:6px;outline:none;width:100%;padding:.75rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:var(--ucla-blue);box-shadow:0 0 0 2px #2774ae1a}.form-group input:disabled{background-color:var(--bg-color);cursor:not-allowed}.form-error{color:var(--danger);background-color:#fee2e2;border:1px solid #fecaca;border-radius:6px;margin-bottom:1rem;padding:.75rem;font-size:.85rem}.btn-primary{background-color:var(--ucla-blue);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;margin-bottom:1rem;padding:.75rem;font-size:.95rem;font-weight:600;transition:background-color .2s,transform .1s}.btn-primary:hover:not(:disabled){background-color:var(--ucla-blue-dark);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-toggle{text-align:center;border-top:1px solid var(--border-color);padding-top:1rem}.auth-toggle p{color:var(--text-secondary);font-size:.9rem}.btn-link{color:var(--ucla-blue);cursor:pointer;font-weight:600;font-size:inherit;background:0 0;border:none;padding:0;text-decoration:none;transition:color .2s}.btn-link:hover:not(:disabled){color:var(--ucla-blue-dark);text-decoration:underline}.btn-link:disabled{opacity:.6;cursor:not-allowed}.user-email{opacity:.9;margin-top:.25rem;font-size:.9rem}.user-email-right{color:#fff;align-self:center;margin-right:1.5rem;font-size:1rem;font-weight:400}.btn-logout{background-color:var(--danger);color:#fff;margin-left:.5rem}.btn-logout:hover{background-color:#dc2626}.mobile-tab-bar{display:none}.sidebar-wrapper{flex-direction:column;display:flex}.planner-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}@media (width<=768px){.app-header{padding:.6rem 1rem}.brand h1{font-size:1.1rem}.user-email-right{display:none}.header-btn{padding:.4rem .7rem;font-size:.8rem}.main-content{flex-direction:column;position:relative}.mobile-tab-bar{background:var(--surface);border-bottom:2px solid var(--border-color);z-index:5;flex-shrink:0;display:flex}.mobile-tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;flex:1;margin-bottom:-2px;padding:.7rem;font-size:.9rem;font-weight:600;transition:all .2s}.mobile-tab-btn.active{color:var(--ucla-blue);border-bottom-color:var(--ucla-blue);background:#f0f6ff}.sidebar-wrapper{flex-shrink:0;height:100%;width:100%!important}.planner-wrapper{width:100%;height:100%;overflow:hidden auto}.mobile-hidden{display:none!important}.mobile-visible{flex-direction:column;flex:1;width:100%;overflow:hidden;display:flex!important}.desktop-only{display:none!important}.planner-grid{gap:1rem;padding:1rem;overflow-x:hidden}.quarters-container{-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;flex-direction:row;gap:0;display:flex;overflow-x:auto}.quarter-column{scroll-snap-align:start;flex-shrink:0;min-width:240px;min-height:200px}.horizontal-resizer{display:none}.sidebar-top-section{max-height:45vh;height:auto!important}.sidebar-course-card{padding:.5rem .75rem}.year-label-container{padding:.5rem 1rem}.login-overlay{align-items:flex-end}.login-modal{border-radius:16px 16px 0 0;width:100%;max-height:90vh;overflow-y:auto}}
