@font-face{font-family:Rix;src:url(https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2102-01@1.0/RixYeoljeongdo_Regular.woff) format("woff");font-weight:400;font-display:swap}:root{font-family:Rix,Apple SD Gothic Neo,Noto Sans KR,sans-serif;line-height:1.5;font-weight:400;color:#221410;background:radial-gradient(circle at top,rgba(255,135,91,.16),transparent 20%),radial-gradient(circle at 20% 16%,rgba(89,191,202,.12),transparent 18%),linear-gradient(180deg,#120d0d,#231513 18%,#f1e6dc 54%,#f7eee8);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#070a0ab8 0,#130e0dc7 18%,#f1e6dce0 52%,#f7efe8f0),radial-gradient(circle at 50% 0,rgba(255,121,68,.12),transparent 24%),url(/demon-slayer-hero.png) center top / cover fixed no-repeat}body:before{content:"";position:fixed;inset:0;pointer-events:none;background:linear-gradient(180deg,#03060747,#0f0a092e 30%,#fff7ef14),linear-gradient(rgba(255,255,255,.028) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:auto,26px 26px,26px 26px;opacity:.48;mix-blend-mode:soft-light}a{color:inherit;text-decoration:none}#root{min-height:100vh}.app-shell{position:relative;width:min(1240px,calc(100vw - 32px));margin:0 auto;padding:34px 0 72px}.app-shell:before{content:"";position:fixed;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(244,80,42,.05),transparent 18%,transparent 82%,rgba(113,181,172,.05)),radial-gradient(circle at 12% 18%,rgba(255,119,51,.18),transparent 24%),radial-gradient(circle at 82% 10%,rgba(126,208,216,.12),transparent 20%),radial-gradient(circle at 50% 120%,rgba(111,20,12,.3),transparent 34%);z-index:-2}.hero,.score-panel,.toolbar,.resource-card,.source-card,.empty-state{position:relative;overflow:hidden}.hero{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(300px,.75fr);gap:22px;margin-bottom:28px;padding:30px;border:1px solid rgba(112,188,174,.14);border-radius:32px;background:linear-gradient(135deg,#040c0ef5,#091918f0),#091414;box-shadow:0 28px 90px #0208086b}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,rgba(0,0,0,.38) 25%,transparent 25%,transparent 50%,rgba(0,0,0,.38) 50%,rgba(0,0,0,.38) 75%,transparent 75%,transparent),linear-gradient(45deg,rgba(52,128,108,.26) 25%,transparent 25%,transparent 50%,rgba(52,128,108,.26) 50%,rgba(52,128,108,.26) 75%,transparent 75%,transparent);background-size:144px 144px,144px 144px;background-position:0 0,72px 72px;opacity:.52;-webkit-mask-image:linear-gradient(90deg,#000000eb,#0000001a);mask-image:linear-gradient(90deg,#000000eb,#0000001a)}.hero:after{content:"";position:absolute;inset:auto -6% -24% 26%;height:72%;border-radius:50%;background:repeating-radial-gradient(circle at 50% 50%,#76d8e557 0 12px,#76d8e500 12px 26px),radial-gradient(circle at center,rgba(112,219,238,.2),transparent 62%);opacity:.9;transform:rotate(-11deg)}.hero-copy,.score-panel>*,.source-grid,.toolbar,.resource-list{position:relative;z-index:1}.hero-copy{display:grid;gap:12px;align-content:start}.eyebrow{margin:0;font-size:.78rem;font-weight:800;letter-spacing:.24em;text-transform:uppercase;color:#f6dfb1}.hero h1{margin:0;display:grid;gap:10px;max-width:11ch;font-size:clamp(3.2rem,6.8vw,5.8rem);line-height:.9;letter-spacing:-.04em;color:#f5efe4;text-shadow:0 10px 32px rgba(0,0,0,.45)}.hero-title-main{display:block}.hero-title-sub{display:inline-flex;width:fit-content;padding:8px 14px;border-radius:999px;background:#0e12128f;border:1px solid rgba(255,243,221,.2);color:#f6dfb1;font-size:clamp(1rem,2vw,1.45rem);letter-spacing:.02em;line-height:1.1}.hero-text{max-width:62ch;margin:0;color:#ebf2efd1;font-size:1rem}.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.hero-badges span,.pill{display:inline-flex;align-items:center;justify-content:center;padding:9px 14px;border-radius:999px;border:1px solid rgba(171,235,222,.16);background:#f4f6ee14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#eef6f3;font-size:.88rem;font-weight:800}.summary-panel{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:8px}.summary-stat{display:grid;gap:4px;min-height:0;padding:14px 16px;border-radius:20px;border:1px solid rgba(140,218,201,.14);background:#f2f5ef14;color:#eef7f4}.summary-stat strong{font-size:1.36rem;line-height:1.1}.summary-stat span{color:#eef7f4b8;font-size:.8rem;font-weight:700;line-height:1.2}.summary-stat.accent{background:linear-gradient(135deg,#8f160fdb,#e74d2ccc);border-color:#ffad974d}.hero-aside{position:relative;z-index:1;display:grid;gap:14px;align-content:end}.theme-card{display:grid;gap:6px;padding:18px;border-radius:24px;border:1px solid rgba(255,255,255,.12);background:#0814148a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#eff7f3;box-shadow:inset 0 1px #ffffff0a}.theme-card strong{font-size:1rem}.theme-card span{color:#eff7f3b8;font-size:.92rem}.theme-card--checkered{background:linear-gradient(45deg,rgba(0,0,0,.52) 25%,transparent 25%,transparent 50%,rgba(0,0,0,.52) 50%,rgba(0,0,0,.52) 75%,transparent 75%,transparent),linear-gradient(45deg,rgba(47,120,103,.72) 25%,transparent 25%,transparent 50%,rgba(47,120,103,.72) 50%,rgba(47,120,103,.72) 75%,transparent 75%,transparent),#060f0fa3;background-size:52px 52px,52px 52px,auto;background-position:0 0,26px 26px,0 0}.theme-card--water{background:radial-gradient(circle at top right,rgba(135,240,255,.22),transparent 30%),repeating-radial-gradient(circle at 10% 120%,#91ecf538 0 10px,#91ecf500 10px 22px),#051518b8}.theme-card--ember{background:radial-gradient(circle at 16% 24%,rgba(255,106,71,.32),transparent 24%),linear-gradient(135deg,#52110cdb,#1c0a09d1)}.source-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:20px}.score-panel{display:grid;gap:16px;margin-bottom:24px;padding:24px 24px 26px;border-radius:30px;background:radial-gradient(circle at 85% 0,rgba(121,217,233,.16),transparent 22%),linear-gradient(180deg,#faf4ebf5,#f8efe7f2);border:1px solid rgba(83,25,18,.14);box-shadow:0 18px 55px #30120c1f}.score-panel:before{content:"";position:absolute;inset:auto -8% -45% 40%;height:88%;border-radius:50%;background:repeating-radial-gradient(circle at center,#59b0b91f 0 12px,#59b0b900 12px 26px);transform:rotate(-12deg)}.score-panel__header{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(360px,.95fr);gap:16px;align-items:start}.score-panel h2{margin:0 0 8px;font-size:clamp(1.7rem,3vw,2.4rem);color:#28120d}.score-panel__copy{display:grid;gap:6px}.score-panel .eyebrow{color:#8e2719}.score-panel__copy p:last-child{margin:0;color:#684d42}.score-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.score-metric{display:grid;gap:4px;min-height:0;padding:16px;border-radius:18px;background:#fffcf8b8;border:1px solid rgba(132,36,22,.12)}.score-metric strong{font-size:1.5rem;color:#7d1e13}.score-metric span{color:#78594d}.score-chart-card{min-width:0;padding:18px;border-radius:24px;background:linear-gradient(180deg,#fffc,#fff9f5cc);border:1px solid rgba(132,36,22,.08)}.score-chart{display:grid;gap:12px}.score-chart svg{width:100%;height:auto;overflow:visible}.chart-grid-line{stroke:#78372629;stroke-dasharray:4 6}.chart-axis-label,.chart-date-label{fill:#8a6a5c;font-size:12px;font-weight:700}.chart-line{fill:none;stroke:#861f13;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}.chart-point{fill:#fff6ef;stroke:#3b9088;stroke-width:3}.chart-caption{display:flex;flex-wrap:wrap;gap:8px}.chart-caption span,.download-placeholder{display:inline-flex;align-items:center;padding:8px 10px;border-radius:999px;background:#571a120f;color:#714f45;font-size:.84rem;font-weight:700}.score-chart-empty{display:grid;place-items:center;gap:8px;min-height:260px;text-align:center;color:#64483d}.source-card{display:grid;gap:16px;padding:20px;border-radius:24px;background:linear-gradient(180deg,#fffbf6f5,#f7efe8f2);border:1px solid rgba(96,31,20,.12);box-shadow:0 14px 36px #37161014}.source-card.focused{background:linear-gradient(45deg,rgba(10,15,15,.92) 25%,transparent 25%,transparent 50%,rgba(10,15,15,.92) 50%,rgba(10,15,15,.92) 75%,transparent 75%,transparent),linear-gradient(45deg,rgba(41,113,96,.94) 25%,transparent 25%,transparent 50%,rgba(41,113,96,.94) 50%,rgba(41,113,96,.94) 75%,transparent 75%,transparent),linear-gradient(135deg,#11201f,#1f3e37);background-size:64px 64px,64px 64px,auto;background-position:0 0,32px 32px,0 0;color:#f8efe1}.source-card h2{margin:4px 0 10px;font-size:1.2rem}.source-card p{margin:0;color:inherit;opacity:.88}.source-label{font-size:.82rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.source-card a,.actions a,.source-link{display:inline-flex;width:fit-content;align-items:center;justify-content:center;padding:10px 14px;border-radius:14px;border:1px solid rgba(124,34,21,.16);background:#84241614;color:#7a2014;font-weight:800}.source-card.focused a{background:#fff8ec1f;border-color:#fff8ec24;color:#fff3e1}.toolbar{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px;padding:18px;border-radius:24px;background:#101413d1;border:1px solid rgba(126,206,193,.12);position:sticky;top:16px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 18px 44px #0508083d;z-index:2}.toolbar label,.meta-block,.memo-field{display:grid;gap:8px}.toolbar label{font-size:.92rem;font-weight:700;color:#e7f1ed}.resource-list{display:grid;gap:14px}.resource-card{padding:20px;border-radius:26px;border:1px solid rgba(96,31,20,.1);background:linear-gradient(180deg,#fffbf6f0,#faf5eff2);box-shadow:0 18px 46px #2d120c14}.resource-card.highlight{border-color:#7f1d123d;background:radial-gradient(circle at top right,rgba(112,212,224,.12),transparent 20%),linear-gradient(180deg,#fff7f2f5,#fffcf8fa)}.resource-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}.unit-info{flex:1}.unit-actions{display:flex;flex-direction:column;gap:10px;align-items:flex-end}.resource-head h3{margin:10px 0 8px;font-size:1.45rem;color:#22110d}.resource-head p{margin:0;color:#675247}.pill-row{display:flex;flex-wrap:wrap;gap:8px}.pill{border-color:#6a160f1a;background:#84241614;color:#6d1d13}.pill.grade{background:linear-gradient(135deg,#183b37,#2b7a6b);color:#f9f6ec}.pill.unit{background:#3d98a024;color:#1e5f61}.attachment-list{display:grid;gap:12px;margin-top:18px}.study-grid-head{display:grid;grid-template-columns:148px 100px minmax(220px,1fr) 140px 140px 96px;gap:10px;padding:0 14px;color:#85675a;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.attachment-card{padding:20px;border-radius:22px;background:linear-gradient(180deg,#ffffffb8,#fffaf6f5);border:1px solid rgba(96,31,20,.08);box-shadow:inset 0 1px #ffffff73}.attachment-head{display:flex;flex-direction:column;gap:16px}.attachment-title{font-size:1.05rem;color:#1a2e28;min-width:0}.attachment-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.study-grid{display:grid;grid-template-columns:148px 100px minmax(220px,1fr) 140px 140px 96px;gap:10px;align-items:stretch;padding:16px;background:linear-gradient(90deg,#7b1e1408,#3b90880d);border-radius:16px;border:1px solid rgba(96,31,20,.06)}.study-grid label,.download-cell,.save-cell{display:grid;gap:8px;font-size:.9rem;font-weight:700;color:#57433a}.memo-label{min-width:0}.download-cell button,.save-cell button{width:100%;min-height:48px}.download-cell,.save-cell{align-content:end}.mobile-field-label{display:none;font-size:.78rem;font-weight:800;color:#85695d;letter-spacing:.04em;text-transform:uppercase}.empty-state{padding:32px;border-radius:24px;background:#fff9f3e0;border:1px solid rgba(96,31,20,.08)}.meta-grid{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:12px;margin-top:18px}.meta-block{padding:14px;border-radius:18px;background:#f6f4ee}.meta-block.toggle{align-content:center}.meta-label{font-size:.82rem;font-weight:800;color:#5e7069;text-transform:uppercase;letter-spacing:.05em}.memo-field{margin-top:12px}.memo-field textarea{min-height:92px;resize:vertical}select,textarea,button,input[type=checkbox],input[type=text],input[type=date]{font:inherit}select,textarea,input[type=text],input[type=date]{width:100%;padding:12px 14px;border:1px solid rgba(93,31,22,.16);border-radius:14px;background:#fffbf7f5;color:#221511}.toolbar select,.toolbar input[type=text]{background:#fff8eef0}button{border:none;padding:11px 16px;border-radius:14px;background:linear-gradient(135deg,#7d1f13,#d94f2e);color:#fff7ef;font-weight:800;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}button:hover{transform:translateY(-1px);box-shadow:0 12px 20px #7d1f1347}button.secondary,button.ghost{background:linear-gradient(135deg,#22534d,#3a9688);color:#f4fbf9;box-shadow:none}button.ghost{padding:8px 12px}input[type=checkbox]{width:20px;height:20px;accent-color:#7d1f13}.card-save-button,.unit-save-button{background:linear-gradient(135deg,#7b2014,#ef6335);color:#fff7ef;box-shadow:0 10px 18px #7d1f132e}.card-save-button:hover:not(:disabled),.unit-save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 22px #7d1f133d;background:linear-gradient(135deg,#932517,#ff7742)}.card-save-button:disabled,.unit-save-button:disabled{background:#ccc;color:#666;cursor:not-allowed;box-shadow:none}.status-badge.저장중{background:#ffeb3b;color:#856404}@media(max-width:1080px){.hero{grid-template-columns:1fr}.hero h1{max-width:none}}@media(max-width:960px){.source-grid,.toolbar,.meta-grid,.score-panel__header{grid-template-columns:1fr}.resource-head{flex-direction:column}.score-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:640px){.app-shell{width:min(100vw - 20px,1240px);padding-top:18px}.hero,.score-panel,.resource-card,.toolbar,.source-card{border-radius:22px}.hero,.score-panel,.resource-card,.source-card,.toolbar{padding-left:18px;padding-right:18px}.summary-panel,.score-metrics{grid-template-columns:1fr}.score-chart-card{padding:14px}.study-grid-head{display:none}.attachment-card{padding:16px}.study-grid{grid-template-columns:1fr;gap:12px;padding:14px}.mobile-field-label{display:block}.attachment-title-row{align-items:flex-start}.chart-caption{display:grid;grid-template-columns:1fr}}
