html{scroll-behavior:smooth}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background-color .3s ease,color .3s ease}:root{--champlain-navy:#003c5f;--champlain-dark-blue:#002a3a;--champlain-blue:#236192;--champlain-bright-blue:#00a9e0;--champlain-green:#74aa50;--champlain-teal:#3dc4b2;--champlain-red:#be3a34;--champlain-dark-green:#28724f;--champlain-gold:#fdc55e;--champlain-light-blue:#7ed3ef;--champlain-lightest-blue:#bee9f7;--champlain-dark:#1a1a1a;--champlain-gray:#666;--champlain-light-gray:#f5f5f5;--champlain-white:#fff;--shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 12px rgba(0,0,0,.1);--shadow-lg:0 10px 30px rgba(0,0,0,.12);--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-tertiary:#f8f9fa;--text-primary:#2c3e50;--text-secondary:#666;--text-tertiary:#999;--border-color:#ddd;--border-color-light:#e0e0e0;--card-bg:#fff;--sidebar-bg:#fff;--input-bg:#fff;--input-border:#ddd;--modal-overlay:rgba(0,0,0,.5);--transition-fast:0.15s ease;--transition-normal:0.3s ease;--z-below:-1;--z-base:1;--z-raised:10;--z-header:100;--z-nav:1000;--z-modal:2000;--z-toast:9000;--z-max:10000}.hidden{display:none!important}:focus-visible{outline:2px solid var(--champlain-bright-blue);outline-offset:2px}:focus:not(:focus-visible){outline:none}.cta-button:focus-visible,.dashboard-card:focus-visible,.interest-btn:focus-visible,.login-btn:focus-visible,.quick-action-pill:focus-visible,.role-btn:focus-visible{outline-offset:3px;box-shadow:0 0 0 4px rgba(0,169,224,.2)}.header{background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-dark-blue) 100%);color:#fff;padding:12px 30px;display:flex;justify-content:space-between;align-items:center;gap:20px;box-shadow:0 4px 20px rgba(0,42,58,.3);border-bottom:none;position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-header)}.header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal),var(--champlain-green))}.logo-section{display:flex;align-items:center;gap:20px;flex-shrink:0}.logo-text{font-size:24px;font-weight:800;letter-spacing:-.5px;border-left:3px solid hsla(0,0%,100%,.3);padding-left:20px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.user-info{display:flex;align-items:center;gap:15px;flex-shrink:0}.user-badge{background:linear-gradient(135deg,var(--champlain-bright-blue),var(--champlain-teal));padding:8px 18px;border-radius:25px;font-size:13px;border:none;box-shadow:0 2px 10px rgba(0,169,224,.3)}.logout-btn,.user-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-weight:700}.logout-btn{background:transparent;border:2px solid hsla(0,0%,100%,.5);padding:10px 24px;border-radius:25px;cursor:pointer;font-size:14px;transition:all var(--transition-normal)}.logout-btn:hover{background:#fff;color:var(--champlain-navy);transform:translateY(-2px);box-shadow:0 6px 20px hsla(0,0%,100%,.3);border-color:#fff}.main-container{display:flex;min-height:calc(100vh - 73px);background:linear-gradient(135deg,#e8f4fc,#f5f7fa 50%,#f0f4f8);overflow:hidden}.sidebar{width:420px;background:linear-gradient(180deg,#fff,#f8fafc);border-right:none;padding:30px;overflow-y:auto;box-shadow:4px 0 20px rgba(0,60,95,.08);flex-shrink:0;max-height:calc(100vh - 73px);transition:background-color var(--transition-normal),border-color var(--transition-normal)}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:rgba(0,60,95,.15);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:rgba(0,60,95,.3)}.sidebar{scrollbar-width:thin;scrollbar-color:rgba(0,60,95,.15) transparent}.sidebar h2{color:var(--champlain-navy);font-size:26px;margin-bottom:25px;padding-bottom:15px;border-bottom:none;font-weight:800;background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.sidebar h2:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:4px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));border-radius:2px}.section{background:#fff;border:none;border-radius:16px;padding:24px;margin-bottom:25px;transition:all var(--transition-normal);box-shadow:0 4px 15px rgba(0,60,95,.06);position:relative;overflow:hidden}.section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));opacity:0;transition:opacity var(--transition-normal)}.section:hover{box-shadow:0 8px 30px rgba(0,60,95,.1);transform:translateY(-2px)}.section:hover:before{opacity:1}.section h3{color:var(--champlain-navy);font-size:16px;margin-bottom:18px;font-weight:700;display:flex;align-items:center;gap:8px}.section h3:before{content:"";width:4px;height:20px;background:var(--champlain-bright-blue);border-radius:2px}.btn{width:100%;padding:14px 20px;background:linear-gradient(135deg,#f8fafc,#f0f4f8);border:none;color:var(--champlain-navy);border-radius:12px;cursor:pointer;margin:10px 0;font-size:15px;font-weight:700;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px rgba(0,60,95,.08);position:relative;overflow:hidden}.btn:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--champlain-bright-blue),var(--champlain-teal));opacity:0;transition:opacity var(--transition-normal)}.btn:hover{background:linear-gradient(135deg,var(--champlain-bright-blue) 0,var(--champlain-blue) 100%);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,169,224,.25)}.btn:hover:before{opacity:0}.badge{background:var(--champlain-red);color:#fff;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.sidebar-search-input{width:100%;padding:10px;border:2px solid var(--border-color);border-radius:4px;font-size:14px;transition:border-color var(--transition-fast)}.sidebar-search-input:focus{border-color:var(--champlain-bright-blue);outline:none;box-shadow:0 0 0 3px rgba(0,169,224,.1)}.sidebar-search-wrap{margin-bottom:15px}.sidebar-filter-row{margin-bottom:10px;display:flex;gap:8px}.sidebar-filter-btn{flex:1 1;padding:8px 12px;background:var(--champlain-bright-blue);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:600;transition:opacity var(--transition-fast),transform var(--transition-fast)}.sidebar-filter-btn:hover{opacity:.9;transform:translateY(-1px)}.sidebar-filter-btn--secondary{flex:none;background:#6c757d}.sidebar-filter-summary{margin-bottom:10px;padding:8px;background:var(--bg-tertiary);border-radius:4px;font-size:12px}.sidebar-filter-summary__count{font-weight:600;color:var(--champlain-navy)}.sidebar-filter-summary__detail{color:var(--text-secondary);margin-top:4px}.sidebar-filter-panel{display:none;margin-bottom:15px;padding:15px;background:var(--bg-tertiary);border-radius:6px;border:1px solid var(--border-color)}.sidebar-filter-panel h4{margin:0 0 12px;color:var(--champlain-navy);font-size:14px}.sidebar-filter-group{margin-bottom:12px}.sidebar-filter-group__label{font-weight:600;font-size:12px;color:#333;display:block;margin-bottom:6px}.sidebar-filter-group__options{display:flex;flex-wrap:wrap;gap:6px}.sidebar-filter-group__options--column{flex-direction:column;gap:4px;max-height:150px;overflow-y:auto}.sidebar-filter-presets{margin-top:15px;padding-top:12px;border-top:1px solid var(--border-color)}.sidebar-preset-btn{width:100%;padding:8px;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;margin-bottom:6px;transition:opacity var(--transition-fast)}.sidebar-preset-btn:hover{opacity:.9}.sidebar-preset-btn--save{background:var(--champlain-green)}.sidebar-preset-btn--load{background:var(--champlain-blue)}.sidebar-course-list{max-height:200px;overflow-y:auto}.sidebar-course-list::-webkit-scrollbar{width:4px}.sidebar-course-list::-webkit-scrollbar-thumb{background:rgba(0,60,95,.15);border-radius:2px}.sidebar-selected-section{margin-top:20px}.sidebar-selected-section h4{color:var(--champlain-navy);font-size:14px;margin-bottom:10px}.sidebar-similar-courses{display:none;margin-top:15px;background:#fff;border-radius:6px;border:1px solid #e0e0e0}.sidebar-similar-courses .collapsible-toggle{background:#fff;border-color:#e0e0e0;color:var(--champlain-navy)}.sidebar-similar-courses__list{padding:0 12px 12px}.sidebar-compare-section{margin-top:15px}.sidebar-compare-hint{font-size:11px;color:var(--text-secondary);margin-top:6px;text-align:center}.stats-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.stat-card{background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-blue) 100%);padding:24px;border-radius:12px;text-align:center;color:#fff;box-shadow:var(--shadow-md);transition:all var(--transition-normal);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,hsla(0,0%,100%,.1) 0,transparent 70%);border-radius:50%}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-value{font-size:42px;font-weight:800;margin-bottom:6px;text-shadow:0 2px 8px rgba(0,0,0,.2);position:relative}.stat-label{font-size:12px;opacity:.95;font-weight:600;letter-spacing:.5px;text-transform:uppercase;position:relative}.landing-page{min-height:100vh;background:linear-gradient(135deg,#e8f4fc,#f5f7fa 50%,#f0f4f8);overflow-x:hidden}.landing-nav{position:fixed;top:0;left:0;right:0;background:rgba(0,60,95,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:var(--z-nav);border-bottom:3px solid var(--champlain-bright-blue)}.landing-nav-content{max-width:1400px;margin:0 auto;padding:15px 40px;display:flex;justify-content:space-between;align-items:center}.landing-logo{display:flex;align-items:center;gap:15px;color:#fff;font-size:20px;font-weight:700}.landing-logo img{height:45px}.landing-nav-links{display:flex;gap:30px}.landing-nav-links a{color:hsla(0,0%,100%,.9);text-decoration:none;font-weight:600;font-size:15px;transition:color var(--transition-normal)}.landing-nav-links a:hover{color:var(--champlain-bright-blue)}.landing-hero{background:linear-gradient(135deg,#002a3a,#003c5f 50%,#236192);padding:140px 40px 60px;position:relative;min-height:calc(100vh - 54px);display:flex;align-items:center}.landing-hero:before{top:0;left:0;right:0;bottom:0;background-image:linear-gradient(hsla(0,0%,100%,.03) 1px,transparent 0),linear-gradient(90deg,hsla(0,0%,100%,.03) 1px,transparent 0);background-size:60px 60px}.landing-hero:after,.landing-hero:before{content:"";position:absolute;pointer-events:none}.landing-hero:after{width:800px;height:800px;background:radial-gradient(circle,rgba(0,169,224,.08) 0,transparent 60%);top:-200px;right:-200px;border-radius:50%}.hero-content{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 480px;grid-gap:60px;gap:60px;align-items:center;position:relative;z-index:var(--z-raised)}.hero-text{color:#fff}.hero-text h1{font-size:52px;font-weight:800;margin-bottom:20px;line-height:1.1;letter-spacing:-1px}.hero-subtitle{font-size:22px;color:var(--champlain-bright-blue);margin-bottom:20px;font-weight:600}.hero-description{font-size:18px;line-height:1.7;color:hsla(0,0%,100%,.85);margin-bottom:40px;max-width:540px}.hero-stats{display:flex;gap:0;margin-left:0}.hero-stat{text-align:left;padding:0 32px 0 0;position:relative}.hero-stat+.hero-stat{padding-left:32px}.hero-stat+.hero-stat:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:1px;background:hsla(0,0%,100%,.2)}.hero-stat .stat-number{display:block;font-size:42px;font-weight:800;color:var(--champlain-bright-blue);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;min-width:3ch;line-height:1.1}.hero-stat .stat-text{font-size:14px;color:hsla(0,0%,100%,.8);text-transform:uppercase;letter-spacing:1px}.hero-wave{position:absolute;bottom:0;left:0;right:0;line-height:0}.hero-wave svg{width:100%;height:120px}.hero-login .login-card{background:#fff;padding:40px;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3)}.hero-login .login-card h2{color:var(--champlain-navy);font-size:28px;font-weight:700;margin-bottom:8px;text-align:center}.role-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:25px}.role-btn{display:flex;align-items:center;gap:15px;padding:16px 20px;border:2px solid #e0e0e0;border-radius:12px;background:#fff;cursor:pointer;transition:all var(--transition-normal);text-align:left}.role-btn:hover{transform:translateX(5px);box-shadow:0 4px 15px rgba(0,0,0,.1)}.role-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0;color:var(--champlain-navy)}.role-icon svg{display:block}.role-info{flex:1 1}.role-name{display:block;font-size:16px;font-weight:700;color:var(--champlain-navy);margin-bottom:2px}.role-desc{font-size:13px;color:var(--champlain-gray)}.role-student{border-color:var(--champlain-lightest-blue)}.role-student:hover{border-color:var(--champlain-bright-blue);background:linear-gradient(135deg,var(--champlain-lightest-blue) 0,#f0faff 100%)}.role-student .role-icon{background:linear-gradient(135deg,var(--champlain-lightest-blue) 0,var(--champlain-light-blue) 100%)}.role-faculty{border-color:#d9f5f2}.role-faculty:hover{border-color:var(--champlain-teal)}.role-faculty .role-icon,.role-faculty:hover{background:linear-gradient(135deg,#d9f5f2,#b0e8e2)}.role-admin{border-color:#fef3d8}.role-admin:hover{border-color:var(--champlain-gold)}.role-admin .role-icon,.role-admin:hover{background:linear-gradient(135deg,#fef3d8,#fde9a8)}.login-demo-note{text-align:center;margin-top:18px;font-size:12px;color:#aaa;letter-spacing:.2px}.landing-about{padding:100px 40px;background:linear-gradient(135deg,#e8f4fc,#f5f7fa 50%,#f0f4f8)}.about-content{max-width:1200px;margin:0 auto}.about-header{text-align:center;margin-bottom:60px}.about-header h2{font-size:42px;font-weight:800;color:var(--champlain-navy);margin-bottom:20px}.about-header h2:after{content:"";display:block;width:60px;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));margin:16px auto 0;border-radius:2px}.about-header p{font-size:18px;color:var(--champlain-gray);max-width:700px;margin:0 auto;line-height:1.7}.about-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:30px;gap:30px}.feature-card{background:#fff;padding:35px;border-radius:16px;box-shadow:0 4px 20px rgba(0,0,0,.08);transition:all var(--transition-normal);border:1px solid #e8eaf0}.feature-card:hover{transform:translateY(-8px);box-shadow:0 12px 40px rgba(0,0,0,.12)}.feature-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--champlain-lightest-blue) 0,var(--champlain-light-blue) 100%);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.feature-card h3{font-size:20px;font-weight:700;color:var(--champlain-navy);margin-bottom:12px}.feature-card p{font-size:15px;color:var(--champlain-gray);line-height:1.7}.landing-competencies{padding:100px 40px;background:linear-gradient(180deg,#f5f7fa,#fff)}.competencies-content{max-width:1200px;margin:0 auto}.competencies-header{text-align:center;margin-bottom:60px}.competencies-header h2{font-size:42px;font-weight:800;color:var(--champlain-navy);margin-bottom:20px}.competencies-header h2:after{content:"";display:block;width:60px;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));margin:16px auto 0;border-radius:2px}.competencies-header p{font-size:18px;color:var(--champlain-gray);max-width:700px;margin:0 auto;line-height:1.7}.competencies-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:25px;gap:25px;margin-bottom:60px}.competency-card{background:#fff;padding:30px;border-radius:16px;box-shadow:0 4px 15px rgba(0,0,0,.06);transition:all var(--transition-normal);border:1px solid #e8eaf0;position:relative;overflow:hidden}.competency-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--accent-color,var(--champlain-bright-blue))}.competency-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,.1)}.competency-number{font-size:48px;font-weight:800;color:var(--accent-color,var(--champlain-bright-blue));opacity:.15;position:absolute;top:15px;right:20px;line-height:1}.competency-card h3{font-size:18px;font-weight:700;color:var(--champlain-navy);margin-bottom:12px;position:relative}.competency-card p{font-size:14px;color:var(--champlain-gray);line-height:1.6;position:relative}.competency-icon{width:60px;height:60px;margin-bottom:15px;object-fit:contain}.competency-weights{background:#fff;padding:40px;border-radius:16px;box-shadow:0 4px 20px rgba(0,0,0,.08);border:1px solid #e8eaf0}.competency-weights h3{font-size:22px;font-weight:700;color:var(--champlain-navy);margin-bottom:25px;text-align:center}.weight-legend{display:flex;gap:40px;justify-content:center;flex-wrap:wrap}.weight-item{display:flex;align-items:flex-start;gap:15px;max-width:300px}.weight-badge{width:45px;height:45px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:#fff;flex-shrink:0}.weight-1{background:linear-gradient(135deg,var(--champlain-light-blue) 0,var(--champlain-bright-blue) 100%)}.weight-2{background:linear-gradient(135deg,var(--champlain-gold) 0,#e8b040 100%)}.weight-3{background:linear-gradient(135deg,var(--champlain-green) 0,var(--champlain-dark-green) 100%)}.weight-info strong{display:block;font-size:16px;color:var(--champlain-navy);margin-bottom:4px}.weight-info p{font-size:14px;color:var(--champlain-gray);line-height:1.5;margin:0}.landing-visualizations{padding:100px 40px;background:linear-gradient(180deg,#fff,#e8f4fc)}.visualizations-content{max-width:1200px;margin:0 auto}.visualizations-header{text-align:center;margin-bottom:60px}.visualizations-header h2{font-size:42px;font-weight:800;color:var(--champlain-navy);margin-bottom:20px}.visualizations-header h2:after{content:"";display:block;width:60px;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));margin:16px auto 0;border-radius:2px}.visualizations-header p{font-size:18px;color:var(--champlain-gray);max-width:700px;margin:0 auto;line-height:1.7}.visualizations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));grid-gap:30px;gap:30px;margin-bottom:60px}.viz-feature-card{background:#fff;padding:35px;border-radius:14px;box-shadow:0 2px 12px rgba(0,60,95,.06);transition:transform .3s ease,box-shadow .3s ease;border:1px solid rgba(0,60,95,.06);position:relative;overflow:hidden;will-change:transform}.viz-feature-card:after{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));border-radius:20px 20px 0 0}.viz-feature-card:hover{transform:translateY(-8px);box-shadow:0 16px 50px rgba(0,60,95,.15)}.viz-feature-icon{width:70px;height:70px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:32px}.viz-feature-icon svg{display:block}.viz-feature-card h3{font-size:22px;font-weight:700;color:var(--champlain-navy);margin-bottom:12px}.viz-feature-card p{font-size:15px;color:var(--champlain-gray);line-height:1.7;margin-bottom:20px}.viz-feature-benefits{display:flex;gap:10px;flex-wrap:wrap}.viz-feature-benefits span{background:linear-gradient(135deg,var(--champlain-lightest-blue) 0,var(--champlain-light-blue) 100%);color:var(--champlain-navy);padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600}.visualizations-cta{text-align:center;padding:50px;background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-dark-blue) 100%);border-radius:20px;color:#fff}.visualizations-cta p{font-size:24px;font-weight:600;margin-bottom:25px}.cta-button{display:inline-block;padding:16px 40px;background:linear-gradient(135deg,var(--champlain-bright-blue) 0,var(--champlain-teal) 100%);color:#fff;text-decoration:none;border-radius:30px;font-size:18px;font-weight:700;transition:all var(--transition-normal);box-shadow:0 4px 15px rgba(0,169,224,.4)}.cta-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(0,169,224,.5)}.landing-preview{padding:100px 40px;background:linear-gradient(180deg,#e8f4fc,#f5f7fa)}.preview-content{max-width:1100px;margin:0 auto}.preview-header{text-align:center;margin-bottom:50px}.preview-header h2{font-size:42px;font-weight:800;color:var(--champlain-navy);margin-bottom:20px}.preview-header h2:after{content:"";display:block;width:60px;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));margin:16px auto 0;border-radius:2px}.preview-header p{font-size:18px;color:var(--champlain-gray);max-width:600px;margin:0 auto;line-height:1.7}.preview-showcase{display:flex;flex-direction:column;gap:24px}.preview-window{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,60,95,.15);overflow:hidden;border:1px solid rgba(0,60,95,.1)}.preview-toolbar{display:flex;align-items:center;gap:8px;padding:14px 20px;background:linear-gradient(135deg,#f0f2f5,#e8eaed);border-bottom:1px solid #dde0e4}.preview-dot{width:12px;height:12px;border-radius:50%}.preview-toolbar-title{margin-left:12px;font-size:13px;font-weight:600;color:var(--champlain-gray)}.preview-body{padding:0;min-height:340px;display:flex;align-items:center;justify-content:center;background:#fafbfc}.preview-graph{width:100%;height:340px}.preview-graph svg{width:100%;height:100%}.preview-caption{display:flex;gap:30px;justify-content:center;flex-wrap:wrap}.preview-caption-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--champlain-gray);font-weight:500}.landing-how-it-works{padding:100px 40px;background:linear-gradient(135deg,#e8f4fc,#f5f7fa 50%,#f0f4f8)}.how-it-works-content{max-width:1100px;margin:0 auto}.how-it-works-header{text-align:center;margin-bottom:60px}.how-it-works-header h2{font-size:42px;font-weight:800;color:var(--champlain-navy);margin-bottom:16px}.how-it-works-header h2:after{content:"";display:block;width:60px;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));margin:16px auto 0;border-radius:2px}.how-it-works-header p{font-size:18px;color:var(--champlain-gray);line-height:1.7}.how-it-works-steps{display:flex;align-items:flex-start;justify-content:center;gap:0}.step-card{background:#fff;border-radius:14px;padding:40px 30px;text-align:center;flex:1 1;max-width:300px;box-shadow:0 2px 12px rgba(0,60,95,.06);border:1px solid rgba(0,60,95,.06);border-top:3px solid var(--champlain-bright-blue);position:relative;transition:all var(--transition-normal)}.step-card:nth-of-type(3){border-top-color:var(--champlain-teal)}.step-card:nth-of-type(5){border-top-color:var(--champlain-green)}.step-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,60,95,.1)}.step-number{position:absolute;top:-16px;left:50%;transform:translateX(-50%);width:36px;height:36px;background:linear-gradient(135deg,var(--champlain-bright-blue),var(--champlain-teal));color:#fff;border-radius:50%;font-size:16px;font-weight:800;box-shadow:0 4px 12px rgba(0,169,224,.4)}.step-icon,.step-number{display:flex;align-items:center;justify-content:center}.step-icon{width:64px;height:64px;border-radius:16px;margin:10px auto 20px}.step-card h3{font-size:20px;font-weight:700;color:var(--champlain-navy);margin-bottom:12px}.step-card p{font-size:14px;color:var(--champlain-gray);line-height:1.7}.step-connector{display:flex;align-items:center;padding-top:60px;flex-shrink:0;margin:0 8px}.step-connector svg{opacity:.4}.landing-competency-strip{padding:80px 40px;background:linear-gradient(180deg,#f5f7fa,#e8f4fc)}.competency-strip-content{max-width:1200px;margin:0 auto}.competency-strip-header{text-align:center;margin-bottom:40px}.competency-strip-header h2{font-size:36px;font-weight:800;color:var(--champlain-navy);margin-bottom:12px}.competency-strip-header p{font-size:17px;color:var(--champlain-gray);line-height:1.6}.competency-strip-scroll{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.competency-strip-item{display:flex;flex-direction:column;align-items:center;gap:10px;width:90px;text-align:center;transition:transform .3s ease}.competency-strip-item:hover{transform:translateY(-6px)}.competency-strip-item img{width:56px;height:56px;object-fit:contain;padding:8px;background:#fff;border-radius:14px;box-shadow:0 3px 12px rgba(0,0,0,.08);border:2px solid var(--accent,#e8eaf0);transition:border-color .3s ease,box-shadow .3s ease}.competency-strip-item:hover img{box-shadow:0 6px 20px rgba(0,0,0,.12)}.competency-strip-item span{font-size:11px;font-weight:700;color:var(--champlain-navy);line-height:1.3}@media (max-width:768px){.landing-competency-strip,.landing-how-it-works,.landing-preview{padding:60px 20px}.how-it-works-header h2,.preview-header h2{font-size:32px}.competency-strip-header h2{font-size:28px}.how-it-works-steps{flex-direction:column;align-items:center;gap:20px}.step-connector{transform:rotate(90deg);padding-top:0;margin:0}.step-card{max-width:100%}.preview-caption{flex-direction:column;align-items:center;gap:12px}.competency-strip-scroll{gap:14px}.competency-strip-item{width:75px}.competency-strip-item img{width:48px;height:48px}}.landing-discovery{padding:100px 40px;background:linear-gradient(180deg,#f0f4f8,#fff)}.discovery-content{max-width:1200px;margin:0 auto}.discovery-header{text-align:center;margin-bottom:50px}.discovery-header h2{font-size:42px;font-weight:800;color:var(--champlain-navy);margin-bottom:20px}.discovery-header h2:after{content:"";display:block;width:60px;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));margin:16px auto 0;border-radius:2px}.discovery-header p{font-size:18px;color:var(--champlain-gray);max-width:700px;margin:0 auto;line-height:1.7}.interest-categories{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:40px}.interest-btn{display:flex;align-items:center;gap:10px;padding:14px 24px;background:#fff;border:2px solid #e0e5eb;border-radius:50px;cursor:pointer;font-size:14px;font-weight:600;color:var(--champlain-navy);transition:all var(--transition-normal);box-shadow:0 2px 8px rgba(0,0,0,.04)}.interest-btn:hover{border-color:var(--champlain-bright-blue);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,169,224,.15)}.interest-btn.active{background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-blue) 100%);border-color:var(--champlain-navy);color:#fff;box-shadow:0 4px 20px rgba(0,60,95,.3)}.interest-btn svg{flex-shrink:0}.interest-btn .count{background:rgba(0,169,224,.15);color:var(--champlain-bright-blue);padding:2px 8px;border-radius:12px;font-size:12px;font-weight:700}.interest-btn.active .count{background:hsla(0,0%,100%,.2);color:#fff}.skill-packs-container{background:#fff;border-radius:20px;padding:30px;box-shadow:0 8px 40px rgba(0,0,0,.08);border:1px solid #e8eaf0}.skill-packs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;flex-wrap:wrap;gap:15px}.skill-packs-header h3{font-size:22px;font-weight:700;color:var(--champlain-navy);margin:0}.skill-packs-filters{display:flex;gap:8px}.filter-chip{padding:8px 16px;background:#f5f7fa;border:1px solid #e0e5eb;border-radius:20px;cursor:pointer;font-size:13px;font-weight:600;color:var(--champlain-gray);transition:all var(--transition-fast)}.filter-chip:hover{background:#e8eef4;color:var(--champlain-navy)}.filter-chip.active{background:var(--champlain-bright-blue);border-color:var(--champlain-bright-blue);color:#fff}.skill-packs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:20px;gap:20px;min-height:200px}.skill-packs-empty{grid-column:1/-1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--champlain-gray);text-align:center}.skill-packs-empty svg{margin-bottom:20px;opacity:.5}.skill-packs-empty p{font-size:16px;max-width:300px}.skill-pack-card{background:#f8fafc;border:1px solid #e8eaf0;border-radius:16px;padding:24px;transition:all var(--transition-normal);display:flex;flex-direction:column}.skill-pack-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.1);border-color:var(--champlain-bright-blue)}.skill-pack-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;width:-moz-fit-content;width:fit-content}.skill-pack-badge.open{background:#e8f5e9;color:#2e7d32}.skill-pack-badge.open-prereq{background:#e0f2f1;color:#00695c}.skill-pack-badge.required{background:#fff3e0;color:#e65100}.skill-pack-badge.choice{background:#e3f2fd;color:#1565c0}.skill-pack-title{font-size:18px;font-weight:700;color:var(--champlain-navy);margin-bottom:6px;line-height:1.3}.skill-pack-program{font-size:13px;color:var(--champlain-bright-blue);font-weight:600;margin-bottom:12px}.skill-pack-description{font-size:14px;color:var(--champlain-gray);line-height:1.6;margin-bottom:16px;flex:1 1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.skill-pack-courses{border-top:1px solid #e8eaf0;padding-top:16px;margin-top:auto}.skill-pack-courses-label{font-size:11px;font-weight:700;color:var(--champlain-gray);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.skill-pack-course-list{display:flex;flex-wrap:wrap;gap:6px}.skill-pack-course{background:#fff;border:1px solid #e0e5eb;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;color:var(--champlain-navy)}.skill-pack-course.more{background:var(--champlain-bright-blue);color:#fff;border-color:var(--champlain-bright-blue)}.skill-packs-search-row{display:flex;gap:15px;width:100%;margin-bottom:20px}.skill-packs-search{flex:1 1;display:flex;align-items:center;background:#f5f7fa;border:2px solid #e0e5eb;border-radius:12px;padding:0 16px;transition:all var(--transition-fast)}.skill-packs-search:focus-within{border-color:var(--champlain-bright-blue);background:#fff}.skill-packs-search svg{color:var(--champlain-gray);flex-shrink:0}.skill-packs-search input{flex:1 1;border:none;background:transparent;padding:12px;font-size:14px;outline:none}.program-filter{padding:12px 16px;border:2px solid #e0e5eb;border-radius:12px;font-size:14px;font-weight:600;color:var(--champlain-navy);background:#f5f7fa;cursor:pointer;min-width:200px;transition:all var(--transition-fast)}.program-filter:focus{border-color:var(--champlain-bright-blue);outline:none}.skill-pack-card{cursor:pointer}.skill-pack-progress{margin-top:16px;padding-top:16px;border-top:1px solid #e8eaf0}.progress-bar{height:8px;background:#e0e5eb;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-bar.large{height:12px;border-radius:6px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));border-radius:inherit;transition:width .3s ease}.progress-text{font-size:12px;color:var(--champlain-gray);font-weight:600}.skill-pack-actions{margin-top:16px;padding-top:16px;border-top:1px solid #e8eaf0}.quick-add-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;background:linear-gradient(135deg,var(--champlain-bright-blue) 0,var(--champlain-teal) 100%);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.quick-add-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(0,169,224,.4)}.quick-add-btn:active{transform:translateY(0)}.skill-pack-toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);padding:16px 24px;border-radius:12px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:600;z-index:var(--z-max);animation:slideUp .3s ease;box-shadow:0 8px 30px rgba(0,0,0,.2)}.toast-success{background:var(--champlain-dark-green);color:#fff}.toast-info{background:var(--champlain-navy);color:#fff}.toast-warning{background:var(--champlain-red);color:#fff}.toast-close{background:none;border:none;color:inherit;font-size:20px;cursor:pointer;opacity:.7;transition:opacity .2s}.toast-close:hover{opacity:1}.course-item-prereqs small{font-size:12px;color:#999}.selected-badge{background:var(--champlain-green);color:#fff;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase}.btn-secondary{padding:12px 24px;background:#f5f7fa;color:var(--champlain-navy);border:1px solid #e0e5eb;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{background:#e8eef4}.btn-primary{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,var(--champlain-bright-blue) 0,var(--champlain-teal) 100%);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(0,169,224,.4)}.quick-add-modal-btn svg{flex-shrink:0}.skill-packs-sidebar{margin-top:20px;padding:16px;background:#f8fafc;border-radius:12px;border:1px solid #e8eaf0}.skill-packs-sidebar h3{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--champlain-navy);margin:0 0 12px}.skill-packs-suggestions{display:flex;flex-direction:column;gap:10px}.suggestion-card{padding:12px;background:#fff;border:1px solid #e0e5eb;border-radius:8px;cursor:pointer;transition:all var(--transition-fast)}.suggestion-card:hover{border-color:var(--champlain-bright-blue);box-shadow:0 2px 8px rgba(0,0,0,.08)}.suggestion-title{font-size:13px;font-weight:600;color:var(--champlain-navy);margin-bottom:2px}.suggestion-program,.suggestion-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-program{font-size:11px;color:#888;margin-bottom:8px}.suggestion-progress{display:flex;align-items:center;gap:10px}.mini-progress-bar{flex:1 1;height:8px;background:#e0e5eb;border-radius:4px;overflow:hidden}.mini-progress-bar .progress-fill{height:100%;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-green));border-radius:4px;transition:width .3s ease}.progress-label,.suggestion-progress span{font-size:11px;font-weight:600;color:var(--champlain-gray);white-space:nowrap}.no-suggestions{font-size:13px;color:var(--champlain-gray);text-align:center;padding:10px;margin:0}@media (max-width:768px){.landing-discovery{padding:60px 20px}.discovery-header h2{font-size:32px}.interest-categories{gap:8px}.interest-btn{padding:10px 16px;font-size:13px}.skill-packs-container{padding:20px}.skill-packs-header{flex-direction:column;align-items:flex-start}.skill-packs-grid{grid-template-columns:1fr}.skill-packs-filters{width:100%;overflow-x:auto;padding-bottom:5px}.skill-packs-search-row{flex-direction:column}.program-filter{min-width:100%}.skill-pack-toast{left:20px;right:20px;transform:none;width:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}}.landing-footer{background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-dark-blue) 100%);color:#fff;padding:60px 40px 30px}.footer-content{max-width:1200px;margin:0 auto}.footer-brand{display:flex;align-items:center;gap:20px;margin-bottom:40px}.footer-brand img{height:60px}.footer-brand strong{font-size:20px;display:block;margin-bottom:4px}.footer-brand p{margin:0;font-size:14px;opacity:.8}.footer-links{display:flex;gap:80px;margin-bottom:40px}.footer-column h4{font-size:16px;font-weight:700;margin-bottom:20px;color:var(--champlain-bright-blue)}.footer-column a{display:block;color:hsla(0,0%,100%,.7);text-decoration:none;font-size:14px;margin-bottom:12px;transition:color var(--transition-fast),transform var(--transition-fast)}.footer-column a:hover{color:var(--champlain-bright-blue);transform:translateX(3px)}.footer-bottom{padding-top:30px;border-top:1px solid hsla(0,0%,100%,.1);text-align:center}.footer-bottom p{font-size:14px;color:hsla(0,0%,100%,.5);margin:0;letter-spacing:.3px}@media (max-width:1024px){.hero-content{grid-template-columns:1fr;gap:40px;text-align:center}.hero-text{order:1}.hero-login{order:2}.hero-description{margin:0 auto 40px}.hero-stats{justify-content:center;margin-left:0}.hero-text h1{font-size:42px}}@media (max-width:768px){.landing-nav-content{padding:12px 20px}.landing-nav-links{display:none}.landing-hero{padding:100px 20px 60px}.hero-text h1{font-size:32px}.hero-subtitle{font-size:18px}.hero-description{font-size:16px}.hero-stats{flex-wrap:wrap;gap:20px;margin-left:0}.hero-stat{padding:0 20px}.hero-stat+.hero-stat:before{display:none}.hero-stat .stat-number{font-size:32px}.hero-login .login-card{padding:30px 25px}.landing-about,.landing-competencies{padding:60px 20px}.about-header h2,.competencies-header h2{font-size:32px}.weight-legend{flex-direction:column;gap:25px}.weight-item{max-width:100%}.footer-links{flex-direction:column;gap:30px}.footer-brand{flex-direction:column;text-align:center}.landing-visualizations{padding:60px 20px}.visualizations-header h2{font-size:32px}.visualizations-grid{grid-template-columns:1fr}.visualizations-cta{padding:30px 20px}.visualizations-cta p{font-size:20px}}.login-subtitle{margin-bottom:25px}.input-group{margin-bottom:18px}.input-group label{color:var(--champlain-navy);margin-bottom:8px}.input-group input{padding:14px 16px}.input-group input,.login-btn{border-radius:10px;transition:all var(--transition-normal)}.login-btn{margin-top:10px}.login-info{text-align:left;margin-top:20px;color:var(--champlain-navy);padding:14px 16px;background:linear-gradient(135deg,var(--champlain-lightest-blue) 0,#f0faff 100%);line-height:1.6}.error-message{font-weight:500}.skill-packs-header-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.sp-view-toggle{display:flex;background:#f0f4f8;border-radius:10px;padding:4px;gap:2px}.sp-view-btn{display:flex;align-items:center;justify-content:center;width:38px;height:34px;border:none;border-radius:8px;background:transparent;color:var(--champlain-gray);cursor:pointer;transition:all var(--transition-fast)}.sp-view-btn:hover{background:#e0e5eb;color:var(--champlain-navy)}.sp-view-btn.active{background:var(--champlain-navy);color:#fff;box-shadow:0 2px 6px rgba(0,60,95,.25)}.skill-packs-list{display:flex;flex-direction:column;gap:8px;min-height:200px}.sp-list-item{border:1px solid #e8eaf0;border-radius:12px;background:#f8fafc;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}.sp-list-item:hover{border-color:#c8d0d8}.sp-list-item.open{border-color:var(--champlain-bright-blue);box-shadow:0 4px 16px rgba(0,169,224,.1)}.sp-list-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 20px;background:transparent;border:none;cursor:pointer;text-align:left;gap:16px;transition:background .2s ease}.sp-list-header:hover{background:rgba(0,60,95,.03)}.sp-list-item.open .sp-list-header{background:linear-gradient(135deg,rgba(0,60,95,.04),rgba(35,97,146,.04));border-bottom:1px solid #e8eaf0}.sp-list-header-info{display:flex;flex-direction:column;gap:6px;flex:1 1;min-width:0}.sp-list-title{font-size:16px;font-weight:700;color:var(--champlain-navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-list-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.sp-list-meta .skill-pack-badge{margin-bottom:0}.sp-list-code{font-size:13px;font-weight:700;color:var(--champlain-blue);background:var(--champlain-lightest-blue);padding:2px 10px;border-radius:6px}.sp-list-progress-hint{font-size:12px;font-weight:600;color:var(--champlain-teal);background:rgba(61,196,178,.1);padding:2px 8px;border-radius:6px}.sp-list-chevron{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:rgba(0,60,95,.06);color:var(--champlain-gray);transition:transform .3s ease,background .2s ease,color .2s ease}.sp-list-item.open .sp-list-chevron{transform:rotate(180deg);background:rgba(0,169,224,.12);color:var(--champlain-bright-blue)}.sp-list-body{max-height:0;overflow:hidden;transition:max-height .35s ease}.sp-list-item.open .sp-list-body{max-height:1200px}.sp-list-body-inner{padding:20px 24px 24px}.sp-list-detail-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #f0f2f4}.sp-list-detail-row:last-of-type{border-bottom:none}.sp-list-label{font-size:12px;font-weight:700;color:var(--champlain-gray);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;min-width:80px}.sp-list-value{font-size:14px;font-weight:500;color:var(--champlain-navy)}.sp-list-description{margin-top:12px;padding-top:12px;border-top:1px solid #e8eaf0}.sp-list-description p{font-size:14px;color:var(--champlain-gray);line-height:1.7;margin:8px 0 0}.sp-list-courses-section{margin-top:16px;padding-top:16px;border-top:1px solid #e8eaf0}.sp-list-courses{display:flex;flex-direction:column;gap:6px;margin-top:10px}.sp-list-course{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fff;border:1px solid #e8eaf0;border-radius:8px;font-size:13px;transition:border-color .2s ease,background .2s ease}.sp-list-course.selected{background:#f0f9ff;border-color:var(--champlain-bright-blue)}.sp-list-course-code{font-weight:700;color:var(--champlain-navy);min-width:80px}.sp-list-course-title{flex:1 1;color:#495057;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sp-list-course-status{font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;white-space:nowrap;flex-shrink:0;min-width:120px;text-align:right}.sp-list-course-status.selected-tag{background:rgba(0,169,224,.12);color:var(--champlain-bright-blue)}.sp-list-course-status.prereq-tag{background:#fff3e0;color:#e65100;max-width:200px;overflow:hidden;text-overflow:ellipsis}.sp-list-progress{margin-top:16px;padding-top:16px;border-top:1px solid #e8eaf0}.sp-list-actions{margin-top:16px}.sp-list-actions .quick-add-btn{width:auto;padding:10px 20px}@media (max-width:768px){.skill-packs-header-controls{flex-direction:column;align-items:flex-start;width:100%}.sp-list-header{padding:14px 16px}.sp-list-title{font-size:14px}.sp-list-meta{gap:6px}.sp-list-body-inner{padding:16px}.sp-list-course{flex-wrap:wrap;gap:6px}.sp-list-course-code{min-width:auto}.sp-list-detail-row{flex-direction:column;align-items:flex-start;gap:4px}.sp-list-label{min-width:auto}}.sp-overlap-checker-panel{background:#fff;border:1.5px solid #d0dce8;border-radius:10px;margin-bottom:24px;overflow:hidden;box-shadow:0 2px 8px rgba(0,60,95,.06)}.sp-overlap-checker-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 22px;background:linear-gradient(90deg,#f0f5fa,#e8f0f8);border:none;cursor:pointer;font-size:15px;font-weight:600;color:var(--champlain-navy,#003c5f);text-align:left;transition:background .2s}.sp-overlap-checker-header:hover{background:linear-gradient(90deg,#e4eef8,#d8e8f4)}.sp-overlap-checker-header-left{display:flex;align-items:center;gap:10px}.sp-overlap-checker-badge{background:var(--champlain-bright-blue,#00a9e0);color:#fff;font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px;letter-spacing:.02em;text-transform:uppercase}.sp-overlap-checker-toggle-hint{font-size:13px;font-weight:400;color:#5a7a96;display:flex;align-items:center;gap:8px}.sp-overlap-checker-body{padding:22px 24px;border-top:1px solid #d8e5f0}.sp-overlap-checker-description{color:#4a6275;font-size:14px;line-height:1.6;margin:0 0 18px}.sp-overlap-input-row{margin-bottom:14px}.sp-overlap-input-group{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.sp-overlap-course-input{flex:1 1;min-width:220px;padding:9px 14px;border:1.5px solid #b8cfe0;border-radius:6px;font-size:14px;color:#1a2e3d;background:#f8fbfd;outline:none;transition:border-color .2s}.sp-overlap-course-input:focus{border-color:var(--champlain-bright-blue,#00a9e0);background:#fff}.sp-overlap-add-btn{padding:9px 18px;background:var(--champlain-navy,#003c5f);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.sp-overlap-add-btn:hover{background:var(--champlain-blue,#236192)}.sp-overlap-selected-label{font-size:12px;font-weight:600;color:#5a7a96;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.sp-overlap-selected-courses{display:flex;flex-wrap:wrap;gap:8px;min-height:38px;margin-bottom:16px;padding:6px 10px;background:#f4f8fc;border:1px dashed #b8cfe0;border-radius:6px;align-items:center}.sp-overlap-empty-hint{color:#9ab0c2;font-size:13px;font-style:italic}.sp-overlap-chip{display:inline-flex;align-items:center;gap:6px;background:var(--champlain-navy,#003c5f);color:#fff;border-radius:16px;padding:4px 12px 4px 10px;font-size:13px;font-weight:600}.sp-overlap-chip-code{letter-spacing:.02em}.sp-overlap-chip-remove{background:none;border:none;color:hsla(0,0%,100%,.75);cursor:pointer;font-size:16px;line-height:1;padding:0;transition:color .15s}.sp-overlap-chip-remove:hover{color:#fff}.sp-overlap-actions{display:flex;align-items:center;gap:14px;margin-bottom:20px}.sp-overlap-check-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;background:var(--champlain-bright-blue,#00a9e0);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s,opacity .2s}.sp-overlap-check-btn:hover:not(:disabled){background:#0093c4}.sp-overlap-check-btn:disabled{opacity:.45;cursor:not-allowed}.sp-overlap-actions-hint{font-size:13px;color:#7a94a8}.sp-overlap-results{border-top:1px solid #d8e5f0;padding-top:20px}.sp-overlap-results:empty{border-top:none;padding-top:0}.sp-overlap-results-inner{display:flex;flex-direction:column;gap:16px}.sp-overlap-summary-banner{display:flex;align-items:center;gap:10px;background:#eef6eb;border:1px solid #c3dbb8;border-radius:7px;padding:10px 16px;font-size:14px;color:#2a5a1e;font-weight:500}.sp-overlap-section-title{font-size:13px;font-weight:700;color:var(--champlain-navy,#003c5f);text-transform:uppercase;letter-spacing:.05em;margin:0 0 10px;display:flex;align-items:center;gap:8px}.sp-overlap-section-title--spaced{margin-top:8px}.sp-overlap-count-badge{background:var(--champlain-bright-blue,#00a9e0);color:#fff;border-radius:12px;padding:1px 8px;font-size:12px;font-weight:700;letter-spacing:0;text-transform:none}.sp-overlap-course-list{display:flex;flex-direction:column;gap:10px}.sp-overlap-course-row{background:#f8fbfd;border:1px solid #d0dce8;border-radius:7px;padding:12px 16px;display:flex;flex-wrap:wrap;align-items:flex-start;gap:10px}.sp-overlap-course-info{display:flex;align-items:baseline;gap:8px;flex:1 1 180px}.sp-overlap-course-code{font-weight:700;font-size:14px;color:var(--champlain-navy,#003c5f)}.sp-overlap-course-name{font-size:13px;color:#4a6275}.sp-overlap-badge{font-size:12px;font-weight:600;border-radius:12px;padding:3px 10px;white-space:nowrap;flex-shrink:0}.sp-overlap-badge-none{background:#eef6eb;color:#2a5a1e}.sp-overlap-badge-one{background:#fff3e0;color:#8a4a00}.sp-overlap-badge-many{background:#fdecea;color:#8a1a0a}.sp-overlap-sp-list{width:100%;display:flex;flex-wrap:wrap;gap:6px 16px;align-items:center;margin-top:4px}.sp-overlap-sp-name{font-size:13px;font-weight:600;color:#2a4a6a}.sp-overlap-sp-program{font-size:12px;color:#7a94a8}.sp-overlap-sp-none{font-size:13px;color:#6a9460;font-style:italic}.sp-overlap-table-wrapper{overflow-x:auto;border-radius:7px;border:1px solid #d0dce8}.sp-overlap-table{width:100%;border-collapse:collapse;font-size:14px}.sp-overlap-table thead th{background:var(--champlain-navy,#003c5f);color:#fff;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;text-align:left}.sp-overlap-table tbody tr{border-bottom:1px solid #e0ecf4;transition:background .1s}.sp-overlap-table tbody tr:last-child{border-bottom:none}.sp-overlap-table tbody tr:hover{background:#f4f8fc}.sp-overlap-table td{padding:10px 14px;vertical-align:top}.sp-overlap-sp-col-title strong{font-weight:600;color:#1a2e3d}.sp-overlap-sp-meta{font-size:12px;color:#7a94a8;margin-top:2px}.sp-overlap-sp-col-type{font-size:12px;color:#4a6275;white-space:nowrap}.sp-overlap-match-label{display:inline-block;font-size:12px;font-weight:600;border-radius:10px;padding:3px 10px;white-space:nowrap}.sp-overlap-match-label.sp-overlap-exact{background:#fdecea;color:#8a1a0a}.sp-overlap-match-label.sp-overlap-superset{background:#fff3e0;color:#8a4a00}.sp-overlap-match-label.sp-overlap-partial{background:#fff8e1;color:#6a5000}.sp-overlap-shared-codes{font-size:12px;color:#4a6275;font-family:monospace;letter-spacing:.02em}.sp-overlap-no-match{display:flex;align-items:center;gap:14px;background:#eef6eb;border:1px solid #c3dbb8;border-radius:7px;padding:14px 18px;color:#2a5a1e;font-size:14px;font-weight:500}@media (max-width:600px){.sp-overlap-input-group{flex-direction:column;align-items:stretch}.sp-overlap-add-btn{width:100%;text-align:center}.sp-overlap-actions{flex-direction:column;align-items:flex-start}.sp-overlap-checker-toggle-hint{display:none}.sp-overlap-table{font-size:12px}}.login-page-old{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#002a3a,#003c5f 50%,#236192);padding:20px;position:relative;overflow:hidden}.login-card{background:#fff;padding:50px;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);width:100%;max-width:480px;position:relative;z-index:var(--z-raised)}.login-logo{text-align:center;margin-bottom:30px}.login-title{color:var(--champlain-navy);font-size:32px;font-weight:700;margin-bottom:8px;text-align:center}.login-subtitle{color:var(--champlain-gray);text-align:center;margin-bottom:35px;font-size:15px}.input-group{margin-bottom:24px}.input-group label{display:block;color:var(--champlain-dark);font-weight:600;margin-bottom:10px;font-size:14px}.input-group input{width:100%;padding:15px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;transition:all .3s ease;background:#fafbfc}.input-group input:focus{outline:none;border-color:var(--champlain-bright-blue);background:#fff;box-shadow:0 0 0 3px rgba(0,169,224,.1)}.login-btn{width:100%;padding:16px;background:linear-gradient(135deg,var(--champlain-bright-blue) 0,var(--champlain-blue) 100%);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px rgba(0,169,224,.3)}.login-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,169,224,.4)}.login-btn:active{transform:translateY(0)}.login-info{margin-top:30px;padding:20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:8px;font-size:13px;color:var(--champlain-gray);border-left:4px solid var(--champlain-bright-blue)}.error-message{color:#d32f2f;margin-top:15px;text-align:center;font-size:14px;padding:12px;background:#ffebee;border-radius:6px;border-left:4px solid #d32f2f}.viz-container{flex:1 1;padding:25px 35px;background:transparent;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;max-height:calc(100vh - 73px)}.viz-header{margin-bottom:16px;flex-shrink:0;background:#fff;padding:18px 24px;border-radius:14px;box-shadow:0 2px 12px rgba(0,60,95,.06)}.viz-header h1{color:var(--champlain-navy);font-size:22px;margin-bottom:4px;font-weight:800;background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.viz-header p{color:#6c757d;font-size:14px;font-weight:500}.view-toggle{display:flex;gap:0;background:linear-gradient(135deg,#f0f4f8,#e8eef3);border-radius:12px;padding:6px;box-shadow:inset 0 2px 4px rgba(0,60,95,.08);border:none}.toggle-btn{padding:12px 28px;border:none;background:transparent;color:#6c757d;cursor:pointer;font-size:14px;font-weight:600;border-radius:8px;transition:all .3s ease;white-space:nowrap}.toggle-btn:hover{background:#f8f9fa;color:var(--champlain-navy)}.toggle-btn.active{background:linear-gradient(135deg,var(--champlain-bright-blue) 0,var(--champlain-blue) 100%);color:#fff;box-shadow:0 4px 12px rgba(0,169,224,.3)}.header-nav-toggle.view-toggle{background:hsla(0,0%,100%,.1);border-radius:10px;padding:4px;box-shadow:none;flex-shrink:1;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.header-nav-toggle.view-toggle::-webkit-scrollbar{display:none}.header-nav-toggle .toggle-btn{padding:8px 16px;font-size:13px;color:hsla(0,0%,100%,.7);border-radius:7px}.header-nav-toggle .toggle-btn:hover{background:hsla(0,0%,100%,.15);color:#fff}.header-nav-toggle .toggle-btn.active{background:var(--champlain-bright-blue);color:#fff;box-shadow:0 2px 8px rgba(0,169,224,.4)}.viz-header-row{display:flex;justify-content:space-between;align-items:center}.view-toggle-mobile{display:none!important;flex-wrap:wrap;gap:6px;margin-top:14px;background:linear-gradient(135deg,#f0f4f8,#e8eef3);border-radius:10px;padding:6px}.view-toggle-mobile .toggle-btn{flex:1 1;min-width:calc(33% - 6px);padding:10px 12px;font-size:13px;text-align:center}.graph-wrapper{background:#fff;border-radius:20px;box-shadow:0 8px 40px rgba(0,60,95,.1);padding:0;height:calc(100vh - 250px);min-height:700px;position:relative;overflow:hidden;border:none}.graph-wrapper>div{position:absolute!important;top:0;left:0;right:0;bottom:0;width:100%!important;height:100%!important;overflow:auto!important;padding:30px;box-sizing:border-box;z-index:var(--z-base);transition:opacity .15s ease}.graph-wrapper>div.hidden{visibility:hidden!important;opacity:0!important;z-index:var(--z-below)!important;pointer-events:none!important}.graph-wrapper>div:not(.hidden){visibility:visible!important;opacity:1!important;z-index:var(--z-raised)!important}.toast-notification{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--champlain-navy,#003c5f);color:#fff;padding:12px 20px;border-radius:10px;font-size:13px;font-weight:600;box-shadow:0 6px 20px rgba(0,60,95,.3);display:flex;align-items:center;gap:12px;z-index:var(--z-toast);opacity:0;transition:opacity .2s ease,transform .2s ease;pointer-events:none}.toast-notification.visible{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}.toast-notification .toast-undo{background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.3);color:#fff;padding:4px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:700;transition:background .15s}.toast-notification .toast-undo:hover{background:hsla(0,0%,100%,.35)}.competency-table th.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative}.competency-table th.sortable:hover{background:#002a48}.competency-table th .sort-indicator{margin-left:4px;font-size:10px;opacity:.5}.competency-table th.sorted .sort-indicator{opacity:1}.legend{display:flex;gap:30px;margin-bottom:20px;flex-wrap:wrap;padding:20px 24px;background:linear-gradient(135deg,#f8f9fa,#fff);border-radius:12px;border:1px solid #e8eaf0}.legend-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--champlain-navy);font-weight:600}.legend-color{width:24px;height:24px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.15);flex-shrink:0}#networkView{width:100%;height:100%;position:relative}#networkGraph{min-height:600px}#tableView{flex:1 1;overflow:auto;display:flex;flex-direction:column}.table-container{flex:1 1;overflow:auto;border-radius:8px;border:1px solid #e8eaf0}.competency-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;min-width:100%}.competency-table thead{position:-webkit-sticky;position:sticky;top:0;background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-blue) 100%);color:#fff;z-index:var(--z-raised);box-shadow:0 2px 8px rgba(0,0,0,.1)}.competency-table th{padding:16px 12px;text-align:left;font-weight:700;border:1px solid hsla(0,0%,100%,.15);font-size:12px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;background:var(--champlain-navy)}.competency-table th:first-child{min-width:200px;position:-webkit-sticky;position:sticky;left:0;z-index:calc(var(--z-raised) + 1);background:var(--champlain-navy);box-shadow:2px 0 4px rgba(0,0,0,.1)}.competency-table td{padding:14px 12px;border:1px solid #e8eaf0;text-align:center;background:#fff;white-space:nowrap}.competency-table tbody tr{transition:all .2s ease}.competency-table tbody tr:hover,.competency-table tbody tr:hover td{background:#f8fbff}.competency-table td:first-child{text-align:left;font-weight:600;color:var(--champlain-navy);position:-webkit-sticky;position:sticky;left:0;background:#fff;z-index:calc(var(--z-raised) - 5);box-shadow:2px 0 4px rgba(0,0,0,.05)}.competency-table tbody tr:hover td:first-child{background:#f8fbff}.competency-table tfoot{background:linear-gradient(135deg,#f8f9fa,#e9ecef);font-weight:700;position:-webkit-sticky;position:sticky;bottom:0;z-index:var(--z-raised);border-top:3px solid var(--champlain-navy);box-shadow:0 -2px 8px rgba(0,0,0,.1)}.competency-table tfoot td{padding:16px 12px;text-align:center;border:1px solid #e8eaf0;font-size:14px;color:var(--champlain-navy);font-weight:700;background:#f8f9fa}.competency-table tfoot td.total-label{text-align:left;font-size:13px;letter-spacing:.5px;text-transform:uppercase;position:-webkit-sticky;position:sticky;left:0;z-index:11;background:#f8f9fa;border-right:2px solid #e8eaf0;box-shadow:2px 0 4px rgba(0,0,0,.05)}.competency-table tfoot td.total-cell{font-size:16px;color:var(--champlain-blue);font-weight:800}.course-code-cell{font-weight:700;color:var(--champlain-blue);font-size:13px}.course-name-cell{font-size:11px;color:#6c757d;margin-top:4px;font-weight:400}.check-mark{color:var(--champlain-green);font-size:20px;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1)}.empty-table-message{text-align:center;padding:60px 20px;color:#6c757d;font-size:16px}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:var(--modal-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);overflow-y:auto}.modal-content{background:var(--card-bg);margin:50px auto;padding:0;width:90%;max-width:800px;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);animation:slideUp .3s ease;transition:background-color .3s ease}@keyframes slideUp{0%{transform:translateY(20px)}to{transform:translateY(0)}}.modal-header{background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-blue) 100%);color:#fff;padding:28px 35px;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:26px;margin:0;font-weight:700}.close-btn{background:hsla(0,0%,100%,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid hsla(0,0%,100%,.3);color:#fff;font-size:28px;cursor:pointer;line-height:1;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.close-btn:hover{background:#fff;color:var(--champlain-navy);transform:rotate(90deg)}.modal-body{padding:35px}.form-group{margin-bottom:25px}.form-group label{display:block;color:var(--champlain-dark);font-weight:600;margin-bottom:10px;font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:14px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;font-family:inherit;transition:all .3s ease;background:#fafbfc}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--champlain-bright-blue);background:#fff;box-shadow:0 0 0 3px rgba(0,169,224,.1)}.form-group textarea{min-height:120px;resize:vertical}.competency-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:14px;gap:14px}.competency-option{display:flex;align-items:center;padding:14px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#fafbfc}.competency-option:hover{border-color:var(--champlain-bright-blue);background:#fff;box-shadow:var(--shadow-sm)}.competency-option input{width:auto;margin-right:12px}.competency-weight-option{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border:2px solid #e8eaf0;border-radius:8px;background:#fff;transition:all .2s ease}.competency-weight-option:hover{border-color:var(--champlain-bright-blue);background:#f8fbff;box-shadow:var(--shadow-sm)}.competency-weight-option label{font-weight:600;color:var(--champlain-navy);font-size:14px}.competency-weight-select{width:170px;padding:10px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;background:#fafbfc}.competency-weight-select:focus{outline:none;border-color:var(--champlain-bright-blue);background:#fff;box-shadow:0 0 0 3px rgba(0,169,224,.1)}.competency-weight-select:hover{border-color:var(--champlain-blue)}.competency-weight-select option{padding:8px}.submit-btn{width:100%;padding:16px;background:linear-gradient(135deg,var(--champlain-bright-blue) 0,var(--champlain-blue) 100%);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px rgba(0,169,224,.3)}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,169,224,.4)}.proposal-card{background:#fff;border:1px solid #e8eaf0;border-radius:12px;padding:24px;margin-bottom:18px;transition:all .3s ease}.proposal-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.proposal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.proposal-title{color:var(--champlain-navy);font-size:18px;font-weight:700}.proposal-status{padding:8px 18px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-pending{background:linear-gradient(135deg,#fff3cd,#ffe69c);color:#856404;border:1px solid #ffc107}.status-approved{background:linear-gradient(135deg,#d4edda,#c3e6cb);color:#155724;border:1px solid var(--champlain-green)}.status-rejected{background:linear-gradient(135deg,#f8d7da,#f5c6cb);color:#721c24;border:1px solid var(--champlain-red)}.status-revision{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100;border:1px solid #ff9800}.status-resubmitted{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#0d47a1;border:1px solid #42a5f5}.status-feedback{background:linear-gradient(135deg,#f3e5f5,#e1bee7);color:#6a1b9a;border:1px solid #ab47bc}.proposal-info{font-size:13px;color:var(--champlain-gray);margin-bottom:14px}.proposal-actions{display:flex;gap:10px;margin-top:18px}.action-btn{padding:12px 22px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;color:#fff;transition:all .3s ease;box-shadow:var(--shadow-sm)}.btn-view{background:var(--champlain-blue);color:#fff}.btn-approve{background:var(--champlain-green);color:#fff}.btn-reject{background:var(--champlain-red);color:#fff}.action-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.success-message{color:#4caf50;margin-top:15px;text-align:center;font-weight:600;padding:12px;background:#d4edda;border-radius:8px;border-left:4px solid #4caf50}.edit-tab{flex-shrink:0;transition:all .3s ease}.edit-tab:hover{background:var(--champlain-blue)!important;color:#fff!important}.edit-tab.active{position:relative}.edit-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:4px;background:var(--champlain-bright-blue);border-radius:2px 2px 0 0}.progress-step{position:relative;transition:all .3s ease}.progress-step.active{background:#fff!important}.edit-tab-content .form-group{margin-bottom:20px}.edit-tab-content .form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--champlain-navy);font-size:14px}.edit-tab-content .form-group input[type=number],.edit-tab-content .form-group input[type=text],.edit-tab-content .form-group select,.edit-tab-content .form-group textarea{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;font-family:inherit;transition:all .2s ease}.edit-tab-content .form-group input:focus,.edit-tab-content .form-group select:focus,.edit-tab-content .form-group textarea:focus{outline:none;border-color:var(--champlain-bright-blue);box-shadow:0 0 0 3px rgba(0,169,224,.1)}.edit-tab-content .form-group input::placeholder,.edit-tab-content .form-group textarea::placeholder{color:#999}.edit-tab-content .form-group small{display:block;margin-top:6px;font-size:12px;color:#666}.edit-assessment-item,.edit-clo-item,.edit-plo-item{transition:all .2s ease}.edit-assessment-item:hover,.edit-clo-item:hover,.edit-plo-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.remove-edit-assessment,.remove-edit-clo,.remove-edit-plo{transition:all .2s ease}.remove-edit-assessment:hover,.remove-edit-clo:hover,.remove-edit-plo:hover{background:var(--champlain-red)!important;transform:scale(1.05)}.edit-assessment-clos,.edit-assessment-desc,.edit-assessment-name,.edit-clo-desc,.edit-clo-id,.edit-clo-plos,.edit-plo-comps,.edit-plo-desc,.edit-plo-id{transition:all .2s ease}.edit-assessment-desc:focus,.edit-assessment-name:focus,.edit-clo-desc:focus,.edit-clo-id:focus,.edit-plo-desc:focus,.edit-plo-id:focus{transform:scale(1.01);box-shadow:0 2px 8px rgba(33,150,243,.2)}#editNextTab,#editPrevTab,#saveEditCourse{transition:all .2s ease;font-family:inherit}#editNextTab:hover,#editPrevTab:hover{background:#5a6268!important;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}#saveEditCourse{position:relative;overflow:hidden}#saveEditCourse:hover{background:#45a049!important;transform:translateY(-2px);box-shadow:0 6px 16px rgba(74,170,80,.3)}#saveEditCourse:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:hsla(0,0%,100%,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s}#saveEditCourse:active:before{width:300px;height:300px}@media (max-width:768px){.competency-weight-option{flex-direction:column;gap:10px;align-items:flex-start}.competency-weight-select{width:100%}.edit-tab{font-size:11px!important;padding:10px 15px!important}.edit-clo-item .edit-clo-id,.edit-plo-item .edit-plo-id{width:100px!important}}.edit-tab-content.loading{opacity:.5;pointer-events:none}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--champlain-red)}.form-group input.success,.form-group select.success,.form-group textarea.success{border-color:var(--champlain-green)}.help-text{display:inline-block;margin-left:6px;padding:2px 8px;background:var(--champlain-lightest-blue);color:var(--champlain-blue);border-radius:12px;font-size:11px;font-weight:600;cursor:help}.help-text:hover{background:var(--champlain-bright-blue);color:#fff}.edit-tab-content h3{position:relative;padding-bottom:15px}.edit-tab-content h3:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),transparent);border-radius:2px}.edit-tab-content>div[style*="background: #e3f2fd"],.edit-tab-content>div[style*="background: #e8f5e9"],.edit-tab-content>div[style*="background: #f3e5f5"],.edit-tab-content>div[style*="background: #fff3e0"]{position:relative;overflow:hidden}.edit-tab-content>div[style*="background: #e3f2fd"]:before,.edit-tab-content>div[style*="background: #e8f5e9"]:before,.edit-tab-content>div[style*="background: #f3e5f5"]:before,.edit-tab-content>div[style*="background: #fff3e0"]:before{content:"";position:absolute;top:-50%;right:-50%;width:200px;height:200px;background:radial-gradient(circle,hsla(0,0%,100%,.3) 0,transparent 70%);pointer-events:none}.edit-tab-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{transform:translateY(10px)}to{transform:translateY(0)}}#editCourseModal .modal-content{animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translateY(-30px)}to{transform:translateY(0)}}#editCourseModal .modal-body::-webkit-scrollbar{width:10px}#editCourseModal .modal-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}#editCourseModal .modal-body::-webkit-scrollbar-thumb{background:var(--champlain-blue);border-radius:10px}#editCourseModal .modal-body::-webkit-scrollbar-thumb:hover{background:var(--champlain-navy)}.collapsible-toggle{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(135deg,#f0f4f8,#e2e8f0);border:1px solid #d0d7de;border-radius:10px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all .2s ease;margin-bottom:12px}.collapsible-toggle:hover{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);border-color:var(--champlain-blue);box-shadow:0 2px 8px rgba(0,60,95,.1)}.collapsible-toggle:not(.collapsed){background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-blue) 100%);border-color:var(--champlain-navy);color:#fff;box-shadow:0 2px 8px rgba(0,60,95,.2)}.collapsible-toggle-label{font-size:15px;font-weight:700;letter-spacing:.01em}.collapsible-toggle-arrow{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(0,0,0,.08);transition:transform .25s ease,background .2s ease;font-size:0}.collapsible-toggle-arrow:after{content:"";display:block;width:8px;height:8px;border-right:2.5px solid;border-bottom:2.5px solid;transform:rotate(-45deg);margin-left:-2px;transition:transform .25s ease}.collapsible-toggle:not(.collapsed) .collapsible-toggle-arrow{background:hsla(0,0%,100%,.2)}.collapsible-toggle:not(.collapsed) .collapsible-toggle-arrow:after{transform:rotate(45deg);margin-top:-3px;margin-left:0}.collapsible-body{overflow:hidden;max-height:2000px;transition:max-height .3s ease,opacity .25s ease;opacity:1}.collapsible-body.collapsed{max-height:0;opacity:0}.competency-tracker{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #e8eaf0;border-radius:12px;padding:20px;margin-bottom:18px;box-shadow:var(--shadow-sm)}.competency-header{font-weight:700;color:var(--champlain-navy);margin-bottom:14px;font-size:15px;display:flex;align-items:center;gap:8px}.competency-header:before{content:"";width:4px;height:18px;background:var(--champlain-bright-blue);border-radius:2px}.competency-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid #e8eaf0;font-size:13px;transition:all .2s ease}.competency-item:last-child{border-bottom:none}.competency-item:hover{background:rgba(0,169,224,.05);margin:0 -10px;padding:12px 10px;border-radius:6px}.competency-name{flex:1 1;color:#2c3e50;font-weight:500}.competency-status{display:flex;align-items:center;gap:5px}.status-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-shadow:0 2px 6px rgba(0,0,0,.15);transition:all .3s ease}.status-icon:hover{transform:scale(1.1)}.status-met{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff}.status-partial{background:linear-gradient(135deg,#ff9800,#ffa726);color:#fff}.status-minimal{background:linear-gradient(135deg,#2196f3,#42a5f5);color:#fff}.status-not-met{background:linear-gradient(135deg,#f44336,#ef5350);color:#fff}.course-list{margin-top:12px;padding:12px;background:#fff;border-radius:8px;border:1px solid #e8eaf0}.course-item{padding:8px 0;font-size:13px;color:#495057;transition:all .2s ease}.course-item:hover{padding-left:8px}.course-code{font-weight:700;color:var(--champlain-blue)}.missing-alert{background:linear-gradient(135deg,#fff3cd,#ffe69c);border:2px solid #ffc107;border-radius:12px;padding:20px;margin-top:18px;box-shadow:var(--shadow-sm)}.missing-alert-title{font-weight:700;color:#856404;margin-bottom:12px;font-size:15px;display:flex;align-items:center;gap:8px}.missing-list{list-style:none;padding:0;margin:0}.missing-list li{padding:8px 0;color:#856404;font-size:13px;font-weight:500}.missing-list li:before{content:"⚠ ";margin-right:8px;font-size:16px}.summary-stats{display:flex;gap:12px;margin-top:12px}.summary-stat{flex:1 1;text-align:center;padding:16px;border-radius:10px;font-size:13px;box-shadow:var(--shadow-sm);transition:all .3s ease}.summary-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-met{background:linear-gradient(135deg,#d4edda,#c3e6cb);color:#155724;border:2px solid #4caf50}.stat-missing{background:linear-gradient(135deg,#f8d7da,#f5c6cb);color:#721c24;border:2px solid #d32f2f}.stat-number{font-size:32px;font-weight:800;display:block;margin-bottom:4px}.course-search-item{padding:14px;margin:8px 0;background:#fff;border:2px solid #e8eaf0;border-radius:10px;cursor:pointer;transition:all .3s ease}.course-search-item:hover{border-color:var(--champlain-bright-blue);background:#f8fbff;transform:translateX(4px);box-shadow:var(--shadow-md)}.course-search-item.selected{border-color:var(--champlain-bright-blue);background:linear-gradient(135deg,var(--champlain-lightest-blue) 0,#f0faff 100%);box-shadow:0 4px 12px rgba(0,169,224,.2)}.course-search-code{font-weight:700;color:var(--champlain-navy);font-size:14px}.course-search-name{font-size:13px;color:#495057;margin-top:4px}.course-search-comps{font-size:11px;color:#6c757d;margin-top:6px}.selected-course-item{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;margin:8px 0;background:linear-gradient(135deg,var(--champlain-lightest-blue) 0,#f0faff 100%);border:2px solid var(--champlain-bright-blue);border-radius:10px;font-size:13px;font-weight:600;box-shadow:0 2px 8px rgba(0,169,224,.15);transition:all .3s ease}.selected-course-item:hover{transform:translateX(4px);box-shadow:0 4px 12px rgba(0,169,224,.25)}.remove-course-btn{background:linear-gradient(135deg,var(--champlain-red) 0,#a33028 100%);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:11px;font-weight:700;transition:all .3s ease;box-shadow:0 2px 6px rgba(190,58,52,.3)}.remove-course-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(190,58,52,.4)}.filter-checkbox{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.filter-checkbox:hover{background:#f8f9fa;border-color:var(--champlain-bright-blue)}.filter-checkbox input[type=checkbox]{margin:0;cursor:pointer}.filter-checkbox input[type=checkbox]:checked+span{font-weight:600;color:var(--champlain-bright-blue)}.filter-checkbox span{color:#333}#filterPanel{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0;overflow:hidden}to{opacity:1;max-height:1000px}}.similar-course-item{padding:8px;margin-bottom:6px;background:#fff;border-radius:4px;border:1px solid #ddd;cursor:pointer;transition:all .2s ease;font-size:12px}.similar-course-item:hover{background:#f8f9fa;border-color:var(--champlain-green);transform:translateX(4px)}.similar-course-code{font-weight:600;color:var(--champlain-navy)}.similar-course-name{color:#666;margin-top:2px}.similarity-score{display:inline-block;padding:2px 6px;background:var(--champlain-green);color:#fff;border-radius:3px;font-size:10px;font-weight:600;margin-left:6px}.graph-type-btn{transition:all .3s ease}.graph-type-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.15)}.graph-type-btn.active{box-shadow:0 2px 8px rgba(0,169,224,.4)}.graph-chart-container{transition:opacity .3s ease}.graph-chart-container.hidden{display:none}.graph-tooltip{line-height:1.6}.graph-tooltip strong{color:#00a9e0}#barChart,#pieChart,#radarChart{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}#barChart .bar{transition:opacity .2s ease}#pieChart .arc path{transition:all .2s ease}#radarChart circle,#radarChart line,#radarChart path{transition:all .3s ease}#graphsCourseList>div{transition:all .2s ease}#graphsCourseList>div:hover{transform:translateX(5px);box-shadow:0 2px 6px rgba(0,0,0,.1)}#graphsInfoBox{animation:slideInFromTop .5s ease}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){#graphTypeToggle{flex-direction:column;width:100%}.graph-type-btn{width:100%}#graphsContainer{padding:15px}#barChart,#pieChart,#radarChart{height:400px!important}}@media print{.graph-type-btn{display:none}#graphsContainer{box-shadow:none;border:1px solid #ccc}}.course-card,.proposal-card,.section,.stat-card,input,select,textarea{transition:background-color .3s ease,border-color .3s ease,color .3s ease}input,select,textarea{background:var(--input-bg);border-color:var(--input-border);color:var(--text-primary)}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}.keyboard-shortcuts-hint{position:fixed;bottom:20px;right:20px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:8px 14px;font-size:12px;color:var(--text-secondary);box-shadow:var(--shadow-md);z-index:var(--z-header);display:flex;align-items:center;gap:8px;opacity:.8;transition:opacity .3s ease}.keyboard-shortcuts-hint:hover{opacity:1}.keyboard-shortcuts-hint kbd{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;padding:2px 6px;font-family:monospace;font-size:11px;color:var(--text-primary)}.shortcuts-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--modal-overlay);z-index:var(--z-modal);align-items:center;justify-content:center}.shortcuts-modal.active{display:flex}.shortcuts-content{background:var(--card-bg);border-radius:16px;padding:30px;max-width:500px;width:90%;box-shadow:var(--shadow-lg)}.shortcuts-content h3{color:var(--champlain-navy);margin-bottom:20px;font-size:20px;display:flex;align-items:center;gap:10px}[data-theme=dark] .shortcuts-content h3{color:var(--text-primary)}.shortcut-list{display:flex;flex-direction:column;gap:12px}.shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-color)}.shortcut-item:last-child{border-bottom:none}.shortcut-keys{display:flex;gap:6px}.shortcut-keys kbd{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--bg-secondary) 100%);border:1px solid var(--border-color);border-radius:6px;padding:6px 10px;font-family:monospace;font-size:13px;color:var(--text-primary);box-shadow:0 2px 0 var(--border-color)}.shortcut-desc{color:var(--text-secondary);font-size:14px}.dept-group-dropdown{position:relative;margin-bottom:6px}.dept-group-dropdown-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:6px 10px;font-size:12px;font-weight:600;color:var(--champlain-navy);background:#fff;border:1.5px solid #d0d7e0;border-radius:6px;cursor:pointer;transition:border-color .15s,background .15s}.dept-group-dropdown-toggle:hover{border-color:var(--champlain-navy);background:#f5f7fa}.dept-group-dropdown-toggle.open{border-color:var(--champlain-navy);border-bottom-left-radius:0;border-bottom-right-radius:0}.dept-group-dropdown-arrow{font-size:10px;transition:transform .2s}.dept-group-dropdown-toggle.open .dept-group-dropdown-arrow{transform:rotate(180deg)}.dept-group-dropdown-panel{display:none;border:1.5px solid var(--champlain-navy);border-top:none;border-radius:0 0 6px 6px;background:#f8fafc;padding:8px}.dept-group-dropdown-panel.open{display:block}.dept-group-select{display:flex;flex-wrap:wrap;gap:4px}.dept-group-btn{padding:3px 8px;font-size:11px;font-weight:700;border:1.5px solid var(--champlain-navy);border-radius:4px;background:#fff;color:var(--champlain-navy);cursor:pointer;transition:background .15s,color .15s;line-height:1.4}.dept-group-btn.all-selected,.dept-group-btn:hover{background:var(--champlain-navy);color:#fff}.dept-group-btn.partial-selected{background:#e8eef5;border-color:var(--champlain-blue);color:var(--champlain-blue)}.recently-viewed{margin-top:15px}.recently-viewed h4{font-size:13px;color:var(--text-secondary);margin-bottom:10px;display:flex;align-items:center;gap:6px}.recent-courses-list{display:flex;flex-direction:column;gap:6px}.recent-course-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-tertiary);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:13px}.recent-course-item:hover{background:var(--champlain-bright-blue);color:#fff;transform:translateX(4px)}.recent-course-code{font-weight:700;color:var(--champlain-blue)}.recent-course-item:hover .recent-course-code{color:#fff}.recent-course-name{color:var(--text-secondary);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-course-item:hover .recent-course-name{color:hsla(0,0%,100%,.9)}.competency-manage-card{background:#fff;border:1px solid #e8eaf0;border-radius:10px;padding:18px;margin-bottom:12px;transition:all .3s ease}.competency-manage-card:hover{box-shadow:var(--shadow-md);border-color:var(--champlain-bright-blue);transform:translateY(-2px)}.small-action-btn{background:var(--champlain-blue);color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;font-size:12px;transition:all .3s ease;font-weight:600;box-shadow:var(--shadow-sm)}.small-action-btn:hover{background:var(--champlain-navy);transform:scale(1.05);box-shadow:var(--shadow-md)}.objective-item{background:#fff;border:1px solid #e8eaf0;border-radius:8px;padding:12px 18px;margin-bottom:10px;font-size:13px;color:var(--champlain-navy);font-weight:500;transition:all .2s ease}.objective-item:hover{box-shadow:var(--shadow-sm);border-color:var(--champlain-bright-blue)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--champlain-blue) 0,var(--champlain-bright-blue) 100%);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--champlain-navy)}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.loading{animation:shimmer 2s infinite;background:linear-gradient(90deg,#f6f7f8 0,#edeef1 20%,#f6f7f8 40%,#f6f7f8);background-size:1000px 100%}.mobile-menu-toggle{display:none;background:hsla(0,0%,100%,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid hsla(0,0%,100%,.4);color:#fff;font-size:24px;width:45px;height:45px;border-radius:8px;cursor:pointer;transition:all .3s ease;align-items:center;justify-content:center;padding:0;margin-right:15px;z-index:calc(var(--z-header) + 1)}.mobile-menu-toggle:hover{background:hsla(0,0%,100%,.3);transform:scale(1.05)}.mobile-menu-toggle:active{transform:scale(.95)}.toast-container{position:fixed;top:24px;right:24px;z-index:var(--z-toast);flex-direction:column;gap:10px;pointer-events:none}.toast,.toast-container{display:flex;max-width:420px}.toast{pointer-events:auto;align-items:flex-start;gap:12px;background:#fff;padding:14px 16px;border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,.14);border-left:4px solid var(--champlain-bright-blue);animation:toastIn .35s cubic-bezier(.21,1.02,.73,1) forwards;font-size:14px;line-height:1.5;color:#333}.toast.toast-exit{animation:toastOut .25s ease forwards}.toast-icon{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;margin-top:1px}.toast-body{flex:1 1;min-width:0}.toast-title{font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px}.toast-message{word-break:break-word;white-space:pre-line}.toast-dismiss{flex-shrink:0;background:none;border:none;color:#aaa;font-size:18px;cursor:pointer;padding:0 2px;line-height:1;transition:color .15s}.toast-dismiss:hover{color:#555}.toast-progress{position:absolute;bottom:0;left:4px;right:0;height:3px;border-radius:0 0 10px 0;background:currentColor;opacity:.25;transform-origin:left}@keyframes toastIn{0%{transform:translateX(120%);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes toastOut{0%{transform:translateX(0);opacity:1;max-height:200px;margin-bottom:0}to{transform:translateX(120%);opacity:0;max-height:0;margin-bottom:-10px}}@keyframes toastProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.toast-success{border-left-color:#4caf50}.toast-success .toast-icon{background:#e8f5e9;color:#2e7d32}.toast-success .toast-title{color:#2e7d32}.toast-error{border-left-color:#f44336}.toast-error .toast-icon{background:#fdecea;color:#c62828}.toast-error .toast-title{color:#c62828}.toast-warning{border-left-color:#ff9800}.toast-warning .toast-icon{background:#fff3e0;color:#e65100}.toast-warning .toast-title{color:#e65100}.toast-info{border-left-color:var(--champlain-bright-blue)}.toast-info .toast-icon{background:#e3f2fd;color:#1565c0}.toast-info .toast-title{color:#1565c0}.feedback-new-badge{display:inline-block;background:#e53935;color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;margin-left:8px;text-transform:uppercase;letter-spacing:.5px;vertical-align:middle;animation:feedbackPulse 1.5s ease-in-out infinite}@keyframes feedbackPulse{0%,to{opacity:1}50%{opacity:.65}}.empty-state{text-align:center;padding:60px 20px;color:#6c757d}.empty-state-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-state-title{font-size:20px;font-weight:700;color:var(--champlain-navy);margin-bottom:10px}.empty-state-description{font-size:14px;color:#6c757d}#networkView{flex:1 1;display:flex;flex-direction:column;overflow:auto;min-height:0}#networkGraph{flex:1 1;width:100%;height:100%;min-height:700px;border-radius:8px}.comparison-btn{background:linear-gradient(135deg,var(--champlain-green) 0,#5a9a3a 100%);color:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;transition:all .3s ease;width:100%;justify-content:center}.comparison-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(116,170,80,.4)}.comparison-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.comparison-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--modal-overlay);z-index:var(--z-modal);align-items:center;justify-content:center;padding:20px}.comparison-modal.active{display:flex}.comparison-content{background:#fff;border-radius:16px;max-width:1200px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3)}.comparison-header{padding:20px 24px;background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-blue) 100%);color:#fff;display:flex;justify-content:space-between;align-items:center}.comparison-header h2{margin:0;font-size:20px;font-weight:700}.comparison-close{background:hsla(0,0%,100%,.2);border:none;color:#fff;width:36px;height:36px;border-radius:8px;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.comparison-close:hover{background:hsla(0,0%,100%,.3)}.comparison-body{padding:24px;overflow-y:auto;flex:1 1}.comparison-table{display:flex;flex-direction:column;gap:0}.comparison-header-row{display:grid;grid-template-columns:220px 1fr;grid-gap:0;gap:0;border-bottom:2px solid var(--champlain-navy);padding-bottom:16px;margin-bottom:8px}.comparison-corner-label{font-size:12px;font-weight:700;color:var(--champlain-blue);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:flex-end;padding-bottom:4px}.comparison-col-header{text-align:center;padding:8px 12px}.comparison-course-code{font-size:16px;font-weight:700;color:var(--champlain-navy);margin-bottom:2px}.comparison-course-name{font-size:13px;color:#666;line-height:1.3}.comparison-course-credits{font-size:12px;color:var(--champlain-blue);font-weight:600;margin-top:4px}.comparison-rows{display:flex;flex-direction:column;gap:0}.comparison-row{display:grid;grid-template-columns:220px 1fr;grid-gap:0;gap:0;padding:10px 0;border-bottom:1px solid #eee;transition:background .15s ease}.comparison-row:hover{background:#f8f9fa}.comparison-row-shared{background:#f1f8e9}.comparison-row-shared:hover{background:#e8f5e9}.comparison-row-label{font-size:13px;font-weight:600;color:#333;display:flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;text-align:center}.comparison-wedge{flex-shrink:0}.comparison-row-cells{display:grid;grid-gap:12px;gap:12px}.comparison-cell{display:flex;flex-direction:column;align-items:center;gap:6px;padding:4px 8px}.comparison-cell-empty{justify-content:center}.comparison-cell-dash{color:#ccc;font-size:14px;font-weight:600}.comparison-competency-weight{font-weight:700;padding:2px 10px;border-radius:12px;font-size:12px;white-space:nowrap}.weight-1{background:#e3f2fd;color:#1565c0}.weight-2{background:#fff3e0;color:#e65100}.weight-3{background:#e8f5e9;color:#2e7d32}.comparison-weight-bar-track{width:100%;max-width:120px;height:6px;background:#e8eaf0;border-radius:3px;overflow:hidden}.comparison-weight-bar{height:100%;border-radius:3px;transition:width .4s ease}.comparison-stats-row{display:grid;grid-template-columns:220px 1fr;grid-gap:0;gap:0;margin-top:12px;padding-top:16px;border-top:2px solid var(--champlain-navy)}.comparison-stat-col{display:flex;flex-direction:column;gap:6px;align-items:center}.comparison-stat{background:#f8f9fa;padding:8px 12px;border-radius:8px;text-align:center;width:100%;max-width:140px}.comparison-stat-value{font-size:18px;font-weight:700;color:var(--champlain-navy)}.comparison-stat-label{font-size:10px;color:#666;text-transform:uppercase;letter-spacing:.3px}.comparison-empty{text-align:center;padding:40px;color:#666}.comparison-empty-icon{font-size:48px;margin-bottom:16px}.export-dropdown{position:relative;display:inline-block}.export-btn{background:linear-gradient(135deg,var(--champlain-blue) 0,var(--champlain-bright-blue) 100%);color:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;transition:all .3s ease}.export-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,169,224,.4)}.export-menu{position:absolute;top:100%;right:0;background:#fff;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.2);min-width:180px;padding:8px;z-index:var(--z-header);display:none;margin-top:8px}.export-menu.active{display:block}.export-menu-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:8px;cursor:pointer;transition:background .2s ease;font-size:14px;color:#333}.export-menu-item:hover{background:#f0f4f8}.export-menu-item .icon{font-size:18px}.export-menu-item .label{font-weight:600}.export-menu-item .desc{font-size:11px;color:#666}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:calc(var(--z-header) - 1);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .3s ease}.touch-active{transform:scale(.95);opacity:.8}@media (max-width:768px){.action-btn,.btn,.toggle-btn{min-height:48px;padding:14px 20px;font-size:16px}.close-btn{min-width:48px;min-height:48px}input,select,textarea{min-height:48px;font-size:16px!important}}.swipe-indicator{display:none}@media (max-width:768px){.swipe-indicator{display:block}}.mobile-scroll-hint{animation:pulse 2s infinite}@media (max-width:1200px){.sidebar{width:360px}.stats-grid{grid-template-columns:1fr}.header-nav-toggle .toggle-btn{padding:7px 12px;font-size:12px}}@media (max-width:768px){.mobile-menu-toggle{display:flex}.main-container{flex-direction:column;position:relative}.sidebar{position:fixed;top:73px;left:0;width:85%;max-width:320px;height:calc(100vh - 73px);border-right:1px solid #e8eaf0;border-bottom:none;z-index:var(--z-header);transform:translateX(-100%);transition:transform .3s ease;background:#fff;box-shadow:2px 0 12px rgba(0,0,0,.15)}.sidebar.sidebar-open{transform:translateX(0)}.sidebar.sidebar-closed{transform:translateX(-100%)}.sidebar-overlay{display:block}.viz-container{padding:15px;width:100%;margin-left:0}.viz-header{margin-bottom:12px}.viz-header h1{font-size:20px}.viz-header p{font-size:13px}.header-nav-toggle.view-toggle{display:none}.view-toggle-mobile{display:flex!important}.graph-wrapper{height:calc(100vh - 320px);padding:15px}#networkGraph,.graph-wrapper{min-height:400px}.competency-table{font-size:11px}.competency-table td,.competency-table th{padding:10px 8px}.competency-table th{font-size:10px}.competency-table th:first-child{min-width:150px}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.competency-grid{grid-template-columns:1fr}.modal-content{width:95%;margin:20px auto;max-height:90vh;overflow-y:auto}.modal-header{padding:20px;position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-raised)}.modal-header h2{font-size:20px}.modal-body{padding:20px;max-height:none}.login-card{padding:30px 25px;margin:15px}.login-title{font-size:26px}.header{padding:12px 15px;flex-wrap:nowrap}.logo-text{font-size:16px;padding-left:12px}.logo-section img{height:40px!important;margin-right:10px!important}.user-info{gap:8px}.user-badge{padding:6px 12px;font-size:11px}.logout-btn{padding:8px 16px;font-size:13px}.stats-grid{grid-template-columns:1fr;gap:12px}.stat-card{padding:18px}.stat-value{font-size:32px}.legend{gap:15px;padding:15px}.legend-item{font-size:12px}.form-group{margin-bottom:20px}.proposal-card{padding:18px}.proposal-header{flex-direction:column;align-items:flex-start;gap:10px}.proposal-actions{flex-direction:column;width:100%}.action-btn{width:100%}.course-search-item{padding:12px}.course-search-code{font-size:13px}.course-search-name{font-size:12px}.selected-course-item{flex-wrap:wrap;gap:8px}.remove-course-btn{margin-left:auto}.section{padding:18px;margin-bottom:18px}.section h3{font-size:15px}.competency-item{font-size:12px}#filterPanel{padding:12px}.filter-checkbox{font-size:11px;padding:8px 10px}#pathwayGraphContainer{flex-direction:column}#pathwayGraphContainer>div{min-width:100%}.pathway-box{height:300px!important}@media (max-width:480px){.user-badge,.viz-header p{display:none}.logo-section img{display:none!important}}}@media (max-width:768px) and (orientation:landscape){.sidebar{width:60%;max-width:280px}.graph-wrapper{height:calc(100vh - 200px)}.modal-content{max-height:85vh}}@media print{.action-btn,.btn,.header,.modal,.sidebar{display:none}.viz-container{padding:0}.graph-wrapper{box-shadow:none;border:1px solid #000}}.action-btn:focus,.btn:focus,.toggle-btn:focus,input:focus,select:focus,textarea:focus{outline:3px solid var(--champlain-bright-blue);outline-offset:2px}@media (prefers-contrast:high){.action-btn,.btn{border-width:3px}.stat-card{border:2px solid #fff}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.action-btn:focus-visible,.btn:focus-visible,.course-search-item:focus-visible{outline:3px solid var(--champlain-bright-blue);outline-offset:3px}.animate-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}.animate-on-scroll.animated{opacity:1;transform:translateY(0)}.animate-on-scroll.delay-1{transition-delay:.1s}.animate-on-scroll.delay-2{transition-delay:.2s}.animate-on-scroll.delay-3{transition-delay:.3s}.animate-on-scroll.delay-4{transition-delay:.4s}.animate-on-scroll.delay-5{transition-delay:.5s}.animate-on-scroll.delay-6{transition-delay:.6s}.hero-text h1{animation:heroSlideUp .7s ease-out both}.hero-text .hero-subtitle{animation:heroSlideUp .7s ease-out .1s both}.hero-text .hero-description{animation:heroSlideUp .7s ease-out .2s both}.hero-stats{animation:heroSlideUp .7s ease-out .3s both}.login-card{animation:heroSlideIn .7s ease-out .2s both}@keyframes heroSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes heroSlideIn{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}.landing-hero:before{animation:floatBlob1 20s ease-in-out infinite}.landing-hero:after{animation:floatBlob2 25s ease-in-out infinite}@keyframes floatBlob1{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-20px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(20px,10px) scale(1.02)}}@keyframes floatBlob2{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-25px,15px) scale(1.03)}66%{transform:translate(15px,-25px) scale(.97)}}.hero-wave svg path{animation:waveFlow 8s ease-in-out infinite;transform-origin:center}@keyframes waveFlow{0%,to{d:path("M0,64L48,69.3C96,75,192,85,288,80C384,75,480,53,576,48C672,43,768,53,864,64C960,75,1056,85,1152,80C1248,75,1344,53,1392,42.7L1440,32L1440,120L1392,120C1344,120,1248,120,1152,120C1056,120,960,120,864,120C768,120,672,120,576,120C480,120,384,120,288,120C192,120,96,120,48,120L0,120Z")}50%{d:path("M0,80L48,74.7C96,69,192,59,288,64C384,69,480,91,576,96C672,101,768,91,864,80C960,69,1056,59,1152,64C1248,69,1344,91,1392,101.3L1440,112L1440,120L1392,120C1344,120,1248,120,1152,120C1056,120,960,120,864,120C768,120,672,120,576,120C480,120,384,120,288,120C192,120,96,120,48,120L0,120Z")}}.hero-stat .stat-number{display:inline-block}.role-btn{position:relative;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.role-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:radial-gradient(circle,hsla(0,0%,100%,.3) 0,transparent 70%);transform:translate(-50%,-50%);transition:width .5s ease,height .5s ease;border-radius:50%;pointer-events:none}.role-btn:hover:before{width:300px;height:300px}.role-btn:hover{transform:translateY(-3px) scale(1.02)}.role-btn:active{transform:translateY(0) scale(.98)}.role-btn:hover .role-icon{animation:iconBounce .5s ease}@keyframes iconBounce{0%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}.feature-card{transition:transform .4s cubic-bezier(.175,.885,.32,1.275),box-shadow .4s ease}.feature-card:hover .feature-icon{animation:featureIconPop .4s ease}@keyframes featureIconPop{0%{transform:scale(1) rotate(0deg)}50%{transform:scale(1.2) rotate(-5deg)}to{transform:scale(1) rotate(0deg)}}.competency-card{transition:transform .4s cubic-bezier(.175,.885,.32,1.275),box-shadow .4s ease}.competency-card:hover .competency-icon{animation:competencyIconSpin .6s ease}@keyframes competencyIconSpin{0%{transform:scale(1) rotate(0deg)}25%{transform:scale(1.1) rotate(-10deg)}75%{transform:scale(1.1) rotate(10deg)}to{transform:scale(1) rotate(0deg)}}.competency-card:before{transition:height .3s ease}.competency-card:hover:before{height:6px}.viz-feature-card:hover .viz-feature-icon{animation:vizIconGlow .5s ease;box-shadow:0 0 20px rgba(0,169,224,.4)}@keyframes vizIconGlow{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.landing-nav-links a{position:relative}.landing-nav-links a:after{content:"";position:absolute;bottom:-4px;left:50%;width:0;height:2px;background:var(--champlain-bright-blue);transition:width .3s ease,left .3s ease}.landing-nav-links a:hover:after{width:100%;left:0}.cta-button,.visualizations-cta .cta-button{position:relative;overflow:hidden}.cta-button:after{content:"";position:absolute;top:50%;left:50%;width:5px;height:5px;background:hsla(0,0%,100%,.5);opacity:0;border-radius:100%;transform:scale(1) translate(-50%);transform-origin:50% 50%}.cta-button:hover:after{animation:ctaRipple 1s ease-out}@keyframes ctaRipple{0%{transform:scale(0);opacity:.5}to{transform:scale(40);opacity:0}}.weight-badge{transition:transform .3s ease,box-shadow .3s ease}.weight-item:hover .weight-badge{transform:scale(1.15);box-shadow:0 4px 15px rgba(0,0,0,.2)}.login-btn{position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);transition:left .5s ease}.login-btn:hover:before{left:100%}.about-header,.competencies-header,.visualizations-header{position:relative}.animate-on-scroll.from-left{opacity:0;transform:translateX(-30px)}.animate-on-scroll.from-left.animated{opacity:1;transform:translateX(0)}.animate-on-scroll.from-right{opacity:0;transform:translateX(30px)}.animate-on-scroll.from-right.animated{opacity:1;transform:translateX(0)}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.animate-on-scroll{opacity:1;transform:none}.dash-stat,.dashboard-card,.dashboard-quick-actions,.dashboard-welcome,.hero-stats,.hero-text .hero-description,.hero-text .hero-subtitle,.hero-text h1,.login-card{animation:none;opacity:1;transform:none}}.dashboard-welcome{animation:dashFadeUp .6s ease-out both}.dash-stat{animation:dashFadeUp .5s ease-out both}.dash-stat:first-child{animation-delay:.1s}.dash-stat:nth-child(2){animation-delay:.2s}.dash-stat:nth-child(3){animation-delay:.3s}.dash-stat:nth-child(4){animation-delay:.4s}.dashboard-quick-actions{animation:dashFadeUp .5s ease-out .3s both}.dashboard-card{animation:dashFadeUp .5s ease-out both}.dashboard-card:first-child{animation-delay:.15s}.dashboard-card:nth-child(2){animation-delay:.25s}.dashboard-card:nth-child(3){animation-delay:.35s}.dashboard-card:nth-child(4){animation-delay:.45s}.dashboard-card:nth-child(5){animation-delay:.55s}@keyframes dashFadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}#dashboardPage{min-height:100vh;background:linear-gradient(135deg,#e8f4fc,#f5f7fa 50%,#f0f4f8)}.dashboard-content{max-width:1200px;margin:0 auto;padding:50px 40px 80px;min-height:calc(100vh - 73px)}.dashboard-welcome{margin-bottom:50px;text-align:center}.dashboard-welcome h1{font-size:36px;font-weight:800;color:var(--champlain-navy);margin-bottom:12px;letter-spacing:-.5px}.dashboard-welcome p{font-size:18px;color:var(--champlain-gray);max-width:600px;margin:0 auto;line-height:1.6}.dashboard-stats-bar{display:flex;gap:20px;margin-bottom:30px;justify-content:center;flex-wrap:wrap}.dash-stat{background:#fff;border-radius:14px;padding:20px 28px;text-align:center;flex:1 1;min-width:140px;max-width:220px;box-shadow:0 2px 12px rgba(0,60,95,.06);border:1px solid rgba(0,60,95,.06);border-top:3px solid transparent;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.dash-stat:first-child{border-top-color:var(--champlain-bright-blue)}.dash-stat:nth-child(2){border-top-color:var(--champlain-gold)}.dash-stat:nth-child(3){border-top-color:var(--champlain-teal)}.dash-stat:nth-child(4){border-top-color:var(--champlain-green)}.dash-stat:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,60,95,.1)}.dash-stat-value{font-size:32px;font-weight:800;color:var(--champlain-navy);line-height:1.2;margin-bottom:4px}.dash-stat-label{font-size:12px;font-weight:600;color:var(--champlain-gray);text-transform:uppercase;letter-spacing:.5px}.dashboard-quick-actions{display:flex;align-items:center;gap:10px;margin-bottom:36px;flex-wrap:wrap;justify-content:center}.quick-actions-label{font-size:13px;font-weight:700;color:var(--champlain-gray);text-transform:uppercase;letter-spacing:.5px;margin-right:4px}.quick-action-pill{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:#fff;border:2px solid #e0e5eb;border-radius:50px;cursor:pointer;font-size:13px;font-weight:600;color:var(--champlain-navy);transition:all var(--transition-normal);white-space:nowrap}.quick-action-pill:hover{border-color:var(--champlain-bright-blue);color:var(--champlain-bright-blue);background:linear-gradient(135deg,#f0faff 0,var(--champlain-lightest-blue) 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,169,224,.15)}.quick-action-pill svg{flex-shrink:0}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));grid-gap:30px;gap:30px}.dashboard-card{background:#fff;border-radius:20px;padding:35px;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 4px 20px rgba(0,60,95,.08);border:1px solid rgba(0,60,95,.06);position:relative;overflow:hidden}.dashboard-card:after{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.dashboard-card:hover{transform:translateY(-8px);box-shadow:0 16px 50px rgba(0,60,95,.15)}.dashboard-card:hover:after{transform:scaleX(1)}.dashboard-card-icon{width:70px;height:70px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:22px}.dashboard-card-icon--viz{background:linear-gradient(135deg,var(--champlain-navy),var(--champlain-blue))}.dashboard-card-icon--competency{background:linear-gradient(135deg,var(--champlain-gold),#e8b040)}.dashboard-card-icon--skillpacks{background:linear-gradient(135deg,var(--champlain-green),var(--champlain-dark-green))}.dashboard-card-icon--proposals{background:linear-gradient(135deg,var(--champlain-blue),var(--champlain-navy))}.dashboard-card-icon--admin{background:linear-gradient(135deg,var(--champlain-red),#a33028)}.dashboard-card h3{font-size:22px;font-weight:700;color:var(--champlain-navy);margin-bottom:12px}.dashboard-card p{font-size:15px;color:var(--champlain-gray);line-height:1.7;margin-bottom:20px}.dashboard-card-tags{display:flex;gap:8px;flex-wrap:wrap}.dashboard-card-tags span{background:linear-gradient(135deg,var(--champlain-lightest-blue) 0,var(--champlain-light-blue) 100%);color:var(--champlain-navy);padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600}.back-to-dashboard-btn{background:transparent;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid hsla(0,0%,100%,.5);color:#fff;padding:10px 24px;border-radius:25px;cursor:pointer;font-weight:700;font-size:14px;transition:all var(--transition-normal)}.back-to-dashboard-btn:hover{background:hsla(0,0%,100%,.15);border-color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px hsla(0,0%,100%,.15)}.landing-footer-mini{text-align:center;padding:20px 40px;background:var(--champlain-dark-blue);color:hsla(0,0%,100%,.6);font-size:14px}.landing-footer-mini p{margin:0}#competenciesPage,#skillPacksPage{min-height:100vh;background:linear-gradient(180deg,#f5f7fa,#fff)}.standalone-page-content{max-width:1200px;margin:0 auto;padding:50px 40px 80px}.mgmt-section{background:#fff;border:1px solid #e2e6ea;border-radius:8px;padding:24px 28px;margin-bottom:24px}.mgmt-section--last{margin-bottom:40px}.mgmt-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.mgmt-section-title{font-size:16px;font-weight:700;color:var(--champlain-navy);margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid #e2e6ea}.mgmt-section-header .mgmt-section-title{margin-bottom:0;padding-bottom:0;border-bottom:none}.btn-primary-action{margin:0;background:var(--champlain-bright-blue);color:#fff;border:none;white-space:nowrap}.mgmt-search-bar{margin-bottom:16px}.mgmt-search-input{width:100%;padding:10px 14px;border:1px solid #ced4da;border-radius:6px;font-size:14px;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.mgmt-search-input:focus{outline:none;border-color:var(--champlain-bright-blue);box-shadow:0 0 0 3px rgba(0,169,224,.15)}.mgmt-list-container{max-height:500px;overflow-y:auto}.standalone-page-header{text-align:center;margin-bottom:60px}.standalone-page-header h1{font-size:42px;font-weight:800;color:var(--champlain-navy);margin-bottom:20px}.standalone-page-header h1:after{content:"";display:block;width:60px;height:3px;background:linear-gradient(90deg,var(--champlain-bright-blue),var(--champlain-teal));margin:16px auto 0;border-radius:2px}.standalone-page-header p{font-size:18px;color:var(--champlain-gray);max-width:700px;margin:0 auto;line-height:1.7}.standalone-page-cta{text-align:center;padding:50px;background:linear-gradient(135deg,var(--champlain-navy) 0,var(--champlain-dark-blue) 100%);border-radius:20px;color:#fff;margin-top:60px}.standalone-page-cta p{font-size:24px;font-weight:600;margin-bottom:25px}.standalone-page-cta .cta-button{display:inline-block;padding:16px 40px;background:linear-gradient(135deg,var(--champlain-bright-blue) 0,var(--champlain-teal) 100%);color:#fff;text-decoration:none;border-radius:30px;font-size:18px;font-weight:700;transition:all var(--transition-normal);box-shadow:0 4px 15px rgba(0,169,224,.4);border:none;cursor:pointer}.standalone-page-cta .cta-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(0,169,224,.5)}@media (max-width:768px){.standalone-page-content{padding:30px 20px 60px}.standalone-page-header h1{font-size:32px}.standalone-page-cta{padding:30px 20px}.standalone-page-cta p{font-size:20px}.dashboard-content{padding:30px 20px 60px}.dashboard-welcome h1{font-size:28px}.dashboard-welcome p{font-size:16px}.dashboard-stats-bar{gap:12px}.dash-stat{padding:14px 16px;min-width:100px}.dash-stat-value{font-size:24px}.dashboard-quick-actions{gap:8px}.quick-actions-label{display:none}.quick-action-pill{padding:8px 14px;font-size:12px}.dashboard-grid{grid-template-columns:1fr;gap:20px}.dashboard-card{padding:25px}.dashboard-card h3{font-size:20px}}