:root{--font-sans:"Noto Sans KR", sans-serif;--font-title:"Outfit", "Noto Sans KR", sans-serif;--bg-dark:#070a13;--bg-card:#0f172aa6;--bg-card-hover:#17255473;--border-glass:#ffffff14;--border-glass-active:#8b5cf666;--primary:#8b5cf6;--primary-glow:#8b5cf659;--secondary:#6366f1;--accent:#ec4899;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--shadow-lg:0 20px 25px -5px #00000080, 0 10px 10px -5px #0006;--shadow-neon:0 0 15px #8b5cf640;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-dark);color:var(--text-primary);background-image:radial-gradient(at 0 0,#6366f11f 0,#0000 50%),radial-gradient(at 50% 0,#8b5cf614 0,#0000 50%),radial-gradient(at 100% 100%,#ec48990f 0,#0000 50%);background-attachment:fixed;min-height:100vh;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0f172a80}::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#8b5cf680}h1,h2,h3,h4,h5,h6{font-family:var(--font-title);letter-spacing:-.02em;font-weight:700}button,input,select,textarea{font-family:inherit}.main-header{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-glass);z-index:50;background:#0f172a73;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.header-logo{cursor:pointer;align-items:center;gap:10px;display:flex}.header-logo-icon{color:var(--primary);filter:drop-shadow(0 0 8px var(--primary-glow))}.header-title{background:linear-gradient(135deg, var(--text-primary) 30%, var(--primary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:20px;font-weight:800}.header-actions{align-items:center;gap:12px;display:flex}.app-root-layout{flex-direction:column;min-height:100vh;transition:padding-right .3s;display:flex}.app-root-layout.drawer-open{padding-right:380px}@media (width<=1024px){.app-root-layout.drawer-open{padding-right:0}}.app-main-content{box-sizing:border-box;flex-grow:1;width:100%;max-width:1280px;margin:0 auto;padding:32px 24px}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex;box-shadow:0 4px 12px #8b5cf640}.btn-primary:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary.loading{background:var(--text-muted);cursor:wait}.btn-primary.success{background:var(--success)}.btn-primary-soft{color:var(--primary);cursor:pointer;background:#8b5cf61a;border:1px solid #8b5cf640;border-radius:10px;align-items:center;gap:6px;padding:10px 18px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary-soft:hover{color:#fff;background:#8b5cf62e;border-color:#8b5cf666}.btn-danger-soft{color:var(--danger);cursor:pointer;background:#ef444414;border:1px solid #ef444433;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;transition:all .2s;display:inline-flex}.btn-danger-soft:hover{background:#ef44442e;border-color:#ef444459}.btn-danger{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 14px;font-size:13px;transition:all .2s}.btn-danger:hover{background:#dc2626;box-shadow:0 0 10px #ef44444d}.btn-icon-only{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:inline-flex}.btn-icon-only:hover{color:var(--text-primary);background:#ffffff0d}.btn-icon-only.text-danger:hover{color:var(--danger);background:#ef44441a}.btn-text-icon{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;font-size:14px;transition:all .2s;display:inline-flex}.btn-text-icon:hover{color:var(--text-primary)}.btn-large{width:100%;padding:14px 28px;font-size:16px}.input-group{align-items:center;width:100%;display:flex;position:relative}.input-icon{color:var(--text-muted);width:18px;height:18px;position:absolute;left:14px}.input-group input{border:1px solid var(--border-glass);width:100%;color:var(--text-primary);background:#0f172a99;border-radius:10px;outline:none;padding:12px 16px 12px 42px;font-size:14px;transition:all .2s}.input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow);background:#0f172ad9}.alert{box-sizing:border-box;border-radius:8px;align-items:flex-start;gap:10px;margin-top:12px;padding:12px 16px;font-size:13px;line-height:1.4;display:flex}.alert-danger{color:#fca5a5;background:#ef444414;border:1px solid #ef444433}.alert-success{color:#a7f3d0;background:#10b98114;border:1px solid #10b98133}.alert-icon{flex-shrink:0;width:16px;height:16px;margin-top:2px}.setup-container{justify-content:center;align-items:center;min-height:80vh;padding:24px;display:flex}.setup-glass-card{background:var(--bg-card);border:1px solid var(--border-glass);width:100%;max-width:520px;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(16px);text-align:center;border-radius:20px;padding:40px}.setup-header{margin-bottom:30px}.logo-badge{border:1px solid var(--border-glass-active);width:56px;height:56px;box-shadow:var(--shadow-neon);background:#8b5cf626;border-radius:16px;justify-content:center;align-items:center;margin-bottom:20px;display:inline-flex}.logo-icon{color:var(--primary);width:28px;height:28px}.setup-glass-card h1{margin-bottom:6px;font-size:26px}.setup-glass-card .subtitle{color:var(--text-secondary);font-size:14px}.setup-body .description{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.6}.info-box{border:1px solid var(--border-glass);text-align:left;background:#ffffff05;border-radius:12px;margin-bottom:24px;padding:18px}.info-box h4{color:var(--text-primary);margin-bottom:10px;font-size:13px}.info-box ol{color:var(--text-secondary);padding-left:20px;font-size:12.5px;line-height:1.7}.link-highlight{color:var(--primary);font-weight:500;text-decoration:none}.link-highlight:hover{text-decoration:underline}.setup-form{flex-direction:column;gap:16px;display:flex}.builder-container{max-width:720px;margin:40px auto}.builder-header{text-align:center;margin-bottom:32px}.builder-header h1{background:linear-gradient(135deg, #fff 40%, var(--primary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:10px;font-size:28px}.builder-header p{color:var(--text-secondary);font-size:14px;line-height:1.6}.builder-card{background:var(--bg-card);border:1px solid var(--border-glass);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);border-radius:18px;padding:32px}.builder-form{flex-direction:column;gap:24px;display:flex}.form-group{text-align:left;flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-primary);align-items:center;gap:6px;font-size:14px;font-weight:600;display:flex}.form-label-icon{width:16px;height:16px;color:var(--primary)}.topic-input-wrapper{flex-direction:column;gap:4px;display:flex}.topic-input-wrapper input{border:1px solid var(--border-glass);color:var(--text-primary);background:#0f172a80;border-radius:10px;outline:none;padding:14px 18px;font-size:15px;transition:all .2s}.topic-input-wrapper input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow);background:#0f172abf}.input-hint{color:var(--text-muted);font-size:11.5px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=600px){.form-row{grid-template-columns:1fr}}.form-group select{border:1px solid var(--border-glass);color:var(--text-primary);cursor:pointer;background:#0f172a80;border-radius:10px;outline:none;padding:14px;font-size:14px;transition:all .2s}.form-group select:focus{border-color:var(--primary);background:#0f172abf}.recommend-topics{text-align:center;margin-top:32px}.recommend-topics h4{color:var(--text-secondary);margin-bottom:12px;font-size:13.5px}.topic-tags{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.tag{border:1px solid var(--border-glass);color:var(--text-secondary);cursor:pointer;background:#ffffff08;border-radius:20px;padding:8px 14px;font-size:12px;transition:all .2s}.tag:hover{border-color:var(--border-glass-active);color:var(--text-primary);background:#8b5cf61a}.loader-container{justify-content:center;align-items:center;min-height:80vh;padding:24px;display:flex}.loader-card{background:var(--bg-card);border:1px solid var(--border-glass);text-align:center;-webkit-backdrop-filter:blur(16px);width:100%;max-width:600px;box-shadow:var(--shadow-lg);border-radius:20px;padding:40px}.spinner-glow{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);width:72px;height:72px;box-shadow:0 0 25px var(--primary-glow);border-radius:50%;justify-content:center;align-items:center;margin-bottom:24px;padding:2px;display:inline-flex}.spinner-glow.mini{width:48px;height:48px;margin-bottom:16px}.spinner-inner{background:var(--bg-dark);border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.spinner-icon{color:var(--primary);width:32px;height:32px}.spinner-glow.mini .spinner-icon{width:20px;height:20px}.loader-card h3{margin-bottom:6px;font-size:22px}.loader-subtitle{color:var(--primary);margin-bottom:30px;font-size:13.5px;font-weight:500}.progress-steps-container{text-align:left;flex-direction:column;gap:16px;max-width:460px;margin:0 auto 30px;display:flex}.progress-step-item{opacity:.35;align-items:center;gap:14px;transition:all .3s;display:flex}.progress-step-item.active{opacity:1;transform:translate(4px)}.progress-step-item.completed{opacity:.75}.step-icon-wrapper{border:1px solid var(--border-glass);background:#ffffff05;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.progress-step-item.active .step-icon-wrapper{border-color:var(--border-glass-active);background:#8b5cf626;box-shadow:0 0 10px #8b5cf633}.progress-step-item.completed .step-icon-wrapper{background:#10b98126;border-color:#10b9814d}.step-icon{width:16px;height:16px;color:var(--text-muted)}.progress-step-item.active .step-icon{color:var(--primary)}.progress-step-item.completed .step-icon{color:var(--success)}.step-text{color:var(--text-secondary);font-size:13px}.progress-step-item.active .step-text{color:var(--text-primary);font-weight:500}.loader-tip{color:var(--text-muted);background:#ffffff03;border:1px solid #ffffff08;border-radius:8px;padding:10px;font-size:12px}.dashboard-container{flex-direction:column;gap:24px;display:flex}.dashboard-card{background:var(--bg-card);border:1px solid var(--border-glass);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);border-radius:16px;padding:24px}.hero-stats-card{position:relative;overflow:hidden}.hero-stats-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#8b5cf626 0%,#0000 70%);width:120px;height:120px;position:absolute;top:0;right:0}.stats-main-info{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.stats-text-block{text-align:left;max-width:80%}.level-badge{letter-spacing:.05em;text-transform:uppercase;color:var(--primary);background:#8b5cf626;border:1px solid #8b5cf640;border-radius:6px;margin-bottom:8px;padding:4px 8px;font-size:11px;font-weight:700;display:inline-block}.stats-text-block h2{margin-bottom:8px;font-size:24px}.curriculum-overview{color:var(--text-secondary);font-size:13.5px;line-height:1.5}.stats-row{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}@media (width<=600px){.stats-row{grid-template-columns:1fr}}.stat-box{border:1px solid var(--border-glass);text-align:left;background:#ffffff05;border-radius:12px;padding:16px}.stat-label{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:6px;font-size:12px;display:flex}.stat-svg-icon{width:14px;height:14px}.text-orange{color:#f97316}.text-purple{color:var(--primary)}.stat-value{font-size:20px;font-weight:700;font-family:var(--font-title)}.progress-section{text-align:left}.progress-text-row{color:var(--text-secondary);justify-content:space-between;margin-bottom:8px;font-size:13px;font-weight:500;display:flex}.percentage-glow{color:var(--primary);text-shadow:0 0 10px #8b5cf64d;font-weight:700}.progress-bar-track{background:#ffffff0d;border-radius:4px;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--primary) 0%, var(--secondary) 100%);height:100%;box-shadow:0 0 10px var(--primary-glow);border-radius:4px;transition:width .6s cubic-bezier(.4,0,.2,1)}.dashboard-grid{grid-template-columns:3fr 2fr;gap:24px;display:grid}@media (width<=1024px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-grid-left,.dashboard-grid-right{flex-direction:column;display:flex}.calendar-card{background:var(--bg-card);border:1px solid var(--border-glass);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);text-align:left;border-radius:16px;height:100%;padding:24px}.calendar-header{margin-bottom:20px}.calendar-header h3{align-items:center;gap:8px;margin-bottom:4px;font-size:17px;display:flex}.calendar-subtitle{color:var(--text-muted);font-size:12px}.calendar-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;display:grid}.calendar-day-card{border:1px solid var(--border-glass);text-align:center;cursor:pointer;background:#ffffff04;border-radius:12px;flex-direction:column;align-items:center;padding:16px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.calendar-day-card:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-glass-active);transform:translateY(-3px);box-shadow:0 5px 15px #8b5cf626}.calendar-day-card.active{border-color:var(--primary);background:#8b5cf60d;box-shadow:0 0 12px #8b5cf633}.calendar-day-card.active:before{content:"";background:var(--primary);width:100%;height:3px;position:absolute;top:0;left:0}.calendar-day-card.completed{background:#10b98105;border-color:#10b98133}.calendar-day-card.locked{opacity:.4;cursor:not-allowed}.day-number{color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.calendar-day-card.active .day-number{color:var(--primary)}.calendar-day-card.completed .day-number{color:var(--success)}.day-status-icon{margin-bottom:12px}.icon-wrap{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.icon-wrap.completed{color:var(--success);background:#10b98126}.icon-wrap.active{color:var(--primary);background:#8b5cf626}.icon-wrap.locked{color:var(--text-muted);background:#ffffff05}.status-svg{width:14px;height:14px}.day-card-title{color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;height:34px;margin-bottom:8px;font-size:12px;font-weight:500;line-height:1.4;display:-webkit-box;overflow:hidden}.day-card-badge-container{flex-direction:column;align-items:center;gap:4px;display:flex}.day-score-badge{color:var(--accent);background:#ec489926;border:1px solid #ec489940;border-radius:4px;padding:1px 6px;font-size:9.5px;font-weight:700}.day-complete-badge{color:var(--success);background:#10b98126;border-radius:4px;padding:1px 6px;font-size:9.5px;font-weight:600}.day-status-text{color:var(--text-muted);font-size:10px;font-weight:500}.pulsing-text{color:var(--primary);animation:2s infinite pulseText}@keyframes pulseText{0%,to{opacity:.6}50%{opacity:1}}.badge-card{height:100%}.badges-list{flex-direction:column;gap:14px;display:flex}.badge-item{border:1px solid var(--border-glass);background:#ffffff03;border-radius:12px;align-items:center;gap:14px;padding:12px;transition:all .25s;display:flex}.badge-item.locked{opacity:.5}.badge-item:hover:not(.locked){background:#ffffff08;transform:translate(3px)}.badge-icon-frame{border:1px solid #0000;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:all .3s;display:flex}.badge-icon-svg{width:20px;height:20px}.badge-info{text-align:left}.badge-name{color:var(--text-primary);margin-bottom:2px;font-size:13.5px;font-weight:700}.badge-item.locked .badge-name{color:var(--text-muted)}.badge-desc{color:var(--text-secondary);font-size:11px}.active-action-banner{border:1px solid var(--border-glass-active);text-align:left;box-shadow:var(--shadow-neon);background:linear-gradient(135deg,#8b5cf626 0%,#6366f126 100%);border-radius:16px;justify-content:space-between;align-items:center;padding:24px;display:flex}@media (width<=600px){.active-action-banner{text-align:center;flex-direction:column;gap:16px}}.banner-text h4{margin-bottom:4px;font-size:17px}.banner-text p{color:var(--text-secondary);font-size:13px}.study-room-layout{flex-direction:column;gap:24px;display:flex}.study-header-bar{border:1px solid var(--border-glass);background:#0f172a59;border-radius:12px;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}@media (width<=600px){.study-header-bar{flex-direction:column;align-items:flex-start;gap:12px}}.study-title-group{align-items:center;gap:10px;display:flex}.study-day-badge{background:var(--primary);color:#fff;border-radius:4px;padding:2px 8px;font-size:12px;font-weight:700}.status-badge-complete{color:var(--success);background:#10b9811f;border:1px solid #10b98140;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.status-badge-progress{color:var(--warning);background:#f59e0b1f;border:1px solid #f59e0b40;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.study-grid-main{grid-template-columns:3fr 1.6fr;gap:24px;display:grid}@media (width<=1024px){.study-grid-main{grid-template-columns:1fr}}.study-content-area{flex-direction:column;gap:24px;display:flex}.study-card{background:var(--bg-card);border:1px solid var(--border-glass);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);text-align:left;border-radius:16px;padding:24px}.section-title-wrap{align-items:center;gap:8px;margin-bottom:12px;display:flex}.sec-icon{width:20px;height:20px}.text-red{color:#ef4444}.text-pink{color:var(--accent)}.text-indigo{color:var(--secondary)}.sec-desc{color:var(--text-secondary);margin-bottom:20px;font-size:12.5px}.card-header-actions{border-bottom:1px solid var(--border-glass);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:14px;display:flex}.btn-tts{border:1px solid var(--border-glass);color:var(--text-secondary);cursor:pointer;background:#ffffff05;border-radius:8px;align-items:center;gap:8px;padding:8px 14px;font-size:12.5px;font-weight:500;transition:all .2s;display:inline-flex}.btn-tts:hover{border-color:var(--border-glass-active);color:var(--primary);background:#8b5cf61a}.btn-tts.playing{border-color:var(--primary);color:var(--text-primary);background:#8b5cf626}.audio-wave{align-items:flex-end;gap:2px;height:12px;margin-left:2px;display:flex}.wave-bar{background:var(--primary);border-radius:1px;width:2px;height:3px;animation:.8s infinite alternate audioBounce}.wave-bar:nth-child(2){height:6px;animation-delay:.15s}.wave-bar:nth-child(3){height:4px;animation-delay:.3s}.wave-bar:nth-child(4){height:8px;animation-delay:.45s}@keyframes audioBounce{0%{height:2px}to{height:12px}}.day-overview-summary{color:var(--primary);border-left:3px solid var(--primary);background:#8b5cf60d;border-radius:4px;margin-bottom:24px;padding:12px 16px;font-size:14px;font-weight:500;line-height:1.5}.concepts-markdown-render{color:var(--text-primary);font-size:15px;line-height:1.7}.concepts-markdown-render p{margin-bottom:16px}.concepts-markdown-render h4,.concepts-markdown-render h3{color:var(--text-primary);border-bottom:1px solid #ffffff08;margin:28px 0 12px;padding-bottom:6px;font-weight:700}.concepts-markdown-render ul,.concepts-markdown-render ol{margin-bottom:16px;padding-left:24px}.concepts-markdown-render li{margin-bottom:6px}.concepts-markdown-render blockquote{border-left:4px solid var(--border-glass-active);color:var(--text-secondary);margin:16px 0;padding-left:16px;font-style:italic}.youtube-videos-list{flex-direction:column;gap:20px;display:flex}.youtube-video-item{border:1px solid var(--border-glass);background:#ffffff03;border-radius:12px;padding:16px}.video-meta-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.video-tag{color:#fca5a5;background:#ef444426;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.video-title{color:var(--text-primary);text-align:left;flex-grow:1;font-size:14.5px;font-weight:600}.video-duration{color:var(--text-secondary);font-size:11.5px}.video-iframe-wrapper{border:1px solid var(--border-glass);border-radius:10px;height:0;padding-bottom:56.25%;position:relative;overflow:hidden}.video-iframe-wrapper iframe{width:100%;height:100%;position:absolute;top:0;left:0}.video-link-fallback,.no-video-fallback{border:1px dashed var(--border-glass);background:#ffffff01;border-radius:10px;flex-direction:column;align-items:center;gap:12px;padding:24px;display:flex}.video-link-fallback p,.no-video-fallback p{color:var(--text-secondary);text-align:center;font-size:12.5px}.study-sidebar-area{flex-direction:column;gap:24px;display:flex}.flashcards-wrapper{flex-direction:column;gap:16px;display:flex}.flashcard-scene{perspective:600px;cursor:pointer;height:140px}.flashcard-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1);position:relative}.flashcard-inner.is-flipped{transform:rotateY(180deg)}.flashcard-face{backface-visibility:hidden;text-align:center;box-sizing:border-box;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:absolute;box-shadow:0 4px 10px #00000040}.flashcard-front{border:1px solid var(--border-glass);color:var(--text-primary);background:linear-gradient(135deg,#1e293bcc 0%,#0f172acc 100%)}.flashcard-front h4{color:var(--primary);text-shadow:0 0 10px #8b5cf626;margin-bottom:6px;font-size:15px;font-weight:700}.flashcard-back{border:1px solid var(--border-glass-active);color:var(--text-primary);background:linear-gradient(135deg,#581c8733 0%,#0f172af2 100%);transform:rotateY(180deg)}.flashcard-back p{color:var(--text-secondary);font-size:12.5px;line-height:1.5}.card-hint{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:9.5px;font-weight:700}.card-hint-back{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:9.5px;font-weight:700}.flip-prompt,.flip-prompt-back{color:var(--text-muted);font-size:10px;position:absolute;bottom:8px}.flip-prompt-back{color:var(--primary);opacity:.6}.challenge-trigger-card{background:linear-gradient(135deg,#ec489908 0%,#0f172abf 100%);border-color:#ec489933;position:relative;overflow:hidden}.section-glow-bubble{background:var(--accent);filter:blur(40px);opacity:.2;border-radius:50%;width:100px;height:100px;position:absolute;top:-40px;right:-40px}.challenge-trigger-card h3{margin-bottom:8px;font-size:18px}.challenge-trigger-card p{color:var(--text-secondary);margin-bottom:20px;font-size:12.5px;line-height:1.5}.glow-btn{background:linear-gradient(135deg, var(--accent) 0%, #db2777 100%);box-shadow:0 4px 15px #ec489933}.glow-btn:hover{box-shadow:0 6px 22px #ec489959!important}.quiz-page-layout{flex-direction:column;gap:24px;display:flex}.practice-tabs{border:1px solid var(--border-glass);background:#0f172a66;border-radius:12px;gap:8px;padding:6px;display:flex}.tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:13.5px;font-weight:600;transition:all .2s;display:flex}.tab-btn:hover:not(:disabled){color:var(--text-primary);background:#ffffff05}.tab-btn.active{color:#fff;border:1px solid var(--border-glass);background:#ffffff0d}.tab-btn:disabled{opacity:.4;cursor:not-allowed}.tab-icon{width:16px;height:16px}.practice-pane-container{min-height:480px}.no-quiz-fallback{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:48px;display:flex}.fallback-icon{width:48px;height:48px;color:var(--text-muted)}.quiz-question-wizard{background:var(--bg-card);border:1px solid var(--border-glass);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);border-radius:16px;padding:32px}.wizard-progress-bar{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex;position:relative}.wizard-progress-bar:before{content:"";background:#ffffff08;border-radius:2px;width:100%;height:4px;position:absolute;bottom:-8px;left:0}.progress-fill{background:var(--primary);border-radius:2px;height:4px;transition:width .3s;position:absolute;bottom:-8px;left:0}.wizard-progress-bar .progress-text{color:var(--text-muted);font-size:11.5px;font-weight:700}.quiz-question-card{text-align:left}.question-text{margin-bottom:24px;font-size:18px;line-height:1.5}.quiz-options-list{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.quiz-option-btn{border:1px solid var(--border-glass);width:100%;color:var(--text-primary);text-align:left;cursor:pointer;background:#ffffff03;border-radius:12px;align-items:center;padding:16px 20px;font-size:14.5px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.quiz-option-btn:hover:not(:disabled){border-color:var(--border-glass-active);background:#8b5cf608;transform:translate(4px)}.quiz-option-btn.selected{border-color:var(--primary);background:#8b5cf614;box-shadow:0 0 10px #8b5cf626}.quiz-option-btn.correct{border-color:var(--success);color:#fff;background:#10b98114;font-weight:600}.quiz-option-btn.incorrect{border-color:var(--danger);color:#f87171;background:#ef444414}.quiz-option-btn.disabled{opacity:.6;cursor:not-allowed}.option-num{color:var(--text-muted);margin-right:14px;font-weight:700}.quiz-option-btn.selected .option-num{color:var(--primary)}.quiz-option-btn.correct .option-num{color:var(--success)}.quiz-option-btn.incorrect .option-num{color:var(--danger)}.option-text{flex-grow:1}.option-feedback-icon{flex-shrink:0;width:18px;height:18px;margin-left:10px}.quiz-explanation-card{border:1px solid var(--border-glass);background:#ffffff03;border-radius:10px;margin-bottom:24px;padding:16px}.explanation-title{margin-bottom:6px;font-size:13px}.explanation-text{color:var(--text-secondary);font-size:12.5px;line-height:1.5}.quiz-action-row{justify-content:flex-end;display:flex}.quiz-result-summary-card{background:var(--bg-card);border:1px solid var(--border-glass);text-align:center;max-width:480px;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);border-radius:20px;margin:40px auto;padding:40px}.trophy-glow{width:64px;height:64px;color:var(--accent);background:#ec489926;border:1px solid #ec489940;border-radius:50%;justify-content:center;align-items:center;margin-bottom:20px;display:inline-flex;box-shadow:0 0 15px #ec489933}.trophy-svg{width:28px;height:28px}.score-ratio{font-family:var(--font-title);justify-content:center;align-items:baseline;gap:4px;margin:18px 0;display:flex}.score-correct{color:var(--primary);text-shadow:0 0 15px var(--primary-glow);font-size:48px;font-weight:800}.score-divider{color:var(--text-muted);font-size:24px}.score-total{color:var(--text-secondary);font-size:24px;font-weight:600}.score-eval{color:var(--text-secondary);margin-bottom:30px;font-size:14px}.writing-layout{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (width<=1024px){.writing-layout{grid-template-columns:1fr}}.writing-input-pane,.writing-feedback-pane{flex-direction:column;display:flex}.writing-prompt-box{border:1px solid var(--border-glass);background:#ffffff04;border-radius:12px;margin-bottom:20px;padding:18px}.prompt-desc{color:var(--text-primary);margin-bottom:12px;font-size:15px;font-weight:600;line-height:1.5}.guidelines-list{color:var(--text-secondary);border-top:1px dashed var(--border-glass);padding-top:10px;font-size:12px;line-height:1.6}.writing-form{flex-direction:column;gap:16px;display:flex}.textarea-wrapper{position:relative}.textarea-wrapper textarea{border:1px solid var(--border-glass);width:100%;color:var(--text-primary);resize:vertical;box-sizing:border-box;background:#0f172a80;border-radius:12px;outline:none;padding:16px;font-size:14.5px;transition:all .2s}.textarea-wrapper textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow);background:#0f172abf}.char-count{color:var(--text-muted);font-size:11px;position:absolute;bottom:12px;right:12px}.writing-graded-badge-container{justify-content:flex-end;display:flex}.graded-badge{color:var(--success);background:#10b98126;border:1px solid #10b98140;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700}.feedback-loading-card{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.loading-subtext{color:var(--text-secondary);max-width:320px;margin-top:8px;font-size:12px;line-height:1.5}.feedback-empty-card{text-align:center;border:1px dashed var(--border-glass);background:#ffffff01;flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.empty-icon{width:44px;height:44px;color:var(--text-muted);margin-bottom:16px}.feedback-empty-card h4{margin-bottom:6px;font-size:15px}.feedback-empty-card p{color:var(--text-secondary);max-width:300px;font-size:12px;line-height:1.5}.feedback-result-card{border-color:var(--border-glass-active);flex-direction:column;gap:20px;display:flex;box-shadow:0 0 20px #8b5cf61a}.feedback-result-header{border-bottom:1px solid var(--border-glass);align-items:center;gap:20px;padding-bottom:16px;display:flex}.score-radial-container{flex-shrink:0}.score-radial-ring{background:linear-gradient(135deg, var(--accent) 0%, #db2777 100%);color:#fff;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:72px;height:72px;display:flex;box-shadow:0 0 15px #ec48994d}.score-num{font-size:26px;font-weight:800;line-height:1;font-family:var(--font-title)}.score-label{opacity:.8;font-size:9px;font-weight:700}.feedback-title-block h4{margin-bottom:2px;font-size:16px}.feedback-title-block p{color:var(--text-secondary);font-size:11.5px}.feedback-section-box{border:1px solid var(--border-glass);background:#ffffff03;border-radius:10px;padding:16px}.feedback-section-box h5{color:var(--primary);margin-bottom:8px;font-size:12.5px;font-weight:700}.feedback-text-body{color:var(--text-primary);font-size:13px;line-height:1.6}.model-answer-box{background:#10b98103;border-color:#10b98133}.model-answer-box h5{color:var(--success)}.model-answer-content{color:var(--text-primary);white-space:pre-wrap;font-size:13px;line-height:1.6}.complete-action-wrapper{margin-top:10px}.ai-companion-drawer{-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--border-glass);z-index:100;background:#0a0f1ed9;flex-direction:column;width:380px;height:100vh;animation:.3s cubic-bezier(.4,0,.2,1) slideIn;display:flex;position:fixed;top:0;right:0;box-shadow:-10px 0 30px #00000080}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@media (width<=600px){.ai-companion-drawer{width:100%}}.drawer-header{border-bottom:1px solid var(--border-glass);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.drawer-title{text-align:left;align-items:center;gap:10px;display:flex}.bot-icon{color:var(--primary);width:22px;height:22px;filter:drop-shadow(0 0 5px var(--primary-glow))}.drawer-title h4{font-size:15px;font-weight:700}.drawer-title .subtitle{color:var(--text-secondary);font-size:11px}.btn-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;display:flex}.btn-close:hover{color:var(--text-primary);background:#ffffff0d}.drawer-chat-area{flex-direction:column;flex-grow:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.chat-bubble-row{gap:10px;display:flex}.user-row{flex-direction:row-reverse}.chat-avatar{border:1px solid var(--border-glass);background:#ffffff0d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.avatar-svg{width:14px;height:14px}.chat-bubble-content{text-align:left;max-width:75%}.chat-bubble{white-space:pre-line;border-radius:12px;padding:10px 14px;font-size:13.5px;line-height:1.5}.tutor-row .chat-bubble{border:1px solid var(--border-glass);color:var(--text-primary);background:#ffffff08}.user-row .chat-bubble{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);color:#fff}.chat-bubble p strong{color:var(--primary)}.user-row .chat-bubble p strong{color:#fff;text-decoration:underline}.typing-bubble{align-items:center;gap:4px;padding:14px;display:flex}.typing-dot{background:var(--primary);border-radius:50%;width:6px;height:6px;animation:1s infinite alternate typingBounce}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%{opacity:.4;transform:translateY(0)}to{opacity:1;transform:translateY(-4px)}}.chat-error-alert{color:var(--danger);background:#ef444414;border:1px solid #ef444426;border-radius:6px;align-items:center;gap:6px;padding:8px 12px;font-size:11px;display:flex}.error-icon{width:14px;height:14px}.chat-suggestions{border-top:1px solid #ffffff08;flex-wrap:wrap;gap:6px;padding:10px 20px;display:flex}.suggestion-chip{color:var(--text-secondary);cursor:pointer;text-align:left;background:#8b5cf60d;border:1px solid #8b5cf626;border-radius:14px;padding:6px 12px;font-size:11.5px;transition:all .2s}.suggestion-chip:hover{border-color:var(--primary);color:var(--text-primary);background:#8b5cf61f}.drawer-input-row{border-top:1px solid var(--border-glass);align-items:flex-end;gap:8px;padding:16px 20px;display:flex}.drawer-input-row textarea{border:1px solid var(--border-glass);color:var(--text-primary);resize:none;box-sizing:border-box;background:#0f172a99;border-radius:10px;outline:none;flex-grow:1;padding:10px 12px;font-size:13px}.drawer-input-row textarea:focus{border-color:var(--primary)}.btn-send{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.btn-send:hover:not(:disabled){background:var(--secondary)}.btn-send:disabled{opacity:.4;cursor:not-allowed}.send-svg{width:16px;height:16px}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:120;background:#0009;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.25s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-modal{background:var(--bg-card);border:1px solid var(--border-glass);width:100%;max-width:480px;box-shadow:var(--shadow-lg);border-radius:16px;animation:.3s cubic-bezier(.34,1.56,.64,1) popIn;overflow:hidden}@keyframes popIn{0%{opacity:0;transform:scale(.9)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border-glass);background:#00000026;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h3{font-size:16px}.modal-body{text-align:left;flex-direction:column;gap:20px;padding:24px;display:flex}.settings-section h4{margin-bottom:4px;font-size:14px}.section-desc{color:var(--text-secondary);margin-bottom:14px;font-size:11.5px}.settings-key-form{flex-direction:column;gap:12px;display:flex}.mini-alert{margin-top:0;padding:8px 12px;font-size:12px}.btn-full{width:100%}.divider{border:none;border-top:1px solid var(--border-glass)}.danger-zone{background:#ef444403;border:1px solid #ef444426;border-radius:10px;padding:14px}.danger-title{color:var(--danger);align-items:center;gap:6px;display:flex}.danger-icon{width:16px;height:16px}.danger-actions{flex-direction:column;gap:16px;display:flex}.danger-action-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.action-text{max-width:70%}.action-text h5{margin-bottom:2px;font-size:12px;font-weight:700}.action-text p{color:var(--text-secondary);font-size:10.5px;line-height:1.4}.animate-pulse{animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.03)}}.animate-fade-in{animation:.4s ease-out fadeInBlock}@keyframes fadeInBlock{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.animate-bounce-horizontal{animation:1s infinite bounceHorizontal}@keyframes bounceHorizontal{0%,to{transform:translate(0)}50%{transform:translate(4px)}}.font-bold{font-weight:700}.text-lg{font-size:16px}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.demo-mode-divider{text-align:center;color:var(--text-muted);align-items:center;margin:14px 0;font-size:12px;display:flex}.demo-mode-divider:before,.demo-mode-divider:after{content:"";border-bottom:1px solid var(--border-glass);flex:1}.demo-mode-divider:not(:empty):before{margin-right:.5em}.demo-mode-divider:not(:empty):after{margin-left:.5em}
