:root{--ou-red:#c62828;--ou-red-strong:#b71c1c;--ou-ink:#17120e;--ou-ink-2:#3d2e26;--ou-muted:#7a6358;--ou-ghost:#b09a8e;--ou-cream:#fdfaf5;--ou-surface:#fff;--ou-surface-2:#faf7f3;--ou-border:#3723191a;--ou-border-strong:#3723192e}.ou-settings-page{background:var(--ou-cream);min-height:100vh;color:var(--ou-ink);padding:28px}.ou-settings-header{justify-content:space-between;align-items:flex-start;margin-bottom:18px;display:flex}.ou-settings-header-logout{border:1px solid var(--ou-border-strong);width:auto;min-width:34px;height:34px;color:var(--ou-muted);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:0 10px;font-size:.78rem;font-weight:600;transition:color .15s,background .15s,border-color .15s;display:flex}.ou-settings-header-logout:hover{color:var(--ou-red);background:#c628280f;border-color:#c6282840}.ou-settings-header-logout:disabled{opacity:.5;cursor:not-allowed}.ou-settings-page-title{margin:0;font-size:2rem;line-height:1.1}.ou-settings-page-subtitle{color:var(--ou-muted);margin-top:6px;font-size:.9rem}.ou-status-text{color:var(--ou-muted);font-size:.85rem}.ou-status-error{color:#991b1b}.ou-settings-shell{border:1px solid var(--ou-border);background:var(--ou-surface);border-radius:12px;grid-template-columns:240px minmax(0,1fr);min-height:calc(100vh - 160px);display:grid;overflow:hidden}.ou-settings-nav{border-right:1px solid var(--ou-border);background:var(--ou-surface);padding:18px 0}.ou-settings-nav-header{border-bottom:1px solid var(--ou-border);margin-bottom:10px;padding:0 18px 14px;font-size:.95rem;font-weight:700}.ou-settings-nav-item{width:100%;color:var(--ou-muted);text-align:left;cursor:pointer;background:0 0;border:0;border-left:2px solid #0000;align-items:center;gap:10px;padding:9px 18px;font-size:.83rem;display:flex}.ou-settings-nav-item:hover{background:var(--ou-surface-2);color:var(--ou-ink-2)}.ou-settings-nav-item.active{border-left-color:var(--ou-red);color:var(--ou-red);background:#c628280d;font-weight:600}.ou-settings-nav-icon{justify-content:center;align-items:center;display:inline-flex}.ou-settings-content{padding:22px 28px 40px;overflow-y:auto}.ou-toast-message{border:1px solid var(--ou-border);background:var(--ou-surface);color:var(--ou-ink-2);border-radius:10px;margin-bottom:14px;padding:10px 12px;font-size:.8rem}.ou-settings-section{display:none}.ou-settings-section.active{display:block}.ou-section-title{margin:0;font-size:1.35rem}.ou-section-subtitle{color:var(--ou-muted);margin:6px 0 18px;font-size:.85rem}.ou-sync-indicator{border:1px solid var(--ou-border);color:var(--ou-muted);background:var(--ou-surface-2);border-radius:999px;align-items:center;gap:6px;margin:-10px 0 14px;padding:4px 8px;font-size:.68rem;font-weight:600;display:inline-flex}.ou-sync-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.ou-sync-indicator.synced{color:#2e7d32;background:#2e7d3214;border-color:#2e7d3242}.ou-sync-indicator.saving{color:#8d6e05;background:#f9a82526;border-color:#8d6e0542}.ou-sync-indicator.error{color:#991b1b;background:#b71c1c1a;border-color:#991b1b47}.ou-card{border:1px solid var(--ou-border);background:var(--ou-surface);border-radius:10px;margin-bottom:14px;overflow:hidden}.ou-card-title{border-bottom:1px solid var(--ou-border);background:var(--ou-surface-2);justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;font-size:.84rem;font-weight:700;display:flex}.ou-inline-title{align-items:center;gap:6px;display:inline-flex}.ou-card-body{padding:4px 0}.ou-card-footer{padding:12px 16px 14px}.ou-row{border-bottom:1px solid var(--ou-border);justify-content:space-between;align-items:center;gap:14px;padding:12px 16px;display:flex}.ou-row:last-child{border-bottom:none}.ou-row-text{flex:1}.ou-row-label{color:var(--ou-ink-2);font-size:.82rem;font-weight:600}.ou-row-desc{color:var(--ou-ghost);margin-top:4px;font-size:.72rem}.ou-inline-row{flex-wrap:wrap;align-items:center;gap:8px;padding:12px 16px;display:flex}.ou-input,.ou-select,.ou-textarea{border:1.5px solid var(--ou-border-strong);background:var(--ou-surface-2);color:var(--ou-ink-2);border-radius:8px;padding:8px 10px;font-size:.78rem}.ou-input,.ou-select{min-width:220px}.ou-textarea{resize:vertical;width:calc(100% - 32px);min-height:280px;margin:10px 16px 14px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.ou-input:focus,.ou-select:focus,.ou-textarea:focus{border-color:var(--ou-red);outline:none}.ou-btn{cursor:pointer;border:1.5px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:.78rem;font-weight:600;text-decoration:none;display:inline-flex}.ou-btn:disabled{opacity:.55;cursor:not-allowed}.ou-btn-sm{padding:6px 10px;font-size:.72rem}.ou-btn-primary{background:var(--ou-red);color:#fff}.ou-btn-primary:hover{background:var(--ou-red-strong)}.ou-btn-outline{border-color:var(--ou-border-strong);background:var(--ou-surface);color:var(--ou-ink-2)}.ou-btn-outline:hover{color:var(--ou-red);border-color:#c6282859}.ou-btn-danger{color:#991b1b;background:#b71c1c14;border-color:#b71c1c47}.ou-btn-success{color:#2e7d32;background:#2e7d321a;border-color:#2e7d3247}.ou-toggle{flex-shrink:0;width:38px;height:20px;position:relative}.ou-toggle input{opacity:0;width:0;height:0}.ou-toggle-track{background:#d9cec7;border-radius:999px;transition:background .2s;position:absolute;top:0;bottom:0;left:0;right:0}.ou-toggle-thumb{background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 2px #0003}.ou-toggle input:checked+.ou-toggle-track{background:var(--ou-red)}.ou-toggle input:checked+.ou-toggle-track+.ou-toggle-thumb{transform:translate(18px)}.ou-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:14px;display:grid}.ou-kpi-card{border:1px solid var(--ou-border);background:var(--ou-surface);border-radius:10px;padding:10px}.ou-kpi-label{color:var(--ou-ghost);font-size:.7rem}.ou-kpi-value{margin-top:4px;font-size:1.1rem;font-weight:700}.ou-empty-text{color:var(--ou-muted);padding:12px 16px;font-size:.78rem}.ou-program-list{gap:8px;padding:10px;display:grid}.ou-program-row{border:1px solid var(--ou-border);background:var(--ou-surface-2);border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:10px;display:flex}.ou-program-name{color:var(--ou-ink-2);margin:0;font-size:.8rem}.ou-program-meta{color:var(--ou-ghost);margin:2px 0 0;font-size:.7rem}.ou-program-actions{align-items:center;gap:6px;display:inline-flex}.ou-pill{border:1px solid var(--ou-border-strong);background:var(--ou-surface);color:var(--ou-ink-2);border-radius:999px;align-items:center;gap:4px;padding:4px 8px;font-size:.68rem;font-weight:700;display:inline-flex}.ou-pill.ok{color:#2e7d32;background:#2e7d3214;border-color:#2e7d3247}.ou-btn-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:12px 16px;display:grid}.ou-danger-card{background:#b71c1c0a;border:1px solid #b71c1c33;border-radius:10px;padding:14px 16px}.ou-danger-title{color:#991b1b;font-size:.82rem;font-weight:700}.ou-danger-desc{color:var(--ou-muted);margin:8px 0 12px;font-size:.74rem}.ou-app-row{border-bottom:1px solid var(--ou-border);justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.ou-app-row:last-child{border-bottom:none}.ou-app-title{margin:0;font-size:.8rem;font-weight:600}@media (max-width:1080px){.ou-settings-page{padding:14px}.ou-settings-shell{grid-template-columns:1fr}.ou-settings-nav{border-right:none;border-bottom:1px solid var(--ou-border);grid-template-columns:repeat(3,minmax(0,1fr));gap:2px;padding:10px;display:grid}.ou-settings-nav-header{grid-column:1/-1;margin:0 0 6px}.ou-settings-nav-item{border-left:none;border-radius:8px}.ou-settings-nav-item.active{border-left:none}.ou-settings-content{padding:16px}.ou-kpi-grid,.ou-btn-grid{grid-template-columns:1fr}.ou-row,.ou-inline-row,.ou-app-row{flex-direction:column;align-items:flex-start}.ou-input,.ou-select{width:100%;min-width:0}.ou-btn{width:100%}}@media (max-width:640px){.ou-settings-shell{min-height:0}.ou-settings-nav{grid-template-columns:repeat(2,minmax(0,1fr))}}.cal-panel{flex-direction:column;gap:10px;display:flex}.cal-loading{color:var(--ou-muted);align-items:center;gap:8px;padding:16px 0;font-size:.8rem;display:flex}.cal-spin{animation:.8s linear infinite ou-spin}@keyframes ou-spin{to{transform:rotate(360deg)}}.cal-empty{color:var(--ou-ghost);text-align:center;flex-direction:column;align-items:center;gap:6px;padding:32px 20px;font-size:.82rem;display:flex}.cal-empty-sub{color:var(--ou-ghost);font-size:.72rem;line-height:1.5}.cal-error-text{color:#991b1b;padding:10px 0;font-size:.78rem}.cal-schedule-select-row{align-items:center;gap:10px;margin-bottom:4px;display:flex}.cal-select-label{color:var(--ou-ink-2,#3d2e26);white-space:nowrap;font-size:.78rem;font-weight:500}.cal-select-wrap{flex:1;position:relative}.cal-select-chevron{pointer-events:none;color:var(--ou-ghost);position:absolute;top:50%;right:10px;transform:translateY(-50%)}.cal-service-card{border:1px solid var(--ou-border);background:var(--ou-surface);border-radius:10px;transition:border-color .2s;overflow:hidden}.cal-service-card.open{border-color:var(--ou-border-strong)}.cal-service-card.done{border-color:#2e7d324d}.cal-service-header{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:13px 16px;transition:background .15s;display:flex}.cal-service-header:hover{background:var(--ou-surface-2)}.cal-service-icon-wrap{border:1px solid var(--ou-border);background:var(--ou-surface-2);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.cal-service-header-text{flex:1;align-items:center;gap:8px;display:flex}.cal-service-name{color:var(--ou-ink-2,#3d2e26);font-size:.83rem;font-weight:500}.cal-service-status-badge{border-radius:100px;align-items:center;gap:4px;padding:2px 7px;font-size:.65rem;font-weight:600;display:inline-flex}.cal-service-status-badge.ok{color:#2e7d32;background:#2e7d3214;border:1px solid #2e7d3238}.cal-service-status-badge.err{color:var(--ou-red,#c62828);background:#c628280f;border:1px solid #c6282833}.cal-chevron{color:var(--ou-ghost);flex-shrink:0;transition:transform .2s}.cal-chevron.up{transform:rotate(180deg)}.cal-service-body{border-top:1px solid var(--ou-border);background:var(--ou-surface-2);padding:0}.cal-service-desc{color:var(--ou-muted);padding:12px 16px 8px;font-size:.76rem;line-height:1.5}.cal-course-list{border-top:1px solid var(--ou-border);border-bottom:1px solid var(--ou-border)}.cal-course-row{border-bottom:1px solid var(--ou-border);align-items:center;gap:10px;padding:10px 16px;transition:background .12s;display:flex}.cal-course-row:last-child{border-bottom:none}.cal-course-row:hover{background:#37231908}.cal-check{border:1.5px solid var(--ou-border-strong);background:var(--ou-surface);cursor:pointer;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:17px;height:17px;transition:all .15s;display:flex}.cal-check.checked{background:var(--ou-red,#c62828);border-color:var(--ou-red,#c62828)}.cal-check.synced{background:#2e7d32;border-color:#2e7d32}.cal-course-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.cal-course-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.cal-course-code{color:var(--ou-ink-2,#3d2e26);font-size:.78rem;font-weight:600}.cal-course-name{color:var(--ou-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;font-weight:300;overflow:hidden}.cal-course-time{color:var(--ou-ghost);font-size:.67rem;font-weight:300}.cal-action-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:11px 16px;display:flex}.cal-action-info{color:var(--ou-ghost);font-size:.72rem}.cal-sync-btn{background:var(--ou-red,#c62828);color:#fff;cursor:pointer;border:none;border-radius:7px;flex-shrink:0;align-items:center;gap:6px;padding:8px 18px;font-family:inherit;font-size:.78rem;font-weight:500;transition:all .18s;display:flex;box-shadow:0 2px 8px #c6282833}.cal-sync-btn:hover:not(:disabled){background:var(--ou-red-strong,#b71c1c);transform:translateY(-1px)}.cal-sync-btn:disabled{opacity:.55;cursor:default;transform:none}.cal-success-row{align-items:center;gap:10px;display:flex}.cal-success-text{color:#2e7d32;font-size:.75rem;font-weight:500}.cal-error-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.cal-error-text-sm{color:#991b1b;font-size:.72rem}.cal-retry-btn{color:var(--ou-muted);border:1px solid var(--ou-border-strong);cursor:pointer;white-space:nowrap;background:0 0;border-radius:5px;align-items:center;gap:4px;padding:3px 8px;font-family:inherit;font-size:.7rem;transition:all .15s;display:flex}.cal-retry-btn:hover{color:var(--ou-ink-2,#3d2e26)}.cal-ics-fallback{color:var(--ou-ghost);border-top:1px solid var(--ou-border);flex-wrap:wrap;align-items:center;gap:3px;padding:9px 16px;font-size:.7rem;display:flex}.cal-ics-link{color:var(--ou-red,#c62828);cursor:pointer;background:0 0;border:none;align-items:center;gap:3px;padding:0;font-family:inherit;font-size:.7rem;font-weight:500;transition:opacity .15s;display:inline-flex}.cal-ics-link:hover{opacity:.75}
