:root{color-scheme:light;--bg: #f6f1e8;--bg-strong: #efe2d1;--surface: rgba(255, 250, 243, .84);--surface-strong: #fff8f0;--surface-inverse: #14323d;--line: rgba(24, 37, 45, .12);--line-strong: rgba(24, 37, 45, .2);--text: #1d2b2f;--text-subtle: #59686d;--accent: #ff7a59;--accent-strong: #f2542d;--accent-soft: rgba(255, 122, 89, .16);--shadow: 0 20px 50px -28px rgba(55, 36, 18, .35);--radius-xl: 32px;--radius-lg: 22px;--radius-md: 16px;--content-max: 1720px;font-family:SUIT,Pretendard,Noto Sans KR,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;color:var(--text);background:radial-gradient(circle at top left,rgba(255,179,71,.2),transparent 28%),radial-gradient(circle at right 10% top 12%,rgba(79,140,255,.12),transparent 24%),linear-gradient(180deg,#fbf7f1,#f4ecdf 48%,#efe6db)}body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(20,50,61,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(20,50,61,.03) 1px,transparent 1px);background-size:36px 36px;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.48),transparent 92%);mask-image:linear-gradient(180deg,rgba(0,0,0,.48),transparent 92%)}a{color:inherit;text-decoration:none}button,input,select{font:inherit}#root{min-height:100vh}.app-shell{display:grid;grid-template-columns:minmax(320px,400px) minmax(0,1fr);gap:24px;max-width:var(--content-max);min-height:100vh;margin:0 auto;padding:24px}.content-column{display:grid;gap:24px;min-width:0}.sidebar,.hero-panel,.map-panel,.detail-hero,.detail-card,.timeline-card{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow)}.sidebar{position:sticky;top:24px;align-self:start;display:grid;gap:22px;padding:28px}.sidebar__intro h1,.hero-panel h2,.map-panel h2,.detail-hero h1{margin:8px 0 10px;font-family:MaruBuri,Iropke Batang,SUIT,sans-serif;letter-spacing:-.04em;line-height:1.05}.sidebar__intro h1{font-size:clamp(2rem,2.4vw,3rem)}.sidebar__intro p,.map-panel__header p,.hero-panel p,.detail-hero p,.detail-card p{margin:0;color:var(--text-subtle);line-height:1.6}.eyebrow{display:inline-flex;align-items:center;gap:6px;margin:0;font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-strong)}.sidebar__section,.detail-card,.timeline-card{display:grid;gap:14px}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.section-title-row h2{margin:0;font-size:1.05rem}.section-title-row span{color:var(--text-subtle);font-size:.88rem}.region-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.region-chip{display:grid;gap:4px;justify-items:start;padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--line);background:#ffffff9e;cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.region-chip:hover,.region-chip.is-active{transform:translateY(-1px)}.region-chip span{font-weight:700}.region-chip small{color:var(--text-subtle)}.search-input{display:flex;align-items:center;gap:10px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-md);background:#ffffffb8}.search-input input{width:100%;border:0;outline:0;background:transparent;color:var(--text)}.filter-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.filter-field{display:grid;gap:8px}.filter-field span{font-size:.84rem;color:var(--text-subtle)}.filter-field select{padding:12px 14px;border-radius:14px;border:1px solid var(--line);background:#ffffffb8;color:var(--text)}.course-list{display:grid;gap:12px}.course-card{display:grid;gap:12px;padding:18px;border-radius:20px;border:1px solid var(--line);background:#ffffffc2;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.course-card:hover,.course-card.is-hovered,.course-card.is-active{transform:translateY(-1px);border-color:#f2542d4d;box-shadow:0 18px 34px -26px #14323d59}.course-card h3{margin:0;font-size:1.12rem;letter-spacing:-.02em}.course-card p{margin:0;color:var(--text-subtle);line-height:1.55}.course-card__topline,.detail-hero__chips,.course-card__metrics,.course-card__footer,.map-panel__legend,.map-popup__metrics,.timeline__meta,.detail-tags,.movement-list,.hero-panel__stats{display:flex;flex-wrap:wrap;gap:10px}.badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#14323d14;color:var(--text-subtle);font-size:.78rem;font-weight:700}.badge--warm{background:var(--accent-soft);color:var(--accent-strong)}.course-card__metrics span,.map-popup__metrics span,.hero-panel__stats div,.timeline__meta span,.movement-list li{display:inline-flex;align-items:center;gap:6px;color:var(--text-subtle);font-size:.9rem}.course-card__footer{justify-content:space-between;color:var(--text-subtle);font-size:.82rem}.empty-state{display:grid;place-items:center;gap:8px;min-height:160px;padding:24px;border-radius:20px;border:1px dashed var(--line-strong);color:var(--text-subtle);text-align:center}.hero-panel{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 28px}.hero-panel__stats div{display:grid;gap:6px;min-width:124px;padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:#ffffff9e}.hero-panel__stats strong{font-size:1.1rem;color:var(--text)}.map-panel{display:grid;gap:22px;min-width:0;padding:24px 24px 28px}.map-panel__header{display:flex;align-items:end;justify-content:space-between;gap:18px}.map-panel__header h2{margin:8px 0 6px;font-size:clamp(1.8rem,2vw,2.6rem)}.map-panel__legend span{display:inline-flex;align-items:center;gap:8px;color:var(--text-subtle);font-size:.84rem}.legend-dot{width:10px;height:10px;border-radius:999px}.legend-dot--selected{background:var(--accent)}.legend-dot--hovered{background:#14b8a6}.map-stage{position:relative;overflow:hidden;min-height:780px;border-radius:28px;border:1px solid var(--line);background:radial-gradient(circle at 18% 20%,rgba(255,122,89,.13),transparent 22%),radial-gradient(circle at 76% 18%,rgba(79,140,255,.15),transparent 24%),linear-gradient(180deg,#ffffffdb,#f4ecdfd6)}.map-stage__zoom{position:absolute;inset:0;transition:transform .32s ease,transform-origin .32s ease}.map-region{position:absolute;overflow:hidden;border:1px solid;border-radius:26px;background:#ffffff94;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease}.map-region:hover,.map-region.is-active{transform:translateY(-2px);background:#ffffffd1}.map-region__glow,.map-region__routes{position:absolute;inset:0}.map-region__header{position:absolute;top:10px;left:12px;right:12px;z-index:2;display:flex;justify-content:space-between;gap:12px;font-size:.84rem;font-weight:700}.map-region__header small{color:var(--text-subtle);font-weight:600}.route-line{fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;opacity:.16;transition:opacity .18s ease,stroke-width .18s ease,filter .18s ease}.route-line--hovered{opacity:.5;stroke-width:3.2}.route-line--selected{opacity:.9;stroke-width:4;filter:drop-shadow(0 0 10px rgba(255,255,255,.7))}.course-marker{position:absolute;z-index:3;width:18px;height:18px;padding:0;border-radius:999px;border:2px solid;background:#ffffffe6;transform:translate(-50%,-50%);cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease}.course-marker span{position:absolute;inset:50%;width:6px;height:6px;border-radius:999px;transform:translate(-50%,-50%);background:currentColor}.course-marker:after{content:"";position:absolute;inset:-6px;border-radius:999px;border:1px solid currentColor;opacity:0}.course-marker--hovered,.course-marker--selected{transform:translate(-50%,-50%) scale(1.14);box-shadow:0 0 0 10px #ffffff2e}.course-marker--hovered:after,.course-marker--selected:after{opacity:.34;animation:pulse-marker 1.8s ease-out infinite}.course-marker--selected{color:#fff}.map-stage__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:18px;pointer-events:none}.map-stage__hint,.map-popup{margin-left:auto;width:min(360px,100%);pointer-events:auto}.map-stage__hint{padding:12px 14px;border-radius:16px;background:#14323de0;color:#ffffffd1;font-size:.84rem;line-height:1.5}.map-popup{display:grid;gap:12px;padding:18px;border:1px solid var(--line);border-radius:22px;background:#fffcf8f0;box-shadow:0 20px 40px -24px #14323d6b}.map-popup__topline{display:flex;align-items:center;justify-content:space-between;gap:12px}.map-popup h3{margin:0;font-size:1.2rem}.map-popup p{margin:0;color:var(--text-subtle);line-height:1.6}.detail-link,.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--accent-strong);font-weight:700}.map-popup__stops{display:grid;gap:8px;margin:0;padding:0;list-style:none}.map-popup__stops li{display:flex;align-items:center;gap:10px;color:var(--text-subtle)}.map-popup__stops strong{width:44px;color:var(--text)}.detail-page{min-height:100vh;padding:24px}.detail-page__shell{display:grid;gap:22px;max-width:1240px;margin:0 auto}.detail-hero,.timeline-card,.detail-card{padding:26px 28px}.detail-hero{display:flex;align-items:start;justify-content:space-between;gap:22px}.detail-hero h1{font-size:clamp(2rem,4vw,3.4rem)}.detail-hero__summary{display:grid;gap:12px;min-width:min(320px,100%)}.detail-hero__summary div{display:grid;gap:6px;padding:16px 18px;border-radius:18px;background:#ffffffb8;border:1px solid var(--line)}.detail-hero__summary strong{display:inline-flex;align-items:center;gap:8px;font-size:1rem}.detail-hero__summary span{color:var(--text-subtle)}.detail-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);gap:22px}.detail-highlight{font-size:1.02rem;color:var(--text)}.detail-tags span{padding:8px 12px;border-radius:999px;background:#14323d14;color:var(--text-subtle);font-size:.84rem}.movement-list{margin:0;padding:0;list-style:none;flex-direction:column;align-items:start}.timeline{display:grid;gap:18px;margin:0;padding:0;list-style:none}.timeline__item{display:grid;grid-template-columns:16px 88px minmax(0,1fr);gap:18px;align-items:start}.timeline__dot{width:16px;height:16px;margin-top:8px;border-radius:999px;border:3px solid;background:#fff;box-shadow:0 0 0 6px #ffffffe6}.timeline__time{padding-top:4px;color:var(--text-subtle);font-size:.94rem;font-weight:700}.timeline__content{display:grid;gap:10px;padding:0 0 18px;border-bottom:1px solid var(--line)}.timeline__content h3{margin:0;font-size:1.08rem}.timeline__content p{margin:0;color:var(--text-subtle);line-height:1.6}@keyframes pulse-marker{0%{transform:scale(.9);opacity:.4}to{transform:scale(1.6);opacity:0}}@media(max-width:1180px){.app-shell{grid-template-columns:1fr}.sidebar{position:static}.map-stage{min-height:680px}.detail-grid,.detail-hero,.hero-panel,.map-panel__header{grid-template-columns:1fr;flex-direction:column;align-items:start}}@media(max-width:760px){.app-shell,.detail-page{padding:14px}.sidebar,.map-panel,.hero-panel,.detail-hero,.detail-card,.timeline-card{padding:20px;border-radius:24px}.region-grid,.filter-grid{grid-template-columns:1fr}.map-stage{min-height:560px}.map-stage__overlay{gap:12px}.map-stage__hint,.map-popup{width:100%}.timeline__item{grid-template-columns:16px minmax(0,1fr)}.timeline__time{grid-column:2;padding-top:0}.timeline__content{grid-column:2}}
