:root{--bg-base:#0b0f19;--bg-surface:#141b2db3;--bg-surface-solid:#141b2d;--border-color:#ffffff14;--border-focus:#3b82f6;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--color-accent:#06b6d4;--color-secondary:#6366f1;--color-tertiary:#a855f7;--color-success:#10b981;--color-error:#ef4444;--color-warning:#f59e0b;--glass-bg:#1e293b73;--glass-blur:blur(12px);--glass-border:#ffffff0d;--glass-shadow:0 8px 32px 0 #0000005e;--font-main:"Noto Sans JP", sans-serif;--font-display:"Outfit", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-base);color:var(--text-primary);font-family:var(--font-main);flex-direction:column;min-height:100vh;display:flex;overflow-x:hidden}.app-container{flex-direction:column;min-height:100vh;display:flex}.app-header{-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--border-color);z-index:100;background-color:#0b0f19cc;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.logo-area{align-items:center;gap:.75rem;display:flex}.logo-icon{color:var(--color-accent);font-size:2.25rem}.logo-text h1{font-family:var(--font-display);letter-spacing:.5px;font-size:1.25rem;font-weight:700}.logo-text .sub-title{font-family:var(--font-display);color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:.75rem}.app-nav{border:1px solid var(--border-color);background:#ffffff08;border-radius:9999px;gap:.5rem;padding:.25rem;display:flex}.nav-item{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:9999px;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.nav-item span.material-icons-round{font-size:1.1rem}.nav-item:hover{color:var(--text-primary);background:#ffffff0d}.nav-item.active{background:linear-gradient(135deg, var(--color-accent) 0%, var(--color-secondary) 100%);color:#fff;box-shadow:0 4px 15px #06b6d44d}.score-badge{font-family:var(--font-display);background:#6366f126;border:1px solid #6366f14d;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-weight:700;transition:opacity .3s;display:flex;box-shadow:0 0 15px #6366f11a}.score-badge.hidden{opacity:0;pointer-events:none}.score-label{color:var(--text-secondary);font-size:.8rem}#score-value{color:var(--color-secondary);font-size:1.1rem}.app-main{flex:1;width:100%;max-width:1600px;margin:0 auto;padding:2rem;position:relative}.mode-section{opacity:0;transition:opacity .4s,transform .4s;display:none;transform:translateY(15px)}.mode-section.active-section{opacity:1;display:block;transform:translateY(0)}.workspace-grid{grid-template-columns:1.1fr .9fr;align-items:start;gap:2rem;display:grid}.panel{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:16px;flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex}.panel-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:.75rem;display:flex}.panel-header h2{align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;display:flex}.panel-header h2 span{color:var(--color-accent)}.btn-toggle{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:#ffffff0d;border-radius:8px;align-items:center;gap:.35rem;padding:.4rem .8rem;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.btn-toggle span{font-size:1rem}.btn-toggle.active{color:var(--color-accent);background:#06b6d426;border-color:#06b6d466}.btn-icon{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;background:#ffffff0d;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.btn-icon:hover{border-color:var(--text-secondary);background:#ffffff1a}.btn-outline{color:var(--text-primary);cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.6rem 1.2rem;font-weight:500;transition:all .2s;display:flex}.btn-outline:hover{background:#ffffff0d;border-color:#ffffff4d}.btn-primary{background:linear-gradient(135deg, var(--color-accent) 0%, var(--color-secondary) 100%);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 15px #06b6d440}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #06b6d466}.btn-secondary{background:linear-gradient(135deg, var(--color-secondary) 0%, var(--color-tertiary) 100%);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 15px #6366f140}.btn-secondary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.btn-tertiary{background:linear-gradient(135deg, var(--color-tertiary) 0%, #ec4899 100%);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 15px #a855f740}.btn-tertiary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #a855f766}.canvas-3d-wrapper{aspect-ratio:16/10;background:radial-gradient(circle,#1e293b 0%,#0f172a 100%);border:1px solid #ffffff08;border-radius:12px;width:100%;position:relative;overflow:hidden}#canvas-3d-container{width:100%;height:100%}.viewer-instructions{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--border-color);color:var(--text-secondary);pointer-events:none;white-space:nowrap;background:#0f172abf;border-radius:9999px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.75rem;display:flex;position:absolute;bottom:.75rem;left:50%;transform:translate(-50%)}.viewer-instructions span{font-size:.9rem}.control-panel{flex-direction:column;gap:1rem;display:flex}.control-group{flex-direction:column;gap:.5rem;display:flex}.control-group-row{gap:1rem;width:100%;display:flex}.half-width{flex:1}.control-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:500}.control-label-row{justify-content:justify;justify-content:space-between;align-items:center;display:flex}.control-val{font-family:var(--font-display);color:var(--color-accent);background:#06b6d41a;border-radius:4px;padding:.1rem .5rem;font-size:.85rem;font-weight:700}.select-wrapper{width:100%;position:relative}#select-model{border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-family:var(--font-main);appearance:none;cursor:pointer;background:#ffffff0a;border-radius:8px;padding:.75rem 1rem;font-size:.9rem;transition:all .2s}#select-model:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 2px #3b82f633}.select-arrow{pointer-events:none;color:var(--text-secondary);position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.slider-container{border:1px solid var(--border-color);background:#ffffff05;border-radius:8px;align-items:center;gap:.5rem;padding:.4rem;display:flex}.btn-axis{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:.5rem .75rem;font-size:.75rem;font-weight:600;transition:all .2s}.btn-axis:hover{color:var(--text-primary);background:#ffffff0d}.btn-axis.active{background:var(--text-primary);color:var(--bg-base)}input[type=range]{appearance:none;background:#ffffff14;border-radius:3px;outline:none;flex:1;height:6px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--color-accent);cursor:pointer;border-radius:50%;width:16px;height:16px;transition:transform .1s;box-shadow:0 0 8px #06b6d480}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.25)}.toggle-switch-container{align-items:center;gap:.75rem;height:100%;display:flex}.switch{width:44px;height:22px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.switch-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.slider.round{cursor:pointer;border:1px solid var(--border-color);background-color:#ffffff14;border-radius:34px;transition:all .4s;position:absolute;inset:0}.slider.round:before{content:"";background-color:var(--text-secondary);border-radius:50%;width:14px;height:14px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:#06b6d426;border-color:#06b6d466}input:checked+.slider:before{background-color:var(--color-accent);transform:translate(22px)}.drawing-layout{background:#0003;border:1px solid #ffffff05;border-radius:12px;grid-template-rows:auto auto;grid-template-columns:1fr 1fr;gap:1rem;padding:1rem;display:grid}.drawing-cell{aspect-ratio:1;background:#111827;border:1px solid #ffffff08;border-radius:8px;flex-direction:column;gap:.5rem;padding:.75rem;display:flex;position:relative}.cell-title{color:var(--text-secondary);border-left:2px solid var(--color-accent);padding-left:.5rem;font-size:.75rem;font-weight:600}#section-title{border-left-color:var(--color-secondary)}.drawing-canvas{cursor:crosshair;background-color:#151c2e;border-radius:6px;width:100%;height:100%}.legend-indicator{color:var(--text-secondary);gap:1rem;font-size:.75rem;display:flex}.line-sample{vertical-align:middle;width:24px;height:2px;margin-right:4px;display:inline-block}.outline-line{background-color:#fff}.hidden-line{background:repeating-linear-gradient(90deg,#3b82f6,#3b82f6 4px,#0000 4px 8px)}.center-line{background:repeating-linear-gradient(90deg,#ef4444,#ef4444 8px,#0000 8px 11px,#ef4444 11px 13px,#0000 13px 16px)}.quiz-container{width:100%;max-width:1200px;margin:0 auto;display:none}.quiz-container.active-sub-section{display:block}.quiz-welcome-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:1.5rem;padding:3rem 2rem;display:flex}.quiz-welcome-icon{color:var(--color-accent);background:#06b6d41a;border-radius:50%;padding:1rem;font-size:4rem}.quiz-welcome-card p{color:var(--text-secondary);max-width:600px;line-height:1.6}.quiz-modes-list{grid-template-columns:repeat(3,1fr);gap:1.5rem;width:100%;margin-top:1.5rem;display:grid}.quiz-mode-card{border:1px solid var(--border-color);text-align:left;background:#ffffff05;border-radius:12px;flex-direction:column;gap:1rem;padding:1.5rem;transition:all .3s;display:flex}.quiz-mode-card:hover{background:#ffffff0a;border-color:#ffffff26;transform:translateY(-5px)}.quiz-card-header{align-items:center;gap:.5rem;display:flex}.mode-icon{font-size:1.5rem}.text-primary{color:var(--color-accent)!important}.text-secondary{color:var(--color-secondary)!important}.text-tertiary{color:var(--color-tertiary)!important}.quiz-mode-card p{color:var(--text-secondary);flex-grow:1;font-size:.85rem;line-height:1.5}.quiz-mode-card button{width:100%}.quiz-game-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.progress-bar-container{flex-grow:.6;align-items:center;gap:1rem;display:flex}.progress-text{white-space:nowrap;font-size:.9rem;font-weight:500}.progress-track{border:1px solid var(--border-color);background:#ffffff0d;border-radius:9999px;width:100%;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--color-accent), var(--color-secondary));border-radius:9999px;height:100%;transition:width .4s}.btn-text-icon{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.25rem;font-size:.9rem;font-weight:500;transition:color .2s;display:flex}.btn-text-icon:hover{color:var(--color-error)}.quiz-game-layout{grid-template-columns:1.1fr .9fr;align-items:start;gap:2rem;display:grid}.quiz-media-container{aspect-ratio:16/11;background:#0f172a;border:1px solid #ffffff05;border-radius:12px;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.quiz-media-box{width:100%;height:100%}.compact-layout{gap:.5rem;height:100%;padding:.5rem}.compact-layout .drawing-cell{padding:.35rem}.quiz-answers-pane{flex-direction:column;gap:1.5rem;display:flex}.choices-container{flex-direction:column;gap:.75rem;display:flex}.btn-choice{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;text-align:left;background:#ffffff05;border-radius:12px;align-items:center;gap:1rem;width:100%;padding:1rem 1.5rem;transition:all .2s;display:flex}.btn-choice:hover:not(:disabled){background:#ffffff0d;border-color:#ffffff26;transform:translate(5px)}.btn-choice:focus{outline:none}.btn-choice:disabled{cursor:not-allowed;opacity:.7}.btn-choice.correct{box-shadow:0 0 15px #10b98126;border-color:var(--color-success)!important;background:#10b9811a!important}.btn-choice.incorrect{border-color:var(--color-error)!important;background:#ef44441a!important}.choice-num{width:28px;height:28px;font-family:var(--font-display);color:var(--text-secondary);border:1px solid var(--border-color);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.btn-choice.correct .choice-num{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-choice.incorrect .choice-num{background:var(--color-error);color:#fff;border-color:var(--color-error)}.choice-text{font-size:.95rem;font-weight:500}.feedback-panel{border:1px solid var(--border-color);background:#ffffff08;border-radius:12px;flex-direction:column;gap:1rem;padding:1.25rem;animation:.3s ease-out slideUp;display:flex}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.feedback-status{align-items:center;gap:.5rem;display:flex}.feedback-status span{font-size:1.75rem}.feedback-status h4{font-size:1.1rem;font-weight:600}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}#feedback-explanation{color:var(--text-secondary);font-size:.85rem;line-height:1.6}.result-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:1.5rem;max-width:600px;margin:0 auto;padding:3rem 2rem;display:flex}.result-icon{color:var(--color-warning);font-size:5rem;animation:2s infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.result-score-block{margin:1rem 0}.result-score{font-family:var(--font-display);background:linear-gradient(135deg, var(--color-accent), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:3.5rem;font-weight:700}.result-evaluation{color:var(--text-primary);margin-top:.5rem;font-size:1.25rem;font-weight:600}.result-summary-details{color:var(--text-secondary);max-width:450px;font-size:.9rem;line-height:1.6}.result-actions{gap:1rem;width:100%;margin-top:1rem;display:flex}.result-actions button{flex:1}.guide-container{flex-direction:column;gap:2rem;max-width:1200px;margin:0 auto;display:flex}.guide-header-card{text-align:center;background:linear-gradient(135deg,#06b6d41a 0%,#6366f11a 100%);border:1px solid #06b6d433;border-radius:16px;padding:2rem;box-shadow:0 4px 30px #0003}.guide-header-card h2{margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.guide-header-card p{color:var(--text-secondary);font-size:.95rem}.guide-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.guide-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:16px;flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.guide-card h3{border-bottom:1px solid var(--border-color);color:var(--color-accent);padding-bottom:.5rem;font-size:1.1rem;font-weight:600}.guide-visual-placeholder{aspect-ratio:16/9;background-color:#111827;border:1px solid #ffffff08;border-radius:8px;width:100%;position:relative;overflow:hidden}.guide-card ul{color:var(--text-secondary);flex-direction:column;gap:.5rem;padding-left:1.25rem;font-size:.85rem;line-height:1.6;display:flex}.guide-card ul strong{color:var(--text-primary)}.guide-footer-actions{justify-content:center;margin-top:1rem;display:flex}.app-footer{border-top:1px solid var(--border-color);text-align:center;color:var(--text-muted);background-color:#0b0f1980;margin-top:3rem;padding:1.5rem 2rem;font-size:.75rem}@media (width<=1024px){.workspace-grid,.quiz-game-layout,.guide-grid{grid-template-columns:1fr}}@media (width<=768px){.app-header{flex-direction:column;gap:1rem;padding:1rem}.app-nav{justify-content:space-around;width:100%}.nav-item{padding:.5rem .8rem;font-size:.8rem}.app-main{padding:1rem}.drawing-layout,.quiz-modes-list{grid-template-columns:1fr}}
