:root {
    color-scheme: light;
    --bg: #06101f;
    --bg-elevated: #eef4fb;
    --bg-soft: #e4edf8;
    --surface: rgba(255, 255, 255, 0.9);
    --surface-soft: rgba(255, 255, 255, 0.98);
    --surface-strong: #edf4fb;
    --surface-glass: rgba(255, 255, 255, 0.78);
    --text: #1c2b42;
    --text-strong: #0d1726;
    --muted: #61748e;
    --muted-strong: #42556f;
    --primary: #2163aa;
    --primary-strong: #174d87;
    --primary-deep: #0f3d6d;
    --success: #149f68;
    --warning: #a56b14;
    --danger: #c44459;
    --accent: rgba(33, 99, 170, 0.1);
    --accent-strong: rgba(33, 99, 170, 0.16);
    --line: rgba(96, 116, 144, 0.14);
    --line-strong: rgba(96, 116, 144, 0.24);
    --shadow: 0 24px 50px rgba(18, 44, 76, 0.12);
    --shadow-soft: 0 14px 30px rgba(18, 44, 76, 0.08);
    --header-start: #fffef8;
    --header-end: #fff6ee;
    --header-link-bg: rgba(255, 255, 255, 0.88);
    --header-link-hover: rgba(255, 236, 204, 0.98);
    --footer-bg: rgba(255, 250, 243, 0.9);
    --toggle-bg: rgba(255, 255, 255, 0.72);
    --toggle-border: rgba(230, 180, 108, 0.24);
    --toggle-text: #8c5c1a;
    --input-bg: rgba(255, 255, 255, 0.96);
    --input-placeholder: #8292a7;
    --button-bg: linear-gradient(135deg, #ffcb4b 0%, #ff9e6b 100%);
    --button-text: #503100;
    --button-shadow: 0 14px 28px rgba(255, 171, 63, 0.24);
    --table-stripe: rgba(255, 177, 76, 0.05);
    --radius-sm: 12px;
    --radius-md: 18px;
    --radius-lg: 26px;
    --radius-xl: 32px;
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
    --space-7: 32px;
    --space-8: 40px;
    --container: 1360px;
}

:root[data-theme='dark'] {
    color-scheme: dark;
    --bg: #06101f;
    --bg-elevated: #0b1628;
    --bg-soft: #0f1d34;
    --surface: rgba(11, 22, 40, 0.88);
    --surface-soft: rgba(16, 29, 52, 0.92);
    --surface-strong: rgba(22, 39, 69, 0.98);
    --surface-glass: rgba(14, 26, 45, 0.72);
    --text: #dce8fb;
    --text-strong: #f8fbff;
    --muted: #8fa5c7;
    --muted-strong: #b5c6e2;
    --primary: #77baff;
    --primary-strong: #b6dbff;
    --primary-deep: #4e8fdd;
    --success: #56d6a0;
    --warning: #f0b869;
    --danger: #ff8f9d;
    --accent: rgba(119, 186, 255, 0.14);
    --accent-strong: rgba(119, 186, 255, 0.22);
    --line: rgba(143, 165, 199, 0.16);
    --line-strong: rgba(143, 165, 199, 0.3);
    --shadow: 0 24px 60px rgba(2, 8, 20, 0.46);
    --shadow-soft: 0 16px 36px rgba(2, 8, 20, 0.22);
    --header-start: #09172d;
    --header-end: #11294a;
    --header-link-bg: rgba(255, 255, 255, 0.05);
    --header-link-hover: rgba(255, 255, 255, 0.1);
    --footer-bg: rgba(7, 15, 27, 0.9);
    --toggle-bg: rgba(255, 255, 255, 0.06);
    --toggle-border: rgba(255, 255, 255, 0.1);
    --toggle-text: #f8fbff;
    --input-bg: rgba(10, 19, 34, 0.92);
    --button-bg: linear-gradient(135deg, #4d87cf 0%, #6eb8ff 100%);
    --button-text: #04101f;
    --button-shadow: 0 14px 30px rgba(76, 137, 208, 0.28);
    --table-stripe: rgba(143, 165, 199, 0.04);
}

html { background: var(--bg); color-scheme: inherit; }
html, body { min-height: 100%; background: var(--bg); color: var(--text); }
body { margin: 0; transition: background-color .2s ease, color .2s ease; }
*, *::before, *::after { box-sizing: border-box; }
body, button, input, select, textarea { font-family: "Pretendard", "Apple SD Gothic Neo", "Noto Sans KR", sans-serif; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--primary-strong); }
h1,h2,h3,h4,h5,h6,strong,label,th { color: var(--text-strong); letter-spacing: -0.02em; }
p,ul,ol,dl,small,span,li,td,caption { color: inherit; }
::selection { background: rgba(119,186,255,.26); color: var(--text-strong); }
button,input,select,textarea { transition: background-color .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease,transform .2s ease; }
button,.button,.site-button,.admin-button,input[type='submit'],input[type='button'],input[type='reset'] { display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:11px 18px;border:1px solid transparent;border-radius:999px;background:var(--button-bg);color:var(--button-text);box-shadow:var(--button-shadow);font:inherit;font-weight:700;cursor:pointer;text-decoration:none;white-space:nowrap; }
button:hover,.button:hover,.site-button:hover,.admin-button:hover,input[type='submit']:hover,input[type='button']:hover,input[type='reset']:hover { transform: translateY(-1px); filter: brightness(1.03); }
.button--secondary,.site-button--secondary,.admin-button--secondary,button.button--secondary { background: rgba(255,255,255,.8); color: var(--text-strong); border-color: var(--line); box-shadow: none; }
.button--ghost,.site-button--ghost,.admin-button--ghost,button.button--ghost { background: transparent; color: var(--text); border-color: var(--line); box-shadow: none; }
button:focus-visible,.button:focus-visible,.site-button:focus-visible,.admin-button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible { outline: 2px solid var(--primary); outline-offset: 3px; }
input,select,textarea { width:100%; border:1px solid var(--line); border-radius:18px; background:var(--input-bg); color:var(--text); }
input,select { min-height:46px; padding:11px 14px; }
textarea { min-height:140px; padding:14px; resize:vertical; }
input::placeholder,textarea::placeholder { color: var(--input-placeholder); }
input:focus,select:focus,textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 4px rgba(119,186,255,.12); }
table { width:100%; border-collapse: collapse; background: transparent; color: var(--text); }
thead { background: rgba(255,255,255,.4); }
th,td { padding:14px 16px; border-bottom:1px solid var(--line); text-align:left; vertical-align: top; }
tbody tr:nth-child(even) { background: var(--table-stripe); }
hr { border:0; border-top:1px solid var(--line); }
.surface-card,.glass-card,.panel-card,.metric-card,.feature-card,.list-card,.detail-card,.stat-card,.metric-tile,.hero-panel,.attachment-item,.section-card { border: 1px solid var(--line); border-radius: 28px; box-shadow: var(--shadow-soft); }
.surface-card,.panel-card,.metric-card,.feature-card,.list-card,.detail-card,.stat-card,.metric-tile,.hero-panel,.attachment-item,.section-card { background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,250,244,.92)); }
:root[data-theme='dark'] .surface-card,:root[data-theme='dark'] .panel-card,:root[data-theme='dark'] .metric-card,:root[data-theme='dark'] .feature-card,:root[data-theme='dark'] .list-card,:root[data-theme='dark'] .detail-card,:root[data-theme='dark'] .stat-card,:root[data-theme='dark'] .metric-tile,:root[data-theme='dark'] .hero-panel,:root[data-theme='dark'] .attachment-item,:root[data-theme='dark'] .section-card { background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01)); }
.glass-card { background: var(--surface-glass); }
.site-chip,.meta-badge,.status-badge { display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:6px 12px;border-radius:999px;background:rgba(255,208,86,.18);color:#9b5b00;font-size:12px;font-weight:700;letter-spacing:.01em; }
.status-badge--success { background: rgba(86,214,160,.14); color: var(--success); }
.status-badge--warning { background: rgba(240,184,105,.18); color: var(--warning); }
.status-badge--danger { background: rgba(255,143,157,.14); color: var(--danger); }
.section-heading { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:18px; }
.section-heading h2,.section-heading h3,.section-heading p,.hero-panel__label,.hero-panel__sub,.metric-tile__label,.metric-tile__sub { margin:0; }
.section-heading p,.meta-text,.helper-text,.kicker,.table-path { color: var(--muted); }
.kicker { font-size:12px; text-transform:uppercase; letter-spacing:.08em; font-weight:700; }
.page-stack,.detail-stack,.content-stack,.list-stack,.attachment-list,.hero-panel__list { display:grid; gap:18px; }
.section-shell,.page-panel,.admin-panel,.admin-detail-card,.admin-login-card,.admin-login-info { border:1px solid var(--line); border-radius:32px; background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,249,241,.88)); box-shadow: var(--shadow-soft); padding: 28px; position: relative; overflow:hidden; }
:root[data-theme='dark'] .section-shell,:root[data-theme='dark'] .page-panel,:root[data-theme='dark'] .admin-panel,:root[data-theme='dark'] .admin-detail-card,:root[data-theme='dark'] .admin-login-card,:root[data-theme='dark'] .admin-login-info { background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01)); }
.section-shell::before,.page-panel::before { display:none; content:none; }
.filter-bar,.inline-form,.toolbar-row,.search-row,.admin-filter,.admin-inline-form { display:flex; flex-wrap:wrap; gap:12px; align-items:center; }
.filter-bar > *,.search-row > * { flex:1 1 180px; }
.inline-form .actions,.toolbar-row .actions,.filter-bar .actions { display:flex; gap:10px; flex-wrap:wrap; }
.empty-note,.info-note { padding:16px 18px; border-radius:18px; background: rgba(255,255,255,.5); border:1px solid var(--line); color: var(--muted); }
.theme-toggle { display:inline-flex; align-items:center; gap:8px; border:1px solid var(--toggle-border); background:var(--toggle-bg); color:var(--toggle-text); border-radius:999px; padding:10px 14px; min-height:auto; box-shadow:none; font:inherit; cursor:pointer; }
.theme-toggle__icon { font-size:14px; }
.theme-toggle__label { font-size:14px; font-weight:700; }
.site-header__actions,.site-header__stats,.site-footer__meta,.card-topline,.list-card__side,.hero__grid,.detail-layout { display:flex; gap:14px; }
.site-header__actions,.site-header__stats { align-items:center; flex-wrap:wrap; }
.site-header__stats { color: var(--muted); font-size:13px; }
.site-header__stats strong { color: var(--text-strong); font-size:14px; }
.site-footer__meta { flex-wrap:wrap; color: var(--muted); font-size:13px; }
.card-topline { align-items:center; justify-content:space-between; gap:10px; margin-bottom:10px; }
.hero--dashboard,.hero--compact { border-radius: 36px; }
.hero__grid { justify-content:space-between; align-items:stretch; gap:20px; }
.hero__grid > * { flex:1 1 0; }
.hero.common-hero,.common-hero { position:relative; min-height:auto; display:block; padding:24px 0 20px; background:transparent !important; border:none !important; border-radius:0 !important; box-shadow:none !important; isolation:auto; text-align:center; }
.common-hero::before,.common-hero::after { display:none; }
.common-hero__grid,.common-hero__copy { position:relative; z-index:1; }
.common-hero__grid { display:block; }
.common-hero__copy { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; width:100%; }
.common-hero__copy > * { margin:0; }
.common-hero__eyebrow { padding:0; min-height:auto; background:transparent; border:none; border-radius:0; box-shadow:none; backdrop-filter:none; color: var(--muted); font-size:13px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; text-align:center; word-break:keep-all; }
.common-hero__title { text-align:center; word-break:keep-all; }
.common-hero__subtitle { max-width:700px; color: var(--muted); text-align:center; word-break:keep-all; }
.common-hero__final-line { color: var(--text-strong); font-size:16px; font-weight:700; text-align:center; word-break:keep-all; }
.common-hero__nav { display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:10px; width:100%; margin-top:4px; }
.common-hero__nav-link { display:inline-flex; align-items:center; justify-content:center; min-height:42px; padding:0 16px; border-radius:999px; border:1px solid rgba(18,44,76,.12); background:transparent; color: var(--text-strong); font-size:14px; font-weight:700; white-space:nowrap; word-break:keep-all; box-shadow:none; backdrop-filter:none; transition: border-color .2s ease, background-color .2s ease, color .2s ease; }
.common-hero__nav-link:hover,.common-hero__nav-link:focus-visible { transform:none; border-color: rgba(18,44,76,.22); background: rgba(18,44,76,.04); }
.common-hero__nav-link.is-active { background: rgba(18,44,76,.08); border-color: rgba(18,44,76,.18); color: var(--text-strong); box-shadow:none; }
.hero-panel { padding:24px; align-self:stretch; display:grid; gap:12px; min-width:260px; background: linear-gradient(180deg, rgba(255,246,224,.92), rgba(255,255,255,.92)); }
:root[data-theme='dark'] .hero-panel { background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01)); }
.hero-panel__label { color: var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.08em; }
.hero-panel__value { font-size: clamp(28px,4vw,44px); line-height:1; font-weight:800; letter-spacing:-.05em; color: var(--text-strong); }
.hero-panel__sub { color: var(--muted); font-size:14px; line-height:1.7; }
.metric-strip { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:16px; }
.metric-tile { padding:22px; display:grid; gap:8px; }
.metric-tile__label { color: var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.08em; }
.metric-tile__value { font-size: clamp(22px,3vw,34px); line-height:1; color: var(--text-strong); }
.metric-tile__sub { color: var(--muted); font-size:13px; }
.quick-links--dense,.list-grid--stacked { grid-template-columns: 1fr; }
.campaign-grid,.timeline-grid { display:grid; gap:18px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.section-card--dense,.list-card--row { padding:24px; }
.section-card--dense h3,.list-card--row h3 { margin:0 0 10px; }
.section-card__actions { display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }
.section-card__actions .section-card__link { display:inline-flex; }
.landing-index { padding-top:24px; padding-bottom:24px; }
.landing-index__chips { display:flex; flex-wrap:wrap; gap:10px; }
.landing-index__chip { min-height:36px; padding:8px 14px; background:rgba(255,255,255,.82); border:1px solid var(--line); color:var(--text-strong); }
.list-card--row { display:flex; align-items:center; justify-content:space-between; gap:16px; }
.list-card__main { flex:1 1 auto; }
.list-card__side { flex-direction:column; align-items:flex-end; justify-content:center; min-width:130px; }
.detail-layout { align-items:flex-start; }
.detail-layout--placeholder { display:block; }
.detail-article { flex:1 1 auto; min-width:0; }
.page-panel.detail-placeholder-frame { min-height:clamp(280px, 48vh, 560px); display:grid; place-items:center; background:rgba(255,255,255,.08) !important; border:none !important; box-shadow:0 12px 32px rgba(10,16,24,.08) !important; backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.page-panel.detail-placeholder-frame::before { display:none !important; }
:root[data-theme='dark'] .page-panel.detail-placeholder-frame { background:rgba(18,24,37,.18) !important; box-shadow:0 14px 36px rgba(0,0,0,.22) !important; }
.detail-placeholder-text { font-size:clamp(24px, 3vw, 40px); font-weight:700; color:var(--muted); text-align:center; }
.detail-sidebar { width:320px; display:grid; gap:16px; }
.detail-card--compact { padding:22px; }
.attachment-item { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 16px; }
.attachment-item > span:first-child { flex: 1 1 auto; min-width: 0; word-break: keep-all; }
.attachment-item > .meta-text { flex: 0 0 auto; white-space: nowrap; }
.rich-content { line-height:1.75; }
.page-panel--search,.admin-panel--filter { padding:18px; }
.search-row--strong input { flex:1 1 320px; }
.section-heading--search-results { align-items:center; }
.search-result-summary { display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end; }
.search-empty-state { display:grid; gap:14px; padding:30px; border-radius:24px; border:1px dashed var(--line-strong); background: rgba(255,255,255,.5); }
.search-empty-state__actions,.search-empty-state__tips,.search-empty-state__tips div { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.search-empty-state__tips { padding-top:6px; color: var(--muted); }
.search-empty-state__tips span { font-size:12px; text-transform:uppercase; letter-spacing:.08em; }
.search-empty-state__tips a { display:inline-flex; align-items:center; min-height:34px; padding:0 12px; border-radius:999px; border:1px solid var(--line); color: var(--text); background: rgba(255,255,255,.7); }
.table-shell--responsive { overflow-x:auto; }
.hero--landing { overflow:hidden; }
.hero--landing-stage { min-height: calc(100svh - 140px); display:grid; align-items:center; }
.hero.hero--landing-frame-only { padding:0; margin:0; border:none; border-radius:0; background:transparent; box-shadow:none; overflow:visible; }
.hero.hero--landing-frame-only::after { display:none; }
.hero__grid--landing { display:grid; grid-template-columns:minmax(0, 1.15fr) 360px; gap:22px; align-items:stretch; }
.hero__grid--landing-stage { grid-template-columns:minmax(0, 1fr); align-items:center; justify-items:center; }
.hero__grid--landing-frame-only { width:100%; min-height:inherit; display:grid; place-items:center; }
.hero-copy { display:grid; align-content:center; gap:0; }
.hero-copy--landing-stage { gap:10px; }
.hero-stage-visual { display:grid; justify-items:center; gap:16px; width:100%; }
.hero-stage-visual__badge,.hero-visual-card__badge { display:inline-flex; width:fit-content; min-height:30px; padding:6px 12px; border-radius:999px; background: rgba(255,255,255,.72); color:#9b5b00; font-size:12px; font-weight:700; }
.hero-stage-visual__frame { width:min(100%, 520px); aspect-ratio: 1 / 1; display:grid; place-items:center; padding:32px; border-radius:40px; border:1px solid rgba(255,198,73,.32); background: linear-gradient(180deg, rgba(255,255,255,.32), rgba(255,255,255,.72)), radial-gradient(circle at 82% 18%, rgba(141,212,255,.34), transparent 30%), linear-gradient(135deg, #fff6d8 0%, #fff9f1 46%, #fff0eb 100%); box-shadow: var(--shadow-soft); }
.hero-stage-visual--frame-only { gap:0; min-height:inherit; place-items:center; }
.hero-stage-visual__frame--transparent { width:auto; max-width:100%; padding:0; border:none; border-radius:0; background:transparent; box-shadow:none; }
.hero-stage-visual__media-slot { width:clamp(180px, 20vw, 320px); aspect-ratio:1 / 1; display:grid; place-items:center; border:1px dashed rgba(18,44,76,.18); border-radius:24px; background: transparent; }
.hero-stage-visual__media-image { width:clamp(180px, 20vw, 320px); max-width:100%; height:auto; display:block; object-fit:contain; border-radius:24px; box-shadow:none; }
.hero-stage-visual__hint { display:inline-flex; align-items:center; justify-content:center; width:min(100%, 280px); min-height:56px; padding:14px 18px; border-radius:22px; border:1px dashed rgba(155,91,0,.28); background: rgba(255,255,255,.7); color:#8a6641; font-size:14px; font-weight:600; line-height:1.6; text-align:center; word-break: keep-all; }
.quick-move { margin-top:32px; width:100%; padding:0; border:none; border-radius:0; background:transparent; box-shadow:none; }
.quick-move .section-heading { margin-bottom:16px; }
.poster-section-intro,
.event-section-intro {
  margin-top:44px;
  padding-block:clamp(24px, 3.5vw, 44px);
  display:grid;
  align-content:center;
  gap:10px;
  justify-items:center;
  text-align:center;
}
.poster-section-intro__title,
.event-section-intro__title {
  margin:0;
  font-size:clamp(42px, 4.2vw, 56px);
  line-height:1.2;
  letter-spacing:-0.03em;
  color: var(--text-strong);
}
.poster-section-intro__description,
.event-section-intro__description {
  margin:0;
  max-width:720px;
  font-size:clamp(18px, 2.7vw, 24px);
  color: var(--text);
  line-height:1.72;
  word-break: keep-all;
}
.quick-move__grid { width:100%; display:grid; grid-template-columns:repeat(4, minmax(0, 1fr)); gap:16px; }
.quick-move--poster { margin-top:18px; }
.quick-move--poster .quick-move__grid { grid-template-columns:minmax(0, 1fr) minmax(0, 3fr); }
.quick-move--poster .quick-move__item:first-child .quick-move__frame { aspect-ratio:2 / 3; }
.quick-move--poster .quick-move__item:last-child .quick-move__frame { aspect-ratio:2 / 1; }
.quick-move--overview-intro .quick-move__grid { grid-template-columns:minmax(0, 1fr) minmax(0, 1fr) minmax(0, 2fr); }
.quick-move--overview-intro .quick-move__item:nth-child(-n + 2) .quick-move__frame { aspect-ratio:2 / 3; }
.quick-move--overview-intro .quick-move__item:last-child .quick-move__frame { aspect-ratio:2 / 1; }
.quick-move--event { margin-top:18px; }
.quick-move--event .quick-move__grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
.quick-move--event .quick-move__frame { aspect-ratio:3 / 2; }
.quick-move__item {
  border-radius:22px;
  padding:0;
  background: transparent;
}
.quick-move__frame {
  width:100%;
  aspect-ratio:1 / 1;
  border-radius:18px;
  display:grid;
  place-items:center;
  padding:0;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.36);
  background: linear-gradient(180deg, rgba(255,255,255,.34), rgba(255,255,255,.18));
  backdrop-filter: blur(12px) saturate(1.08);
  -webkit-backdrop-filter: blur(12px) saturate(1.08);
  box-shadow: 0 12px 24px rgba(18,44,76,.1);
}
.quick-move__item--placeholder .quick-move__frame {
  background: linear-gradient(180deg, rgba(255,255,255,.26), rgba(255,255,255,.12));
}
.quick-move__slot {
  width:100%;
  height:100%;
  border-radius:inherit;
  background: rgba(255,255,255,.12);
}
.quick-move__image {
  width:100%;
  height:100%;
  border-radius:inherit;
  object-fit:cover;
  background: transparent;
  display:block;
}
:root[data-theme='dark'] .quick-move__frame {
  border-color: rgba(141,212,255,.24);
  background: linear-gradient(180deg, rgba(18,35,58,.42), rgba(10,19,34,.28));
  box-shadow: 0 12px 26px rgba(2,8,16,.34);
}
:root[data-theme='dark'] .quick-move__item--placeholder .quick-move__frame {
  background: linear-gradient(180deg, rgba(18,35,58,.3), rgba(10,19,34,.2));
}
:root[data-theme='dark'] .quick-move__slot {
  background: rgba(143,165,199,.08);
}
.hero-visual-card { display:grid; align-content:end; gap:14px; min-height:340px; padding:28px; border-radius:36px; border:1px solid rgba(255,198,73,.28); background: linear-gradient(180deg, rgba(255,255,255,.24), rgba(255,255,255,.58)), radial-gradient(circle at 15% 12%, rgba(255,207,82,.52), transparent 32%), radial-gradient(circle at 82% 18%, rgba(141,212,255,.38), transparent 30%), linear-gradient(135deg, #fff5d0 0%, #fff8ef 45%, #fff1ea 100%); box-shadow: var(--shadow-soft); }
.hero-visual-card--summary { min-height:auto; }
.hero-visual-card strong { font-size: clamp(30px,3vw,40px); line-height:1.16; letter-spacing:-.04em; color:#5a3c13; }
.hero-visual-card p { color:#7e6241; font-size:15px; line-height:1.7; margin:0; }
.landing-shortcuts { display:grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap:14px; margin-top:24px; }
.landing-shortcut { display:grid; gap:10px; align-content:end; min-height:220px; padding:22px; border-radius:30px; border:1px solid rgba(255,255,255,.55); color:#4f3a24; box-shadow: var(--shadow-soft); position:relative; overflow:hidden; transition: transform .2s ease,border-color .2s ease,box-shadow .2s ease,filter .2s ease; }
.landing-shortcut::after { content:''; position:absolute; inset:auto -10% -30% auto; width:150px; height:150px; border-radius:50%; background: radial-gradient(circle, rgba(255,255,255,.4), rgba(255,255,255,0)); pointer-events:none; }
.landing-shortcut__kicker { position:relative; z-index:1; color:#8b6d4b; font-size:12px; font-weight:700; letter-spacing:.08em; }
.landing-shortcut strong,.landing-shortcut p { position:relative; z-index:1; }
.landing-shortcut strong { font-size:24px; line-height:1.18; letter-spacing:-.03em; }
.landing-shortcut p { margin:0; color:#6f5a45; line-height:1.65; font-size:14px; }
.landing-shortcut:hover,.landing-shortcut:focus-visible { transform:translateY(-3px); border-color:rgba(255,184,76,.54); box-shadow: var(--shadow); filter:saturate(1.03); }
.landing-shortcut--week { background: linear-gradient(180deg, rgba(255,255,255,.46), rgba(255,245,216,.96)), linear-gradient(135deg, #ffe48c 0%, #fff7d9 100%); }
.landing-shortcut--contents { background: linear-gradient(180deg, rgba(255,255,255,.46), rgba(231,248,255,.95)), linear-gradient(135deg, #bfefff 0%, #e9fbff 100%); }
.landing-shortcut--daily { background: linear-gradient(180deg, rgba(255,255,255,.46), rgba(240,234,255,.96)), linear-gradient(135deg, #d3c9ff 0%, #f2efff 100%); }
.landing-shortcut--culture { background: linear-gradient(180deg, rgba(255,255,255,.46), rgba(255,232,244,.96)), linear-gradient(135deg, #ffc3dc 0%, #fff0f7 100%); }
.landing-shortcut--discover { background: linear-gradient(180deg, rgba(255,255,255,.46), rgba(228,255,247,.96)), linear-gradient(135deg, #c5f5e9 0%, #effff9 100%); }
.campaign-grid--heroic { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.section-card--heroic { min-height:220px; }
.roadmap-hero { overflow:hidden; }
.roadmap-panel { background: linear-gradient(180deg, rgba(226,245,255,.94), rgba(255,255,255,.92)); }
.roadmap-flow { display:flex; align-items:center; justify-content:space-between; gap:0; padding:20px 4px 6px; overflow-x:auto; }
.roadmap-step { position:relative; z-index:1; display:grid; justify-items:center; gap:12px; min-width:132px; text-align:center; flex:0 0 auto; }
.roadmap-step::before { content:''; width:92px; height:92px; border-radius:50%; border:2px solid rgba(255,184,76,.45); background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.98), rgba(255,244,227,.94)); box-shadow: 0 18px 36px rgba(18,44,76,.12); }
.roadmap-step > * { position:relative; z-index:1; }
.roadmap-step__number { position:absolute; top:28px; display:inline-flex; align-items:center; justify-content:center; min-width:44px; min-height:44px; padding:0 10px; border-radius:999px; background: var(--button-bg); color: var(--button-text); font-size:14px; font-weight:800; box-shadow: var(--button-shadow); }
.roadmap-step strong { margin-top:-8px; font-size:15px; line-height:1.5; color: var(--text-strong); word-break: keep-all; }
.roadmap-step.is-active::before { border-color: rgba(33,99,170,.42); background: radial-gradient(circle at 30% 30%, rgba(238,248,255,.98), rgba(217,236,255,.94)); }
.roadmap-line { flex:1 1 56px; min-width:56px; height:4px; margin:0 -6px; border-radius:999px; background: linear-gradient(90deg, rgba(255,191,87,.9), rgba(118,187,255,.7)); }
.roadmap-summary-grid { margin-top:24px; }
:root[data-theme='dark'] .roadmap-panel { background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015)); }
:root[data-theme='dark'] .roadmap-step::before { border-color: rgba(119,186,255,.28); background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.06), rgba(255,255,255,.02)); }
:root[data-theme='dark'] .roadmap-step.is-active::before { border-color: rgba(255,206,91,.46); background: radial-gradient(circle at 30% 30%, rgba(255,214,112,.12), rgba(255,255,255,.02)); }
@media (max-width: 1024px) {
  .metric-grid,.stats-grid,.metric-strip,.campaign-grid--heroic,.hero__grid--landing,.landing-shortcuts,.detail-layout { grid-template-columns: repeat(2, minmax(0, 1fr)); display:grid; }
  .hero--landing-stage { min-height: auto; }
  .hero--landing-stage.hero--landing-frame-only { min-height: calc(100svh - 140px); }
  .hero__grid--landing-stage { grid-template-columns: minmax(0, 1fr); }
  .hero-stage-visual { order: 2; }
  .hero-visual-card--summary { order: 3; min-height: 240px; }
  .feature-grid,.content-grid,.admin-metric-grid,.admin-feature-grid,.admin-content-grid,.admin-detail-grid,.admin-login-grid { grid-template-columns: 1fr; display:grid; }
  .detail-sidebar { width:auto; }
}
@media (max-width: 768px) {
  button,.button,.site-button,.admin-button,input[type='submit'],input[type='button'],input[type='reset'] { min-height:46px; }
  .metric-grid,.stats-grid,.metric-strip,.campaign-grid--heroic,.hero__grid--landing,.landing-shortcuts { grid-template-columns: 1fr; }
  .metric-card,.feature-card,.list-card,.detail-card,.stat-card,.panel-card,.section-shell,.page-panel,.admin-panel,.admin-detail-card,.admin-login-card,.admin-login-info,.hero-panel,.metric-tile,.section-card { padding:18px; }
  .section-heading { align-items:flex-start; flex-direction:column; }
  .list-card--row,.site-header__actions,.hero__grid,.detail-layout { display:grid; }
  .list-card__side { align-items:flex-start; min-width:0; }
  .common-hero { min-height:auto; padding:20px 0 16px; }
  .common-hero__nav { gap:10px; justify-content:center; }
  .common-hero__nav-link { width:100%; justify-content:center; padding:12px 16px; }
  .hero-stage-visual__frame { width:100%; max-width:420px; padding:24px; border-radius:32px; }
  .hero-stage-visual__frame--transparent { width:auto; max-width:100%; padding:0; }
  .hero-stage-visual__media-slot,
  .hero-stage-visual__media-image { width:clamp(160px, 46vw, 240px); border-radius:20px; }
  .quick-move { margin-top:24px; }
  .poster-section-intro,
  .event-section-intro {
    margin-top:32px;
    padding-block:clamp(18px, 6vw, 28px);
    gap:8px;
  }
  .poster-section-intro__title,
  .event-section-intro__title { font-size:clamp(34px, 8vw, 42px); }
  .poster-section-intro__description,
  .event-section-intro__description { font-size:18px; line-height:1.65; }
  .quick-move__grid { grid-template-columns:repeat(2, minmax(0, 1fr)); gap:12px; }
  .quick-move--poster { margin-top:14px; }
  .quick-move--poster .quick-move__grid { grid-template-columns:1fr; }
  .quick-move--poster .quick-move__item:last-child .quick-move__frame { aspect-ratio:1 / 1; }
  .quick-move--overview-intro .quick-move__item .quick-move__frame { aspect-ratio:1 / 1; }
  .quick-move--event { margin-top:14px; }
  .quick-move--event .quick-move__grid { grid-template-columns:1fr; }
  .quick-move__item { padding:0; border-radius:18px; }
  .quick-move__frame { border-radius:14px; }
  .quick-move__slot,
  .quick-move__image { border-radius:12px; }
  .landing-shortcut { min-height:180px; }
}
@media (max-width: 520px) {
  .filter-bar > *,.search-row > *,.admin-filter--grid > * { flex-basis:100%; }
  .inline-form .actions,.toolbar-row .actions,.filter-bar .actions,.form-actions { width:100%; }
  .inline-form .actions > *,.toolbar-row .actions > *,.filter-bar .actions > *,.form-actions > * { flex: 1 1 calc(50% - 6px); }
  .site-footer__meta { grid-template-columns:1fr; display:grid; }
}
