:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--gradient-start: #f5f6ff;--gradient-end: #d7ecff;--surface: rgba(255, 255, 255, .92);--surface-strong: rgba(255, 255, 255, .98);--accent: #5a63ff;--accent-dark: #3f4cff;--accent-soft: rgba(90, 99, 255, .22);--text-main: #0f1540;--text-muted: #5b6494;--text-subtle: #8790be;--chip-bg: rgba(90, 99, 255, .14);--chip-text: #2936a3;--shadow-soft: 0 26px 48px rgba(90, 110, 255, .18);--shadow-card: 0 30px 56px rgba(94, 120, 255, .2);font-family:Plus Jakarta Sans,Pretendard,Apple SD Gothic Neo,Noto Sans KR,sans-serif}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Noto Sans KR,Plus Jakarta Sans,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--text-main);background:radial-gradient(1100px 700px at 15% -10%,#f4f7ff,#eaf2ff 35%,#e4f0ff,#d8ecff 75%,#cfe8ff),linear-gradient(180deg,#eef4ff,#e5f0ff);line-height:1.6}.page{min-height:100vh;display:flex;justify-content:center;padding:4rem 1.5rem 5rem}.result-wrapper{width:min(1100px,100%);display:flex;flex-direction:column;gap:2.4rem}.topbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.6rem;border-radius:999px;background:#fffc;box-shadow:0 18px 40px #7896ff2e;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#5a63ff,#64a3ff);color:#fff;font-weight:700;letter-spacing:.08em}.brand strong{font-size:1.05rem;font-weight:700}.brand span{display:block;font-size:.7rem;color:var(--text-subtle);letter-spacing:.22em}.topbar-actions{display:flex;gap:.5rem}.pill{border:none;border-radius:999px;padding:.65rem 1.4rem;font-size:.9rem;font-weight:600;cursor:pointer;background:linear-gradient(135deg,#5a63ff,#64a3ff);color:#fff;transition:transform .12s ease,opacity .12s ease}.pill:disabled{opacity:.6;cursor:progress}.pill.ghost{background:#ffffff2e;border:1px solid rgba(88,105,255,.32);color:var(--text-main)}.control-panel,.metrics-section,.graph-section,.risk-section,.summary-section,.videos-section{border-radius:28px;padding:2rem;background:#ffffffe6;box-shadow:var(--shadow-soft)}.control-panel{display:grid;gap:1.5rem}.control-field{display:flex;flex-direction:column;gap:.6rem;font-weight:600;color:var(--text-main)}.control-field span{font-size:.85rem;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.12em}.file-chip{padding:.8rem 1rem;border-radius:18px;background:#5a63ff1f;font-weight:500}.segmented{display:flex;background:#5a63ff14;border-radius:999px;padding:.2rem;gap:.2rem}.segmented button{flex:1;border:none;background:transparent;border-radius:999px;padding:.5rem .9rem;font-weight:600;cursor:pointer;color:var(--text-muted)}.segmented button.active{background:#fff;color:var(--text-main);box-shadow:0 6px 14px #5a63ff33}.flags{border:1px dashed rgba(90,99,255,.2);border-radius:20px;padding:1rem;display:grid;gap:.5rem}.checkbox{display:flex;align-items:center;gap:.4rem}.control-actions{display:flex;justify-content:flex-end}.section-header{display:flex;flex-direction:column;gap:.2rem;margin-bottom:1.5rem}.section-header h2{margin:0;font-size:1.3rem}.section-header span{font-size:.9rem;color:var(--text-muted)}.metric-grid{display:grid;gap:1rem}.metric__row{display:flex;justify-content:space-between;font-weight:600}.progress-bar{height:10px;border-radius:999px;background:#0f154014;overflow:hidden}.progress-bar .fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#4f46e5,#5a63ff)}.progress-bar--thick .fill,.progress-bar--power .fill{background:linear-gradient(90deg,#4f46e5,#5a63ff)}.resonance-card{margin-top:1.2rem;border-radius:22px;padding:1rem 1.3rem;border:1px solid rgba(90,99,255,.18);background:#fffffff2;box-shadow:0 12px 24px #5e78ff26}.resonance-card__value{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:.4rem}.resonance-card__value span{text-transform:uppercase;font-size:.78rem;letter-spacing:.1em;color:var(--text-subtle)}.resonance-card__value strong{font-size:1.4rem;color:var(--accent-dark)}.resonance-card p{margin:0;color:var(--text-muted)}.resonance-card--total{border:none;background:linear-gradient(120deg,#0ea5e9,#6366f1);color:#fff;box-shadow:0 18px 36px #0ea5e959}.resonance-card--total .resonance-card__value span,.resonance-card--total .resonance-card__value strong,.resonance-card--total p{color:#fff}.graph-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.graph-card{border:1px solid rgba(90,99,255,.16);border-radius:22px;background:#fffffff2;padding:1.2rem 1.4rem;box-shadow:0 18px 32px #5e78ff26}.graph-card__label{text-transform:uppercase;font-size:.75rem;letter-spacing:.12em;color:var(--text-subtle)}.graph-card__value{font-size:1.4rem;font-weight:700;margin:.3rem 0 .6rem;color:var(--accent-dark)}.ai-summary{border:1px solid rgba(90,99,255,.16);border-radius:22px;background:#fffffff2;padding:1.2rem 1.4rem;box-shadow:0 12px 24px #5e78ff1f;display:grid;gap:.8rem}.ai-summary p{margin:0;color:var(--text-muted);line-height:1.7}.ai-summary__provider{font-size:.85rem;color:var(--text-subtle)}.insight-card,.video-card{border:1px solid rgba(90,99,255,.16);border-radius:20px;padding:1.1rem 1.3rem;background:#ffffffeb;box-shadow:0 12px 24px #5e78ff1f}.video-card{display:flex;flex-direction:column;gap:.9rem}.video-thumb{position:relative;display:block;width:100%;border-radius:16px;overflow:hidden;aspect-ratio:16 / 9;box-shadow:inset 0 0 0 1px #fff3}.video-thumb img{width:100%;height:100%;object-fit:cover;display:block}.video-thumb__badge{position:absolute;right:10px;bottom:10px;background:#0f1540d1;color:#fff;font-size:.7rem;padding:.2rem .6rem;border-radius:999px;letter-spacing:.08em}.video-thumb--static{pointer-events:none}.video-title{text-decoration:none;color:inherit}.video-title h3,.video-card h3{margin:0;font-size:1.05rem;line-height:1.35}.video-body{display:flex;flex-direction:column;gap:.4rem}.risk-list{display:grid;gap:1rem}.risk progress{width:100%;height:12px;border-radius:999px;overflow:hidden;appearance:none}progress::-webkit-progress-bar{background:#0f154014;border-radius:999px}progress::-webkit-progress-value{background:linear-gradient(90deg,#5a63ff29,#5a63ff);border-radius:999px}.videos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.video-channel{font-size:.85rem;color:var(--text-subtle)}.video-card p{margin:.6rem 0 0;color:var(--text-muted)}.video-meta{display:flex;flex-wrap:wrap;gap:.4rem .6rem;font-size:.8rem;color:var(--text-subtle)}.video-query,.video-source{border:1px solid rgba(90,99,255,.25);border-radius:999px;padding:.15rem .55rem;font-size:.75rem;color:var(--accent-dark);background:#5a63ff14}.error{color:#dc2626;font-weight:600}@media(max-width:720px){.control-panel,.metrics-section,.graph-section,.risk-section,.summary-section,.videos-section{padding:1.5rem}.topbar{flex-direction:column;gap:1rem;border-radius:24px}}.submit-progress{margin-top:.8rem;padding:.75rem 1rem;border-radius:18px;background:#5a63ff14;border:1px solid rgba(90,99,255,.2);display:flex;flex-direction:column;gap:.4rem;color:var(--text-muted);font-size:.9rem}.submit-progress__bar{position:relative;width:100%;height:6px;border-radius:999px;background:#5a63ff33;overflow:hidden}.submit-progress__bar:after{content:"";position:absolute;left:-40%;top:0;width:40%;height:100%;border-radius:inherit;background:linear-gradient(90deg,#5a63ff,#8b9bff);animation:submit-progress-slide 1.2s ease-in-out infinite}@keyframes submit-progress-slide{0%{transform:translate(0);opacity:0}10%{opacity:1}to{transform:translate(260%);opacity:0}}.tonal-section{border-radius:28px;padding:2rem;background:#ffffffe6;box-shadow:var(--shadow-soft)}.tonal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}.tonal-card{background:var(--surface-strong);border-radius:24px;padding:1.5rem;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:.75rem}.tonal-card--notes{gap:1.25rem}.note-pair{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.note-pill{border:1px solid rgba(90,99,255,.2);border-radius:20px;padding:1rem 1.25rem;background:#5a63ff14;display:flex;flex-direction:column;gap:.35rem}.note-pill span{font-size:.8rem;text-transform:uppercase;color:var(--text-subtle)}.note-pill strong{font-size:1.4rem;letter-spacing:.04em}.note-pill--accent{background:linear-gradient(135deg,#5a63ff1f,#64a3ff26);border-color:#5a63ff59}.note-pill--empty{background:#0f15400a;border-style:dashed}.note-hint{margin:0;font-size:.9rem;color:var(--text-muted)}.landing-page{min-height:100vh;padding:4rem 1.5rem 5rem;display:flex;flex-direction:column;gap:3rem;color:var(--text-main, #0f1540)}.landing-hero{max-width:960px;margin:0 auto;text-align:center;padding:3rem 2rem;border-radius:32px;background:#ffffffeb;box-shadow:0 30px 60px #5e78ff2e}.landing-hero__tag{display:inline-flex;align-items:center;gap:.35rem;font-size:.9rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-subtle, #8790be)}.landing-hero h1{margin:1rem 0 .6rem;font-size:clamp(2.4rem,3vw,3.2rem);line-height:1.2}.landing-hero h1 span{display:block;color:var(--accent-dark, #3f4cff)}.landing-hero p{margin:0 auto 1.6rem;max-width:640px;color:var(--text-muted, #5b6494)}.landing-hero__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem;margin-bottom:1.2rem}.cta{border-radius:999px;padding:.9rem 1.8rem;font-weight:600;border:none;cursor:pointer;text-decoration:none;transition:transform .12s ease,box-shadow .12s ease}.cta.primary{background:linear-gradient(135deg,#5a63ff,#64a3ff);color:#fff;box-shadow:0 18px 34px #5a63ff40}.cta.ghost{background:#ffffff2e;border:1px solid rgba(88,105,255,.32);color:var(--text-main, #0f1540)}.cta:hover{transform:translateY(-2px)}.landing-hero__badges{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}.landing-hero__badges span{padding:.35rem .9rem;border-radius:999px;background:#5a63ff1f;color:var(--chip-text, #2936a3);font-size:.85rem}.landing-hero__studio{margin-top:.8rem;font-size:.85rem;color:var(--text-subtle, #8790be)}.landing-section{max-width:1100px;margin:0 auto;padding:2.5rem;border-radius:28px;background:#ffffffe6;box-shadow:0 24px 48px #5e78ff24}.landing-section__header{margin-bottom:1.8rem}.landing-section__header h2{margin:0;font-size:1.8rem}.landing-section__header p{margin:.4rem 0 0;color:var(--text-muted, #5b6494)}.landing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}.landing-card{padding:1.6rem;border-radius:20px;border:1px solid rgba(90,99,255,.14);background:#fffffff2;box-shadow:0 16px 32px #5e78ff1f}.landing-card h3{margin:0 0 .6rem}.landing-card p{margin:0;color:var(--text-muted, #5b6494)}.landing-section--trainer{background:linear-gradient(135deg,#fffffff2,#ecf4fffa)}.trainer-card{display:flex;flex-direction:column;gap:1rem;text-align:center}.trainer-tag{align-self:center;padding:.35rem 1rem;border-radius:999px;border:1px solid rgba(90,99,255,.2);font-size:.85rem;letter-spacing:.18em;color:var(--text-subtle, #8790be);text-transform:uppercase}.trainer-artists{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.landing-section--cta{text-align:center;background:linear-gradient(135deg,#4338ca,#6366f1);color:#fff}.landing-section--cta p{color:#ffffffd9}.landing-section--cta .cta.primary{margin-top:1.4rem;background:#fff;color:#2b2e77}@media(max-width:640px){.landing-section,.landing-hero{padding:2rem 1.4rem}}.trainer-credentials{list-style:none;margin:0;padding:0;display:grid;gap:.4rem;color:var(--text-muted, #5b6494)}.trainer-credentials li{font-size:.95rem}
