.header{background-color:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 0;position:sticky;top:0;z-index:1000;box-shadow:0 2px 4px #0000000d}.header-container{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;position:relative}.logo{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.3rem;font-weight:700;color:#667eea;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:color .2s;margin-right:30px}.logo:hover{color:#5568d3}.hamburger{display:none;flex-direction:column;justify-content:space-around;width:2rem;height:2rem;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001}.hamburger span{width:2rem;height:.25rem;background-color:#667eea;border-radius:10px;transition:all .3s ease;position:relative;transform-origin:1px}.hamburger.active span:nth-child(1){transform:rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg)}.nav{display:flex;gap:2rem;align-items:center;margin-left:auto}.nav-link{color:#6b7280;text-decoration:none;font-size:1.2rem;font-weight:500;transition:color .2s;white-space:nowrap}.nav-link:hover{color:#667eea}.auth-section{display:flex;align-items:center;gap:1rem}.auth-buttons{display:flex;gap:1rem}.btn-login,.btn-signup{padding:.625rem 1.25rem;border-radius:6px;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .2s;white-space:nowrap}.btn-login{color:#667eea;border:2px solid #667eea;background-color:#fff}.btn-login:hover{background-color:#667eea;color:#fff}.btn-signup{background-color:#667eea;color:#fff;border:2px solid #667eea}.btn-signup:hover{background-color:#5568d3;border-color:#5568d3}.user-menu-wrapper{position:relative}.user-button{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.9375rem!important;font-weight:500;color:#1f2937}.user-button:hover{border-color:#667eea;color:#667eea}.user-button .user-name{color:inherit;font-weight:500;font-size:.9375rem!important}.dropdown-arrow{font-size:.625rem!important;transition:transform .2s;color:#9ca3af}.dropdown-arrow.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;z-index:1002;overflow:hidden;animation:dropdown-fade-in .2s ease}@keyframes dropdown-fade-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:.875rem 1rem;background-color:#f9fafb}.dropdown-user-name{font-size:.9375rem;font-weight:600;color:#1f2937;margin-bottom:.25rem}.dropdown-user-email{font-size:.8125rem;color:#6b7280}.dropdown-divider{height:1px;background-color:#e5e7eb;margin:.25rem 0}.dropdown-item{display:flex;align-items:center;padding:.75rem 1rem;color:#1f2937;text-decoration:none;font-size:.9375rem;font-weight:500;transition:all .2s;cursor:pointer;background:none;border:none;width:100%;text-align:left}.dropdown-item:hover{background-color:#f9fafb;color:#667eea}.dropdown-item.logout{color:#ef4444}.dropdown-item.logout:hover{background-color:#fef2f2;color:#dc2626}.mobile-overlay{display:none}@media(max-width:768px){.header-container{padding:0 1rem}.hamburger{display:flex}.nav{position:fixed;top:0;right:-100%;width:280px;height:100vh;background-color:#fff;flex-direction:column;align-items:flex-start;padding:5rem 2rem 2rem;gap:1.5rem;box-shadow:-2px 0 10px #0000001a;transition:right .3s ease;z-index:1000}.nav.mobile-open{right:0}.nav-link{font-size:1.1rem;width:100%;padding:.75rem 0;border-bottom:1px solid #e5e7eb}.auth-section{position:fixed;top:0;right:-100%;width:280px;height:100vh;background-color:#fff;flex-direction:column;align-items:flex-start;padding:5rem 2rem 2rem;gap:1.5rem;box-shadow:-2px 0 10px #0000001a;transition:right .3s ease;z-index:1000;margin-left:0}.auth-section.mobile-open{right:0}.auth-buttons{flex-direction:column;width:100%;gap:1rem}.btn-login,.btn-signup{width:100%;text-align:center;padding:.875rem}.user-menu-wrapper{width:100%}.user-button{width:100%;justify-content:space-between;padding:.75rem 1rem}.user-dropdown{position:static;box-shadow:none;border:1px solid #e5e7eb;border-radius:8px;margin-top:.5rem}.mobile-overlay{display:block;position:fixed;top:0;left:0;width:100%;height:100vh;background-color:#00000080;z-index:999}}@media(max-width:480px){.logo{font-size:1.25rem}.nav,.auth-section{width:85%;max-width:300px}.nav-link{font-size:1rem}.user-dropdown{min-width:100%}}.footer{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;margin-top:auto}.footer-main{padding:var(--spacing-3xl) 0 var(--spacing-xl);border-bottom:1px solid rgba(255,255,255,.1)}.footer-content{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--spacing-3xl)}.company-info{max-width:500px}.footer-logo{margin-bottom:var(--spacing-lg)}.footer-logo h3{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xs);color:#fff;display:flex;align-items:center;gap:var(--spacing-sm)}.footer-tagline{color:#ffffffb3;font-size:var(--font-size-sm);margin:0;font-style:italic}.company-details{margin-top:var(--spacing-lg)}.company-details p{margin:0;margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);line-height:1.6;color:#ffffffd9}.company-details p strong{color:#fff;font-weight:var(--font-weight-semibold)}.footer-section{display:flex;flex-direction:column}.footer-title{font-size:var(--font-size-lg);margin-bottom:var(--spacing-lg);color:#fff;font-weight:var(--font-weight-semibold);position:relative;padding-bottom:var(--spacing-sm)}.footer-title:after{content:"";position:absolute;left:0;bottom:0;width:40px;height:2px;background:var(--color-primary-light)}.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.footer-links li{margin:0}.footer-links a{color:#ffffffd9;text-decoration:none;font-size:var(--font-size-sm);transition:all var(--transition-fast);display:inline-block;padding:var(--spacing-xs) 0}.footer-links a:hover{color:#fff;padding-left:var(--spacing-sm);text-decoration:none}.footer-link-highlight{display:inline-flex!important;align-items:center;gap:.3rem;color:#a5b4fc!important;font-weight:600;margin-top:.4rem;padding:.32rem .75rem!important;border:1px solid rgba(165,180,252,.4);border-radius:20px;background:#667eea26;transition:all .2s ease!important}.footer-link-highlight:hover{background:#667eea59!important;border-color:#a5b4fcb3!important;color:#fff!important;padding-left:.75rem!important;transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.contact-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.contact-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin:0;font-size:var(--font-size-sm);color:#ffffffd9;line-height:1.6}.contact-item .icon{font-size:var(--font-size-lg);flex-shrink:0;margin-top:2px}.contact-item.email{margin-top:var(--spacing-sm)}.contact-item.email a{color:var(--color-primary-light);text-decoration:none;font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}.contact-item.email a:hover{color:#fff;text-decoration:underline}.footer-bottom{padding:var(--spacing-lg) 0;background:#0003}.footer-bottom p{text-align:center;margin:0;font-size:var(--font-size-sm);color:#fff9}@media(max-width:1024px){.footer-content{grid-template-columns:1fr 1fr;gap:var(--spacing-2xl)}.company-info{grid-column:1 / -1;max-width:100%}}@media(max-width:768px){.footer-main{padding:var(--spacing-2xl) 0 var(--spacing-lg)}.footer-content{grid-template-columns:1fr;gap:var(--spacing-xl)}.footer-logo h3{font-size:var(--font-size-xl)}.footer-title{font-size:var(--font-size-base);margin-bottom:var(--spacing-md)}.company-details{margin-top:var(--spacing-md)}.contact-item{flex-direction:row}}@media(max-width:480px){.footer-main{padding:var(--spacing-xl) 0}.footer-logo h3{font-size:var(--font-size-lg)}.company-details p,.footer-links a,.contact-item{font-size:.75rem}}.banner-container{position:relative;width:100%;height:700px;overflow:hidden;background:#000}.banner-viewport{position:relative;width:100%;height:100%;overflow:hidden}.banner-track{display:flex;height:100%;width:100%}.banner-slide{flex-shrink:0;width:100%;height:100%;position:relative;cursor:pointer}.banner-image{width:100%;height:100%;position:relative}.banner-image img{width:100%;height:100%;object-fit:cover;display:block}.banner-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:transparent;z-index:1;pointer-events:none}.banner-content{position:absolute;z-index:2;color:#fff;max-width:1400px;left:50%;transform:translate(-50%);padding:0 4rem;width:100%}.banner-content.position-left-top{top:4rem}.banner-content.position-left-top>*{text-align:left;margin-left:0;margin-right:auto}.banner-content.position-center-top{top:4rem;text-align:center}.banner-content.position-center-top>*{margin-left:auto;margin-right:auto}.banner-content.position-right-top{top:4rem;text-align:right}.banner-content.position-right-top>*{margin-left:auto;margin-right:0}.banner-content.position-left-center{top:50%;transform:translate(-50%,-50%)}.banner-content.position-left-center>*{text-align:left;margin-left:0;margin-right:auto}.banner-content.position-center-center{top:50%;transform:translate(-50%,-50%);text-align:center}.banner-content.position-center-center>*{margin-left:auto;margin-right:auto}.banner-content.position-right-center{top:50%;transform:translate(-50%,-50%);text-align:right}.banner-content.position-right-center>*{margin-left:auto;margin-right:0}.banner-content.position-left-bottom{top:auto;bottom:4rem}.banner-content.position-left-bottom>*{text-align:left;margin-left:0;margin-right:auto}.banner-content.position-center-bottom{top:auto;bottom:4rem;text-align:center}.banner-content.position-center-bottom>*{margin-left:auto;margin-right:auto}.banner-content.position-right-bottom{top:auto;bottom:4rem;text-align:right}.banner-content.position-right-bottom>*{margin-left:auto;margin-right:0}.banner-title{font-size:3rem;font-weight:700;margin-bottom:1.5rem;line-height:1.2;text-shadow:2px 2px 12px rgba(0,0,0,.8);animation:fadeInUp .8s ease-out .2s backwards;white-space:pre-wrap}.banner-description{font-size:1.25rem;margin-bottom:2rem;opacity:.95;line-height:1.6;text-shadow:none;max-width:700px;animation:fadeInUp .8s ease-out .3s backwards;white-space:pre-wrap}.banner-btn{padding:1rem 2.5rem;font-size:1.125rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block;background:var(--button-bg-color, #667eea);color:#fff;box-shadow:0 6px 20px #667eea66;animation:fadeInUp .8s ease-out .4s backwards}.banner-btn:hover{filter:brightness(.9);transform:translateY(-3px);box-shadow:0 8px 25px #0000004d}.banner-control{position:absolute;top:50%;transform:translateY(-50%);background:#fffffff2;color:#667eea;border:none;width:55px;height:55px;border-radius:50%;font-size:2rem;cursor:pointer;z-index:10;transition:all .3s;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px #0003}.banner-control:hover:not(:disabled){background:#fff;transform:translateY(-50%) scale(1.15);box-shadow:0 8px 25px #0000004d}.banner-control:disabled{opacity:.5;cursor:not-allowed}.banner-control.prev{left:2rem}.banner-control.next{right:2rem}.banner-indicators{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.75rem;z-index:10}.indicator-text{font-size:.875rem;font-weight:600;color:#fff;background:#0009;padding:.4rem 1rem;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.indicator-dots{display:flex;gap:.5rem}.indicator{width:10px;height:10px;border-radius:50%;background:#fff6;border:none;cursor:pointer;transition:all .3s;padding:0}.indicator.active{background:#fff;width:30px;border-radius:5px}.indicator:hover:not(:disabled){background:#ffffffb3}.indicator:disabled{cursor:not-allowed}@media(max-width:1400px){.banner-container{height:750px}.banner-content{padding:0 3rem}.banner-title{font-size:2.5rem}.banner-description{font-size:1.125rem}}@media(max-width:1024px){.banner-container{height:600px}.banner-content{padding:0 2rem}.banner-title{font-size:2rem}.banner-description{font-size:1rem}.banner-btn{padding:.875rem 2rem;font-size:1rem}.banner-content.position-left-top,.banner-content.position-center-top,.banner-content.position-right-top{top:3rem}.banner-content.position-left-bottom,.banner-content.position-center-bottom,.banner-content.position-right-bottom{bottom:3rem}}@media(max-width:768px){.banner-container{height:500px}.banner-content{padding:0 1.5rem}.banner-title{font-size:1.75rem;margin-bottom:1rem}.banner-description{font-size:.875rem;margin-bottom:1.5rem}.banner-btn{padding:.75rem 1.75rem;font-size:.875rem}.banner-control{width:45px;height:45px;font-size:1.5rem}.banner-control.prev{left:1rem}.banner-control.next{right:1rem}.banner-content.position-left-top,.banner-content.position-center-top,.banner-content.position-right-top{top:2rem}.banner-content.position-left-bottom,.banner-content.position-center-bottom,.banner-content.position-right-bottom{bottom:2rem}}@media(max-width:480px){.banner-container{height:400px}.banner-content{padding:0 1rem}.banner-title{font-size:1.5rem}.banner-description{font-size:.8rem;margin-bottom:1rem}.banner-btn{padding:.625rem 1.5rem;font-size:.8rem}.banner-control{width:40px;height:40px;font-size:1.25rem}.banner-control.prev{left:.5rem}.banner-control.next{right:.5rem}.indicator-text{font-size:.75rem;padding:.3rem .75rem}.indicator{width:8px;height:8px}.indicator.active{width:24px}.banner-content.position-left-top,.banner-content.position-center-top,.banner-content.position-right-top{top:1.5rem}.banner-content.position-left-bottom,.banner-content.position-center-bottom,.banner-content.position-right-bottom{bottom:1.5rem}}.banner-track{will-change:transform}.banner-slide{will-change:opacity}:root{--color-primary: #667eea;--color-primary-hover: #5568d3;--color-primary-light: #8b9af7;--color-best: #FFD700;--color-new: #00D4AA;--color-online: #667eea;--color-offline: #FF6B6B;--color-text-primary: #1a1a1a;--color-text-secondary: #4a5568;--color-text-muted: #718096;--color-bg-white: #ffffff;--color-border: #e2e8f0;--color-border-light: #f1f3f5;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .12);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--transition-base: all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}.home-page{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg-white);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans KR,sans-serif}.container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-xl)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-lg)}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.loading-container p{font-size:var(--font-size-lg);color:var(--color-text-secondary);font-weight:500}.courses-section{padding:var(--spacing-3xl) 0 4rem 0;background:var(--color-bg-white);border-bottom:none}.courses-section:nth-child(odd){background:#fafbfc}.courses-section:nth-child(2n){background:var(--color-bg-white)}.courses-section:last-of-type{border-bottom:none}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-lg);padding:0!important;background:transparent!important;border-bottom:none!important;border:none!important}.section-badge{display:none}.section-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);margin:0;letter-spacing:-.3px;border-bottom:none!important;text-decoration:none!important}.section-description{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0;text-align:right;white-space:nowrap}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.course-card-home{background:var(--color-bg-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition-base);cursor:pointer;display:flex;flex-direction:column;height:100%;border:1px solid var(--color-border)}.course-card-home:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:#667eea}.course-thumbnail-wrapper{position:relative;width:100%;height:200px;overflow:hidden;background:#f8f9fa}.course-thumbnail-img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.course-card-home:hover .course-thumbnail-img{transform:scale(1.08)}.thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:var(--font-size-lg);font-weight:600}.badge-overlay{position:absolute;top:var(--spacing-md);left:var(--spacing-md);right:var(--spacing-md);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm)}.course-badge-tag{padding:.375rem .75rem;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.5px;text-transform:uppercase;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.badge-best{background:#ffd700f2;color:#8b6914}.badge-new{background:#00d4aaf2;color:#00725c}.badge-online{background:#5b4ef5f2;color:#fff}.badge-offline{background:#ff6b6bf2;color:#fff}.discount-tag{padding:.375rem .75rem;background:#dc2626f2;color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:700;box-shadow:var(--shadow-sm)}.free-tag{padding:.375rem .75rem;background:#059669f2;color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:700;box-shadow:var(--shadow-sm)}.course-card-content{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1}.course-category-tag{display:inline-block;width:fit-content;font-size:var(--font-size-xs);color:#667eea;font-weight:600;padding:.25rem .625rem;background:#f5f3ff;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px}.course-card-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;min-height:2.8em}.course-instructor-name{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:500;margin:0}.course-meta-info{display:flex;align-items:center;justify-content:space-between;padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);margin-top:auto}.rating-info{display:flex;align-items:center;gap:.25rem;font-size:var(--font-size-sm)}.rating-star{color:#fbbf24;font-size:var(--font-size-base)}.review-count{color:var(--color-text-muted);font-size:var(--font-size-xs)}.student-count{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:500}.course-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--spacing-sm);margin-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.course-level-badge{font-size:var(--font-size-xs);color:var(--color-text-secondary);padding:.25rem .625rem;background:#f8f9fa;border-radius:var(--radius-sm);font-weight:600}.price-original-small{font-size:var(--font-size-xs);color:var(--color-text-muted);text-decoration:line-through}.price-current-bold{font-size:var(--font-size-lg);font-weight:800;color:#667eea;letter-spacing:-.3px}.price-free-label{font-size:var(--font-size-lg);font-weight:800;color:#059669}.view-more{text-align:center;margin-top:var(--spacing-2xl)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;text-decoration:none;transition:var(--transition-base);cursor:pointer;border:none;font-family:inherit}.btn-outline{background:transparent;color:#667eea;border:2px solid var(--color-primary)}.btn-outline:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-lg{padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-lg)}.features-section{padding:var(--spacing-3xl) 0 4rem 0;background:var(--color-bg-white);border-top:none}.features-header{text-align:center;margin-bottom:var(--spacing-3xl)}.features-title{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text-primary);margin-bottom:var(--spacing-sm);letter-spacing:-.5px}.features-subtitle{font-size:var(--font-size-lg);color:var(--color-text-muted);font-weight:400}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-xl)}.feature-card{background:var(--color-bg-white);padding:var(--spacing-xl);border-radius:var(--radius-lg);text-align:center;transition:var(--transition-base);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#667eea}.feature-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.feature-description{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6}@media(max-width:1024px){.container{padding:0 var(--spacing-lg)}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.section-title,.features-title{font-size:var(--font-size-2xl)}}@media(max-width:768px){.courses-section{padding:var(--spacing-2xl) 0}.section-header{margin-bottom:var(--spacing-2xl)}.section-title{font-size:var(--font-size-xl)}.section-description{font-size:var(--font-size-base)}.courses-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.course-thumbnail-wrapper{height:180px}.features-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.features-section{padding:var(--spacing-2xl) 0}.features-title{font-size:var(--font-size-xl)}.btn-lg{width:100%}}@media(max-width:480px){.container{padding:0 var(--spacing-md)}.section-badge{padding:.375rem 1rem;font-size:.625rem}.course-card-title{font-size:var(--font-size-base)}.badge-overlay{top:var(--spacing-sm);left:var(--spacing-sm);right:var(--spacing-sm)}}.section-title-link{cursor:pointer;transition:color .2s ease;text-decoration:none;color:var(--color-text-primary)}.section-title-link:hover{color:#667eea}.badge-cert{display:none}.cert-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.cert-card-home{background:var(--color-bg-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition-base);cursor:pointer;display:flex;flex-direction:column;height:100%;border:1px solid var(--color-border)}.cert-card-home:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:#667eea}.cert-thumbnail-wrapper{position:relative;width:100%;height:180px;overflow:hidden;background:#f0f0ff}.cert-thumbnail-img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.cert-card-home:hover .cert-thumbnail-img{transform:scale(1.08)}.cert-thumbnail-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);gap:8px}.cert-placeholder-icon{font-size:2.5rem;line-height:1}.cert-placeholder-text{color:#fff;font-size:var(--font-size-base);font-weight:700;letter-spacing:1px}.cert-badge-overlay{position:absolute;top:var(--spacing-md);left:var(--spacing-md);right:var(--spacing-md);display:flex;justify-content:space-between;align-items:flex-start}.cert-badge-tag{padding:.375rem .75rem;background:#667eeaf2;color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.5px;text-transform:uppercase;box-shadow:var(--shadow-sm)}.cert-card-content{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1}.cert-card-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;min-height:2.8em}.cert-info-row{display:flex;gap:var(--spacing-md);padding:var(--spacing-sm) 0;border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light)}.cert-info-item{display:flex;flex-direction:column;gap:2px;flex:1}.cert-info-label{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:500}.cert-info-value{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:700}.cert-retry-info{font-size:var(--font-size-xs);color:#4c3db5;background:#f0eeff;padding:.25rem .625rem;border-radius:var(--radius-sm);display:inline-block;width:fit-content;font-weight:500}.cert-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.cert-price-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.cert-price-current{font-size:var(--font-size-lg);font-weight:800;color:#667eea;letter-spacing:-.3px}.cert-apply-btn{font-size:var(--font-size-sm);font-weight:700;color:#667eea;white-space:nowrap;padding:.375rem .75rem;border:1.5px solid #667eea;border-radius:var(--radius-sm);transition:var(--transition-base)}.cert-card-home:hover .cert-apply-btn{background:#667eea;color:#fff}.btn-outline-cert{background:transparent;color:#667eea;border:2px solid #667eea;display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;text-decoration:none;transition:var(--transition-base);cursor:pointer;font-family:inherit}.btn-outline-cert:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 10px 15px #667eea4d}.section-cert{background:inherit}.nav-link-cert{color:#6b7280;font-weight:500;position:relative}.nav-link-cert:after{content:"";position:absolute;bottom:-4px;left:0;width:100%;height:2px;background:#667eea;border-radius:2px;transform:scaleX(0);transition:transform .2s ease}.nav-link-cert:hover:after{transform:scaleX(1)}.nav-link-cert:hover{color:#667eea}@media(max-width:768px){.cert-grid{grid-template-columns:1fr}.cert-thumbnail-wrapper{height:160px}.cert-info-row{gap:var(--spacing-sm)}}@media(max-width:480px){.cert-card-title{font-size:var(--font-size-base)}}.signup-wrapper{min-height:calc(100vh - 160px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl, 2rem) var(--spacing-lg, 1rem);background-color:var(--color-background, #ffffff)}.signup-container{width:100%;max-width:500px;background:#fff;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg, 0 4px 6px rgba(0, 0, 0, .1));padding:var(--spacing-2xl, 2rem)}.signup-title{font-size:var(--font-size-2xl, 1.875rem);font-weight:var(--font-weight-bold, 700);color:var(--color-primary, #1e3a8a);text-align:center;margin-bottom:var(--spacing-2xl, 2rem)}.signup-form{display:flex;flex-direction:column;gap:var(--spacing-lg, 1rem)}.form-item input[type=text],.form-item input[type=email],.form-item input[type=tel],.form-item input[type=password]{width:100%;padding:var(--spacing-md, .75rem);border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, 8px);font-size:var(--font-size-base, 1rem);transition:var(--transition-base, all .2s ease)}.email-check-wrapper{display:flex;gap:var(--spacing-sm, .5rem);align-items:stretch}.email-check-wrapper input{flex:1;min-width:0}.email-check-wrapper input.locked{background-color:var(--color-background-light, #f8f9fa);color:var(--color-text-secondary, #6b7280);cursor:not-allowed;border-color:var(--color-border, #d1d5db)}.check-button{flex-shrink:0;min-width:90px;padding:var(--spacing-md, .75rem) var(--spacing-lg, 1rem);background-color:var(--color-primary, #1e3a8a);color:#fff;border:none;border-radius:var(--radius-md, 8px);font-size:var(--font-size-sm, .875rem);font-weight:var(--font-weight-medium, 500);cursor:pointer;transition:var(--transition-base, all .2s ease);white-space:nowrap}.check-button:hover:not(:disabled){background-color:var(--color-primary-dark, #1e40af);transform:translateY(-1px);box-shadow:var(--shadow-md, 0 2px 4px rgba(0, 0, 0, .1))}.check-button:disabled{background-color:var(--color-border, #d1d5db);cursor:not-allowed;transform:none}.check-button.edit-button{background-color:var(--color-secondary, #f59e0b);color:#fff}.check-button.edit-button:hover:not(:disabled){background-color:#d97706}.checkbox-group{display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem);padding:var(--spacing-lg, 1rem);background-color:var(--color-background-light, #f9fafb);border-radius:var(--radius-md, 8px)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);font-size:var(--font-size-sm, .875rem);color:var(--color-text-primary, #1f2937);cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed}.checkbox-label:first-child{font-weight:var(--font-weight-semibold, 600);color:var(--color-primary, #1e3a8a)}.checkbox-divider{height:1px;background-color:var(--color-border, #e5e7eb);margin:var(--spacing-xs, .25rem) 0}.success-message{display:block;color:var(--color-success, #10b981);font-size:var(--font-size-sm, .875rem);margin-top:var(--spacing-xs, .25rem);font-weight:var(--font-weight-medium, 500)}.success-message:before{content:"✓ ";font-weight:700}.signup-footer{margin-top:var(--spacing-xl, 1.5rem);text-align:center;font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #6b7280)}.signup-footer a{color:var(--color-primary, #1e3a8a);text-decoration:none;font-weight:var(--font-weight-medium, 500);transition:color .2s}.signup-footer a:hover{color:var(--color-primary-dark, #1e40af);text-decoration:underline}@media(max-width:768px){.signup-wrapper{padding:var(--spacing-lg, 1rem)}.signup-container{padding:var(--spacing-xl, 1.5rem)}.signup-title{font-size:var(--font-size-xl, 1.5rem)}.check-button{padding:12px var(--spacing-md, .75rem);font-size:var(--font-size-xs, .75rem);min-width:70px}}@media(max-width:480px){.signup-wrapper{padding:var(--spacing-md, .75rem)}.signup-container{padding:var(--spacing-lg, 1rem);box-shadow:none}.signup-title{font-size:var(--font-size-lg, 1.25rem);margin-bottom:var(--spacing-lg, 1rem)}.form-item input{font-size:var(--font-size-sm, .875rem);padding:var(--spacing-sm, .625rem)}.check-button{padding:10px var(--spacing-sm, .5rem);font-size:var(--font-size-xs, .75rem);min-width:60px}.submit-button{padding:var(--spacing-md, .75rem)}}.login-wrapper{min-height:calc(100vh - 160px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl, 2rem) var(--spacing-lg, 1rem);background-color:var(--color-background, #ffffff)}.login-container{width:100%;max-width:450px;background:#fff;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg, 0 4px 6px rgba(0, 0, 0, .1));padding:var(--spacing-2xl, 2rem)}.login-title{font-size:var(--font-size-2xl, 1.875rem);font-weight:var(--font-weight-bold, 700);color:var(--color-primary, #1e3a8a);text-align:center;margin-bottom:var(--spacing-2xl, 2rem)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg, 1rem)}.form-item input[type=email],.form-item input[type=password]{width:100%;padding:var(--spacing-md, .75rem);border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, 8px);font-size:var(--font-size-base, 1rem);transition:var(--transition-base, all .2s ease)}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper input{flex:1;padding-right:3rem}.password-toggle{position:absolute;right:var(--spacing-md, .75rem);background:none;border:none;cursor:pointer;font-size:1.25rem;padding:var(--spacing-xs, .25rem);opacity:.6;transition:opacity .2s}.password-toggle:hover{opacity:1}.password-toggle:disabled{cursor:not-allowed;opacity:.3}.form-options{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-xs, .25rem)}.remember-me{display:flex;align-items:center;gap:var(--spacing-xs, .5rem);font-size:var(--font-size-sm, .875rem);color:var(--color-text-primary, #1f2937);cursor:pointer}.remember-me input[type=checkbox]{width:16px;height:16px;cursor:pointer}.remember-me input[type=checkbox]:disabled{cursor:not-allowed}.forgot-password{font-size:var(--font-size-sm, .875rem);color:var(--color-primary, #1e3a8a);text-decoration:none;font-weight:var(--font-weight-medium, 500);transition:color .2s}.forgot-password:hover{color:var(--color-primary-dark, #1e40af);text-decoration:underline}.login-footer{margin-top:var(--spacing-xl, 1.5rem);text-align:center;font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #6b7280)}.login-footer a{color:var(--color-primary, #1e3a8a);text-decoration:none;font-weight:var(--font-weight-medium, 500);transition:color .2s}.login-footer a:hover{color:var(--color-primary-dark, #1e40af);text-decoration:underline}@media(max-width:768px){.login-wrapper{padding:var(--spacing-lg, 1rem)}.login-container{padding:var(--spacing-xl, 1.5rem)}.login-title{font-size:var(--font-size-xl, 1.5rem)}}@media(max-width:480px){.login-wrapper{padding:var(--spacing-md, .75rem)}.login-container{padding:var(--spacing-lg, 1rem);box-shadow:none}.login-title{font-size:var(--font-size-lg, 1.25rem);margin-bottom:var(--spacing-lg, 1rem)}.form-item input{font-size:var(--font-size-sm, .875rem);padding:var(--spacing-sm, .625rem)}.submit-button{padding:var(--spacing-md, .75rem)}.form-options{flex-direction:column;gap:var(--spacing-sm, .5rem);align-items:flex-start}}.forgot-password-wrapper{min-height:calc(100vh - 160px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl, 2rem) var(--spacing-lg, 1rem);background-color:var(--color-background, #ffffff)}.forgot-password-container{width:100%;max-width:450px;background:#fff;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg, 0 4px 6px rgba(0, 0, 0, .1));padding:var(--spacing-2xl, 2rem)}.forgot-password-title{font-size:var(--font-size-2xl, 1.875rem);font-weight:var(--font-weight-bold, 700);color:var(--color-primary, #1e3a8a);text-align:center;margin-bottom:var(--spacing-lg, 1rem)}.forgot-password-description{text-align:center;color:var(--color-text-secondary, #6b7280);font-size:var(--font-size-sm, .875rem);line-height:1.6;margin-bottom:var(--spacing-xl, 1.5rem)}.forgot-password-form{display:flex;flex-direction:column;gap:var(--spacing-lg, 1rem)}.form-item{display:flex;flex-direction:column;gap:var(--spacing-xs, .5rem)}.form-item label{font-size:var(--font-size-sm, .875rem);font-weight:var(--font-weight-medium, 500);color:var(--color-text-primary, #1f2937)}.form-item input[type=email]{width:100%;padding:var(--spacing-md, .75rem);border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, 8px);font-size:var(--font-size-base, 1rem);transition:var(--transition-base, all .2s ease)}.form-item input:focus{outline:none;border-color:var(--color-primary, #1e3a8a);box-shadow:0 0 0 3px #1e3a8a1a}.form-item input:disabled{background-color:var(--color-background-light, #f3f4f6);cursor:not-allowed}.error-message{display:block;color:var(--color-error, #ef4444);font-size:var(--font-size-sm, .875rem);margin-top:var(--spacing-xs, .25rem)}.submit-button{width:100%;padding:var(--spacing-lg, 1rem);background-color:var(--color-primary, #1e3a8a);color:#fff;border:none;border-radius:var(--radius-md, 8px);font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-semibold, 600);cursor:pointer;transition:var(--transition-base, all .2s ease);margin-top:var(--spacing-md, .75rem)}.submit-button:hover:not(:disabled){background-color:var(--color-primary-dark, #1e40af);transform:translateY(-2px);box-shadow:var(--shadow-lg, 0 4px 8px rgba(0, 0, 0, .15))}.submit-button:disabled{background-color:var(--color-border, #d1d5db);cursor:not-allowed;transform:none}.forgot-password-footer{margin-top:var(--spacing-xl, 1.5rem);text-align:center}.back-to-login{font-size:var(--font-size-sm, .875rem);color:var(--color-primary, #1e3a8a);text-decoration:none;font-weight:var(--font-weight-medium, 500);transition:color .2s}.back-to-login:hover{color:var(--color-primary-dark, #1e40af);text-decoration:underline}.success-icon{font-size:4rem;text-align:center;margin-bottom:var(--spacing-lg, 1rem)}.success-message-box{background-color:var(--color-background-light, #f0fdf4);border:1px solid #86efac;border-radius:var(--radius-md, 8px);padding:var(--spacing-lg, 1rem);margin-bottom:var(--spacing-xl, 1.5rem)}.success-description{text-align:center;color:var(--color-text-primary, #1f2937);font-size:var(--font-size-base, 1rem);line-height:1.6;margin-bottom:var(--spacing-md, .75rem)}.success-description strong{color:var(--color-primary, #1e3a8a);font-weight:var(--font-weight-semibold, 600)}.success-note{text-align:center;color:var(--color-text-secondary, #6b7280);font-size:var(--font-size-sm, .875rem);line-height:1.5}.success-actions{display:flex;flex-direction:column;gap:var(--spacing-md, .75rem)}.back-to-login-button{display:block;width:100%;padding:var(--spacing-lg, 1rem);background-color:var(--color-primary, #1e3a8a);color:#fff;border:none;border-radius:var(--radius-md, 8px);font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-semibold, 600);text-align:center;text-decoration:none;cursor:pointer;transition:var(--transition-base, all .2s ease)}.back-to-login-button:hover{background-color:var(--color-primary-dark, #1e40af);transform:translateY(-2px);box-shadow:var(--shadow-lg, 0 4px 8px rgba(0, 0, 0, .15))}.resend-button{width:100%;padding:var(--spacing-lg, 1rem);background-color:transparent;color:var(--color-primary, #1e3a8a);border:2px solid var(--color-primary, #1e3a8a);border-radius:var(--radius-md, 8px);font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-semibold, 600);cursor:pointer;transition:var(--transition-base, all .2s ease)}.resend-button:hover{background-color:var(--color-primary, #1e3a8a);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-lg, 0 4px 8px rgba(0, 0, 0, .15))}@media(max-width:768px){.forgot-password-wrapper{padding:var(--spacing-lg, 1rem)}.forgot-password-container{padding:var(--spacing-xl, 1.5rem)}.forgot-password-title{font-size:var(--font-size-xl, 1.5rem)}}@media(max-width:480px){.forgot-password-wrapper{padding:var(--spacing-md, .75rem)}.forgot-password-container{padding:var(--spacing-lg, 1rem);box-shadow:none}.forgot-password-title{font-size:var(--font-size-lg, 1.25rem);margin-bottom:var(--spacing-md, .75rem)}.success-icon{font-size:3rem}.form-item input{font-size:var(--font-size-sm, .875rem);padding:var(--spacing-sm, .625rem)}.submit-button,.back-to-login-button,.resend-button{padding:var(--spacing-md, .75rem)}}.course-card{--color-primary: #667eea;--color-text-primary: #1a1a1a;--color-text-secondary: #4a5568;--color-text-muted: #718096;--color-bg-white: #ffffff;--color-border: #e2e8f0;--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .12);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--transition: all .3s cubic-bezier(.4, 0, .2, 1);background:var(--color-bg-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition);cursor:pointer;display:flex;flex-direction:column;height:100%;border:1px solid var(--color-border)}.course-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:#667eea}.course-thumbnail-wrapper{position:relative;width:100%;height:200px;overflow:hidden;background:#f8f9fa;flex-shrink:0}.course-thumbnail-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.course-card:hover .course-thumbnail-img{transform:scale(1.08)}.thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1rem;font-weight:600}.badge-overlay{position:absolute;top:1rem;left:1rem;right:1rem;display:flex;justify-content:space-between;align-items:flex-start}.badge-right{display:flex;flex-direction:column;gap:.375rem;align-items:flex-end}.discount-tag{padding:.375rem .75rem;background:#dc2626f2;color:#fff;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;box-shadow:0 1px 3px #00000026}.free-tag{padding:.375rem .75rem;background:#059669f2;color:#fff;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;box-shadow:0 1px 3px #00000026}.course-card-content{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;flex:1}.course-category-tag{display:inline-block;width:fit-content;font-size:.75rem;color:#667eea;font-weight:600;padding:.25rem .625rem;background:#f5f3ff;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px}.course-card-title{font-size:1.125rem;font-weight:700;color:var(--color-text-primary);line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;min-height:2.8em}.course-instructor-name{font-size:.875rem;color:var(--color-text-muted);font-weight:500;margin:0}.course-meta-info{display:flex;align-items:center;justify-content:space-between;padding-top:.5rem;border-top:1px solid var(--color-border)}.rating-info{display:flex;align-items:center;gap:.25rem;font-size:.875rem}.rating-star{color:#fbbf24;font-size:1rem}.rating-number{font-weight:600;color:var(--color-text-primary)}.review-count{color:var(--color-text-muted);font-size:.75rem}.student-count{font-size:.75rem;color:var(--color-text-muted);font-weight:500}.course-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;margin-top:auto;border-top:1px solid var(--color-border)}.course-level-badge{font-size:.75rem;color:var(--color-text-secondary);padding:.25rem .625rem;background:#f8f9fa;border-radius:var(--radius-sm);font-weight:600}.course-price-info{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.price-original-small{font-size:.75rem;color:var(--color-text-muted);text-decoration:line-through}.price-current-bold{font-size:1.125rem;font-weight:800;color:#667eea;letter-spacing:-.3px}.price-free-label{font-size:1.125rem;font-weight:800;color:#059669}@media(max-width:768px){.course-card{border-radius:8px}.course-thumbnail-wrapper{height:180px}.course-card-content{padding:1rem}.course-card-title,.price-current-bold{font-size:1rem}}@media(max-width:480px){.course-card-title{font-size:.9375rem}.badge-overlay{top:.75rem;left:.75rem;right:.75rem}}:root{--color-primary: #5624d0;--color-primary-hover: #401bad;--color-text-primary: #1a1a1a;--color-text-secondary: #666;--color-text-muted: #999;--color-bg-light: #f8fafc;--color-bg-white: #ffffff;--color-border: #e5e7eb;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--transition-base: all .3s cubic-bezier(.4, 0, .2, 1)}.course-list-page{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg-white)}.container{max-width:1400px;margin:0 auto;padding:0 2rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-container p{font-size:1.125rem;color:var(--color-text-secondary);font-weight:500}.page-hero{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;padding:4rem 0 3rem;position:relative;overflow:hidden}.page-hero:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at top right,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.page-hero .container{position:relative;z-index:1}.page-title{font-size:3rem;font-weight:800;margin:0 0 1rem;letter-spacing:-1px;animation:fadeInUp .6s ease}.page-subtitle{font-size:1.25rem;opacity:.95;margin:0;font-weight:400;animation:fadeInUp .6s ease .1s both}.filter-section{background:#fff;border-bottom:1px solid var(--color-border);padding:1.5rem 0;box-shadow:0 2px 8px #0000000d}.filter-wrapper{max-width:1400px;margin:0 auto;padding:0 2rem}.filter-bar{display:grid;grid-template-columns:repeat(5,1fr) auto;gap:1.25rem;align-items:end}.filter-group{display:flex;flex-direction:column;gap:.4rem}.filter-group label{font-size:.8125rem;font-weight:600;color:var(--color-text-primary);letter-spacing:-.2px}.filter-select{width:100%;padding:.75rem .875rem;border:2px solid var(--color-border);border-radius:8px;font-size:.9375rem;color:var(--color-text-primary);background:#fff;cursor:pointer;transition:var(--transition-base);font-weight:500}.filter-select:hover{border-color:var(--color-primary)}.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #5624d01a}.btn-reset{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;background:var(--color-bg-light);color:var(--color-text-secondary);border:2px solid var(--color-border);border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition-base);white-space:nowrap;width:auto;height:auto;align-self:flex-end}.btn-reset:hover{background:var(--color-text-secondary);color:#fff;border-color:var(--color-text-secondary)}.result-info{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--color-border)}.result-count{font-size:1.0625rem;color:var(--color-text-secondary);margin:0;font-weight:500}.result-count strong{color:var(--color-primary);font-weight:700;font-size:1.125rem}.courses-section{padding:3rem 0;flex:1}.courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.no-results{text-align:center;padding:5rem 2rem;background:var(--color-bg-light);border-radius:16px}.no-results h3{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem;letter-spacing:-.5px}.no-results p{font-size:1.125rem;color:var(--color-text-secondary);margin:0 0 2rem}.btn-reset-large{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition-base);width:auto}.btn-reset-large:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(min-width:1400px){.container{max-width:1400px}.filter-wrapper{max-width:1400px;padding:0 2rem}}@media(max-width:1200px){.container,.filter-wrapper{padding:0 1.5rem}.filter-bar{grid-template-columns:repeat(3,1fr);gap:1rem}.btn-reset{grid-column:1 / -1;width:100%;justify-content:center}.courses-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}}@media(max-width:768px){.container,.filter-wrapper{padding:0 1rem}.page-hero{padding:2.5rem 0 2rem}.page-title{font-size:1.875rem;line-height:1.2}.page-subtitle{font-size:.9375rem;line-height:1.5}.filter-bar{grid-template-columns:repeat(2,1fr);gap:.75rem}.btn-reset{grid-column:1 / -1;width:100%}.courses-section{padding:2rem 0}.courses-grid{grid-template-columns:1fr;gap:1.25rem}.no-results{padding:3rem 1.5rem;border-radius:12px}.no-results h3{font-size:1.25rem}.no-results p{font-size:.9375rem}}@media(max-width:480px){.container,.filter-wrapper{padding:0 .875rem}.page-title{font-size:1.625rem}.page-subtitle{font-size:.875rem}.filter-bar{grid-template-columns:1fr}.courses-section{padding:1.5rem 0}.no-results{padding:2.5rem 1.25rem}.no-results h3{font-size:1.125rem}}.payment{min-height:100vh;display:flex;flex-direction:column;background-color:#f8f9fa}.payment-main{flex:1;padding:3rem 1.5rem}.payment-container{max-width:1200px;margin:0 auto}.payment-title{font-size:2rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem;text-align:left}.payment-subtitle{font-size:1rem;color:#666;margin-bottom:1.5rem;text-align:left}.payment-test-notice{font-size:.9375rem;color:#ff5757;margin-bottom:2rem;padding:1rem 1.25rem;background:#fff3f3;border-radius:8px;border:1px solid #ffcccc}.payment-section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000000d}.payment-section-title{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0;border-left:4px solid #667eea;padding-left:.75rem}.payment-info-table{display:flex;flex-direction:column;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.payment-info-row{display:grid;grid-template-columns:150px 1fr;border-bottom:1px solid #e0e0e0}.payment-info-row:last-child{border-bottom:none}.payment-info-label{background-color:#f8f9fa;padding:1rem 1.25rem;font-weight:600;color:#666;font-size:.9375rem;display:flex;align-items:center;border-right:1px solid #e0e0e0}.payment-info-value{padding:1rem 1.25rem;color:#1a1a1a;font-size:.9375rem;line-height:1.6;display:flex;align-items:center}.payment-notice-content{padding:1rem;border-radius:8px;line-height:1.8;border:1px solid #e0e0e0}.payment-notice-content p{margin:0;color:#333;font-size:.9375rem}.payment-cert-content{background-color:#f0f4ff;border-color:#c7d4fc}.payment-exam-cert-content{background-color:#fff7ed;border-color:#f9d9a8}.payment-cert-content strong{color:#3b5bdb}.payment-exam-cert-content strong{color:#e67e22}.payment-price-section{border:2px solid #667eea;background:linear-gradient(135deg,#f5f7ff,#fff)}.payment-price-breakdown{display:flex;flex-direction:column;gap:1rem}.payment-price-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0}.payment-price-label{font-size:1rem;color:#666}.payment-price-value{font-size:1rem;color:#1a1a1a;font-weight:600}.payment-original-price{text-decoration:line-through;color:#999;font-weight:400}.payment-discount-value{color:#f44336;font-weight:700}.payment-total-row{border-top:2px solid #667eea;padding-top:1.5rem;margin-top:.5rem}.payment-total-row .payment-price-label{font-size:1.125rem;font-weight:700;color:#1a1a1a}.payment-total-price{font-size:1.5rem;font-weight:700;color:#667eea}.payment-actions{display:flex;gap:1rem;margin-top:2rem}.payment-btn-cancel,.payment-btn-confirm{flex:1;padding:1rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.payment-btn-cancel{background:#fff;color:#666;border:2px solid #e0e0e0}.payment-btn-cancel:hover:not(:disabled){background:#f5f5f5;border-color:#bdbdbd}.payment-btn-cancel:disabled{opacity:.5;cursor:not-allowed}.payment-btn-confirm{background:#667eea;color:#fff}.payment-btn-confirm:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.payment-btn-confirm:disabled{background:#ccc;cursor:not-allowed;transform:none}.payment-btn-spinner{width:18px;height:18px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:paymentSpin .8s linear infinite;flex-shrink:0}@keyframes paymentSpin{to{transform:rotate(360deg)}}.payment-bottom-notice{margin-top:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.payment-bottom-notice p{font-size:.875rem;color:#666;line-height:1.8;margin:.5rem 0}.payment-error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.payment-error-container p{font-size:1.125rem;color:#666}.payment-error-container button{padding:.75rem 2rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.payment-error-container button:hover{background:#5568d3}@media(max-width:768px){.payment-main{padding:2rem 1rem}.payment-container{max-width:100%}.payment-title{font-size:1.5rem}.payment-section{padding:1.5rem}.payment-actions{flex-direction:column}.payment-btn-cancel,.payment-btn-confirm{width:100%}.payment-info-row{grid-template-columns:110px 1fr}.payment-info-label,.payment-info-value{padding:.75rem 1rem;font-size:.875rem}}.payment-btn-toss{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:1rem 2.5rem;background:#0064ff;color:#fff;border:none;border-radius:8px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:background .15s,opacity .15s;min-width:200px}.payment-btn-toss:hover:not(:disabled){background:#0052d9}.payment-btn-toss:disabled{opacity:.6;cursor:not-allowed}.payment-success{min-height:100vh;display:flex;flex-direction:column;background-color:#f8f9fa}.success-main{flex:1;padding:3rem 1.5rem}.success-container{max-width:1200px;margin:0 auto}.success-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem}.success-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:#e8f5e9;border-radius:50%;flex-shrink:0;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.success-header-text{flex:1}.success-title{font-size:2rem;font-weight:700;color:#1a1a1a;margin-bottom:.4rem;text-align:left}.success-subtitle{font-size:1rem;color:#666;line-height:1.6;text-align:left}.success-section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000000d}.success-section-title{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin-bottom:1.5rem;border-left:4px solid #667eea;padding-left:.75rem}.success-info-table{display:flex;flex-direction:column;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.success-info-row{display:grid;grid-template-columns:150px 1fr;border-bottom:1px solid #e0e0e0}.success-info-row:last-child{border-bottom:none}.success-info-label{background-color:#f8f9fa;padding:1rem 1.25rem;font-weight:600;color:#666;font-size:.9375rem;display:flex;align-items:center;border-right:1px solid #e0e0e0}.success-info-value{padding:1rem 1.25rem;color:#1a1a1a;font-size:.9375rem;line-height:1.6;display:flex;align-items:center}.success-course-name{font-weight:600;color:#667eea}.success-total-row{border-top:2px solid #667eea!important;background:linear-gradient(135deg,#f5f7ff,#fff)}.success-total-row .success-info-label{font-size:1rem;font-weight:700;color:#1a1a1a;background:transparent}.success-total-price{font-size:1.5rem!important;font-weight:700;color:#667eea!important}.success-notice-content{padding:1rem;background-color:#fff8e1;border-radius:8px;border:1px solid #ffe082;line-height:1.8}.success-notice-content p{margin:.4rem 0;color:#333;font-size:.9375rem}.success-notice-content strong{color:#1a1a1a;font-weight:600}.success-actions{display:flex;gap:1rem;margin-top:2rem}.success-btn-primary,.success-btn-secondary{flex:1;padding:1rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .3s ease}.success-btn-primary{background:#667eea;color:#fff}.success-btn-primary:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.success-btn-secondary{background:#fff;color:#666;border:2px solid #e0e0e0}.success-btn-secondary:hover{background:#f5f5f5;border-color:#bdbdbd}@media(max-width:768px){.success-main{padding:2rem 1rem}.success-container{max-width:100%}.success-header{flex-direction:column;align-items:flex-start;gap:1rem}.success-icon{width:64px;height:64px}.success-title{font-size:1.5rem}.success-section{padding:1.5rem}.success-info-row{grid-template-columns:110px 1fr}.success-info-label,.success-info-value{padding:.75rem 1rem;font-size:.875rem}.success-total-price{font-size:1.25rem!important}.success-actions{flex-direction:column}.success-btn-primary,.success-btn-secondary{width:100%}}.order-container{width:100%;max-width:1200px;margin:0 auto}.section-title{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0;border-left:4px solid #667eea;padding-left:.75rem}.info-table-label{background-color:#f8f9fa;padding:1rem 1.25rem;font-weight:600;color:#666;font-size:.9375rem;display:flex;align-items:center;border-right:1px solid #e0e0e0}.info-table-value{padding:1rem 1.25rem;color:#1a1a1a;font-size:.9375rem;line-height:1.6;display:flex;align-items:center}.notice-content{padding:1rem;background-color:#fff;border-radius:8px;line-height:1.8;border:1px solid #e0e0e0}.warning-content,.announcement-content{background-color:#fff}.notice-content p{margin:0;color:#333;font-size:.9375rem}.order-info-list{display:flex;flex-direction:column;gap:1rem}.order-info-row{display:flex;justify-content:space-between;align-items:center;padding:.875rem 0;border-bottom:1px solid #f0f0f0}.order-info-row:last-child{border-bottom:none}.order-info-label{font-size:.9375rem;font-weight:600;color:#666}.order-info-value{font-size:.9375rem;color:#1a1a1a;font-weight:500}.discount-row .value.discount{color:#f44336;font-weight:700}.btn-back,.btn-confirm{flex:1;padding:1rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .3s ease}.btn-confirm{background:#667eea;color:#fff}.btn-confirm:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.order-bottom-notice p{font-size:.875rem;color:#666;line-height:1.8;margin:.5rem 0}.spinner{width:48px;height:48px;border:4px solid #f0f0f0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.error-container button{padding:.75rem 2rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}@media(max-width:768px){.order-main{padding:2rem 1rem}.order-container{max-width:100%}.order-title{font-size:1.5rem}.order-section{padding:1.5rem}.order-actions{flex-direction:column}.btn-back,.btn-confirm{width:100%}.info-table-row{grid-template-columns:120px 1fr}.info-table-label,.info-table-value,.order-table-col{padding:.75rem 1rem;font-size:.875rem}.coupon-input-group{flex-direction:column}.btn-apply-coupon{width:100%}}.cert-content{background-color:#f0f4ff;border:1px solid #c7d4fc}.exam-cert-content{background-color:#fff7ed;border:1px solid #f9d9a8}.cert-content strong,.exam-cert-content strong{color:#3b5bdb}.exam-cert-content strong{color:#e67e22}.agree-all-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:1rem;font-weight:700;color:#1a1a1a}.agree-item-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.9375rem;color:#333}.policy-modal-overlay{position:fixed;inset:0;background:#0000008c;z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeInOverlay .15s ease;cursor:default}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.policy-modal{background:#fff;border-radius:14px;width:100%;max-width:1200px;height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040;animation:slideUpModal .2s ease;overflow:hidden}@keyframes slideUpModal{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.policy-modal-content{font-size:.875rem;line-height:1.8;color:#374151;word-break:break-word}.policy-modal-content table th,.policy-modal-content table td{border:1px solid #e5e7eb;padding:6px 10px}@media(max-width:600px){.policy-modal{height:90vh;border-radius:10px 10px 0 0}.agree-item-row{flex-wrap:wrap;gap:8px}}:root{--cv-primary: #667eea;--cv-primary-h: #5a6fd6;--cv-bg: #f0f2f5;--cv-surface: #ffffff;--cv-surface2: #f4f5f8;--cv-border: #e2e4ea;--cv-text: #1a1d27;--cv-text-sub: #6b7280;--cv-topbar-h: 52px;--cv-sidebar-w: 340px;--cv-radius: 10px;--cv-radius-sm: 6px}.cv-page{width:100vw;height:100vh;overflow:hidden;background:var(--cv-bg);color:var(--cv-text);display:flex;flex-direction:column;position:fixed;inset:0;z-index:100}.cv-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem;color:var(--cv-text-sub)}.cv-spinner{width:44px;height:44px;border:4px solid var(--cv-border);border-top-color:var(--cv-primary);border-radius:50%;animation:cv-spin .8s linear infinite}@keyframes cv-spin{to{transform:rotate(360deg)}}.cv-error-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem;text-align:center}.cv-error-icon{font-size:3rem}.cv-error-msg{font-size:1.1rem;color:var(--cv-text-sub);max-width:400px}.cv-btn-back{padding:.65rem 1.5rem;background:var(--cv-primary);color:#fff;border:none;border-radius:50px;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s}.cv-btn-back:hover{background:var(--cv-primary-h)}.cv-topbar{height:var(--cv-topbar-h);flex-shrink:0;display:flex;align-items:center;gap:1rem;padding:0 1.25rem;background:var(--cv-surface);border-bottom:1px solid var(--cv-border);z-index:10;box-shadow:0 1px 4px #0000000f}.cv-btn-topback{padding:.35rem .9rem;background:transparent;border:1px solid var(--cv-border);color:var(--cv-text-sub);border-radius:var(--cv-radius-sm);cursor:pointer;font-size:.82rem;white-space:nowrap;transition:border-color .2s,color .2s;flex-shrink:0}.cv-btn-topback:hover{border-color:var(--cv-primary);color:var(--cv-primary)}.cv-topbar-title{flex:1;font-size:.95rem;font-weight:600;color:var(--cv-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cv-topbar-count{font-size:.8rem;color:var(--cv-text-sub);white-space:nowrap;flex-shrink:0}.cv-layout{display:flex;flex:1;overflow:hidden;min-height:0}.cv-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.cv-player-wrap{position:relative;width:100%;flex-shrink:0;background:#000;max-height:calc(100vh - var(--cv-topbar-h) - 56px - 48px);aspect-ratio:16 / 9}.cv-iframe-wrap,.cv-player{position:absolute;inset:0;width:100%;height:100%}.cv-iframe-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;background:transparent;user-select:none;-webkit-user-select:none}.cv-no-video{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:var(--cv-surface2);color:var(--cv-text-sub)}.cv-no-video-icon{display:none}.cv-no-video p{font-size:1rem;margin:0}.cv-lesson-info{padding:.9rem 1.25rem;border-bottom:1px solid var(--cv-border);background:#fff;flex-shrink:0;overflow-y:auto;max-height:100px}.cv-lesson-title{font-size:1rem;font-weight:700;color:var(--cv-text);margin:0 0 .3rem}.cv-lesson-desc{font-size:.85rem;color:var(--cv-text-sub);margin:0;line-height:1.6}.cv-tabs{height:48px;flex-shrink:0;display:flex;border-top:1px solid var(--cv-border);background:#f8f9fb;overflow-x:auto;scrollbar-width:none}.cv-tabs::-webkit-scrollbar{display:none}.cv-tab-btn{flex:1;min-width:80px;display:flex;align-items:center;justify-content:center;gap:.3rem;padding:0 .5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--cv-text-sub);font-size:.78rem;font-weight:500;cursor:pointer;transition:color .2s,border-color .2s;white-space:nowrap}.cv-tab-btn:hover{color:var(--cv-text)}.cv-tab-btn.active{color:var(--cv-primary);border-bottom-color:var(--cv-primary);background:#667eea1a}.cv-tab-icon{display:none}.cv-sidebar{width:var(--cv-sidebar-w);flex-shrink:0;border-left:1px solid var(--cv-border);background:#f8f9fb;display:flex;flex-direction:column;overflow:hidden}.cv-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem;border-bottom:1px solid var(--cv-border);flex-shrink:0;background:#f2f3f7}.cv-sidebar-title{font-size:.9rem;font-weight:700;color:var(--cv-text);margin:0}.cv-sidebar-total{font-size:.75rem;color:var(--cv-primary);background:#667eea1f;padding:.15rem .55rem;border-radius:50px;font-weight:600}.cv-curriculum{overflow-y:auto;flex:1;padding:.4rem 0;scrollbar-width:thin;scrollbar-color:var(--cv-border) transparent}.cv-curriculum::-webkit-scrollbar{width:4px}.cv-curriculum::-webkit-scrollbar-track{background:transparent}.cv-curriculum::-webkit-scrollbar-thumb{background:var(--cv-border);border-radius:2px}.cv-section{border-bottom:1px solid var(--cv-border)}.cv-sec-head{width:100%;display:flex;align-items:center;gap:.45rem;padding:.65rem 1.25rem;background:transparent;border:none;color:var(--cv-text);font-size:.82rem;font-weight:600;cursor:pointer;text-align:left;transition:background .15s}.cv-sec-head:hover{background:var(--cv-surface2)}.cv-sec-head.open{color:var(--cv-primary)}.cv-sec-arrow{font-size:.6rem;flex-shrink:0}.cv-sec-name{flex:1;line-height:1.35}.cv-sec-cnt{font-size:.72rem;color:var(--cv-text-sub);flex-shrink:0}.cv-lessons{background:#00000008}.cv-lesson-row{width:100%;display:flex;align-items:center;gap:.5rem;padding:.55rem 1.25rem .55rem 2rem;background:transparent;border:none;color:var(--cv-text-sub);font-size:.8rem;cursor:pointer;text-align:left;transition:background .15s,color .15s}.cv-lesson-row:hover{background:var(--cv-surface2);color:var(--cv-text)}.cv-lesson-row.active{background:#667eea1f;color:var(--cv-primary);font-weight:600}.cv-lesson-num{font-size:.72rem;flex-shrink:0;min-width:18px;opacity:.7}.cv-lesson-name{flex:1;line-height:1.35}.cv-lesson-dur{font-size:.72rem;flex-shrink:0;color:var(--cv-text-sub)}.cv-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:1.5rem;animation:cv-fade .15s ease}@keyframes cv-fade{0%{opacity:0}to{opacity:1}}.cv-modal{background:#fff;border-radius:16px;width:100%;max-width:1200px;height:80vh;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 60px #00000080;animation:cv-up .2s ease}@keyframes cv-up{0%{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}.cv-modal-header{display:flex;align-items:center;padding:1.1rem 1.4rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.cv-modal-title{flex:1;font-size:1.05rem;font-weight:700;color:#1a1a2e;margin:0}.cv-modal-close{width:30px;height:30px;border:none;background:#f3f4f6;border-radius:50%;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:background .2s;color:#374151}.cv-modal-close:hover{background:#e5e7eb}.cv-modal-tabs{display:flex;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid #e5e7eb;background:#fafbfc;flex-shrink:0;gap:0;padding:0 .5rem}.cv-modal-tabs::-webkit-scrollbar{display:none}.cv-modal-tab-btn{display:flex;align-items:center;gap:.3rem;padding:.6rem .85rem;background:transparent;border:none;border-bottom:2.5px solid transparent;color:#6b7280;font-size:.78rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s;flex-shrink:0}.cv-modal-tab-btn:hover{color:#374151}.cv-modal-tab-btn.active{color:#667eea;border-bottom-color:#667eea;font-weight:700;background:#667eea0a}.cv-modal-body{overflow-y:auto;padding:1.4rem;flex:1}.cv-modal-text p{color:#374151;font-size:.92rem;line-height:1.8;margin:0 0 .4rem}.cv-modal-empty{text-align:center;color:#9ca3af;font-size:.92rem;padding:2rem 0}.cv-file-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.65rem}.cv-file-item{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;background:#f8f9ff;border-radius:8px;border:1px solid #e5e7eb}.cv-file-icon{font-size:1rem}.cv-file-link{color:#667eea;text-decoration:none;font-size:.88rem;font-weight:500}.cv-file-link:hover{text-decoration:underline}.cv-stats{display:flex;flex-direction:column;gap:.85rem}.cv-stats-row{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0;border-bottom:1px solid #f3f4f6}.cv-stats-label{font-size:.92rem;color:#374151;font-weight:500}.cv-stats-value{font-size:.92rem;color:#667eea;font-weight:700}.cv-progress-bar-wrap{height:8px;background:#e5e7eb;border-radius:50px;overflow:hidden;margin-top:.4rem}.cv-progress-bar{height:100%;background:#667eea;border-radius:50px;transition:width .4s ease}.cv-stats-note{font-size:.78rem;color:#9ca3af;margin:.4rem 0 0}.cv-topbar-progress{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.cv-tp-bar{width:120px;height:6px;background:#dde0e7;border-radius:50px;overflow:hidden}.cv-tp-fill{height:100%;background:var(--cv-primary);border-radius:50px;transition:width .5s ease}.cv-tp-pct{font-size:.78rem;color:var(--cv-primary);font-weight:700;min-width:34px;text-align:right}.cv-cert-badge{font-size:.75rem;background:#667eea1a;color:#667eea;border:1px solid rgba(102,126,234,.25);border-radius:50px;padding:.2rem .6rem;font-weight:600;flex-shrink:0}.cv-yt-container{position:absolute;inset:0;width:100%;height:100%;background:#000}.cv-yt-container>div,.cv-yt-container iframe{width:100%!important;height:100%!important}.cv-lesson-info-row{display:flex;align-items:center;gap:.75rem;justify-content:space-between}.cv-lesson-pct{font-size:.75rem;color:var(--cv-primary);background:#667eea1f;padding:.15rem .5rem;border-radius:50px;font-weight:600;flex-shrink:0}.cv-done-icon{width:10px;height:10px;border-radius:50%;background:#667eea;flex-shrink:0;display:inline-block}.cv-play-icon{width:8px;height:8px;border-radius:50%;background:var(--cv-primary);flex-shrink:0;display:inline-block;box-shadow:0 0 0 2px #667eea40}.cv-todo-icon{width:8px;height:8px;border-radius:50%;border:1.5px solid #cbd5e1;flex-shrink:0;display:inline-block;background:transparent}.cv-note-wrap{display:flex;flex-direction:column;gap:.65rem}.cv-note-label{font-size:.82rem;color:#667eea;font-weight:600;padding:.4rem .75rem;background:#f0f2ff;border-radius:6px}.cv-note-editor{width:100%;min-height:200px;padding:.9rem 1rem;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.9rem;line-height:1.7;resize:vertical;color:#374151;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.cv-note-editor:focus{outline:none;border-color:#667eea}.cv-note-status{font-size:.78rem;color:#9ca3af;text-align:right;margin:0}.cv-qna-wrap{display:flex;flex-direction:column;gap:1.1rem}.cv-qna-input-area{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#f8f9ff;border:1.5px solid #e0e4ff;border-radius:12px}.cv-qna-input-label{font-size:.82rem;color:#374151;margin:0}.cv-qna-input{width:100%;min-height:80px;padding:.75rem .9rem;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.9rem;line-height:1.6;resize:vertical;color:#374151;font-family:inherit;box-sizing:border-box;transition:border-color .2s;background:#fff}.cv-qna-input:focus{outline:none;border-color:#667eea}.cv-qna-input-footer{display:flex;align-items:center;justify-content:space-between}.cv-qna-input-hint{font-size:.72rem;color:#9ca3af}.cv-qna-submit{padding:.5rem 1.3rem;background:#667eea;color:#fff;border:none;border-radius:50px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.cv-qna-submit:hover:not(:disabled){background:#5a6fd6}.cv-qna-submit:disabled{opacity:.45;cursor:not-allowed}.cv-qna-filter{display:flex;gap:.4rem;border-bottom:1px solid #e5e7eb;padding-bottom:.6rem}.cv-qna-filter-btn{padding:.35rem .9rem;background:transparent;border:1.5px solid #e5e7eb;border-radius:50px;font-size:.78rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .18s}.cv-qna-filter-btn:hover{border-color:#667eea;color:#667eea}.cv-qna-filter-btn.active{background:#667eea;border-color:#667eea;color:#fff}.cv-qna-list{display:flex;flex-direction:column;gap:.85rem}.cv-qna-item{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:box-shadow .2s}.cv-qna-item.answered{border-color:#d1d5f7}.cv-qna-item:hover{box-shadow:0 2px 12px #667eea1a}.cv-qna-q{background:#f9fafb;padding:.85rem 1rem}.cv-qna-q-top{display:flex;align-items:center;gap:.45rem;margin-bottom:.45rem}.cv-qna-a{background:#f0f2ff;border-top:1px solid #e0e4ff;padding:.85rem 1rem}.cv-qna-a-top{display:flex;align-items:center;gap:.45rem;margin-bottom:.45rem}.cv-qna-badge{font-size:.68rem;font-weight:700;padding:.12rem .42rem;border-radius:4px;flex-shrink:0;letter-spacing:.03em}.cv-qna-badge.q{background:#e5e7eb;color:#374151}.cv-qna-badge.a{background:#667eea;color:#fff}.cv-qna-date{font-size:.7rem;color:#9ca3af}.cv-qna-lesson-tag{font-size:.68rem;color:#667eea;background:#667eea1a;padding:.1rem .45rem;border-radius:50px;margin-left:auto}.cv-qna-text{font-size:.88rem;color:#374151;margin:0;line-height:1.7;white-space:pre-wrap}.cv-qna-pending{display:flex;align-items:center;gap:.45rem;padding:.6rem 1rem;font-size:.8rem;color:#9ca3af;background:#fafafa;border-top:1px solid #f3f4f6;font-style:italic}.cv-qna-pending-dot{width:7px;height:7px;border-radius:50%;background:#e5e7eb;display:inline-block;animation:cv-blink 1.2s ease-in-out infinite}@keyframes cv-blink{0%,to{opacity:1}50%{opacity:.3}}.cv-qna-empty{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:2.5rem 0;color:#9ca3af;text-align:center}.cv-qna-empty-icon{display:none}.cv-qna-empty p{font-size:.88rem;margin:0}.cv-cert-notice{background:#f4f5f8;border:1px solid #e2e4ea;border-radius:8px;padding:.75rem 1rem;font-size:.88rem;color:#374151;font-weight:600;text-align:center}.cv-stats-section-title{font-size:.82rem;font-weight:700;color:#374151;margin:.5rem 0 .4rem}.cv-lesson-progress-list{display:flex;flex-direction:column;gap:.35rem;margin-top:.4rem}.cv-lp-row{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:#374151;padding:.35rem 0;border-bottom:1px solid #f3f4f6}.cv-lp-icon{flex-shrink:0;font-size:.72rem;font-weight:700;min-width:28px;text-align:center;color:#667eea}.cv-lp-name{flex:1}.cv-lp-pct{color:#667eea;font-weight:600;font-size:.78rem;flex-shrink:0}@media(max-width:1024px){:root{--cv-sidebar-w: 280px}}@media(max-width:768px){.cv-page{position:relative;height:auto;overflow:visible}.cv-layout{flex-direction:column;overflow:visible}.cv-main{overflow:visible}.cv-player-wrap{max-height:none}.cv-sidebar{width:100%;border-left:none;border-top:1px solid var(--cv-border);max-height:360px}.cv-tab-btn{min-width:72px;font-size:.72rem}}.cv-notice-wrap{display:flex;flex-direction:column;gap:1rem}.cv-notice-section{border-radius:12px;overflow:hidden;border:1px solid #e5e7eb}.cv-notice-sec-header{display:flex;align-items:center;gap:.55rem;padding:.75rem 1.1rem;font-weight:700;font-size:.9rem}.cv-notice-sec-icon{display:none}.cv-notice-sec-title{margin:0;font-size:.9rem;font-weight:700}.cv-notice-sec-body{padding:.75rem 1.1rem 1rem;font-size:.9rem;color:#374151;line-height:1.75}.cv-notice-sec-body p{margin:0}.cv-notice-sec-body strong{color:#1a1d27}.cv-notice-announcement .cv-notice-sec-header,.cv-notice-guide .cv-notice-sec-header,.cv-notice-warning .cv-notice-sec-header,.cv-notice-cert .cv-notice-sec-header,.cv-notice-exam .cv-notice-sec-header{background:#f4f5f8;color:#374151;border-bottom:1px solid #e2e4ea}.cv-notice-empty{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:3rem 0;color:#9ca3af;text-align:center;font-size:2rem}.cv-notice-empty p{font-size:.9rem;margin:0}.cv-mat-wrap{display:flex;flex-direction:column;gap:.9rem}.cv-mat-filter{display:flex;gap:.4rem;border-bottom:1px solid #e5e7eb;padding-bottom:.6rem}.cv-mat-filter-btn{padding:.35rem .9rem;background:transparent;border:1.5px solid #e5e7eb;border-radius:50px;font-size:.78rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .18s}.cv-mat-filter-btn:hover{border-color:#667eea;color:#667eea}.cv-mat-filter-btn.active{background:#667eea;border-color:#667eea;color:#fff}.cv-mat-lesson-label{font-size:.82rem;color:#667eea;font-weight:600;padding:.4rem .75rem;background:#f0f2ff;border-radius:6px;margin:0}.cv-file-item{display:flex;align-items:flex-start;gap:.6rem;padding:.75rem 1rem;background:#f8f9ff;border-radius:8px;border:1px solid #e5e7eb;transition:border-color .18s,background .18s}.cv-file-item:hover{border-color:#667eea;background:#f0f2ff}.cv-file-ext{font-size:.65rem;font-weight:700;color:#667eea;background:#667eea1a;border:1px solid rgba(102,126,234,.25);border-radius:4px;padding:.15rem .4rem;flex-shrink:0;align-self:center;letter-spacing:.04em;min-width:34px;text-align:center}.cv-file-info{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0}.cv-file-lesson{font-size:.7rem;color:#667eea;background:#667eea1a;padding:.1rem .45rem;border-radius:50px;align-self:flex-start}.cv-file-link{color:#374151;text-decoration:none;font-size:.88rem;font-weight:500;word-break:break-all;transition:color .15s}.cv-file-link:hover{color:#667eea;text-decoration:underline}.cv-mat-empty{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:2.5rem 0;color:#9ca3af;text-align:center;font-size:1.8rem}.cv-mat-empty p{font-size:.88rem;margin:0;color:#9ca3af}.cv-instructor-card{display:flex;flex-direction:column;gap:0}.cv-instructor-thumb{width:100%;border-bottom:1px solid var(--cv-border, #e2e4ea);background:#000;flex-shrink:0}.cv-instructor-thumb img{width:100%;max-height:340px;object-fit:cover;object-position:center top;display:block;opacity:.95}.cv-instructor-info{padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1rem;background:#fff}.cv-inst-name{font-size:1.3rem;font-weight:700;color:var(--cv-text, #1a1d27);margin:0;line-height:1.3}.cv-inst-row{display:flex;align-items:baseline;gap:.85rem;padding:.6rem 0;border-bottom:1px solid var(--cv-border, #e2e4ea)}.cv-inst-row:last-child{border-bottom:none}.cv-inst-section{display:flex;flex-direction:column;gap:.45rem;padding-top:.25rem}.cv-inst-label{font-size:.78rem;font-weight:700;color:var(--cv-text-sub, #6b7280);white-space:nowrap;min-width:90px;letter-spacing:.02em}.cv-inst-value{font-size:.9rem;color:var(--cv-text, #1a1d27);font-weight:500;line-height:1.5}.cv-inst-pre{font-family:inherit;font-size:.875rem;color:var(--cv-text, #1a1d27);line-height:1.8;white-space:pre-wrap;word-break:break-word;margin:0;padding:.85rem 1rem;background:var(--cv-surface2, #f4f5f8);border-radius:8px;border:1px solid var(--cv-border, #e2e4ea)}@media(max-width:600px){.cv-instructor-thumb img{max-height:200px}.cv-instructor-info{padding:1.1rem 1rem}.cv-inst-row{flex-direction:column;gap:.25rem}.cv-inst-label{min-width:unset}}:root{--primary-color: #667eea;--primary-hover: #5568d3;--text-primary: #1a1a1a;--text-secondary: #333333;--text-tertiary: #767676;--border-color: #e8e8e8;--bg-light: #fafafa;--bg-white: #ffffff;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .12);--shadow-purple: 0 4px 12px rgba(91, 78, 245, .2);--transition: all .2s ease;--max-width: 1400px}.course-detail-public{min-height:100vh;background:var(--bg-white);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans KR,sans-serif}.course-detail-loading,.course-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1.5rem}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.hero-top-section{background:var(--bg-white);padding:2rem 0 1.5rem;border-bottom:1px solid var(--border-color)}.hero-top-container{max-width:var(--max-width);margin:0 auto;padding:0 2rem;display:flex;flex-direction:column;gap:1rem}.hero-top-section .breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-tertiary);font-weight:400;margin-bottom:0}.hero-top-section .breadcrumb span{cursor:pointer;transition:var(--transition)}.hero-top-section .breadcrumb span:hover:not(.separator):not(.current){color:var(--text-primary)}.hero-top-section .breadcrumb .separator{color:var(--text-tertiary)}.hero-top-section .breadcrumb .current{color:var(--text-secondary);font-weight:500}.hero-top-section .category-badge{display:inline-block;padding:.375rem .75rem;background:var(--bg-light);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;font-size:.8125rem;font-weight:600;text-transform:none;letter-spacing:0;width:fit-content}.hero-top-section .hero-title{font-size:2rem;font-weight:700;line-height:1.3;margin:.5rem 0 0;color:var(--text-primary);letter-spacing:-.3px}.hero-top-section .hero-subtitle{font-size:1rem;line-height:1.6;color:var(--text-tertiary);margin:0;font-weight:400}.hero-banner-wrapper{width:100%;background:var(--bg-white);padding:0;border-bottom:1px solid var(--border-color)}.hero-banner{max-width:var(--max-width);margin:0 auto;padding:0 2rem}.hero-banner img{width:100%;max-height:400px;object-fit:cover;border-radius:0;display:block}.instructor-profile-banner-wrapper{width:100%;background:#1a1d27;border-bottom:1px solid var(--border-color)}.instructor-profile-banner{max-width:var(--max-width);margin:0 auto;padding:0 2rem;position:relative;overflow:hidden}.instructor-profile-banner img{width:100%;max-height:360px;object-fit:cover;object-position:center top;display:block}.instructor-profile-overlay{position:absolute;bottom:0;left:2rem;right:2rem;padding:2rem 1.5rem 1.25rem;background:linear-gradient(to top,rgba(0,0,0,.72) 0%,rgba(0,0,0,.35) 60%,transparent 100%);display:flex;flex-direction:column;gap:.3rem}.instructor-profile-label{font-size:.72rem;font-weight:600;color:#ffffffb3;letter-spacing:.08em;text-transform:uppercase}.instructor-profile-name{font-size:1.35rem;font-weight:700;color:#fff;line-height:1.3}.instructor-profile-bio{font-size:.875rem;color:#ffffffd1;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:.15rem}@media(max-width:768px){.instructor-profile-banner img{max-height:220px}.instructor-profile-overlay{left:1rem;right:1rem;padding:1.5rem 1rem 1rem}.instructor-profile-name{font-size:1.1rem}}@media(max-width:480px){.instructor-profile-banner{padding:0}.instructor-profile-overlay{left:0;right:0}.instructor-profile-banner img{max-height:180px}}.hero-section{background:var(--bg-white);color:var(--text-primary);padding:2rem 0 3rem;border-bottom:1px solid var(--border-color)}.hero-container{max-width:var(--max-width);margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr 360px;gap:3rem;align-items:start}.hero-content{display:flex;flex-direction:column;gap:1.5rem}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-tertiary);font-weight:400;margin-bottom:.5rem}.breadcrumb span{cursor:pointer;transition:var(--transition)}.breadcrumb span:hover:not(.separator):not(.current){color:var(--text-primary)}.breadcrumb .separator{color:var(--text-tertiary)}.breadcrumb .current{color:var(--text-secondary);font-weight:500}.category-badge{display:inline-block;padding:.375rem .75rem;background:var(--bg-light);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;font-size:.8125rem;font-weight:600;text-transform:none;letter-spacing:0;width:fit-content}.hero-title{font-size:2rem;font-weight:700;line-height:1.3;margin:.5rem 0 0;color:var(--text-primary);letter-spacing:-.3px}.hero-subtitle{font-size:1rem;line-height:1.6;color:var(--text-tertiary);margin:0;font-weight:400}.hero-meta-row{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin-top:.5rem}.hero-instructor-info{display:flex;gap:2rem}.instructor-item{display:flex;flex-direction:column;gap:.375rem}.instructor-item .label{font-size:.75rem;color:var(--text-tertiary);font-weight:500}.instructor-item .value{font-size:.9375rem;color:var(--text-primary);font-weight:600}.hero-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.hero-tag{padding:.375rem .75rem;background:var(--bg-light);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;font-size:.8125rem;font-weight:500;transition:var(--transition)}.hero-tag:hover{background:var(--border-color)}.target-audience-inline{margin-top:.5rem}.inline-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 .625rem}.inline-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.inline-list li{padding-left:1.25rem;position:relative;font-size:.8125rem;line-height:1.5;color:var(--text-secondary)}.inline-list li:before{position:absolute;left:0;top:0;color:var(--text-tertiary);font-size:1rem;line-height:1.5}.hero-info-plain{margin-top:.5rem}.plain-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem}.plain-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.plain-list li{position:relative;font-size:.9375rem;line-height:1.6;color:var(--text-secondary)}.plain-list li:before{position:absolute;left:0;top:0;color:var(--text-tertiary);font-size:1.25rem;line-height:1.5}.hero-description-card{margin-top:.5rem;padding:1.5rem;background:var(--bg-light);border:1px solid var(--border-color);border-radius:8px}.description-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem}.description-text{font-size:.9375rem;line-height:1.7;color:var(--text-secondary);white-space:pre-wrap}.hero-sidebar{width:360px}.price-card{background:var(--bg-white);border-radius:8px;padding:1.5rem;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);position:sticky;top:90px}.price-card-info{display:flex;flex-direction:column;gap:.75rem;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border-color)}.discount-badge{display:inline-block;background:#ff5757;color:#fff;padding:.375rem .75rem;border-radius:4px;font-size:.8125rem;font-weight:700;width:fit-content;margin-bottom:.75rem}.price-display{display:flex;flex-direction:column;gap:.375rem;margin-bottom:.75rem}.price-original{font-size:1rem;color:var(--text-tertiary);text-decoration:line-through;font-weight:400}.price-current{font-size:2rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.price-free{font-size:2rem;font-weight:700;color:#00c896;letter-spacing:-.5px}.price-info-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.price-info-item:last-child{border-bottom:none}.price-info-label{color:var(--text-tertiary);font-weight:400;font-size:.875rem}.price-info-value{color:var(--text-primary);font-weight:600;font-size:.875rem}.btn-enroll{width:100%;padding:1rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:700;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-purple)}.btn-enroll:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #5b4ef54d}.instructor-detail-card{background:#fff;border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.instructor-detail-banner{width:100%;border-bottom:1px solid var(--border-color)}.instructor-detail-banner img{width:100%;max-height:320px;object-fit:cover;object-position:center top;display:block}.instructor-detail-body{padding:1.75rem 2rem;display:flex;flex-direction:column;gap:1.5rem;background:#fff}.instructor-detail-top{display:flex;align-items:flex-start;gap:1.25rem}.instructor-detail-photo{width:90px;height:116px;object-fit:cover;border-radius:8px;border:1px solid var(--border-color);flex-shrink:0}.instructor-detail-meta{display:flex;flex-direction:column;gap:.3rem;padding-top:.25rem}.instructor-detail-name{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.instructor-detail-position{font-size:.875rem;font-weight:600;color:var(--primary-color);margin:0}.instructor-detail-org{font-size:.875rem;color:var(--text-secondary);margin:0}.instructor-detail-fields{font-size:.8125rem;color:var(--text-tertiary);margin:0;padding:.3rem .75rem;background:#f5f5ff;border-radius:4px;display:inline-block;margin-top:.25rem}.instructor-detail-bio{padding:1.25rem 1.5rem;background:#fafafa;border-radius:8px;border-left:3px solid var(--primary-color)}.instructor-detail-bio p{font-size:.9375rem;color:var(--text-secondary);line-height:1.75;margin:0 0 .4rem}.instructor-detail-bio p:last-child{margin-bottom:0}.instructor-detail-section{border-top:1px solid var(--border-color);padding-top:1.25rem}.instructor-detail-section h4{font-size:.875rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;letter-spacing:.02em}.instructor-detail-section pre{font-family:inherit;font-size:.875rem;color:var(--text-secondary);line-height:1.8;white-space:pre-wrap;word-break:break-word;margin:0;padding:.75rem 1rem;background:#f8f8f8;border-radius:6px}@media(max-width:768px){.instructor-detail-body{padding:1.25rem 1.1rem}.instructor-detail-banner img{max-height:200px}.instructor-detail-photo{width:70px;height:90px}.instructor-detail-name{font-size:1.1rem}}.content-section--instructor{padding:0!important;background:#fff;border:none!important;box-shadow:none!important}.instructor-thumb-only{width:100%;border-radius:0;overflow:hidden}.instructor-thumb-only img{width:100%;max-height:400px;object-fit:cover;object-position:center top;display:block}@media(max-width:768px){.instructor-thumb-only img{max-height:240px}}.detail-tabs-sticky{position:sticky;top:70px;z-index:999;background:#fff;border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.tabs-container{max-width:var(--max-width);margin:0 auto;padding:0 2rem;display:flex;gap:2rem}.tab-anchor{padding:1rem 0;background:none;border:none;font-size:.9375rem;font-weight:600;color:var(--text-tertiary);cursor:pointer;transition:var(--transition);border-bottom:2px solid transparent;white-space:nowrap}.tab-anchor:hover{color:var(--text-primary)}.tab-anchor.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.course-detail-wrapper{max-width:var(--max-width);margin:2rem auto;padding:0 2rem}.detail-main{display:flex;flex-direction:column;gap:2rem}.content-section{background:var(--bg-white);padding:2.5rem;border-radius:8px;border:1px solid var(--border-color);scroll-margin-top:160px}.section-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);letter-spacing:-.3px}.promo-video{margin-bottom:0;border-radius:6px;overflow:hidden;aspect-ratio:16 / 9;background:#000}.promo-video iframe{width:100%;height:100%;border:none}.content-block{margin-bottom:2rem}.content-block:last-child{margin-bottom:0}.block-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.bullet-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.875rem}.bullet-list li{padding-left:1.5rem;position:relative;font-size:.9375rem;line-height:1.6;color:var(--text-secondary)}.bullet-list li:before{position:absolute;left:0;top:0;color:var(--text-tertiary);font-size:1.25rem;line-height:1.5}.description-content{font-size:.9375rem;line-height:1.7;color:var(--text-secondary);white-space:pre-wrap}.detail-images-section{padding:0;background:transparent;border:none}.detail-images-section .section-title{padding:0 2rem;margin-bottom:1.5rem}.detail-images-container{display:flex;flex-direction:column;gap:0;border-radius:0;overflow:visible}.detail-image-card{width:100%;background:var(--bg-white)}.detail-image-card img{width:100%;height:auto;display:block}.curriculum-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.curriculum-header .section-title{margin:0;padding:0;border:none}.btn-toggle-all{padding:.625rem 1.25rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-purple)}.btn-toggle-all:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #5b4ef54d}.curriculum-summary{padding:1rem 1.25rem;background:var(--bg-light);border-radius:6px;margin-bottom:1.5rem;border:1px solid var(--border-color)}.curriculum-summary p{font-size:.9375rem;color:var(--text-primary);margin:0;font-weight:500}.curriculum-list{display:flex;flex-direction:column;gap:.5rem}.curriculum-section-card{border:1px solid var(--border-color);border-radius:6px;overflow:hidden;background:var(--bg-white);transition:var(--transition)}.curriculum-section-card:hover{box-shadow:var(--shadow-sm)}.section-header-bar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--bg-white);cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--border-color)}.section-header-bar:hover{background:var(--bg-light)}.section-info{display:flex;align-items:center;gap:1rem;flex:1}.section-title-text{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.section-meta{font-size:.8125rem;color:var(--text-tertiary);font-weight:400}.section-toggle-btn{background:transparent;color:var(--text-tertiary);border:none;width:24px;height:24px;border-radius:4px;font-size:.75rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.section-toggle-btn:hover{background:var(--bg-light)}.lesson-list{background:var(--bg-white)}.lesson-row{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-bottom:1px solid var(--border-color);transition:var(--transition)}.lesson-row:last-child{border-bottom:none}.lesson-row:hover{background:var(--bg-light)}.lesson-main-info{display:flex;align-items:center;gap:.75rem;flex:1}.lesson-number{width:28px;height:28px;background:var(--bg-light);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600;flex-shrink:0}.lesson-title{font-size:.9375rem;color:var(--text-primary);font-weight:400}.lesson-badge{padding:.25rem .625rem;border-radius:4px;font-size:.75rem;font-weight:600}.lesson-badge.free{background:#e6f7f1;color:#00c896}.lesson-meta-info{display:flex;align-items:center;gap:.75rem}.lesson-duration,.lesson-attachments{font-size:.8125rem;color:var(--text-tertiary);font-weight:400}.reviews-summary{margin-bottom:1.5rem;padding:1.5rem;background:var(--bg-light);border-radius:6px;display:flex;justify-content:center;align-items:center;border:1px solid var(--border-color)}.rating-box{text-align:center}.rating-score{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.rating-stars{font-size:1.25rem;color:#ffc107;margin-bottom:.5rem}.rating-count{font-size:.875rem;color:var(--text-tertiary);margin:0}.reviews-list{display:flex;flex-direction:column;gap:1rem}.review-card{padding:1.25rem;background:var(--bg-light);border-radius:6px;border:1px solid var(--border-color);transition:var(--transition)}.review-card:hover{box-shadow:var(--shadow-sm)}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.review-user{display:flex;align-items:center;gap:.75rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-light);border:2px solid var(--border-color);color:var(--text-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;overflow:hidden}.user-info{display:flex;flex-direction:column;gap:.25rem}.user-info strong{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.review-date{font-size:.8125rem;color:var(--text-tertiary)}.review-rating{font-size:1rem;color:#ffc107}.review-comment{font-size:.9375rem;line-height:1.6;color:var(--text-secondary);margin:0}.policy-block{margin-bottom:1.5rem}.policy-block:last-child{margin-bottom:0}.policy-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.policy-content{padding:1.25rem;background:var(--bg-light);border-radius:6px;border:1px solid var(--border-color)}.policy-content pre{font-family:inherit;font-size:.875rem;line-height:1.7;color:var(--text-secondary);margin:0;white-space:pre-wrap;word-wrap:break-word}.floating-enroll-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border-color);box-shadow:0 -4px 12px #00000014;z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.floating-content{max-width:var(--max-width);margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.floating-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.floating-title{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.floating-price{display:flex;align-items:center;gap:.5rem}.discount-badge-small{padding:.25rem .5rem;background:#ff5757;color:#fff;border-radius:4px;font-size:.75rem;font-weight:700}.price-current-small{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.btn-enroll-floating{padding:.875rem 2rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:.9375rem;font-weight:700;cursor:pointer;transition:var(--transition);white-space:nowrap;box-shadow:var(--shadow-purple)}.btn-enroll-floating:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #5b4ef54d}.cert-notice-row{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1.25rem}.cert-notice-card{display:flex;align-items:flex-start;gap:.875rem;padding:1rem 1.25rem;background:#667eea0d;border:1px solid rgba(102,126,234,.2);border-left:3px solid var(--primary-color);border-radius:6px}.cert-notice-icon{font-size:1.1rem;color:var(--primary-color);flex-shrink:0;margin-top:.1rem}.cert-notice-body{display:flex;flex-direction:column;gap:.25rem}.cert-notice-body strong{font-size:.9375rem;font-weight:700;color:var(--text-primary)}.cert-notice-body p{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.cert-notice-desc{color:var(--text-tertiary);font-size:.8125rem}.btn-already-owned{background:#4caf50!important;color:#fff!important;cursor:pointer}.btn-already-owned:hover{background:#43a047!important}.btn-repurchase{background:#ff9800!important;color:#fff!important}.btn-repurchase:hover{background:#fb8c00!important}.already-owned-notice{margin-top:.75rem;font-size:.875rem;color:#2e7d32;font-weight:500;text-align:center;background:#e8f5e9;border-radius:6px;padding:.5rem .75rem}.expired-notice{margin-top:.75rem;font-size:.875rem;color:#e65100;font-weight:500;text-align:center;background:#fff3e0;border-radius:6px;padding:.5rem .75rem}.btn-already-owned-floating{background:#4caf50!important}.btn-repurchase-floating{background:#ff9800!important}@media(max-width:1024px){.hero-container{grid-template-columns:1fr;gap:2rem}.hero-sidebar{width:100%}.price-card{position:static}}@media(max-width:768px){:root{--max-width: 100%}.hero-banner,.hero-container,.tabs-container,.course-detail-wrapper,.floating-content{padding-left:1rem;padding-right:1rem}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.9375rem}.hero-meta-row{gap:1rem}.target-audience-inline{margin-top:0}.inline-title{font-size:.8125rem}.inline-list li{font-size:.75rem}.hero-info-plain{margin-top:5rem}.plain-title{font-size:.9375rem}.plain-list li{font-size:.875rem}.hero-description-card{padding:1.25rem;margin-top:1.5rem}.description-title{font-size:.9375rem}.description-text{font-size:.875rem}.content-section{padding:1.5rem}.section-title{font-size:1.25rem}.tabs-container{gap:1rem;overflow-x:auto}.tab-anchor{font-size:.875rem;padding:.875rem 0}.floating-content{flex-direction:column;gap:.75rem;padding:1rem}.floating-info{width:100%;text-align:center}.btn-enroll-floating{width:100%}}@media(max-width:480px){.hero-title{font-size:1.25rem}.price-current,.price-free{font-size:1.75rem}.section-title{font-size:1.125rem}.block-title{font-size:1rem}}@media(max-width:768px){.hero-top-section{padding:1.5rem 0 1rem}.hero-top-container{padding:0 1rem;gap:.75rem}.hero-top-section .hero-title{font-size:1.5rem}.hero-top-section .hero-subtitle{font-size:.9375rem}.hero-top-section .breadcrumb{font-size:.75rem}.hero-top-section .category-badge{font-size:.75rem;padding:.3rem .6rem}}.audience-item{font-size:.875rem;color:var(--text-secondary);line-height:1.6}.audience-item:not(:last-child){margin-bottom:.25rem}.course-actions{display:flex;gap:.5rem;margin-top:.75rem}.btn-action{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:#f8f9fa;color:#495057;border:1px solid #e0e0e0;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-action:hover{background:#e9ecef;border-color:#667eea;color:#667eea}.btn-action svg{flex-shrink:0}.btn-action.active{background:#fff0f0;border-color:#ff5757;color:#ff5757}.btn-action.active:hover{background:#ffe5e5}.btn-action span{white-space:nowrap}.cert-notice-card{padding:.875rem 1rem}.cert-sale-deadline{font-size:.78rem;color:#ef4444;margin:-8px 0 8px}.cert-block{margin-bottom:2rem}.cert-check-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:12px}.cert-check-list li{display:flex;align-items:flex-start;gap:10px;font-size:.9375rem;color:var(--text-secondary);line-height:1.6}.cert-check-icon{flex-shrink:0;width:22px;height:22px;background:#ede9fe;color:#7c3aed;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;margin-top:1px}.cert-video-wrap{position:relative;padding-bottom:56.25%;height:0;border-radius:12px;overflow:hidden;background:#000;margin-top:12px}.cert-video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none}.cert-related-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.cert-related-chip{padding:8px 16px;background:#ede9fe;color:#6d28d9;border-radius:20px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s}.cert-related-chip:hover{background:#ddd6fe}.cert-exam-overview{display:flex;gap:14px;flex-wrap:wrap;margin:16px 0 28px}.cert-exam-stat{flex:1;min-width:110px;background:var(--bg-white);border-radius:12px;padding:18px 14px;text-align:center;box-shadow:var(--shadow-md);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:6px}.cert-exam-stat-val{font-size:1.45rem;font-weight:800;color:#4f46e5}.cert-exam-stat-label{font-size:.75rem;color:var(--text-tertiary)}.cert-sub-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:24px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.cert-table-wrap{overflow-x:auto;border-radius:10px;box-shadow:var(--shadow-md);margin-bottom:24px}.cert-table{width:100%;border-collapse:collapse;background:var(--bg-white);font-size:.875rem}.cert-table th{background:var(--bg-light);padding:12px 16px;text-align:left;font-weight:600;color:#475569;white-space:nowrap}.cert-table td{padding:12px 16px;border-bottom:1px solid var(--bg-light);color:var(--text-secondary)}.cert-table tfoot td{background:var(--bg-light);font-weight:700;border-top:2px solid var(--border-color);border-bottom:none}.cert-notice-blocks{display:flex;flex-direction:column;gap:12px;margin-top:20px}.cert-notice-block{padding:16px 18px;border-radius:10px;border-left:4px solid}.cert-notice-block h3{font-size:.875rem;font-weight:700;margin-bottom:8px}.cert-notice-block pre{font-family:inherit;font-size:.875rem;white-space:pre-wrap;line-height:1.7}.cert-notice--blue{background:#eff6ff;border-color:#3b82f6;color:#1e40af}.cert-notice--green{background:#f0fdf4;border-color:#22c55e;color:#166534}.cert-notice--yellow{background:#fffbeb;border-color:#f59e0b;color:#92400e}.cert-issuer-card{display:flex;align-items:center;gap:20px;padding:22px;background:var(--bg-white);border-radius:12px;box-shadow:var(--shadow-md);margin-bottom:16px;border:1px solid var(--border-color)}.cert-issuer-logo{width:80px;height:80px;object-fit:contain;border-radius:10px;border:1px solid var(--border-color);flex-shrink:0}.cert-issuer-name{font-size:1.05rem;font-weight:700;margin-bottom:6px;color:var(--text-primary)}.cert-issuer-desc{font-size:.875rem;color:var(--text-tertiary);line-height:1.6}.cert-issuer-rows{background:var(--bg-white);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.cert-issuer-row{display:flex;align-items:center;padding:13px 20px;border-bottom:1px solid var(--bg-light);font-size:.875rem}.cert-issuer-row:last-child{border-bottom:none}.cert-issuer-row-label{width:140px;flex-shrink:0;color:var(--text-tertiary)}.cert-issuer-row-val{color:var(--text-primary);font-weight:600}a.cert-issuer-row-val{color:#4f46e5;text-decoration:none}a.cert-issuer-row-val:hover{text-decoration:underline}.cert-steps{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:16px 0 28px}.cert-step{display:flex;align-items:center;gap:8px}.cert-step-num{width:30px;height:30px;background:#4f46e5;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700;flex-shrink:0}.cert-step-text{padding:9px 14px;background:var(--bg-white);border:1.5px solid var(--border-color);border-radius:8px;font-size:.875rem;color:var(--text-secondary);box-shadow:var(--shadow-sm)}.cert-step-arrow{font-size:1.4rem;color:#94a3b8}.cert-info-cards{display:flex;gap:14px;flex-wrap:wrap;margin-top:16px}.cert-info-card{flex:1;min-width:150px;background:var(--bg-white);border-radius:12px;padding:18px 16px;box-shadow:var(--shadow-md);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:6px}.cert-info-icon{font-size:1.4rem}.cert-info-card strong{font-size:.875rem;font-weight:700;color:var(--text-primary)}.cert-info-card p{font-size:.82rem;color:var(--text-tertiary);line-height:1.5}.cert-info-card--format{border-color:#c7d2fe;background:#eef2ff}.cert-info-card--format strong{color:#4338ca}.cert-info-card--format p{color:#4338ca;font-weight:600;font-size:.875rem}.hero-benefits .cert-check-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.hero-benefits .cert-check-list li{display:flex;align-items:flex-start;gap:8px;font-size:.875rem;color:var(--text-primary);line-height:1.55}.hero-benefits .cert-check-icon{color:#7c3aed;font-weight:700;flex-shrink:0;margin-top:1px}.cert-career-list{display:flex;flex-direction:column;gap:16px;margin-top:16px}.cert-career-item{background:var(--bg-white);border-radius:12px;padding:22px 24px;box-shadow:var(--shadow-md);border:1px solid var(--border-color);transition:box-shadow .2s}.cert-career-item:hover{box-shadow:var(--shadow-lg)}.cert-career-item-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.cert-career-num{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:#7c3aed;color:#fff;font-size:.8125rem;font-weight:800;display:flex;align-items:center;justify-content:center}.cert-career-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.cert-career-content{font-size:.875rem;color:var(--text-secondary);line-height:1.7;margin:0;padding-left:40px}.cert-img-modal{position:fixed;inset:0;background:#000000d9;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.cert-img-modal-inner{position:relative}.cert-img-modal-inner img{max-width:90vw;max-height:85vh;border-radius:10px;display:block}.cert-img-modal-close{position:absolute;top:-14px;right:-14px;width:30px;height:30px;background:#ef4444;color:#fff;border:none;border-radius:50%;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center}@media(max-width:600px){.cert-exam-overview{gap:8px}.cert-exam-stat{min-width:80px;padding:12px 8px}.cert-steps{flex-direction:column;align-items:flex-start}.cert-step-arrow{transform:rotate(90deg)}.cert-info-cards{flex-direction:column}.cert-issuer-card{flex-direction:column;text-align:center}.cert-issuer-row-label{width:110px}}.order-confirmation{min-height:100vh;display:flex;flex-direction:column;background-color:#f8f9fa}.order-main{flex:1;padding:3rem 1.5rem}.order-container{max-width:1200px;margin:0 auto}.order-title{font-size:2rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.order-subtitle{font-size:1rem;color:#666;margin-bottom:2rem}.order-section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000000d}.section-title{font-size:1.125rem;font-weight:700;color:#1a1a1a;margin-bottom:1.5rem;padding-bottom:.75rem;padding-left:.75rem;border-bottom:2px solid #f0f0f0;border-left:4px solid #667eea}.cert-thumb-row{margin-bottom:1.25rem}.cert-order-thumb{width:100%;max-height:200px;object-fit:cover;border-radius:10px;border:1px solid #e5e7eb}.course-info-table{display:flex;flex-direction:column;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.info-table-row{display:grid;grid-template-columns:150px 1fr;border-bottom:1px solid #e0e0e0}.info-table-row:last-child{border-bottom:none}.info-table-label{background-color:#f8f9fa;padding:.875rem 1.25rem;font-weight:600;color:#555;font-size:.875rem;display:flex;align-items:center;border-right:1px solid #e0e0e0}.info-table-value{padding:.875rem 1.25rem;color:#1a1a1a;font-size:.9375rem;line-height:1.6;display:flex;align-items:center}.applicant-form{display:flex;flex-direction:column;gap:1.125rem}.applicant-field{display:flex;flex-direction:column;gap:6px}.applicant-label{font-size:.875rem;font-weight:600;color:#374151}.applicant-label .required{color:#dc2626;margin-left:2px}.applicant-input{padding:.75rem 1rem;font-size:.9375rem;border:1.5px solid #d1d5db;border-radius:8px;outline:none;transition:border-color .15s,box-shadow .15s}.applicant-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1f}.applicant-input.input-error{border-color:#dc2626!important}.field-error-msg{font-size:.8rem;color:#dc2626;margin:0;font-weight:500}.notice-content{padding:1rem 1.25rem;background-color:#f9fafb;border-radius:8px;line-height:1.8;border:1px solid #e5e7eb}.warning-content{background-color:#fffbeb;border-color:#fde68a}.announcement-content{background-color:#eff6ff;border-color:#bfdbfe}.notice-content p{margin:0;color:#374151;font-size:.9375rem}.policy-sub-block{margin-bottom:1.25rem}.policy-sub-block:last-child{margin-bottom:0}.policy-sub-title{font-size:.875rem;font-weight:700;color:#374151;margin:0 0 8px}.agree-list{display:flex;flex-direction:column;gap:0}.agree-all-row{padding:12px 14px;background:#f0f4ff;border-radius:8px;margin-bottom:14px}.agree-all-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:1rem;font-weight:700;color:#1a1a1a;text-decoration:none!important}.agree-all-label input{width:18px;height:18px;accent-color:#667eea;cursor:pointer;flex-shrink:0}.agree-divider{height:1px;background:#e0e0e0;margin:2px 0 6px}.agree-item-row{display:flex;align-items:center;justify-content:space-between;padding:12px 4px;border-bottom:1px solid #f5f5f5}.agree-item-row:last-child{border-bottom:none}.agree-item-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.9375rem;color:#333;text-decoration:none!important}.agree-item-label input{width:16px;height:16px;accent-color:#667eea;cursor:pointer;flex-shrink:0}.btn-view-policy{padding:5px 14px;font-size:.8125rem;font-weight:500;color:#667eea;background:#fff;border:1px solid #667eea;border-radius:6px;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}.coupon-input-area{display:flex;flex-direction:column;gap:1rem}.coupon-input-group{display:flex;gap:.75rem}.coupon-input{flex:1;padding:.875rem 1rem;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:border-color .3s ease}.coupon-input:focus{border-color:#667eea}.coupon-input::placeholder{color:#999}.btn-apply-coupon{padding:.875rem 2rem;font-size:1rem;font-weight:600;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-apply-coupon:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.coupon-error{font-size:.875rem;color:#f44336;margin:0}.coupon-applied{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#e8f5e9;border-radius:8px;border-left:4px solid #4caf50}.coupon-success{font-size:.9375rem;font-weight:600;color:#2e7d32}.coupon-discount-amount{font-size:1rem;font-weight:700;color:#f44336}.price-section{border:2px solid #667eea;background:linear-gradient(135deg,#f5f7ff,#fff)}.price-breakdown{display:flex;flex-direction:column;gap:1rem}.price-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0}.price-row .label{font-size:1rem;color:#666}.price-row .value{font-size:1rem;color:#1a1a1a;font-weight:600}.discount-row .value.discount{color:#16a34a;font-weight:700}.total-row{border-top:2px solid #667eea;padding-top:1.5rem;margin-top:.5rem}.total-row .label{font-size:1.125rem;font-weight:700;color:#1a1a1a}.total-price{font-size:1.5rem;font-weight:700;color:#667eea}.order-actions{display:flex;gap:1rem;margin-top:2rem}.btn-back,.btn-confirm{flex:1;padding:1rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.btn-back{background:#fff;color:#666;border:2px solid #e0e0e0}.btn-back:hover{background:#f5f5f5;border-color:#bdbdbd}.btn-confirm{background:#667eea;color:#fff;box-shadow:0 4px 14px #667eea59}.btn-confirm:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 6px 18px #667eea66}.btn-confirm:disabled,.btn-confirm.btn-submitting{background:#a5b4fc;cursor:not-allowed;transform:none;box-shadow:none}.order-bottom-notice{margin-top:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.order-bottom-notice p{font-size:.875rem;color:#666;line-height:1.8;margin:.25rem 0}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.spinner{width:48px;height:48px;border:4px solid #e8ecfd;border-top:4px solid #667eea;border-radius:50%;animation:spin .7s linear infinite}.error-container p{font-size:1rem;color:#666}.error-container button{padding:.75rem 2rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}.error-container button:hover{background:#5568d3}@media(max-width:640px){.order-main{padding:1.5rem 1rem}.order-title{font-size:1.5rem}.order-section{padding:1.5rem}.order-actions{flex-direction:column}.btn-back,.btn-confirm{width:100%}.info-table-row{grid-template-columns:110px 1fr}.info-table-label,.info-table-value{padding:.75rem 1rem;font-size:.875rem}.cert-order-thumb{max-height:140px}}.btn-view-policy{flex-shrink:0;padding:4px 12px;font-size:.8rem;font-weight:600;color:#667eea;background:transparent;border:1.5px solid #667eea;border-radius:6px;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s;line-height:1.5}.btn-view-policy:hover{background:#667eea;color:#fff}.policy-modal-overlay{position:fixed;inset:0;background:#0000008c;z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease;cursor:default}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.policy-modal{background:#fff;border-radius:14px;width:100%;max-width:1200px;height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040;animation:slideUp .2s ease;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.policy-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #f0f0f0;flex-shrink:0}.policy-modal-title{font-size:1.125rem;font-weight:700;color:#1a1a1a;margin:0}.policy-modal-close{width:32px;height:32px;border:none;background:#f5f5f5;border-radius:50%;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#555;transition:background .15s;flex-shrink:0}.policy-modal-close:hover{background:#e5e7eb;color:#1a1a1a}.policy-modal-body{flex:1;overflow-y:auto;padding:20px 24px;-webkit-overflow-scrolling:touch}.policy-modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 0;color:#888;font-size:.9rem}.policy-modal-content{font-size:.875rem;line-height:1.8;color:#374151;word-break:break-word;margin:0;font-family:inherit}.policy-modal-content h1,.policy-modal-content h2,.policy-modal-content h3,.policy-modal-content h4{font-size:1rem;font-weight:700;margin:16px 0 8px;color:#111827}.policy-modal-content p{margin:0 0 10px}.policy-modal-content ul,.policy-modal-content ol{padding-left:20px;margin:6px 0 12px}.policy-modal-content li{margin-bottom:4px}.policy-modal-content table{width:100%;border-collapse:collapse;margin:12px 0;font-size:.8125rem}.policy-modal-content table th,.policy-modal-content table td{border:1px solid #e5e7eb;padding:6px 10px;text-align:left}.policy-modal-content table th{background:#f9fafb;font-weight:600}.policy-modal-content strong{font-weight:700}.policy-modal-content a{color:#667eea;text-decoration:underline}.policy-modal-footer{padding:14px 24px 20px;border-top:1px solid #f0f0f0;text-align:right;flex-shrink:0}.btn-policy-confirm{padding:9px 28px;font-size:.9375rem;font-weight:600;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .15s}.btn-policy-confirm:hover{background:#5568d3}@media(max-width:640px){.policy-modal{height:90vh;border-radius:10px 10px 0 0}.policy-modal-overlay{align-items:flex-end;padding:0}}:root{--ocd-primary: #667eea;--ocd-primary-hover: #5a6fd6;--ocd-primary-light: #eef2ff;--ocd-primary-mid: #c7d2fe;--ocd-bg: #ffffff;--ocd-card-bg: #ffffff;--ocd-surface: #f8f9ff;--ocd-border: #e8eaf6;--ocd-border-strong: #c7d2fe;--ocd-text: #1a1a2e;--ocd-sub: #6b7280;--ocd-sub-light: #9ca3af;--ocd-shadow: 0 1px 8px rgba(102,126,234,.08);--ocd-shadow-md: 0 4px 20px rgba(102,126,234,.12);--ocd-shadow-lg: 0 8px 32px rgba(102,126,234,.16);--ocd-radius: 16px;--ocd-radius-sm: 10px;--ocd-radius-xs: 6px}.ocd-page{min-height:100vh;display:flex;flex-direction:column;background:var(--ocd-bg)}.ocd-container{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2.5rem 2rem 6rem}.ocd-back-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem 1.1rem;background:transparent;color:var(--ocd-sub);font-size:.875rem;font-weight:600;border:1.5px solid #d1d5db;border-radius:50px;cursor:pointer;transition:border-color .18s,color .18s;margin-bottom:1.75rem;letter-spacing:-.01em}.ocd-back-btn:hover{border-color:var(--ocd-primary);color:var(--ocd-primary)}.ocd-hero{display:grid;grid-template-columns:300px 1fr;background:var(--ocd-card-bg);border-radius:var(--ocd-radius);box-shadow:var(--ocd-shadow-lg);overflow:hidden;margin-bottom:1.5rem;border:1px solid var(--ocd-border)}.ocd-hero-thumb{position:relative;height:220px;background:var(--ocd-primary-light);flex-shrink:0}.ocd-hero-img{width:100%;height:100%;object-fit:cover;display:block}.ocd-hero-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--ocd-primary-light) 0%,var(--ocd-primary-mid) 100%)}.ocd-badge-offline{position:absolute;top:12px;left:12px;background:var(--ocd-primary);color:#fff;font-size:.72rem;font-weight:700;padding:.22rem .7rem;border-radius:50px;letter-spacing:.04em}.ocd-hero-info{padding:1.75rem 2rem;display:flex;flex-direction:column;justify-content:center;gap:.55rem}.ocd-title{font-size:1.5rem;font-weight:800;color:var(--ocd-text);margin:0;line-height:1.35;letter-spacing:-.025em}.ocd-subtitle{font-size:.93rem;color:var(--ocd-sub);margin:0;line-height:1.55}.ocd-meta-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.3rem}.ocd-tag{display:inline-flex;align-items:center;padding:.22rem .65rem;border-radius:50px;font-size:.77rem;font-weight:600;letter-spacing:.01em}.ocd-tag--level{background:var(--ocd-primary-light);color:var(--ocd-primary)}.ocd-tag--duration,.ocd-tag--count,.ocd-tag--time{background:#f3f4f6;color:#4b5563}.ocd-tag--type{background:var(--ocd-primary);color:#fff}.ocd-section{background:var(--ocd-card-bg);border-radius:var(--ocd-radius);padding:2rem;box-shadow:var(--ocd-shadow);border:1px solid var(--ocd-border);margin-bottom:1.5rem}.ocd-section-title{font-size:1rem;font-weight:700;color:var(--ocd-text);margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--ocd-primary);letter-spacing:-.01em}.ocd-description{font-size:.94rem;color:#374151;line-height:1.9;margin:0;white-space:pre-line}.ocd-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.65rem}.ocd-list-item{display:flex;align-items:flex-start;gap:.75rem;font-size:.92rem;color:#374151;line-height:1.55}.ocd-list-dot{flex-shrink:0;width:6px;height:6px;border-radius:50%;background:var(--ocd-primary);margin-top:.5rem}.ocd-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.ocd-two-col .ocd-section{margin-bottom:0}.ocd-instructor-card{display:flex;gap:1.5rem;align-items:flex-start}.ocd-instructor-avatar{flex-shrink:0;width:80px;height:80px;border-radius:50%;overflow:hidden;border:2px solid var(--ocd-border-strong)}.ocd-instructor-img{width:100%;height:100%;object-fit:cover;display:block}.ocd-instructor-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--ocd-primary-light);color:var(--ocd-primary);font-size:1.6rem;font-weight:800;letter-spacing:-.02em}.ocd-instructor-body{flex:1;display:flex;flex-direction:column;gap:.35rem}.ocd-instructor-name{font-size:1.1rem;font-weight:800;color:var(--ocd-text);margin:0;letter-spacing:-.02em}.ocd-instructor-badge{display:inline-flex;align-items:center;padding:.15rem .6rem;background:var(--ocd-primary-light);color:var(--ocd-primary);font-size:.72rem;font-weight:700;border-radius:50px;width:fit-content;letter-spacing:.02em}.ocd-instructor-bio{font-size:.9rem;color:var(--ocd-sub);margin:.3rem 0 0;line-height:1.75;white-space:pre-line}.ocd-curriculum-summary{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--ocd-sub);font-weight:500;margin-bottom:1.1rem;padding:.65rem 1rem;background:var(--ocd-surface);border-radius:var(--ocd-radius-sm);border:1px solid var(--ocd-border)}.ocd-divider{display:inline-block;width:3px;height:3px;border-radius:50%;background:var(--ocd-sub-light);vertical-align:middle;flex-shrink:0}.ocd-curriculum{display:flex;flex-direction:column;gap:.5rem}.ocd-cur-section{border:1.5px solid var(--ocd-border);border-radius:var(--ocd-radius-sm);overflow:hidden;transition:border-color .18s}.ocd-cur-section--open{border-color:var(--ocd-primary)}.ocd-cur-header{display:flex;align-items:center;gap:.7rem;width:100%;padding:.95rem 1.1rem;background:var(--ocd-surface);border:none;cursor:pointer;text-align:left;transition:background .15s}.ocd-cur-section--open .ocd-cur-header,.ocd-cur-header:hover{background:var(--ocd-primary-light)}.ocd-cur-toggle{font-size:.8rem;color:var(--ocd-primary);flex-shrink:0;width:1rem;text-align:center}.ocd-cur-section-num{font-size:.72rem;font-weight:700;color:#fff;background:var(--ocd-primary);padding:.13rem .55rem;border-radius:50px;flex-shrink:0;letter-spacing:.01em}.ocd-cur-section-title{flex:1;font-size:.92rem;font-weight:700;color:var(--ocd-text);line-height:1.4}.ocd-cur-section-meta{font-size:.78rem;color:var(--ocd-sub);flex-shrink:0;white-space:nowrap}.ocd-cur-section-desc{font-size:.86rem;color:var(--ocd-sub);margin:0;padding:.65rem 1.1rem;line-height:1.65;background:var(--ocd-primary-light);border-bottom:1px solid var(--ocd-border)}.ocd-cur-lessons{list-style:none;padding:0;margin:0}.ocd-cur-lesson{display:flex;align-items:center;gap:.75rem;padding:.7rem 1.1rem;border-bottom:1px solid #f3f4f6;font-size:.88rem;color:#374151;transition:background .12s}.ocd-cur-lesson:last-child{border-bottom:none}.ocd-cur-lesson:hover{background:#fafafa}.ocd-cur-lesson--empty{justify-content:center;color:var(--ocd-sub-light);font-size:.84rem;padding:1.2rem}.ocd-cur-lesson--empty:hover{background:none}.ocd-cur-lesson-type{font-size:.68rem;font-weight:700;padding:.12rem .5rem;background:var(--ocd-primary-light);color:var(--ocd-primary);border-radius:var(--ocd-radius-xs);flex-shrink:0;letter-spacing:.02em}.ocd-cur-lesson-title{flex:1;line-height:1.4}.ocd-cur-preview-badge{font-size:.67rem;font-weight:700;padding:.1rem .5rem;background:#dbeafe;color:#1d4ed8;border-radius:50px;flex-shrink:0}.ocd-cur-lesson-dur{font-size:.78rem;color:var(--ocd-sub-light);flex-shrink:0;white-space:nowrap}.ocd-address-block{padding:1rem 1.25rem;background:var(--ocd-surface);border-radius:var(--ocd-radius-sm);border-left:3px solid var(--ocd-primary);margin-bottom:1.1rem}.ocd-address{font-size:.97rem;font-weight:700;color:var(--ocd-text);margin:0 0 .2rem;line-height:1.4}.ocd-detail-address{font-size:.86rem;color:var(--ocd-sub);margin:0}.ocd-no-address{font-size:.9rem;color:var(--ocd-sub);text-align:center;padding:2rem 0;margin:0;line-height:1.7}.ocd-map-wrap{width:100%;height:380px;position:relative;background:#e5e7eb;border-radius:var(--ocd-radius-sm);overflow:hidden;margin-bottom:.75rem;border:1px solid var(--ocd-border)}.ocd-map-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;font-size:.84rem;color:var(--ocd-sub);background:var(--ocd-surface)}.ocd-map-iframe{width:100%;height:100%;border:none;display:block;transition:opacity .35s}.ocd-map-links{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:.75rem}.ocd-map-link{display:flex;align-items:center;justify-content:center;padding:.65rem 1rem;font-size:.84rem;font-weight:700;text-decoration:none;border-radius:var(--ocd-radius-sm);transition:opacity .15s,transform .15s;letter-spacing:.01em}.ocd-map-link:hover{opacity:.85;transform:translateY(-1px)}.ocd-map-link--kakao{background:#fee500;color:#3a1d1d}.ocd-map-link--naver{background:#03c75a;color:#fff}.ocd-notice{display:flex;gap:.75rem;align-items:flex-start;padding:.9rem 1.1rem;border-radius:var(--ocd-radius-sm);margin-bottom:.6rem;font-size:.9rem;line-height:1.65}.ocd-notice:last-child{margin-bottom:0}.ocd-notice p{margin:0;color:#374151}.ocd-notice--announce{background:#eff6ff;border-left:3px solid #3b82f6}.ocd-notice--guide{background:#f0fdf4;border-left:3px solid #22c55e}.ocd-notice--caution{background:#fff7ed;border-left:3px solid #f97316}.ocd-notice-label{font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:50px;flex-shrink:0;margin-top:.15rem;letter-spacing:.03em}.ocd-notice--announce .ocd-notice-label{background:#dbeafe;color:#1d4ed8}.ocd-notice--guide .ocd-notice-label{background:#dcfce7;color:#166534}.ocd-notice--caution .ocd-notice-label{background:#fed7aa;color:#9a3412}.ocd-policy-text{font-size:.9rem;color:var(--ocd-sub);line-height:1.85;margin:0;white-space:pre-line}.ocd-footer-actions{display:flex;gap:.9rem;justify-content:flex-end;margin-top:2rem;flex-wrap:wrap}.ocd-btn-ghost{padding:.72rem 1.75rem;background:transparent;color:var(--ocd-sub);font-size:.92rem;font-weight:600;border:1.5px solid #d1d5db;border-radius:50px;cursor:pointer;transition:border-color .18s,color .18s;letter-spacing:-.01em}.ocd-btn-ghost:hover{border-color:var(--ocd-primary);color:var(--ocd-primary)}.ocd-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.72rem 1.75rem;background:var(--ocd-primary);color:#fff;font-size:.92rem;font-weight:700;border:none;border-radius:50px;text-decoration:none;cursor:pointer;box-shadow:0 4px 14px #667eea59;transition:background .18s,transform .18s;letter-spacing:-.01em}.ocd-btn-primary:hover{background:var(--ocd-primary-hover);transform:translateY(-1px)}.ocd-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8rem 2rem;gap:1.2rem;color:var(--ocd-sub);font-size:.92rem}.ocd-spinner{width:40px;height:40px;border:3px solid var(--ocd-primary-light);border-top-color:var(--ocd-primary);border-radius:50%;animation:ocd-spin .75s linear infinite}.ocd-spinner--sm{width:26px;height:26px;border-width:2.5px}@keyframes ocd-spin{to{transform:rotate(360deg)}}.ocd-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:6rem 2rem;text-align:center}.ocd-error-title{font-size:1.1rem;font-weight:700;color:var(--ocd-text);margin:0}.ocd-error-msg{font-size:.9rem;color:var(--ocd-sub);margin:0}@media(max-width:768px){.ocd-container{padding:1.5rem 1rem 4rem}.ocd-hero{grid-template-columns:1fr}.ocd-hero-thumb{height:200px}.ocd-hero-info{padding:1.25rem 1.25rem 1.5rem}.ocd-title{font-size:1.25rem}.ocd-two-col{grid-template-columns:1fr;gap:1rem}.ocd-instructor-card{flex-direction:column;align-items:center;text-align:center;gap:1rem}.ocd-instructor-badge{margin:0 auto}.ocd-section{padding:1.25rem}.ocd-map-wrap{height:260px}}@media(max-width:480px){.ocd-footer-actions{flex-direction:column}.ocd-btn-ghost,.ocd-btn-primary{width:100%;text-align:center}}:root{--ce-primary: #667eea;--ce-primary-h: #5a6fd6;--ce-danger: #ef4444;--ce-warn: #f59e0b;--ce-success: #10b981;--ce-bg: #f1f5f9;--ce-card: #ffffff;--ce-border: #e2e8f0;--ce-text: #1e293b;--ce-sub: #64748b;--ce-radius: 12px;--ce-shadow: 0 4px 20px rgba(0,0,0,.08)}.ce-loading,.ce-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--ce-sub);font-size:1rem}.ce-spinner{width:48px;height:48px;border:4px solid var(--ce-border);border-top-color:var(--ce-primary);border-radius:50%;animation:ce-spin .7s linear infinite}@keyframes ce-spin{to{transform:rotate(360deg)}}.ce-error span{font-size:2.5rem}.ce-error button{margin-top:.5rem;padding:.6rem 1.5rem;background:var(--ce-primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem}.ce-pre-page{min-height:100vh;background:var(--ce-bg);display:flex;align-items:flex-start;justify-content:center;padding:3rem 1rem}.ce-pre-wrap{width:100%;max-width:680px;display:flex;flex-direction:column;gap:1.5rem}.ce-pre-header{display:flex;align-items:center;gap:1rem;background:var(--ce-card);border-radius:var(--ce-radius);padding:1.25rem 1.5rem;box-shadow:var(--ce-shadow)}.ce-pre-header-icon{font-size:2.2rem}.ce-pre-title{font-size:1.25rem;font-weight:800;color:var(--ce-text);margin:0}.ce-pre-subtitle{font-size:.9rem;color:var(--ce-sub);margin:.2rem 0 0}.ce-pre-section{background:var(--ce-card);border-radius:var(--ce-radius);padding:1.25rem 1.5rem;box-shadow:var(--ce-shadow)}.ce-pre-section-title{font-size:1rem;font-weight:700;color:var(--ce-text);margin:0 0 1rem;padding-bottom:.6rem;border-bottom:2px solid var(--ce-primary)}.ce-check-list{display:flex;flex-direction:column;gap:.7rem}.ce-check-item{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;border-radius:8px;background:#f0fdf4;border:1px solid #bbf7d0}.ce-check-item.fail{background:#fef2f2;border-color:#fecaca}.ce-check-icon{font-size:1.1rem}.ce-check-content{display:flex;flex-direction:column;gap:.1rem}.ce-check-label{font-size:1rem;font-weight:600;color:var(--ce-text)}.ce-check-status{font-size:.88rem;color:var(--ce-sub)}.ce-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.ce-info-box{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:1rem;background:#f8faff;border-radius:10px;border:1px solid var(--ce-border);text-align:center}.ce-info-icon{font-size:1.4rem}.ce-info-label{font-size:.88rem;color:var(--ce-sub);font-weight:500}.ce-info-value{font-size:1rem;font-weight:800;color:var(--ce-primary)}.ce-notice-list{margin:0;padding:0 0 0 1.2rem;display:flex;flex-direction:column;gap:.55rem;color:var(--ce-text);font-size:.9rem;line-height:1.6}.ce-notice-list li strong{color:var(--ce-danger)}.ce-pre-actions{display:flex;gap:.75rem;justify-content:flex-end}.ce-btn-primary{padding:.75rem 2rem;background:var(--ce-primary);color:#fff;font-size:.95rem;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:background .2s,transform .15s;letter-spacing:.01em}.ce-btn-primary:hover{background:var(--ce-primary-h);transform:translateY(-1px)}.ce-btn-primary:disabled{background:#cbd5e1;color:#94a3b8;cursor:default;transform:none}.ce-btn-secondary{padding:.75rem 1.5rem;background:transparent;color:var(--ce-sub);font-size:.95rem;font-weight:600;border:1.5px solid var(--ce-border);border-radius:10px;cursor:pointer;transition:background .2s}.ce-btn-secondary:hover{background:#f1f5f9}.ce-btn-danger{padding:.75rem 2rem;background:var(--ce-danger);color:#fff;font-size:.95rem;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:background .2s}.ce-btn-danger:hover{background:#dc2626}.ce-exam-page{min-height:100vh;display:flex;flex-direction:column;background:#f1f5f9;color:#1e293b;-webkit-user-select:none;user-select:none;position:relative}.ce-focus-alert{position:fixed;top:0;left:0;right:0;z-index:9999;background:var(--ce-danger);color:#fff;text-align:center;padding:.75rem 1rem;font-size:.95rem;font-weight:700;letter-spacing:.02em;animation:ce-slidein .3s ease}@keyframes ce-slidein{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.ce-topbar{display:flex;align-items:center;gap:1rem;padding:.6rem 1.2rem;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;position:sticky;top:0;z-index:100}.ce-topbar-left{display:flex;align-items:center;gap:.75rem;flex:0 0 auto}.ce-topbar-title{font-size:.88rem;font-weight:700;color:#1e293b;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ce-topbar-progress{font-size:.8rem;color:#64748b;white-space:nowrap}.ce-topbar-center{flex:1}.ce-progress-bar-wrap{width:100%;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.ce-progress-bar-fill{height:100%;background:var(--ce-primary);border-radius:3px;transition:width .3s ease}.ce-topbar-right{display:flex;align-items:center;gap:1rem;flex:0 0 auto}.ce-font-ctrl{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:#64748b}.ce-font-ctrl button{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:4px;padding:.2rem .5rem;cursor:pointer;font-size:.75rem;transition:background .15s}.ce-font-ctrl button:hover{background:#e2e8f0}.ce-timer{font-size:1rem;font-weight:800;color:#1e293b;background:#e2e8f0;padding:.3rem .8rem;border-radius:8px;font-variant-numeric:tabular-nums;letter-spacing:.05em;min-width:70px;text-align:center;transition:background .4s,color .4s}.ce-timer--warn{background:#78350f;color:#fde68a;animation:ce-pulse 1s ease infinite}.ce-timer--danger{background:#7f1d1d;color:#fca5a5;animation:ce-pulse .5s ease infinite}@keyframes ce-pulse{0%,to{opacity:1}50%{opacity:.7}}.ce-dot-bar{display:flex;flex-wrap:wrap;gap:4px;padding:.5rem 1.2rem;background:#fff;border-bottom:1px solid #e2e8f0}.ce-dot{width:26px;height:26px;border-radius:50%;border:1.5px solid #cbd5e1;background:#f8fafc;color:#64748b;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.ce-dot:hover{border-color:var(--ce-primary);color:#1e293b}.ce-dot--current{border-color:var(--ce-primary)!important;background:var(--ce-primary);color:#fff}.ce-dot--answered{background:#dcfce7;border-color:#22c55e;color:#15803d}.ce-dot--flagged{background:#fef3c7;border-color:var(--ce-warn);color:#b45309}.ce-dot--current.ce-dot--flagged{background:var(--ce-warn);border-color:var(--ce-warn);color:#fff}.ce-main{display:flex;flex:1;overflow:hidden}.ce-sidebar{width:320px;flex-shrink:0;background:#fff;border-right:1px solid #e2e8f0;padding:1.5rem 1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.ce-sidebar-title{font-size:.9rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin:0}.ce-sidebar-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}.ce-idx-btn{position:relative;width:100%;aspect-ratio:1;border-radius:6px;border:1px solid #e2e8f0;background:#f8fafc;color:#64748b;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.ce-idx-btn:hover{border-color:var(--ce-primary);color:#1e293b}.ce-idx-btn.active{background:var(--ce-primary);border-color:var(--ce-primary);color:#fff}.ce-idx-btn.answered{background:#dcfce7;border-color:#16a34a;color:#15803d}.ce-idx-btn.flagged{border-color:var(--ce-warn);color:#b45309}.ce-flag-dot{position:absolute;top:1px;right:2px;font-size:.55rem;color:var(--ce-warn)}.ce-sidebar-legend{display:flex;flex-wrap:wrap;gap:.5rem .9rem;font-size:.88rem;color:#64748b}.ce-leg{margin-right:2px}.ce-leg--answered{color:#22c55e}.ce-leg--flagged{color:var(--ce-warn)}.ce-leg--empty{color:#475569}.ce-sidebar-stats{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;color:#64748b;border-top:1px solid #e2e8f0;padding-top:.5rem}.ce-question-area{flex:1;padding:2.5rem 3rem;overflow-y:auto;background:#f8fafc}.ce-q-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.ce-q-num{font-size:1.05rem;font-weight:700;color:#64748b;background:#f1f5f9;padding:.2rem .7rem;border-radius:50px}.ce-q-points{font-size:1rem;font-weight:600;color:#b45309;background:#fef3c7;padding:.2rem .6rem;border-radius:50px}.ce-flag-btn{margin-left:auto;font-size:.95rem;font-weight:600;padding:.25rem .7rem;border-radius:6px;border:1px solid #e2e8f0;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s}.ce-flag-btn:hover{border-color:var(--ce-warn);color:var(--ce-warn)}.ce-flag-btn.active{background:#fef3c7;border-color:var(--ce-warn);color:#b45309}.ce-q-text{font-size:1.25rem;line-height:2;color:#1e293b;margin-bottom:1.75rem;white-space:pre-wrap}.ce-q-media{margin-bottom:1.25rem}.ce-q-img{max-width:100%;border-radius:8px;border:1px solid #e2e8f0}.ce-q-video{max-width:100%;border-radius:8px}.ce-answer-area{margin-bottom:2.5rem}.ce-mc-options{display:flex;flex-direction:column;gap:.85rem}.ce-mc-option{display:flex;align-items:center;gap:.75rem;padding:1.1rem 1.4rem;border:1.5px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;transition:all .15s;color:#334155;font-size:.95em;line-height:1.5}.ce-mc-option:hover{border-color:var(--ce-primary);background:#eff6ff}.ce-mc-option.selected{border-color:var(--ce-primary);background:#eff6ff;color:#1e40af}.ce-mc-option input{display:none}.ce-mc-marker{font-size:1.05em;font-weight:700;color:var(--ce-primary);min-width:1.4em;text-align:center}.ce-mc-option.selected .ce-mc-marker{color:#2563eb}.ce-mc-label{flex:1}.ce-short-input{width:100%;padding:.85rem 1rem;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;color:#1e293b;font-size:.95em;outline:none;transition:border-color .2s;box-sizing:border-box}.ce-short-input:focus{border-color:var(--ce-primary)}.ce-short-input::placeholder{color:#94a3b8}.ce-essay-input{width:100%;padding:.85rem 1rem;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;color:#1e293b;font-size:.95em;outline:none;resize:vertical;min-height:180px;line-height:1.7;transition:border-color .2s;box-sizing:border-box;font-family:inherit}.ce-essay-input:focus{border-color:var(--ce-primary)}.ce-essay-input::placeholder{color:#94a3b8}.ce-q-nav{display:flex;gap:.75rem;justify-content:flex-end;padding-top:.5rem;border-top:1px solid #e2e8f0}.ce-btn-nav{padding:.6rem 1.3rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s}.ce-btn-nav:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.ce-btn-nav:disabled{opacity:.4;cursor:default}.ce-btn-nav--next{background:var(--ce-primary);border-color:var(--ce-primary);color:#fff}.ce-btn-nav--next:hover{background:var(--ce-primary-h);border-color:var(--ce-primary-h);color:#fff}.ce-btn-submit{padding:.6rem 1.5rem;background:var(--ce-success);border:none;border-radius:8px;color:#fff;font-size:.88rem;font-weight:700;cursor:pointer;transition:background .15s}.ce-btn-submit:hover{background:#059669}.ce-no-question{display:flex;align-items:center;justify-content:center;height:200px;color:#94a3b8;font-size:.9rem}.ce-footer{position:sticky;bottom:0;background:#fff;border-top:1px solid #e2e8f0;padding:.5rem 1.2rem;display:flex;justify-content:flex-end}.ce-btn-submit-footer{padding:.55rem 1.5rem;background:var(--ce-success);border:none;border-radius:8px;color:#fff;font-size:.88rem;font-weight:700;cursor:pointer;transition:background .15s}.ce-btn-submit-footer:hover{background:#059669}.ce-confirm-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.ce-confirm-box{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:2rem;width:100%;max-width:420px;box-shadow:0 20px 60px #00000080}.ce-confirm-title{font-size:1.15rem;font-weight:800;color:#1e293b;margin:0 0 1.25rem;text-align:center}.ce-confirm-stats{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.ce-confirm-row{display:flex;justify-content:space-between;align-items:center;padding:.55rem .75rem;border-radius:8px;background:#f8fafc;font-size:.9rem;color:#64748b}.ce-confirm-row.warn{background:#fff7ed}.ce-confirm-row strong{font-size:1rem;color:#1e293b}.ce-confirm-row strong.green{color:#4ade80}.ce-confirm-row strong.red{color:#f87171}.ce-confirm-row strong.orange{color:#fb923c}.ce-confirm-warn{font-size:.82rem;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.6rem .75rem;margin-bottom:1rem;line-height:1.5}.ce-confirm-actions{display:flex;gap:.75rem;justify-content:flex-end}.ce-done-page{min-height:100vh;background:var(--ce-bg);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.ce-done-box{background:var(--ce-card);border-radius:20px;padding:3rem 2.5rem;max-width:480px;width:100%;box-shadow:var(--ce-shadow);text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.ce-done-icon{font-size:4rem;line-height:1}.ce-done-title{font-size:1.5rem;font-weight:800;color:var(--ce-text);margin:0}.ce-done-sub{font-size:.95rem;color:var(--ce-sub);margin:0}.ce-done-stats{display:flex;gap:1.5rem;font-size:.9rem;color:var(--ce-sub);background:#f8faff;border:1px solid var(--ce-border);border-radius:10px;padding:.75rem 1.25rem}.ce-done-violation{color:var(--ce-danger);font-weight:600}.ce-done-notice{font-size:.85rem;color:var(--ce-sub);background:#fefce8;border:1px solid #fde68a;border-radius:8px;padding:.7rem 1rem;line-height:1.6;margin:0;text-align:left}.ce-done-notice strong{color:var(--ce-text)}.ce-done-actions{margin-top:.5rem}@media(max-width:1000px){.ce-sidebar{display:none}.ce-dot-bar{padding:.4rem .7rem}.ce-question-area{padding:1rem}}@media(max-width:600px){.ce-topbar-title{max-width:100px;font-size:.78rem}.ce-font-ctrl{display:none}.ce-info-grid{grid-template-columns:repeat(2,1fr)}.ce-pre-page{padding:1rem}}.ce-save-toast{position:fixed;bottom:4rem;right:1.5rem;z-index:200;padding:.45rem 1rem;border-radius:8px;font-size:.78rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:ce-fadein .2s ease}.ce-save-toast--saving{background:#f8fafcf2;color:#64748b;border:1px solid #e2e8f0}.ce-save-toast--saved{background:#14532dd9;color:#86efac;border:1px solid #16a34a}.ce-save-toast--error{background:#7f1d1dd9;color:#fca5a5;border:1px solid #dc2626}.ce-subject-group{margin-bottom:.5rem}.ce-subject-label{font-size:.8rem;font-weight:700;color:var(--ce-primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px;border-left:2px solid var(--ce-primary);padding:.25rem .3rem .25rem .4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ce-subject-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}.ce-dot-subject-label{font-size:.6rem;font-weight:700;color:var(--ce-primary);background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;padding:.1rem .4rem;white-space:nowrap;align-self:center}.ce-sidebar-summary{display:flex;flex-direction:column;gap:4px;padding:.7rem .75rem;background:#f8faff;border-radius:8px;border:1px solid #dbeafe;margin-bottom:.5rem}.ce-sidebar-summary-label{font-size:.8rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em}.ce-sidebar-summary-count{font-size:.82rem;color:#64748b}.ce-sidebar-summary-count strong{font-size:1rem;color:var(--ce-primary);font-weight:800}.ce-sidebar-total-bar{height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden}.ce-sidebar-total-fill{height:100%;background:var(--ce-primary);border-radius:2px;transition:width .3s ease}.ce-acc{border-radius:8px;overflow:hidden;border:1px solid #e2e8f0;margin-bottom:4px;background:#fff}.ce-acc--active{border-color:var(--ce-primary)}.ce-acc-header{width:100%;display:flex;align-items:center;gap:5px;padding:.45rem .6rem;background:transparent;border:none;cursor:pointer;text-align:left;transition:background .15s}.ce-acc-header:hover{background:#f8faff}.ce-acc--active .ce-acc-header{background:#eff6ff}.ce-acc-arrow{font-size:.8rem;color:#94a3b8;width:10px;flex-shrink:0}.ce-acc--active .ce-acc-arrow{color:var(--ce-primary)}.ce-acc-name{flex:1;font-size:.72rem;font-weight:700;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ce-acc--active .ce-acc-name{color:var(--ce-primary)}.ce-acc-badge{font-size:.63rem;font-weight:700;color:#94a3b8;background:#f1f5f9;border-radius:50px;padding:.1rem .4rem;flex-shrink:0;white-space:nowrap}.ce-acc-badge.done{color:#15803d;background:#dcfce7}.ce-acc-bar{height:3px;background:#e2e8f0}.ce-acc-bar-fill{height:100%;background:var(--ce-primary);transition:width .3s ease}.ce-acc--active .ce-acc-bar-fill{background:var(--ce-primary)}.ce-acc-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:3px;padding:.4rem .5rem;background:#fafafa}.ce-acc-grid .ce-idx-btn{width:100%;aspect-ratio:1;border-radius:5px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .12s;display:flex;align-items:center;justify-content:center;position:relative}.ce-acc-grid .ce-idx-btn:hover{border-color:var(--ce-primary);color:var(--ce-primary);background:#eff6ff}.ce-acc-grid .ce-idx-btn.active{background:var(--ce-primary);border-color:var(--ce-primary);color:#fff}.ce-acc-grid .ce-idx-btn.answered{background:#dcfce7;border-color:#86efac;color:#15803d}.ce-acc-grid .ce-idx-btn.flagged{background:#fef3c7;border-color:#fcd34d;color:#b45309}.ce-acc-grid .ce-idx-btn.active.answered{background:var(--ce-primary);border-color:var(--ce-primary);color:#fff}.ce-sidebar{width:320px}.ce-result-badge{display:inline-block;font-size:1.5rem;font-weight:800;padding:.5rem 1.8rem;border-radius:999px;margin-bottom:.75rem}.ce-result-badge.pass{background:#dcfce7;color:#16a34a}.ce-result-badge.fail{background:#fee2e2;color:#dc2626}.ce-score-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:1.5rem 2rem;margin:1rem 0;text-align:center}.ce-score-num{font-size:3.5rem;font-weight:900;line-height:1;margin-bottom:.25rem}.ce-score-num.pass{color:#16a34a}.ce-score-num.fail{color:#dc2626}.ce-score-unit{font-size:1.5rem;font-weight:600}.ce-score-meta{font-size:.85rem;color:#64748b;margin-bottom:.75rem}.ce-score-bar-wrap{background:#e2e8f0;border-radius:999px;height:10px;overflow:hidden}.ce-score-bar{height:100%;border-radius:999px;transition:width 1s ease}.ce-score-bar.pass{background:linear-gradient(90deg,#4ade80,#16a34a)}.ce-score-bar.fail{background:linear-gradient(90deg,#f87171,#dc2626)}.profile-edit{width:100%;max-width:100%}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:.75rem;border-bottom:2px solid #667eea;gap:1.5rem}.section-title{font-size:1.75rem;font-weight:700;color:#667eea;margin:0;padding:0;border:none;white-space:nowrap;flex-shrink:0}.btn-change-password{padding:.625rem 1.25rem;background-color:#fff;color:#667eea;border:2px solid #667eea;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.btn-change-password:hover{background-color:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.btn-change-password:active{transform:translateY(0)}.profile-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.95rem;font-weight:600;color:#1f2937;margin-bottom:.25rem}.form-group input[type=text],.form-group input[type=email],.form-group input[type=tel]{width:100%;padding:.875rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:1rem;background-color:#fff;color:#1f2937;transition:all .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;border-width:2px;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;color:#9ca3af;border-color:#e5e7eb;cursor:not-allowed}.form-group input[readonly]{background-color:#f9fafb;border-color:#d1d5db;cursor:default}.help-text{font-size:.85rem;color:#6b7280;margin-top:.25rem}.help-text.info-text{color:#667eea;font-weight:500;padding:.75rem;background-color:#667eea0d;border:1px solid rgba(102,126,234,.1);border-radius:6px;margin-top:.5rem;line-height:1.5}.address-row{display:flex;gap:.75rem;align-items:stretch}.address-row input{flex:1;min-width:0}.btn-address-search{padding:.875rem 1.25rem;background-color:#667eea;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.btn-address-search:hover:not(:disabled){background-color:#5a6fd6;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.btn-address-search:active{transform:translateY(0)}.btn-address-search:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.form-group input[type=text]#postalCode{margin-bottom:0}.form-group input[type=text]#address{margin-top:.5rem;margin-bottom:0}.form-group input[type=text]#detailAddress{margin-top:.5rem}.checkbox-group{padding:1rem 1.25rem;background-color:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.checkbox-label{display:flex;align-items:flex-start;gap:.875rem;font-size:.95rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:1.125rem;height:1.125rem;margin-top:.125rem;cursor:pointer;accent-color:#667eea;flex-shrink:0}.checkbox-label span{line-height:1.5;color:#1f2937;flex:1}.button-group{display:flex;gap:1rem;margin-top:1rem}.btn-primary{width:100%;padding:1rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;background-color:#667eea;color:#fff;border:none}.btn-primary:hover:not(:disabled){background-color:#5a6fd6;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.pe-modal-overlay{position:fixed;inset:0;background:#00000073;z-index:9000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:pe-fade-in .15s ease}@keyframes pe-fade-in{0%{opacity:0}to{opacity:1}}.pe-modal{background:#fff;border-radius:14px;width:100%;max-width:360px;padding:2rem 1.75rem;display:flex;flex-direction:column;align-items:center;gap:1rem;box-shadow:0 20px 60px #0003;animation:pe-slide-up .18s ease}@keyframes pe-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.pe-modal-icon{font-size:2.75rem;line-height:1}.pe-modal-text{font-size:.9375rem;color:#374151;text-align:center;line-height:1.6;margin:0;white-space:pre-line}.pe-modal-btn{margin-top:.25rem;padding:.625rem 2rem;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .15s}.pe-modal-btn.success{background:#667eea;color:#fff}.pe-modal-btn.success:hover{background:#5a6fd6;transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.pe-modal-btn.error{background:#fee2e2;color:#dc2626}.pe-modal-btn.error:hover{background:#fecaca;transform:translateY(-1px)}@media(max-width:768px){.section-header{flex-direction:column;align-items:flex-start}.section-title{font-size:1.5rem}.btn-change-password{width:100%;justify-content:center}}@media(max-width:480px){.section-title{font-size:1.25rem}.btn-change-password{font-size:.85rem;padding:.625rem 1.25rem}.form-group input{font-size:.95rem;padding:.75rem}.btn-primary{font-size:.95rem;padding:.875rem}.address-row{flex-direction:column}.btn-address-search{width:100%;padding:.875rem}.help-text.info-text{font-size:.8rem;padding:.625rem}.pe-modal{padding:1.75rem 1.25rem}}.pe-pw-modal{background:#fff;border-radius:16px;width:100%;max-width:420px;box-shadow:0 20px 60px #0003;animation:pe-slide-up .18s ease;overflow:hidden}.pe-pw-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #f0f0f0;background:linear-gradient(135deg,#667eea14,#667eea08)}.pe-pw-modal-title{font-size:1.05rem;font-weight:700;color:#1f2937}.pe-pw-modal-close{background:none;border:none;font-size:1rem;color:#9ca3af;cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:all .15s;line-height:1}.pe-pw-modal-close:hover:not(:disabled){background:#f3f4f6;color:#374151}.pe-pw-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.pe-pw-field{display:flex;flex-direction:column;gap:.375rem}.pe-pw-field label{font-size:.9rem;font-weight:600;color:#374151}.pe-pw-input-wrap{position:relative;display:flex;align-items:center}.pe-pw-input-wrap input{width:100%;padding:.8rem 2.75rem .8rem .875rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:.95rem;background:#fff;color:#1f2937;transition:all .2s;box-sizing:border-box}.pe-pw-input-wrap input:focus{outline:none;border-color:#667eea;border-width:2px;box-shadow:0 0 0 3px #667eea1a}.pe-pw-input-wrap input:disabled{background:#f5f5f5;color:#9ca3af;cursor:not-allowed}.pe-pw-toggle{position:absolute;right:.625rem;background:none;border:none;font-size:1rem;cursor:pointer;padding:.25rem;line-height:1;opacity:.6;transition:opacity .15s}.pe-pw-toggle:hover{opacity:1}.pe-pw-strength{display:flex;align-items:center;gap:.625rem;margin-top:.25rem}.pe-pw-strength-bar{display:flex;gap:4px;flex:1}.pe-pw-strength-seg{height:4px;flex:1;border-radius:99px;transition:background-color .25s}.pe-pw-hint{font-size:.8rem;color:#9ca3af}.pe-pw-match{font-size:.8rem;font-weight:500}.pe-pw-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:8px;padding:.75rem 1rem;font-size:.875rem;line-height:1.5}.pe-pw-btn-row{display:flex;gap:.75rem;margin-top:.25rem}.pe-pw-btn-cancel{flex:1;padding:.875rem;border:1.5px solid #d1d5db;border-radius:8px;background:#fff;color:#6b7280;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s}.pe-pw-btn-cancel:hover:not(:disabled){border-color:#9ca3af;color:#374151;background:#f9fafb}.pe-pw-btn-submit{flex:2;padding:.875rem;border:none;border-radius:8px;background:#667eea;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.pe-pw-btn-submit:hover:not(:disabled){background:#5a6fd6;transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.pe-pw-btn-submit:active:not(:disabled){transform:translateY(0)}.pe-pw-btn-submit:disabled,.pe-pw-btn-cancel:disabled{opacity:.5;cursor:not-allowed;transform:none}@media(max-width:480px){.pe-pw-modal{border-radius:12px}.pe-pw-form{padding:1.25rem;gap:1rem}.pe-pw-btn-row{flex-direction:column}.pe-pw-btn-cancel,.pe-pw-btn-submit{flex:none;width:100%}}.wishlist{width:100%}.section-title{font-size:1.75rem;font-weight:700;color:#667eea;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid #667eea}.wl-tab-wrap{display:flex;gap:0;margin-bottom:1.75rem;border-bottom:2px solid #e5e7eb}.wl-tab{display:inline-flex;align-items:center;gap:5px;padding:.55rem 1.25rem;font-size:.9375rem;font-weight:600;border:none;background:none;color:#9ca3af;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.wl-tab:hover{color:#667eea}.wl-tab.active{color:#667eea;border-bottom-color:#667eea}.wl-tab-icon{font-size:1rem}.wl-tab-cnt{background:#f3f4f6;color:#6b7280;font-size:.72rem;padding:1px 7px;border-radius:10px;font-weight:500;transition:background .15s,color .15s}.wl-tab.active .wl-tab-cnt{background:#ede9fe;color:#667eea}.loading-state{text-align:center;padding:3rem 1rem;color:#666}.empty-state{text-align:center;padding:4rem 1rem}.empty-icon{font-size:5rem;margin-bottom:1.5rem}.empty-text{font-size:1.125rem;color:#666}.wishlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.wishlist-card{position:relative;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:all .2s}.wishlist-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001f}.wl-type-badge{position:absolute;top:.6rem;left:.6rem;padding:2px 8px;border-radius:20px;font-size:.72rem;font-weight:600;z-index:10;pointer-events:none}.wl-type-badge.course{background:#667eea26;color:#667eea;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.wl-type-badge.cert{background:#f59e0b26;color:#d97706;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-remove-wishlist{position:absolute;top:.75rem;right:.75rem;width:32px;height:32px;background:#ffffffe6;border:none;border-radius:50%;font-size:1.25rem;color:#ff5757;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 8px #00000026}.btn-remove-wishlist:hover{background:#ff5757;color:#fff;transform:scale(1.1)}.course-thumbnail{width:100%;height:180px;overflow:hidden;background:#f5f5f5;display:flex;align-items:center;justify-content:center}.course-thumbnail img{width:100%;height:100%;object-fit:cover}.no-thumbnail{font-size:4rem;color:#ccc}.course-info{padding:1.25rem}.course-title{font-size:1.0625rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.course-instructor{font-size:.875rem;color:#666;margin-bottom:.75rem}.course-price{display:flex;align-items:center;gap:.5rem}.price-free{font-size:1.0625rem;font-weight:700;color:#16a34a}.price-original{font-size:.875rem;color:#999;text-decoration:line-through}.price-discount{font-size:1.0625rem;font-weight:700;color:#667eea}.price-current{font-size:1.0625rem;font-weight:700;color:#1a1a1a}@media(max-width:768px){.wishlist-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.section-title{font-size:1.5rem}.wl-tab{padding:.5rem .875rem;font-size:.875rem}}.ph-wrap{width:100%;font-family:inherit}.ph-top{display:flex;align-items:baseline;gap:.625rem;margin-bottom:1.25rem}.ph-title{font-size:1.375rem;font-weight:700;color:#1a1a1a;margin:0}.ph-count{font-size:.875rem;color:#9ca3af}.ph-summary-bar{display:flex;align-items:center;background:#f8f9ff;border:1px solid #e8eaf6;border-radius:10px;padding:.75rem 1.25rem;margin-bottom:1rem;gap:0}.ph-sum-item{display:flex;flex-direction:column;gap:2px;flex:1;text-align:center}.ph-sum-label{font-size:.75rem;color:#9ca3af}.ph-sum-value{font-size:1rem;font-weight:700}.ph-sum-blue{color:#667eea}.ph-sum-red{color:#ef4444}.ph-sum-orange{color:#f59e0b}.ph-sum-divider{width:1px;height:32px;background:#e5e7eb;margin:0 1rem}.ph-filter-tabs{display:flex;gap:.375rem;margin-bottom:.75rem;flex-wrap:wrap}.ph-filter-tab{display:inline-flex;align-items:center;gap:5px;padding:.3rem .75rem;font-size:.8125rem;font-weight:500;border-radius:20px;border:1.5px solid #e5e7eb;background:#fff;color:#6b7280;cursor:pointer;transition:all .15s}.ph-filter-tab:hover{border-color:#667eea;color:#667eea}.ph-filter-tab.active{background:#667eea;border-color:#667eea;color:#fff}.ph-tab-cnt{background:#ffffff4d;font-size:.7rem;padding:1px 5px;border-radius:10px}.ph-filter-tab.active .ph-tab-cnt{background:#ffffff40}.ph-filter-tab:not(.active) .ph-tab-cnt{background:#f3f4f6;color:#6b7280}.ph-table-wrap{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.ph-row{display:grid;grid-template-columns:90px 1fr 100px 100px 90px 110px 24px;align-items:center;gap:.5rem;padding:.625rem 1rem}.ph-row-head{background:#f8f9fa;border-bottom:1px solid #e5e7eb;font-size:.75rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.03em}.ph-row-data{cursor:pointer;transition:background .12s;font-size:.875rem;color:#374151;-webkit-user-select:none;user-select:none}.ph-row-data:hover{background:#fafbff}.ph-item-open .ph-row-data{background:#f5f7ff}.ph-item{border-bottom:1px solid #f0f0f0}.ph-item:last-child{border-bottom:none}.ph-col-method{color:#6b7280;font-size:.8125rem}.ph-col-amount{font-weight:600;text-align:right}.ph-col-status{text-align:center}.ph-col-action{display:flex;justify-content:center}.ph-date-main{font-size:.8rem;color:#6b7280;white-space:nowrap}.ph-course-name{display:block;font-weight:600;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.ph-course-inst{display:block;font-size:.75rem;color:#9ca3af;margin-top:1px}.ph-amount{color:#1a1a1a}.ph-expand-icon{font-size:.625rem;color:#9ca3af;text-align:center}.ph-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.ph-s-done{background:#dcfce7;color:#16a34a}.ph-s-pending{background:#fef9c3;color:#a16207}.ph-s-failed{background:#fee2e2;color:#dc2626}.ph-s-refunded{background:#dbeafe;color:#1d4ed8}.ph-s-req{background:#fef3c7;color:#92400e}.ph-s-rejected{background:#fee2e2;color:#dc2626}.ph-s-cancelled{background:#f3f4f6;color:#6b7280}.ph-detail{background:#fafbff;border-top:1px dashed #e5e7eb;padding:1rem 1.25rem;animation:ph-slide-down .18s ease}@keyframes ph-slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.ph-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media(max-width:640px){.ph-detail-grid{grid-template-columns:1fr}}.ph-detail-section{display:flex;flex-direction:column;gap:.5rem}.ph-detail-title{font-size:.75rem;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.ph-detail-rows{display:flex;flex-direction:column;gap:.375rem}.ph-dr{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem}.ph-dr span{color:#6b7280}.ph-dr strong{color:#1a1a1a;font-weight:500;text-align:right}.ph-dr-total{border-top:1px solid #e5e7eb;padding-top:.375rem;margin-top:.125rem}.ph-total{color:#667eea!important;font-size:1rem!important;font-weight:700!important}.ph-line{text-decoration:line-through;color:#9ca3af!important}.ph-discount{color:#ef4444!important}.ph-dr-warn{background:#fff5f5;border-radius:6px;padding:4px 6px;border-left:3px solid #ef4444}.ph-reject-txt{color:#dc2626!important}.ph-reject-notice{margin-top:.75rem;background:#fff5f5;border:1px solid #fca5a5;border-radius:8px;padding:.625rem .875rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem;font-size:.8125rem;color:#7f1d1d}.ph-policy-strip{display:flex;align-items:center;gap:.75rem;margin-top:.875rem;padding:.625rem .875rem;border-radius:8px;font-size:.8125rem;flex-wrap:wrap}.ph-policy-strip.ok{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.ph-policy-strip.no{background:#fff7ed;border:1px solid #fed7aa;color:#92400e}.ph-policy-strip strong{font-weight:700;margin-left:auto}.ph-btn-req{padding:.3rem .75rem;font-size:.775rem;font-weight:600;border-radius:6px;border:1.5px solid #ef4444;color:#ef4444;background:#fff;cursor:pointer;transition:all .15s;white-space:nowrap}.ph-btn-req:hover{background:#fee2e2}.ph-btn-re{background:#fef3c7;color:#92400e;border-color:#f59e0b}.ph-btn-re:hover{background:#fde68a}.ph-empty{text-align:center;padding:3.5rem 1rem;border:1px dashed #e5e7eb;border-radius:10px;color:#9ca3af}.ph-empty-icon{font-size:3rem;display:block;margin-bottom:.75rem}.ph-empty p{font-size:.9375rem;margin:0}.ph-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem;color:#9ca3af;font-size:.875rem}.ph-spinner{width:28px;height:28px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:ph-spin .7s linear infinite}@keyframes ph-spin{to{transform:rotate(360deg)}}.ph-modal-overlay{position:fixed;inset:0;background:#00000073;z-index:9000;display:flex;align-items:center;justify-content:center;padding:1rem}.ph-modal{background:#fff;border-radius:14px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000040}.ph-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;font-size:1rem;font-weight:700;color:#1a1a1a}.ph-modal-close{background:none;border:none;font-size:1.1rem;color:#9ca3af;cursor:pointer;padding:.25rem}.ph-modal-close:hover{color:#374151}.ph-modal-body{flex:1;overflow-y:auto;padding:1.125rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.ph-refund-course-box{background:#f8f9fa;border-radius:8px;padding:.875rem 1rem;display:flex;flex-direction:column;gap:.5rem}.ph-refund-row{display:flex;justify-content:space-between;font-size:.875rem}.ph-refund-row span{color:#6b7280}.ph-refund-row strong{color:#1a1a1a}.ph-refund-row-warn{background:#fff5f5;border-radius:6px;padding:6px 8px;border-left:3px solid #ef4444}.ph-reject-reason-modal{color:#dc2626}.ph-refund-policy-box{border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.ph-policy-title{font-size:.875rem;font-weight:700;color:#374151;margin-bottom:.625rem}.ph-policy-list{padding-left:1.25rem;margin:0 0 .875rem;font-size:.8125rem;color:#4b5563;line-height:1.8}.ph-policy-result{border-radius:8px;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.25rem}.ph-policy-result.refundable{background:#f0fdf4;border:1px solid #bbf7d0}.ph-policy-result.not-refundable{background:#fff7ed;border:1px solid #fed7aa}.ph-policy-label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase}.ph-policy-desc{font-size:.8125rem;color:#374151}.ph-policy-amount{font-size:.875rem;color:#374151;margin-top:.25rem}.ph-policy-amount strong{color:#667eea;font-size:1rem}.ph-policy-warn{margin-top:.625rem;font-size:.8rem;color:#92400e;background:#fef3c7;padding:.5rem .75rem;border-radius:6px}.ph-form-group{display:flex;flex-direction:column;gap:.375rem}.ph-field-label{font-size:.875rem;font-weight:600;color:#374151}.ph-textarea{width:100%;padding:.625rem .75rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:.875rem;resize:vertical;outline:none;font-family:inherit;box-sizing:border-box;transition:border-color .15s}.ph-textarea:focus{border-color:#667eea}.ph-modal-footer{padding:.875rem 1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.625rem}.ph-btn-cancel{padding:.5rem 1.125rem;font-size:.875rem;font-weight:500;border-radius:7px;border:1.5px solid #d1d5db;background:#fff;color:#374151;cursor:pointer}.ph-btn-cancel:hover{background:#f9fafb}.ph-btn-submit{padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;border-radius:7px;border:none;background:#667eea;color:#fff;cursor:pointer;transition:background .15s}.ph-btn-submit:hover:not(:disabled){background:#5a67d8}.ph-btn-submit:disabled{background:#d1d5db;cursor:not-allowed}@media(max-width:768px){.ph-row{grid-template-columns:80px 1fr 80px 80px 70px 90px 20px;font-size:.8125rem;padding:.5rem .75rem;gap:.375rem}.ph-col-method{display:none}.ph-row{grid-template-columns:80px 1fr 80px 70px 90px 20px}.ph-row-head .ph-col-method{display:none}.ph-summary-bar{gap:0;padding:.625rem .75rem}.ph-modal{max-height:95vh}.ph-course-name{max-width:150px}}.ph-dr-refund-summary{border-top:1px solid #e5e7eb;padding-top:.375rem;margin-top:.25rem}.ph-dr-refund-actual{border-top:none;margin-top:0;padding-top:0}.ph-refund-actual-amt{color:#1d4ed8!important;font-size:1rem!important;font-weight:700!important}.ph-dr-policy{align-items:flex-start!important;flex-wrap:wrap;gap:2px 8px}.ph-dr-policy>span{white-space:nowrap;flex-shrink:0;padding-top:1px}.ph-refund-policy-txt{color:#6b7280!important;font-size:.8125rem!important;font-weight:400!important;text-align:right;line-height:1.5;word-break:keep-all;flex:1;min-width:0}.ph-s-partial{background:#ede9fe;color:#6d28d9}.ph-amount-refund-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:1px;line-height:1.3}.ph-amount-orig{font-size:.75rem!important;color:#9ca3af!important;text-decoration:line-through;font-weight:400!important}.ph-amount-refund{font-size:.9rem;font-weight:700;color:#1d4ed8}.ph-sum-sub{display:flex;gap:4px;margin-top:2px;justify-content:center;flex-wrap:wrap}.ph-sum-sub-item{font-size:.68rem;background:#dbeafe;color:#1e40af;padding:1px 6px;border-radius:10px;font-weight:500}.ph-sum-sub-part{background:#ede9fe;color:#6d28d9}.ph-content-tab-wrap{display:flex;gap:0;margin-bottom:1.25rem;border-bottom:2px solid #e5e7eb}.ph-content-tab{display:inline-flex;align-items:center;gap:6px;padding:.625rem 1.5rem;font-size:.9375rem;font-weight:600;border:none;background:none;color:#9ca3af;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.ph-content-tab:hover{color:#667eea}.ph-content-tab.active{color:#667eea;border-bottom-color:#667eea}.ph-content-tab-cnt{background:#f3f4f6;color:#6b7280;font-size:.72rem;padding:1px 7px;border-radius:10px;font-weight:500;transition:background .15s,color .15s}.ph-content-tab.active .ph-content-tab-cnt{background:#ede9fe;color:#667eea}.mypage{min-height:100vh;background-color:#f9fafb}.mypage-container{display:grid;grid-template-columns:300px 1fr;gap:2.5rem;max-width:1400px;margin:0 auto;padding:2rem;min-height:calc(100vh - 160px)}.mypage-sidebar{position:sticky;top:100px;height:fit-content;max-height:calc(100vh - 120px);overflow-y:auto;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column}.user-card{padding:2.5rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;border-radius:12px 12px 0 0}.user-avatar{width:90px;height:90px;border-radius:50%;background-color:#fff;color:#667eea;display:flex;align-items:center;justify-content:center;font-size:2.25rem;font-weight:700;margin:0 auto 1rem;box-shadow:0 4px 12px #00000026;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.25rem;color:#667eea}.user-name{font-size:1.375rem;font-weight:700;margin-bottom:.5rem;color:#fff}.user-email{font-size:.95rem;opacity:.9;color:#fff}.mypage-nav{flex:1;padding:.5rem 0;display:flex;flex-direction:column}.nav-item{width:100%;padding:1.125rem 2rem;background:none;border:none;border-left:3px solid transparent;text-align:left;font-size:1.0625rem;color:#6b7280;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.875rem}.nav-item:hover{background-color:#667eea0d;color:#667eea}.nav-item.active{background-color:#667eea1a;color:#667eea;font-weight:600;border-left-color:#667eea}.mypage-content{background-color:#fff;border-radius:12px;padding:2.5rem;box-shadow:0 2px 8px #00000014;min-height:600px}.mypage-container>p{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.25rem;color:#6b7280;grid-column:1 / -1}@media(min-width:1600px){.mypage-container{max-width:1600px;grid-template-columns:320px 1fr;gap:3rem}.user-avatar{width:100px;height:100px;font-size:2.5rem}.avatar-placeholder{font-size:2.5rem}.user-name{font-size:1.5rem}.nav-item{padding:1.25rem 2rem;font-size:1.125rem}.mypage-content{padding:3rem}}@media(max-width:1024px){.mypage-container{grid-template-columns:260px 1fr;gap:2rem;padding:1.5rem;max-width:100%}.mypage-sidebar{top:90px}.user-card{padding:2rem 1.5rem}.user-avatar{width:75px;height:75px;font-size:1.875rem}.avatar-placeholder{font-size:1.875rem}.user-name{font-size:1.25rem}.nav-item{padding:1rem 1.5rem;font-size:1rem}.mypage-content{padding:2rem}}@media(max-width:768px){.mypage-container{grid-template-columns:1fr;gap:1.5rem;padding:1rem}.mypage-sidebar{position:static;max-height:none;top:0}.user-card{padding:1.5rem 1rem;border-radius:12px 12px 0 0}.user-avatar{width:60px;height:60px;font-size:1.5rem}.avatar-placeholder{font-size:1.5rem}.user-name{font-size:1.125rem}.user-email{font-size:.85rem}.mypage-nav{padding:0}.nav-item{padding:.875rem 1.25rem;font-size:.9375rem}.mypage-content{padding:1.5rem}}@media(max-width:480px){.mypage-container{padding:.75rem}.mypage-content{padding:1rem}.user-card{padding:1.25rem .75rem}.user-avatar{width:50px;height:50px;font-size:1.25rem;margin-bottom:.75rem}.avatar-placeholder{font-size:1.25rem}.user-name{font-size:1rem}.user-email{font-size:.8rem}.nav-item{padding:.75rem 1rem;font-size:.875rem;gap:.625rem}}:root{--mc-primary: #667eea;--mc-primary-hover: #5a6fd6;--mc-bg: #f8f9ff;--mc-card-bg: #ffffff;--mc-border: #e5e7eb;--mc-text-main: #1a1a2e;--mc-text-sub: #6b7280;--mc-shadow: 0 2px 12px rgba(102,126,234,.1);--mc-shadow-hover: 0 10px 32px rgba(102,126,234,.2);--mc-radius: 14px;--mc-radius-sm: 8px}.mc-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--mc-bg)}.mc-container{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:3rem 2rem 5rem}.mc-page-title{font-size:2rem;font-weight:800;color:var(--mc-text-main);margin:0 0 .4rem;letter-spacing:-.02em}.mc-page-subtitle{font-size:1rem;color:var(--mc-text-sub);margin:0 0 3rem}.mc-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6rem 2rem;gap:1.2rem;color:var(--mc-text-sub)}.mc-spinner{width:44px;height:44px;border:4px solid var(--mc-border);border-top-color:var(--mc-primary);border-radius:50%;animation:mc-spin .8s linear infinite}@keyframes mc-spin{to{transform:rotate(360deg)}}.mc-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6rem 2rem;background:var(--mc-card-bg);border-radius:var(--mc-radius);border:1.5px dashed var(--mc-border);gap:.75rem;text-align:center}.mc-empty-icon{font-size:4rem;margin:0 0 .5rem;line-height:1}.mc-empty-text{font-size:1.25rem;font-weight:700;color:var(--mc-text-main);margin:0}.mc-empty-sub{font-size:.95rem;color:var(--mc-text-sub);margin:0 0 1rem}.mc-btn-browse{display:inline-flex;align-items:center;gap:.4rem;padding:.75rem 2rem;background:var(--mc-primary);color:#fff;font-size:.95rem;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:background .2s,transform .2s;box-shadow:0 4px 14px #667eea4d}.mc-btn-browse:hover{background:var(--mc-primary-hover);transform:translateY(-2px)}.mc-section{margin-bottom:3.5rem}.mc-section-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--mc-primary)}.mc-section-icon{font-size:1.4rem;line-height:1}.mc-section-title{font-size:1.3rem;font-weight:700;color:var(--mc-text-main);margin:0;flex:1}.mc-section-count{font-size:.85rem;font-weight:600;color:var(--mc-primary);background:#eef2ff;padding:.2rem .7rem;border-radius:50px}.mc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}.mc-card{background:var(--mc-card-bg);border-radius:var(--mc-radius);box-shadow:var(--mc-shadow);overflow:hidden;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease;display:flex;flex-direction:column;border:1px solid transparent}.mc-card:hover{transform:translateY(-6px);box-shadow:var(--mc-shadow-hover);border-color:#667eea26}.mc-thumb-wrap{width:100%;height:200px;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,#e0e7ff,#ede9fe);position:relative}.mc-thumb-img{width:100%!important;height:100%!important;object-fit:cover!important;display:block!important;transition:transform .4s ease}.mc-card:hover .mc-thumb-img{transform:scale(1.04)}.mc-thumb-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#a5b4fc;background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.mc-card-body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;flex:1;gap:.35rem}.mc-title{font-size:1rem;font-weight:700;color:var(--mc-text-main);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mc-subtitle{font-size:.875rem;color:var(--mc-text-sub);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.mc-instructor{font-size:.875rem;color:var(--mc-text-sub);margin:.2rem 0 0}.mc-meta{display:flex;align-items:center;gap:.6rem;margin:.4rem 0 .8rem;flex-wrap:wrap}.mc-level{display:inline-flex;align-items:center;padding:.2rem .7rem;background:#eef2ff;color:var(--mc-primary);border-radius:50px;font-size:.78rem;font-weight:600}.mc-duration{font-size:.82rem;color:var(--mc-text-sub)}.mc-btn-continue{margin-top:auto;padding:.7rem 1.25rem;background:var(--mc-primary);color:#fff;font-size:.9rem;font-weight:600;border:none;border-radius:var(--mc-radius-sm);cursor:pointer;transition:background .2s,transform .2s;width:100%;text-align:center;letter-spacing:.01em}.mc-btn-continue:hover{background:var(--mc-primary-hover);transform:translateY(-1px)}@media(max-width:1100px){.mc-grid{grid-template-columns:repeat(2,1fr);gap:1.4rem}}@media(max-width:768px){.mc-container{padding:2rem 1rem 4rem}.mc-page-title{font-size:1.5rem}}@media(max-width:640px){.mc-grid{grid-template-columns:1fr;gap:1.2rem}.mc-empty{padding:4rem 1.5rem}}.mc-cert-placeholder{background:linear-gradient(135deg,#fef9c3,#fde68a);color:#b45309}.mc-cert-badge{position:absolute;top:10px;right:10px;background:#f59e0b;color:#fff;font-size:.72rem;font-weight:700;padding:.2rem .6rem;border-radius:50px;letter-spacing:.02em;pointer-events:none;box-shadow:0 2px 6px #f59e0b59}.mc-cert-applicant{font-size:.82rem;color:var(--mc-text-sub)}.mc-cert-price{font-size:.82rem;font-weight:700;color:var(--mc-primary);background:#eef2ff;padding:.15rem .55rem;border-radius:50px}.mc-cert-date{font-size:.82rem;color:var(--mc-text-sub);margin:0 0 .6rem}.mc-btn-exam{margin-top:auto;padding:.7rem 1.25rem;background:#f59e0b;color:#fff;font-size:.9rem;font-weight:600;border:none;border-radius:var(--mc-radius-sm);cursor:pointer;transition:background .2s,transform .2s;width:100%;text-align:center;letter-spacing:.01em}.mc-btn-exam:hover{background:#d97706;transform:translateY(-1px)}.mc-btn-browse--cert{background:#f59e0b;box-shadow:0 4px 14px #f59e0b4d}.mc-btn-browse--cert:hover{background:#d97706}.mc-course-badge{position:absolute;top:10px;right:10px;font-size:.72rem;font-weight:700;padding:.2rem .6rem;border-radius:50px;letter-spacing:.02em;pointer-events:none;box-shadow:0 2px 6px #00000026}.mc-course-badge--online{background:#667eea;color:#fff;box-shadow:0 2px 6px #667eea59}.mc-course-badge--offline{background:#10b981;color:#fff;box-shadow:0 2px 6px #10b98159}.mc-tabs{display:flex;gap:.5rem;margin-bottom:2.5rem;background:var(--mc-card-bg);border-radius:14px;padding:.5rem;box-shadow:var(--mc-shadow);border:1px solid var(--mc-border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.mc-tabs::-webkit-scrollbar{display:none}.mc-tab{display:inline-flex;align-items:center;gap:.45rem;padding:.6rem 1.25rem;border:none;border-radius:10px;background:transparent;color:var(--mc-text-sub);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .18s,color .18s,box-shadow .18s;white-space:nowrap;flex-shrink:0}.mc-tab:hover{background:#f0f3ff;color:var(--mc-primary)}.mc-tab--active{background:var(--mc-primary);color:#fff;box-shadow:0 4px 12px #667eea59}.mc-tab--active:hover{background:var(--mc-primary-hover);color:#fff}.mc-tab-icon{font-size:1rem;line-height:1}.mc-tab-label{letter-spacing:-.01em}.mc-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.4rem;height:1.4rem;padding:0 .35rem;background:#e5e7eb;color:#6b7280;font-size:.72rem;font-weight:700;border-radius:50px;transition:background .18s,color .18s}.mc-tab-count--active{background:#ffffff47;color:#fff}.mc-tab-content{animation:mc-fadein .22s ease}@keyframes mc-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.mc-tabs{gap:.3rem;padding:.4rem;margin-bottom:1.75rem}.mc-tab{padding:.55rem .9rem;font-size:.84rem}}.mc-card{position:relative}.mc-card--refund-pending{cursor:default!important}.mc-card--refund-pending:hover{transform:none!important;box-shadow:var(--mc-shadow)!important;border-color:transparent!important}.mc-card--refund-pending .mc-thumb-img{transform:none!important;filter:brightness(.6)}.mc-refund-overlay{position:absolute;inset:0;background:#ef44441a;border-radius:var(--mc-radius);z-index:10;display:flex;align-items:center;justify-content:center;pointer-events:none}.mc-refund-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:.4rem;background:#ffffffeb;border:1.5px solid #ef4444;border-radius:10px;padding:.7rem 1.2rem;box-shadow:0 4px 16px #ef44442e}.mc-refund-overlay-icon{font-size:1.4rem;line-height:1;animation:mc-spin-slow 2s linear infinite}@keyframes mc-spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mc-refund-overlay-text{font-size:.82rem;font-weight:700;color:#dc2626;white-space:nowrap;letter-spacing:-.01em}.mc-refund-rejected-badge{position:absolute;top:10px;left:10px;background:#fee2e2;color:#dc2626;border:1px solid #fca5a5;font-size:.7rem;font-weight:700;padding:.18rem .55rem;border-radius:50px;letter-spacing:.02em;pointer-events:none;box-shadow:0 1px 4px #dc26262e;z-index:2}.mc-btn-continue:disabled,.mc-btn-exam:disabled{background:#d1d5db;color:#9ca3af;cursor:default;transform:none;box-shadow:none}.mc-btn-exam--retry{background:#ea580c!important;box-shadow:0 4px 14px #ea580c4d!important}.mc-btn-exam--retry:hover{background:#c2410c!important;transform:translateY(-1px)}.mc-btn-exam--passed{background:#059669!important;box-shadow:0 4px 14px #0596694d!important}.mc-btn-exam--passed:hover{background:#047857!important;transform:translateY(-1px)}.mc-cert-status-row{display:flex;align-items:center;gap:.5rem;margin:.4rem 0 .2rem;flex-wrap:wrap}.mc-cert-status{display:inline-flex;align-items:center;font-size:.74rem;font-weight:700;padding:.18rem .62rem;border-radius:50px;letter-spacing:.02em;white-space:nowrap}.mc-cert-status--none{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.mc-cert-status--failed{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5}.mc-cert-status--passed{background:#dcfce7;color:#16a34a;border:1px solid #86efac}.mc-cert-status--exhausted{background:#f1f5f9;color:#94a3b8;border:1px solid #cbd5e1}.mc-cert-attempt-count{font-size:.78rem;color:var(--mc-text-sub);white-space:nowrap}.mc-cert-score-row{display:flex;align-items:center;gap:.45rem;margin:.25rem 0 .4rem;flex-wrap:wrap}.mc-cert-score-label{font-size:.78rem;color:var(--mc-text-sub)}.mc-cert-score-value{font-size:.9rem;font-weight:700}.mc-cert-score--pass{color:#16a34a}.mc-cert-score--fail{color:#dc2626}.mc-cert-score-date{font-size:.74rem;color:#16a34a;background:#dcfce7;padding:.1rem .45rem;border-radius:50px}.mc-cert-passed-overlay{position:absolute;inset:0;background:#0596692e;display:flex;align-items:center;justify-content:center;pointer-events:none}.mc-cert-passed-stamp{font-size:2.2rem;font-weight:900;color:#fff;border:4px solid #fff;border-radius:8px;padding:.2rem .9rem;letter-spacing:.1em;opacity:.92;text-shadow:0 2px 8px rgba(0,0,0,.25);transform:rotate(-12deg);box-shadow:0 4px 16px #0000002e}.mc-card--exhausted{cursor:default!important}.mc-card--exhausted:hover{transform:none!important;box-shadow:var(--mc-shadow)!important;border-color:transparent!important}.mc-card--exhausted .mc-thumb-img{filter:grayscale(40%) brightness(.85)}.mc-cert-btn-group{display:flex;flex-direction:column;gap:.5rem;margin-top:auto}.mc-cert-btn-group .mc-btn-exam{margin-top:0}.mc-btn-exam--review{background:transparent!important;color:#ea580c!important;border:1.5px solid #ea580c!important;box-shadow:none!important}.mc-btn-exam--review:hover{background:#fff7ed!important;transform:translateY(-1px)}.mc-modal-backdrop{position:fixed;inset:0;background:#0000008c;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:mc-fadein .2s ease;cursor:default;overscroll-behavior:contain;touch-action:none}.mc-modal{background:#fff;border-radius:18px;width:100%;max-width:1200px;max-height:80vh;overflow:hidden;box-shadow:0 24px 64px #00000040;display:flex;flex-direction:column}.mc-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.5rem 1.75rem 1rem;border-bottom:1px solid #f0f0f0;position:sticky;top:0;background:#fff;z-index:1;border-radius:18px 18px 0 0}.mc-modal-title{font-size:1.2rem;font-weight:800;color:#1a1a2e;margin:0 0 .2rem}.mc-modal-subtitle{font-size:.88rem;color:#6b7280;margin:0}.mc-modal-close{background:none;border:none;font-size:1.25rem;color:#9ca3af;cursor:pointer;padding:.2rem .4rem;line-height:1;border-radius:6px;transition:background .15s,color .15s;flex-shrink:0}.mc-modal-close:hover{background:#f3f4f6;color:#374151}.mc-modal-body{padding:1.25rem 1.75rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start;overflow-y:auto;flex:1 1 auto;min-height:0}.mc-modal-left{display:flex;flex-direction:column;gap:1.25rem;min-width:0}.mc-modal-right{display:flex;flex-direction:column;gap:1rem;min-width:0;border-left:1px solid #f0f0f0;padding-left:2rem}.mc-apply-score-summary{display:flex;align-items:center;justify-content:center;gap:.75rem;background:linear-gradient(135deg,#dcfce7,#d1fae5);border:1.5px solid #86efac;border-radius:12px;padding:.9rem 1.5rem}.mc-apply-score-num{font-size:2rem;font-weight:900;color:#059669;line-height:1}.mc-apply-score-label{font-size:1rem;font-weight:700;color:#16a34a}.mc-apply-section-title{font-size:.95rem;font-weight:700;color:#1a1a2e;margin:0 0 .85rem}.mc-apply-cert-meta{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.mc-apply-cert-meta-item{display:flex;align-items:center;gap:.6rem;flex:1;min-width:130px;padding:.75rem 1rem;background:#f8f9ff;border:1px solid #e5e7eb;border-radius:10px}.mc-apply-cert-meta-item--format{background:#eef2ff;border-color:#c7d2fe}.mc-apply-cert-meta-icon{font-size:1.4rem;flex-shrink:0;line-height:1}.mc-apply-cert-meta-item div{display:flex;flex-direction:column;gap:2px}.mc-apply-cert-meta-label{font-size:.72rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.03em}.mc-apply-cert-meta-value{font-size:.875rem;font-weight:700;color:#1a1a2e}.mc-apply-cert-meta-item--format .mc-apply-cert-meta-label{color:#818cf8}.mc-apply-cert-meta-item--format .mc-apply-cert-meta-value{color:#4338ca}.mc-apply-graph-section{background:#f8f9ff;border-radius:12px;padding:1.1rem 1.25rem;border:1px solid #e5e7eb}.mc-apply-graph-loading,.mc-apply-graph-empty{display:flex;align-items:center;justify-content:center;gap:.5rem;color:#9ca3af;font-size:.88rem;padding:1rem 0}.mc-bar-chart{display:flex;flex-direction:column;gap:.75rem}.mc-bar-row{display:grid;grid-template-columns:120px 1fr 80px;align-items:center;gap:.65rem}.mc-bar-label{font-size:.8rem;color:#374151;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mc-bar-track{height:12px;background:#e5e7eb;border-radius:50px;overflow:hidden}.mc-bar-fill{height:100%;border-radius:50px;transition:width .5s ease}.mc-bar-value{display:flex;flex-direction:column;align-items:flex-end;gap:.05rem}.mc-bar-pts{font-size:.78rem;font-weight:700;color:#374151}.mc-bar-total{font-weight:400;color:#9ca3af}.mc-bar-pct{font-size:.72rem;font-weight:700}.mc-apply-form{display:flex;flex-direction:column;gap:1.1rem}.mc-apply-form-row{display:flex;flex-direction:column;gap:.35rem}.mc-apply-form-row label{font-size:.85rem;font-weight:600;color:#374151}.mc-apply-form-row input{padding:.62rem .9rem;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.92rem;color:#1a1a2e;transition:border-color .18s;outline:none;width:100%;box-sizing:border-box}.mc-apply-form-row input:focus{border-color:#667eea}.mc-apply-form-row input[readonly]{background:#f9fafb;color:#6b7280}.mc-apply-addr-row{display:flex;gap:.5rem}.mc-apply-postal{flex:1;min-width:0}.mc-apply-addr-btn{padding:.62rem 1rem;background:#667eea;color:#fff;font-size:.85rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;white-space:nowrap;transition:background .18s;flex-shrink:0}.mc-apply-addr-btn:hover{background:#5a6fd6}.mc-apply-addr-btn:disabled{background:#d1d5db;cursor:default}.mc-apply-help{font-size:.78rem;color:#9ca3af}.mc-apply-error{font-size:.85rem;color:#dc2626;background:#fee2e2;border-radius:8px;padding:.6rem .9rem;margin:0}.mc-apply-submit-btn{padding:.85rem;background:#059669;color:#fff;font-size:1rem;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:background .2s,transform .2s;width:100%;box-shadow:0 4px 14px #0596694d;letter-spacing:-.01em}.mc-apply-submit-btn:hover{background:#047857;transform:translateY(-1px)}.mc-apply-submit-btn:disabled{background:#d1d5db;box-shadow:none;cursor:default;transform:none}.mc-apply-success{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:2rem 1rem;text-align:center}.mc-apply-success-icon{font-size:3rem}.mc-apply-success-text{font-size:1.1rem;font-weight:700;color:#059669;margin:0}.mc-apply-success-sub{font-size:.9rem;color:#6b7280;margin:0}@media(max-width:640px){.mc-modal{border-radius:14px;max-width:98vw}.mc-modal-body{grid-template-columns:1fr;gap:1rem}.mc-modal-header{padding:1.25rem 1.25rem .9rem}.mc-modal-body{padding:1rem 1.25rem 1.5rem}.mc-bar-row{grid-template-columns:90px 1fr 64px;gap:.45rem}.mc-bar-label{font-size:.74rem}.mc-cert-btn-group{gap:.4rem}}.mc-history-modal{max-width:560px;max-height:85vh}.mc-history-body{padding:1.5rem 1.75rem 2rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.mc-history-status-box{display:flex;align-items:flex-start;gap:.9rem;padding:1rem 1.25rem;border:2px solid;border-radius:12px}.mc-history-status-icon{font-size:1.6rem;line-height:1;flex-shrink:0}.mc-history-status-label{font-size:1rem;font-weight:800;margin:0 0 .2rem}.mc-history-status-desc{font-size:.83rem;color:#6b7280;margin:0}.mc-history-section{display:flex;flex-direction:column;gap:.5rem}.mc-history-section-title{font-size:.85rem;font-weight:700;color:#374151;margin:0 0 .25rem;padding-bottom:.4rem;border-bottom:1px solid #e5e7eb}.mc-history-grid{display:flex;flex-direction:column;gap:.45rem}.mc-history-row{display:flex;align-items:baseline;gap:.5rem}.mc-history-key{flex-shrink:0;width:90px;font-size:.8rem;color:#9ca3af;font-weight:600}.mc-history-val{font-size:.88rem;color:#1f2937;word-break:break-all}.mc-history-note{font-size:.88rem;color:#374151;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem 1rem;margin:0;white-space:pre-wrap}.mc-history-close-btn{margin-top:.5rem;width:100%;padding:.75rem;background:#f3f4f6;border:none;border-radius:10px;font-size:.95rem;font-weight:700;color:#374151;cursor:pointer;transition:background .15s}.mc-history-close-btn:hover{background:#e5e7eb}.mc-btn-exam--history{background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;font-size:.82rem}.mc-btn-exam--history:hover{background:linear-gradient(135deg,#6d28d9,#4c1d95)}.mc-cert-date--applied{color:#7c3aed!important;font-weight:600}:root{--crv-primary: #667eea;--crv-bg: #f8f9ff;--crv-card-bg: #ffffff;--crv-border: #e5e7eb;--crv-text: #1a1a2e;--crv-sub: #6b7280;--crv-radius: 14px;--crv-radius-sm: 8px;--crv-shadow: 0 2px 12px rgba(102,126,234,.08);--crv-ok: #16a34a;--crv-ng: #e11d48;--crv-ok-bg: #f0fdf4;--crv-ok-border: #bbf7d0;--crv-ng-light: #f43f5e;--crv-emp: #9ca3af;--crv-essay: #7c3aed}.crv-page{min-height:100vh;display:flex;flex-direction:column;background:var(--crv-bg)}.crv-center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem}.crv-spinner{width:44px;height:44px;border:4px solid var(--crv-border);border-top-color:var(--crv-primary);border-radius:50%;animation:crv-spin .8s linear infinite}@keyframes crv-spin{to{transform:rotate(360deg)}}.crv-loading-text{color:var(--crv-sub);font-size:.95rem}.crv-error-icon{font-size:3rem}.crv-error-text{font-size:.95rem;color:var(--crv-text);font-weight:600}.crv-container{flex:1;max-width:1280px;width:100%;margin:0 auto;padding:1.5rem 1.5rem 4rem;display:flex;flex-direction:column;gap:1.25rem}.crv-top-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.crv-top-left{display:flex;align-items:center;gap:1rem}.crv-back-btn{padding:.45rem 1rem;border:1.5px solid var(--crv-border);border-radius:var(--crv-radius-sm);background:var(--crv-card-bg);font-size:.85rem;font-weight:600;color:var(--crv-sub);cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.crv-back-btn:hover{background:#f3f4f6;border-color:#9ca3af}.crv-page-title{font-size:1.4rem;font-weight:800;color:var(--crv-text);margin:0 0 .1rem;letter-spacing:-.02em}.crv-page-sub{font-size:.85rem;color:var(--crv-sub);margin:0}.crv-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.55rem 1.15rem;border-radius:var(--crv-radius-sm);font-size:.88rem;font-weight:700;cursor:pointer;transition:background .18s,transform .18s;border:none}.crv-btn--outline{background:var(--crv-card-bg);border:1.5px solid var(--crv-border);color:var(--crv-sub)}.crv-btn--outline:hover{background:#f3f4f6}.crv-attempt-tabs{background:var(--crv-card-bg);border-radius:var(--crv-radius);border:1px solid var(--crv-border);box-shadow:var(--crv-shadow);overflow:hidden}.crv-attempt-tabs-inner{display:flex;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--crv-border) transparent}.crv-attempt-tabs-inner::-webkit-scrollbar{height:4px}.crv-attempt-tabs-inner::-webkit-scrollbar-thumb{background:var(--crv-border);border-radius:2px}.crv-attempt-tab{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.85rem 1.4rem;border:none;border-right:1px solid var(--crv-border);background:transparent;cursor:pointer;transition:background .15s;position:relative;min-width:110px}.crv-attempt-tab:last-child{border-right:none}.crv-attempt-tab:hover{background:#f8f9ff}.crv-attempt-tab--active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;border-radius:3px 3px 0 0;background:var(--crv-primary)}.crv-attempt-tab--active{background:#f5f7ff}.crv-tab-round{font-size:.78rem;font-weight:700;color:var(--crv-sub)}.crv-attempt-tab--active .crv-tab-round{color:var(--crv-primary)}.crv-tab-score{font-size:1.15rem;font-weight:900;letter-spacing:-.03em;line-height:1;color:#475569}.crv-attempt-tab--pass .crv-tab-score{color:var(--crv-ok)}.crv-tab-badge{font-size:.68rem;font-weight:600;padding:.1rem .5rem;border-radius:50px}.crv-tab-badge--pass{background:var(--crv-ok-bg);color:var(--crv-ok);border:1px solid var(--crv-ok-border)}.crv-tab-badge--fail{background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db}.crv-tab-date{font-size:.7rem;color:var(--crv-sub);font-weight:400}.crv-top-panel{display:grid;grid-template-columns:320px 1fr;gap:1rem;align-items:start}.crv-summary-card{background:var(--crv-card-bg);border-radius:var(--crv-radius);box-shadow:var(--crv-shadow);border:1px solid var(--crv-border);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem;height:100%}.crv-summary-main{display:flex;flex-direction:row;align-items:center;gap:1rem}.crv-summary-score{font-size:2.8rem;font-weight:900;line-height:1;letter-spacing:-.03em;color:var(--crv-text)}.crv-summary-score-unit{font-size:1.2rem;font-weight:700;margin-left:2px}.crv-summary-score--pass{color:var(--crv-ok)}.crv-summary-score--fail{color:var(--crv-text)}.crv-badge--pass{display:inline-flex;align-items:center;font-size:.82rem;font-weight:700;padding:.25rem .8rem;border-radius:50px;background:var(--crv-ok-bg);color:var(--crv-ok);border:1px solid var(--crv-ok-border)}.crv-badge--fail{display:inline-flex;align-items:center;font-size:.82rem;font-weight:700;padding:.25rem .8rem;border-radius:50px;background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.crv-summary-divider{height:1px;background:var(--crv-border)}.crv-summary-meta{display:flex;flex-direction:column;gap:.5rem}.crv-summary-item{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.crv-summary-lbl{font-size:.76rem;color:var(--crv-sub);font-weight:500;white-space:nowrap}.crv-summary-val{font-size:.88rem;font-weight:700;color:var(--crv-text);text-align:right}.crv-chart-card{background:var(--crv-card-bg);border-radius:var(--crv-radius);box-shadow:var(--crv-shadow);border:1px solid var(--crv-border);padding:1.25rem 1.5rem}.crv-section-title{font-size:.92rem;font-weight:700;color:var(--crv-text);margin:0 0 1rem}.crv-bar-chart{display:flex;flex-direction:column;gap:.65rem}.crv-bar-row{display:grid;grid-template-columns:120px 1fr 130px;align-items:center;gap:.6rem}.crv-bar-row--total{border-top:1px solid var(--crv-border);padding-top:.65rem;margin-top:.1rem}.crv-bar-label{font-size:.8rem;font-weight:600;color:var(--crv-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crv-bar-track{height:10px;background:#f1f5f9;border-radius:50px;overflow:hidden}.crv-bar-fill{height:100%;border-radius:50px;transition:width .5s ease;min-width:3px}.crv-bar-info{display:flex;align-items:center;justify-content:space-between;gap:.4rem}.crv-bar-pts{font-size:.8rem;font-weight:700;color:var(--crv-text)}.crv-bar-total{font-weight:400;color:var(--crv-sub)}.crv-bar-pct{font-size:.76rem;font-weight:600}.crv-filter-sticky{position:sticky;top:0;z-index:100;background:var(--crv-bg);padding:.6rem 0 .4rem;margin:0 -.25rem;display:flex;flex-direction:column;gap:.4rem;box-shadow:0 4px 12px #0000000d;border-radius:0 0 var(--crv-radius-sm) var(--crv-radius-sm)}.crv-filter-bar{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center;padding:0 .25rem}.crv-filter-spacer{flex:1}.crv-filter-btn{padding:.38rem .9rem;border:1.5px solid var(--crv-border);border-radius:50px;background:var(--crv-card-bg);font-size:.82rem;font-weight:600;color:var(--crv-sub);cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.crv-filter-btn:hover{background:#f3f4f6;border-color:#9ca3af}.crv-filter-btn--active,.crv-filter--ng.crv-filter-btn--active{background:#1e293b;border-color:#1e293b;color:#fff}.crv-filter--ok.crv-filter-btn--active{background:#166534;border-color:#166534;color:#fff}.crv-filter--empty.crv-filter-btn--active{background:#374151;border-color:#374151;color:#fff}.crv-filter--essay.crv-filter-btn--active{background:#5b21b6;border-color:#5b21b6;color:#fff}.crv-accordion-toggle-all{padding:.38rem .85rem;border:1.5px solid #cbd5e1;border-radius:50px;background:transparent;font-size:.78rem;font-weight:700;color:#64748b;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.crv-accordion-toggle-all:hover{background:#f1f5f9;color:var(--crv-text)}.crv-filter-notice{margin:0 .25rem;padding:.4rem .9rem;border-radius:var(--crv-radius-sm);font-size:.82rem;font-weight:500;background:#f8fafc;border:1px solid var(--crv-border);color:var(--crv-sub)}.crv-ans-list{display:flex;flex-direction:column;gap:.6rem}.crv-subject-group{display:flex;flex-direction:column;gap:0}.crv-subject-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--crv-card-bg);border-radius:var(--crv-radius-sm);border:1px solid var(--crv-border);border-left:4px solid var(--crv-primary);flex-wrap:wrap;gap:.5rem;cursor:pointer;transition:background .15s,border-radius .15s;width:100%;text-align:left}.crv-subject-header--open{border-radius:var(--crv-radius-sm) var(--crv-radius-sm) 0 0;border-bottom-color:transparent;background:#f8faff}.crv-subject-header:hover{background:#f8faff}.crv-subject-header-left{display:flex;align-items:center;gap:.5rem}.crv-accordion-icon{font-size:.68rem;color:#94a3b8;width:14px}.crv-subject-name{font-size:.92rem;font-weight:700;color:var(--crv-text)}.crv-subject-count{font-size:.73rem;font-weight:600;color:var(--crv-sub);background:#f1f5f9;padding:.08rem .5rem;border-radius:50px}.crv-subject-meta{display:flex;align-items:center;gap:.4rem;font-size:.78rem}.crv-subj-ok{color:#16a34a;font-weight:600}.crv-subj-ng{color:#64748b;font-weight:600}.crv-subj-emp{color:var(--crv-emp);font-weight:500}.crv-subj-score{color:var(--crv-sub);font-weight:500}.crv-subj-sep{color:#d1d5db}.crv-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding:.75rem;background:#f8fafc;border:1px solid var(--crv-border);border-top:none;border-radius:0 0 var(--crv-radius-sm) var(--crv-radius-sm);animation:crv-expand .18s ease}@keyframes crv-expand{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.crv-ans-card{background:var(--crv-card-bg);border-radius:var(--crv-radius);box-shadow:0 1px 4px #0000000f;border:1px solid var(--crv-border);border-left:4px solid transparent;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.7rem}.crv-ans-card--ng{border-left-color:#f87171}.crv-ans-card--ok{border-left-color:#4ade80}.crv-ans-card--empty{border-left-color:#d1d5db}.crv-ans-card--essay{border-left-color:#a78bfa}.crv-card-top{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.crv-card-num{font-size:.74rem;color:var(--crv-sub);font-weight:600;background:#f1f5f9;padding:.1rem .5rem;border-radius:50px}.crv-card-badge{font-size:.72rem;font-weight:700;padding:.12rem .55rem;border-radius:50px;border:1px solid transparent}.crv-card-badge--ok{background:var(--crv-ok-bg);color:var(--crv-ok);border-color:var(--crv-ok-border)}.crv-card-badge--ng{background:#fff;color:#64748b;border-color:#e2e8f0}.crv-card-badge--empty{background:#f8fafc;color:#94a3b8;border-color:#e2e8f0}.crv-card-badge--essay{background:#f5f3ff;color:var(--crv-essay);border-color:#e9d5ff}.crv-card-pts{margin-left:auto;font-size:.73rem;font-weight:700;color:#64748b;background:#f1f5f9;padding:.1rem .45rem;border-radius:50px}.crv-card-diff{font-size:.7rem;font-weight:600;padding:.1rem .45rem;border-radius:50px;border:1px solid transparent}.crv-card-diff--상{background:#fff0f0;color:#b91c1c;border-color:#fecaca}.crv-card-diff--중{background:#fffbeb;color:#92400e;border-color:#fde68a}.crv-card-diff--하{background:var(--crv-ok-bg);color:var(--crv-ok);border-color:var(--crv-ok-border)}.crv-card-qtext{font-size:.91rem;font-weight:600;color:var(--crv-text);line-height:1.55;margin:0}.crv-options-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.crv-option{display:flex;align-items:center;gap:.45rem;padding:.32rem .65rem;border-radius:6px;border:1px solid #f1f5f9;font-size:.83rem;color:#475569;background:#fafafa}.crv-option--correct{background:var(--crv-ok-bg);border-color:var(--crv-ok-border);color:#166534;font-weight:600}.crv-option--wrong{background:#f8fafc;border-color:#e2e8f0;color:#334155}.crv-option-no{font-size:.83rem;font-weight:700;min-width:1.3rem}.crv-option-text{flex:1}.crv-option-tag{font-size:.66rem;font-weight:700;padding:.09rem .4rem;border-radius:50px;white-space:nowrap}.crv-option-tag--correct{background:var(--crv-ok);color:#fff}.crv-option-tag--wrong{background:#475569;color:#fff}.crv-ans-cols{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.crv-ans-col{padding:.5rem .75rem;border-radius:var(--crv-radius-sm);border:1px solid var(--crv-border);display:flex;flex-direction:column;gap:.22rem;background:#fafafa}.crv-ans-col--correct,.crv-ans-col--ok{background:var(--crv-ok-bg);border-color:var(--crv-ok-border)}.crv-ans-col--ng{background:#fafafa;border-color:var(--crv-border)}.crv-ans-col--empty{background:#fafafa}.crv-ans-col-lbl{font-size:.68rem;font-weight:700;color:var(--crv-sub);text-transform:uppercase;letter-spacing:.04em}.crv-ans-display{display:inline-flex;align-items:center;gap:.3rem;font-size:.85rem;font-weight:600}.crv-ans-display--correct,.crv-ans-display--ok{color:#166534}.crv-ans-display--ng{color:#334155}.crv-ans-circle{font-size:.92rem;font-weight:700}.crv-muted{color:var(--crv-sub);font-style:italic;font-size:.82rem}.crv-essay-area{padding:.65rem .9rem;background:#faf5ff;border:1px solid #ede9fe;border-radius:var(--crv-radius-sm);display:flex;flex-direction:column;gap:.3rem}.crv-essay-label{font-size:.74rem;font-weight:700;color:var(--crv-essay);margin:0}.crv-essay-content{font-size:.87rem;color:var(--crv-text);margin:0;line-height:1.5;white-space:pre-wrap}.crv-essay-score{font-size:.82rem;color:var(--crv-essay);margin:0}.crv-essay-max{color:var(--crv-sub)}.crv-explanation{display:flex;gap:.5rem;padding:.75rem .9rem;background:#fffdf5;border:1px solid #fde68a;border-radius:var(--crv-radius-sm)}.crv-explanation-icon{font-size:1rem;flex-shrink:0;line-height:1.4}.crv-explanation-title{font-size:.72rem;font-weight:700;color:#92400e;margin:0 0 .2rem;text-transform:uppercase;letter-spacing:.04em}.crv-explanation-text{font-size:.86rem;color:#78350f;line-height:1.55;margin:0;white-space:pre-wrap}.crv-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 2rem;background:var(--crv-card-bg);border-radius:var(--crv-radius);border:1.5px dashed var(--crv-border);gap:.65rem;text-align:center}.crv-empty-icon{font-size:2.5rem;margin:0}.crv-empty-text{font-size:1rem;font-weight:700;color:var(--crv-text);margin:0}.crv-bottom-actions{display:flex;align-items:center;justify-content:flex-start;gap:.75rem;padding-top:1rem;border-top:1px solid var(--crv-border);flex-wrap:wrap}@media(max-width:1100px){.crv-top-panel{grid-template-columns:1fr}.crv-summary-card{flex-direction:row;align-items:flex-start;gap:1.5rem}.crv-summary-meta{flex-direction:row;flex-wrap:wrap;gap:.75rem 1.5rem}.crv-summary-item{flex-direction:column;align-items:flex-start}.crv-summary-val{text-align:left}.crv-summary-divider{display:none}}@media(max-width:860px){.crv-card-grid{grid-template-columns:1fr}.crv-bar-row{grid-template-columns:90px 1fr 100px;gap:.45rem}.crv-bar-label,.crv-bar-pts{font-size:.74rem}.crv-bar-pct{font-size:.7rem}.crv-attempt-tab{min-width:90px;padding:.65rem 1rem}}@media(max-width:640px){.crv-container{padding:1rem .9rem 3.5rem;gap:1rem}.crv-summary-card{flex-direction:column}.crv-summary-main{flex-direction:row}.crv-filter-bar{gap:.3rem}.crv-ans-cols{grid-template-columns:1fr}.crv-tab-date{display:none}}@media(max-width:480px){.crv-top-header{flex-direction:column;gap:.65rem}.crv-bar-row{grid-template-columns:75px 1fr}.crv-bar-info{display:none}.crv-bar-track{height:9px}.crv-bottom-actions{flex-direction:column}.crv-bottom-actions .crv-btn{width:100%;justify-content:center}.crv-attempt-tab{min-width:80px;padding:.55rem .75rem}.crv-tab-score{font-size:1rem}}.ia-wrap{max-width:860px;margin:0 auto;padding:2.5rem 1.5rem 5rem;min-height:100vh;background:#f8fafc}.ia-header{text-align:center;margin-bottom:2.5rem;padding:2.5rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;box-shadow:0 8px 32px #667eea59}.ia-header-badge{display:inline-block;background:#fff3;border:1px solid rgba(255,255,255,.4);border-radius:20px;padding:.3rem 1rem;font-size:.8rem;font-weight:600;letter-spacing:.05em;margin-bottom:1rem;text-transform:uppercase}.ia-title{font-size:2rem;font-weight:800;margin:0 0 .75rem;color:#fff}.ia-subtitle{font-size:.95rem;color:#ffffffe0;line-height:1.7;margin:0}.ia-form{display:flex;flex-direction:column;gap:1.5rem}.ia-section{background:#fff;border-radius:16px;padding:1.75rem 2rem;border:1px solid #e2e8f0;box-shadow:0 1px 6px #0000000d;display:flex;flex-direction:column;gap:1.1rem}.ia-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.ia-section-num{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.75rem;font-weight:800;border-radius:8px;flex-shrink:0}.ia-section-title{font-size:1.1rem;font-weight:700;color:#1e293b;margin:0}.ia-section-desc{font-size:.8rem;color:#94a3b8;margin-left:auto}.ia-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.ia-field{display:flex;flex-direction:column;gap:.4rem}.ia-label{font-size:.85rem;font-weight:600;color:#374151}.ia-required{color:#ef4444;margin-left:2px}.ia-input,.ia-textarea{padding:.6rem .9rem;border:1.5px solid #e2e8f0;border-radius:10px;font-size:.9rem;color:#1e293b;background:#f8fafc;transition:border-color .2s,box-shadow .2s;font-family:inherit;resize:vertical;line-height:1.6}.ia-input:focus,.ia-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1f;background:#fff}.ia-input::placeholder,.ia-textarea::placeholder{color:#cbd5e1}.ia-textarea--curriculum{min-height:220px;font-family:Pretendard,Apple SD Gothic Neo,sans-serif;font-size:.88rem;line-height:1.8;white-space:pre-wrap;background:#f8fafc}.ia-textarea--curriculum:focus{background:#fff}.ia-radio-group{display:flex;gap:1rem;flex-wrap:wrap}.ia-radio-label{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;padding:.45rem 1rem;border:1.5px solid #e2e8f0;border-radius:20px;transition:all .2s;background:#f8fafc}.ia-radio-label:has(.ia-radio:checked){border-color:#667eea;background:#eef0fe;color:#4f46e5;font-weight:600}.ia-radio{accent-color:#667eea}.ia-radio-text{font-size:.88rem;color:#374151}.ia-file-list{display:flex;flex-direction:column;gap:.75rem}.ia-file-item{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.1rem;border:1.5px solid #e2e8f0;border-radius:12px;background:#f8fafc;gap:1rem;transition:border-color .2s}.ia-file-item:hover{border-color:#c7d2fe}.ia-file-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.ia-file-icon{font-size:1.5rem;flex-shrink:0}.ia-file-name{font-size:.88rem;font-weight:600;color:#1e293b;margin:0 0 .15rem}.ia-file-desc{font-size:.78rem;color:#94a3b8;margin:0}.ia-file-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem 1rem;background:#667eea;color:#fff;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;flex-shrink:0;transition:background .2s,transform .15s;white-space:nowrap}.ia-file-btn:hover{background:#5a6fd6;transform:translateY(-1px)}.ia-file-selected{color:#34d399;font-size:.78rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ia-error{padding:.9rem 1.1rem;background:#fef2f2;border:1px solid #fca5a5;border-radius:10px;color:#dc2626;font-size:.88rem;font-weight:500}.ia-privacy-notice{padding:1rem 1.25rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;color:#64748b;font-size:.82rem;line-height:1.7}.ia-privacy-notice p{margin:0}.ia-privacy-notice a{color:#667eea;text-decoration:underline}.ia-submit-wrap{display:flex;justify-content:center;padding-top:.5rem}.ia-btn-submit{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1rem;font-weight:700;border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 18px #667eea66;transition:all .2s;letter-spacing:.02em}.ia-btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #667eea80}.ia-btn-submit:disabled{opacity:.7;cursor:not-allowed}.ia-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:ia-spin .7s linear infinite}@keyframes ia-spin{to{transform:rotate(360deg)}}.ia-success{text-align:center;padding:4rem 2rem;background:#fff;border-radius:20px;box-shadow:0 4px 24px #00000012}.ia-success-icon{font-size:3.5rem;margin-bottom:1.25rem}.ia-success h2{font-size:1.6rem;font-weight:800;color:#1e293b;margin:0 0 .75rem}.ia-success p{color:#64748b;font-size:.95rem;line-height:1.8;margin:0 0 2rem}.ia-btn-home{padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;border:none;border-radius:10px;font-size:.95rem;cursor:pointer;box-shadow:0 4px 14px #667eea59;transition:all .2s}.ia-btn-home:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea73}@media(max-width:640px){.ia-wrap{padding:1.5rem 1rem 4rem}.ia-header{padding:1.75rem 1.25rem}.ia-title{font-size:1.5rem}.ia-section{padding:1.25rem 1.1rem}.ia-grid-2{grid-template-columns:1fr}.ia-file-item{flex-direction:column;align-items:flex-start}.ia-file-btn{width:100%;justify-content:center}.ia-radio-group{gap:.5rem}.ia-btn-submit{width:100%;justify-content:center}}:root{--ip-primary: #3b82f6;--ip-primary-dark: #2563eb;--ip-bg: #f8fafc;--ip-card-bg: #ffffff;--ip-border: #e2e8f0;--ip-text: #1e293b;--ip-text-muted: #64748b;--ip-radius: 12px;--ip-shadow: 0 2px 8px rgba(0,0,0,.08);--ip-shadow-hover: 0 8px 24px rgba(0,0,0,.14)}.ip-wrap{min-height:100vh;background:var(--ip-bg);font-family:Pretendard,sans-serif}.ip-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:12px;color:var(--ip-text-muted)}.ip-spinner{width:36px;height:36px;border:3px solid var(--ip-border);border-top-color:var(--ip-primary);border-radius:50%;animation:spin .7s linear infinite}.ip-empty{display:flex;flex-direction:column;align-items:center;padding:80px 0;gap:12px;color:var(--ip-text-muted)}.ip-empty-icon{font-size:48px}.ip-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;display:inline-block}.badge-active{background:#dcfce7;color:#16a34a}.badge-draft{background:#fef9c3;color:#ca8a04}.badge-closed{background:#fee2e2;color:#dc2626}.badge-inactive{background:#f1f5f9;color:#64748b}.ip-list-header{background:linear-gradient(135deg,#1e3a5f,#2563eb);color:#fff;padding:48px 24px 36px}.ip-list-header-inner{max-width:1100px;margin:0 auto}.ip-logo{font-size:22px;font-weight:700;margin-bottom:8px}.ip-list-desc{font-size:14px;opacity:.85;margin:0}.ip-list-body{max-width:1100px;margin:0 auto;padding:32px 24px}.ip-list-search-wrap{margin-bottom:24px}.ip-list-search{width:100%;max-width:400px;padding:10px 16px;border:1.5px solid var(--ip-border);border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}.ip-list-search:focus{border-color:var(--ip-primary)}.ip-course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.ip-course-card{background:var(--ip-card-bg);border-radius:var(--ip-radius);box-shadow:var(--ip-shadow);cursor:pointer;overflow:hidden;transition:box-shadow .25s,transform .25s;border:2px solid transparent}.ip-course-card:hover{box-shadow:var(--ip-shadow-hover);transform:translateY(-3px)}.ip-course-card.authed{border-color:#22c55e}.ip-card-thumb-wrap{position:relative;aspect-ratio:16/9;background:#e2e8f0;overflow:hidden}.ip-card-thumb{width:100%;height:100%;object-fit:cover}.ip-card-thumb-placeholder{display:flex;align-items:center;justify-content:center;height:100%;font-size:32px;color:#94a3b8}.ip-card-thumb-wrap .ip-badge{position:absolute;top:8px;left:8px}.ip-authed-badge{position:absolute;top:8px;right:8px;background:#22c55e;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px}.ip-card-body{padding:14px 16px}.ip-card-title{font-size:15px;font-weight:700;color:var(--ip-text);margin:0 0 6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ip-card-instructor{font-size:13px;color:var(--ip-text-muted);margin:0 0 10px}.ip-card-stats{display:flex;gap:12px;font-size:12px;color:var(--ip-text-muted)}.ip-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.ip-modal{background:#fff;border-radius:16px;padding:32px;width:100%;max-width:440px;position:relative;box-shadow:0 20px 60px #0003;animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ip-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--ip-text-muted)}.ip-modal-title{font-size:20px;font-weight:700;color:var(--ip-text);margin:0 0 20px}.ip-modal-course{display:flex;gap:12px;align-items:center;background:#f8fafc;border-radius:10px;padding:12px;margin-bottom:24px}.ip-modal-thumb{width:64px;height:48px;object-fit:cover;border-radius:6px;flex-shrink:0}.ip-modal-course-title{font-size:14px;font-weight:600;color:var(--ip-text);margin:0 0 4px}.ip-modal-course-inst{font-size:12px;color:var(--ip-text-muted);margin:0}.ip-pw-form{display:flex;flex-direction:column;gap:12px}.ip-pw-label{font-size:13px;font-weight:600;color:var(--ip-text)}.ip-pw-input-wrap{position:relative}.ip-pw-input{width:100%;padding:11px 44px 11px 14px;border:1.5px solid var(--ip-border);border-radius:8px;font-size:14px;outline:none;transition:border-color .2s;box-sizing:border-box}.ip-pw-input:focus{border-color:var(--ip-primary)}.ip-pw-input.error{border-color:#ef4444}.ip-pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px}.ip-pw-error{font-size:12px;color:#ef4444;margin:0}.ip-pw-submit{background:var(--ip-primary);color:#fff;border:none;border-radius:8px;padding:12px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}.ip-pw-submit:hover:not(:disabled){background:var(--ip-primary-dark)}.ip-pw-submit:disabled{opacity:.6;cursor:not-allowed}.ip-header{background:#1e3a5f;color:#fff;padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;gap:16px}.ip-header-left{display:flex;align-items:center;gap:16px;min-width:0}.ip-back-btn{background:#ffffff26;border:none;color:#fff;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;white-space:nowrap;transition:background .2s}.ip-back-btn:hover{background:#ffffff40}.ip-header-course{display:flex;align-items:center;gap:10px;min-width:0}.ip-header-title{font-size:15px;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ip-header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.ip-header-instructor{font-size:13px;opacity:.8}.ip-logout-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;transition:background .2s}.ip-logout-btn:hover{background:#ffffff40}.ip-tabs{display:flex;border-bottom:2px solid var(--ip-border);background:#fff;padding:0 24px}.ip-tab{background:none;border:none;padding:14px 20px;font-size:14px;font-weight:600;cursor:pointer;color:var(--ip-text-muted);border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s;display:flex;align-items:center;gap:6px}.ip-tab.active{color:var(--ip-primary);border-bottom-color:var(--ip-primary)}.ip-tab-badge{background:#ef4444;color:#fff;font-size:11px;font-weight:700;padding:1px 6px;border-radius:10px}.ip-qna-wrap{max-width:860px;margin:0 auto;padding:28px 24px}.ip-qna-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:20px}.ip-filter-btns{display:flex;gap:8px}.ip-filter-btn{background:#f1f5f9;border:1.5px solid var(--ip-border);border-radius:6px;padding:6px 14px;font-size:13px;cursor:pointer;transition:all .2s}.ip-filter-btn.active{background:var(--ip-primary);color:#fff;border-color:var(--ip-primary)}.ip-search{padding:8px 14px;border:1.5px solid var(--ip-border);border-radius:6px;font-size:13px;outline:none;min-width:220px;transition:border-color .2s}.ip-search:focus{border-color:var(--ip-primary)}.ip-qna-list{display:flex;flex-direction:column;gap:12px}.ip-qna-item{background:#fff;border:1.5px solid var(--ip-border);border-radius:10px;overflow:hidden;transition:border-color .2s}.ip-qna-item.open{border-color:var(--ip-primary)}.ip-qna-header{display:grid;grid-template-columns:1fr auto;align-items:start;gap:12px;padding:16px;cursor:pointer}.ip-qna-meta{grid-column:1;display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.ip-qna-status{font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px}.ip-qna-status.answered{background:#dcfce7;color:#16a34a}.ip-qna-status.unanswered{background:#fef3c7;color:#d97706}.ip-qna-user{font-size:12px;color:var(--ip-text-muted)}.ip-qna-date{font-size:12px;color:var(--ip-text-muted);margin-left:auto}.ip-qna-question{grid-column:1;font-size:14px;color:var(--ip-text);margin:0;line-height:1.6}.ip-qna-arrow{color:var(--ip-text-muted);font-size:12px;padding-top:4px}.ip-qna-body{border-top:1.5px solid var(--ip-border);padding:16px;background:#f8fafc;display:flex;flex-direction:column;gap:12px}.ip-prev-answer{background:#fff;border-left:3px solid #22c55e;padding:10px 14px;border-radius:0 8px 8px 0;font-size:13px;color:var(--ip-text)}.ip-prev-answer strong{display:block;margin-bottom:6px;font-size:12px;color:#16a34a}.ip-answer-input{width:100%;padding:12px;border:1.5px solid var(--ip-border);border-radius:8px;font-size:14px;resize:vertical;font-family:inherit;outline:none;transition:border-color .2s;box-sizing:border-box}.ip-answer-input:focus{border-color:var(--ip-primary)}.ip-answer-actions{display:flex;justify-content:flex-end;gap:8px}.ip-btn-cancel{background:#f1f5f9;border:1.5px solid var(--ip-border);border-radius:6px;padding:8px 16px;cursor:pointer;font-size:13px}.ip-btn-save{background:var(--ip-primary);color:#fff;border:none;border-radius:6px;padding:8px 20px;cursor:pointer;font-size:13px;font-weight:600;transition:background .2s}.ip-btn-save:hover:not(:disabled){background:var(--ip-primary-dark)}.ip-btn-save:disabled{opacity:.6;cursor:not-allowed}.ip-info-wrap{max-width:860px;margin:0 auto;padding:28px 24px;display:flex;flex-direction:column;gap:24px}.ip-info-grid{display:grid;grid-template-columns:260px 1fr;gap:24px}@media(max-width:640px){.ip-info-grid{grid-template-columns:1fr}}.ip-info-thumb{width:100%;border-radius:10px;object-fit:cover}.ip-info-title{font-size:20px;font-weight:700;margin:0 0 8px}.ip-info-sub{font-size:14px;color:var(--ip-text-muted);margin:0 0 16px}.ip-info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--ip-border);font-size:14px}.ip-info-row span:first-child{color:var(--ip-text-muted)}.ip-price-disc{color:#ef4444;font-weight:600}.ip-info-desc,.ip-info-section,.ip-info-notice{background:#fff;border-radius:10px;padding:20px;box-shadow:var(--ip-shadow)}.ip-info-desc h3,.ip-info-section h3,.ip-info-notice h3{font-size:16px;font-weight:700;margin:0 0 12px}.ip-info-desc p{font-size:14px;line-height:1.7;color:var(--ip-text);margin:0}.ip-info-section ul{margin:0;padding-left:20px}.ip-info-section li{font-size:14px;color:var(--ip-text);line-height:1.7}.ip-info-notice{background:#fffbeb;border-left:4px solid #f59e0b}@media(max-width:768px){.ip-course-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.ip-header{padding:0 16px}.ip-header-title,.ip-header-instructor{display:none}.ip-qna-toolbar{flex-direction:column;align-items:flex-start}.ip-search{min-width:unset;width:100%}}.ip-tabs{gap:0}.ip-students-wrap{max-width:1100px;margin:0 auto;padding:28px 24px}.ip-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:14px;margin-bottom:28px}.ip-kpi-card{background:#fff;border-radius:12px;padding:18px 14px;text-align:center;box-shadow:0 2px 8px #00000012;border-top:3px solid #e2e8f0;transition:transform .2s}.ip-kpi-card:hover{transform:translateY(-2px)}.ip-kpi-card.accent-green{border-top-color:#22c55e}.ip-kpi-card.accent-blue{border-top-color:#3b82f6}.ip-kpi-card.accent-red{border-top-color:#ef4444}.ip-kpi-card.accent-yellow{border-top-color:#f59e0b}.ip-kpi-card.accent-gray{border-top-color:#94a3b8}.ip-kpi-card.accent-purple{border-top-color:#a855f7}.ip-kpi-card.accent-teal{border-top-color:#14b8a6}.ip-kpi-icon{font-size:22px;display:block;margin-bottom:8px}.ip-kpi-val{font-size:28px;font-weight:800;color:#1e293b;line-height:1}.ip-kpi-label{font-size:12px;color:#64748b;margin-top:4px;font-weight:500}.ip-progress-summary{background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 2px 8px #00000012;margin-bottom:28px}.ip-ps-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.ip-ps-title{font-size:15px;font-weight:700;color:#1e293b}.ip-ps-avg{font-size:13px;color:#64748b}.ip-ps-avg strong{color:#3b82f6;font-size:16px}.ip-ps-bars{display:flex;flex-direction:column;gap:12px}.ip-ps-bar-row{display:grid;grid-template-columns:120px 1fr 100px;align-items:center;gap:12px}.ip-ps-bar-label{font-size:13px;color:#475569;text-align:right}.ip-ps-bar-track{height:10px;background:#f1f5f9;border-radius:99px;overflow:hidden}.ip-ps-bar-fill{height:100%;border-radius:99px;transition:width .5s ease}.ip-ps-bar-fill.green{background:#22c55e}.ip-ps-bar-fill.blue{background:#3b82f6}.ip-ps-bar-fill.purple{background:#a855f7}.ip-ps-bar-val{font-size:12px;color:#64748b}.ip-stud-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000012}.ip-stud-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;margin-bottom:16px}.ip-stud-table-wrap{overflow-x:auto}.ip-stud-table{width:100%;border-collapse:collapse;font-size:13px;min-width:700px}.ip-stud-table thead tr{background:#f8fafc}.ip-stud-table th{padding:10px 12px;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0;white-space:nowrap}.ip-stud-table td{padding:10px 12px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.ip-stud-table tbody tr:hover{background:#f8fafc}.ip-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.ip-th-sortable:hover{color:#3b82f6}.ip-stud-name{display:flex;align-items:center;gap:8px;white-space:nowrap}.ip-stud-email{color:#64748b;font-size:12px}.ip-st-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap}.ip-st-badge.confirmed{background:#dcfce7;color:#16a34a}.ip-st-badge.free{background:#dbeafe;color:#1d4ed8}.ip-st-badge.refunded{background:#fee2e2;color:#dc2626}.ip-st-badge.refund-req{background:#fef3c7;color:#d97706}.ip-st-badge.cancelled{background:#f1f5f9;color:#64748b}.ip-st-badge.completed{background:#f3e8ff;color:#7c3aed}.ip-prog-wrap{display:flex;align-items:center;gap:8px;min-width:100px}.ip-prog-bar-track{flex:1;height:6px;background:#e2e8f0;border-radius:99px;overflow:hidden}.ip-prog-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.ip-prog-pct{font-size:12px;color:#475569;min-width:32px;text-align:right}.ip-stud-count{font-size:12px;color:#94a3b8;text-align:right;margin:10px 0 0}@media(max-width:768px){.ip-kpi-grid{grid-template-columns:repeat(4,1fr)}.ip-ps-bar-row{grid-template-columns:80px 1fr 70px}.ip-stud-toolbar{flex-direction:column;align-items:flex-start}}@media(max-width:480px){.ip-kpi-grid{grid-template-columns:repeat(2,1fr)}}.cl-main{min-height:calc(100vh - 140px);background:#f8fafc}.cl-hero{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;text-align:center;padding:60px 24px 48px}.cl-hero-title{font-size:2rem;font-weight:800;margin-bottom:10px}.cl-hero-sub{font-size:1rem;opacity:.85}.cl-container{max-width:1200px;margin:0 auto;padding:40px 24px 60px}.cl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.cl-card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 12px #00000012;cursor:pointer;transition:transform .2s,box-shadow .2s}.cl-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px #4f46e526}.cl-card-thumb{position:relative;width:100%;aspect-ratio:16/9;background:#e0e7ff;overflow:hidden}.cl-card-thumb img{width:100%;height:100%;object-fit:cover}.cl-card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem}.cl-purchased-badge{position:absolute;top:10px;right:10px;background:#10b981;color:#fff;font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:20px}.cl-card-body{padding:18px}.cl-card-title{font-size:1rem;font-weight:700;color:#1a1a2e;margin-bottom:8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cl-card-desc{font-size:.82rem;color:#64748b;line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cl-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.cl-tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600}.cl-tag-blue{background:#dbeafe;color:#1e40af}.cl-tag-red{background:#fee2e2;color:#991b1b}.cl-tag-purple{background:#ede9fe;color:#5b21b6}.cl-tag-green{background:#dcfce7;color:#166534}.cl-tag-gray{background:#f1f5f9;color:#475569}.cl-card-price{display:flex;align-items:baseline;gap:8px}.cl-original-price{font-size:.8rem;color:#94a3b8;text-decoration:line-through}.cl-final-price{font-size:1.1rem;font-weight:700;color:#4f46e5}.cl-loading,.cl-empty{text-align:center;padding:80px 20px;color:#94a3b8;font-size:1rem}@media(max-width:640px){.cl-hero-title{font-size:1.5rem}.cl-grid{grid-template-columns:1fr}}.admin-layout{display:flex;min-height:100vh;background-color:#f5f7fa}.admin-sidebar{position:fixed;left:0;top:0;width:260px;height:100vh;background:linear-gradient(180deg,#1e40af,#1e3a8a);color:#fff;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a;z-index:100}.admin-logo{padding:2rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.admin-logo h2{margin:0;font-size:1.5rem;color:#fff}.admin-logo a{text-decoration:none;color:#fff}.admin-nav{flex:1;padding:1rem 0;overflow-y:auto}.admin-nav-item{display:flex;align-items:center;gap:1rem;padding:.85rem 1.5rem;color:#fffc;text-decoration:none;transition:all .2s;border-left:3px solid transparent;font-size:.95rem}.admin-nav-item:hover{background-color:#ffffff1a;color:#fff}.admin-nav-item.active{background-color:#ffffff26;color:#fff;border-left-color:#60a5fa;font-weight:600}.admin-nav-section{border-top:1px solid rgba(255,255,255,.06)}.admin-nav-group{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.5rem;background:none;border:none;border-left:3px solid transparent;color:#ffffffe6;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:left;letter-spacing:.01em}.admin-nav-group:hover{background-color:#ffffff1a;color:#fff}.admin-nav-group.open{background-color:#ffffff1a;color:#fff;border-left-color:#60a5fa80}.nav-arrow{font-size:.75rem;opacity:.7;transition:transform .2s}.admin-nav-children{background:#00000026;padding:.25rem 0}.admin-nav-child{display:block;padding:.65rem 1.5rem .65rem 2.5rem;color:#ffffffa6;text-decoration:none;font-size:.875rem;border-left:3px solid transparent;transition:all .15s;position:relative}.admin-nav-child:before{content:"";position:absolute;left:1.5rem;top:50%;transform:translateY(-50%);width:5px;height:5px;border-radius:50%;background:#ffffff4d;transition:background .15s}.admin-nav-child:hover{color:#ffffffe6;background-color:#ffffff12}.admin-nav-child:hover:before{background:#fff9}.admin-nav-child.active{color:#fff;font-weight:600;border-left-color:#60a5fa;background-color:#ffffff1a}.admin-nav-child.active:before{background:#60a5fa}.nav-icon{font-size:1.1rem}.nav-label{font-size:.95rem}.admin-footer{padding:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.back-to-site{display:block;padding:.75rem 1rem;background-color:#ffffff1a;color:#fff;text-decoration:none;border-radius:8px;text-align:center;transition:all .2s;font-size:.875rem}.back-to-site:hover{background-color:#fff3}.admin-main{margin-left:260px;flex:1;min-height:100vh}.admin-content{padding:2rem;max-width:1400px;margin:0 auto}@media(max-width:768px){.admin-sidebar{width:70px}.admin-logo h2{font-size:1rem;text-align:center}.nav-label,.nav-arrow,.admin-nav-children{display:none}.admin-nav-item,.admin-nav-group{justify-content:center;padding:1rem}.admin-main{margin-left:70px}.back-to-site{font-size:.7rem;padding:.5rem .25rem}}.dashboard{padding:1rem}.dashboard-title{font-size:2rem;font-weight:700;color:#1e293b;margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1.5rem;box-shadow:0 2px 8px #00000014;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #0000001f}.stat-icon{font-size:3rem;width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e40af,#1e3a8a);border-radius:12px;flex-shrink:0}.stat-info h3{font-size:.95rem;color:#64748b;margin:0 0 .5rem;font-weight:500}.stat-value{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0}.dashboard-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #00000014}.dashboard-section h2{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:1.5rem}.todo-list{display:flex;flex-direction:column;gap:1rem}.todo-item{padding:1rem;background:#f8fafc;border-radius:8px;border-left:4px solid #1e40af;font-size:1rem;color:#475569}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.25rem;color:#64748b}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.stat-card{padding:1.25rem}.stat-icon{font-size:2.5rem;width:60px;height:60px}.stat-value{font-size:1.5rem}}.category-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:10000;padding:2rem}.category-modal-content{background:#fff;border-radius:16px;width:100%;max-width:1200px;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column}.category-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2)}.category-modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#fff}.category-modal-header .btn-close{background:transparent;border:none;font-size:2rem;color:#fff;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.category-modal-header .btn-close:hover{background:#fff3;transform:rotate(90deg)}.category-modal-body{padding:2rem;overflow-y:auto;display:grid;grid-template-columns:450px 1fr;gap:2rem}.category-form-section{background:#f9fafb;border-radius:12px;padding:1.5rem;border:1px solid #e5e7eb;height:fit-content;position:sticky;top:0}.category-form-section h3{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:#1f2937;padding-bottom:.75rem;border-bottom:2px solid #667eea}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#374151;font-size:.9rem}.form-group input[type=text],.form-group input[type=number]{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;transition:all .2s}.form-group input[type=text]:focus,.form-group input[type=number]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#ef4444}.form-group small{display:block;margin-top:.25rem;font-size:.8rem;color:#6b7280}.error-text{display:block;color:#ef4444;font-size:.85rem;margin-top:.25rem;font-weight:500}.sub-category-item{display:flex;gap:.5rem;margin-bottom:.75rem}.sub-category-item input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;transition:all .2s}.sub-category-item input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-remove-sub{width:36px;height:36px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-size:1.25rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-remove-sub:hover{background:#dc2626;transform:scale(1.05)}.btn-add-sub{width:100%;padding:.75rem;background:#fff;border:2px dashed #d1d5db;border-radius:8px;color:#667eea;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.btn-add-sub:hover{border-color:#667eea;background:#f0f4ff}.form-actions{display:flex;gap:.75rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.btn-cancel{flex:1;padding:.875rem;background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#6b7280;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#f3f4f6;border-color:#9ca3af}.btn-submit{flex:1;padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.category-list-section{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e5e7eb}.category-list-section h3{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:#1f2937;padding-bottom:.75rem;border-bottom:2px solid #667eea}.loading,.empty-state{text-align:center;padding:3rem;color:#9ca3af;font-size:.95rem}.category-list{display:flex;flex-direction:column;gap:1rem}.category-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;transition:all .2s}.category-item:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a;transform:translateY(-2px)}.category-info{flex:1}.category-name{font-size:1.1rem;font-weight:600;color:#1f2937;margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem}.category-order{font-size:.8rem;font-weight:500;color:#6b7280;background:#fff;padding:.25rem .75rem;border-radius:20px;border:1px solid #e5e7eb}.category-subs{display:flex;flex-wrap:wrap;gap:.5rem}.sub-badge{display:inline-block;padding:.375rem .875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-size:.85rem;font-weight:500}.category-actions{display:flex;gap:.5rem;margin-left:1rem}.category-actions .btn-edit,.category-actions .btn-delete{padding:.625rem 1.25rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.9rem}.category-actions .btn-edit{background:#3b82f6;color:#fff}.category-actions .btn-edit:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.category-actions .btn-delete{background:#ef4444;color:#fff}.category-actions .btn-delete:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.category-actions .btn-edit:disabled,.category-actions .btn-delete:disabled{opacity:.5;cursor:not-allowed;transform:none}.category-modal-body::-webkit-scrollbar{width:8px}.category-modal-body::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.category-modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.category-modal-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media(max-width:1024px){.category-modal-body{grid-template-columns:1fr}.category-form-section{position:relative}}*,*:before,*:after{box-sizing:border-box}.course-management{max-width:1400px;margin:0 auto;padding:2rem;font-family:Pretendard,Noto Sans KR,sans-serif}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:4rem 2rem;color:#64748b;font-size:.95rem}.spinner{width:28px;height:28px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:cm-spin .8s linear infinite;flex-shrink:0}@keyframes cm-spin{to{transform:rotate(360deg)}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.header-buttons{display:flex;align-items:center;gap:.5rem;flex-shrink:0;flex-wrap:wrap}.btn-category{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap;font-family:inherit}.btn-category:hover{background:#e2e8f0}.btn-create{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #667eea59;transition:opacity .15s,transform .1s;white-space:nowrap;font-family:inherit}.btn-create:hover{opacity:.88}.btn-create:active{transform:scale(.97)}.category-filter{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.9rem 1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:1rem;overflow-x:auto}.filter-btn{display:inline-flex;align-items:center;padding:.4rem .85rem;background:#f8fafc;color:#64748b;border:1px solid #e2e8f0;border-radius:20px;font-size:.82rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s,box-shadow .15s;font-family:inherit}.filter-btn:hover{background:#eff6ff;border-color:#93c5fd;color:#1e40af}.filter-btn.active{background:#667eea;color:#fff;border-color:#667eea;font-weight:600;box-shadow:0 2px 6px #667eea4d}.search-bar{position:relative;margin-bottom:1rem}.search-bar input{width:100%;padding:.6rem 2.5rem .6rem .9rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#1e293b;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.search-bar input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.search-bar input::placeholder{color:#94a3b8}.btn-clear-search{position:absolute;right:.65rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;font-size:.85rem;cursor:pointer;padding:.25rem .35rem;border-radius:4px;line-height:1;transition:color .12s,background .12s}.btn-clear-search:hover{color:#475569;background:#f1f5f9}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 2rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;color:#94a3b8;font-size:.95rem;text-align:center}.empty-state p{margin:0;color:#94a3b8}.course-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;overflow-x:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 #f8fafc}.course-table-wrapper::-webkit-scrollbar{height:6px}.course-table-wrapper::-webkit-scrollbar-track{background:#f8fafc}.course-table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.course-table{width:100%;min-width:1200px;border-collapse:collapse;font-size:.875rem}.course-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0}.course-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.course-table tbody tr{cursor:pointer;border-left:3px solid transparent;transition:background .12s}.course-table tbody tr:hover td{background:#f8fafc}.course-table td{padding:.8rem 1rem;color:#374151;border-bottom:1px solid #f1f5f9;vertical-align:middle}.course-table tbody tr:last-child td{border-bottom:none}.col-no{width:50px;text-align:center}.col-title{min-width:220px}.col-category{width:110px}.col-instructor{width:100px}.col-price,.col-discount{width:90px;text-align:right}.col-students{width:80px;text-align:center}.col-status{width:90px;text-align:center}.col-course-list,.col-home{width:100px;text-align:center}.col-actions{width:90px;text-align:center}.course-title-cell{display:flex;align-items:flex-start;gap:.65rem}.course-title-cell img{width:48px;height:48px;object-fit:cover;border-radius:6px;flex-shrink:0;border:1px solid #e2e8f0}.course-title-text{display:flex;flex-direction:column;gap:.2rem}.course-title-text strong{color:#1e293b;font-weight:600;font-size:.875rem;line-height:1.3}.course-subtitle{font-size:.78rem;color:#94a3b8;line-height:1.3}.sub-category{font-size:.78rem;color:#94a3b8}.price-free{display:inline-block;padding:.18rem .55rem;background:#dcfce7;color:#14532d;border-radius:20px;font-size:.75rem;font-weight:700}.status-badge{display:inline-flex;align-items:center;padding:.22rem .65rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.status-draft{background:#f1f5f9;color:#475569}.status-scheduled{background:#fef3c7;color:#92400e}.status-active{background:#dcfce7;color:#14532d}.status-inactive{background:#fee2e2;color:#991b1b}.status-private{background:#e0e7ff;color:#3730a3}.badge-group{display:flex;flex-wrap:wrap;gap:.3rem;justify-content:center}.badge{display:inline-flex;align-items:center;padding:.18rem .55rem;border-radius:20px;font-size:.72rem;font-weight:700;white-space:nowrap}.badge-best{background:#fef3c7;color:#92400e}.badge-new{background:#dbeafe;color:#1e40af}.badge-regular{background:#f1f5f9;color:#475569}.badge-default{background:#e0e7ff;color:#3730a3}.badge-none{font-size:.78rem;color:#94a3b8}.action-buttons{display:flex;align-items:center;justify-content:center;gap:.4rem}.btn-action{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:7px;font-size:.9rem;cursor:pointer;transition:background .12s,border-color .12s,transform .1s;line-height:1}.btn-action:hover{background:#eff6ff;border-color:#93c5fd}.btn-action:active{transform:scale(.95)}.btn-copy:hover{background:#eff6ff;border-color:#93c5fd}.btn-delete:hover{background:#fee2e2;border-color:#fca5a5}@media(max-width:1200px){.course-management-pc-only{display:flex;align-items:center;justify-content:center;padding:3rem;background:#fff8f8;border:1px solid #fca5a5;border-radius:12px;color:#991b1b;font-size:.95rem;text-align:center}}@media(max-width:768px){.course-management{padding:1rem .75rem 2rem}.page-header{flex-direction:column;align-items:flex-start}.header-buttons{width:100%}.btn-category,.btn-create{flex:1;justify-content:center}.category-filter{padding:.75rem;gap:.4rem}.filter-btn{font-size:.78rem;padding:.35rem .7rem}}.cd-container{max-width:1280px;margin:0 auto;padding:1.5rem 1.25rem 3rem;font-family:Pretendard,Noto Sans KR,sans-serif}.cd-back-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:.825rem;font-weight:600;cursor:pointer;position:absolute;top:-2.4rem;left:0;transition:background .15s;font-family:inherit;white-space:nowrap}.cd-back-btn:hover{background:#e2e8f0}.cd-header{background:#fff;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;margin-top:2.6rem;border:1px solid #e2e8f0;position:relative}.cd-header-info{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:10px;flex-wrap:wrap}.cd-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.22rem .65rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.cd-badge-indigo{background:#eff6ff;color:#4051c4}.cd-tabs{display:flex;gap:.25rem;background:#fff;padding:.5rem;border-radius:12px;margin-bottom:1.5rem;border:1px solid #e2e8f0}.cd-tab{flex:1;padding:.75rem 1rem;border:none;border-radius:8px;background:transparent;color:#64748b;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.cd-tab:hover{background:#f8fafc;color:#334155}.cd-tab.active{background:#667eea;color:#fff;font-weight:600;box-shadow:0 2px 8px #667eea59}.cd-sub-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.cd-sub-tab{padding:.5rem 1.1rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#475569;font-size:.87rem;font-weight:500;cursor:pointer;transition:all .15s}.cd-sub-tab:hover{border-color:#667eea;color:#667eea}.cd-sub-tab.active{border-color:#667eea;background:#667eea;color:#fff}.cd-section-card{background:#fff;border-radius:12px;padding:1.5rem 1.75rem;margin-bottom:1.5rem;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000a}.cd-section-title{font-size:1.05rem;font-weight:700;color:#1e293b;margin:0 0 1.25rem}.cd-form-group input:focus,.cd-form-group select:focus,.cd-form-group textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff;background:#fff}.cd-btn-primary{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1.4rem;background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #667eea59;transition:opacity .15s,transform .1s,box-shadow .15s;white-space:nowrap;font-family:inherit}.cd-btn-primary:hover:not(:disabled){opacity:.88}.cd-btn-primary:active:not(:disabled){transform:scale(.97)}.cd-btn-primary:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.cd-btn-secondary{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap;font-family:inherit}.cd-btn-secondary:hover:not(:disabled){background:#e2e8f0}.cd-btn-warning{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #f59e0b4d;transition:opacity .15s,transform .1s;white-space:nowrap;font-family:inherit}.cd-btn-warning:hover:not(:disabled){opacity:.88}.cd-btn-warning:active:not(:disabled){transform:scale(.97)}.cd-btn-sm{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .85rem;background:#eff6ff;border:1.5px solid #93c5fd;border-radius:6px;color:#2563eb;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s;font-family:inherit}.cd-btn-sm:hover{background:#dbeafe;border-color:#60a5fa}.cd-btn-xs{display:inline-flex;align-items:center;padding:.3rem .65rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#475569;font-size:.78rem;font-weight:500;cursor:pointer;margin-right:.3rem;transition:background .12s,border-color .12s;font-family:inherit}.cd-btn-xs.cd-btn-danger{border-color:#fecaca;color:#dc2626;background:#fff}.cd-status-btn.active,.cd-status-btn:hover{border-color:#667eea;color:#667eea;background:#eff6ff}.cd-discount-info{display:flex;gap:1.5rem;background:#eff6ff;border:1px solid #dbeafe;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.88rem;color:#1e40af}.cd-table-wrapper{overflow-x:auto;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#fff}.cd-table{width:100%;border-collapse:collapse;font-size:.88rem}.cd-table thead tr{border-bottom:2px solid #e2e8f0}.cd-table th{background:#f8fafc;color:#64748b;font-size:.75rem;font-weight:600;padding:.75rem 1rem;text-align:left;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.cd-table td{padding:.6rem 1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;background:#fff}.cd-table tr.cd-row-selected td{background:#eff6ff}.cd-empty-cell{text-align:center;color:#94a3b8;padding:2rem!important}.cd-stat-card{background:#fff;border-radius:12px;padding:1.25rem 1.5rem;text-align:center;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000a;transition:box-shadow .15s,transform .15s}.cd-stat-card.cd-stat-warning{border-top:3px solid #e8a020}.cd-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.cd-search-input{padding:.55rem .9rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.88rem;outline:none;min-width:220px}.cd-search-input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.cd-coupon-form{background:#f8fafc;border:1.5px dashed #93c5fd;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.cd-coupon-form h4{font-size:.95rem;font-weight:700;color:#2563eb;margin:0 0 1rem}.cd-point-adj-panel{margin-top:1.5rem;background:#eff6ff;border:1px solid #dbeafe;border-radius:12px;padding:1.25rem 1.5rem}.cd-point-adj-panel h4{font-size:.95rem;font-weight:700;color:#1e40af;margin:0 0 1rem}.cd-chart-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000a}.cd-modal{background:#fff;border-radius:16px;padding:2rem;max-width:520px;width:100%;box-shadow:0 20px 60px #0003;animation:cd-fadein .2s ease,cd-slideup .2s ease}@keyframes cd-fadein{0%{opacity:0}to{opacity:1}}@keyframes cd-slideup{0%{transform:translateY(20px)}to{transform:translateY(0)}}.cd-clickable-row{cursor:pointer;transition:background .15s}.cd-clickable-row:hover{background:#f8fafc}.cd-row-highlight{background:#eff6ff!important}.cd-row-current td:first-child{border-left:3px solid #667eea;padding-left:calc(1rem - 3px)}.cd-row-current td{background:#fff!important}.cd-qna-mgmt-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.cd-qna-stats{display:flex;align-items:center;gap:.5rem}.cd-qna-lesson{font-size:.8rem;background:#f1f5f9;padding:2px 8px;border-radius:4px}.cd-student-profile-modal{background:#fff;border-radius:16px;width:1200px;max-width:96vw;height:80vh;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000002e;overflow:hidden;position:relative}.cd-spm-header{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#667eea;color:#fff}.cd-spm-avatar{width:52px;height:52px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;color:#fff;flex-shrink:0}.cd-spm-title-area{flex:1;min-width:0}.cd-spm-name{font-size:1.2rem;font-weight:700;margin:0 0 2px}.cd-spm-email{font-size:.85rem;opacity:.85;margin:0}.cd-spm-header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.cd-spm-close{background:#fff3;border:none;color:#fff;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .15s}.cd-spm-close:hover{background:#ffffff59}.cd-spm-tabs{display:flex;border-bottom:2px solid #e2e8f0;background:#f8fafc;flex-shrink:0}.cd-spm-tab{padding:.75rem 1.25rem;border:none;background:none;cursor:pointer;font-size:.875rem;font-weight:500;color:#64748b;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.cd-spm-tab:hover{color:#667eea}.cd-spm-tab.active{color:#667eea;border-bottom-color:#667eea;background:#fff}.cd-spm-body{flex:1;overflow-y:auto;padding:1.5rem}.cd-spm-section{display:flex;flex-direction:column;gap:.75rem}.cd-spm-sec-title{font-size:.95rem;font-weight:600;color:#334155;margin:0 0 .5rem;padding-bottom:.5rem;border-bottom:1px solid #e2e8f0}.cd-spm-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;background:#f8fafc;border-radius:10px;padding:1rem}.cd-spm-info-row{display:flex;flex-direction:column;gap:2px}.cd-spm-label{font-size:.75rem;color:#94a3b8;font-weight:500;text-transform:uppercase;letter-spacing:.03em}.cd-spm-value{font-size:.9rem;color:#1e293b;font-weight:500}.cd-spm-refund-policy{background:#fff3e0;border:1px solid #fde68a;border-radius:10px;padding:1rem 1.25rem}.cd-spm-refund-policy h4{font-size:.9rem;font-weight:600;margin:0 0 .5rem;color:#92400e}.cd-spm-policy-status{font-size:.875rem;color:#78350f;margin:0 0 .25rem}.cd-spm-refund-amount{font-size:.9rem;color:#065f46;margin:0 0 .5rem}.cd-spm-no-refund{font-size:.875rem;color:#dc2626;margin:0 0 .5rem}.cd-spm-policy-detail{font-size:.8rem;color:#64748b}.cd-spm-policy-detail ul{margin:4px 0 0 1rem;padding:0}.cd-spm-policy-detail li{margin-bottom:2px}.cd-refund-info-box{background:#f8fafc;border-radius:8px;padding:1rem;margin-bottom:1rem;font-size:.875rem;line-height:1.8}.cd-refund-highlight{color:#dc2626;font-size:1rem}.cd-refund-law-box{background:#fff3e0;border:1px solid #fcd34d;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.8rem}.cd-refund-law-box ul{margin:4px 0 0 1rem;padding:0}.cd-refund-law-box li{margin-bottom:2px}.cd-spm-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.cd-spm-stat-card{background:#f8fafc;border-radius:10px;padding:1.25rem;text-align:center}.cd-spm-stat-value{font-size:1.75rem;font-weight:700;color:#1e293b;margin-bottom:4px}.cd-spm-stat-label{font-size:.8rem;color:#64748b}.cd-badge-blue{background:#eff6ff;color:#4051c4}@media(max-width:600px){.cd-student-profile-modal{width:100vw;max-width:100vw;height:100vh;max-height:100vh;border-radius:0}.cd-spm-info-grid,.cd-spm-stats-grid{grid-template-columns:1fr}.cd-spm-tabs{overflow-x:auto}}.cd-stats-lesson-detail{background:#f8fafc;border-radius:10px;padding:1rem 1.25rem;margin-top:.5rem}.cd-stats-lesson-title{font-size:.875rem;font-weight:600;color:#334155;margin:0 0 .75rem}.cd-stats-section-row{margin-bottom:1rem}.cd-stats-sec-name{font-size:.8rem;font-weight:600;color:#64748b;margin-bottom:.4rem;padding-bottom:.3rem;border-bottom:1px solid #e2e8f0}.cd-stats-lesson-row{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.8rem}.cd-stats-lesson-status{width:18px;flex-shrink:0;text-align:center;font-size:.75rem}.cd-stats-lesson-name{flex:1;color:#475569;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cd-stats-lesson-bar{width:80px;height:6px;background:#e2e8f0;border-radius:3px;flex-shrink:0;overflow:hidden}.cd-stats-lesson-fill{height:100%;border-radius:3px;transition:width .3s}.cd-stats-lesson-pct{width:32px;text-align:right;font-weight:600;flex-shrink:0}.cd-stats-lesson-time{color:#94a3b8;flex-shrink:0;font-size:.75rem}.cd-btn-danger{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #ef44444d;transition:opacity .15s,transform .1s;white-space:nowrap;font-family:inherit}.cd-btn-danger:hover:not(:disabled){opacity:.88}.cd-btn-danger:active:not(:disabled){transform:scale(.97)}.cd-btn-danger:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.cd-btn-refund-confirm{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.6rem;background:#ef4444;color:#fff;border:none;border-radius:10px;font-size:.925rem;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}.cd-btn-refund-confirm:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 6px 16px #ef444473}.cd-btn-refund-confirm:disabled,.cd-btn-refund-confirm.disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed;transform:none;box-shadow:none}.cd-btn-refund-confirm.force{background:#b91c1c;animation:cd-refund-pulse 1.5s ease-in-out infinite}@keyframes cd-refund-pulse{0%,to{box-shadow:0 0 #b91c1c66}50%{box-shadow:0 0 0 6px #b91c1c00}}.cd-refund-modal{background:#fff;border-radius:16px;width:560px;max-width:96vw;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0003;display:flex;flex-direction:column}.cd-refund-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 0}.cd-refund-modal-header h3{font-size:1.1rem;font-weight:700;color:#1e293b;margin:0}.cd-refund-modal>.cd-refund-info-box,.cd-refund-modal>.cd-refund-law-box,.cd-refund-modal>.cd-refund-amount-section,.cd-refund-modal>.cd-force-refund-box,.cd-refund-modal>.cd-form-group,.cd-refund-modal>.cd-modal-actions{margin:0 1.5rem}.cd-refund-modal>.cd-refund-info-box{margin-top:1rem}.cd-refund-modal>.cd-modal-actions{margin-bottom:1.5rem;padding-top:.5rem}.cd-refund-info-row{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;padding:.35rem 0;font-size:.875rem;border-bottom:1px solid #f1f5f9}.cd-refund-info-row:last-child{border-bottom:none}.cd-refund-info-row>span:first-child{color:#64748b;flex-shrink:0;font-weight:500}.cd-refund-policy-text{color:#475569;font-size:.82rem;text-align:right}.cd-refund-amount-section{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;padding:1rem 1.25rem;margin-top:.75rem!important;margin-bottom:.75rem!important}.cd-refund-amount-label{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.75rem}.cd-refund-amount-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.cd-refund-auto-amount,.cd-refund-manual-input{flex:1;min-width:130px;display:flex;flex-direction:column;gap:4px}.cd-refund-amount-desc{font-size:.75rem;color:#94a3b8}.cd-refund-auto-value{font-size:1.25rem;font-weight:700;color:#1e293b}.cd-refund-auto-value.cd-refund-zero{color:#94a3b8;text-decoration:line-through;font-size:1rem}.cd-refund-divider{font-size:1.25rem;color:#94a3b8;flex-shrink:0}.cd-refund-input-wrap{display:flex;align-items:center;border:2px solid #667eea;border-radius:8px;background:#fff;overflow:hidden}.cd-refund-won{padding:0 .5rem;font-size:.9rem;color:#667eea;font-weight:600;background:#eff6ff;border-right:2px solid #667eea}.cd-refund-amount-input{border:none;outline:none;padding:.45rem .6rem;font-size:1rem;font-weight:600;width:100%;color:#1e293b}.cd-refund-final{margin-top:.75rem;padding-top:.6rem;border-top:1px solid #e2e8f0;font-size:.9rem;color:#475569;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.cd-refund-final-value{font-size:1.35rem;color:#dc2626}.cd-refund-manual-badge{background:#fef3c7;color:#92400e;border:1px solid #fde68a;border-radius:4px;padding:2px 7px;font-size:.75rem;font-weight:600}.cd-force-refund-box{background:#fff7ed;border:1.5px solid #fed7aa;border-radius:10px;padding:.875rem 1rem;margin-top:0!important;margin-bottom:.75rem!important}.cd-force-refund-label{display:flex;align-items:center;gap:.6rem;font-size:.875rem;font-weight:600;color:#c2410c;cursor:pointer}.cd-force-refund-label input[type=checkbox]{width:16px;height:16px;accent-color:#dc2626;cursor:pointer}.cd-force-refund-warn{margin:.5rem 0 0 1.6rem;font-size:.8rem;color:#9a3412;line-height:1.5}@media(max-width:600px){.cd-refund-modal{width:100vw;max-width:100vw;border-radius:16px 16px 0 0}.cd-refund-amount-row{flex-direction:column}.cd-refund-divider{transform:rotate(90deg)}}.cd-sub-tab{position:relative}.cd-sub-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;background:#ef4444;color:#fff;border-radius:999px;font-size:.72rem;font-weight:700;line-height:1;vertical-align:middle;animation:cd-badge-pop .25s ease}@keyframes cd-badge-pop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.cd-sub-tab.active .cd-sub-tab-badge{background:#fff;color:#ef4444}.cd-qna-title-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.cd-qna-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.cd-qna-filter-tabs{display:flex;gap:.4rem}.cd-qna-filter-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem 1rem;border:1.5px solid #e2e8f0;border-radius:999px;background:#fff;color:#475569;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.cd-qna-filter-btn:hover{border-color:#667eea;color:#667eea}.cd-qna-filter-btn.active{background:#667eea;border-color:transparent;color:#fff;font-weight:600}.cd-qna-filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;padding:0 4px;background:#ef4444;color:#fff;border-radius:999px;font-size:.7rem;font-weight:700;line-height:1}.cd-qna-filter-btn.active .cd-qna-filter-badge{background:#ffffff59}.cd-btn-template{background:#fff;border:1.5px solid #667eea;color:#667eea;border-radius:8px;padding:.45rem 1rem;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.cd-btn-template:hover{background:#667eea;color:#fff}.cd-qna-reply-actions{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.cd-btn-tpl-trigger{background:#f1f5f9;border:1px solid #cbd5e1;color:#475569;border-radius:6px;padding:.3rem .7rem;font-size:.78rem;cursor:pointer;transition:all .12s}.cd-btn-tpl-trigger:hover{background:#e2e8f0;color:#1e293b}.cd-tpl-dropdown{border:1.5px solid #e2e8f0;border-radius:10px;background:#fff;box-shadow:0 6px 20px #0000001a;overflow:hidden;margin-bottom:.5rem;max-height:220px;overflow-y:auto}.cd-tpl-empty{padding:1rem;color:#94a3b8;font-size:.85rem;text-align:center}.cd-tpl-item{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:.65rem 1rem;border:none;border-bottom:1px solid #f1f5f9;background:transparent;cursor:pointer;text-align:left;transition:background .12s}.cd-tpl-item:last-child{border-bottom:none}.cd-tpl-item:hover{background:#f8fafc}.cd-tpl-title{font-size:.875rem;font-weight:600;color:#1e293b;margin-bottom:.2rem}.cd-tpl-preview{font-size:.78rem;color:#94a3b8}.cd-tpl-modal{background:#fff;border-radius:14px;width:520px;max-width:96vw;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000002e;display:flex;flex-direction:column}.cd-tpl-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;border-bottom:1px solid #f1f5f9;position:sticky;top:0;background:#fff;z-index:1}.cd-tpl-modal-header h3{font-size:1.05rem;font-weight:700;color:#1e293b;margin:0}.cd-tpl-close{width:32px;height:32px;border:none;border-radius:50%;background:#f1f5f9;color:#475569;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.cd-tpl-close:hover{background:#e2e8f0;color:#1e293b}.cd-btn-tpl-delete{padding:.3rem .75rem;border:none;border-radius:6px;background:#ef4444;color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s}.cd-btn-tpl-delete:hover{background:#dc2626}.cd-tpl-add-form{padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9;display:flex;flex-direction:column;gap:.65rem}.cd-tpl-add-form h4{font-size:.9rem;font-weight:600;color:#475569;margin:0}.cd-tpl-input{width:100%;padding:.55rem .8rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.875rem;outline:none;transition:border-color .15s;box-sizing:border-box}.cd-tpl-input:focus{border-color:#667eea}.cd-tpl-textarea{width:100%;padding:.6rem .8rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.875rem;resize:vertical;outline:none;transition:border-color .15s;box-sizing:border-box;font-family:inherit}.cd-tpl-textarea:focus{border-color:#667eea}.cd-tpl-list{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}.cd-tpl-list h4{font-size:.9rem;font-weight:600;color:#475569;margin:0 0 .5rem}.cd-tpl-list-item{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc}.cd-tpl-list-info{flex:1;min-width:0}.cd-tpl-list-title{display:block;font-size:.875rem;color:#1e293b;margin-bottom:.25rem}.cd-tpl-list-body{font-size:.8rem;color:#64748b;margin:0;white-space:pre-wrap;word-break:break-word}.cd-spm-qna-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.cd-spm-qna-badges{display:flex;gap:.4rem;flex-wrap:wrap}.cd-spm-qna-badge{display:inline-flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;border-radius:999px;font-size:.7rem;font-weight:700;min-width:18px;height:18px;padding:0 5px;margin-left:5px;line-height:1;animation:cd-badge-pop .25s ease}.cd-spm-tpl-wrap{position:relative;margin-bottom:.5rem}.cd-btn-tpl-sm{padding:.3rem .8rem;border:1.5px solid #667eea;border-radius:6px;background:#fff;color:#667eea;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.cd-btn-tpl-sm:hover{background:#eff6ff}.cd-spm-tpl-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:200;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 16px #0000001f;min-width:260px;max-width:380px;max-height:220px;overflow-y:auto}.cd-spm-tpl-item{display:flex;flex-direction:column;width:100%;padding:.6rem .9rem;border:none;background:none;cursor:pointer;text-align:left;border-bottom:1px solid #f1f5f9;transition:background .12s}.cd-spm-tpl-item:last-child{border-bottom:none}.cd-spm-tpl-item:hover{background:#f8fafc}.cd-spm-tpl-item strong{font-size:.85rem;color:#1e293b;font-weight:600;margin-bottom:2px}.cd-spm-tpl-preview{font-size:.78rem;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cd-sub-tab-count{display:inline-flex;align-items:center;justify-content:center;background:#e2e8f0;color:#475569;border-radius:999px;font-size:.7rem;font-weight:700;min-width:18px;height:18px;padding:0 5px;margin-left:5px;line-height:1}.cd-sub-tab.active .cd-sub-tab-count{background:#ffffff4d;color:#fff}.cd-tpl-tab-layout{display:grid;grid-template-columns:320px 1fr;gap:1.5rem;align-items:start}@media(max-width:900px){.cd-tpl-tab-layout{grid-template-columns:1fr}}.cd-tpl-add-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;position:sticky;top:0}.cd-tpl-form{display:flex;flex-direction:column;gap:.6rem;margin-top:.75rem}.cd-tpl-label{font-size:.82rem;font-weight:600;color:#475569;margin-bottom:-.2rem}.cd-tpl-category-input-wrap{position:relative}.cd-tpl-list-panel{display:flex;flex-direction:column;gap:1rem}.cd-tpl-list-header{display:flex;flex-direction:column;gap:.75rem}.cd-tpl-cat-filter{display:flex;flex-wrap:wrap;gap:.4rem}.cd-tpl-cat-btn{padding:.3rem .75rem;border:1.5px solid #e2e8f0;border-radius:999px;background:#fff;color:#64748b;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:.3rem}.cd-tpl-cat-btn:hover{border-color:#667eea;color:#667eea;background:#eff6ff}.cd-tpl-cat-btn.active{background:#667eea;border-color:#667eea;color:#fff;font-weight:600}.cd-tpl-cat-count{display:inline-flex;align-items:center;justify-content:center;background:#ffffff40;border-radius:999px;min-width:16px;height:16px;padding:0 4px;font-size:.68rem;font-weight:700;line-height:1}.cd-tpl-cat-btn:not(.active) .cd-tpl-cat-count{background:#e2e8f0;color:#475569}.cd-tpl-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem}.cd-tpl-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.5rem;transition:box-shadow .15s,border-color .15s}.cd-tpl-card:hover{box-shadow:0 2px 12px #667eea1a;border-color:#c7d2f5}.cd-tpl-card-top{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.cd-tpl-cat-badge{padding:.18rem .55rem;background:#eff6ff;color:#4051c4;border-radius:999px;font-size:.72rem;font-weight:600;white-space:nowrap}.cd-tpl-card-title{font-size:.9rem;font-weight:600;color:#1e293b}.cd-tpl-card-body{font-size:.82rem;color:#64748b;line-height:1.5;white-space:pre-wrap;word-break:break-word;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.cd-tpl-card-actions{display:flex;gap:.5rem;justify-content:flex-end;border-top:1px solid #f1f5f9;padding-top:.5rem;margin-top:auto}.cd-tpl-edit-form{display:flex;flex-direction:column;gap:.5rem}.cd-tpl-edit-actions{display:flex;gap:.5rem}.cd-btn-xs.cd-btn-outline{padding:.28rem .65rem;border:1.5px solid #667eea;border-radius:6px;background:none;color:#667eea;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.cd-btn-xs.cd-btn-outline:hover{background:#eff6ff}.cd-btn-secondary.cd-btn-sm{padding:.35rem .75rem;font-size:.82rem}.cd-stats-chart-wrap{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1rem}.cd-stats-chart{display:flex;flex-direction:column;gap:.55rem;margin-top:.75rem}.cd-chart-row{display:grid;grid-template-columns:110px 1fr 80px;align-items:center;gap:.6rem}.cd-chart-label{font-size:.8rem;color:#475569;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cd-chart-bar-wrap{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.cd-chart-bar-fill{height:100%;border-radius:999px;transition:width .4s ease;min-width:2px}.cd-chart-meta{display:flex;align-items:center;gap:.35rem;justify-content:flex-end}.cd-chart-pct{font-size:.82rem;font-weight:700;min-width:36px;text-align:right}.cd-chart-sub{font-size:.72rem;color:#94a3b8;white-space:nowrap}.cd-chart-total-row{display:grid;grid-template-columns:110px 1fr 80px;align-items:center;gap:.6rem;margin-top:.6rem;padding-top:.6rem;border-top:1.5px dashed #e2e8f0}.cd-chart-total-label{font-size:.8rem;font-weight:700;color:#1e293b}.cd-chart-total-fill{height:12px!important}.cd-tpl-group{border-bottom:1px solid #f1f5f9}.cd-tpl-group:last-child{border-bottom:none}.cd-tpl-group-label{padding:.45rem .9rem .3rem;font-size:.72rem;font-weight:700;color:#667eea;background:#f8fafc;letter-spacing:.03em;text-transform:uppercase;border-bottom:1px solid #f1f5f9;position:sticky;top:0;z-index:1}.cd-tpl-empty-state{padding:1rem .9rem;display:flex;flex-direction:column;align-items:center;gap:.6rem;text-align:center}.cd-tpl-empty-state p{font-size:.82rem;color:#94a3b8;margin:0}.cd-tpl-dropdown-2step{min-width:240px;max-width:320px;max-height:280px;overflow-y:auto}.cd-tpl-step-header{display:flex;align-items:center;gap:.5rem;padding:.55rem .9rem;font-size:.78rem;font-weight:700;color:#475569;background:#f8fafc;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:2;letter-spacing:.01em}.cd-tpl-step-header span{color:#667eea;font-weight:600}.cd-tpl-back-btn{display:inline-flex;align-items:center;border:none;background:none;color:#667eea;font-size:.82rem;font-weight:600;cursor:pointer;padding:.1rem .3rem;border-radius:4px;transition:background .12s}.cd-tpl-back-btn:hover{background:#eff6ff}.cd-tpl-cat-step{display:flex;flex-direction:column}.cd-tpl-cat-row{display:flex;align-items:center;width:100%;padding:.65rem .9rem;border:none;background:none;cursor:pointer;text-align:left;border-bottom:1px solid #f1f5f9;transition:background .12s;gap:.5rem}.cd-tpl-cat-row:last-child{border-bottom:none}.cd-tpl-cat-row:hover{background:#f0f4ff}.cd-tpl-cat-row-name{flex:1;font-size:.87rem;font-weight:600;color:#1e293b}.cd-tpl-cat-row-count{font-size:.75rem;color:#94a3b8;background:#f1f5f9;border-radius:999px;padding:.1rem .45rem;font-weight:600}.cd-tpl-cat-row-arrow{font-size:1rem;color:#cbd5e1;font-weight:400}.cd-tpl-cat-row:hover .cd-tpl-cat-row-arrow{color:#667eea}.cd-tpl-answer-step{display:flex;flex-direction:column}.cd-badge-pulse{animation:cd-badge-pulse-anim 1.8s ease-in-out infinite}@keyframes cd-badge-pulse-anim{0%,to{opacity:1}50%{opacity:.55}}.cd-spm-reject-box{background:#fff5f5;border:1px solid #fecaca;border-radius:8px;padding:.75rem 1rem;margin-bottom:.75rem}.cd-spm-reject-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.cd-spm-reject-date{font-size:.78rem;color:#9ca3af;margin-left:auto}.cd-spm-reject-reason{font-size:.85rem;color:#b91c1c;margin:.25rem 0;font-weight:500}.cd-spm-reject-hint{font-size:.8rem;color:#d97706;margin:0}.cd-spm-pending-box{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:.65rem 1rem;margin-bottom:.75rem;font-size:.85rem;color:#92400e}.cd-spm-pending-box p{margin:.25rem 0 0}.cd-spm-re-req-hint{color:#b45309;font-size:.8rem}.cd-spm-refunded-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.65rem 1rem;margin-bottom:.75rem;font-size:.85rem}.cd-spm-refunded-row{display:flex;justify-content:space-between;align-items:flex-start;padding:.2rem 0;border-bottom:1px solid #f1f5f9;gap:.5rem}.cd-spm-refunded-row:last-child{border-bottom:none}.cd-spm-refunded-row>span{color:#64748b;white-space:nowrap}.cd-spm-refunded-row>strong{text-align:right;color:#1e293b}.cd-spm-refunded-policy strong{color:#475569;font-size:.82rem;word-break:keep-all}.cd-spm-refund-amt{color:#2563eb;font-size:.95rem}.cd-btn-warn{background:#fef3c7;color:#92400e;border:1px solid #f59e0b;border-radius:6px;padding:.35rem .75rem;font-size:.82rem;cursor:pointer;transition:background .2s}.cd-btn-warn:hover{background:#fde68a}.cd-clickable-row:has(.cd-badge-purple){background:#faf5ff}.cd-clickable-row:has(.cd-badge-red){background:#fff5f5}.course-form-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.course-form-loading .spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.course-form-loading p{color:#6b7280;font-size:1rem}.course-form-header h1{margin:0;font-size:1.75rem;font-weight:700;color:#1f2937;flex-shrink:0}.btn-back{padding:.75rem 1.5rem;background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#6b7280;font-weight:600;cursor:pointer;transition:all .2s;font-size:.95rem;white-space:nowrap;flex-shrink:0;margin-left:auto;flex-grow:0;width:auto}.btn-back:hover{background:#f3f4f6;border-color:#9ca3af;color:#374151}.course-form{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.form-section{padding:2rem;border-bottom:1px solid #e5e7eb}.form-section:last-of-type{border-bottom:none}.form-section h2{margin:0 0 1.5rem;font-size:1.5rem;font-weight:700;color:#1f2937;position:relative;padding-left:1rem}.form-section h2:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:1.5rem;background:#667eea;border-radius:2px}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151;font-size:.95rem}.form-group input[type=text],.form-group input[type=number],.form-group input[type=file],.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;transition:all .2s;font-family:inherit}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#ef4444}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:768px){.form-row{grid-template-columns:1fr}}.array-item{display:flex;gap:.5rem;margin-bottom:.75rem}.array-item input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem}.array-item button{padding:.5rem .75rem;background:#ef4444;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1.25rem;font-weight:700;transition:background .2s}.array-item button:hover{background:#dc2626}.btn-add-array,.btn-add-section,.btn-add-lesson{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.95rem}.btn-add-array:hover,.btn-add-section:hover,.btn-add-lesson:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.curriculum-section{margin-bottom:1.5rem;border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.section-header-left{display:flex;align-items:center;gap:1rem;flex:1}.drag-handle{padding:.5rem;background:none;border:none;cursor:grab;color:#9ca3af;font-size:1.25rem}.drag-handle:active{cursor:grabbing}.section-header input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;font-weight:600}.btn-toggle-section{padding:.5rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s}.btn-toggle-section:hover{background:#f3f4f6}.btn-remove-section{padding:.5rem 1rem;background:#fee2e2;color:#dc2626;border:1px solid #fecaca;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.9rem}.btn-remove-section:hover{background:#fecaca}.section-content{padding:1.5rem}.section-content>textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;margin-bottom:1rem;font-family:inherit}.lesson-item{margin-bottom:1rem;padding:1.5rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.lesson-header{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem}.drag-handle-lesson{padding:.5rem;background:none;border:none;cursor:grab;color:#9ca3af}.lesson-header input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-weight:600}.btn-remove-lesson{padding:.5rem .75rem;background:#fee2e2;color:#dc2626;border:1px solid #fecaca;border-radius:6px;font-size:1.25rem;font-weight:700;cursor:pointer;transition:background .2s}.btn-remove-lesson:hover{background:#fecaca}.lesson-details{display:grid;grid-template-columns:1fr 150px auto;gap:.75rem;margin-bottom:1rem}@media(max-width:768px){.lesson-details{grid-template-columns:1fr}}.lesson-details input{padding:.75rem;border:1px solid #d1d5db;border-radius:8px}.lesson-preview-toggle{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;white-space:nowrap}.lesson-item>textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;margin-bottom:1rem;font-family:inherit}.lesson-materials{margin-top:1rem;padding:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px}.lesson-materials label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151}.materials-list{list-style:none;padding:0;margin:1rem 0 0}.materials-list li{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:.5rem}.materials-list li a{color:#667eea;text-decoration:none;font-weight:500}.materials-list li a:hover{text-decoration:underline}.materials-list button{padding:.25rem .5rem;background:#fee2e2;color:#dc2626;border:none;border-radius:4px;cursor:pointer;font-weight:700}.upload-progress{margin-top:.75rem;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;position:relative}.progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s}.upload-progress span{position:absolute;right:8px;top:-24px;font-size:.875rem;font-weight:600;color:#667eea}.thumbnail-preview{margin-top:1rem;border-radius:8px;overflow:hidden;max-width:600px;border:2px solid #e5e7eb}.thumbnail-preview img{width:100%;height:auto;display:block}.detail-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem}.detail-image-item{position:relative;border-radius:8px;overflow:hidden;border:2px solid #e5e7eb;background:#fff}.detail-image-item img{width:100%;height:150px;object-fit:cover;display:block}.drag-handle-detail{position:absolute;top:8px;left:8px;padding:.5rem;background:#ffffffe6;border:none;border-radius:6px;cursor:grab;color:#6b7280}.btn-remove-detail-image{position:absolute;top:8px;right:8px;padding:.5rem;background:#ef4444e6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:700}.exposure-settings{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1.5rem}@media(max-width:768px){.exposure-settings{grid-template-columns:1fr}}.exposure-card{padding:1.5rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px}.exposure-card h3{margin:0 0 .5rem;font-size:1.125rem;font-weight:700;color:#1f2937}.exposure-card p{margin:0 0 1rem;font-size:.875rem;color:#6b7280}.exposure-checkboxes{display:flex;flex-wrap:wrap;gap:1rem}.exposure-checkboxes label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.home-exposure-toggle{margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding:2rem;background:#f9fafb;border-top:1px solid #e5e7eb}.btn-cancel,.btn-submit{padding:.875rem 2rem;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.btn-cancel{background:#fff;color:#6b7280;border:1px solid #d1d5db}.btn-cancel:hover{background:#f3f4f6}.btn-submit:hover:not(:disabled){background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-submit:disabled{background:#9ca3af;cursor:not-allowed}.error-text{display:block;margin-top:.5rem;padding:.5rem .75rem;background:#fef2f2;border-left:3px solid #ef4444;border-radius:4px;color:#dc2626;font-size:.875rem;font-weight:500}.upload-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.upload-overlay-content{background:#fff;padding:2rem 3rem;border-radius:16px;text-align:center;box-shadow:0 20px 50px #0000004d}.upload-overlay-spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.upload-overlay-text{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.upload-overlay-subtext{font-size:.875rem;color:#6b7280}.upload-status-simple{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f0f9ff;border:1px solid #bfdbfe;border-radius:8px;margin-top:.75rem}.upload-icon{font-size:1.5rem}.upload-text{font-weight:600;color:#1e40af}.upload-error-container{margin-top:.75rem;padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.upload-error-message{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:#dc2626;font-weight:500}.error-icon{font-size:1.25rem}.btn-retry-upload{padding:.5rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.btn-retry-upload:hover{background:#b91c1c}.empty-lessons-message{padding:2rem;text-align:center;background:#fef3c7;border:2px dashed #fbbf24;border-radius:8px;margin-bottom:1rem}.empty-lessons-message p{margin:0;color:#92400e;font-weight:500}.help-text{display:block;margin-top:.5rem;font-size:.875rem;color:#6b7280;font-style:italic}textarea[placeholder*=공지사항],textarea[placeholder*=안내사항],textarea[placeholder*=주의사항]{border-left:3px solid #667eea;transition:all .3s ease}textarea[placeholder*=공지사항]:focus{border-left-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}textarea[placeholder*=안내사항]:focus{border-left-color:#10b981;box-shadow:0 0 0 3px #10b9811a}textarea[placeholder*=주의사항]:focus{border-left-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}label:has(+input.error),label:has(+select.error),label:has(+textarea.error){color:#ef4444;font-weight:600}@media(max-width:768px){.help-text{font-size:.8125rem}.course-form-container{padding:1rem}.course-form-header{flex-direction:column;gap:1rem;align-items:stretch}.btn-back{width:100%;text-align:center;margin-left:0}}.form-group .checkbox-label+.checkbox-label{margin-top:.5rem}.exam-settings-panel{margin-top:1.25rem;border:1.5px solid #667eea;border-radius:12px;overflow:hidden;background:#fafbff}.exam-settings-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:linear-gradient(90deg,#667eea,#764ba2);color:#fff;font-weight:700;font-size:.95rem}.exam-settings-body{padding:1.25rem}.exam-retry-row{display:flex;flex-direction:column}@media(max-width:768px){.exam-settings-panel{margin-top:1rem}.exam-settings-body{padding:1rem}}.gamification-notice{margin-top:.5rem;padding:.75rem 1rem;background:#667eea0f;border-left:3px solid #667eea;border-radius:0 6px 6px 0;font-size:.82rem;color:#4b5563;line-height:1.5}.lesson-duration-wrap{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.lesson-duration-input{width:90px;padding:.35rem .5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.85rem;font-family:Courier New,monospace;letter-spacing:.05em;text-align:center;transition:border-color .15s}.lesson-duration-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea26}.lesson-duration-label{font-size:.75rem;color:#9ca3af;white-space:nowrap}.cert-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}.cert-card{border:1.5px solid #e5e7eb;border-radius:10px;padding:1rem 1.2rem;background:#fafafa;transition:border-color .2s,box-shadow .2s}.cert-card--active{border-color:#667eea;background:#667eea0a;box-shadow:0 0 0 3px #667eea1a}.cert-card-header{display:flex;align-items:center;gap:.6rem;cursor:pointer;margin-bottom:.5rem}.cert-card-header input[type=checkbox]{width:16px;height:16px;accent-color:#667eea;cursor:pointer;flex-shrink:0}.cert-card-title{font-weight:600;font-size:.95rem;color:#1f2937}.cert-card-desc{font-size:.82rem;color:#6b7280;margin:0 0 0 1.6rem;line-height:1.5}.cert-card .exam-settings-panel{margin-top:1rem}@media(max-width:640px){.cert-row{grid-template-columns:1fr}}.instructor-image-preview{margin-top:1rem;border-radius:8px;overflow:hidden;border:2px solid #e5e7eb;max-width:100%;position:relative}.instructor-image-preview img{width:100%;height:auto;display:block;object-fit:cover;aspect-ratio:3 / 1;object-position:center}.btn-remove-instructor-img{position:absolute;top:.6rem;right:.6rem;padding:.35rem .8rem;background:#0000008c;color:#fff;border:none;border-radius:6px;font-size:.8rem;cursor:pointer;transition:background .2s}.btn-remove-instructor-img:hover{background:#000000bf}.form-row .form-group-full{flex:0 0 100%;width:100%}.form-row-images{align-items:flex-start}.form-row-images .form-group{flex:1 1 0;min-width:0}.form-row-images .thumbnail-preview,.form-row-images .instructor-image-preview{max-width:100%}.instructor-selected-preview{display:flex;align-items:flex-start;gap:.75rem;margin-top:.75rem;padding:.75rem;background:#f4f5f8;border-radius:8px;border:1px solid #e2e4ea}.instructor-selected-preview img{width:120px;aspect-ratio:3 / 1;object-fit:cover;border-radius:6px;flex-shrink:0}.instructor-selected-info{display:flex;flex-direction:column;gap:.25rem}.instructor-selected-info strong{font-size:.95rem;font-weight:700;color:#1a1d27}.instructor-selected-info span{font-size:.85rem;color:#6b7280}.instructor-selected-info p{font-size:.82rem;color:#6b7280;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cf-radio-group{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.4rem}.cf-radio-label{display:flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;color:#4a5568;background:#f8fafc;transition:border-color .18s,background .18s,color .18s;-webkit-user-select:none;user-select:none}.cf-radio-label input[type=radio]{accent-color:#4f46e5;width:16px;height:16px;cursor:pointer}.cf-radio-label:hover{border-color:#a5b4fc;background:#eef2ff}.cf-radio-active{border-color:#4f46e5!important;background:#eef2ff!important;color:#3730a3!important}.cf-online-type-group{width:100%}.cf-live-section{background:#f0f4ff;border:1.5px solid #c7d2fe;border-radius:12px;padding:1.4rem 1.6rem 1.2rem;margin:0 0 1.4rem}.cf-live-title{font-size:1rem;font-weight:700;color:#3730a3;margin:0 0 1.1rem;padding-bottom:.65rem;border-bottom:1.5px solid #c7d2fe;letter-spacing:-.01em}.cf-optional{font-size:.8rem;font-weight:400;color:#9ca3af;margin-left:.25rem}.cf-live-section .form-row{display:flex;gap:1rem;flex-wrap:wrap}.cf-live-section .form-group{flex:1;min-width:240px}.cf-live-section input[type=datetime-local]{width:100%;padding:.55rem .75rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:.9rem;background:#fff;color:#1a1d27;cursor:pointer;transition:border-color .18s}.cf-live-section input[type=datetime-local]:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.cf-live-section input[type=datetime-local].error,.cf-live-section input[type=url].error{border-color:#ef4444}.cf-live-section input[type=url]{width:100%;padding:.55rem .75rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:.9rem;background:#fff;color:#1a1d27;transition:border-color .18s}.cf-live-section input[type=url]:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.banner-management{padding:2rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-header h1{font-size:1.55rem;font-weight:700;color:#1e293b;margin:0 0 .3rem;line-height:1.3}.header-buttons{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.info-box{background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;padding:1.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 4px 6px #667eea33}.info-box p{margin:0 0 .5rem;font-size:1.1rem}.info-box ul{margin:.5rem 0 0 1.5rem;padding:0}.info-box li{margin:.3rem 0;font-size:.95rem}.btn-create{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease;font-weight:600}.btn-create:hover{background:#5a67d8;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-back{background:#94a3b8;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease}.btn-back:hover{background:#64748b}.banner-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:2rem}.banner-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border:1px solid #e2e8f0}.banner-card:hover{box-shadow:0 4px 16px #667eea26;transform:translateY(-4px);border-color:#667eea}.banner-card.inactive{opacity:.6}.banner-preview{position:relative;width:100%;height:200px;overflow:hidden}.banner-preview img{width:100%;height:100%;object-fit:cover}.inactive-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;color:#fff;padding:.5rem 1rem;border-radius:8px;font-weight:700;font-size:1.2rem}.banner-info{padding:1.5rem}.banner-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.banner-header h3{margin:0;font-size:1.3rem;color:#1e293b;flex:1;white-space:pre-wrap}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;flex-shrink:0}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.status-badge.scheduled{background:#fff3cd;color:#856404}.banner-description{color:#64748b;margin-bottom:1rem;line-height:1.5;white-space:pre-wrap}.banner-meta{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:1rem}.meta-item{margin-bottom:.5rem;font-size:.9rem;color:#475569}.meta-item:last-child{margin-bottom:0}.meta-item strong{color:#1e293b;margin-right:.5rem}.banner-actions{display:flex;gap:.5rem}.btn-toggle,.btn-edit,.btn-delete{flex:1;padding:.6rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease}.btn-toggle{background:#ffc107;color:#000}.btn-toggle:hover{background:#e0a800}.btn-edit{background:#667eea;color:#fff}.btn-edit:hover{background:#5a67d8}.btn-delete{background:#dc3545;color:#fff}.btn-delete:hover{background:#c82333}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.empty-state p{font-size:1.3rem;color:#64748b;margin-bottom:1.5rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem;overflow-y:auto}body.modal-open{overflow:hidden}.modal-content{background:#fff;border-radius:16px;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003;margin:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid #e2e8f0;background:#fff;color:#1e293b;border-radius:16px 16px 0 0;position:sticky;top:0;z-index:10;box-shadow:0 2px 8px #0000001a}.modal-header h2{margin:0;font-size:1.75rem;color:#1e293b;font-weight:700}.btn-close{background:#f1f5f9;border:none;font-size:1.5rem;cursor:pointer;color:#1e293b;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-close:hover{background:#e0e0e0;transform:scale(1.1)}.banner-form{padding:2rem}.form-section{margin-bottom:2.5rem;padding:2rem;background:#f8f9fa;border-radius:12px;border:1.5px solid #e2e8f0}.form-section:last-of-type{margin-bottom:0}.section-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid #667eea;display:flex;align-items:center;gap:.5rem}.section-title:before{content:"";width:4px;height:1.5rem;background:#667eea;border-radius:2px}.section-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 2rem}.section-grid.single-column{grid-template-columns:1fr}.span-full{grid-column:1 / -1}.form-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.form-column-left,.form-column-right{display:flex;flex-direction:column;gap:1.5rem}.form-full-width{grid-column:1 / -1}.form-group{display:flex;flex-direction:column}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#1e293b;font-size:.95rem}.form-group label .required{color:#dc3545;margin-left:.25rem}.form-group label .optional-label{font-weight:400;color:#94a3b8;font-size:.85rem;margin-left:.5rem}.form-group input[type=text],.form-group input[type=number],.form-group input[type=url],.form-group input[type=datetime-local],.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .3s ease;box-sizing:border-box;font-family:inherit;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.form-group small{display:block;margin-top:.5rem;color:#64748b;font-size:.85rem}.form-group small.line-hint{color:#667eea;font-style:italic}.datetime-group{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.checkbox-label{display:flex;align-items:center;gap:.625rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:background .2s ease}.checkbox-label:hover{background:#667eea0d}.checkbox-label input[type=checkbox]{width:18px;height:18px;margin:0;cursor:pointer;accent-color:#667eea;flex-shrink:0}.checkbox-label span{line-height:1.2;-webkit-user-select:none;user-select:none}.radio-group{display:flex;gap:2rem;padding:.75rem;background:#fff;border-radius:8px;border:1.5px solid #e2e8f0;flex-wrap:wrap}.radio-label{display:flex;align-items:center;gap:.625rem;cursor:pointer;font-weight:400;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease}.radio-label:hover{background:#f8f9fa}.radio-label input[type=radio]{width:18px;height:18px;margin:0;cursor:pointer;accent-color:#667eea;flex-shrink:0}.radio-label span{line-height:1.2;-webkit-user-select:none;user-select:none}.radio-label input[type=radio]:checked+span{font-weight:600;color:#667eea}.position-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.position-option{display:flex;align-items:center;gap:.625rem;padding:.75rem;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff}.position-option:hover{border-color:#667eea;background:#f7fafc}.position-option input[type=radio]{width:18px;height:18px;margin:0;cursor:pointer;accent-color:#667eea;flex-shrink:0}.position-option span{line-height:1.2;font-size:.9rem;-webkit-user-select:none;user-select:none}.position-option.selected{border-color:#667eea;background:#667eea0d}.image-upload-area{border:2px dashed #667eea;border-radius:8px;padding:1.5rem;text-align:center;background:#fff;transition:all .3s ease;cursor:pointer}.image-upload-area:hover{background:#f0f3ff;border-color:#5a67d8}.image-upload-area input[type=file]{display:none}.upload-label{display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer}.upload-icon{font-size:2.5rem;color:#667eea}.upload-text{font-size:1rem;color:#667eea;font-weight:600}.upload-hint{font-size:.85rem;color:#999}.image-preview{margin-top:1rem;border-radius:8px;overflow:hidden;max-width:100%;border:1.5px solid #e2e8f0;position:relative}.image-preview img{width:100%;height:auto;display:block}.image-preview-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.image-preview:hover .image-preview-overlay{opacity:1}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1rem;background:#fff;border-radius:8px}.schedule-warning{background:#fff3cd;border:2px solid #ffc107;border-radius:8px;padding:1rem;margin-top:1rem;display:flex;align-items:start;gap:.75rem}.schedule-warning-icon{font-size:1.5rem;color:#856404;flex-shrink:0}.schedule-warning-content{flex:1}.schedule-warning-title{font-weight:600;color:#856404;margin:0 0 .25rem;font-size:.95rem}.schedule-warning-text{margin:0;color:#856404;font-size:.875rem;line-height:1.4}.form-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid #e2e8f0;grid-column:1 / -1}.btn-cancel,.btn-submit{flex:1;padding:1rem;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel{background:#94a3b8;color:#fff}.btn-cancel:hover{background:#64748b;transform:translateY(-2px)}.btn-submit{background:#667eea;color:#fff}.btn-submit:hover{background:#5a67d8;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-cancel:disabled,.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:400px}.spinner{border:4px solid #e2e8f0;border-top:4px solid #667eea;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.modal-content{max-width:95%}.form-container{grid-template-columns:1fr;gap:1.5rem}.form-full-width{grid-column:1}.section-grid{grid-template-columns:1fr}.position-grid{grid-template-columns:repeat(2,1fr)}.datetime-group{grid-template-columns:1fr}}@media(max-width:768px){.banner-list{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-buttons{width:100%;flex-direction:column}.form-section{padding:1.5rem}.form-row{grid-template-columns:1fr}.radio-group{flex-direction:column;gap:.75rem}.position-grid{grid-template-columns:1fr}.modal-header,.banner-form{padding:1.5rem}.form-actions{flex-direction:column}.datetime-group{grid-template-columns:1fr}}.form-group textarea[name=title]{resize:vertical;min-height:60px;line-height:1.5;font-size:1rem;font-family:inherit;white-space:pre-wrap}.im-page{padding:2rem}.im-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.im-title{font-size:1.55rem;font-weight:700;color:#1e293b;margin:0 0 .3rem;line-height:1.3}.im-sub{font-size:.875rem;color:#64748b;margin:0}.im-btn-add{padding:.6rem 1.4rem;background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;border:none;font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0;box-shadow:0 2px 8px #667eea4d;border-radius:10px}.im-btn-add:hover{background:linear-gradient(135deg,#5a67d8,#4c51bf)}.im-loading,.im-empty{text-align:center;padding:4rem 0;color:#64748b;font-size:.95rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.im-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem}.im-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s}.im-card:hover{box-shadow:0 4px 20px #667eea1f;border-color:#c7d2fe}.im-card-banner{width:100%;aspect-ratio:3 / 1;object-fit:cover;display:block;background:#f4f5f8}.im-card-banner-placeholder{width:100%;aspect-ratio:3 / 1;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.im-card-main{display:flex;align-items:flex-start;gap:.85rem;padding:.9rem 1rem;flex:1}.im-card-photo-wrap{flex-shrink:0}.im-card-photo{width:68px;height:88px;object-fit:cover;border-radius:6px;border:1px solid #e2e8f0;display:block}.im-card-photo-ph{width:68px;height:88px;background:#e2e8f0;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;color:#94a3b8}.im-card-body{flex:1;min-width:0}.im-card-name{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 .15rem}.im-card-pos{font-size:.8rem;color:#667eea;font-weight:600;margin:0 0 .1rem}.im-card-org{font-size:.8rem;color:#475569;margin:0 0 .25rem}.im-card-field{font-size:.77rem;color:#64748b;margin:0 0 .2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.im-card-meta{font-size:.75rem;color:#94a3b8;margin:0}.im-card-actions{display:flex;border-top:1px solid #e2e8f0}.im-btn-edit,.im-btn-del{flex:1;padding:.6rem;border:none;background:transparent;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s}.im-btn-edit{color:#667eea;border-right:1px solid #e2e8f0}.im-btn-edit:hover{background:#f0f3ff;color:#5a67d8}.im-btn-del{color:#dc2626}.im-btn-del:hover{background:#fef2f2}.im-modal-overlay{position:fixed;inset:0;background:#00000085;z-index:300;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow-y:auto}.im-modal{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000038;animation:im-pop .22s ease}@keyframes im-pop{0%{opacity:0;transform:scale(.96) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.im-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.75rem;border-bottom:1px solid #e2e8f0;flex-shrink:0}.im-modal-header h2{margin:0;font-size:1.15rem;font-weight:700;color:#1e293b}.im-modal-close{width:34px;height:34px;border:none;background:#f1f5f9;border-radius:50%;font-size:1.1rem;cursor:pointer;color:#475569;display:flex;align-items:center;justify-content:center;transition:background .15s;line-height:1}.im-modal-close:hover{background:#e2e8f0}.im-modal-body{flex:1;overflow-y:auto;padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1.75rem}.im-section{display:flex;flex-direction:column;gap:1rem}.im-section-title{font-size:.82rem;font-weight:700;color:#64748b;letter-spacing:.06em;text-transform:uppercase;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0;margin:0}.im-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.25rem}.im-col-2{grid-column:span 2}.im-field{display:flex;flex-direction:column;gap:.35rem}.im-field label{font-size:.84rem;font-weight:600;color:#475569}.im-hint{font-size:.74rem;font-weight:400;color:#94a3b8;margin-left:.35rem}.im-field input[type=text],.im-field input[type=email],.im-field input[type=tel],.im-field input[type=date],.im-field textarea{padding:.6rem .85rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.9rem;color:#1e293b;font-family:inherit;transition:border-color .2s;background:#fff;resize:vertical}.im-field input:focus,.im-field textarea:focus{outline:none;border-color:#93c5fd;background:#fff;box-shadow:0 0 0 3px #eff6ff}.im-upload-row{display:flex;align-items:center;gap:.6rem}.im-btn-file{padding:.5rem 1rem;background:#f1f5f9;color:#475569;border:1.5px solid #e2e8f0;border-radius:7px;font-size:.84rem;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.im-btn-file:hover:not(:disabled){background:#e2e8f0}.im-btn-file:disabled{opacity:.5;cursor:not-allowed}.im-btn-img-del{padding:.4rem .8rem;background:transparent;color:#dc2626;border:1.5px solid #fca5a5;border-radius:7px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.im-btn-img-del:hover{background:#fef2f2}.im-prog-wrap{display:flex;align-items:center;gap:.6rem}.im-prog-bar{flex:1;height:5px;background:#e2e8f0;border-radius:50px;overflow:hidden}.im-prog-fill{height:100%;background:#667eea;border-radius:50px;transition:width .2s}.im-prog-wrap span{font-size:.72rem;color:#64748b}.im-err{font-size:.8rem;color:#dc2626;margin:0}.im-preview{border-radius:8px;overflow:hidden;border:1.5px solid #e2e8f0;margin-top:.3rem}.im-preview img{display:block;width:100%}.im-preview.square img{width:100px;height:130px;object-fit:cover}.im-preview.wide img{width:100%;aspect-ratio:3 / 1;object-fit:cover}.im-modal-footer{display:flex;gap:.75rem;padding:1.1rem 1.75rem;border-top:1px solid #e2e8f0;flex-shrink:0}.im-btn-cancel{flex:1;padding:.65rem;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.im-btn-cancel:hover{background:#e2e8f0}.im-btn-save{flex:2;padding:.65rem;background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.im-btn-save:hover:not(:disabled){background:#1e3a8a}.im-btn-save:disabled,.im-btn-cancel:disabled{opacity:.5;cursor:not-allowed}.im-confirm-overlay{position:fixed;inset:0;background:#00000080;z-index:400;display:flex;align-items:center;justify-content:center}.im-confirm{background:#fff;border-radius:12px;padding:1.75rem 2rem;max-width:360px;width:90%;text-align:center;box-shadow:0 8px 32px #0000002e}.im-confirm p{font-size:.95rem;color:#1e293b;margin:0 0 1.25rem;line-height:1.6}.im-confirm p span{font-size:.82rem;color:#64748b}.im-confirm-btns{display:flex;gap:.75rem}.im-confirm-btns button{flex:1;padding:.65rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.im-confirm-btns button:first-child{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.im-confirm-btns button:first-child:hover{background:#e2e8f0}.im-confirm-btns button.del{background:#dc2626;color:#fff}.im-confirm-btns button.del:hover{background:#b91c1c}.im-doc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:900px){.im-doc-grid{grid-template-columns:1fr}}.im-doc-label{display:block;font-size:.82rem;font-weight:600;color:#475569;margin-bottom:.45rem}.im-doc-preview{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;flex-wrap:wrap}.im-doc-icon{font-size:1.1rem;flex-shrink:0}.im-doc-link{font-size:.82rem;color:#2563eb;text-decoration:none;font-weight:500;word-break:break-all;flex:1}.im-doc-link:hover{text-decoration:underline}.im-doc-ok{font-size:.75rem;color:#16a34a;font-weight:600;background:#dcfce7;padding:.15rem .5rem;border-radius:999px;flex-shrink:0}.im-prog-pct{font-size:.78rem;color:#667eea;font-weight:600;min-width:36px;text-align:right}@media(max-width:600px){.im-two-col{grid-template-columns:1fr}.im-col-2{grid-column:span 1}.im-modal{max-height:95vh}.im-modal-body{padding:1.1rem}}.um-container{max-width:1400px;margin:0 auto;padding:2rem;background:#f8fafc;min-height:100vh}.um-spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:um-spin .8s linear infinite;flex-shrink:0}@keyframes um-spin{to{transform:rotate(360deg)}}.um-loading{display:flex;align-items:center;justify-content:center;gap:1rem;padding:4rem;color:#64748b}.um-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.um-page-title{font-size:1.6rem;font-weight:700;color:#1e293b;margin:0 0 .2rem}.um-page-sub{font-size:.9rem;color:#64748b;margin:0}.um-stat-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:1024px){.um-stat-cards{grid-template-columns:repeat(3,1fr)}}@media(max-width:640px){.um-stat-cards{grid-template-columns:repeat(2,1fr)}}.um-stat-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:1.1rem 1.4rem;box-shadow:0 1px 3px #0000000d}.um-stat-label{font-size:.82rem;color:#64748b;margin-bottom:.35rem}.um-stat-value{font-size:1.5rem;font-weight:700;color:#1e293b}.um-stat-green .um-stat-value{color:#10b981}.um-stat-red .um-stat-value{color:#ef4444}.um-stat-gray .um-stat-value{color:#94a3b8}.um-stat-blue .um-stat-value{color:#667eea}.um-toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.um-search{flex:1;min-width:220px;max-width:360px;padding:.55rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;outline:none;background:#fff;transition:border-color .15s}.um-search:focus{border-color:#667eea}.um-filter-tabs{display:flex;gap:.35rem}.um-filter-tab{padding:.45rem .9rem;border-radius:8px;border:1px solid #e2e8f0;background:#fff;font-size:.85rem;color:#475569;cursor:pointer;transition:all .15s}.um-filter-tab:hover{border-color:#667eea;color:#667eea}.um-filter-tab.active{background:#667eea;border-color:#667eea;color:#fff}.um-table-wrap{background:#fff;border-radius:14px;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000d;overflow:hidden}.um-list-table{width:100%;border-collapse:collapse;font-size:.875rem}.um-list-table thead tr{background:#f8fafc;border-bottom:1px solid #e2e8f0}.um-list-table th{padding:.8rem 1rem;text-align:left;font-weight:600;color:#475569;white-space:nowrap}.um-th-sort{cursor:pointer;-webkit-user-select:none;user-select:none}.um-th-sort:hover{color:#667eea}.um-sort-icon{font-size:.75rem;color:#94a3b8;margin-left:.2rem}.um-sort-icon.active{color:#667eea}.um-list-table td{padding:.85rem 1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;color:#334155}.um-tr{cursor:pointer;transition:background .12s}.um-tr:hover{background:#f8fafc}.um-tr:last-child td{border-bottom:none}.um-td-empty{text-align:center;color:#94a3b8;padding:3rem!important}.um-td-center{text-align:center}.um-user-cell{display:flex;align-items:center;gap:.7rem}.um-user-avatar-sm{width:34px;height:34px;border-radius:50%;background:#667eea;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;flex-shrink:0}.um-user-name{font-weight:600;color:#1e293b;font-size:.88rem}.um-user-email{font-size:.8rem;color:#64748b}.um-pagination{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.2rem;border-top:1px solid #f1f5f9;flex-wrap:wrap;gap:.5rem}.um-page-info{font-size:.85rem;color:#64748b}.um-page-btns{display:flex;gap:.3rem}.um-page-btn{width:34px;height:34px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}.um-page-btn:hover:not(:disabled){border-color:#667eea;color:#667eea}.um-page-btn.active{background:#667eea;border-color:#667eea;color:#fff}.um-page-btn:disabled{opacity:.35;cursor:default}.um-badge{display:inline-block;padding:.22rem .6rem;border-radius:999px;font-size:.76rem;font-weight:600}.um-badge-green{background:#dcfce7;color:#15803d}.um-badge-red{background:#fee2e2;color:#b91c1c}.um-badge-gray{background:#f1f5f9;color:#475569}.um-badge-orange{background:#fff3e0;color:#b45309}.um-badge-blue{background:#dbeafe;color:#1d4ed8}.um-btn{padding:.5rem 1.1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s}.um-btn-primary{background:#667eea;color:#fff;border-color:#667eea}.um-btn-primary:hover{background:#5567d5}.um-btn-secondary{background:#fff;color:#475569;border-color:#e2e8f0}.um-btn-secondary:hover{background:#f1f5f9}.um-btn-success{background:#10b981;color:#fff;border-color:#10b981}.um-btn-success:hover{background:#059669}.um-btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}.um-btn-danger:hover{background:#dc2626}.um-btn-outline{background:#fff;color:#667eea;border-color:#667eea}.um-btn-outline:hover{background:#e8eeff}.um-btn-sm{padding:.38rem .85rem;font-size:.82rem;border-radius:7px;border:1px solid transparent;cursor:pointer;font-weight:500;transition:all .15s}.um-btn-sm.um-btn-primary{background:#667eea;color:#fff;border-color:#667eea}.um-btn-sm.um-btn-primary:hover{background:#5567d5}.um-btn-sm.um-btn-secondary{background:#fff;color:#475569;border-color:#e2e8f0}.um-btn-sm.um-btn-secondary:hover{background:#f1f5f9}.um-btn-sm.um-btn-success{background:#10b981;color:#fff;border-color:#10b981}.um-btn-sm.um-btn-success:hover{background:#059669}.um-btn-sm.um-btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}.um-btn-sm.um-btn-danger:hover{background:#dc2626}.um-btn-sm.um-btn-outline{background:#fff;color:#667eea;border-color:#667eea}.um-btn-sm.um-btn-outline:hover{background:#e8eeff}.um-btn-xs{padding:.25rem .65rem;font-size:.78rem;border-radius:6px;border:1px solid transparent;cursor:pointer;font-weight:500;transition:all .13s}.um-btn-xs.um-btn-outline{background:#fff;color:#667eea;border-color:#667eea}.um-btn-xs.um-btn-outline:hover{background:#e8eeff}.um-btn-xs.um-btn-danger{background:#fff;color:#ef4444;border-color:#ef4444}.um-btn-xs.um-btn-danger:hover{background:#fee2e2}.um-modal-overlay{position:fixed;inset:0;background:#0f172a73;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;overflow-y:auto}.um-modal{background:#fff;border-radius:18px;width:1200px;max-width:calc(100vw - 2rem);height:80vh;display:flex;flex-direction:column;overflow:hidden;position:relative;box-shadow:0 20px 60px #0000002e}.um-modal-loading{display:flex;align-items:center;justify-content:center;gap:1rem;padding:4rem;color:#64748b}.um-modal-header{padding:1.3rem 1.5rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;flex-shrink:0}.um-modal-user-info{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}.um-modal-avatar{width:46px;height:46px;border-radius:50%;background:#667eea;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;flex-shrink:0}.um-modal-name{font-size:1.05rem;font-weight:700;color:#1e293b}.um-modal-email{font-size:.82rem;color:#64748b;margin-top:.1rem}.um-modal-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.um-modal-close{width:30px;height:30px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;font-size:1rem;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center;transition:all .13s;flex-shrink:0}.um-modal-close:hover{background:#f1f5f9;color:#1e293b}.um-modal-tabs{display:flex;border-bottom:1px solid #f1f5f9;padding:0 1.2rem;flex-shrink:0;background:#fff;overflow-x:auto}.um-modal-tab{padding:.7rem 1rem;font-size:.85rem;font-weight:500;color:#64748b;border:none;background:none;cursor:pointer;border-bottom:2.5px solid transparent;white-space:nowrap;transition:all .13s;position:relative;display:flex;align-items:center;gap:.4rem}.um-modal-tab:hover{color:#667eea}.um-modal-tab.active{color:#667eea;border-bottom-color:#667eea;font-weight:600}.um-tab-badge{font-size:.68rem;font-weight:700;padding:.1rem .42rem;border-radius:999px;min-width:18px;text-align:center;background:#e2e8f0;color:#475569}.um-modal-body{flex:1;overflow-y:auto;padding:1.4rem 1.5rem}.um-info-grid{display:flex;flex-direction:column;gap:0}.um-info-row{display:flex;align-items:baseline;gap:1rem;padding:.7rem 0;border-bottom:1px solid #f1f5f9;font-size:.875rem}.um-info-row:last-child{border-bottom:none}.um-info-row>span:first-child{min-width:110px;color:#64748b;font-size:.82rem;flex-shrink:0}.um-info-row>strong{color:#1e293b;font-weight:600}.um-info-full{flex-wrap:wrap}.um-code{font-family:Courier New,monospace;font-size:.78rem;background:#f1f5f9;padding:.2rem .5rem;border-radius:5px;color:#475569;word-break:break-all}.um-section-title{font-size:.95rem;font-weight:700;color:#1e293b;margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem}.um-count{background:#e8eeff;color:#667eea;font-size:.75rem;padding:.1rem .5rem;border-radius:999px;font-weight:700}.um-empty{text-align:center;color:#94a3b8;padding:1.5rem;font-size:.875rem}.um-course-list{display:flex;flex-direction:column;gap:.7rem}.um-course-card{background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0;padding:.9rem 1.1rem}.um-course-card-completed{background:#f0fdf4;border-color:#bbf7d0}.um-course-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.um-course-title{font-weight:600;color:#1e293b;font-size:.88rem;flex:1}.um-course-meta{display:flex;gap:.8rem;font-size:.78rem;color:#64748b;flex-wrap:wrap;align-items:center}.um-course-sub{font-size:.78rem;color:#64748b;margin-top:.3rem}.um-progress-row{display:flex;align-items:center;gap:.7rem;margin:.4rem 0}.um-progress-bar-wrap{flex:1;height:7px;background:#e2e8f0;border-radius:999px;overflow:hidden}.um-progress-bar{height:100%;border-radius:999px;transition:width .4s}.um-progress-pct{font-size:.82rem;font-weight:700;min-width:38px;text-align:right}.um-table{width:100%;border-collapse:collapse;font-size:.85rem}.um-table th{background:#f8fafc;text-align:left;padding:.6rem .8rem;font-weight:600;color:#475569;border-bottom:1px solid #e2e8f0}.um-table td{padding:.65rem .8rem;border-bottom:1px solid #f1f5f9;color:#334155;vertical-align:middle}.um-table tr:last-child td{border-bottom:none}.um-payments-tab{min-height:320px}.um-payments-table{table-layout:fixed;font-size:.73rem}.um-payments-table th{padding:.45rem .5rem;font-size:.71rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.um-payments-table td{padding:.5rem;font-size:.73rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.um-payments-table th:nth-child(3),.um-payments-table td:nth-child(3){white-space:normal;word-break:break-word}.um-memo-input-area{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.2rem}.um-memo-textarea{width:100%;padding:.7rem .9rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;resize:vertical;outline:none;font-family:inherit;box-sizing:border-box;transition:border-color .15s}.um-memo-textarea:focus{border-color:#667eea}.um-memo-list{display:flex;flex-direction:column;gap:.6rem}.um-memo-item{background:#f8fafc;border-radius:9px;border:1px solid #e2e8f0;padding:.8rem 1rem}.um-memo-content{font-size:.875rem;color:#334155;margin-bottom:.5rem;white-space:pre-wrap}.um-memo-footer{display:flex;align-items:center;gap:.7rem;font-size:.78rem;color:#94a3b8}.um-memo-footer button{margin-left:auto}.um-inner-modal-overlay{position:fixed;inset:0;background:#0f172a8c;z-index:2000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.um-inner-modal{background:#fff;border-radius:14px;width:90%;max-width:420px;box-shadow:0 8px 32px #0000002e;overflow:hidden}.um-inner-modal-header{padding:1rem 1.2rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:.95rem;color:#1e293b}.um-inner-modal-body{padding:1.2rem}.um-inner-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.2rem}.um-field-label{display:block;font-size:.82rem;font-weight:600;color:#475569;margin-bottom:.4rem}.um-select,.um-input{width:100%;padding:.55rem .85rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;outline:none;font-family:inherit;box-sizing:border-box;background:#fff;transition:border-color .15s}.um-select:focus,.um-input:focus{border-color:#667eea}.um-textarea{width:100%;padding:.6rem .85rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;resize:vertical;outline:none;font-family:inherit;box-sizing:border-box;transition:border-color .15s}.um-textarea:focus{border-color:#667eea}.um-extend-days{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;margin-top:.4rem}.um-day-btn{padding:.3rem .75rem;border-radius:7px;border:1px solid #e2e8f0;background:#fff;font-size:.82rem;cursor:pointer;transition:all .13s}.um-day-btn:hover{border-color:#667eea;color:#667eea}.um-day-btn.active{background:#667eea;border-color:#667eea;color:#fff}.um-refund-info{background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;padding:.8rem 1rem;margin-bottom:.2rem}@media(max-width:768px){.um-container{padding:1rem 1rem 3rem}.um-modal{width:100%;height:90vh;border-radius:14px}.um-modal-header{flex-direction:column;align-items:flex-start}.um-modal-actions{width:100%;justify-content:flex-start}.um-list-table{font-size:.8rem}.um-list-table th,.um-list-table td{padding:.6rem .7rem}}.um-refund-history{margin-top:.5rem}.um-td-price{font-weight:600;color:#ef4444;text-align:right}.um-td-reason{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#64748b;font-size:.82rem}.um-course-filter-row{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}.um-cf-btn{display:flex;align-items:center;gap:.45rem;padding:.4rem .9rem;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;font-size:.82rem;font-weight:500;color:#475569;cursor:pointer;transition:all .13s}.um-cf-btn:hover{border-color:#667eea;color:#667eea}.um-cf-btn.active{background:#667eea;border-color:#667eea;color:#fff}.um-cf-btn.active .um-cf-count{background:#ffffff40;color:#fff}.um-cf-btn.um-cf-blue.active{background:#667eea;border-color:#667eea}.um-cf-btn.um-cf-green.active{background:#10b981;border-color:#10b981}.um-cf-btn.um-cf-purple.active{background:#8b5cf6;border-color:#8b5cf6}.um-cf-btn.um-cf-blue:not(.active):hover{border-color:#667eea;color:#667eea}.um-cf-btn.um-cf-green:not(.active):hover{border-color:#10b981;color:#10b981}.um-cf-btn.um-cf-purple:not(.active):hover{border-color:#8b5cf6;color:#8b5cf6}.um-cf-count{background:#f1f5f9;color:#64748b;font-size:.72rem;font-weight:700;padding:.05rem .45rem;border-radius:999px;min-width:18px;text-align:center;transition:all .13s}.um-course-table{table-layout:fixed;font-size:.8rem}.um-course-table th{font-size:.75rem;padding:.5rem .6rem}.um-course-table td{padding:.55rem .6rem;vertical-align:middle}.um-course-table th:nth-child(1){width:28%}.um-course-table th:nth-child(2){width:9%}.um-course-table th:nth-child(3){width:21%}.um-course-table th:nth-child(4){width:10%}.um-course-table th:nth-child(5){width:16%}.um-course-table th:nth-child(6){width:16%}.um-enr-title{font-weight:600;color:#1e293b;font-size:.82rem}.um-enr-sub{font-size:.76rem;color:#94a3b8;margin-top:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.um-enr-lesson-sub{font-size:.72rem;color:#94a3b8}.um-progress-meta-row{display:flex;align-items:center;justify-content:space-between;margin-top:.2rem}.um-btn-progress-icon{background:none;border:none;cursor:pointer;font-size:.78rem;padding:0 2px;opacity:.55;line-height:1;transition:opacity .12s}.um-btn-progress-icon:hover{opacity:1}.um-progress-inline{display:flex;align-items:center;gap:.5rem}.um-progress-inline .um-progress-bar-wrap{flex:1;height:6px;background:#e2e8f0;border-radius:999px;overflow:hidden}.um-progress-inline .um-progress-bar{height:100%;border-radius:999px;transition:width .4s}.um-progress-inline .um-progress-pct{font-size:.78rem;font-weight:700;min-width:34px;text-align:right}.um-date-done{color:#10b981;font-size:.78rem;font-weight:500}.um-date-exp{color:#f59e0b;font-size:.78rem}.um-exam-inline{margin-top:.3rem}.um-badge-purple{background:#ede9fe;color:#6d28d9}.um-refund-modal-lg{background:#fff;border-radius:14px;width:580px;max-width:calc(100vw - 2rem);max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #00000047;display:flex;flex-direction:column}.um-refund-modal-lg .um-inner-modal-header{flex-shrink:0;padding:1.1rem 1.4rem;border-bottom:1px solid #e2e8f0;font-size:1rem;font-weight:700;color:#1e293b;display:flex;align-items:center;justify-content:space-between}.um-refund-modal-lg .um-inner-modal-body{flex:1;overflow-y:auto;padding:1.4rem}.um-refund-modal-lg .um-inner-modal-footer{flex-shrink:0;padding:1rem 1.4rem;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:.6rem;margin-top:0;background:#fff}.um-refund-info-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:1rem 1.1rem;margin-bottom:1rem}.um-refund-info-row{display:flex;align-items:baseline;gap:.7rem;font-size:.85rem;padding:.28rem 0;border-bottom:1px solid #f1f5f9}.um-refund-info-row:last-child{border-bottom:none}.um-refund-info-row>span:first-child{color:#64748b;min-width:72px;font-size:.8rem}.um-refund-policy-text{color:#334155;font-size:.82rem}.um-refund-law-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:.8rem 1rem;margin-bottom:1rem;font-size:.82rem;color:#1e40af}.um-refund-law-box p{margin:0 0 .4rem;font-size:.83rem}.um-refund-law-box ul{margin:0;padding-left:1.2rem}.um-refund-law-box li{margin-bottom:.2rem}.um-refund-amount-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:1rem 1.1rem;margin-bottom:1rem}.um-refund-amount-label{font-size:.78rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.6rem}.um-refund-amount-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.um-refund-auto-amount,.um-refund-manual-input{flex:1;min-width:130px}.um-refund-amount-desc{display:block;font-size:.75rem;color:#64748b;margin-bottom:.3rem}.um-refund-auto-value{font-size:1.15rem;font-weight:700;color:#0f172a}.um-refund-auto-value.um-refund-zero{color:#ef4444;font-size:.9rem}.um-refund-divider{font-size:1.1rem;color:#94a3b8;align-self:flex-end;padding-bottom:4px}.um-refund-input-wrap{display:flex;align-items:center;border:1.5px solid #cbd5e1;border-radius:7px;background:#fff;overflow:hidden}.um-refund-input-wrap:focus-within{border-color:#667eea}.um-refund-won{padding:.4rem .5rem;font-size:.9rem;color:#64748b;background:#f1f5f9;border-right:1px solid #e2e8f0}.um-refund-amount-input{border:none;outline:none;padding:.4rem .6rem;font-size:.9rem;width:100%;color:#0f172a}.um-refund-amount-input::-webkit-inner-spin-button,.um-refund-amount-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.um-refund-final{margin-top:.7rem;padding-top:.6rem;border-top:1px solid #e2e8f0;font-size:.9rem;color:#334155;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.um-refund-final-value{font-size:1.1rem;font-weight:700;color:#0f172a}.um-refund-manual-badge{background:#fef3c7;color:#92400e;border:1px solid #fcd34d;border-radius:4px;font-size:.72rem;font-weight:600;padding:2px 7px}.um-force-refund-box{background:#fff7ed;border:1.5px solid #fed7aa;border-radius:8px;padding:.8rem 1rem;margin-bottom:1rem}.um-force-refund-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#c2410c;cursor:pointer}.um-force-refund-warn{margin:.5rem 0 0;font-size:.8rem;color:#9a3412;line-height:1.5}.um-form-group{margin-bottom:1rem}.um-btn-refund-confirm{padding:.52rem 1.3rem;border:none;border-radius:8px;font-size:.875rem;font-weight:700;cursor:pointer;background:#dc2626;color:#fff;transition:background .15s,transform .1s;letter-spacing:-.01em}.um-btn-refund-confirm:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.um-btn-refund-confirm:active:not(:disabled){transform:none}.um-btn-refund-confirm.force{background:#991b1b}.um-btn-refund-confirm.force:hover:not(:disabled){background:#7f1d1d}.um-btn-refund-confirm.disabled,.um-btn-refund-confirm:disabled{background:#cbd5e1;color:#94a3b8;cursor:not-allowed}@media(max-width:640px){.um-refund-modal-lg{width:100%;border-radius:16px 16px 0 0;max-height:92vh;position:fixed;bottom:0;left:0;right:0}.um-refund-amount-row{flex-direction:column;gap:.6rem}.um-refund-divider{display:none}}.um-tab-badge-red{background:#fee2e2;color:#b91c1c}.um-badge-lg{font-size:.9rem;padding:.35rem .9rem;border-radius:20px}.um-acct-status-tab{padding:.5rem 0}.um-acct-status-summary{display:flex;align-items:center;justify-content:space-between;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.2rem;margin-bottom:1.5rem}.um-acct-status-current{display:flex;align-items:center;gap:.75rem}.um-acct-status-label{font-size:.85rem;font-weight:600;color:#64748b}.um-acct-log-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.um-acct-log-title{font-size:.92rem;font-weight:700;color:#1e293b}.um-acct-log-count{font-size:.8rem;color:#94a3b8;background:#f1f5f9;padding:.15rem .6rem;border-radius:20px}.um-acct-log-list{display:flex;flex-direction:column;gap:.6rem}.um-acct-log-item{display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:1rem;padding:.85rem 1rem;border-radius:10px;border:1px solid #e2e8f0;background:#fff;transition:box-shadow .12s}.um-acct-log-item:hover{box-shadow:0 2px 8px #0000000f}.um-acct-log-item--suspend{border-left:3px solid #ef4444;background:#fff8f8}.um-acct-log-item--release{border-left:3px solid #10b981;background:#f0fdf4}.um-acct-log-badges{display:flex;align-items:center;gap:.4rem;white-space:nowrap}.um-acct-log-arrow{font-size:.85rem;color:#94a3b8;font-weight:700}.um-acct-log-reason{font-size:.87rem;color:#374151;line-height:1.5;word-break:break-all;padding-top:.1rem}.um-acct-log-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;white-space:nowrap}.um-acct-log-date{font-size:.78rem;color:#94a3b8}.um-acct-log-by{font-size:.75rem;color:#667eea;font-weight:600}.um-suspend-modal{max-width:460px!important;width:100%}.um-suspend-user-info{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:1rem}.um-suspend-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;flex-shrink:0}.um-suspend-name{font-size:.9rem;font-weight:600;color:#1e293b}.um-suspend-email{font-size:.78rem;color:#64748b;margin-top:.1rem}.um-suspend-change-box{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.7rem 1rem;border-radius:10px;margin-bottom:.5rem;font-size:.9rem}.um-suspend-change-box--block{background:#fff1f2;border:1px solid #fecaca}.um-suspend-change-box--release{background:#f0fdf4;border:1px solid #bbf7d0}.um-suspend-arrow{font-size:1.1rem;color:#64748b;font-weight:700}.um-suspend-required{font-size:.78rem;color:#ef4444;margin:.4rem 0 0;line-height:1.4}@media(max-width:600px){.um-acct-log-item{grid-template-columns:1fr;gap:.5rem}.um-acct-log-meta{align-items:flex-start;flex-direction:row;gap:.5rem}.um-acct-status-summary{flex-direction:column;align-items:flex-start;gap:.75rem}}.um-date-row{display:flex;align-items:center;gap:.25rem;line-height:1.5}.um-date-label-done{font-size:.68rem;font-weight:700;color:#fff;background:#10b981;border-radius:3px;padding:0 5px;flex-shrink:0}.um-date-label-exp{font-size:.68rem;font-weight:700;color:#fff;background:#f59e0b;border-radius:3px;padding:0 5px;flex-shrink:0}.um-date-exp-muted{font-size:.82rem;color:#94a3b8;text-decoration:line-through}.um-text-muted{color:#cbd5e1;font-size:.85rem}.um-manage-cell{display:flex;flex-direction:row;flex-wrap:wrap;gap:.3rem;align-items:center}.um-btn-cert{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;padding:.25rem .6rem;font-size:.72rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.um-btn-cert:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.um-btn-cert:disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed;opacity:1}.um-cert-issued-badge{font-size:.72rem;font-weight:600;color:#10b981;background:#d1fae5;border-radius:6px;padding:.25rem .55rem;white-space:nowrap}.um-btn-dormant{background:#64748b;color:#fff;border:none;border-radius:8px;padding:.45rem 1rem;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s}.um-btn-dormant:hover{background:#475569}.um-btn-dormant:disabled{opacity:.5;cursor:not-allowed}.um-btn-xs.um-btn-dormant{padding:.25rem .55rem;font-size:.72rem;border-radius:6px}.um-btn-progress-detail{display:inline-block;margin-top:.35rem;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:5px;padding:.2rem .55rem;font-size:.7rem;font-weight:500;cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.um-btn-progress-detail:hover{background:#667eea;color:#fff;border-color:#667eea}.um-progress-detail-modal{max-width:1000px;width:95%;height:70vh;max-height:70vh;display:flex;flex-direction:column}.um-progress-detail-title{font-size:1rem;font-weight:700;color:#1e293b}.um-progress-detail-course{font-size:.82rem;color:#64748b;margin-top:.2rem}.um-progress-detail-body{overflow-y:auto;flex:1;padding:1rem 1.25rem}.um-progress-detail-summary{display:flex;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;margin-bottom:1.25rem}.um-pds-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem;border-right:1px solid #e2e8f0}.um-pds-item:last-child{border-right:none}.um-pds-num{font-size:1.3rem;font-weight:800;color:#1e293b;line-height:1.2}.um-pds-num.um-pds-done{font-size:1rem;color:#10b981}.um-pds-label{font-size:.72rem;color:#94a3b8;margin-top:.2rem}.um-pd-section{margin-bottom:1rem;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.um-pd-section-header{display:flex;align-items:center;gap:.6rem;padding:.5rem .85rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.um-pd-section-idx{font-size:.7rem;font-weight:700;color:#667eea;background:#ede9fe;border-radius:4px;padding:.1rem .45rem}.um-pd-section-title{font-size:.85rem;font-weight:600;color:#334155;flex:1}.um-pd-section-count{font-size:.75rem;color:#94a3b8}.um-pd-table{width:100%;border-collapse:collapse;font-size:.8rem}.um-pd-table th{background:#f8fafc;color:#64748b;font-weight:600;padding:.4rem .6rem;border-bottom:1px solid #e2e8f0;text-align:left}.um-pd-table td{padding:.45rem .6rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.um-pd-table tr:last-child td{border-bottom:none}.um-pd-row-done{background:#f0fdf4}.um-pd-idx{color:#94a3b8;font-size:.75rem}.um-pd-lesson-title{display:flex;align-items:center;gap:.4rem}.um-pd-check{font-size:.85rem;flex-shrink:0}.um-pd-center{text-align:center}.um-pd-mono{font-family:Courier New,monospace;font-size:.78rem;color:#475569}.um-edit-phone-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.um-input-sm{padding:.3rem .6rem;border:1.5px solid #cbd5e1;border-radius:6px;font-size:.85rem;outline:none;width:180px;transition:border-color .2s}.um-input-sm:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1f}.um-courses-header-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.85rem;flex-wrap:nowrap}.um-courses-header-row .um-course-filter-row{margin-bottom:0;flex-wrap:wrap}.um-modal-overlay-sub{z-index:1100}.um-modal-sm{width:min(520px,95vw);max-height:90vh;display:flex;flex-direction:column}.um-addenr-body{display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.um-addenr-desc{font-size:.85rem;color:#475569;background:#f8fafc;border-radius:8px;padding:.75rem 1rem;border:1px solid #e2e8f0;line-height:1.6;margin:0}.um-addenr-select-wrap{display:flex;flex-direction:column;gap:.5rem}.um-label{font-size:.8rem;font-weight:600;color:#475569}.um-select{padding:.5rem .75rem;border:1.5px solid #cbd5e1;border-radius:8px;font-size:.85rem;background:#fff;outline:none;transition:border-color .2s}.um-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1f}.um-addenr-preview{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background:#f0f4ff;border-radius:8px;border:1px solid #c7d2fe;margin-top:.25rem}.um-addenr-thumb{width:72px;height:48px;object-fit:cover;border-radius:5px;flex-shrink:0}.um-addenr-title{font-size:.85rem;font-weight:600;color:#1e293b;line-height:1.4}.um-addenr-meta{font-size:.75rem;color:#64748b;margin-top:.3rem}.um-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid #e2e8f0;background:#f8fafc;border-radius:0 0 16px 16px;flex-shrink:0}.um-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:7px;padding:.45rem 1rem;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.um-btn-primary:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.um-btn-primary:disabled{opacity:.45;cursor:not-allowed}.um-btn-sm.um-btn-primary{padding:.5rem 1.1rem;font-size:.85rem}.um-addenr-duration-wrap{display:flex;flex-direction:column;gap:.5rem;padding:.85rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.um-label-hint{font-size:.75rem;font-weight:400;color:#667eea;margin-left:.4rem}.um-input-days-text{width:100%!important;box-sizing:border-box}.um-addenr-quick-days{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.2rem}.um-quick-day-btn{padding:.25rem .6rem;border:1.5px solid #cbd5e1;border-radius:20px;background:#fff;font-size:.75rem;font-weight:500;color:#475569;cursor:pointer;transition:all .15s}.um-quick-day-btn:hover{border-color:#667eea;color:#667eea;background:#ede9fe}.um-quick-day-btn.active{background:#667eea;border-color:#667eea;color:#fff}.um-enr-title-row{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem}.um-badge-admin-added{display:inline-flex;align-items:center;gap:.2rem;font-size:.68rem;font-weight:600;padding:.15rem .45rem;border-radius:10px;background:#fef3c7;color:#92400e;border:1px solid #fcd34d;white-space:nowrap;cursor:default}.um-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;background:#fff;border-radius:10px;border:1px solid #e2e8f0}.um-course-filter-select-wrap{display:flex;align-items:center;gap:.3rem;margin-left:auto}.um-course-filter-select{padding:.45rem .75rem;border:1.5px solid #cbd5e1;border-radius:8px;font-size:.82rem;background:#fff;color:#334155;outline:none;cursor:pointer;max-width:220px;transition:border-color .2s}.um-course-filter-select:focus{border-color:#667eea}.um-course-filter-select:disabled{opacity:.6;cursor:not-allowed}.um-course-filter-clear{width:22px;height:22px;border-radius:50%;border:none;background:#e2e8f0;color:#475569;font-size:.75rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.um-course-filter-clear:hover{background:#ef4444;color:#fff}.um-filter-badge-active{color:#667eea;font-weight:600;font-size:.82rem}.um-page-info{font-size:.82rem;color:#64748b;display:flex;align-items:center;flex-wrap:wrap;gap:.2rem}.um-btn-cancel-enr{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;font-size:.72rem;font-weight:600;border-radius:5px;border:1.5px solid #f87171;color:#dc2626;background:#fff5f5;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.um-btn-cancel-enr:hover{background:#fee2e2;color:#b91c1c;border-color:#dc2626}.um-badge-yellow{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.um-badge-red{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.um-btn-warning{border:1.5px solid #f59e0b;color:#b45309;background:#fffbeb}.um-btn-warning:hover{background:#fef3c7;color:#92400e}.um-payment-action-cell{white-space:nowrap}.um-refund-action-group{display:flex;gap:4px;flex-wrap:nowrap}.um-amount-refund-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:1px;line-height:1.3}.um-amount-orig{font-size:.72rem;color:#94a3b8;text-decoration:line-through}.um-amount-refund{font-size:.875rem;font-weight:700;color:#1d4ed8}.um-td-refund{text-align:right;white-space:nowrap}.um-td-refund-empty{color:#cbd5e1;font-size:.8rem}.um-refund-amount-cell{display:inline-flex;align-items:center;gap:5px;font-weight:700;color:#1d4ed8;font-size:.875rem}.um-refund-partial-tag{font-size:.68rem;font-weight:600;background:#ede9fe;color:#6d28d9;padding:1px 5px;border-radius:8px;line-height:1.4}.um-refund-full-tag{font-size:.68rem;font-weight:600;background:#dbeafe;color:#1d4ed8;padding:1px 5px;border-radius:8px;line-height:1.4}.um-amount-refund-wrap{display:contents}.um-badge-gold{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #f59e0b;font-size:.72rem;font-weight:700;padding:2px 7px;border-radius:9999px;white-space:nowrap}.um-cert-section{margin-top:.5rem}.um-cert-exam-table th,.um-cert-exam-table td{font-size:.82rem;padding:8px 10px}.um-cert-exam-table thead th{background:#f1f5f9;color:#475569;font-weight:600;border-bottom:2px solid #e2e8f0}.um-cert-exam-table tbody tr:hover{background:#f8fafc}.um-cert-count-badge{display:inline-block;margin-left:4px;font-size:.68rem;font-weight:600;color:#7c3aed;background:#ede9fe;border-radius:8px;padding:1px 5px;line-height:1.5;vertical-align:middle}.um-payments-tab .um-badge{font-size:.72rem}.um-courses-tab .um-section-title{font-size:.9rem;font-weight:700;color:#1e293b;border-left:3px solid #667eea;padding-left:.6rem;display:flex;align-items:center;gap:.35rem}.um-exams-tab{display:flex;flex-direction:column;gap:1rem}.um-exam-summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:.5rem}.um-exam-stat-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:.85rem 1rem;text-align:center}.um-exam-stat-card--blue{background:#eff6ff;border-color:#bfdbfe}.um-exam-stat-card--green{background:#f0fdf4;border-color:#bbf7d0}.um-exam-stat-card--gold{background:#fffbeb;border-color:#fde68a}.um-exam-stat-num{font-size:1.6rem;font-weight:800;color:#1e293b;line-height:1.2}.um-exam-stat-card--blue .um-exam-stat-num{color:#2563eb}.um-exam-stat-card--green .um-exam-stat-num{color:#16a34a}.um-exam-stat-card--gold .um-exam-stat-num{color:#92400e}.um-exam-stat-label{font-size:.75rem;color:#64748b;margin-top:.2rem;font-weight:500}.um-exam-row-passed{background:#f0fdf4!important}.um-exam-row-passed:hover{background:#dcfce7!important}.um-exam-detail-toggle{cursor:pointer;font-size:.75rem;font-weight:600;color:#667eea;padding:3px 8px;border-radius:6px;border:1px solid #c7d2fe;background:#eef2ff;white-space:nowrap;-webkit-user-select:none;user-select:none;transition:background .15s}.um-exam-detail-toggle:hover{background:#e0e7ff}.um-exam-detail-row>td.um-exam-detail-cell{padding:0;background:#f8fafc;border-left:3px solid #667eea}.um-exam-detail-inner{padding:.75rem 1.25rem .75rem 1.5rem}.um-exam-history-table{width:100%;border-collapse:collapse;font-size:.8rem}.um-exam-history-table th{background:#f1f5f9;color:#475569;font-weight:600;padding:6px 10px;border-bottom:1px solid #e2e8f0;text-align:left}.um-exam-history-table td{padding:6px 10px;border-bottom:1px solid #f1f5f9;color:#334155}.um-exam-history-table tr:last-child td{border-bottom:none}.um-exam-history-table tr:hover td{background:#f0f9ff}.um-payment-filter-row{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.um-pf-btn{display:inline-flex;align-items:center;gap:.3rem;padding:6px 14px;border-radius:20px;border:1.5px solid #e2e8f0;background:#f8fafc;color:#64748b;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s}.um-pf-btn:hover{border-color:#667eea;color:#667eea;background:#eef2ff}.um-pf-btn.active{background:#667eea;border-color:#667eea;color:#fff}.um-pf-btn.active .um-cf-count{background:#ffffff40;color:#fff}.um-tab-badge-purple{background:#ede9fe;color:#7c3aed}.um-modal-tabs{overflow-x:auto;white-space:nowrap;scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.um-modal-tab{flex-shrink:0}@media(max-width:640px){.um-exam-summary-row{grid-template-columns:repeat(2,1fr)}}.um-tab-badge-gray{background:#e2e8f0;color:#475569}.um-tab-badge-blue{background:#dbeafe;color:#1d4ed8}.um-tab-badge-green{background:#dcfce7;color:#15803d}.um-split-count{display:inline-block;font-size:.82rem;font-weight:700;padding:2px 10px;border-radius:20px;min-width:28px;text-align:center}.um-split-count--course{background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe}.um-split-count--cert{background:#ede9fe;color:#7c3aed;border:1px solid #ddd6fe}.um-type-label{font-size:.8rem;font-weight:600}.um-type-cert,.um-type-course{display:inline-block;font-size:.72rem;font-weight:700;white-space:nowrap;line-height:1.4}.um-type-cert{color:#7c3aed}.um-type-course{color:#2563eb}.om-badge{display:inline-flex;align-items:center;padding:.22rem .65rem;border-radius:20px;font-size:.78rem;font-weight:600;white-space:nowrap}.om-badge-green{background:#d1fae5;color:#065f46}.om-badge-yellow{background:#fef9c3;color:#854d0e}.om-badge-orange{background:#ffedd5;color:#9a3412}.om-badge-red{background:#fee2e2;color:#991b1b}.om-badge-gray{background:#f1f5f9;color:#475569}.om-badge-purple{background:#ede9fe;color:#5b21b6}.om-wrap{display:flex;flex-direction:column;gap:1rem;padding:2rem}.om-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.om-title{font-size:1.55rem;font-weight:700;color:#1e293b;margin:0 0 .3rem;line-height:1.3}.om-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.om-stat-card{display:flex;align-items:center;gap:.75rem;background:#fff;border-radius:12px;padding:1rem 1.25rem;border:1px solid #e2e8f0;border-left:4px solid transparent;transition:box-shadow .15s}.om-stat-card:hover{box-shadow:0 4px 12px #667eea1a}.om-stat-card--blue{border-color:#667eea}.om-stat-card--green{border-color:#10b981}.om-stat-card--yellow{border-color:#f59e0b}.om-stat-card--orange{border-color:#f97316}.om-stat-card--gray{border-color:#94a3b8}.om-stat-card--purple{border-color:#8b5cf6}.om-stat-card--red{border-color:#ef4444}.om-stat-num{font-size:1.15rem;font-weight:700;color:#1e293b}.om-stat-label{font-size:.78rem;color:#64748b;margin-top:2px}.om-filter-wrap{background:#fff;border-radius:12px;padding:1.25rem 1.5rem;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:.85rem}.om-filter-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.om-filter-label{font-size:.82rem;font-weight:600;color:#475569;min-width:40px}.om-btn-group{display:flex;gap:6px}.om-filter-btn{padding:5px 14px;border-radius:20px;border:1px solid #e2e8f0;background:#fff;font-size:.82rem;color:#475569;cursor:pointer;transition:all .15s}.om-filter-btn.active{background:#667eea;color:#fff;border-color:#667eea}.om-date-range{display:flex;align-items:center;gap:8px}.om-date-input{padding:5px 10px;border:1px solid #e2e8f0;border-radius:8px;font-size:.82rem;color:#475569}.om-status-tabs{display:flex;gap:0;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.om-status-tab{padding:6px 14px;border:none;background:#fff;font-size:.82rem;color:#475569;cursor:pointer;position:relative;transition:background .15s;border-right:1px solid #e2e8f0}.om-status-tab:last-child{border-right:none}.om-status-tab.active{background:#667eea;color:#fff;font-weight:600}.om-noti-dot{display:inline-flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;border-radius:50%;width:17px;height:17px;font-size:.68rem;font-weight:700;margin-left:5px;vertical-align:middle}.om-search-wrap{display:flex;align-items:center;gap:6px;flex:1;max-width:420px}.om-search-input{flex:1;padding:7px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;outline:none;color:#1e293b}.om-search-input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.om-search-btn{padding:7px 14px;background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600}.om-search-clear{padding:6px 10px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;color:#64748b}.om-table-wrap{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden}.om-loading-bar{height:3px;background:#e2e8f0;overflow:hidden}.om-loading-bar-fill{height:100%;background:#667eea;width:60%;animation:omLoadSlide 1s infinite}@keyframes omLoadSlide{0%{transform:translate(-100%)}to{transform:translate(200%)}}.om-table{width:100%;border-collapse:collapse;font-size:.875rem}.om-table th{background:#f8fafc;padding:12px 14px;text-align:left;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e2e8f0;white-space:nowrap}.om-table th.om-th-price,.om-table th.om-th-date{cursor:pointer;-webkit-user-select:none;user-select:none}.om-table th.om-th-price:hover,.om-table th.om-th-date:hover{background:#f0f3ff}.om-sort-icon{margin-left:4px;opacity:.4;font-size:.75rem}.om-sort-icon.active{opacity:1;color:#667eea}.om-tr{cursor:pointer;transition:background .12s;border-bottom:1px solid #e2e8f0}.om-tr:hover{background:#f8fafc}.om-table td{padding:11px 14px;vertical-align:middle}.om-empty{text-align:center;color:#94a3b8;padding:3rem;font-size:.9rem}.om-order-id{font-family:monospace;font-size:.78rem;color:#64748b;background:#f1f5f9;padding:2px 6px;border-radius:4px}.om-user-cell{display:flex;flex-direction:column;gap:2px}.om-user-name{font-weight:600;color:#1e293b}.om-user-email{font-size:.75rem;color:#94a3b8}.om-course-title{font-weight:500;color:#667eea;max-width:220px;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.om-td-price{font-weight:700;color:#1e293b;white-space:nowrap}.om-free-tag{background:#d1fae5;color:#065f46;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.om-pm-badge{font-size:.82rem;color:#475569}.om-td-date{font-size:.78rem;color:#64748b;white-space:nowrap}.om-detail-btn{padding:4px 10px;background:#eff6ff;color:#667eea;border:1px solid #dbeafe;border-radius:6px;font-size:.78rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.om-detail-btn:hover{background:#667eea;color:#fff;border-color:#667eea}.om-loadmore-wrap{text-align:center;padding:1.25rem}.om-loadmore-btn{padding:9px 24px;background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:.875rem;font-weight:600;box-shadow:0 2px 8px #667eea4d}.om-loadmore-btn:disabled{opacity:.6;cursor:default}.om-tab-nav{display:flex;align-items:flex-end;gap:0;padding:0 1.75rem;border-bottom:2px solid #e2e8f0;background:#fff;flex-shrink:0}.om-tab-btn{padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;color:#94a3b8;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.om-tab-btn:hover{color:#475569}.om-tab-btn.active{color:#667eea;border-bottom-color:#667eea}.om-tab-panel{display:flex;flex-direction:column;gap:1rem;width:100%}.om-tab-panel--2col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}.om-modal-overlay{position:fixed;inset:0;background:#00000085;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:hidden}.om-modal{background:#fff;border-radius:16px;width:100%;max-width:1200px;height:80vh;display:flex;flex-direction:column;box-shadow:0 24px 64px #00000038;animation:omFadeIn .18s ease;overflow:hidden}@keyframes omFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.om-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.75rem;border-bottom:1px solid #e2e8f0;flex-shrink:0;gap:1rem}.om-modal-header-left{display:flex;flex-direction:column;gap:5px;min-width:0}.om-modal-title{font-size:1.2rem;font-weight:700;color:#1e293b;margin:0;line-height:1.3}.om-modal-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.om-modal-orderId{font-family:monospace;font-size:.78rem;color:#94a3b8;background:#f1f5f9;padding:2px 8px;border-radius:5px}.om-modal-close{background:#f1f5f9;border:none;font-size:1.2rem;color:#475569;cursor:pointer;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.om-modal-close:hover{background:#e2e8f0;color:#1e293b}.om-modal-body{overflow-y:auto;padding:1.5rem 1.75rem;flex:1;min-height:0;display:flex;flex-direction:column;gap:0}.om-modal-body::-webkit-scrollbar{width:5px}.om-modal-body::-webkit-scrollbar-track{background:#f8fafc}.om-modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.om-detail-section{border:1px solid #e2e8f0;border-radius:10px;overflow:visible}.om-detail-section--refund{border-color:#fca5a5}.om-detail-section-title{font-size:.825rem;font-weight:700;color:#334155;text-transform:none;letter-spacing:0;margin:0;padding:9px 14px;background:#f1f5f9;border-bottom:1px solid #e2e8f0;border-radius:10px 10px 0 0}.om-detail-grid{display:block}.om-detail-row{display:grid;grid-template-columns:140px 1fr;padding:9px 14px;border-bottom:1px solid #e2e8f0;align-items:baseline;gap:.5rem}.om-detail-row:last-child{border-bottom:none}.om-detail-row--highlight{background:#f0f9ff}.om-detail-label{font-size:.8rem;color:#64748b;font-weight:600;white-space:nowrap}.om-detail-val{font-size:.875rem;color:#1e293b;word-break:break-word;line-height:1.5}.om-mono{font-family:monospace;font-size:.8rem;color:#475569}.om-price-final{font-size:1rem;font-weight:700;color:#667eea}.om-price-refund{font-size:1rem;font-weight:700;color:#dc2626}.om-link{color:#667eea;text-decoration:underline;font-size:.82rem}.om-hint{font-size:.75rem;color:#94a3b8;font-weight:400}.om-progress-wrap{display:flex;align-items:center;gap:8px}.om-progress-bar{flex:1;height:7px;background:#e2e8f0;border-radius:4px;overflow:hidden;max-width:140px}.om-progress-fill{height:100%;background:#10b981;border-radius:4px;transition:width .3s}.om-progress-pct{font-weight:700;font-size:.875rem;color:#1e293b;min-width:36px}.om-refund-policy-label{margin:10px 14px 12px;padding:9px 13px;border-radius:7px;font-size:.82rem;font-weight:600;border:1px solid;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.om-refund-policy-label.refundable{background:#f0fdf4;color:#15803d;border-color:#86efac}.om-refund-policy-label.no-refund{background:#fef2f2;color:#b91c1c;border-color:#fca5a5}.om-loading-small{padding:12px 14px;color:#94a3b8;font-size:.82rem}.om-empty-small{padding:10px 14px;color:#94a3b8;font-size:.82rem;margin:0}.om-action-bar{display:flex;gap:8px;padding:2px 0}.om-btn{padding:9px 20px;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s}.om-btn:disabled{opacity:.6;cursor:default}.om-btn-green{background:#dcfce7;color:#15803d;border:1px solid #86efac}.om-btn-red{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5}.om-btn-orange{background:#ffedd5;color:#c2410c;border:1px solid #fdba74}.om-btn-gray{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.om-modal-footer{display:flex;align-items:center;gap:8px;padding:1rem 1.75rem;border-top:1px solid #e2e8f0;background:#f8fafc;flex-shrink:0;border-radius:0 0 16px 16px}.om-refund-panel{background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:.9rem 1rem}.om-refund-panel-title{font-size:.9rem;font-weight:700;margin:0 0 .75rem;color:#92400e}.om-refund-policy-box{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.82rem;margin-bottom:1rem}.om-refund-amount{color:#667eea}.om-refund-form{display:flex;flex-direction:column;gap:.6rem}.om-form-label{font-size:.82rem;font-weight:600;color:#475569}.om-form-input{padding:8px 12px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.875rem;outline:none;color:#1e293b}.om-form-input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.om-form-textarea{padding:8px 12px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.875rem;resize:vertical;outline:none;color:#1e293b}.om-form-textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.om-force-label{display:flex;align-items:center;gap:8px;font-size:.82rem;color:#dc2626;font-weight:600;cursor:pointer}.om-refund-btns{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.om-tab-panel--2col .om-detail-section{align-self:start}.om-detail-section{transition:box-shadow .15s}.om-detail-section:hover{box-shadow:0 2px 8px #667eea14}.om-modal-header{background:#fff;border-radius:16px 16px 0 0}.om-modal-orderId{color:#94a3b8}@media(max-width:1300px){.om-modal{max-width:calc(100vw - 3rem)}}@media(max-width:768px){.om-stats-grid{grid-template-columns:repeat(2,1fr)}.om-table th:nth-child(5),.om-table td:nth-child(5){display:none}.om-table th:nth-child(7),.om-table td:nth-child(7){display:none}.om-detail-row{grid-template-columns:110px 1fr}.om-modal-overlay{padding:0;align-items:flex-end}.om-modal{border-radius:16px 16px 0 0;max-width:100%;height:92svh}.om-modal-body{padding:1rem}.om-tab-panel--2col{grid-template-columns:1fr}.om-tab-btn{padding:.65rem 1rem;font-size:.82rem}.om-modal-footer{border-radius:0}}.om-refund-modal-overlay{position:fixed;inset:0;background:#0000008c;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1.5rem}.om-refund-modal{background:#fff;border-radius:14px;width:100%;max-width:480px;display:flex;flex-direction:column;box-shadow:0 24px 64px #0000004d;animation:omFadeIn .15s ease;overflow:hidden}.om-refund-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.1rem 1.5rem;background:#fff;border-bottom:1px solid #fca5a5;flex-shrink:0}.om-refund-modal-title{font-size:1.05rem;font-weight:700;color:#dc2626;margin:0}.om-refund-modal-sub{font-size:.8rem;color:#94a3b8;display:block;margin-top:2px}.om-refund-modal-header .om-modal-close{color:#475569!important}.om-refund-modal-header .om-modal-close:hover{background:#e2e8f0!important;color:#1e293b!important}.om-refund-modal-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.85rem;overflow-y:auto;max-height:calc(100vh - 260px)}.om-refund-policy-box-v2{border-radius:8px;padding:.85rem 1rem;border:1px solid}.om-refund-policy-box-v2.refundable{background:#f0fdf4;border-color:#86efac}.om-refund-policy-box-v2.no-refund{background:#fef2f2;border-color:#fca5a5}.om-refund-policy-tag{font-size:.75rem;font-weight:700;letter-spacing:.03em;margin-bottom:3px}.om-refund-policy-box-v2.refundable .om-refund-policy-tag{color:#15803d}.om-refund-policy-box-v2.no-refund .om-refund-policy-tag{color:#dc2626}.om-refund-policy-desc{font-size:.82rem;color:#475569;line-height:1.45}.om-refund-policy-amount{font-size:.82rem;color:#475569;margin-top:4px}.om-refund-policy-amount strong{color:#667eea;font-size:.95rem}.om-refund-info-row{display:flex;align-items:baseline;gap:10px;font-size:.85rem;padding:5px 0;border-bottom:1px solid #e2e8f0}.om-refund-info-label{color:#64748b;font-weight:600;min-width:72px}.om-refund-info-val{color:#1e293b}.om-refund-field{display:flex;flex-direction:column;gap:5px}.om-refund-field-hint{font-size:.75rem;color:#94a3b8}.om-refund-confirm-row{display:flex;align-items:center;justify-content:space-between;background:#fef9c3;border:1px solid #fde047;border-radius:8px;padding:.75rem 1rem}.om-refund-confirm-label{font-size:.85rem;font-weight:600;color:#854d0e}.om-refund-confirm-amount{font-size:1.15rem;font-weight:800;color:#dc2626}.om-refund-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:1rem 1.5rem;border-top:1px solid #e2e8f0;flex-shrink:0;background:#f8fafc}.pa-wrap{display:flex;flex-direction:column;gap:1.25rem;padding:2rem;max-width:1400px}.pa-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.pa-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0}.pa-saved-at{font-size:.78rem;color:#9ca3af;display:block;margin-top:3px}.pa-header-actions{display:flex;gap:8px;align-items:center}.pa-btn{padding:8px 18px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:opacity .15s,background .15s;text-decoration:none;display:inline-flex;align-items:center}.pa-btn:disabled{opacity:.6;cursor:default}.pa-btn-primary{background:#667eea;color:#fff}.pa-btn-primary:hover{background:#4f46e5}.pa-btn-ghost{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.pa-btn-ghost:hover{background:#e5e7eb}.pa-btn-add{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.pa-btn-add:hover{background:#dbeafe}.pa-tabs{display:flex;gap:0;border-bottom:2px solid #e5e7eb}.pa-tab{padding:8px 20px;border:none;background:none;font-size:.875rem;font-weight:600;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.pa-tab:hover{color:#374151}.pa-tab.active{color:#667eea;border-bottom-color:#667eea}.pa-editor-wrap{display:flex;flex-direction:column;gap:6px}.pa-editor-hint{font-size:.78rem;color:#9ca3af;background:#f8fafc;padding:7px 12px;border-radius:6px;border:1px solid #e5e7eb}.pa-editor-hint code{background:#e0e7ff;color:#4338ca;padding:1px 5px;border-radius:4px;font-size:.78rem;margin:0 2px}.pa-textarea{width:100%;min-height:560px;padding:1rem 1.25rem;font-size:.875rem;font-family:Consolas,Monaco,monospace;line-height:1.7;border:1px solid #d1d5db;border-radius:8px;resize:vertical;outline:none;color:#1f2937;background:#fafafa;box-sizing:border-box}.pa-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26;background:#fff}.pa-editor-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.pa-char-count{font-size:.75rem;color:#9ca3af}.pa-note-row{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:flex-end}.pa-note-label{font-size:.78rem;font-weight:600;color:#6b7280;white-space:nowrap}.pa-note-input{width:320px;padding:.4rem .75rem;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.82rem;color:#374151;outline:none;transition:border-color .15s}.pa-version-badge{display:inline-block;padding:2px 8px;background:#eef2ff;color:#4338ca;border-radius:20px;font-size:.75rem;font-weight:700}.pa-btn-restore{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.pa-btn-restore:hover{background:#ffedd5}.ph-empty{padding:4rem;text-align:center;color:#9ca3af;font-size:.9rem}.ph-empty-sub{font-size:.8rem;margin-top:4px}.ph-layout{display:grid;grid-template-columns:260px 1fr;gap:1.5rem;align-items:start}.ph-list{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;position:sticky;top:1.5rem}.ph-list-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#f8fafc;border-bottom:1px solid #f1f5f9;font-size:.78rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.ph-refresh-btn{background:none;border:none;cursor:pointer;color:#9ca3af;font-size:1rem;padding:2px 6px;border-radius:4px;transition:color .12s}.ph-refresh-btn:hover{color:#374151}.ph-row{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem;border:none;border-bottom:1px solid #f1f5f9;background:#fff;cursor:pointer;text-align:left;transition:background .12s;gap:6px}.ph-row-left{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.ph-row-arrow{color:#d1d5db;font-size:1rem}.ph-detail{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;min-height:400px}.ph-detail-empty{display:flex;align-items:center;justify-content:center;height:300px;color:#9ca3af;font-size:.9rem}.ph-detail-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#f8fafc;border-bottom:1px solid #e5e7eb;gap:12px;flex-wrap:wrap}.ph-detail-body{padding:1.5rem 2rem}.ph-ver{display:inline-block;padding:2px 8px;background:#eef2ff;color:#4338ca;border-radius:20px;font-size:.75rem;font-weight:700}.ph-date{font-size:.8rem;color:#6b7280}.ph-note{font-size:.78rem;color:#9ca3af;background:#f3f4f6;padding:1px 6px;border-radius:4px}.ph-note-badge{font-size:.78rem;color:#92400e;background:#fef3c7;border:1px solid #fde68a;padding:2px 8px;border-radius:20px}.pa-preview-wrap{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:2rem;min-height:400px}.pa-loading{padding:3rem;text-align:center;color:#9ca3af;font-size:.9rem}.pa-faq-toolbar{display:flex;align-items:center;gap:12px}.pa-faq-count{font-size:.82rem;color:#6b7280}.pa-faq-empty{text-align:center;padding:3rem;color:#9ca3af;display:flex;flex-direction:column;align-items:center;gap:1rem}.pa-faq-list{display:flex;flex-direction:column;gap:1rem}.pa-faq-item{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1.25rem;display:flex;flex-direction:column;gap:10px}.pa-faq-item-header{display:flex;align-items:center;justify-content:space-between}.pa-faq-num{font-size:.78rem;font-weight:700;color:#667eea;background:#eef2ff;padding:2px 8px;border-radius:20px}.pa-faq-item-actions{display:flex;gap:4px}.pa-icon-btn{padding:4px 8px;border:1px solid #e5e7eb;border-radius:6px;background:#f9fafb;color:#6b7280;cursor:pointer;font-size:.75rem;transition:all .12s}.pa-icon-btn:hover{background:#e5e7eb;color:#374151}.pa-icon-btn--del{border-color:#fca5a5;color:#ef4444}.pa-icon-btn--del:hover{background:#fee2e2}.pa-faq-q{width:100%;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;font-weight:600;outline:none;box-sizing:border-box}.pa-faq-q:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26}.pa-faq-a{width:100%;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;line-height:1.6;resize:vertical;outline:none;box-sizing:border-box;font-family:inherit}.pa-faq-a:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26}.pa-header-meta{display:flex;align-items:center;gap:8px;margin-top:4px}.pa-version-badge{display:inline-block;background:#e0e7ff;color:#4338ca;font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:20px}.pa-editor-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-top:4px}.pa-note-row{display:flex;align-items:center;gap:8px;flex:1;min-width:280px}.pa-note-label{font-size:.78rem;font-weight:700;color:#6b7280;white-space:nowrap}.pa-note-input{flex:1;padding:5px 10px;border:1px solid #d1d5db;border-radius:7px;font-size:.82rem;color:#374151;outline:none;transition:border-color .15s}.pa-note-input:focus{border-color:#667eea}.pa-note-input::placeholder{color:#d1d5db}.pa-btn-restore{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.pa-btn-restore:hover{background:#fde68a}.ph-wrap{min-height:400px}.ph-empty{text-align:center;padding:4rem 2rem;color:#9ca3af;font-size:.9rem}.ph-empty-sub{font-size:.8rem;margin-top:6px;color:#d1d5db}.ph-layout{display:grid;grid-template-columns:260px 1fr;gap:1.25rem;align-items:start}.ph-list{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;position:sticky;top:1rem}.ph-list-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background:#f8fafc;border-bottom:1px solid #e5e7eb;font-size:.78rem;font-weight:700;color:#6b7280}.ph-refresh-btn{background:none;border:none;cursor:pointer;font-size:1rem;color:#9ca3af;transition:color .15s,transform .3s;padding:0 2px}.ph-refresh-btn:hover{color:#667eea;transform:rotate(180deg)}.ph-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem 1rem;background:none;border:none;border-bottom:1px solid #f1f5f9;cursor:pointer;text-align:left;transition:background .12s;gap:8px}.ph-row:last-child{border-bottom:none}.ph-row:hover{background:#f8fafc}.ph-row.active{background:#eff6ff;border-left:3px solid #667eea;padding-left:calc(1rem - 3px)}.ph-row-left{display:flex;align-items:center;gap:8px;min-width:0}.ph-row-info{display:flex;flex-direction:column;gap:2px;min-width:0}.ph-ver{font-size:.75rem;font-weight:700;color:#4f46e5;background:#e0e7ff;padding:1px 7px;border-radius:20px;white-space:nowrap;flex-shrink:0}.ph-date{font-size:.78rem;color:#6b7280}.ph-note{font-size:.75rem;color:#9ca3af;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ph-row-arrow{font-size:1rem;color:#d1d5db;flex-shrink:0}.ph-row.active .ph-row-arrow{color:#667eea}.ph-detail{border:1px solid #e5e7eb;border-radius:10px;min-height:400px;overflow:hidden}.ph-detail-empty{display:flex;align-items:center;justify-content:center;height:400px;color:#9ca3af;font-size:.9rem}.ph-detail-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:#f8fafc;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;gap:8px}.ph-detail-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ph-note-badge{font-size:.78rem;color:#6b7280;background:#f3f4f6;padding:2px 8px;border-radius:4px}.ph-detail-body{padding:1.5rem 2rem;max-height:600px;overflow-y:auto}.faq-admin-body{display:grid;grid-template-columns:240px 1fr;gap:1.5rem;align-items:start;margin-top:1.5rem}.faq-cat-panel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;position:sticky;top:1.5rem}.faq-cat-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border-bottom:1px solid #f1f5f9;background:#f8fafc}.faq-cat-panel-title{font-size:.8rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.pa-btn-sm{padding:.3rem .7rem!important;font-size:.78rem!important}.faq-cat-empty{padding:2rem 1rem;text-align:center;color:#9ca3af;font-size:.85rem}.faq-cat-empty p{margin-bottom:.75rem}.faq-cat-list{list-style:none;margin:0;padding:0}.faq-cat-item{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background .12s;gap:6px}.faq-cat-item:last-child{border-bottom:none}.faq-cat-item:hover{background:#f8fafc}.faq-cat-item.active{background:#eff6ff;border-left:3px solid #4f46e5;padding-left:calc(1rem - 3px)}.faq-cat-item-left{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.faq-cat-name{font-size:.875rem;font-weight:500;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.faq-cat-item.active .faq-cat-name{color:#4f46e5;font-weight:700}.faq-cat-unnamed{font-style:italic;color:#d1d5db;font-weight:400}.faq-cat-cnt{font-size:.75rem;color:#9ca3af}.faq-cat-item-actions{display:flex;gap:2px;opacity:0;transition:opacity .12s;flex-shrink:0}.faq-cat-item:hover .faq-cat-item-actions,.faq-cat-item.active .faq-cat-item-actions{opacity:1}.faq-item-panel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;min-height:400px}.faq-item-empty{display:flex;align-items:center;justify-content:center;height:300px;color:#9ca3af;font-size:.9rem;text-align:center}.faq-cat-name-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid #f1f5f9}.faq-cat-name-label{font-size:.8rem;font-weight:700;color:#374151;white-space:nowrap}.faq-cat-name-input{flex:1;padding:.5rem .875rem;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.9rem;color:#111827;outline:none;transition:border-color .15s}.faq-cat-name-input:focus{border-color:#4f46e5}.faq-cat-name-input::placeholder{color:#d1d5db}@media(max-width:900px){.faq-admin-body{grid-template-columns:1fr}.faq-cat-panel{position:static}.faq-cat-list{display:flex;overflow-x:auto;gap:0}.faq-cat-item{flex-direction:column;align-items:flex-start;min-width:130px;border-bottom:none;border-right:1px solid #f1f5f9}.faq-cat-item.active{border-left:none;border-bottom:3px solid #4f46e5;padding-left:1rem}.faq-cat-item-actions{opacity:1}}html{scrollbar-gutter:stable;overflow-y:scroll}.pp-root{min-height:100vh;background:#f8fafc;font-family:Pretendard,Apple SD Gothic Neo,sans-serif}.pp-hero{background:linear-gradient(135deg,#4f46e5,#667eea);padding:3rem 0 2.5rem;color:#fff}.pp-hero-inner{max-width:1200px;margin:0 auto;padding:0 2rem}.pp-back-home{display:inline-block;font-size:.85rem;color:#ffffffbf;text-decoration:none;margin-bottom:1rem;transition:color .15s}.pp-back-home:hover{color:#fff}.pp-hero-title{font-size:2rem;font-weight:800;margin:0 0 .5rem}.pp-hero-date{font-size:.85rem;color:#ffffffb3;margin:0}.pp-tab-nav{background:#fff;border-bottom:2px solid #e5e7eb;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px #0000000f;width:100%;box-sizing:border-box}.pp-tab-nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;gap:0}.pp-tab-link{display:inline-block;padding:1rem 1.5rem;font-size:.9rem;font-weight:500;color:#6b7280;text-decoration:none;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;white-space:nowrap;letter-spacing:0}.pp-tab-link:after{content:attr(data-text);display:block;font-weight:700;height:0;overflow:hidden;visibility:hidden;pointer-events:none}.pp-tab-link:hover{color:#4f46e5}.pp-tab-link.active{color:#4f46e5;font-weight:700;border-bottom-color:#4f46e5}.pp-body{max-width:1200px;margin:0 auto;padding:2.5rem 2rem 4rem}.pp-main{background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:2.5rem 3rem;min-height:400px}.policy-content{font-size:.95rem;line-height:1.85;color:#374151}.policy-content h1{font-size:1.5rem;font-weight:700;color:#111827;margin:2rem 0 .75rem}.policy-content h2{font-size:1.2rem;font-weight:700;color:#111827;margin:1.75rem 0 .6rem;padding-bottom:.4rem;border-bottom:1px solid #e5e7eb}.policy-content h3{font-size:1.05rem;font-weight:600;color:#1f2937;margin:1.25rem 0 .5rem}.policy-content p{margin:0 0 1rem}.policy-content ul,.policy-content ol{padding-left:1.5rem;margin:0 0 1rem}.policy-content li{margin-bottom:.4rem}.policy-content strong{color:#111827;font-weight:700}.policy-content a{color:#667eea;text-decoration:underline}.policy-content table{width:100%;border-collapse:collapse;font-size:.875rem;margin:1rem 0}.policy-content th,.policy-content td{border:1px solid #e5e7eb;padding:8px 12px;text-align:left}.policy-content th{background:#f8fafc;font-weight:600;color:#374151}.policy-content blockquote{border-left:3px solid #667eea;margin:1rem 0;padding:.75rem 1rem;background:#eff6ff;color:#1e3a8a;border-radius:0 6px 6px 0}.pp-faq-wrap{display:flex;flex-direction:column;gap:1.5rem}.pp-faq-cats{display:flex;flex-wrap:wrap;gap:.5rem;padding-bottom:1.25rem;border-bottom:1px solid #e5e7eb}.pp-faq-cat-btn{display:inline-flex;align-items:center;gap:6px;padding:.5rem 1.1rem;border-radius:999px;border:1.5px solid #e5e7eb;background:#fff;font-size:.875rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s}.pp-faq-cat-btn:hover{border-color:#a5b4fc;color:#4f46e5;background:#f5f3ff}.pp-faq-cat-btn.active{background:#4f46e5;border-color:#4f46e5;color:#fff;font-weight:700}.pp-faq-cat-count{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#ffffff4d;font-size:.75rem;font-weight:700}.pp-faq-cat-btn:not(.active) .pp-faq-cat-count{background:#f3f4f6;color:#6b7280}.pp-faq-list{display:flex;flex-direction:column;gap:.5rem}.pp-faq-item{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;transition:box-shadow .15s}.pp-faq-item.open{box-shadow:0 2px 8px #667eea1f;border-color:#c7d2fe}.pp-faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:none;border:none;cursor:pointer;text-align:left;transition:background .12s;gap:12px}.pp-faq-q:hover{background:#f8fafc}.pp-faq-item.open .pp-faq-q{background:#eff6ff}.pp-faq-q-text{font-size:.95rem;font-weight:600;color:#111827;flex:1}.pp-faq-arrow{font-size:.75rem;color:#9ca3af;flex-shrink:0;transition:transform .2s}.pp-faq-a{padding:1rem 1.25rem 1.25rem;font-size:.9rem;line-height:1.75;color:#374151;border-top:1px solid #e5e7eb;background:#fafafa}.pp-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:3rem;color:#9ca3af;font-size:.9rem}.pp-spinner{width:20px;height:20px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:ppSpin .7s linear infinite}@keyframes ppSpin{to{transform:rotate(360deg)}}.pp-not-found,.pp-empty{padding:3rem;text-align:center;color:#9ca3af;font-size:.9rem}@media(max-width:768px){.pp-hero-title{font-size:1.5rem}.pp-hero-inner{padding:0 1.25rem}.pp-tab-nav-inner{padding:0 1rem;overflow-x:auto}.pp-tab-link{padding:.875rem 1rem;font-size:.82rem}.pp-body{padding:1.25rem 1rem 3rem}.pp-main{padding:1.5rem}.pp-faq-cats{gap:.375rem}.pp-faq-cat-btn{padding:.4rem .875rem;font-size:.82rem}}.pp-history-wrap{margin-top:2.5rem;border-top:1px solid #e5e7eb;padding-top:1.5rem}.pp-history-toggle{display:inline-flex;align-items:center;gap:8px;padding:.6rem 1.1rem;background:#f8fafc;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.875rem;font-weight:600;color:#374151;cursor:pointer;transition:all .15s}.pp-history-toggle:hover{background:#f1f5f9;border-color:#cbd5e1}.pp-history-toggle-icon{font-size:1rem}.pp-history-cur-ver{padding:1px 7px;background:#eef2ff;color:#4338ca;border-radius:20px;font-size:.72rem;font-weight:700}.pp-history-toggle-arrow{font-size:.7rem;color:#9ca3af;margin-left:4px}.pp-history-body{margin-top:1rem;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fff}.pp-history-loading,.pp-history-empty{padding:2rem;text-align:center;color:#9ca3af;font-size:.875rem}.pp-history-list{padding:1.25rem}.pp-history-desc{font-size:.85rem;color:#6b7280;margin-bottom:1rem}.pp-history-row{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border:1px solid #f1f5f9;border-radius:8px;margin-bottom:.4rem;background:#fafafa;cursor:pointer;text-align:left;transition:background .12s,border-color .12s;gap:12px}.pp-history-row:hover{background:#f0f9ff;border-color:#bae6fd}.pp-history-row.latest{border-color:#c7d2fe;background:#eef2ff}.pp-hr-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.pp-hr-ver{display:inline-block;padding:2px 8px;background:#eef2ff;color:#4338ca;border-radius:20px;font-size:.72rem;font-weight:700;flex-shrink:0}.pp-hr-date{font-size:.85rem;color:#374151;font-weight:500}.pp-hr-badge{padding:2px 8px;background:#4f46e5;color:#fff;border-radius:20px;font-size:.72rem;font-weight:700}.pp-hr-arrow{font-size:.8rem;color:#6b7280}.pp-history-viewer{display:flex;flex-direction:column}.pp-history-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#f8fafc;border-bottom:1px solid #e5e7eb;gap:12px;flex-wrap:wrap}.pp-history-viewer-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pp-hv-ver{padding:2px 8px;background:#eef2ff;color:#4338ca;border-radius:20px;font-size:.75rem;font-weight:700}.pp-hv-date{font-size:.85rem;color:#6b7280}.pp-hv-note{font-size:.78rem;color:#92400e;background:#fef3c7;border:1px solid #fde68a;padding:2px 8px;border-radius:20px}.pp-history-back-btn{padding:.4rem .875rem;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.82rem;font-weight:600;color:#374151;cursor:pointer;transition:all .12s}.pp-history-back-btn:hover{background:#f3f4f6;border-color:#d1d5db}.pp-history-wrap{margin-top:3rem;border-top:1px solid #e5e7eb;padding-top:1rem}.pp-history-toggle{display:flex;align-items:center;gap:8px;width:100%;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem 1.1rem;font-size:.875rem;color:#6b7280;cursor:pointer;text-align:left;transition:background .12s,border-color .12s}.pp-history-toggle:hover{background:#f1f5f9;border-color:#c7d2fe;color:#374151}.pp-history-cur-ver{font-size:.75rem;font-weight:700;color:#4f46e5;background:#e0e7ff;padding:1px 7px;border-radius:20px}.pp-history-toggle-arrow{margin-left:auto;font-size:.7rem;color:#9ca3af}.pp-history-body{margin-top:.75rem;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.pp-history-loading,.pp-history-empty{padding:1.5rem;text-align:center;color:#9ca3af;font-size:.875rem}.pp-history-desc{padding:.875rem 1.25rem;font-size:.82rem;color:#6b7280;background:#f8fafc;border-bottom:1px solid #e5e7eb;margin:0}.pp-history-desc strong{color:#374151}.pp-history-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.875rem 1.25rem;border:none;border-bottom:1px solid #f1f5f9;background:#fff;cursor:pointer;text-align:left;transition:background .12s;gap:12px}.pp-history-row:last-child{border-bottom:none}.pp-history-row:hover{background:#f8fafc}.pp-history-row.latest{background:#fafff4}.pp-history-row.latest:hover{background:#f0fdf4}.pp-hr-left{display:flex;align-items:center;gap:10px}.pp-hr-ver{font-size:.75rem;font-weight:700;color:#4f46e5;background:#e0e7ff;padding:2px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}.pp-hr-info{display:flex;flex-direction:column;gap:2px}.pp-hr-date{font-size:.82rem;color:#374151;font-weight:500}.pp-hr-note{font-size:.78rem;color:#9ca3af}.pp-hr-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.pp-hr-badge{font-size:.72rem;font-weight:700;color:#16a34a;background:#dcfce7;padding:2px 8px;border-radius:20px}.pp-hr-arrow{font-size:.82rem;color:#9ca3af}.pp-history-row:hover .pp-hr-arrow{color:#4f46e5}.pp-history-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:#f8fafc;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;gap:8px}.pp-hv-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pp-hv-ver{font-size:.78rem;font-weight:700;color:#4f46e5;background:#e0e7ff;padding:2px 8px;border-radius:20px}.pp-hv-date{font-size:.85rem;color:#374151}.pp-hv-note{font-size:.78rem;color:#6b7280;background:#f3f4f6;padding:2px 8px;border-radius:4px}.pp-history-back-btn{background:none;border:1px solid #e5e7eb;border-radius:6px;padding:4px 12px;font-size:.82rem;color:#6b7280;cursor:pointer;transition:all .12s}.pp-history-back-btn:hover{background:#f3f4f6;color:#374151}.pp-history-viewer-content{padding:2rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.ca-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s,box-shadow .15s;white-space:nowrap;font-family:inherit}.ca-btn:hover:not(:disabled){opacity:.88}.ca-btn:active:not(:disabled){transform:scale(.97)}.ca-btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.ca-btn-sm{padding:.35rem .75rem;font-size:.8rem;border-radius:7px}.ca-btn-primary{background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;box-shadow:0 2px 8px #667eea59}.ca-btn-success{background:linear-gradient(135deg,#059669,#047857);color:#fff;box-shadow:0 2px 8px #0596694d}.ca-btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef44444d}.ca-btn-ghost{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.ca-btn-ghost:hover:not(:disabled){background:#e2e8f0;opacity:1}.ca-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;overflow-x:auto}.ca-table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:700px}.ca-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0}.ca-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.ca-table td{padding:.8rem 1rem;color:#374151;border-bottom:1px solid #f1f5f9;vertical-align:middle}.ca-table tbody tr:last-child td{border-bottom:none}.ca-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.22rem .65rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.ca-badge-active{background:#dcfce7;color:#14532d}.ca-badge-inactive{background:#fee2e2;color:#991b1b}.ca-badge-unlimited{background:#dbeafe;color:#1e40af}.ca-badge-none{background:#fef3c7;color:#92400e}.ca-badge-limited{background:#e0e7ff;color:#3730a3}.ca-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;animation:ca-fadein .18s ease}@keyframes ca-fadein{0%{opacity:0}to{opacity:1}}.ca-modal{background:#fff;border-radius:16px;width:100%;max-width:580px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003;animation:ca-slideup .2s ease}@keyframes ca-slideup{0%{transform:translateY(20px);opacity:.6}to{transform:translateY(0);opacity:1}}.ca-modal-footer{display:flex;justify-content:flex-end;gap:.6rem;padding:1.25rem 1.5rem;border-top:1px solid #f1f5f9}.ca-field{display:flex;flex-direction:column;gap:.35rem}.ca-label{font-size:.8rem;font-weight:600;color:#64748b}.ca-input,.ca-select,.ca-textarea{padding:.5rem .85rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#1e293b;background:#f8fafc;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.ca-input:focus,.ca-select:focus,.ca-textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff;background:#fff}.ca-input::placeholder,.ca-textarea::placeholder{color:#94a3b8}.ca-textarea{resize:vertical;min-height:80px;line-height:1.5}.ca-retry-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.5rem 0 .25rem}.ca-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:3rem;color:#94a3b8;font-size:.95rem;text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.ca-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:3rem;color:#64748b;font-size:.95rem}.cpa-wrap{max-width:1400px;margin:0 auto;padding:2rem;font-family:Pretendard,Noto Sans KR,sans-serif}.cpa-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.cpa-header-left{display:flex;flex-direction:column;gap:.25rem}.cpa-title{font-size:1.55rem;font-weight:700;color:#1e293b;margin:0 0 .3rem}.cpa-subtitle{font-size:.88rem;color:#64748b;margin:0}.cpa-subtitle strong{color:#1e293b}.cpa-tr-clickable{cursor:pointer;transition:background .12s}.cpa-tr-clickable:hover td{background:#f8fafc!important}.cpa-td-title{display:flex;align-items:center;gap:.75rem;min-width:200px}.cpa-thumb{width:48px;height:48px;border-radius:8px;object-fit:cover;flex-shrink:0;border:1px solid #e2e8f0}.cpa-td-desc{font-size:.78rem;color:#94a3b8;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.cpa-td-price{display:flex;flex-direction:column;gap:2px}.cpa-price-ori{font-size:.78rem;color:#94a3b8;text-decoration:line-through}.cpa-price-cur{font-size:.9rem;font-weight:700;color:#667eea}.cpa-status-toggle{display:inline-flex;align-items:center;gap:.3rem;padding:.22rem .65rem;border-radius:20px;font-size:.75rem;font-weight:600;border:none;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.cpa-status-toggle:hover{opacity:.82}.cpa-status-toggle:active{transform:scale(.97)}.cpa-status-toggle.active{background:#dcfce7;color:#14532d}.cpa-status-toggle.inactive{background:#fee2e2;color:#991b1b}.cpa-td-actions{display:flex;gap:.4rem;flex-wrap:nowrap;white-space:nowrap}.cpa-btn-copy{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe;font-size:.8rem;white-space:nowrap;min-width:70px;display:inline-flex;align-items:center;justify-content:center;gap:4px}.cpa-btn-copy:hover:not(:disabled){background:#dbeafe;border-color:#93c5fd;opacity:1}.cpa-btn-copy:disabled{opacity:.45;cursor:not-allowed}.cpa-copy-spinner{display:inline-block;width:14px;height:14px;border:2px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:cpa-spin .8s linear infinite;flex-shrink:0}@keyframes cpa-spin{to{transform:rotate(360deg)}}.cpa-modal{padding:0;width:min(1200px,95vw);max-width:95vw;height:80vh;max-height:80vh;display:flex;flex-direction:column}.cpa-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 1rem;border-bottom:1px solid #f0f0f0;background:#fff;flex-shrink:0}.cpa-modal-title{font-size:1.1rem;font-weight:800;color:#1e293b}.cpa-modal-close{background:none;border:none;font-size:1.1rem;color:#9ca3af;cursor:pointer;padding:.2rem .4rem;border-radius:6px;line-height:1;transition:background .12s,color .12s;flex-shrink:0}.cpa-modal-close:hover{background:#f3f4f6;color:#374151}.cpa-modal-body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1.1rem;flex:1;overflow-y:auto}.cpa-field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.cpa-required{color:#ef4444;margin-left:2px}.cpa-thumb-preview{width:100%;max-height:140px;object-fit:cover;border-radius:8px;border:1px solid #e2e8f0;margin-top:4px}.cpa-radio-label{display:flex;align-items:center;gap:6px;font-size:.875rem;color:#374151;cursor:pointer;padding:.4rem .75rem;border-radius:8px;border:1px solid #e2e8f0;transition:border-color .15s,background .15s}.cpa-radio-label:has(input:checked){border-color:#667eea;background:#eff6ff;color:#667eea}.cpa-radio-label input{accent-color:#667eea;cursor:pointer}.cpa-retry-count{display:flex;align-items:center;gap:6px;font-size:.875rem;color:#374151}.cpa-field-hint{font-size:.78rem;color:#64748b;padding:.4rem .75rem;border-radius:6px;background:#f8fafc;border-left:3px solid #667eea;margin-top:2px;line-height:1.5}@media(max-width:768px){.cpa-wrap{padding:1rem .75rem 2rem}.cpa-field-row{grid-template-columns:1fr}.cpa-header{flex-direction:column}.cpa-td-title{flex-direction:column;align-items:flex-start}.cpa-td-actions{flex-wrap:wrap}.ca-btn{justify-content:center}}@media(max-width:480px){.ca-modal{border-radius:12px}.cpa-modal-body{padding:1rem}.cpa-modal-header{padding:1rem 1rem .75rem}.ca-modal-footer{padding:.875rem 1rem}}.crp-wrap{max-width:1400px;margin:0 auto;padding:2rem}.crp-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.crp-title{font-size:1.55rem;font-weight:700;color:#1e293b;margin:0}.crp-header-sub{font-size:.9rem;color:#64748b;background:#f1f5f9;padding:.25rem .75rem;border-radius:20px}.crp-back-btn{padding:.4rem .9rem;border:1px solid #cbd5e1;border-radius:8px;background:#fff;font-size:.875rem;cursor:pointer;color:#475569;transition:background .15s}.crp-back-btn:hover{background:#f8fafc}.crp-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:.9rem 1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.crp-select{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;background:#f8fafc;min-width:220px;cursor:pointer}.crp-select--sm{min-width:150px}.crp-search{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;flex:1;min-width:180px}.crp-search:focus,.crp-select:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.crp-pass-badge{margin-left:auto;font-size:.83rem;color:#475569;background:#f1f5f9;padding:.3rem .75rem;border-radius:20px;border:1px solid #e2e8f0}.crp-state-msg{padding:2.5rem;text-align:center;color:#64748b;font-size:.95rem}.crp-state-msg--empty{color:#94a3b8}.crp-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.crp-table{width:100%;border-collapse:collapse;font-size:.88rem}.crp-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0}.crp-table th{padding:.7rem 1rem;text-align:left;font-size:.78rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.crp-tr{border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .12s;border-left:3px solid transparent}.crp-tr:hover{background:#f8fafc}.crp-tr--pass{border-left-color:#22c55e}.crp-tr--fail{border-left-color:#ef4444}.crp-tr--pend{border-left-color:#f59e0b}.crp-table td{padding:.75rem 1rem;color:#374151;vertical-align:middle}.crp-attempt-no{display:inline-block;background:#eff6ff;color:#1d4ed8;font-size:.8rem;font-weight:700;padding:.15rem .55rem;border-radius:12px}.crp-td-user{display:flex;flex-direction:column;gap:2px}.crp-td-user strong{font-size:.88rem;color:#1e293b}.crp-td-email{font-size:.75rem;color:#94a3b8}.crp-td-date,.crp-td-time{font-size:.82rem;color:#64748b;white-space:nowrap}.crp-td-score{font-weight:600}.crp-score-val{font-size:.9rem}.crp-score-val--pass{color:#15803d}.crp-score-val--fail{color:#b91c1c}.crp-badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.crp-badge--pass{background:#dcfce7;color:#15803d}.crp-badge--fail{background:#fee2e2;color:#b91c1c}.crp-badge--pend{background:#fef9c3;color:#854d0e}.crp-badge--ing{background:#dbeafe;color:#1d4ed8}.crp-btn-detail{padding:.3rem .75rem;border:1px solid #93c5fd;border-radius:7px;background:#eff6ff;color:#2563eb;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .12s}.crp-btn-detail:hover{background:#dbeafe}.crp-detail-wrap{display:flex;flex-direction:column;gap:1rem}.crp-info-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem}.crp-info-grid{display:flex;flex-wrap:wrap;gap:.5rem 2rem}.crp-info-item{display:flex;flex-direction:column;gap:3px;min-width:110px}.crp-info-lbl{font-size:.72rem;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.crp-info-val{font-size:.88rem;color:#1e293b;font-weight:500}.crp-info-val--no{color:#2563eb;font-weight:700}.crp-info-val--score-pass{color:#15803d;font-weight:700;font-size:1rem}.crp-info-val--score-fail{color:#b91c1c;font-weight:700;font-size:1rem}.crp-ans-summary{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.6rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:.84rem}.crp-sum-item{padding:.2rem .65rem;border-radius:20px;font-weight:600;font-size:.8rem}.crp-sum-ok{background:#dcfce7;color:#15803d}.crp-sum-ng{background:#fee2e2;color:#b91c1c}.crp-sum-emp{background:#f1f5f9;color:#64748b}.crp-sum-essay{background:#ede9fe;color:#6d28d9}.crp-sum-total{margin-left:auto;font-size:.82rem;color:#64748b}.crp-ans-list{display:flex;flex-direction:column;gap:.75rem}.crp-ans-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:1rem 1.25rem;border-left:4px solid #e2e8f0}.crp-ans-card--ok{border-left-color:#22c55e;background:#f0fdf4}.crp-ans-card--ng{border-left-color:#ef4444;background:#fff5f5}.crp-ans-card--empty{border-left-color:#e2e8f0;background:#fafafa}.crp-ans-card--essay{border-left-color:#8b5cf6;background:#faf5ff}.crp-ans-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem;flex-wrap:wrap}.crp-ans-no{width:26px;height:26px;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:#475569;flex-shrink:0}.crp-ans-subject{font-size:.75rem;color:#64748b;background:#f1f5f9;padding:.15rem .5rem;border-radius:10px}.crp-ans-badge{padding:.2rem .55rem;border-radius:20px;font-size:.75rem;font-weight:600}.crp-ans-badge--ok{background:#dcfce7;color:#15803d}.crp-ans-badge--ng{background:#fee2e2;color:#b91c1c}.crp-ans-badge--empty{background:#f1f5f9;color:#64748b}.crp-ans-badge--essay{background:#ede9fe;color:#6d28d9}.crp-ans-pts{margin-left:auto;font-size:.8rem;color:#64748b}.crp-essay-tag{font-size:.75rem;background:#ede9fe;color:#6d28d9;padding:.15rem .55rem;border-radius:12px}.crp-ans-qtext{font-size:.92rem;color:#1e293b;line-height:1.6;margin:0 0 .75rem}.crp-ans-cols{display:flex;gap:.75rem;flex-wrap:wrap}.crp-ans-col{flex:1;min-width:160px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.55rem .75rem}.crp-ans-col--correct{background:#eff6ff;border-color:#bfdbfe}.crp-ans-col--user.crp-ans-col--ok{background:#f0fdf4;border-color:#86efac}.crp-ans-col--user.crp-ans-col--ng{background:#fff5f5;border-color:#fca5a5}.crp-ans-col--score{flex:0 0 160px}.crp-ans-col-lbl{display:block;font-size:.7rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}.crp-ans-col--correct .crp-ans-col-lbl{color:#2563eb}.crp-ans-col-val{font-size:.88rem;color:#1e293b;line-height:1.5}.crp-ans-display{display:inline-flex;align-items:center;gap:.35rem}.crp-ans-circle{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:.82rem;font-weight:700;flex-shrink:0}.crp-ans-display--correct .crp-ans-circle{background:#2563eb;color:#fff}.crp-ans-display--ok .crp-ans-circle{background:#22c55e;color:#fff}.crp-ans-display--ng .crp-ans-circle{background:#ef4444;color:#fff}.crp-ans-display--empty .crp-ans-circle,.crp-ans-display--essay .crp-ans-circle{background:#cbd5e1;color:#475569}.crp-ans-display--correct .crp-ans-text{color:#1d4ed8;font-weight:600}.crp-ans-display--ok .crp-ans-text{color:#15803d;font-weight:600}.crp-ans-display--ng .crp-ans-text{color:#b91c1c;font-weight:600}.crp-ans-text{font-size:.88rem}.crp-muted{color:#94a3b8;font-style:italic;font-size:.85rem}.crp-score-row{display:flex;align-items:center;gap:.4rem;margin-top:.25rem}.crp-score-input{width:68px;padding:.35rem .5rem;border:1px solid #8b5cf6;border-radius:6px;font-size:.9rem;text-align:center}.crp-score-input:focus{outline:none;border-color:#6d28d9;box-shadow:0 0 0 2px #ede9fe}.crp-score-max{font-size:.8rem;color:#64748b}.crp-save-bar{display:flex;align-items:center;justify-content:flex-end;gap:1rem;padding:.75rem 0}.crp-save-msg{font-size:.88rem}.crp-save-msg--ok{color:#15803d}.crp-save-msg--err{color:#b91c1c}.crp-btn{padding:.5rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s;border:none}.crp-btn--primary{background:#2563eb;color:#fff}.crp-btn--primary:hover:not(:disabled){background:#1d4ed8}.crp-btn--primary:disabled{opacity:.5;cursor:not-allowed}.crp-btn--ghost{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.crp-btn--ghost:hover{background:#e2e8f0}@media(max-width:768px){.crp-toolbar{flex-direction:column;align-items:stretch}.crp-select,.crp-search{min-width:0;width:100%}.crp-pass-badge{margin-left:0}.crp-table{font-size:.8rem}.crp-table th,.crp-table td{padding:.5rem .65rem}.crp-info-grid{gap:.75rem 1.5rem}.crp-ans-cols{flex-direction:column}.crp-ans-col--score{flex:1}}.crp-filter-btn{cursor:pointer;border:2px solid transparent;transition:all .15s;-webkit-user-select:none;user-select:none;background:inherit;font-family:inherit;line-height:1}.crp-filter-btn:hover{filter:brightness(.93);transform:translateY(-1px);box-shadow:0 2px 6px #0000001a}.crp-filter-btn--active{filter:brightness(.88);box-shadow:0 0 0 2px currentColor;transform:translateY(-1px)}.crp-sum-ok.crp-filter-btn--active{box-shadow:0 0 0 2px #15803d}.crp-sum-ng.crp-filter-btn--active{box-shadow:0 0 0 2px #b91c1c}.crp-sum-emp.crp-filter-btn--active{box-shadow:0 0 0 2px #64748b}.crp-sum-essay.crp-filter-btn--active{box-shadow:0 0 0 2px #6d28d9}.crp-filter-clear{margin-left:.25rem;padding:.18rem .6rem;border:1px solid #e2e8f0;border-radius:20px;background:#fff;font-size:.75rem;color:#64748b;cursor:pointer;transition:background .12s;font-family:inherit}.crp-filter-clear:hover{background:#f1f5f9;color:#1e293b}.crp-filter-notice{padding:.35rem .9rem;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;font-size:.8rem;color:#92400e;font-weight:600}.crp-score-breakdown{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.crp-sbd-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding:1rem 1.25rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.crp-sbd-title{font-size:.9rem;font-weight:700;color:#475569;letter-spacing:.02em}.crp-sbd-overall{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.crp-sbd-overall-left{display:flex;flex-direction:column;align-items:center;gap:2px}.crp-sbd-pct{font-size:2rem;font-weight:800;line-height:1}.crp-sbd-pct--pass{color:#15803d}.crp-sbd-pct--fail{color:#b91c1c}.crp-sbd-pct-label{font-size:.7rem;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.crp-sbd-overall-right{display:flex;flex-direction:column;gap:.35rem}.crp-sbd-raw-row{display:flex;align-items:baseline;gap:.3rem;font-size:.88rem}.crp-sbd-raw-label{color:#94a3b8;font-size:.75rem}.crp-sbd-raw-val{font-weight:700;color:#1e293b;font-size:1rem}.crp-sbd-raw-sep{color:#94a3b8}.crp-sbd-raw-total{color:#64748b}.crp-sbd-pass-row{display:flex;align-items:center;gap:.5rem;font-size:.8rem}.crp-sbd-pass-label{color:#64748b}.crp-sbd-table-wrap{overflow-x:auto}.crp-sbd-table{width:100%;border-collapse:collapse;font-size:.86rem}.crp-sbd-th{padding:.6rem 1rem;text-align:center;font-size:.75rem;font-weight:600;color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0;white-space:nowrap}.crp-sbd-th--subject{text-align:left;min-width:180px}.crp-sbd-th--num{width:56px}.crp-sbd-th--score,.crp-sbd-th--pct{width:80px}.crp-sbd-row{border-bottom:1px solid #f1f5f9;transition:background .1s}.crp-sbd-row:hover{background:#f8fafc}.crp-sbd-row td,.crp-sbd-foot td{padding:.6rem 1rem;vertical-align:middle}.crp-sbd-td-subject{font-size:.88rem;color:#1e293b;font-weight:500}.crp-sbd-td-ok{text-align:center;color:#15803d;font-weight:600}.crp-sbd-td-ng{text-align:center;color:#b91c1c;font-weight:600}.crp-sbd-td-emp{text-align:center;color:#94a3b8}.crp-sbd-td-essay{text-align:center;color:#6d28d9}.crp-sbd-td-earned{text-align:center;font-weight:600;color:#1e293b}.crp-sbd-td-total{text-align:center;color:#64748b}.crp-sbd-td-pct{text-align:center;font-weight:700}.crp-sbd-pct-ok{color:#15803d}.crp-sbd-pct-ng{color:#b91c1c}.crp-sbd-pct-bold{font-size:.95rem}.crp-sbd-foot{background:#f1f5f9;border-top:2px solid #e2e8f0}.crp-sbd-foot td{font-size:.88rem}.crp-sbd-foot .crp-sbd-td-subject{color:#334155}.crp-subject-group{display:flex;flex-direction:column;gap:.6rem}.crp-subject-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:.6rem 1rem;background:#f1f5f9;border-radius:8px;border-left:4px solid #94a3b8;margin-top:.5rem}.crp-subject-name{font-size:.9rem;font-weight:700;color:#334155}.crp-subject-meta{display:flex;align-items:center;gap:.4rem;font-size:.8rem}.crp-subj-ok{color:#15803d;font-weight:600}.crp-subj-ng{color:#b91c1c;font-weight:600}.crp-subj-sep{color:#cbd5e1}.crp-subj-score{color:#475569;font-weight:600;background:#e2e8f0;padding:.1rem .5rem;border-radius:10px}@media(max-width:768px){.crp-sbd-header{flex-direction:column;align-items:flex-start}.crp-sbd-overall{flex-direction:column;align-items:flex-start;gap:.75rem}.crp-sbd-pct{font-size:1.6rem}.crp-subject-header{flex-direction:column;align-items:flex-start}}.crp-td-cs{white-space:nowrap}.crp-cs-btns{display:flex;flex-direction:column;gap:4px}.crp-btn--cs-reset,.crp-btn--cs-confirm,.crp-btn--cs-delete{display:inline-flex;align-items:center;justify-content:center;height:30px;padding:0 12px;border-radius:6px;font-size:.78rem;font-weight:600;line-height:1;border:1.5px solid transparent;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap;box-sizing:border-box}.crp-btn--cs-reset:hover,.crp-btn--cs-confirm:hover,.crp-btn--cs-delete:hover{opacity:.82;transform:translateY(-1px)}.crp-btn--cs-reset:active,.crp-btn--cs-confirm:active,.crp-btn--cs-delete:active{opacity:.65;transform:translateY(0)}.crp-btn--cs-reset{background:#fff7ed;color:#c2410c;border-color:#fdba74}.crp-btn--cs-confirm{background:#f0fdf4;color:#15803d;border-color:#86efac}.crp-btn--lg{padding:8px 18px;font-size:.9rem;border-radius:8px;flex-shrink:0}.crp-cs-panel{background:#fffbeb;border:1.5px solid #fcd34d;border-radius:12px;padding:20px 24px;margin-bottom:20px}.crp-cs-panel-title{font-size:1rem;font-weight:700;color:#92400e;margin-bottom:8px}.crp-cs-panel-desc{font-size:.88rem;color:#78350f;margin-bottom:16px;line-height:1.6}.crp-cs-panel-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:680px){.crp-cs-panel-actions{grid-template-columns:1fr}}.crp-cs-action-box{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:10px;border:1.5px solid transparent}.crp-cs-action-box--reset{background:#fff7ed;border-color:#fdba74}.crp-cs-action-box--confirm{background:#f0fdf4;border-color:#86efac}.crp-cs-action-icon{font-size:1.8rem;flex-shrink:0}.crp-cs-action-info{flex:1;display:flex;flex-direction:column;gap:4px}.crp-cs-action-info strong{font-size:.92rem;color:#1e293b}.crp-cs-action-info span{font-size:.8rem;color:#64748b;line-height:1.5}.crp-btn--cs-delete{background:#fff1f2;color:#be123c;border-color:#fda4af}.crp-cs-action-box--delete{background:#fff1f2;border-color:#fda4af}.crp-action-row{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.crp-action-row .crp-btn,.crp-action-row .crp-btn-detail{flex-shrink:0}.crp-action-row .crp-btn-detail{height:30px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;line-height:1}.crp-pagination{display:flex;align-items:center;flex-wrap:wrap;gap:4px;padding:16px 4px 8px;justify-content:center}.crp-page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;border-radius:7px;border:1.5px solid #e2e8f0;background:#fff;color:#374151;font-size:.82rem;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s,color .12s;white-space:nowrap}.crp-page-btn:hover:not(:disabled){background:#f1f5f9;border-color:#94a3b8}.crp-page-btn:disabled{opacity:.38;cursor:default}.crp-page-btn--active{background:#2563eb;border-color:#2563eb;color:#fff;font-weight:700}.crp-page-btn--active:hover{background:#1d4ed8;border-color:#1d4ed8}.crp-page-ellipsis{min-width:24px;text-align:center;color:#94a3b8;font-size:.82rem;line-height:34px}.crp-page-info{font-size:.8rem;color:#64748b;margin-left:6px;white-space:nowrap}.crp-page-info--simple{text-align:right;padding:10px 4px 4px;font-size:.8rem;color:#94a3b8}.cia-wrap{max-width:1400px;margin:0 auto;padding:2rem}.cia-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.cia-title{font-size:1.55rem;font-weight:700;color:#1e293b;margin:0 0 .3rem}.cia-sub{font-size:.88rem;color:#64748b;margin:0}.cia-sub strong{color:#1e293b}.cia-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:3rem;color:#64748b;font-size:.95rem}.cia-spinner{width:28px;height:28px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:cia-spin .8s linear infinite}@keyframes cia-spin{to{transform:rotate(360deg)}}.cia-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding:.9rem 1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.cia-tabs{display:flex;flex-wrap:wrap;gap:.4rem}.cia-tab{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;border:1px solid #e2e8f0;border-radius:20px;background:#f8fafc;color:#475569;font-size:.83rem;font-weight:500;cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.cia-tab:hover{background:#f1f5f9;color:#1e293b}.cia-tab--active{background:#667eea;color:#fff;border-color:#667eea;font-weight:700}.cia-tab-cnt{background:#e2e8f0;color:#64748b;font-size:.75rem;font-weight:700;padding:.05rem .45rem;border-radius:10px;min-width:20px;text-align:center}.cia-tab-cnt--active{background:#ffffff40;color:#fff}.cia-search{flex:1;min-width:200px;padding:.5rem .85rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.88rem;background:#f8fafc;transition:border-color .15s,box-shadow .15s}.cia-search:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.cia-search::placeholder{color:#94a3b8}.cia-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:3rem;color:#94a3b8;font-size:.95rem;text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.cia-empty-icon{font-size:2.5rem}.cia-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;overflow-x:auto}.cia-table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:800px}.cia-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0}.cia-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.cia-tr{border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .12s;border-left:3px solid transparent}.cia-tr:hover{background:#f8fafc}.cia-tr--pending{border-left-color:#f59e0b}.cia-tr--approved{border-left-color:#3b82f6}.cia-tr--shipped{border-left-color:#8b5cf6}.cia-tr--delivered{border-left-color:#22c55e}.cia-tr--rejected{border-left-color:#ef4444;opacity:.75}.cia-table td{padding:.8rem 1rem;color:#374151;vertical-align:middle}.cia-td-user{display:flex;flex-direction:column;gap:2px}.cia-td-user strong{font-size:.88rem;color:#1e293b;font-weight:600}.cia-td-phone{font-size:.75rem;color:#94a3b8}.cia-td-cert{font-size:.88rem;color:#1e293b}.cia-td-date{font-size:.82rem;color:#64748b;white-space:nowrap}.cia-score-val{font-size:.95rem;font-weight:700}.cia-muted{color:#94a3b8;font-size:.82rem}.cia-tracking-cell{display:flex;flex-direction:column;gap:3px}.cia-tracking-no{font-family:monospace;font-size:.8rem;color:#1e293b;font-weight:600}.cia-carrier-tag{font-size:.72rem;color:#6b7280}.cia-track-btn{display:inline-block;padding:.15rem .5rem;background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe;border-radius:6px;font-size:.72rem;font-weight:600;text-decoration:none;transition:background .12s;width:fit-content}.cia-track-btn:hover{background:#dbeafe}.cia-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.22rem .65rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.cia-badge--pending{background:#fef3c7;color:#92400e}.cia-badge--approved{background:#dbeafe;color:#1e40af}.cia-badge--rejected{background:#fee2e2;color:#991b1b}.cia-badge--ready{background:#e0e7ff;color:#3730a3}.cia-badge--shipped{background:#ede9fe;color:#5b21b6}.cia-badge--delivered{background:#dcfce7;color:#14532d}.cia-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s,box-shadow .15s;white-space:nowrap}.cia-btn:hover{opacity:.88}.cia-btn:active{transform:scale(.97)}.cia-btn:disabled{opacity:.45;cursor:default;pointer-events:none}.cia-btn-sm{padding:.35rem .75rem;font-size:.8rem;border-radius:7px}.cia-btn-ghost{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.cia-btn-ghost:hover{background:#e2e8f0}.cia-btn-approve{background:linear-gradient(135deg,#059669,#047857);color:#fff;box-shadow:0 2px 8px #0596694d}.cia-btn-reject{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef44444d}.cia-btn-ship{background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;box-shadow:0 2px 8px #7c3aed4d}.cia-btn-deliver{background:linear-gradient(135deg,#0891b2,#0e7490);color:#fff;box-shadow:0 2px 8px #0891b24d}.cia-btn-detail{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.cia-btn-detail:hover{background:#dbeafe}.cia-overlay{position:fixed;inset:0;background:#00000080;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;animation:cia-fadein .18s ease}@keyframes cia-fadein{0%{opacity:0}to{opacity:1}}.cia-modal{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;animation:cia-slideup .2s ease}@keyframes cia-slideup{0%{transform:translateY(20px);opacity:.6}to{transform:translateY(0);opacity:1}}.cia-modal-hd{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.5rem 1rem;border-bottom:1px solid #f0f0f0;background:#fff;border-radius:16px 16px 0 0;flex-shrink:0}.cia-modal-title{font-size:1.15rem;font-weight:800;color:#1e293b;margin:0 0 .2rem}.cia-modal-sub{font-size:.85rem;color:#64748b;margin:0}.cia-modal-close{background:none;border:none;font-size:1.2rem;color:#9ca3af;cursor:pointer;padding:.2rem .4rem;border-radius:6px;line-height:1;transition:background .12s,color .12s;flex-shrink:0}.cia-modal-close:hover{background:#f3f4f6;color:#374151}.cia-modal-body{padding:1.25rem 1.5rem 1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem;flex:1}.cia-section{display:flex;flex-direction:column;gap:.6rem}.cia-section-title{font-size:.8rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin:0;padding-bottom:.4rem;border-bottom:1px solid #f1f5f9}.cia-status-row{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.cia-tracking-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:20px;font-size:.78rem;color:#374151}.cia-track-link{color:#2563eb;font-weight:600;text-decoration:none;font-size:.75rem}.cia-track-link:hover{text-decoration:underline}.cia-info-grid{display:flex;flex-direction:column;gap:.5rem;background:#f8fafc;border:1px solid #f1f5f9;border-radius:10px;padding:.85rem 1rem}.cia-info-row{display:flex;align-items:baseline;gap:.5rem;min-height:1.5rem}.cia-info-key{flex-shrink:0;width:80px;font-size:.78rem;color:#94a3b8;font-weight:600}.cia-info-val{font-size:.875rem;color:#1e293b;word-break:break-all}.cia-info-val--accent{font-weight:700;color:#2563eb;font-size:.95rem}.cia-reject-reason{background:#fff5f5;border:1px solid #fecaca;border-radius:8px;padding:.75rem 1rem;font-size:.875rem;color:#991b1b;margin:0;white-space:pre-wrap}.cia-textarea{width:100%;padding:.6rem .85rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;resize:vertical;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;font-family:inherit;line-height:1.5}.cia-textarea:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.cia-textarea::placeholder{color:#94a3b8}.cia-ship-row{display:flex;gap:.6rem;flex-wrap:wrap}.cia-select{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#f8fafc;cursor:pointer;transition:border-color .15s;min-width:130px}.cia-select:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.cia-input{flex:1;min-width:160px;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.cia-input:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.cia-input::placeholder{color:#94a3b8}.cia-action-row{display:flex;gap:.6rem;flex-wrap:wrap;padding-top:.25rem}.cia-save-msg{font-size:.85rem;color:#059669;margin:0;padding:.5rem .75rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px}.cia-save-msg:has(span[style*=red]),.cia-save-msg:contains("❌"){color:#dc2626;background:#fef2f2;border-color:#fecaca}@media(max-width:768px){.cia-wrap{padding:1rem .75rem 2rem}.cia-toolbar{flex-direction:column;align-items:stretch}.cia-tabs{gap:.3rem}.cia-tab{font-size:.78rem;padding:.35rem .65rem}.cia-modal{max-width:98vw;border-radius:12px}.cia-modal-hd{padding:1rem 1.25rem .75rem}.cia-modal-body{padding:1rem 1.25rem 1.25rem}.cia-action-row{flex-direction:column}.cia-btn{width:100%;justify-content:center}.cia-ship-row{flex-direction:column}.cia-select,.cia-input{min-width:100%}}.course-form-container *,.course-form-container *:before,.course-form-container *:after{box-sizing:border-box}.course-form-container{max-width:1400px;margin:0 auto;padding:2rem;background:#f9fafb;min-height:100vh}.course-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.course-form-header h1{margin:0;font-size:1.75rem;font-weight:700;color:#1f2937}.btn-back{padding:.75rem 1.5rem;background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#6b7280;font-weight:600;cursor:pointer;transition:all .2s;font-size:.95rem;white-space:nowrap;margin-left:auto}.btn-back:hover{background:#f3f4f6;color:#374151}.course-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #00000014}.form-section h2{margin:0 0 1.75rem;font-size:1.25rem;font-weight:700;color:#1f2937;padding-bottom:.75rem;border-bottom:2px solid #667eea}.form-group{margin-bottom:1.25rem;width:100%;min-width:0}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.form-group input[type=text],.form-group input[type=number],.form-group input[type=email],.form-group input[type=tel],.form-group input[type=date],.form-group input[type=password],.form-group select,.form-group textarea{display:block;width:100%;padding:.625rem .875rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:.9375rem;color:#1f2937;background:#fff;transition:border-color .2s,box-shadow .2s;margin:0}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.form-group input.error,.form-group select.error{border-color:#ef4444}.form-group textarea{resize:vertical;min-height:100px}.form-row-full{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem;width:100%;align-items:start}.form-row-full.cols-3{grid-template-columns:2fr 1fr 1fr}.form-row-full.cols-4{grid-template-columns:2fr 1fr 1fr 1fr}@media(max-width:900px){.form-row-full.cols-4{grid-template-columns:1fr 1fr}}@media(max-width:768px){.form-row-full,.form-row-full.cols-3,.form-row-full.cols-4{grid-template-columns:1fr}}.error-text{display:block;font-size:.8125rem;color:#ef4444;margin-top:.375rem}.help-text{display:inline-block;font-size:.8125rem;color:#6b7280;margin-top:.375rem}.tags-preview{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.tag-chip{padding:.25rem .625rem;background:#ede9fe;color:#5b21b6;border-radius:9999px;font-size:.8125rem;font-weight:500}.array-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.array-item input{flex:1;min-width:0;padding:.5rem .75rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:.9rem;transition:border-color .2s;width:100%}.array-item input:focus{outline:none;border-color:#667eea}.array-item button{flex-shrink:0;width:2rem;height:2rem;border:none;background:#fee2e2;color:#ef4444;border-radius:6px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background .15s}.array-item button:hover{background:#fecaca}.step-badge{flex-shrink:0;display:flex;align-items:center;justify-content:center;min-width:3.75rem;padding:.25rem .5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:6px;font-size:.75rem;font-weight:700;white-space:nowrap}.btn-add-array{margin-top:.25rem;padding:.5rem 1rem;background:#f3f4f6;border:1.5px dashed #9ca3af;border-radius:8px;color:#6b7280;font-size:.875rem;cursor:pointer;transition:all .15s;width:100%}.btn-add-array:hover{background:#ede9fe;border-color:#667eea;color:#667eea}.course-search-wrap{position:relative;width:100%}.course-selected-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem}.course-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .625rem .3rem .75rem;background:#ede9fe;color:#4c1d95;border-radius:9999px;font-size:.8125rem;font-weight:500;max-width:240px}.course-tag span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-tag button{flex-shrink:0;width:1.125rem;height:1.125rem;border:none;background:#c4b5fd;color:#4c1d95;border-radius:50%;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;line-height:1;padding:0;transition:background .15s}.course-tag button:hover{background:#a78bfa;color:#fff}.course-search-input-wrap{position:relative;width:100%}.course-search-input{display:block;width:100%;padding:.625rem 2.5rem .625rem .875rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:.9375rem;color:#1f2937;background:#fff;transition:border-color .2s,box-shadow .2s}.course-search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.course-search-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-size:.875rem;pointer-events:none;opacity:.5}.course-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;box-shadow:0 8px 24px #0000001f;max-height:260px;overflow-y:auto;z-index:100}.course-dropdown::-webkit-scrollbar{width:6px}.course-dropdown::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.course-dropdown::-webkit-scrollbar-thumb{background:#c4b5fd;border-radius:3px}.course-dropdown-item{display:flex;align-items:center;gap:.625rem;padding:.625rem 1rem;cursor:pointer;font-size:.9rem;color:#374151;transition:background .1s;border-bottom:1px solid #f3f4f6}.course-dropdown-item:last-child{border-bottom:none}.course-dropdown-item:hover{background:#f5f3ff}.course-dropdown-item.selected{background:#ede9fe;color:#4c1d95;font-weight:600}.course-dropdown-check{flex-shrink:0;width:1.25rem;font-size:.875rem;color:#667eea;font-weight:700}.course-dropdown-empty{padding:1rem;text-align:center;color:#9ca3af;font-size:.875rem}.thumbnail-preview-wrap{position:relative;display:inline-block;margin-top:.75rem}.thumbnail-preview-wrap img{max-width:100%;max-height:200px;border-radius:8px;border:1.5px solid #e5e7eb;display:block}.thumb-remove-btn{position:absolute!important;top:6px!important;right:6px!important;width:26px;height:26px;padding:0;background:#ef4444e6!important;color:#fff!important;border:none;border-radius:50%;font-size:.8rem;font-weight:700;line-height:1;cursor:pointer;display:flex!important;align-items:center;justify-content:center;transition:background .15s,transform .1s;z-index:10}.thumb-remove-btn:hover{background:#dc2626!important;transform:scale(1.1)}.detail-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-top:.75rem}.detail-image-item{position:relative;border-radius:8px;overflow:hidden;border:1.5px solid #e5e7eb}.detail-image-item img{width:100%;height:100px;object-fit:cover;display:block}.btn-remove-detail-img{position:absolute;top:4px;right:4px;width:22px;height:22px;background:#0009;color:#fff;border:none;border-radius:50%;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.upload-status-simple{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#eff6ff;border-radius:6px;margin-top:.5rem;font-size:.875rem;color:#2563eb}.upload-error-container{margin-top:.5rem}.upload-error-message{display:flex;align-items:center;gap:.5rem;color:#ef4444;font-size:.875rem;margin-bottom:.375rem}.btn-retry-upload{padding:.375rem .875rem;background:#eff6ff;border:1px solid #93c5fd;border-radius:6px;color:#2563eb;font-size:.8125rem;cursor:pointer}.btn-retry-upload:hover{background:#dbeafe}.upload-overlay{position:fixed;inset:0;background:#00000080;z-index:9999;display:flex;align-items:center;justify-content:center}.upload-overlay-content{background:#fff;border-radius:16px;padding:2.5rem 3rem;text-align:center;box-shadow:0 20px 60px #00000040}.upload-overlay-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.upload-overlay-text{font-size:1rem;font-weight:600;color:#1f2937}.upload-overlay-subtext{font-size:.875rem;color:#9ca3af;margin-top:.375rem}.subjects-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.subject-item{border:1.5px solid #e5e7eb;border-radius:10px;padding:1.25rem;background:#fafafa;transition:border-color .15s}.subject-item:hover{border-color:#c4b5fd}.subject-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.subject-num{font-size:.875rem;font-weight:700;color:#667eea;background:#ede9fe;padding:.25rem .75rem;border-radius:9999px}.btn-remove-subject{padding:.25rem .75rem;background:#fee2e2;border:none;border-radius:6px;color:#ef4444;font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-remove-subject:hover{background:#fecaca}.btn-add-section{width:100%;padding:.875rem;background:#f5f3ff;border:2px dashed #c4b5fd;border-radius:10px;color:#7c3aed;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .15s;margin-top:.5rem}.btn-add-section:hover{background:#ede9fe;border-color:#667eea}.subjects-summary{display:flex;align-items:center;flex-wrap:wrap;gap:.375rem;margin-top:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:8px;font-size:.875rem;color:#4c1d95}.subjects-summary strong{color:#667eea}.subjects-summary .divider{color:#c4b5fd;font-weight:700}.retry-policy-row{display:flex;align-items:center;flex-wrap:wrap;gap:1rem;padding:.875rem;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px}.radio-option-label{display:flex;align-items:center;gap:.375rem;cursor:pointer;font-size:.9rem;color:#374151}.radio-option-label input[type=radio]{accent-color:#667eea}.retry-limit-input{display:flex;align-items:center;gap:.375rem}.retry-limit-input small{color:#6b7280;font-size:.875rem}.cert-format-options{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.25rem}.cert-format-option{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1rem 1.5rem;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;background:#fff;transition:border-color .18s,background .18s,box-shadow .18s;min-width:130px;flex:1}.cert-format-option input[type=radio]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.cert-format-option:hover{border-color:#a5b4fc;background:#f5f3ff}.cert-format-option--active{border-color:#667eea;background:#eef2ff;box-shadow:0 0 0 3px #667eea26}.cert-format-icon{font-size:1.75rem;line-height:1}.cert-format-label{font-size:.875rem;font-weight:600;color:#374151;white-space:nowrap}.cert-format-option--active .cert-format-label{color:#4338ca}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;position:sticky;bottom:1rem}.btn-cancel{padding:.75rem 2rem;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;color:#6b7280;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-cancel:hover{background:#f3f4f6;color:#374151}.btn-submit{padding:.75rem 2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-size:.9375rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s}.btn-submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-submit:disabled{opacity:.55;cursor:not-allowed}.no-data-text{color:#9ca3af;font-size:.875rem;padding:.5rem}@media(max-width:640px){.course-form-container{padding:1rem}.form-section{padding:1.25rem}.course-form-header h1{font-size:1.25rem}.subjects-summary,.retry-policy-row{flex-direction:column;align-items:flex-start}}.section-desc{font-size:.875rem;color:#6b7280;margin-bottom:1.25rem;padding:.75rem 1rem;background:#f9fafb;border-left:3px solid #667eea;border-radius:0 6px 6px 0}.career-prospect-item{border:1.5px solid #e5e7eb;border-radius:10px;padding:1.25rem;margin-bottom:1rem;background:#fafafa;transition:border-color .15s}.career-prospect-item:hover{border-color:#c4b5fd}.career-prospect-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.career-prospect-num{font-size:.875rem;font-weight:700;color:#667eea;background:#ede9fe;padding:.25rem .75rem;border-radius:9999px}.cd-container{max-width:1400px;margin:0 auto;padding:1.5rem 1.5rem 4rem;background:#f8fafc;min-height:100vh}.cd-loading-full{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:1rem;color:#64748b}.cd-spinner{width:44px;height:44px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:cd-spin .8s linear infinite}@keyframes cd-spin{to{transform:rotate(360deg)}}.cd-loading{text-align:center;color:#64748b;padding:2rem}.cd-back-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:20px;color:#475569;font-size:.875rem;font-weight:500;cursor:pointer;margin-bottom:1.25rem;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.cd-back-btn:hover{background:#f1f5f9;border-color:#94a3b8;color:#1e293b}.cd-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;padding:.25rem 0}.cd-header-info{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.cd-header-left{display:flex;align-items:center;gap:1rem;flex:1}.cd-header-thumb{width:80px;height:60px;object-fit:cover;border-radius:8px;border:1px solid #e2e8f0;flex-shrink:0}.cd-header-title{font-size:1.4rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.cd-header-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.cd-meta-item{font-size:.85rem;color:#64748b;background:#f1f5f9;padding:.2rem .6rem;border-radius:6px}.cd-header-actions{display:flex;gap:.5rem;align-items:flex-start;flex-shrink:0}.cd-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.22rem .7rem;border-radius:999px;font-size:.76rem;font-weight:600;white-space:nowrap}.cd-badge-green{background:#dcfce7;color:#166534}.cd-badge-blue{background:#e8eeff;color:#4051c4}.cd-badge-orange{background:#fff3e0;color:#b45309}.cd-badge-red{background:#fee2e2;color:#b91c1c}.cd-badge-gray{background:#f1f5f9;color:#475569}.cd-badge-purple{background:#ede9fe;color:#6d28d9}.cd-badge-indigo{background:#e8eeff;color:#4051c4}.cd-tabs{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;padding:.75rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.cd-tab{display:inline-flex;align-items:center;gap:.35rem;padding:.42rem .9rem;border:1px solid #e2e8f0;border-radius:20px;background:#f8fafc;color:#475569;font-size:.84rem;font-weight:500;cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.cd-tab:hover{background:#f1f5f9;color:#1e293b;border-color:#cbd5e1}.cd-tab.active{background:#667eea;color:#fff;border-color:#667eea;font-weight:700;box-shadow:0 2px 6px #667eea4d}.cd-sub-tabs{display:flex;gap:.4rem;margin-bottom:1.25rem;flex-wrap:wrap}.cd-sub-tab{display:inline-flex;align-items:center;gap:.3rem;padding:.38rem .85rem;border:1px solid #e2e8f0;border-radius:20px;background:#f8fafc;color:#475569;font-size:.83rem;font-weight:500;cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.cd-sub-tab:hover{background:#f1f5f9;color:#1e293b;border-color:#94a3b8}.cd-sub-tab.active{background:#667eea;color:#fff;border-color:#667eea;font-weight:700}.cd-section-card{background:#fff;border-radius:12px;padding:1.5rem 1.75rem;margin-bottom:1.25rem;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000d}.cd-section-title{font-size:.82rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #f1f5f9}.cd-section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.cd-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.cd-form-group{display:flex;flex-direction:column;gap:.35rem}.cd-form-group.cd-full-width{grid-column:1 / -1}.cd-form-group label{font-size:.83rem;font-weight:600;color:#374151}.cd-form-group input,.cd-form-group select,.cd-form-group textarea{padding:.6rem .85rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.9rem;color:#1e293b;background:#fff;transition:border-color .15s;outline:none;width:100%;box-sizing:border-box}.cd-form-group input:focus,.cd-form-group select:focus,.cd-form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.cd-form-group textarea{resize:vertical}.cd-input-with-btn{display:flex;gap:.5rem}.cd-input-with-btn input{flex:1}.cd-input-row{display:flex;align-items:center;gap:.5rem}.cd-input-row input{width:100px}.cd-btn-primary{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.35rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s,box-shadow .15s;box-shadow:0 2px 8px #667eea4d;font-family:inherit}.cd-btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 14px #667eea73}.cd-btn-primary:active{transform:scale(.97);opacity:.85}.cd-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.cd-btn-secondary{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;color:#475569;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s;font-family:inherit}.cd-btn-secondary:hover{background:#e2e8f0;border-color:#94a3b8;color:#1e293b}.cd-btn-warning{padding:.55rem 1rem;background:#f59e0b;color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.cd-btn-warning:hover{opacity:.9}.cd-btn-sm{padding:.4rem .8rem;background:#fff;border:1.5px solid #667eea;border-radius:6px;color:#667eea;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}.cd-btn-sm:hover{background:#667eea;color:#fff}.cd-btn-xs{padding:.3rem .65rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:5px;color:#475569;font-size:.78rem;cursor:pointer;margin-right:.3rem;transition:all .12s}.cd-btn-xs:hover{background:#e2e8f0}.cd-btn-xs.cd-btn-danger{border-color:#fecaca;color:#dc2626}.cd-btn-xs.cd-btn-danger:hover{background:#fee2e2}.cd-checkbox-group{display:flex;flex-direction:column;gap:.6rem;margin:1rem 0}.cd-checkbox-label{display:flex;align-items:center;gap:.6rem;font-size:.9rem;color:#374151;cursor:pointer;font-weight:500}.cd-checkbox-label input[type=checkbox]{width:17px;height:17px;accent-color:#667eea;cursor:pointer}.cd-thumbnail-area{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:12px;border:1px dashed #cbd5e1}.cd-thumbnail-preview{width:140px;height:90px;border-radius:8px;overflow:hidden;border:1px solid #e2e8f0;flex-shrink:0}.cd-thumbnail-preview img{width:100%;height:100%;object-fit:cover}.cd-label{font-size:.82rem;color:#64748b;margin-bottom:.4rem}.cd-status-quick{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin:1rem 0;padding:.75rem 1rem;background:#f8fafc;border-radius:10px}.cd-status-btn{padding:.4rem .85rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;font-size:.83rem;font-weight:500;cursor:pointer;transition:all .15s}.cd-status-btn.active,.cd-status-btn:hover{border-color:#667eea;color:#667eea;background:#eef}.cd-discount-info{display:flex;gap:1.5rem;background:#eef;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.88rem;color:#5546c0}.cd-discount-info strong{font-size:1rem}.cd-table-wrapper{overflow-x:auto;background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.cd-table{width:100%;border-collapse:collapse;font-size:.875rem}.cd-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0}.cd-table th{padding:.75rem 1rem;text-align:left;font-size:.76rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.cd-table td{padding:.75rem 1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;color:#374151}.cd-table tr:last-child td{border-bottom:none}.cd-table tbody tr:hover td{background:#f8fafc}.cd-table tr.cd-row-selected td{background:#eef2ff}.cd-empty-cell{text-align:center;color:#94a3b8;padding:2.5rem!important}.cd-code{font-family:Courier New,monospace;background:#f1f5f9;padding:.15rem .5rem;border-radius:4px;font-size:.9rem;color:#667eea;font-weight:700;letter-spacing:.05em}.cd-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.cd-stat-card{background:#fff;border-radius:12px;padding:1.15rem 1.35rem;text-align:center;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000d;transition:transform .15s,box-shadow .15s}.cd-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.cd-stat-card.cd-stat-primary{border-top:3px solid #667eea}.cd-stat-card.cd-stat-warning{border-top:3px solid #f59e0b}.cd-stat-value{font-size:1.6rem;font-weight:800;color:#1e293b;margin-bottom:.25rem}.cd-stat-label{font-size:.82rem;color:#64748b;font-weight:500}.cd-green{color:#4caf50}.cd-orange{color:#b45309}.cd-progress-row{display:flex;align-items:center;gap:.6rem;min-width:140px}.cd-progress-bar{flex:1;height:8px;background:#f1f5f9;border-radius:999px;overflow:hidden}.cd-progress-fill{height:100%;border-radius:999px;transition:width .4s}.cd-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:.75rem;flex-wrap:wrap;padding:.75rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:10px}.cd-search-input{padding:.5rem .85rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;outline:none;min-width:220px;background:#f8fafc;transition:border-color .15s,box-shadow .15s}.cd-search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.cd-search-input::placeholder{color:#94a3b8}.cd-qna-item{border:1px solid #e2e8f0;border-radius:8px;padding:.75rem 1rem;margin-bottom:.5rem;transition:border-color .15s}.cd-qna-item.answered{border-color:#bbf7d0;background:#f0fdf4}.cd-qna-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.cd-qna-author{font-weight:600;color:#1e293b;font-size:.85rem}.cd-qna-question{font-size:.9rem;color:#374151;margin:0 0 .5rem;line-height:1.5}.cd-qna-reply{background:#f0fdf4;border-left:3px solid #10b981;padding:.5rem .85rem;border-radius:0 6px 6px 0;margin-bottom:.5rem}.cd-qna-reply p{margin:.2rem 0;font-size:.85rem;color:#166534}.cd-qna-reply-form{display:flex;flex-direction:column;gap:.4rem}.cd-qna-reply-form textarea{padding:.5rem .75rem;border:1.5px solid #e2e8f0;border-radius:6px;font-size:.85rem;resize:vertical;outline:none}.cd-qna-reply-form textarea:focus{border-color:#667eea}.cd-qna-compact{border-bottom:1px solid #f1f5f9;background:#fff}.cd-qna-compact:last-child{border-bottom:none}.cd-qna-compact.answered .cd-qna-compact-row{background:#fff}.cd-qna-compact.open>.cd-qna-compact-row{background:#f8fafc;border-bottom:1px solid #e2e8f0}.cd-qna-compact-row:hover{background:#f8fafc}.cd-qna-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.cd-qna-dot.ans{background:#10b981}.cd-qna-dot.unans{background:#f59e0b}.cd-qna-compact-author{font-size:.8rem;font-weight:600;color:#374151;white-space:nowrap;flex-shrink:0;max-width:100px;overflow:hidden;text-overflow:ellipsis}.cd-qna-compact-q{flex:1;font-size:.85rem;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.cd-qna-compact-lesson{font-size:.75rem;color:#94a3b8;white-space:nowrap;flex-shrink:0;max-width:120px;overflow:hidden;text-overflow:ellipsis}.cd-qna-compact-row{display:flex;flex-direction:column;padding:.6rem .85rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s;gap:.2rem}.cd-qna-compact-main{display:flex;align-items:center;gap:.6rem;min-height:28px}.cd-qna-compact-sub{padding-left:1.1rem}.cd-qna-compact-lesson-full{font-size:.75rem;color:#6366f1;background:#eef2ff;border-radius:4px;padding:.1rem .5rem;display:inline-block;word-break:keep-all}.cd-qna-compact-date{font-size:.75rem;color:#94a3b8;white-space:nowrap;flex-shrink:0}.cd-qna-compact-arrow{font-size:.7rem;color:#94a3b8;flex-shrink:0;transition:transform .15s}.cd-qna-compact-body{padding:.75rem 1rem .85rem 1.2rem;background:#fafafa;border-top:1px solid #f1f5f9}.cd-qna-compact-full-q{font-size:.88rem;color:#374151;line-height:1.55;margin:0 0 .6rem;padding-bottom:.6rem;border-bottom:1px dashed #e2e8f0}.cd-qna-compact-reply{background:#f0fdf4;border-left:3px solid #10b981;padding:.5rem .85rem;border-radius:0 6px 6px 0;margin-bottom:.6rem}.cd-qna-compact-reply-label{font-size:.75rem;font-weight:600;color:#059669;display:block;margin-bottom:.25rem}.cd-qna-compact-reply p{font-size:.85rem;color:#166534;margin:0 0 .25rem}.cd-qna-compact-form{display:flex;flex-direction:column;gap:.4rem}.cd-qna-compact-form textarea{padding:.45rem .75rem;border:1.5px solid #e2e8f0;border-radius:6px;font-size:.85rem;resize:vertical;outline:none;background:#fff}.cd-qna-compact-form textarea:focus{border-color:#667eea}.cd-qna-compact-list{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.cd-review-item{border:1.5px solid #e2e8f0;border-radius:12px;padding:1.25rem;margin-bottom:1rem}.cd-review-item.blinded{opacity:.6;border-style:dashed}.cd-review-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.6rem;flex-wrap:wrap}.cd-stars{color:#b45309;font-size:1rem;letter-spacing:.05em}.cd-review-content{font-size:.92rem;color:#374151;margin:0 0 .75rem;line-height:1.6}.cd-blinded-text{color:#94a3b8;font-style:italic;margin-bottom:.5rem}.cd-review-reply-form{display:flex;gap:.5rem;margin-bottom:.5rem}.cd-review-reply-form textarea{flex:1;padding:.5rem .75rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.85rem;resize:none;outline:none}.cd-review-reply-form textarea:focus{border-color:#667eea}.cd-coupon-form{background:#f8fafc;border:1.5px dashed #c8c8f8;border-radius:14px;padding:1.5rem;margin-bottom:1.5rem}.cd-coupon-form h4{font-size:.95rem;font-weight:700;color:#5546c0;margin:0 0 1rem}.cd-coupon-list h4{font-size:.95rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.cd-empty-msg{color:#94a3b8;text-align:center;padding:1.5rem;font-size:.9rem}.cd-gamification-info-box{background:#fff3e0;border:1.5px solid #fde68a;border-radius:10px;padding:1rem 1.25rem;margin-bottom:1.25rem;font-size:.87rem;color:#78350f;line-height:1.8}.cd-gamification-info-box p{margin:0}.cd-streak-preview{background:#f8fafc;border-radius:12px;padding:1.25rem;margin:1rem 0}.cd-streak-preview h4{font-size:.9rem;font-weight:700;color:#6b21a8;margin:0 0 1rem}.cd-streak-badges{display:flex;gap:1rem;flex-wrap:wrap}.cd-streak-badge{flex:1;min-width:90px;text-align:center;background:#fff;border:1.5px solid #e9d5ff;border-radius:12px;padding:1rem .5rem;box-shadow:0 2px 6px #764ba21a}.cd-streak-icon{font-size:1.5rem;margin-bottom:.4rem}.cd-streak-points{font-size:1.1rem;font-weight:800;color:#7c3aed}.cd-streak-label{font-size:.78rem;color:#9333ea;margin-top:.2rem}.cd-streak-text{font-size:.88rem;color:#b45309;font-weight:600}.cd-toggle-label{display:flex;align-items:center;gap:.75rem;font-size:.88rem;font-weight:600;color:#374151;cursor:pointer}.cd-toggle{position:relative;display:inline-block;width:44px;height:24px}.cd-toggle input{display:none}.cd-toggle-slider{position:absolute;inset:0;background:#e2e8f0;border-radius:999px;transition:.3s;cursor:pointer}.cd-toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 3px #00000040}.cd-toggle input:checked+.cd-toggle-slider{background:#667eea}.cd-toggle input:checked+.cd-toggle-slider:before{transform:translate(20px)}.cd-point-adj-panel{margin-top:1.5rem;background:#eef;border:1.5px solid #c8c8f8;border-radius:14px;padding:1.25rem 1.5rem}.cd-point-adj-panel h4{font-size:.95rem;font-weight:700;color:#4a3f8f;margin:0 0 1rem}.cd-point-value{font-size:1rem;font-weight:700;color:#667eea}.cd-point-plus{color:#4caf50;font-weight:700}.cd-point-minus{color:#ef4444;font-weight:700}.cd-rewards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem}.cd-reward-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:1.25rem;text-align:center;transition:all .15s;box-shadow:0 1px 4px #0000000f}.cd-reward-card:hover{border-color:#667eea;transform:translateY(-2px)}.cd-reward-card.inactive{opacity:.5}.cd-reward-icon{font-size:2rem;margin-bottom:.5rem}.cd-reward-name{font-size:.95rem;font-weight:700;color:#1e293b;margin-bottom:.4rem}.cd-reward-cost{font-size:1.1rem;font-weight:800;color:#667eea;margin-bottom:.3rem}.cd-reward-desc{font-size:.78rem;color:#64748b;margin-bottom:.4rem;min-height:2rem}.cd-reward-stock{font-size:.78rem;color:#94a3b8;margin-bottom:.75rem}.cd-reward-actions{display:flex;justify-content:center;gap:.4rem;flex-wrap:wrap}.cd-period-selector{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.cd-period-btn{padding:.5rem 1rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.cd-period-btn:hover{border-color:#667eea;color:#667eea}.cd-period-btn.active{background:#667eea;border-color:#667eea;color:#fff;font-weight:700}.cd-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.5rem}.cd-chart-card{background:#fff;border-radius:14px;padding:1.5rem;box-shadow:0 1px 6px #00000012}.cd-chart-card h4{font-size:.9rem;font-weight:700;color:#1e293b;margin:0 0 1.25rem}.cd-bar-chart{display:flex;align-items:flex-end;gap:4px;height:160px;padding-bottom:1.75rem;position:relative}.cd-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative}.cd-bar{width:100%;border-radius:4px 4px 0 0;min-height:4px;transition:height .4s ease}.cd-bar-value{font-size:.62rem;color:#667eea;margin-bottom:3px;text-align:center;white-space:nowrap}.cd-bar-label{position:absolute;bottom:-1.4rem;font-size:.63rem;color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:100%}.cd-method-list{display:flex;flex-direction:column;gap:.85rem}.cd-method-item{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.cd-method-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.cd-method-name{font-size:.88rem;font-weight:600;color:#1e293b;min-width:70px}.cd-method-count{font-size:.8rem;color:#64748b;min-width:80px}.cd-method-bar-bg{flex:1;height:8px;background:#f1f5f9;border-radius:999px;overflow:hidden;min-width:80px}.cd-method-bar-fill{height:100%;border-radius:999px;transition:width .4s}.cd-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.cd-modal{background:#fff;border-radius:16px;padding:1.75rem;max-width:580px;width:100%;box-shadow:0 20px 60px #0003}.cd-modal h3{font-size:1.1rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem}.cd-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}@media(max-width:1024px){.cd-stats-row{grid-template-columns:repeat(2,1fr)}.cd-charts-row{grid-template-columns:1fr}}@media(max-width:768px){.cd-container{padding:1rem}.cd-tabs{flex-wrap:wrap}.cd-tab{flex:none;min-width:calc(50% - .25rem)}.cd-form-grid{grid-template-columns:1fr}.cd-stats-row{grid-template-columns:repeat(2,1fr)}.cd-header-info{flex-direction:column}.cd-header-thumb{width:60px;height:45px}}@media(max-width:480px){.cd-stats-row{grid-template-columns:1fr 1fr}.cd-tab{min-width:100%}.cd-rewards-grid{grid-template-columns:1fr 1fr}}.cd-tab-badge{display:inline-block;margin-left:.4rem;padding:.05rem .45rem;background:#ffffff4d;color:inherit;border-radius:999px;font-size:.72rem;font-weight:700;vertical-align:middle}.cd-tab.active .cd-tab-badge{background:#ffffff59;color:#fff}.cad-thumb-area{margin-bottom:1.5rem}.cad-thumb-large{width:200px;height:130px;object-fit:cover;border-radius:12px;border:1px solid #e2e8f0;display:block}.cad-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1.5px solid #e2e8f0;border-radius:12px;overflow:hidden;margin-bottom:1.5rem}.cad-info-item{display:flex;flex-direction:column;gap:4px;padding:14px 18px;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;background:#fff}.cad-info-item:nth-child(2n){border-right:none}.cad-info-item:last-child,.cad-info-item:nth-last-child(2):nth-child(odd){border-bottom:none}.cad-info-item-full{grid-column:1 / -1;border-right:none}.cad-info-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.03em}.cad-info-value{font-size:.95rem;font-weight:500;color:#1e293b}.cad-info-title{font-size:1.05rem;font-weight:700}.cad-info-desc{font-size:.875rem;color:#64748b;line-height:1.55;white-space:pre-wrap}.cad-ori-price{color:#94a3b8;margin-right:.4rem;font-size:.85rem}.cad-subjects-block{margin-top:1.5rem}.cad-subjects-heading{font-size:.95rem;font-weight:700;color:#1e293b;margin-bottom:.75rem}.cad-q-list{display:flex;flex-direction:column;gap:.75rem}.cad-q-item{border:1.5px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem;background:#fff;transition:border-color .15s,box-shadow .15s}.cad-q-item:hover{border-color:#c7d2fe;box-shadow:0 2px 8px #667eea14}.cad-q-item-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.6rem}.cad-q-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:#667eea;color:#fff;border-radius:8px;font-size:.78rem;font-weight:700;flex-shrink:0}.cad-q-text{font-size:.95rem;color:#1e293b;line-height:1.55;margin:.4rem 0;font-weight:500}.cad-q-options{display:flex;flex-direction:column;gap:.4rem;margin-top:.6rem}.cad-q-opt{display:flex;align-items:center;gap:.6rem;padding:.45rem .75rem;border-radius:8px;border:1.5px solid #e2e8f0;background:#f8fafc;font-size:.88rem;color:#374151;transition:all .12s}.cad-q-opt.correct{border-color:#86efac;background:#f0fdf4;color:#166534;font-weight:600}.cad-q-opt-num{width:22px;height:22px;border-radius:50%;background:#e2e8f0;color:#475569;font-size:.75rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.cad-q-opt.correct .cad-q-opt-num{background:#22c55e;color:#fff}.cad-q-short-answer{margin-top:.6rem;padding:.5rem .85rem;background:#f0fdf4;border-left:3px solid #22c55e;border-radius:0 8px 8px 0;font-size:.88rem;color:#166534}.cad-q-explanation{margin-top:.5rem;padding:.5rem .85rem;background:#fffbeb;border-left:3px solid #f59e0b;border-radius:0 8px 8px 0;font-size:.85rem;color:#92400e;line-height:1.5}.cad-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.cad-modal{background:#fff;border-radius:18px;width:100%;max-width:580px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 64px #00000038}.cad-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.75rem;border-bottom:1px solid #f1f5f9;flex-shrink:0}.cad-modal-title{font-size:1.1rem;font-weight:700;color:#1e293b;margin:0}.cad-modal-body{flex:1;overflow-y:auto;padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1rem}.cad-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.75rem;border-top:1px solid #f1f5f9;flex-shrink:0}.cad-radio-row{display:flex;gap:1.5rem;flex-wrap:wrap}.cad-radio-label{display:flex;align-items:center;gap:.45rem;font-size:.9rem;color:#374151;cursor:pointer;font-weight:500}.cad-radio-label input[type=radio]{width:16px;height:16px;accent-color:#667eea;cursor:pointer}.cad-option-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}.cad-option-row input{flex:1}.cad-option-num{width:26px;height:26px;border-radius:50%;background:#e2e8f0;color:#475569;font-size:.78rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.cad-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:768px){.cad-info-grid{grid-template-columns:1fr}.cad-info-item{border-right:none}.cad-info-item-full{grid-column:1}.cad-stats-row{grid-template-columns:1fr 1fr}.cad-modal{max-width:100%;border-radius:14px}}@media(max-width:480px){.cad-stats-row{grid-template-columns:1fr}.cad-modal-body{padding:1rem}.cad-modal-footer{padding:.75rem 1rem}}.cad-exam-config-card{border-top:3px solid #667eea}.cad-pool-stats{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}.cad-pool-stat{display:flex;align-items:baseline;gap:.3rem;padding:.6rem 1.1rem;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;min-width:90px}.cad-pool-stat.cad-pool-hard{border-color:#fca5a5;background:#fff5f5}.cad-pool-stat.cad-pool-mid{border-color:#fcd34d;background:#fffbeb}.cad-pool-stat.cad-pool-easy{border-color:#86efac;background:#f0fdf4}.cad-pool-label{font-size:.78rem;font-weight:700;color:#64748b}.cad-pool-val{font-size:1.35rem;font-weight:800;color:#1e293b;line-height:1}.cad-pool-unit{font-size:.75rem;color:#94a3b8}.cad-config-row{display:grid;grid-template-columns:repeat(3,1fr) auto;gap:1rem;align-items:end}.cad-config-item{display:flex;flex-direction:column;gap:.45rem}.cad-config-label{display:flex;align-items:center;font-size:.83rem;font-weight:600;color:#374151}.cad-config-input-wrap{display:flex;align-items:center;gap:.5rem}.cad-config-input{width:80px;padding:.55rem .75rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:1rem;font-weight:700;color:#1e293b;text-align:center;outline:none;transition:border-color .15s}.cad-config-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.cad-config-pool{font-size:.78rem;color:#94a3b8;white-space:nowrap}.cad-config-total{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:.75rem 1.25rem;background:#eef2ff;border:1.5px solid #c7d2fe;border-radius:10px;gap:.1rem;min-width:90px}.cad-config-total-label{font-size:.72rem;font-weight:600;color:#6366f1;letter-spacing:.03em}.cad-config-total-val{font-size:1.5rem;font-weight:800;color:#4f46e5;line-height:1.1}.cad-config-total-unit{font-size:.72rem;color:#818cf8}.cad-filter-bar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;padding:.75rem 0;margin-bottom:.75rem;border-bottom:1px solid #f1f5f9}.cad-q-search{padding:.5rem .9rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.88rem;color:#1e293b;outline:none;min-width:200px;flex:1;transition:border-color .15s}.cad-q-search:focus{border-color:#667eea}.cad-q-search::placeholder{color:#94a3b8}.cad-diff-filter{display:flex;gap:.3rem}.cad-diff-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;font-size:.83rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.cad-diff-btn:hover{background:#f8fafc;border-color:#94a3b8}.cad-diff-btn.active{background:#667eea;border-color:#667eea;color:#fff}.cad-diff-btn.active .cad-diff-cnt{background:#ffffff4d;color:#fff}.cad-diff-btn.hard.active{background:#ef4444;border-color:#ef4444}.cad-diff-btn.mid.active{background:#f59e0b;border-color:#f59e0b}.cad-diff-btn.easy.active{background:#22c55e;border-color:#22c55e}.cad-diff-cnt{display:inline-block;padding:.05rem .4rem;background:#f1f5f9;border-radius:999px;font-size:.72rem;font-weight:700;color:#475569;transition:all .15s}.cad-q-item{border:1.5px solid #e2e8f0;border-radius:12px;background:#fff;overflow:hidden;transition:border-color .15s,box-shadow .15s}.cad-q-item.open{border-color:#667eea;box-shadow:0 2px 10px #667eea1f}.cad-q-item:hover{border-color:#c7d2fe}.cad-q-accordion-header{cursor:pointer;-webkit-user-select:none;user-select:none;padding:.7rem 1rem;transition:background .12s;flex-wrap:nowrap;gap:.45rem}.cad-q-accordion-header:hover{background:#f8fafc}.cad-q-item.open .cad-q-accordion-header{background:#f5f3ff}.cad-q-preview{flex:1;font-size:.88rem;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.cad-q-item.open .cad-q-preview{color:#4f46e5;font-weight:500}.cad-q-header-actions{display:flex;gap:.35rem;flex-shrink:0}.cad-q-arrow{font-size:.7rem;color:#94a3b8;flex-shrink:0;transition:transform .15s}.cad-q-item.open .cad-q-arrow{color:#667eea}.cad-q-body{padding:1rem 1.25rem 1.1rem;border-top:1px solid #e2e8f0;background:#fafafe}.cad-q-meta-row{display:flex;gap:.75rem;margin-bottom:.6rem}@media(max-width:768px){.cad-config-row{grid-template-columns:1fr 1fr}.cad-config-total{grid-column:1 / -1;flex-direction:row;gap:.75rem;padding:.6rem 1rem}.cad-pool-stats,.cad-filter-bar{gap:.5rem}.cad-q-search{min-width:100%}.cad-diff-filter{flex-wrap:wrap}}@media(max-width:480px){.cad-config-row{grid-template-columns:1fr}}.cad-q-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.cad-xlsx-modal{max-width:860px;max-height:88vh}.cad-xlsx-errors{background:#fff5f5;border:1.5px solid #fca5a5;border-radius:10px;padding:.85rem 1.1rem;margin-bottom:1rem}.cad-xlsx-error-title{font-size:.85rem;font-weight:700;color:#dc2626;margin-bottom:.5rem}.cad-xlsx-error-list{list-style:disc;padding-left:1.25rem;display:flex;flex-direction:column;gap:.2rem}.cad-xlsx-error-list li{font-size:.82rem;color:#b91c1c}.cad-xlsx-info{background:#fffbeb;border:1.5px solid #fde68a;border-radius:10px;padding:.7rem 1rem;margin-bottom:1rem;font-size:.85rem;color:#92400e}.cad-xlsx-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid #e2e8f0}.cad-xlsx-table{min-width:640px}.cad-xlsx-q-text{max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.88rem}.cad-xlsx-footer-info{font-size:.82rem;color:#94a3b8;flex:1;align-self:center}@media(max-width:768px){.cad-q-actions{gap:.35rem}.cad-xlsx-modal{max-width:100%;border-radius:14px}.cad-xlsx-q-text{max-width:140px}}.cad-hint-text{font-size:.75rem;font-weight:400;color:#94a3b8;margin-left:4px}.cad-subject-id-cell{display:flex;align-items:center;gap:8px}.cad-subject-id-code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:5px;padding:2px 8px;font-size:.8rem;color:#4a5568;font-family:Fira Mono,Consolas,monospace;letter-spacing:.02em;-webkit-user-select:all;user-select:all}.cad-copy-btn{display:inline-flex;align-items:center;gap:3px;padding:2px 10px;font-size:.78rem;background:#667eea;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background .18s,transform .12s;white-space:nowrap;flex-shrink:0}.cad-copy-btn:hover{background:#5a67d8;transform:translateY(-1px)}.cad-copy-btn:active{transform:scale(.96)}.cad-total-row{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:.85rem 1.1rem;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px}.cad-total-input{width:100px!important;font-size:1.15rem!important;font-weight:800!important;color:#4f46e5!important;border-color:#c7d2fe!important;background:#fff!important}.cad-total-input:focus{border-color:#667eea!important;box-shadow:0 0 0 3px #667eea26!important}.cad-pct-section{background:#fafbff;border:1.5px solid #e8ecff;border-radius:12px;padding:1rem 1.1rem 1.1rem}.cad-pct-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.85rem;flex-wrap:wrap;gap:.5rem}.cad-pct-title{font-size:.86rem;font-weight:700;color:#374151}.cad-pct-sum{font-size:.82rem;font-weight:600;padding:.25rem .75rem;border-radius:20px}.cad-pct-sum.ok{background:#dcfce7;color:#15803d}.cad-pct-sum.err{background:#fef2f2;color:#dc2626}.cad-pct-bar{display:flex;height:28px;border-radius:8px;overflow:hidden;margin-bottom:1.1rem;background:#e2e8f0;border:1px solid #e2e8f0}.cad-pct-bar>div{display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:#fff;transition:width .3s ease;min-width:28px;overflow:hidden;white-space:nowrap}.cad-pct-bar-hard{background:linear-gradient(90deg,#f87171,#ef4444)}.cad-pct-bar-mid{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.cad-pct-bar-easy{background:linear-gradient(90deg,#4ade80,#22c55e)}.cad-calc-result{font-size:.82rem;color:#475569;margin-top:.35rem;padding:.3rem .6rem;background:#f1f5f9;border-radius:6px;border:1px solid #e2e8f0}.cad-calc-result strong{font-size:1rem;font-weight:800;color:#4f46e5}.cad-calc-result.over{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.cad-calc-result.over strong{color:#dc2626}.cad-pool-avail{color:#94a3b8;font-size:.78rem}.cad-over-warn{font-weight:700;color:#dc2626;font-size:.8rem}@media(max-width:768px){.cad-total-row{flex-wrap:wrap;gap:.6rem}.cad-pct-bar>div{font-size:.65rem}}.cad-auto-badge{display:inline-block;font-size:.68rem;font-weight:700;background:#dcfce7;color:#15803d;border:1px solid #86efac;border-radius:4px;padding:1px 6px;margin-left:6px;letter-spacing:.02em}.cad-auto-input{display:flex;align-items:center;justify-content:center;background:#f0fdf4!important;border-color:#86efac!important;color:#15803d!important;font-weight:800!important;cursor:default;-webkit-user-select:none;user-select:none;pointer-events:none}.cad-total-row{flex-direction:column;align-items:flex-start;gap:.6rem}.cad-total-left{display:flex;align-items:baseline;gap:.75rem;flex-wrap:wrap}.cad-total-hint{font-size:.8rem;color:#64748b}.cad-total-hint strong{font-size:1rem;font-weight:800;color:#4f46e5}.cad-total-right{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.cad-total-auto{border-color:#818cf8!important;color:#818cf8!important;font-style:italic}.cad-total-over-hint{font-size:.78rem;color:#dc2626;font-weight:600}.cad-total-reset-btn{font-size:.75rem;padding:3px 10px;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:5px;color:#64748b;cursor:pointer;transition:background .15s;white-space:nowrap}.cad-total-reset-btn:hover{background:#e2e8f0;color:#374151}.cad-config-total-auto{font-size:.65rem;font-weight:700;background:#ede9fe;color:#7c3aed;border-radius:4px;padding:1px 5px;margin-top:2px}.cad-ses-meta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.cad-ses-retry-badge{display:inline-flex;align-items:center;gap:.3rem;background:#fef3c7;color:#92400e;border:1px solid #fcd34d;border-radius:20px;padding:.25rem .75rem;font-size:.8rem;font-weight:500}.cad-ses-retry-badge.cad-ses-retry-unlim{background:#eff6ff;color:#1d4ed8;border-color:#93c5fd}.cad-ses-price{font-weight:600;color:#0f172a}.cad-ses-coupon{font-size:.78rem;color:#16a34a;font-weight:500}.cad-ses-detail-btn{white-space:nowrap;font-size:.8rem!important;padding:.3rem .7rem!important;background:#f0f4ff!important;color:#4f46e5!important;border:1px solid #c7d2fe!important;border-radius:8px!important;cursor:pointer;transition:background .15s}.cad-ses-detail-btn:hover{background:#e0e7ff!important}.cad-modal-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1200;padding:1rem}.cad-ses-modal{background:#fff;border-radius:18px;width:100%;max-width:640px;max-height:88vh;overflow-y:auto;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column}.cad-ses-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;flex-shrink:0}.cad-ses-modal-user{display:flex;align-items:center;gap:.9rem}.cad-ses-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cad-ses-modal-name{font-size:1rem;font-weight:700;color:#0f172a;margin:0}.cad-ses-modal-email{font-size:.82rem;color:#64748b;margin:.1rem 0 0}.cad-modal-close{background:none;border:none;font-size:1.1rem;color:#94a3b8;cursor:pointer;padding:.3rem .5rem;border-radius:8px;transition:background .15s,color .15s}.cad-modal-close:hover{background:#f1f5f9;color:#374151}.cad-ses-modal-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-bottom:1px solid #e2e8f0;flex-shrink:0}@media(max-width:560px){.cad-ses-modal-summary{grid-template-columns:repeat(2,1fr)}}.cad-ses-sum-item{display:flex;flex-direction:column;gap:.3rem;padding:1rem 1.25rem;border-right:1px solid #e2e8f0}.cad-ses-sum-item:last-child{border-right:none}.cad-ses-sum-label{font-size:.75rem;color:#94a3b8;font-weight:500;text-transform:uppercase;letter-spacing:.03em}.cad-ses-sum-val{font-size:.95rem;font-weight:600;color:#0f172a;display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.cad-ses-remain{font-size:.78rem;font-weight:400;color:#64748b}.cad-ses-left{color:#16a34a;font-weight:600}.cad-ses-exhausted{color:#dc2626;font-weight:600}.cad-ses-modal-body{padding:1.25rem 1.5rem}.cad-ses-modal-subtitle{font-size:.9rem;font-weight:700;color:#374151;margin:0 0 .8rem}.cad-ses-no-history{text-align:center;padding:2rem 0;color:#64748b;font-size:.9rem}.cad-ses-row-pass{background:#f0fdf4!important}.cad-ses-row-pass td{color:#166534}@media(max-width:768px){.cad-ses-modal{border-radius:14px;max-width:100%}.cad-ses-modal-header,.cad-ses-modal-body{padding:1rem}}.cad-pagination{display:flex;align-items:center;justify-content:center;gap:.3rem;padding:1.2rem 0 .4rem;flex-wrap:wrap}.cad-page-btn{min-width:34px;height:34px;padding:0 .6rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;color:#475569;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;line-height:1}.cad-page-btn:hover:not(:disabled){border-color:#667eea;color:#667eea;background:#f0f1ff}.cad-page-btn.active{background:#667eea;border-color:#667eea;color:#fff;font-weight:700}.cad-page-btn:disabled{opacity:.35;cursor:not-allowed}.cad-page-info{font-size:.82rem;color:#94a3b8;margin-left:.4rem;white-space:nowrap}.cad-ses-search-row{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}.cad-ses-total-badge{font-size:.82rem;color:#64748b;white-space:nowrap;background:#f1f5f9;border-radius:20px;padding:.25rem .75rem;border:1px solid #e2e8f0}.cad-ses-row{transition:background .12s}.cad-ses-row:hover{background:#f8faff!important}.cad-ses-row.selected{background:#eef0ff!important}.cad-side-overlay{position:fixed;inset:0;background:#0f172a59;z-index:1100;display:flex;justify-content:flex-end;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:cad-overlay-in .2s ease}@keyframes cad-overlay-in{0%{opacity:0}to{opacity:1}}.cad-side-panel{width:480px;max-width:95vw;height:100vh;background:#fff;box-shadow:-8px 0 32px #0000002e;overflow-y:auto;display:flex;flex-direction:column;animation:cad-panel-slide-in .25s cubic-bezier(.22,1,.36,1)}@keyframes cad-panel-slide-in{0%{transform:translate(100%);opacity:.5}to{transform:translate(0);opacity:1}}.cad-side-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:2px solid #f1f5f9;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:sticky;top:0;z-index:10}.cad-side-user-info{display:flex;align-items:center;gap:.9rem}.cad-ses-avatar-lg{width:48px;height:48px;font-size:1.4rem;border-radius:14px;background:#ffffff40;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.cad-side-name{font-size:1.05rem;font-weight:700;color:#fff;margin:0}.cad-side-email{font-size:.82rem;color:#fffc;margin:.15rem 0 0}.cad-side-header .cad-modal-close{background:#fff3;border:none;color:#fff;border-radius:8px;width:32px;height:32px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .15s}.cad-side-header .cad-modal-close:hover{background:#ffffff59}.cad-side-section{padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9}.cad-side-section-title{font-size:.82rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin:0 0 .9rem}.cad-side-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem 1rem}.cad-side-info-item{display:flex;flex-direction:column;gap:.18rem}.cad-side-info-label{font-size:.75rem;color:#94a3b8;font-weight:600}.cad-side-info-val{font-size:.88rem;color:#1e293b;font-weight:500;word-break:break-all}.cad-mono{font-family:monospace;letter-spacing:.04em}.cad-side-stats{display:flex;gap:0;border:1.5px solid #e2e8f0;border-radius:12px;overflow:hidden;margin-bottom:.8rem}.cad-side-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem;border-right:1px solid #e2e8f0}.cad-side-stat:last-child{border-right:none}.cad-side-stat-num{font-size:1.35rem;font-weight:800;color:#1e293b;line-height:1}.cad-side-stat-label{font-size:.72rem;color:#94a3b8;margin-top:.3rem;font-weight:500}.cad-side-pass-status{text-align:center}.cad-side-big-badge{font-size:.9rem!important;padding:.4rem 1.2rem!important;border-radius:20px!important}.cad-side-section-history{flex:1;border-bottom:none}.cd-table-sm td,.cd-table-sm th{padding:.5rem .6rem;font-size:.82rem}@media(max-width:640px){.cad-side-panel{width:100vw}.cad-side-info-grid{grid-template-columns:1fr}.cad-pagination{gap:.2rem}.cad-page-btn{min-width:30px;height:30px;font-size:.8rem}}.cad-spm-overlay{position:fixed;inset:0;background:#0000008c;z-index:3000;display:flex;align-items:center;justify-content:center;padding:1rem}.cad-spm-modal{background:#fff;border-radius:16px;width:100%;max-width:1200px;height:80vh;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px #00000038}.cad-spm-header{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem 1rem;border-bottom:1px solid #f1f5f9;flex-shrink:0}.cad-spm-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:1.3rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cad-spm-title-area{flex:1;min-width:0}.cad-spm-name{font-size:1.05rem;font-weight:700;color:#1e293b;margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cad-spm-email{font-size:.82rem;color:#64748b;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cad-spm-header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.cad-spm-close{background:none;border:none;font-size:1.1rem;color:#64748b;cursor:pointer;padding:.35rem;border-radius:6px;transition:background .15s}.cad-spm-close:hover{background:#f1f5f9;color:#1e293b}.cad-spm-tabs{display:flex;gap:0;border-bottom:2px solid #e2e8f0;padding:0 1.5rem;flex-shrink:0;background:#fafbfc}.cad-spm-tab{position:relative;padding:.7rem 1.2rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.875rem;font-weight:600;color:#64748b;cursor:pointer;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:.35rem}.cad-spm-tab:hover{color:#6366f1}.cad-spm-tab.active{color:#6366f1;border-bottom-color:#6366f1}.cad-spm-tab-badge{background:#6366f1;color:#fff;font-size:.7rem;font-weight:700;padding:1px 6px;border-radius:10px}.cad-spm-body{flex:1;overflow-y:auto;padding:1.25rem 1.5rem 1.5rem}.cad-spm-section{display:flex;flex-direction:column;gap:1rem}.cad-spm-info-grid{display:flex;flex-direction:column;gap:0;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.cad-spm-info-row{display:flex;align-items:center;padding:.65rem 1rem;border-bottom:1px solid #f1f5f9;gap:1rem}.cad-spm-info-row:last-child{border-bottom:none}.cad-spm-label{width:90px;flex-shrink:0;font-size:.8rem;color:#64748b;font-weight:500}.cad-spm-value{flex:1;font-size:.875rem;color:#1e293b;word-break:break-all}.cad-spm-coupon{color:#6366f1;font-size:.78rem}.cad-mono{font-family:monospace;font-size:.82rem}.cad-spm-refunded-box{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.4rem}.cad-spm-refunded-row{display:flex;justify-content:space-between;font-size:.85rem}.cad-spm-refund-amt{color:#16a34a}.cad-spm-course-hist{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;padding:.75rem 1rem}.cad-spm-stats-grid{display:flex;gap:.75rem;flex-wrap:wrap}.cad-spm-stat-card{flex:1;min-width:80px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:.75rem .5rem;text-align:center}.cad-spm-stat-value{font-size:1.3rem;font-weight:700;color:#1e293b}.cad-spm-stat-label{font-size:.75rem;color:#64748b;margin-top:2px}.cad-spm-pass-status{text-align:center}@media(max-width:640px){.cad-spm-modal{height:95vh;max-height:95vh;border-radius:12px 12px 0 0;align-self:flex-end}.cad-spm-overlay{align-items:flex-end;padding:0}.cad-spm-info-grid{font-size:.82rem}.cad-spm-stats-grid{gap:.5rem}.cad-spm-stat-card{min-width:70px}}.cd-form-group input:focus,.cd-form-group select:focus,.cd-form-group textarea:focus{border-color:#667eea!important;box-shadow:0 0 0 3px #667eea1a!important}.cd-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;padding:.05rem .4rem;background:#0000001a;color:inherit;border-radius:10px;font-size:.72rem;font-weight:700;vertical-align:middle}.cd-tab.active .cd-tab-badge{background:#ffffff47;color:#fff}.cd-status-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.38rem .85rem;border:1px solid #e2e8f0;border-radius:20px;background:#f8fafc;color:#64748b;font-size:.83rem;font-weight:500;cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.cd-status-btn.active,.cd-status-btn:hover{background:#eef2ff;border-color:#667eea;color:#667eea}.cd-status-btn.active{font-weight:700}.cd-empty-cell{text-align:center;color:#94a3b8;padding:2.5rem!important;font-size:.9rem}.cd-progress-fill{background:#667eea}.cd-code{font-family:Courier New,monospace;background:#eef2ff;padding:.15rem .5rem;border-radius:4px;font-size:.85rem;color:#667eea;font-weight:700;letter-spacing:.04em}.cd-muted{color:#94a3b8;font-size:.83rem}.cd-hint{font-size:.8rem;color:#667eea;margin:.25rem 0 0}.cd-discount-info{display:flex;gap:1.5rem;background:#eef2ff;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.88rem;color:#4051c4;border:1px solid #c7d2fe}.cd-loading-full{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:1rem;color:#64748b;background:#f8fafc}@media(max-width:768px){.cd-tabs{gap:.3rem;padding:.6rem .75rem}.cd-tab{font-size:.78rem;padding:.35rem .65rem}.cd-section-card{padding:1.1rem 1.25rem}}.cad-stat-board{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.75rem}.cad-stat-banner{display:flex;align-items:center;gap:.9rem;padding:.85rem 1.1rem;border-radius:12px;position:relative;overflow:hidden}.cad-stat-banner:before{content:"";position:absolute;inset:0;opacity:.08;border-radius:inherit}.cad-stat-banner-green{background:#f0fdf4;border:1.5px solid #86efac}.cad-stat-banner-red{background:#fff5f5;border:1.5px solid #fca5a5}.cad-stat-banner-gray{background:#f8fafc;border:1.5px solid #e2e8f0}.cad-stat-banner-icon{font-size:1.6rem;flex-shrink:0;line-height:1}.cad-stat-banner-text{flex:1;display:flex;flex-direction:column;gap:2px}.cad-stat-banner-text strong{font-size:.97rem;font-weight:700;color:#1e293b}.cad-stat-banner-text span{font-size:.78rem;color:#64748b}.cad-stat-banner-score{text-align:center;flex-shrink:0;line-height:1}.cad-stat-score-num{font-size:1.6rem;font-weight:800;color:#7c3aed}.cad-stat-score-unit{font-size:.82rem;font-weight:600;color:#7c3aed}.cad-stat-score-label{font-size:.7rem;color:#94a3b8;margin-top:2px}.cad-stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:.5rem}.cad-stat-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:.65rem .5rem .55rem;text-align:center;transition:border-color .2s,background .2s}.cad-stat-card-pass{background:#f0fdf4;border-color:#bbf7d0}.cad-stat-card-fail{background:#fff5f5;border-color:#fecaca}.cad-stat-card-warn{background:#fffbeb;border-color:#fde68a}.cad-stat-card-empty{background:#fff5f5;border-color:#fecaca}.cad-stat-card-value{font-size:1.25rem;font-weight:700;color:#1e293b;line-height:1.2}.cad-stat-card-label{font-size:.7rem;color:#64748b;margin-top:3px}.cad-stat-remain-bar{height:3px;background:#e2e8f0;border-radius:99px;margin-top:6px;overflow:hidden}.cad-stat-remain-fill{height:100%;border-radius:99px;transition:width .4s ease}.cad-spm-pass-status{display:none}.cad-spm-big-badge{font-size:.9rem!important;padding:.4rem 1.2rem!important;border-radius:20px!important}.cad-spm-no-history{text-align:center;padding:2rem 1rem;color:#64748b}.cad-refund-modal{background:#fff;border-radius:14px;width:100%;max-width:480px;padding:1.5rem;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;gap:1rem}.cad-refund-full-amount{font-size:1rem;color:#1e293b;padding:.5rem 0}.cad-refund-full-amount strong{color:#6366f1;font-size:1.1rem}@media(max-width:640px){.cad-spm-modal{max-height:95vh;border-radius:12px 12px 0 0;align-self:flex-end}.cad-spm-overlay{align-items:flex-end;padding:0}.cad-spm-info-grid{font-size:.82rem}.cad-spm-stats-grid{gap:.5rem}.cad-spm-stat-card{min-width:70px}}.cad-answer-modal{background:#fff;border-radius:18px;width:min(92vw,820px);max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040;overflow:hidden}.cad-answer-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9;flex-shrink:0}.cad-answer-title{font-size:1.05rem;font-weight:700;color:#1e293b;margin:0 0 .25rem}.cad-answer-meta{font-size:.82rem;color:#64748b;margin:0}.cad-answer-body{overflow-y:auto;padding:1rem 1.5rem 1.5rem;flex:1}.cad-answer-table{font-size:.82rem}.cad-answer-table th{background:#f8fafc;font-size:.78rem;padding:.5rem .6rem}.cad-answer-table td{padding:.45rem .6rem;vertical-align:middle}.cad-ans-list{display:flex;flex-direction:column;gap:0;overflow-y:auto;flex:1}.cad-ans-list-popup{padding:.75rem 1.25rem 1.25rem}.cad-ans-card{border-radius:0;border-bottom:1px solid #f1f5f9;padding:.85rem 1rem;transition:background .15s}.cad-ans-card:first-child{border-top:1px solid #f1f5f9}.cad-ans-card:hover{background:#fafbfc}.cad-ans-card-ok{border-left:3px solid #86efac}.cad-ans-card-ng{border-left:3px solid #fca5a5}.cad-ans-card-empty{border-left:3px solid #e2e8f0}.cad-ans-card-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.45rem}.cad-ans-qno{display:inline-flex;align-items:center;justify-content:center;min-width:1.6rem;height:1.6rem;border-radius:50%;background:#e2e8f0;color:#475569;font-size:.72rem;font-weight:700;flex-shrink:0}.cad-ans-badge{font-size:.72rem;font-weight:700;padding:.18rem .55rem;border-radius:99px}.cad-ans-badge-ok{background:#dcfce7;color:#15803d}.cad-ans-badge-ng{background:#fee2e2;color:#b91c1c}.cad-ans-badge-empty{background:#f1f5f9;color:#94a3b8}.cad-ans-pts{margin-left:auto;font-size:.72rem;color:#94a3b8;font-weight:600}.cad-ans-qtext{font-size:.875rem;color:#1e293b;line-height:1.55;margin:0 0 .55rem;word-break:break-word;white-space:pre-wrap}.cad-ans-row{display:flex;gap:.5rem}.cad-ans-col{flex:1;border-radius:8px;padding:.5rem .7rem;min-width:0}.cad-ans-col-correct{background:#eff6ff;border:1px solid #bfdbfe}.cad-ans-col-user-ok{background:#f0fdf4;border:1px solid #bbf7d0}.cad-ans-col-user-ng{background:#fff5f5;border:1px solid #fecaca}.cad-ans-col-user-empty{background:#f8fafc;border:1px solid #e2e8f0}.cad-ans-col-label{display:block;font-size:.68rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:#94a3b8;margin-bottom:.3rem}.cad-ans-content{display:flex;align-items:flex-start;gap:.35rem}.cad-ans-text{font-size:.83rem;color:#374151;line-height:1.5;word-break:break-word;white-space:pre-wrap}.cad-ans-text-ok{color:#15803d;font-weight:600}.cad-ans-text-ng{color:#b91c1c;font-weight:600}.cad-spm-history-layout{display:flex;flex:1;overflow:hidden;gap:0}.cad-spm-history-left{width:42%;min-width:300px;overflow-y:auto;padding:1.25rem 1rem 1.25rem 1.5rem;border-right:1px solid #f1f5f9;display:flex;flex-direction:column;gap:0}.cad-spm-history-right{flex:1;overflow-y:auto;display:flex;flex-direction:column}.cad-ses-row-selected td{background:#eff6ff!important;outline:2px solid #3b82f6;outline-offset:-1px}.cad-spm-answer-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#94a3b8;gap:.75rem;font-size:.92rem;text-align:center;padding:2rem}.cad-spm-answer-placeholder span{font-size:2.5rem;opacity:.5}.cad-spm-answer-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.cad-spm-answer-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem;border-bottom:1px solid #f1f5f9;flex-shrink:0;background:#fafbfc;flex-wrap:wrap;gap:.5rem}.cad-spm-answer-title{font-weight:700;color:#1e293b;font-size:.95rem}.cad-spm-answer-score{font-weight:700;font-size:.9rem}.cad-spm-answer-summary{font-size:.8rem;color:#64748b}.cad-spm-answer-table{display:none}.cad-answer-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:4100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}@media(max-width:900px){.cad-spm-history-layout{flex-direction:column}.cad-spm-history-left{width:100%;border-right:none;border-bottom:1px solid #f1f5f9;max-height:50vh;padding:1rem}.cad-spm-history-right{max-height:50vh}}.cad-ans-circle{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:1.3rem;height:1.3rem;border-radius:50%;font-size:.75rem;font-weight:700;line-height:1;margin-top:1px}.cad-ans-circle-blue{background:#dbeafe;color:#1d4ed8}.cad-ans-circle-green{background:#dcfce7;color:#15803d}.cad-ans-circle-red{background:#fee2e2;color:#b91c1c}.cad-ans-subject-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.4rem;padding:.6rem 1rem;background:#f1f5f9;border-top:2px solid #cbd5e1;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:2}.cad-ans-subject-name{font-size:.82rem;font-weight:700;color:#1e293b;letter-spacing:-.01em}.cad-ans-subject-meta{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.cad-ans-subject-stat{font-size:.7rem;font-weight:600;padding:.15rem .45rem;border-radius:99px}.cad-ans-subject-stat-ok{background:#dcfce7;color:#15803d}.cad-ans-subject-stat-ng{background:#fee2e2;color:#b91c1c}.cad-ans-subject-stat-emp{background:#f1f5f9;color:#94a3b8}.cad-ans-subject-pts{font-size:.72rem;font-weight:700;color:#7c3aed;background:#ede9fe;padding:.15rem .5rem;border-radius:99px}.cd-btn-xs--regrade{border-color:#bfdbfe;color:#1d4ed8}.cd-btn-xs--regrade:hover{background:#eff6ff;border-color:#93c5fd}.evl-wrap{max-width:1400px;margin:0 auto;padding:2rem;font-family:Pretendard,Noto Sans KR,sans-serif}.evl-header{margin-bottom:1.5rem}.evl-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.evl-title{font-size:1.55rem;font-weight:700;color:#1e293b;margin:0 0 .3rem}.evl-desc{font-size:.88rem;color:#64748b;margin:0}.evl-stats{display:flex;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.evl-stat-card{flex:1;min-width:140px;padding:1rem 1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:.25rem;box-shadow:0 1px 4px #0000000d;transition:box-shadow .15s}.evl-stat-card:hover{box-shadow:0 4px 14px #00000017}.evl-stat-card--total{border-left:4px solid #64748b}.evl-stat-card--high{border-left:4px solid #ef4444}.evl-stat-card--mid{border-left:4px solid #f97316}.evl-stat-card--unique{border-left:4px solid #667eea}.evl-stat-val{font-size:1.9rem;font-weight:700;color:#1e293b;line-height:1.1}.evl-stat-lbl{font-size:.78rem;color:#64748b}.evl-filter{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.25rem}.evl-filter-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;margin-bottom:.6rem}.evl-filter-row:last-child{margin-bottom:0}.evl-filter-row label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;color:#64748b;font-weight:600}.evl-filter-row input,.evl-filter-row select{border:1px solid #e2e8f0;border-radius:8px;padding:.5rem .85rem;font-size:.875rem;color:#1e293b;background:#f8fafc;min-width:160px;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.evl-filter-row input:focus,.evl-filter-row select:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff;background:#fff}.evl-filter-row input::placeholder{color:#94a3b8}.evl-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s,box-shadow .15s;white-space:nowrap;font-family:inherit}.evl-btn:hover:not(:disabled){opacity:.88}.evl-btn:active:not(:disabled){transform:scale(.97)}.evl-btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.evl-btn--primary{background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;box-shadow:0 2px 8px #667eea59}.evl-btn--ghost{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.evl-btn--ghost:hover:not(:disabled){background:#e2e8f0;opacity:1}.evl-btn--guide{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);color:#0369a1;border:1px solid #bae6fd;box-shadow:0 1px 4px #0369a11f;flex-shrink:0;align-self:flex-start}.evl-btn--guide:hover:not(:disabled){background:linear-gradient(135deg,#e0f2fe,#bae6fd);opacity:1;box-shadow:0 3px 10px #0369a133}.evl-summary{font-size:.88rem;color:#64748b;margin-bottom:.75rem}.evl-summary strong{color:#1e293b}.evl-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.875rem}.evl-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;overflow-x:auto}.evl-table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:760px}.evl-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0}.evl-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.evl-table td{padding:.8rem 1rem;color:#374151;border-bottom:1px solid #f1f5f9;vertical-align:middle}.evl-table tbody tr:last-child td{border-bottom:none}.evl-tr{cursor:pointer;transition:background .12s;border-left:3px solid transparent}.evl-tr:hover td{background:#f8fafc}.evl-tr--high{border-left-color:#ef4444}.evl-tr--mid{border-left-color:#f97316}.evl-tr--low{border-left-color:#eab308}.evl-tr--info{border-left-color:#667eea}.evl-tr--gray{border-left-color:#cbd5e1}.evl-td-time{white-space:nowrap;color:#64748b;font-size:.82rem}.evl-td-email{color:#64748b;font-size:.82rem}.evl-td-uid{font-family:monospace;font-size:.8rem;color:#94a3b8;cursor:help}.evl-empty{text-align:center;padding:3rem 1rem;color:#94a3b8;font-size:.95rem}.evl-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.22rem .65rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.evl-badge--red{background:#fee2e2;color:#991b1b}.evl-badge--orange{background:#ffedd5;color:#9a3412}.evl-badge--yellow{background:#fef9c3;color:#713f12}.evl-badge--blue{background:#dbeafe;color:#1e40af}.evl-badge--gray{background:#f1f5f9;color:#475569}.evl-sev{font-size:.8rem;white-space:nowrap}.evl-loadmore{text-align:center;margin-top:1.5rem}.evl-mono{font-family:monospace;font-size:.78rem;color:#64748b}.evl-modal-overlay{position:fixed;inset:0;background:#0000007a;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:hidden}.evl-modal{background:#fff;border-radius:16px;width:100%;max-width:1400px;height:80vh;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 24px 64px #00000038;animation:evlFadeIn .18s ease;overflow:hidden}@keyframes evlFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.evl-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;border-bottom:1px solid #e2e8f0;flex-shrink:0;gap:.75rem}.evl-modal-header--high{background:#fff5f5;border-bottom-color:#fecaca}.evl-modal-header--mid{background:#fff7ed;border-bottom-color:#fed7aa}.evl-modal-header--low{background:#fefce8;border-bottom-color:#fde68a}.evl-modal-header--info{background:#eff6ff;border-bottom-color:#bfdbfe}.evl-modal-header--gray{background:#f8fafc;border-bottom-color:#e2e8f0}.evl-modal-header-left{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.evl-modal-close{background:#0000000f;border:none;font-size:1.25rem;color:#475569;cursor:pointer;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.evl-modal-close:hover{background:#0000001f;color:#1e293b}.evl-sev-pill{display:inline-flex;align-items:center;gap:.2rem;padding:.2rem .7rem;border-radius:20px;font-size:.78rem;font-weight:700}.evl-sev-pill--high{background:#fee2e2;color:#b91c1c}.evl-sev-pill--mid{background:#ffedd5;color:#c2410c}.evl-sev-pill--low{background:#fef9c3;color:#92400e}.evl-sev-pill--info{background:#dbeafe;color:#1d4ed8}.evl-sev-pill--gray{background:#f1f5f9;color:#475569}.evl-modal-tabs{display:flex;align-items:center;gap:0;padding:0 1.5rem;border-bottom:1px solid #e2e8f0;background:#fff;flex-shrink:0}.evl-modal-tab{display:flex;align-items:center;gap:.4rem;padding:.75rem 1.25rem;font-size:.875rem;font-weight:600;color:#64748b;background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s;white-space:nowrap;font-family:inherit}.evl-modal-tab:hover{color:#334155}.evl-modal-tab--active{color:#667eea;border-bottom-color:#667eea}.evl-modal-tab-icon{font-size:1rem}.evl-modal-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 5px;background:#667eea;color:#fff;font-size:.68rem;font-weight:700;border-radius:10px;margin-left:2px}.evl-modal-alert--banner{border-radius:0;border-left:none;border-right:none;border-top:none;flex-shrink:0}.evl-modal-stats-tab{display:flex;flex-direction:column;gap:1rem}.evl-modal-no-stats{padding:2rem;text-align:center;color:#94a3b8;font-size:.875rem;background:#f8fafc;border:1px dashed #e2e8f0;border-radius:10px}.evl-modal-body{flex:1;min-height:0;overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.evl-modal-body::-webkit-scrollbar{width:5px}.evl-modal-body::-webkit-scrollbar-track{background:#f1f5f9}.evl-modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.evl-modal-alert{display:flex;align-items:flex-start;gap:.6rem;padding:.75rem 1rem;border-radius:9px;font-size:.85rem;line-height:1.5;border:1px solid}.evl-modal-alert--high{background:#fef2f2;color:#991b1b;border-color:#fecaca}.evl-modal-alert--mid{background:#fff7ed;color:#9a3412;border-color:#fed7aa}.evl-modal-alert--low{background:#fefce8;color:#713f12;border-color:#fde68a}.evl-modal-alert--info{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.evl-modal-alert--gray{background:#f8fafc;color:#475569;border-color:#e2e8f0}.evl-modal-alert-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.evl-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.evl-modal-section{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.evl-modal-section--full{grid-column:1 / -1}.evl-modal-section-title{font-size:.82rem;font-weight:700;color:#334155;margin:0;padding:8px 14px;background:#f1f5f9;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:.5rem}.evl-modal-section-count{margin-left:auto;background:#667eea;color:#fff;font-size:.72rem;padding:1px 7px;border-radius:10px}.evl-modal-section-meta{margin-left:auto;font-size:.78rem;font-weight:500;color:#64748b;background:#f1f5f9;padding:1px 10px;border-radius:10px;border:1px solid #e2e8f0}.evl-history{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.75rem}.evl-history-group{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.evl-history-group--current{border-color:#c7d2fe;box-shadow:0 0 0 2px #667eea1f}.evl-history-group-header{display:flex;align-items:center;gap:.5rem;padding:7px 12px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.evl-history-group--current .evl-history-group-header{background:#eff6ff;border-bottom-color:#c7d2fe}.evl-history-group-id{font-family:monospace;font-size:.78rem;color:#475569;font-weight:600}.evl-history-group-count{font-size:.72rem;background:#e2e8f0;color:#64748b;padding:1px 7px;border-radius:10px;font-weight:600}.evl-history-group-now{font-size:.72rem;background:#667eea;color:#fff;padding:1px 8px;border-radius:10px;font-weight:700}.evl-history-group .evl-timeline{padding:.5rem .75rem;gap:0}.evl-modal-dl{display:grid;grid-template-columns:80px 1fr;gap:0;margin:0}.evl-modal-dl dt{font-size:.75rem;font-weight:600;color:#94a3b8;padding:8px 14px;border-bottom:1px solid #f1f5f9;white-space:nowrap;align-self:center;background:#fafbfc}.evl-modal-dl dd{margin:0;font-size:.875rem;color:#1e293b;padding:8px 14px;border-bottom:1px solid #f1f5f9;word-break:break-all;align-self:center}.evl-modal-dl dt:last-of-type,.evl-modal-dl dd:last-of-type{border-bottom:none}.evl-modal-typedesc{display:flex;gap:.5rem;align-items:flex-start;padding:.7rem 1rem;background:#f8fafc;border-top:1px solid #e2e8f0;font-size:.82rem;color:#475569;line-height:1.5}.evl-modal-typedesc-icon{flex-shrink:0;margin-top:1px}.evl-modal-detail-msg{border-top:1px solid #e2e8f0;padding:.75rem 1rem}.evl-modal-detail-label{display:block;font-size:.72rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem}.evl-modal-pre{margin:0;background:#1e293b;color:#a5f3fc;padding:.75rem 1rem;border-radius:7px;font-size:.78rem;font-family:monospace;overflow-x:auto;white-space:pre-wrap;word-break:break-all;line-height:1.55}.evl-modal-user-stats{display:flex;gap:0}.evl-modal-user-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:.9rem .5rem;border-right:1px solid #f1f5f9}.evl-modal-user-stat:last-child{border-right:none}.evl-modal-user-stat-val{font-size:1.6rem;font-weight:700;color:#1e293b;line-height:1}.evl-modal-user-stat-lbl{font-size:.75rem;color:#94a3b8}.evl-modal-user-stat--high .evl-modal-user-stat-val{color:#dc2626}.evl-modal-user-stat--mid .evl-modal-user-stat-val{color:#ea580c}.evl-modal-user-stat--low .evl-modal-user-stat-val{color:#ca8a04}.evl-modal-user-stat--info .evl-modal-user-stat-val{color:#2563eb}.evl-modal-user-stat--gray .evl-modal-user-stat-val{color:#64748b}.evl-modal-user-stat--exam .evl-modal-user-stat-val{color:#667eea}.evl-timeline{padding:.75rem 1rem .5rem;display:flex;flex-direction:column;gap:0}.evl-timeline-item{display:flex;gap:.75rem;align-items:flex-start;padding:.55rem 0;position:relative}.evl-timeline-item:not(:last-child):after{content:"";position:absolute;left:7px;top:26px;width:2px;height:calc(100% - 10px);background:#e2e8f0}.evl-timeline-dot{width:14px;height:14px;border-radius:50%;border:2px solid #e2e8f0;background:#fff;flex-shrink:0;margin-top:4px;position:relative;z-index:1}.evl-timeline-item--high .evl-timeline-dot{border-color:#ef4444;background:#fee2e2}.evl-timeline-item--mid .evl-timeline-dot{border-color:#f97316;background:#ffedd5}.evl-timeline-item--low .evl-timeline-dot{border-color:#eab308;background:#fef9c3}.evl-timeline-item--info .evl-timeline-dot{border-color:#667eea;background:#eff6ff}.evl-timeline-item--current .evl-timeline-dot{transform:scale(1.3);box-shadow:0 0 0 3px #667eea40}.evl-timeline-content{flex:1;min-width:0}.evl-timeline-top{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.evl-timeline-time{font-size:.78rem;color:#94a3b8;white-space:nowrap;font-family:monospace}.evl-timeline-now{font-size:.7rem;font-weight:700;background:#667eea;color:#fff;padding:1px 7px;border-radius:10px;white-space:nowrap}.evl-timeline-detail{font-size:.78rem;color:#64748b;margin-top:3px;line-height:1.45}.evl-modal-footer{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.5rem;border-top:1px solid #e2e8f0;background:#f8fafc;flex-shrink:0;border-radius:0 0 16px 16px}.evl-modal-footer-info{font-size:.78rem;color:#94a3b8}@keyframes evl-spin{to{transform:rotate(360deg)}}.evl-guide-modal{background:#fff;border-radius:16px;width:100%;max-width:1400px;height:80vh;max-height:80vh;min-height:340px;display:flex;flex-direction:column;box-shadow:0 24px 64px #00000038;animation:evlFadeIn .18s ease;overflow:hidden}.evl-guide-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1.25rem;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);flex-shrink:0}.evl-guide-header-left{display:flex;align-items:center;gap:.65rem}.evl-guide-title-icon{font-size:1.6rem;line-height:1;flex-shrink:0}.evl-guide-title{font-size:1.05rem;font-weight:700;color:#0c4a6e;margin:0 0 .15rem;line-height:1.3}.evl-guide-subtitle{font-size:.78rem;color:#0369a1;margin:0;line-height:1.4}.evl-guide-2col{display:flex;flex:1 1 0;min-height:0;overflow:hidden}.evl-guide-nav{width:185px;flex-shrink:0;border-right:1px solid #e2e8f0;background:#f8fafc;display:flex;flex-direction:column;overflow-y:auto;padding:.5rem 0}.evl-guide-nav::-webkit-scrollbar{width:4px}.evl-guide-nav::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.evl-guide-nav-item{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem .7rem .85rem;border:none;background:none;border-left:3px solid transparent;cursor:pointer;font-family:inherit;text-align:left;width:100%;transition:background .12s,border-color .12s}.evl-guide-nav-item:hover{background:#f1f5f9}.evl-guide-nav-item--active{background:#fff!important}.evl-guide-nav-item--active.evl-guide-nav-item--high{border-left-color:#ef4444}.evl-guide-nav-item--active.evl-guide-nav-item--mid{border-left-color:#f97316}.evl-guide-nav-item--active.evl-guide-nav-item--low{border-left-color:#eab308}.evl-guide-nav-item--active.evl-guide-nav-item--info{border-left-color:#667eea}.evl-guide-nav-item--active.evl-guide-nav-item--gray{border-left-color:#94a3b8}.evl-guide-nav-icon{font-size:1.1rem;flex-shrink:0}.evl-guide-nav-text{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.evl-guide-nav-label{font-size:.82rem;font-weight:700;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.evl-guide-nav-item--active .evl-guide-nav-label{color:#1e293b}.evl-guide-nav-count{font-size:.68rem;color:#94a3b8;font-weight:500}.evl-guide-nav-arrow{font-size:1rem;color:#cbd5e1;flex-shrink:0;transition:color .12s}.evl-guide-nav-item--active .evl-guide-nav-arrow{color:#667eea}.evl-guide-nav-footer{margin-top:auto;padding:.6rem .85rem;border-top:1px solid #e2e8f0;display:flex;align-items:flex-start;gap:.35rem;font-size:.7rem;color:#94a3b8;line-height:1.45}.evl-guide-nav-footer code{font-size:.67rem;background:#e2e8f0;padding:0 4px;border-radius:3px;color:#475569;font-family:monospace}.evl-guide-nav-footer strong{color:#64748b}.evl-guide-content{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.evl-guide-content-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.1rem;border-bottom:1px solid #e2e8f0;flex-shrink:0}.evl-guide-content-banner--high{background:#fff5f5}.evl-guide-content-banner--mid{background:#fff7ed}.evl-guide-content-banner--low{background:#fefce8}.evl-guide-content-banner--info{background:#eff6ff}.evl-guide-content-banner--gray{background:#f8fafc}.evl-guide-content-banner-icon{font-size:1.6rem;flex-shrink:0;line-height:1}.evl-guide-content-banner-body{display:flex;flex-direction:column;gap:.25rem}.evl-guide-content-banner-desc{font-size:.78rem;margin:0;line-height:1.5;color:#64748b}.evl-guide-content-banner--high .evl-guide-content-banner-desc{color:#b91c1c}.evl-guide-content-banner--mid .evl-guide-content-banner-desc{color:#c2410c}.evl-guide-content-banner--low .evl-guide-content-banner-desc{color:#92400e}.evl-guide-content-banner--info .evl-guide-content-banner-desc{color:#1d4ed8}.evl-guide-content-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.evl-guide-content-list::-webkit-scrollbar{width:5px}.evl-guide-content-list::-webkit-scrollbar-track{background:#f8fafc}.evl-guide-content-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.evl-guide-content-list::-webkit-scrollbar-thumb:hover{background:#667eea}.evl-guide-type-row{display:flex;flex-direction:column;gap:.3rem;padding:.75rem 1.1rem;border-bottom:1px solid #f1f5f9;transition:background .1s}.evl-guide-type-row:last-child{border-bottom:none}.evl-guide-type-row:hover{background:#f8fafc}.evl-guide-type-row-top{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.evl-guide-type-code{font-family:monospace;font-size:.72rem;color:#64748b;background:#f1f5f9;padding:1px 6px;border-radius:4px;border:1px solid #e2e8f0;white-space:nowrap}.evl-guide-type-desc{font-size:.8rem;color:#475569;line-height:1.55;margin:0}.evl-guide-footer{border-radius:0 0 16px 16px}@media(max-width:640px){.evl-modal-grid{grid-template-columns:1fr}.evl-modal{max-width:100%;border-radius:16px 16px 0 0;height:92svh;max-height:92svh}.evl-modal-overlay{align-items:flex-end;padding:0}.evl-modal-footer{border-radius:0}.evl-modal-tabs{padding:0 .75rem}.evl-modal-tab{padding:.65rem .85rem;font-size:.82rem}.evl-guide-modal{max-width:100%;border-radius:16px 16px 0 0;height:92svh;max-height:92svh}.evl-guide-2col{flex-direction:column}.evl-guide-nav{width:100%;flex-direction:row;flex-wrap:nowrap;border-right:none;border-bottom:1px solid #e2e8f0;padding:.4rem .5rem;gap:.3rem;overflow-y:visible;overflow-x:auto}.evl-guide-nav-item{flex:0 0 auto;padding:.35rem .75rem;border-left:none;border-bottom:2px solid transparent;border-radius:20px;width:auto}.evl-guide-nav-item--active{background:#f1f5f9!important;border-radius:20px}.evl-guide-nav-item--active.evl-guide-nav-item--high{border-bottom-color:#ef4444;border-left-color:transparent}.evl-guide-nav-item--active.evl-guide-nav-item--mid{border-bottom-color:#f97316;border-left-color:transparent}.evl-guide-nav-item--active.evl-guide-nav-item--low{border-bottom-color:#eab308;border-left-color:transparent}.evl-guide-nav-item--active.evl-guide-nav-item--info{border-bottom-color:#667eea;border-left-color:transparent}.evl-guide-nav-item--active.evl-guide-nav-item--gray{border-bottom-color:#94a3b8;border-left-color:transparent}.evl-guide-nav-text{flex-direction:row;gap:.3rem;align-items:center}.evl-guide-nav-count,.evl-guide-nav-arrow,.evl-guide-nav-footer{display:none}.evl-guide-footer{border-radius:0}}@media(max-width:768px){.evl-wrap{padding:1rem 1rem 2rem}.evl-filter-row{flex-direction:column;align-items:stretch}.evl-filter-row label{width:100%}.evl-filter-row input,.evl-filter-row select{min-width:unset;width:100%}.evl-stats{gap:.75rem}.evl-stat-card{min-width:calc(50% - .375rem)}.evl-btn{justify-content:center}.evl-header-top{flex-direction:column}.evl-btn--guide{width:100%;justify-content:center}}.iaa-wrap{max-width:1280px;margin:0 auto;padding:1.5rem 1.25rem 4rem;background:#f8fafc;min-height:100vh}.iaa-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:1rem;color:#64748b}.iaa-spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:iaa-spin .7s linear infinite}@keyframes iaa-spin{to{transform:rotate(360deg)}}.iaa-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.iaa-title{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0 0 .3rem;border-left:4px solid #667eea;padding-left:.75rem}.iaa-subtitle{font-size:.88rem;color:#64748b;margin:0;padding-left:1.15rem}.iaa-stat-row{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}.iaa-stat-card{flex:1;min-width:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:1rem .75rem;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .18s}.iaa-stat-card:hover,.iaa-stat-card.active{border-color:#667eea;box-shadow:0 4px 14px #667eea2e;transform:translateY(-2px)}.iaa-stat-card.active{background:#eef0fe}.iaa-stat-num{font-size:1.6rem;font-weight:800;color:#1e293b;line-height:1}.iaa-stat-label{font-size:.78rem;color:#64748b;font-weight:500}.iaa-stat-card--orange.active{border-color:#fb923c;background:#fff7ed}.iaa-stat-card--orange .iaa-stat-num{color:#ea580c}.iaa-stat-card--blue.active{border-color:#60a5fa;background:#eff6ff}.iaa-stat-card--blue .iaa-stat-num{color:#2563eb}.iaa-stat-card--green.active{border-color:#4ade80;background:#f0fdf4}.iaa-stat-card--green .iaa-stat-num{color:#16a34a}.iaa-stat-card--red.active{border-color:#f87171;background:#fef2f2}.iaa-stat-card--red .iaa-stat-num{color:#dc2626}.iaa-toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:.75rem 1rem}.iaa-search{flex:1;border:none;outline:none;font-size:.9rem;color:#1e293b;background:transparent}.iaa-search::placeholder{color:#cbd5e1}.iaa-count{font-size:.82rem;color:#94a3b8;white-space:nowrap;font-weight:500}.iaa-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.iaa-table{width:100%;border-collapse:collapse;font-size:.86rem}.iaa-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0}.iaa-table th{padding:.75rem 1rem;text-align:left;font-size:.76rem;font-weight:600;color:#64748b;text-transform:uppercase;white-space:nowrap;letter-spacing:.04em}.iaa-tr{border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .15s}.iaa-tr:last-child{border-bottom:none}.iaa-tr:hover{background:#f8fafc}.iaa-table td{padding:.75rem 1rem;color:#374151;vertical-align:middle}.iaa-td-date{color:#94a3b8;font-size:.8rem;white-space:nowrap}.iaa-td-name{font-weight:600;color:#1e293b}.iaa-td-email{color:#667eea;font-size:.82rem}.iaa-td-field{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.iaa-edu-badge{display:inline-block;padding:.2rem .6rem;background:#eef0fe;color:#4f46e5;border-radius:20px;font-size:.76rem;font-weight:600;white-space:nowrap}.iaa-status-badge{display:inline-block;padding:.2rem .7rem;border-radius:20px;font-size:.76rem;font-weight:600;white-space:nowrap}.iaa-status--orange{background:#fff7ed;color:#ea580c;border:1px solid #fed7aa}.iaa-status--blue{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.iaa-status--green{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.iaa-status--red{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.iaa-status-select{padding:.28rem .5rem;font-size:.8rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#f8fafc;color:#374151;cursor:pointer;outline:none;transition:border-color .2s}.iaa-status-select:focus{border-color:#667eea}.iaa-status-select:disabled{opacity:.6;cursor:not-allowed}.iaa-status-select--lg{padding:.4rem .75rem;font-size:.88rem}.iaa-empty{text-align:center;padding:3rem;color:#94a3b8;font-size:.95rem}.iaa-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9000;padding:1rem}.iaa-modal{background:#fff;border-radius:20px;width:100%;max-width:1200px;height:80vh;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000038;overflow:hidden}.iaa-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.5rem 1.75rem 1rem;border-bottom:1px solid #f0f0f0;background:linear-gradient(135deg,#667eea,#764ba2)}.iaa-modal-title{font-size:1.2rem;font-weight:800;color:#fff;margin:0 0 .2rem}.iaa-modal-sub{font-size:.82rem;color:#ffffffbf;margin:0}.iaa-modal-close{background:#fff3;border:none;color:#fff;font-size:1.1rem;cursor:pointer;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.iaa-modal-close:hover{background:#ffffff59}.iaa-modal-body{overflow-y:auto;padding:1.5rem 1.75rem;flex:1;display:flex;flex-direction:column;gap:1.5rem}.iaa-modal-status-row{display:flex;align-items:center;gap:.75rem;padding:.9rem 1.1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;flex-wrap:wrap}.iaa-modal-status-label{font-size:.85rem;font-weight:600;color:#374151}.iaa-modal-section{display:flex;flex-direction:column;gap:.75rem}.iaa-modal-section-title{font-size:.9rem;font-weight:700;color:#667eea;margin:0;padding-bottom:.5rem;border-bottom:1px solid #e2e8f0}.iaa-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.iaa-info-item{display:flex;flex-direction:column;gap:.2rem;padding:.6rem .75rem;background:#f8fafc;border-radius:8px;border:1px solid #f1f5f9}.iaa-info-item--full{grid-column:1 / -1}.iaa-info-label{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.iaa-info-value{font-size:.88rem;color:#1e293b;font-weight:500;line-height:1.5;white-space:pre-wrap}.iaa-modal-text-block{padding:.75rem;background:#f8fafc;border-radius:8px;border:1px solid #f1f5f9}.iaa-modal-field-label{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;margin:0 0 .35rem;letter-spacing:.04em}.iaa-modal-field-value{font-size:.88rem;color:#374151;margin:0;white-space:pre-wrap;line-height:1.6}.iaa-file-links{display:flex;flex-direction:column;gap:.5rem}.iaa-file-link{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem .9rem;background:#eef0fe;color:#4f46e5;border-radius:8px;font-size:.85rem;font-weight:600;text-decoration:none;border:1px solid #c7d2fe;transition:all .15s}.iaa-file-link:hover{background:#667eea;color:#fff;border-color:#667eea}.iaa-no-files{color:#94a3b8;font-size:.85rem;margin:0;padding:.5rem 0}.iaa-modal-footer{padding:1rem 1.75rem;border-top:1px solid #f0f0f0;display:flex;justify-content:flex-end}.iaa-btn-close{padding:.55rem 1.5rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;font-size:.88rem;font-weight:600;color:#374151;cursor:pointer;transition:all .15s}.iaa-btn-close:hover{background:#e2e8f0}@media(max-width:768px){.iaa-stat-row{gap:.5rem}.iaa-stat-card{padding:.75rem .5rem}.iaa-stat-num{font-size:1.3rem}.iaa-table{font-size:.8rem}.iaa-table th,.iaa-table td{padding:.6rem}.iaa-modal{max-width:98vw;max-height:88vh;height:88vh}.iaa-info-grid{grid-template-columns:1fr}.iaa-info-item--full{grid-column:1}}@media(max-width:480px){.iaa-wrap{padding:1rem .75rem 3rem}.iaa-title{font-size:1.2rem}}.iaa-file-name-only{display:flex;align-items:center;gap:.6rem;padding:.6rem .9rem;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;font-size:.875rem;color:#92400e;flex-wrap:wrap}.iaa-file-url-missing{font-size:.75rem;color:#b45309;background:#fef3c7;border-radius:4px;padding:.15rem .45rem;font-weight:600}.iaa-curriculum-text{margin:0;padding:1rem 1.2rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;line-height:1.8;color:#334155;white-space:pre-wrap;word-break:break-word;font-family:Pretendard,Apple SD Gothic Neo,sans-serif}:root{--color-primary: #4F46E5;--color-primary-light: #6366F1;--color-primary-dark: #4338CA;--color-secondary: #F59E0B;--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-info: #3B82F6;--color-text-primary: #1F2937;--color-text-secondary: #6B7280;--color-text-light: #9CA3AF;--color-background: #FFFFFF;--color-background-light: #FFFFFF;--color-border: #E5E7EB;--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-code: "Courier New", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--border-radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--transition-fast: .15s ease-in-out;--transition-base: .3s ease-in-out;--transition-slow: .5s ease-in-out}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-primary);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}.btn{display:inline-block;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);text-align:center;border:none;border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-base);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-outline{background-color:transparent;border:2px solid var(--color-primary);color:var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary);color:#fff}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);border:2px solid var(--color-border);border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a8a1a}.error-message{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.text-center{text-align:center}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mt-4{margin-top:var(--spacing-xl)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.mb-4{margin-bottom:var(--spacing-xl)}body{margin:0;padding:0;font-family:var(--font-family-base)}#root{min-height:100vh}
