    :root {
      --bg:        #0E0B09;
      --bg-2:      #161210;
      --bg-3:      #1F1915;
      --surface:   #1A1512;
      --surface-2: #221B16;
      --line:      #3A2F24;
      --line-soft: #2A231E;

      --ink:       #F5EBDA;
      --ink-2:     #D8CDB9;
      --ink-3:     #A79B85;
      --muted:     #756A56;

      --gold:      #D4AF37;
      --gold-2:    #B8860B;
      --gold-soft: rgba(212,175,55,0.14);

      --accent-green: #6FA77C;
      --accent-red:   #D88079;
      --accent-blue:  #7AA7C5;

      --serif: 'Noto Serif KR', 'Cormorant Garamond', serif;
      --sans:  'NanumSquareRound', -apple-system, system-ui, sans-serif;
    }

    * { box-sizing: border-box; }
    html, body {
      margin: 0; padding: 0;
      overscroll-behavior: none;
      overscroll-behavior-y: none;
      overscroll-behavior-x: none;
      touch-action: pan-y pinch-zoom; /* 수평 swipe-back 차단 */
    }
    html { color-scheme: dark; } /* 프리미엄 페이지는 다크 테마 — Samsung Internet 다크모드 강제 변환 차단 */

    body {
      font-family: var(--sans);
      color: var(--ink-2);
      background: var(--bg);
      background-image:
        radial-gradient(900px 500px at 15% 0%, rgba(212,175,55,0.08) 0%, transparent 60%),
        radial-gradient(1200px 600px at 120% 20%, rgba(184,134,11,0.06) 0%, transparent 55%),
        linear-gradient(180deg, #0E0B09 0%, #0B0907 100%);
      background-attachment: fixed;
      min-height: 100vh;
      min-height: 100dvh;
      -webkit-font-smoothing: antialiased;
      line-height: 1.6;
    }

    img, svg { max-width: 100%; height: auto; display: block; }
    a { color: inherit; }

    /* ================================================================
       TOP BAR
       ================================================================ */
    .top-bar {
      position: sticky; top: 0; z-index: 20;
      background: rgba(14,11,9,0.85);
      -webkit-backdrop-filter: saturate(160%) blur(14px);
      backdrop-filter: saturate(160%) blur(14px);
      border-bottom: 1px solid var(--line-soft);
    }
    .top-bar__inner {
      max-width: 780px; margin: 0 auto;
      padding: 18px 24px;
      display: flex; align-items: center; justify-content: space-between;
    }
    .logo {
      display: flex; align-items: center; gap: 10px;
      color: var(--ink); text-decoration: none;
      font-family: var(--serif);
      font-weight: 700; font-size: 16px;
      letter-spacing: 0.02em;
    }
    .logo__mark {
      width: 28px; height: 28px; border-radius: 50%;
      object-fit: cover;
      box-shadow: 0 0 18px rgba(212,175,55,0.35), inset 0 0 0 1px rgba(255,255,255,0.15);
      flex-shrink: 0;
      display: block;
    }
    .logo__hanja {
      font-family: var(--serif);
      color: var(--gold);
      font-size: 14px;
      opacity: 0.7;
      margin-left: 4px;
    }
    .top-badge {
      font-family: var(--serif);
      font-size: 10px;
      font-weight: 700;
      color: var(--gold);
      border: 1px solid var(--gold);
      border-radius: 0;
      padding: 5px 12px;
      letter-spacing: 0.3em;
      background: transparent;
      text-transform: uppercase;
    }
    .top-bar__actions {
      display: flex; align-items: center; gap: 12px;
    }
    .top-bar__link {
      display: inline-flex; align-items: center; gap: 6px;
      color: var(--ink); text-decoration: none;
      font-size: 12px; font-weight: 600;
      padding: 6px 10px;
      border: 1px solid rgba(212,175,55,0.3);
      border-radius: 4px;
      background: rgba(212,175,55,0.06);
      transition: all 0.18s;
    }
    .top-bar__link:hover { border-color: var(--gold); color: var(--gold); }
    .top-bar__link span { letter-spacing: 0.05em; }
    @media (max-width: 480px) {
      .top-bar__link span { display: none; }
      .top-bar__link { padding: 6px 8px; }
      .top-bar__inner { padding: 14px 14px; gap: 8px; }
      .logo { white-space: nowrap; min-width: 0; flex-shrink: 1; gap: 6px; font-size: 14.5px; }
      .logo span { white-space: nowrap; }
      .logo__hanja { display: none; }
      .top-bar__actions { gap: 6px; flex-shrink: 0; }
      .top-badge { padding: 4px 8px; font-size: 9px; letter-spacing: 0.2em; }
    }

    /* ================================================================
       HERO - 매거진 커버
       ================================================================ */
    .hero {
      max-width: 780px; margin: 0 auto;
      padding: 80px 24px 60px;
      text-align: center;
      position: relative;
    }
    .hero::before {
      content: '命';
      position: absolute;
      top: 40px; left: 50%;
      transform: translateX(-50%);
      font-family: var(--serif);
      font-size: 180px;
      color: rgba(212,175,55,0.05);
      font-weight: 900;
      line-height: 1;
      pointer-events: none;
      z-index: 0;
    }
    .hero__kicker {
      font-family: var(--serif);
      font-size: 11px;
      letter-spacing: 0.45em;
      color: var(--gold);
      font-weight: 600;
      margin: 0 0 24px;
      position: relative; z-index: 1;
    }
    .hero__kicker::before,
    .hero__kicker::after {
      content: '';
      display: inline-block;
      width: 24px; height: 1px;
      background: var(--gold);
      vertical-align: middle;
      margin: 0 12px;
      opacity: 0.6;
    }
    .hero__title {
      font-family: var(--serif);
      font-weight: 700;
      font-size: 40px;
      line-height: 1.4;
      color: var(--ink);
      margin: 0 0 14px;
      word-break: keep-all;
      letter-spacing: -0.01em;
      position: relative; z-index: 1;
    }
    .hero__name {
      color: var(--gold);
      font-style: italic;
      font-family: 'Cormorant Garamond', var(--serif);
      font-weight: 600;
      margin-right: 4px;
    }
    .hero__meta {
      font-size: 13px; color: var(--ink-3);
      margin: 0 0 48px;
      letter-spacing: 0.08em;
      position: relative; z-index: 1;
    }

    /* 사주 4기둥 — 한자 중심, 세로로 임팩트 */
    .pillars {
      display: grid; grid-template-columns: repeat(4, 1fr);
      gap: 14px;
      max-width: 500px; margin: 0 auto;
      position: relative; z-index: 1;
    }
    .pillar {
      background: linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);
      border: 1px solid var(--line);
      border-radius: 4px;
      padding: 22px 10px 20px;
      text-align: center;
      position: relative;
      overflow: hidden;
    }
    .pillar::before {
      content: '';
      position: absolute; top: 0; left: 0; right: 0; height: 1px;
      background: linear-gradient(90deg, transparent, var(--gold) 50%, transparent);
      opacity: 0.5;
    }
    .pillar__label {
      font-size: 10px; color: var(--muted);
      letter-spacing: 0.25em;
      margin: 0 0 14px;
    }
    .pillar__gan {
      font-family: var(--serif);
      font-size: 28px; font-weight: 700;
      color: var(--ink);
      line-height: 1;
      margin: 0 0 6px;
    }
    .pillar__ji {
      font-family: var(--serif);
      font-size: 22px; font-weight: 400;
      color: var(--ink-3);
      line-height: 1;
      margin: 0;
    }

    /* ================================================================
       CHAPTER PROGRESS (top sticky bar — 현재 챕터/9 + 진행률)
       ================================================================ */
    .chapter-progress {
      position: sticky;
      top: 64px;  /* top-bar 아래 */
      z-index: 40;
      background: rgba(13,8,5,0.92);
      backdrop-filter: saturate(160%) blur(12px);
      -webkit-backdrop-filter: saturate(160%) blur(12px);
      border-bottom: 1px solid var(--line-soft);
      box-shadow: 0 4px 14px rgba(0,0,0,0.18);
    }
    .chapter-progress__inner {
      max-width: 780px; margin: 0 auto;
      padding: 12px 24px 8px;
      display: flex; align-items: center; justify-content: space-between;
      gap: 16px;
    }
    .chapter-progress__label {
      display: flex; align-items: baseline; gap: 10px;
      min-width: 0;
    }
    .chapter-progress__roman {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic; font-weight: 600;
      font-size: 18px; color: var(--gold);
      flex-shrink: 0;
    }
    .chapter-progress__title {
      font-family: var(--serif);
      font-size: 13px; font-weight: 600;
      color: var(--ink);
      letter-spacing: -0.005em;
      white-space: nowrap;
      overflow: hidden; text-overflow: ellipsis;
    }
    .chapter-progress__count {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      font-size: 14px; color: var(--ink-3);
      flex-shrink: 0;
      letter-spacing: 0.04em;
    }
    .chapter-progress__count strong {
      font-weight: 700; color: var(--gold);
      font-size: 16px;
    }
    .chapter-progress__bar {
      max-width: 780px; margin: 0 auto;
      height: 3px;
      background: rgba(212,175,55,0.10);
      position: relative;
    }
    .chapter-progress__fill {
      height: 100%;
      background: linear-gradient(90deg, var(--gold) 0%, #E8C667 100%);
      width: 0%;
      transition: width 0.42s cubic-bezier(0.34, 1.2, 0.64, 1);
      box-shadow: 0 0 10px rgba(212,175,55,0.55);
    }
    @media (max-width: 480px) {
      .chapter-progress { top: 60px; }
      .chapter-progress__inner { padding: 10px 18px 6px; gap: 10px; }
      .chapter-progress__title { font-size: 12.5px; max-width: 60vw; }
      .chapter-progress__roman { font-size: 16px; }
    }

    /* ================================================================
       CHAPTER FAB (floating prev/next, 큰 좌우 fab)
       ================================================================ */
    .chapter-fab {
      position: fixed;
      top: 50%;
      transform: translateY(-50%);
      z-index: 45;
      width: 52px; height: 52px;
      border-radius: 50%;
      background: rgba(13,8,5,0.78);
      color: var(--gold);
      border: 1px solid rgba(212,175,55,0.36);
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
      cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      box-shadow: 0 8px 24px rgba(0,0,0,0.32);
      transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
    }
    .chapter-fab:hover:not(:disabled) {
      transform: translateY(-50%) scale(1.08);
      background: rgba(20,12,5,0.92);
      border-color: var(--gold);
    }
    .chapter-fab:active { transform: translateY(-50%) scale(0.96); }
    .chapter-fab:disabled {
      opacity: 0.32;
      cursor: not-allowed;
    }
    .chapter-fab--prev { left: 14px; }
    .chapter-fab--next { right: 14px; }
    @media (max-width: 480px) {
      .chapter-fab { width: 44px; height: 44px; }
      .chapter-fab--prev { left: 8px; }
      .chapter-fab--next { right: 8px; }
    }
    @media (max-width: 380px) {
      .chapter-fab { display: none; }  /* 작은 모바일 — 가독성 우선 */
    }

    /* ================================================================
       CHAPTER NAV (sticky under topbar)
       ================================================================ */
    .chapters-nav {
      max-width: 780px; margin: 20px auto 0;
      padding: 0 24px;
      position: relative;
    }
    .chapters-nav__inner {
      display: flex; gap: 0;
      border-top: 1px solid var(--line-soft);
      border-bottom: 1px solid var(--line-soft);
      overflow-x: auto;
      scrollbar-width: none;
    }
    .chapters-nav__inner::-webkit-scrollbar { display: none; }
    .chapter-tab {
      flex-shrink: 0;
      padding: 16px 18px;
      font-family: var(--serif);
      font-size: 12px;
      font-weight: 600;
      color: var(--ink-3);
      letter-spacing: 0.08em;
      text-decoration: none;
      border-bottom: 2px solid transparent;
      transition: all 0.25s ease;
      position: relative;
      white-space: nowrap;
      background: none;
      border-top: none;
      border-left: none;
      border-right: none;
      cursor: pointer;
    }
    .chapter-tab:hover,
    .chapter-tab.is-active {
      color: var(--gold);
      border-bottom-color: var(--gold);
    }
    .chapter-tab__num {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      font-size: 10px;
      opacity: 0.7;
      margin-right: 6px;
    }

    /* ================================================================
       MAIN - 전체 스크롤 컨테이너
       ================================================================ */
    .main {
      max-width: 780px; margin: 0 auto;
      padding: 60px 24px 160px;
    }

    /* ================================================================
       STATE (로딩/에러)
       ================================================================ */
    .state {
      padding: 80px 20px;
      text-align: center;
    }
    .state__spinner {
      width: 56px; height: 56px;
      border: 3px solid var(--line);
      border-top-color: var(--gold);
      border-radius: 50%;
      animation: spin 0.9s linear infinite;
      margin: 0 auto 24px;
    }
    @keyframes spin { to { transform: rotate(360deg); } }
    .state__title {
      font-family: var(--serif);
      font-size: 20px; font-weight: 700;
      color: var(--ink);
      margin: 0 0 10px;
    }
    .state__body {
      font-size: 13px; color: var(--ink-3);
      line-height: 1.9;
      letter-spacing: 0.02em;
    }

    /* ================================================================
       리포트 렌더 타겟 — result.js의 .pr-step 네비 구조를 다크 매거진으로 리스킨
       페이지 넘김(pagination) 모드 유지, 외관만 전환
       ================================================================ */
    #premiumLockSection { display: block; }
    #premiumLockSection .pr-wrap,
    #premiumLockSection .pr-body {
      all: unset; display: block;
    }
    #premiumLockSection .pr-header { display: none !important; }

    /* ── 프로그레스 바 (다크) ── */
    #premiumLockSection .pr-progress {
      height: 2px !important;
      background: var(--line-soft) !important;
      border-radius: 0 !important;
      margin: 0 0 40px !important;
      overflow: hidden !important;
    }
    #premiumLockSection .pr-progress__bar {
      background: linear-gradient(90deg, var(--gold-2), var(--gold), #E8C667) !important;
      border-radius: 0 !important;
      box-shadow: 0 0 10px rgba(212,175,55,0.5) !important;
    }

    /* ── 숨김: 기존 dot 네비 (위의 챕터 탭바로 대체) ── */
    #premiumLockSection .pr-dots { display: none !important; }

    /* ── 스텝 (페이지) ── */
    #premiumLockSection .pr-step {
      display: none;
      animation: fadeSlideUp 0.55s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
      min-height: 60vh;
    }
    #premiumLockSection .pr-step.pr-step--active {
      display: block !important;
    }
    @keyframes fadeSlideUp {
      from { opacity: 0; transform: translateY(16px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    /* ── 각 스텝 타이틀을 챕터 커버로 변환 ── */
    #premiumLockSection .pr-step__title {
      font-family: var(--serif) !important;
      font-size: 32px !important;
      font-weight: 700 !important;
      color: var(--ink) !important;
      text-align: center !important;
      margin: 0 0 14px !important;
      padding-top: 32px !important;
      letter-spacing: -0.01em !important;
      line-height: 1.45 !important;
      position: relative !important;
    }
    #premiumLockSection .pr-step__title::before {
      content: attr(data-kicker);
      display: block;
      font-family: 'Cormorant Garamond', serif;
      font-size: 13px;
      font-style: italic;
      font-weight: 400;
      color: var(--gold);
      letter-spacing: 0.35em;
      text-transform: uppercase;
      margin-bottom: 18px;
    }
    #premiumLockSection .pr-step__title::after {
      content: '';
      display: block;
      width: 40px; height: 1px;
      background: var(--gold);
      margin: 24px auto 0;
      opacity: 0.7;
    }
    #premiumLockSection .pr-step__sub {
      font-family: var(--serif) !important;
      font-size: 14px !important;
      color: var(--ink-3) !important;
      text-align: center !important;
      margin: 18px 0 56px !important;
      letter-spacing: 0.08em !important;
      line-height: 1.8 !important;
    }
    #premiumLockSection .pr-step__body {
      background: transparent !important;
      border-radius: 0 !important;
      padding: 0 !important;
      box-shadow: none !important;
    }

    /* result.js가 만드는 구식 divider 무력화 (우리 report-divider 사용) */
    #premiumLockSection .pr-divider { display: none; }

    /* ── 이전/다음 네비게이션 (다크 리스킨) ── */
    #premiumLockSection .pr-nav {
      display: flex !important;
      justify-content: space-between !important;
      align-items: center !important;
      gap: 16px !important;
      margin: 64px 0 0 !important;
      padding: 28px 0 0 !important;
      border-top: 1px solid var(--line-soft) !important;
    }
    #premiumLockSection .pr-btn {
      font-family: var(--serif) !important;
      font-size: 13px !important;
      font-weight: 600 !important;
      padding: 14px 22px !important;
      border-radius: 2px !important;
      letter-spacing: 0.08em !important;
      cursor: pointer !important;
      transition: all 0.25s ease !important;
      border-width: 1px !important;
      border-style: solid !important;
    }
    #premiumLockSection .pr-btn--prev {
      background: transparent !important;
      border-color: var(--line) !important;
      color: var(--ink-3) !important;
      box-shadow: none !important;
    }
    #premiumLockSection .pr-btn--prev:not(:disabled):hover {
      border-color: var(--gold) !important;
      color: var(--gold) !important;
      transform: none !important;
    }
    #premiumLockSection .pr-btn--prev:disabled {
      opacity: 0.35 !important;
      cursor: not-allowed !important;
    }
    #premiumLockSection .pr-btn--next {
      background: var(--gold) !important;
      border-color: var(--gold) !important;
      color: #0E0B09 !important;
      box-shadow: 0 6px 20px rgba(212,175,55,0.18) !important;
    }
    #premiumLockSection .pr-btn--next:hover {
      background: #E8C667 !important;
      color: #0E0B09 !important;
      transform: translateY(-1px) !important;
      box-shadow: 0 8px 24px rgba(212,175,55,0.28) !important;
    }
    #premiumLockSection .pr-counter {
      font-family: 'Cormorant Garamond', serif !important;
      font-style: italic !important;
      font-size: 15px !important;
      color: var(--gold) !important;
      font-weight: 400 !important;
      letter-spacing: 0.1em !important;
    }

    /* ================================================================
       DESIGN SYSTEM — 다크 매거진 리포트
       ================================================================ */

    /* 챕터 블록 (각 에이전트 = 하나의 챕터) */
    .report-chapter {
      margin: 0 0 100px;
      scroll-margin-top: 80px;
    }
    .report-chapter__cover {
      text-align: center;
      margin: 0 0 48px;
      padding: 20px 0 40px;
      border-bottom: 1px solid var(--line-soft);
      position: relative;
    }
    .report-chapter__cover::after {
      content: '';
      position: absolute;
      bottom: -4px; left: 50%;
      transform: translateX(-50%);
      width: 8px; height: 8px;
      background: var(--bg);
      border: 1px solid var(--gold);
      border-radius: 50%;
    }
    .report-chapter__num {
      font-family: 'Cormorant Garamond', serif;
      font-size: 14px;
      font-style: italic;
      font-weight: 400;
      color: var(--gold);
      letter-spacing: 0.3em;
      margin: 0 0 16px;
      text-transform: uppercase;
    }
    .report-chapter__title {
      font-family: var(--serif);
      font-size: 32px;
      font-weight: 700;
      color: var(--ink);
      margin: 0 0 14px;
      letter-spacing: -0.01em;
      line-height: 1.4;
    }
    .report-chapter__hanja {
      display: inline-block;
      font-family: var(--serif);
      font-size: 13px;
      color: var(--gold);
      opacity: 0.7;
      letter-spacing: 0.4em;
      margin: 0;
      padding-top: 6px;
    }

    /* 카드 - 다크 표면 */
    .report-card {
      background: linear-gradient(180deg, var(--surface) 0%, var(--bg-2) 100%);
      border: 1px solid var(--line);
      border-radius: 6px;
      padding: 40px 36px;
      margin: 0 0 28px;
      position: relative;
      overflow: hidden;
    }
    .report-card::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0; height: 1px;
      background: linear-gradient(90deg, transparent, rgba(212,175,55,0.5) 50%, transparent);
    }
    .report-card__head {
      display: flex; align-items: baseline; gap: 12px;
      padding-bottom: 22px; margin-bottom: 28px;
      border-bottom: 1px solid var(--line-soft);
    }
    .report-card__index {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      font-size: 16px;
      color: var(--gold);
      opacity: 0.85;
      flex-shrink: 0;
    }
    .report-card__title {
      font-family: var(--serif);
      font-size: 20px;
      font-weight: 700;
      color: var(--ink);
      margin: 0;
      letter-spacing: -0.005em;
      flex: 1;
      word-break: keep-all;
    }
    .report-card__hanja {
      font-family: var(--serif);
      font-size: 12px;
      color: var(--gold);
      opacity: 0.5;
      letter-spacing: 0.2em;
      flex-shrink: 0;
    }

    /* 본문 타이포 */
    .report-body p {
      font-size: 17px;
      color: var(--ink-2);
      line-height: 2.2;
      letter-spacing: -0.01em;
      word-break: keep-all;
      overflow-wrap: anywhere;
      margin: 0 0 22px;
    }
    .report-body p:last-child { margin-bottom: 0; }
    .report-body p.lead {
      font-family: var(--serif);
      font-size: 19px;
      color: var(--ink);
      line-height: 2.0;
      font-weight: 500;
      margin-bottom: 28px;
      letter-spacing: -0.015em;
    }
    .report-body p.lead::before {
      content: '';
      display: block;
      width: 32px; height: 1px;
      background: var(--gold);
      margin-bottom: 20px;
      opacity: 0.7;
    }

    /* 인용형 불렛 하이라이트 */
    .report-pullquote {
      padding: 22px 26px;
      border-left: 2px solid var(--gold);
      margin: 28px 0;
      background: rgba(212,175,55,0.04);
      border-radius: 0 4px 4px 0;
    }
    .report-pullquote p {
      font-family: var(--serif);
      font-style: italic;
      font-size: 17px;
      color: var(--ink);
      line-height: 2.0;
      margin: 0;
    }

    /* 섹션 타이틀 (카드 밖) */
    .report-section-title {
      font-family: var(--serif);
      font-size: 18px;
      font-weight: 700;
      margin: 32px 0 20px;
      letter-spacing: 0.01em;
      color: var(--ink);
      display: flex; align-items: center; gap: 12px;
    }
    .report-section-title::before {
      content: ''; width: 4px; height: 16px;
      background: var(--gold);
      flex-shrink: 0;
    }
    .report-section-title--green::before { background: var(--accent-green); }
    .report-section-title--red::before   { background: var(--accent-red);   }
    .report-section-title--gold::before  { background: var(--gold);         }

    /* divider */
    .report-divider {
      display: flex; align-items: center; gap: 14px;
      margin: 36px 0;
    }
    .report-divider::before,
    .report-divider::after {
      content: ''; flex: 1; height: 1px;
      background: linear-gradient(90deg, transparent, var(--line-soft), transparent);
    }
    .report-divider__dot {
      width: 6px; height: 6px; border-radius: 50%;
      background: var(--gold); opacity: 0.6;
    }

    /* 스탯 그리드 (파워/럭/용신) */
    .report-stat-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
      gap: 1px;
      background: var(--line);
      border: 1px solid var(--line);
      margin: 0 0 28px;
      border-radius: 4px;
      overflow: hidden;
    }
    .report-stat {
      background: var(--bg-2);
      padding: 26px 18px 24px;
      text-align: center;
      min-width: 0;
    }
    .report-stat__label {
      font-family: var(--serif);
      font-size: 10px; color: var(--muted);
      letter-spacing: 0.28em;
      margin: 0 0 14px;
      text-transform: uppercase;
    }
    .report-stat__value {
      font-family: var(--serif);
      font-size: 18px; font-weight: 600; color: var(--gold);
      margin: 0;
      word-break: keep-all;
      line-height: 1.4;
    }

    /* 계절 카드 */
    .report-season-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
      gap: 14px;
      margin: 0 0 28px;
    }
    .report-season {
      padding: 26px 24px;
      border: 1px solid var(--line);
      background: var(--bg-2);
      border-radius: 4px;
      position: relative;
      min-width: 0;
    }
    .report-season::before {
      content: '';
      position: absolute;
      top: 0; left: 0; width: 40px; height: 1px;
    }
    .report-season__label {
      font-family: var(--serif);
      font-size: 14px;
      font-weight: 700;
      letter-spacing: 0.05em;
      margin: 0 0 14px;
      display: flex; align-items: center; gap: 8px;
    }
    .report-season__body {
      font-size: 15px;
      color: var(--ink-2);
      line-height: 2.0;
      margin: 0;
      word-break: keep-all;
    }
    .report-season--spring .report-season__label { color: #9FC8A8; }
    .report-season--spring::before { background: #9FC8A8; width: 100%; }
    .report-season--summer .report-season__label { color: #E6A084; }
    .report-season--summer::before { background: #E6A084; width: 100%; }
    .report-season--autumn .report-season__label { color: #D4AF37; }
    .report-season--autumn::before { background: #D4AF37; width: 100%; }
    .report-season--winter .report-season__label { color: #8BB5D4; }
    .report-season--winter::before { background: #8BB5D4; width: 100%; }

    /* 태그 칩 */
    .report-tags {
      display: flex; flex-wrap: wrap; gap: 8px;
      margin: 0 0 28px;
    }
    .report-tag {
      display: inline-block;
      padding: 10px 18px;
      border-radius: 2px;
      font-family: var(--serif);
      font-size: 13px;
      font-weight: 500;
      color: var(--ink-2);
      background: rgba(212,175,55,0.06);
      border: 1px solid rgba(212,175,55,0.25);
      line-height: 1.5;
      word-break: keep-all;
      letter-spacing: 0.02em;
    }
    .report-tag--red   { color: #E8A89F; background: rgba(216,128,121,0.06); border-color: rgba(216,128,121,0.3); }
    .report-tag--green { color: #A3C9AD; background: rgba(111,167,124,0.06); border-color: rgba(111,167,124,0.3); }
    .report-tag--blue  { color: #AFCADC; background: rgba(122,167,197,0.06); border-color: rgba(122,167,197,0.3); }

    /* 콜아웃 (강점/주의) — 대형 번호 매거진 스타일 */
    .report-callout {
      padding: 32px 30px;
      margin: 0 0 18px;
      border: 1px solid var(--line);
      background: var(--bg-2);
      border-radius: 4px;
      position: relative;
      overflow: hidden;
    }
    .report-callout::before {
      content: '';
      position: absolute;
      top: 0; left: 0; bottom: 0;
      width: 3px;
    }
    .report-callout__head {
      display: flex; align-items: flex-start; gap: 20px;
      margin-bottom: 18px;
    }
    .report-callout__num {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      font-size: 34px;
      font-weight: 600;
      line-height: 1;
      flex-shrink: 0;
      padding-top: 2px;
    }
    .report-callout__title {
      font-family: var(--serif);
      font-size: 19px;
      font-weight: 700;
      margin: 0;
      letter-spacing: -0.01em;
      line-height: 1.55;
      padding-top: 6px;
    }
    .report-callout__body {
      font-size: 16px;
      color: var(--ink-2);
      line-height: 2.1;
      margin: 0;
      padding-left: 58px;
      word-break: keep-all;
      letter-spacing: -0.005em;
    }
    .report-callout--strength::before  { background: var(--accent-green); }
    .report-callout--strength .report-callout__num,
    .report-callout--strength .report-callout__title { color: #A3C9AD; }
    .report-callout--warning::before   { background: var(--accent-red); }
    .report-callout--warning .report-callout__num,
    .report-callout--warning .report-callout__title { color: #E8A89F; }

    /* 로드맵 */
    .report-roadmap {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
      gap: 14px;
      margin: 0 0 28px;
    }
    .report-roadmap__year {
      padding: 26px 22px;
      background: var(--bg-2);
      border: 1px solid var(--line);
      border-radius: 4px;
      min-width: 0;
      position: relative;
    }
    .report-roadmap__year::before {
      content: '';
      position: absolute; top: 0; left: 0;
      width: 24px; height: 1px;
      background: var(--gold);
    }
    .report-roadmap__label {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      font-size: 28px;
      font-weight: 600;
      color: var(--gold);
      margin: 0 0 12px;
      letter-spacing: -0.02em;
      line-height: 1;
    }
    .report-roadmap__body {
      font-size: 15px;
      color: var(--ink-2);
      line-height: 1.95;
      margin: 0;
      word-break: keep-all;
    }

    /* 이미지 피겨 */
    .report-figure {
      margin: 36px 0;
      text-align: center;
    }
    .report-figure__img {
      width: 100%;
      max-width: 580px;
      aspect-ratio: 1 / 1;
      object-fit: cover;
      border-radius: 4px;
      box-shadow: 0 12px 48px rgba(212,175,55,0.12), 0 0 0 1px var(--line);
      margin: 0 auto;
    }
    .report-figure__caption {
      font-family: var(--serif);
      font-style: italic;
      font-size: 13px;
      color: var(--muted);
      margin: 14px 0 0;
      letter-spacing: 0.02em;
    }

    /* 오라 컬러 블록 */
    .report-aura-block {
      display: flex; align-items: center; gap: 20px;
      background: var(--bg-2);
      border: 1px solid var(--line);
      border-radius: 4px;
      padding: 26px 28px;
      margin: 0 0 28px;
    }
    .report-aura-block__swatch {
      width: 68px; height: 68px; border-radius: 50%;
      flex-shrink: 0;
      box-shadow:
        inset 0 0 0 2px rgba(255,255,255,0.08),
        0 0 40px rgba(255,255,255,0.1),
        0 0 0 1px var(--line);
    }
    .report-aura-block__title {
      font-family: var(--serif);
      font-size: 17px; font-weight: 700; color: var(--ink);
      margin: 0 0 8px;
      letter-spacing: -0.01em;
    }
    .report-aura-block__body {
      font-size: 14px; color: var(--ink-3);
      line-height: 1.85; margin: 0;
      word-break: keep-all;
    }

    /* 리스트 */
    .report-list {
      list-style: none;
      padding: 0; margin: 0 0 28px;
    }
    .report-list li {
      font-size: 16px;
      color: var(--ink-2);
      line-height: 2.0;
      margin: 0 0 18px;
      letter-spacing: -0.01em;
      word-break: keep-all;
      padding-left: 28px;
      position: relative;
    }
    .report-list li::before {
      content: '';
      position: absolute;
      left: 0; top: 16px;
      width: 14px; height: 1px;
      background: var(--gold);
      opacity: 0.6;
    }

    /* 디스클레이머 */
    .report-disclaimer {
      margin: 36px 0 0;
      padding: 20px 22px;
      background: rgba(212,175,55,0.03);
      border-left: 2px solid var(--gold);
      color: var(--ink-3);
      font-family: var(--serif);
      font-style: italic;
      font-size: 13px;
      line-height: 1.85;
      letter-spacing: 0.02em;
      word-break: keep-all;
    }

    /* 피날레 — 블리드 배너 + 마스터 메시지 */
    .report-finale-banner {
      text-align: center;
      margin: 0 0 44px;
      padding: 56px 32px;
      background:
        radial-gradient(circle at 50% 0%, rgba(212,175,55,0.15) 0%, transparent 60%),
        linear-gradient(180deg, #151008 0%, #0A0705 100%);
      border-radius: 4px;
      border: 1px solid var(--gold);
      position: relative;
    }
    .report-finale-banner::before,
    .report-finale-banner::after {
      content: '◆';
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      font-size: 10px;
      color: var(--gold);
      opacity: 0.6;
    }
    .report-finale-banner::before { top: 18px; }
    .report-finale-banner::after  { bottom: 18px; }
    .report-finale-banner__kicker {
      font-family: var(--serif);
      font-size: 11px;
      letter-spacing: 0.5em;
      color: var(--gold);
      margin: 0 0 18px;
      font-weight: 600;
      padding-left: 0.5em;
    }
    .report-finale-banner__title {
      font-family: var(--serif);
      font-size: 28px;
      font-weight: 700;
      color: var(--ink);
      line-height: 1.5;
      letter-spacing: -0.005em;
      margin: 0;
      word-break: keep-all;
    }
    .report-master-message {
      margin: 48px 0 0;
      padding: 56px 36px;
      background:
        radial-gradient(circle at 30% 20%, rgba(212,175,55,0.1) 0%, transparent 60%),
        linear-gradient(180deg, #0F0C09 0%, #060403 100%);
      border: 1px solid var(--gold);
      border-radius: 4px;
      text-align: center;
      position: relative;
    }
    .report-master-message__kicker {
      font-family: var(--serif);
      font-size: 11px;
      letter-spacing: 0.5em;
      color: var(--gold);
      margin: 0 0 28px;
      font-weight: 600;
      padding-left: 0.5em;
      position: relative;
    }
    .report-master-message__kicker::before,
    .report-master-message__kicker::after {
      content: ''; display: inline-block;
      width: 20px; height: 1px;
      background: var(--gold);
      vertical-align: middle;
      margin: 0 16px;
      opacity: 0.6;
    }
    .report-master-message__body {
      font-family: var(--serif);
      font-size: 19px;
      color: var(--ink);
      line-height: 2.3;
      font-style: italic;
      margin: 0;
      letter-spacing: -0.005em;
      word-break: keep-all;
      font-weight: 400;
    }

    /* ================================================================
       REVIEW — 후기 작성 / 별점
       ================================================================ */
    .review-section {
      max-width: 780px; margin: 40px auto 0;
      padding: 48px 24px;
      border-top: 1px solid var(--line-soft);
      border-bottom: 1px solid var(--line-soft);
    }
    .review-section[hidden] { display: none; }
    .review-section__kicker {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      font-size: 13px;
      color: var(--gold);
      letter-spacing: 0.3em;
      text-align: center;
      margin: 0 0 14px;
    }
    .review-section__title {
      font-family: var(--serif);
      font-size: 24px;
      font-weight: 700;
      color: var(--ink);
      text-align: center;
      margin: 0 0 32px;
      letter-spacing: -0.01em;
    }
    .star-rating {
      display: flex; justify-content: center; gap: 10px;
      margin: 0 0 24px;
    }
    .star-rating__btn {
      background: none; border: none; cursor: pointer;
      font-size: 36px; line-height: 1; padding: 6px;
      color: #3A2F24;
      transition: color 0.15s, transform 0.15s;
    }
    .star-rating__btn:hover,
    .star-rating__btn.is-filled { color: var(--gold); }
    .star-rating__btn:hover { transform: scale(1.1); }
    .review-textarea {
      display: block; width: 100%;
      min-height: 120px; resize: vertical;
      padding: 18px 20px;
      background: var(--bg-2);
      border: 1px solid var(--line);
      border-radius: 4px;
      color: var(--ink);
      font-family: var(--sans);
      font-size: 15px;
      line-height: 1.8;
      letter-spacing: -0.01em;
      transition: border-color 0.2s;
    }
    .review-textarea:focus {
      outline: none;
      border-color: var(--gold);
    }
    .review-textarea::placeholder { color: var(--muted); }
    .review-submit {
      display: block;
      margin: 20px auto 0;
      padding: 14px 36px;
      background: var(--gold);
      color: #0E0B09;
      border: 1px solid var(--gold);
      border-radius: 2px;
      font-family: var(--serif);
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.1em;
      cursor: pointer;
      transition: background 0.2s;
    }
    .review-submit:hover { background: #E8C667; }
    .review-submit:disabled { opacity: 0.5; cursor: not-allowed; }
    .review-message {
      text-align: center;
      margin: 14px 0 0;
      font-size: 13px;
      color: var(--ink-3);
      font-style: italic;
      min-height: 20px;
    }

    /* ================================================================
       FLOATING ACTIONS
       ================================================================ */
    .floating-actions {
      position: fixed; left: 0; right: 0; bottom: 0;
      z-index: 30;
      padding: 18px 20px calc(18px + env(safe-area-inset-bottom));
      background: linear-gradient(to top, rgba(14,11,9,0.98) 60%, rgba(14,11,9,0));
      display: flex; gap: 10px; justify-content: center;
    }
    .floating-action {
      flex: 1; max-width: 240px;
      padding: 15px 18px;
      border-radius: 2px;
      font-family: var(--serif);
      font-size: 13px; font-weight: 600;
      text-decoration: none; text-align: center;
      letter-spacing: 0.08em;
      cursor: pointer;
      transition: all 0.2s;
      border: 1px solid var(--line);
      background: transparent;
      color: var(--ink-2);
    }
    .floating-action:hover {
      border-color: var(--gold);
      color: var(--gold);
    }
    .floating-action--primary {
      background: var(--gold);
      color: #0E0B09;
      border-color: var(--gold);
    }
    .floating-action--primary:hover {
      background: #E8C667;
      color: #0E0B09;
    }

    /* ================================================================
       모바일 폴리시
       ================================================================ */
    @media (max-width: 560px) {
      .hero { padding: 56px 20px 40px; }
      .hero::before { font-size: 120px; top: 30px; }
      .hero__title { font-size: 30px; }
      .pillar__gan { font-size: 24px; }
      .pillar__ji  { font-size: 20px; }
      .main { padding: 40px 20px 140px; }
      .report-chapter { margin-bottom: 70px; }
      .report-chapter__title { font-size: 24px; }
      .report-card { padding: 28px 22px; }
      .report-callout { padding: 24px 22px; }
      .report-callout__body { padding-left: 0; }
      .report-callout__num { font-size: 28px; }
      .report-finale-banner { padding: 40px 22px; }
      .report-finale-banner__title { font-size: 22px; }
      .report-master-message { padding: 40px 22px; }
      .report-master-message__body { font-size: 17px; line-height: 2.15; }
      .report-body p { font-size: 16px; line-height: 2.1; }
      .report-body p.lead { font-size: 17px; }
    }
