/* =========================================================
   LIGNUM — HOME (index)
   ========================================================= */

/* =========================================================
   TOPBAR
   ========================================================= */
.topbar .brandCenter a{
  display:flex;
  align-items:center;
  line-height:1;
  gap:10px;
  text-decoration:none;
  color:inherit;
}

.topbar .brandLogo{
  height:32px;
  width:auto;
  display:block;
}

@media (max-width:720px){
  .topbar .brandLogo{ height:26px; }
}

/* =========================================================
   TYPE
   ========================================================= */
.posterTitle,
.featureTitle{
  font-family: var(--font-display);
}

.posterSub,
.purposeBtn,
.principleItem h3,
.featureKicker,
.featureMeta,
.featureTitleTop,
.featureType,
.inlineLink,
.featureBtn,
.footerBrand{
  font-family: var(--font-body);
}

.posterKo,
.principleItem p,
.principleEg,
.featureDesc,
.microNote,
.traceCard p,
.traceCard .en,
.footerInfo,
.footerNote,
.footerLinks,
.featureInfo,
.heroSubline{
  font-family: var(--font-body);
}

/* =========================================================
   HERO
   ========================================================= */
.posterHero{
  position:relative;
  overflow:hidden;
  text-align:center;
  border-radius: var(--frameR);
  margin-top:28px;
  border:1px solid var(--gold-line);
  box-shadow: var(--shadow2);

  width:100%;
  min-height:78vh;
  height:78vh;

  background:none !important; /* 🔥 이거 핵심 */
}

.heroVideo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover; /* 🔥 꽉 채움 */
  z-index:0;
}

.posterHero::before{
  content:none;
}

.posterHero::after{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid var(--gold);
  box-shadow:
    inset 0 0 0 8px rgba(0,0,0,0),
    0 0 0 1px rgba(200,162,77,.18);
  pointer-events:none;
  z-index:1;
}

.posterHero > *{
  position:relative;
  z-index:2;
}

.posterHeroInner,
.posterEyebrow,
.posterSubline,
.posterProductBlock,
.posterProductMeta,
.posterBrand,
.posterArchiveNo,
.posterArchiveName,
.posterVolumePrice,
.posterTagline,
.heroInner,
.heroLogo{
  display:none !important;
}

/* wordmark */
.heroWordmarkWrap{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
  z-index:2;
}

.heroWordmarkBlock{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  transform:translateY(12%);
  width:min(92%, 1100px);
  margin:0 auto;
}

.heroWordmark{
  position: relative;
  margin: 0;
  font-family: "Cormorant Garamond", "Noto Serif KR", serif;
  font-size: clamp(60px, 8vw, 132px);
  line-height: .92;
  letter-spacing: .14em;
  font-weight: 500;
  color: rgba(245, 239, 224, .95);
  text-align: center;
  text-shadow:
    0 0 12px rgba(0, 0, 0, .34),
    0 0 28px rgba(0, 0, 0, .16);
  user-select: none;
}

.heroWordmark::after{
  content:"";
  position:absolute;
  inset:-28px -36px;
  background:radial-gradient(rgba(0,0,0,.24), transparent 72%);
  filter:blur(28px);
  z-index:-1;
}

.heroSubline{
  position: relative;
  margin: 0;

  font-size: clamp(11px, .95vw, 15px);
  letter-spacing: .22em;
  text-transform: uppercase;

  color: #d8ba79;

  /* 🔥 글자만 살리는 방식 */
  text-shadow:
    0 1px 6px rgba(0,0,0,.55),
    0 0 18px rgba(0,0,0,.22);

  white-space: nowrap;
  user-select: none;
  text-align: center;

  /* ❌ 완전 제거 */
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
}

/* =========================================================
   PRINCIPLES
   ========================================================= */
.principle{
  padding:12px 0 0;
}

.principleRow{
  position:relative;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:0;
  overflow:hidden;
  border-radius:var(--frameR);
  border:1px solid var(--gold-line);
  background: linear-gradient(180deg, rgba(30,40,32,.94), rgba(24,32,26,.98));
  box-shadow: var(--card-shadow), var(--card-inset);
}

.principleRow::before{
  content:"";
  position:absolute;
  inset:12px;
  border:1px solid rgba(200,162,77,.24);
  border-radius:calc(var(--frameR) - 12px);
  pointer-events:none;
}

.principleItem{
  position:relative;
  padding:28px 24px 24px;
  min-height:168px;
  border-left:1px solid rgba(200,162,77,.12);
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

.principleItem:first-child{
  border-left:none;
}

.principleItem h3{
  margin:0 0 14px;
  font-size:13px;
  font-weight:600;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:var(--gold-soft);
}

.principleItem p{
  margin:0;
  font-size:15px;
  line-height:1.82;
  color:var(--fg-soft);
  font-weight:400;
  letter-spacing:.004em;
}

/* =========================================================
   FEATURED ARCHIVE
   ========================================================= */
.feature{
  padding:22px 0 0;
  scroll-margin-top:8px;
}

.featureKicker{
  font-size:13px;
  font-weight:600;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:var(--gold-soft);
}

.featureMeta{
  font-size:13px;
  letter-spacing:.04em;
  color:var(--fg-faint);
}

.featureFrame{
  position:relative;
  overflow:hidden;
  border-radius:var(--frameR);
  border:1px solid var(--gold-line);
  background: linear-gradient(180deg, rgba(30,40,32,.96), rgba(21,28,23,.98));
  box-shadow: var(--card-shadow), var(--card-inset);
  color:var(--card-fg);
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:720px;
  scroll-margin-top:8px;
}

.featureFrame::before{
  content:"";
  position:absolute;
  inset:12px;
  border:1px solid rgba(200,162,77,.26);
  border-radius:calc(var(--frameR) - 12px);
  pointer-events:none;
  z-index:3;
}

.featureMedia{
  position:relative;
  overflow:hidden;
  min-height:600px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:none !important;
}

.featureMedia.isDynamic{
  background-image:
    linear-gradient(180deg, rgba(7,9,8,.10), rgba(7,9,8,.30)),
    radial-gradient(900px 520px at 50% 50%, rgba(0,0,0,0) 0%, rgba(0,0,0,.16) 72%, rgba(0,0,0,.28) 100%),
    var(--feature-img);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

.featureMedia::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(6,8,7,.00) 0%, rgba(6,8,7,.08) 58%, rgba(6,8,7,.24) 100%);
  pointer-events:none;
  z-index:1;
}

.featureMedia::after{
  content:none !important;
}

.featureBody{
  position:relative;
  z-index:4;
  padding:34px 38px 30px 34px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:0;
  border-left:1px solid rgba(200,162,77,.12);
  background: linear-gradient(180deg, rgba(28,36,30,.84), rgba(21,27,23,.90));
}

.featureTitleTop{
  margin:0 0 16px;
  font-size:13px;
  font-weight:600;
  letter-spacing:.08em;
  color:var(--fg-dim);
  text-transform:uppercase;
}

.featureTitle{
  margin:0;
  font-size:52px;
  line-height:1.02;
  font-weight:600;
  letter-spacing:.01em;
  text-transform:uppercase;
  color:var(--fg);
  white-space:nowrap;
  word-break:keep-all;
}

.featureType{
  margin-top:24px;
  font-size:13px;
  font-weight:600;
  letter-spacing:.11em;
  text-transform:uppercase;
  color:var(--gold-soft);
}

.featureDesc{
  margin-top:22px;
  font-size:16px;
  line-height:1.9;
  letter-spacing:.004em;
  color:var(--fg-soft);
  max-width:54ch;
}

.featureInfo{
  margin-top:24px;
  font-size:13px;
  line-height:1.86;
  letter-spacing:.04em;
  color:var(--fg-faint);
  text-transform:uppercase;
}

/* =========================================================
   PRICE + CTA ALIGN SYSTEM
   ========================================================= */
.featurePrice{
  margin-top:30px;
  width:100%;
  display:flex;
  justify-content:flex-end;
  align-items:baseline;
  text-align:right;
  align-self:flex-end;
  gap:10px;
  font-family:"Cormorant Garamond", "Spectral", serif;
  font-size:40px;
  font-weight:600;
  line-height:1;
  letter-spacing:.01em;
  color:#f3efe3;
}

.featurePrice span{
  font-family:"Helvetica Neue", "Arial", sans-serif;
  font-size:16px;
  font-weight:700;
  letter-spacing:.16em;
  opacity:.78;
}

.featureActions{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  text-align:right;
  gap:10px;
  margin-top:18px;
}

.featureBtn{
  display:inline-flex;
  align-items:center;
  justify-content:flex-end;
  margin-top:0;
  padding:0;
  height:auto;
  border:none;
  background:transparent;
  width:auto;
  align-self:flex-end;
  color:var(--fg);
  text-decoration:none;
  letter-spacing:.08em;
  font-size:13px;
  font-weight:600;
  text-align:right;
  transition: color .18s ease, opacity .18s ease, transform .18s ease;
}

.featureBtn:hover{
  opacity:.94;
  transform:translateY(-1px);
}

.featureActions .featureBtn:first-child{
  color:var(--gold-soft);
}

.featureActions .featureBtn:first-child:hover{
  color:var(--gold);
}

.featureBtn.isDisabled{
  opacity:.34;
  pointer-events:none;
}

.microNote{
  margin-top:11px;
  margin-left:auto;
  display:block;
  width:100%;
  text-align:right !important;
  align-self:flex-end;
  font-size:13px;
  line-height:1.8;
  color:var(--fg-faint);
  letter-spacing:.02em;
  white-space:normal;
}

/* =========================================================
   ARCHIVE GRID
   ========================================================= */
.archiveGrid{
  padding:20px 0 10px;
}

.gridHead{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:14px;
  margin:14px 0 12px;
  padding:0 2px;
}

.archiveRailWrap{
  width:100%;
  overflow:visible;
  padding-bottom:0;
}

.archiveRail{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
  min-width:0;
}

.archivePicker{
  appearance:none;
  display:block;
  width:100%;
  padding:0;
  margin:0;
  text-align:left;
  cursor:pointer;
  font:inherit;
  color:inherit;
  background:none;
  border:none;
  border-radius:16px;
}

.archivePicker:focus-visible{
  outline:1px solid var(--gold);
  outline-offset:4px;
}

.archiveCard{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  min-height:250px;
  border-radius:16px;
  border:1px solid rgba(200,162,77,.22);
  background: linear-gradient(180deg, rgba(31,41,33,.96), rgba(22,28,24,.98));
  box-shadow:
    0 12px 32px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.03);
  transition:
    transform .55s cubic-bezier(.22,.61,.36,1),
    border-color .32s ease,
    box-shadow .32s ease;
}

.cardMeta{
  position:absolute;
  left:18px;
  right:18px;
  bottom:16px;
  z-index:4;
  display:flex;
  flex-direction:column;
  gap:6px;
  text-align:left;
}

.cardMetaTop{
  font-size:11px;
  line-height:1.2;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(232,224,204,.72);
  font-family:var(--font-body);
}

.cardMetaTitle{
  font-size:20px;
  line-height:1.04;
  letter-spacing:.03em;
  text-transform:uppercase;
  color:#f3efe3;
  font-family:var(--font-display);
  text-shadow:0 2px 10px rgba(0,0,0,.34);
}

.archiveCard::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.06) 48%, rgba(0,0,0,.48) 100%);
  pointer-events:none;
}

.archiveCard .cardBg{
  position:absolute;
  inset:0;
  z-index:1;
  background-image:var(--card-img);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  transform:scale(1);
  transform-origin:center center;
  will-change:transform;
  transition:transform 1.15s cubic-bezier(.22,.61,.36,1);
}

.archiveCard .cardBg::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.06) 0%, rgba(0,0,0,.10) 42%, rgba(0,0,0,.34) 100%),
    radial-gradient(circle at 50% 45%, rgba(255,255,255,.04) 0%, rgba(255,255,255,0) 58%);
  pointer-events:none;
}

.archiveCard .cardFrame{
  position:absolute;
  inset:10px;
  z-index:3;
  border-radius:8px;
  border:1px solid rgba(212,181,111,.22);
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,.10),
    0 0 0 1px rgba(212,181,111,.05);
  pointer-events:none;
  transition:
    border-color .28s ease,
    box-shadow .28s ease,
    opacity .28s ease;
}

.archivePicker:hover .archiveCard{
  transform:translateY(-6px);
  border-color:rgba(212,181,111,.52);
  box-shadow:
    0 22px 52px rgba(0,0,0,.30),
    0 0 28px rgba(212,181,111,.10),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.archivePicker:hover .archiveCard .cardBg{
  transform:scale(1.11);
}

.archivePicker:hover .archiveCard .cardFrame{
  border-color:rgba(212,181,111,.52);
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,.08),
    0 0 0 1px rgba(212,181,111,.10),
    0 0 22px rgba(212,181,111,.10);
}

.archivePicker.isSelected .archiveCard{
  transform:translateY(-2px);
  border-color:rgba(212,181,111,.70);
  box-shadow:
    0 18px 44px rgba(0,0,0,.30),
    0 0 26px rgba(212,181,111,.10),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.archivePicker.isSelected .archiveCard .cardBg{
  transform:scale(1.01);
}

.archivePicker.isSelected .archiveCard .cardFrame{
  border-color:rgba(212,181,111,.72);
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,.08),
    0 0 0 1px rgba(212,181,111,.14),
    0 0 26px rgba(212,181,111,.14);
}

.cardBottomOnly,
.archiveCard .cardTop,
.archiveCard .cardNo,
.archiveCard .cardName,
.archiveCard .cardMid,
.archiveCard .cardBottom{
  display:none !important;
}

/* =========================================================
   TRACE CARD
   ========================================================= */
.traceCard{
  margin-top:22px;
  position:relative;
  overflow:hidden;
  min-height:460px;
  border-radius:18px;
  padding:54px 52px 60px;
  border:1px solid var(--gold-line);
  box-shadow: var(--card-shadow), var(--card-inset);
  background:
    linear-gradient(180deg, rgba(10,12,10,.10) 0%, rgba(10,12,10,.06) 42%, rgba(10,12,10,.20) 100%),
    url("/assets/pc-home/pc-trace-notebook-topdown.webp");
  background-size:cover;
  background-position:center;
  color:var(--fg);
}

.traceCard::before{
  content:"";
  position:absolute;
  top:22px;
  bottom:22px;
  left:22px;
  width:31%;
  border-radius:14px;
  background: rgba(24,30,25,.34);
  border:1px solid rgba(200,162,77,.18);
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  box-shadow:
    0 18px 40px rgba(0,0,0,.20),
    inset 0 1px 0 rgba(255,255,255,.06),
    inset 0 -1px 0 rgba(0,0,0,.12);
  z-index:0;
  pointer-events:none;
}

.traceCard > *{
  position:relative;
  z-index:1;
  max-width:28%;
}

.traceCard h3,
.traceCard p,
.traceCard .en,
.traceCard .inlineLink,
.inlineLink{
  text-shadow: 0 2px 10px rgba(0,0,0,.14);
}

.traceCard h3{
  margin:0 0 16px;
  font-size:14px;
  font-weight:600;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:var(--gold-soft);
}

.traceCard p{
  margin:0;
  font-size:17px;
  line-height:1.82;
  letter-spacing:.004em;
  color:var(--fg);
}

.traceCard .en{
  margin-top:14px;
  font-size:15px;
  line-height:1.78;
  letter-spacing:.004em;
  color:var(--fg-soft);
}

.inlineLink{
  display:inline-flex;
  margin-top:20px;
  border:none;
  background:transparent;
  padding:0;
  color:var(--fg);
  text-decoration:none;
  letter-spacing:.06em;
  font-size:14px;
  font-weight:600;
}

.inlineLink:hover{
  color:#fff;
}

.clearanceEntry{
  opacity:.72;
  font-size:14px;
  letter-spacing:.08em;
}

.clearanceEntry:hover{
  opacity:1;
}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  padding:28px 0 40px;
}

.footerTop{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}

.footerBrand{
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--fg-dim);
}

.footerInfo{
  display:grid;
  gap:6px;
  color:var(--fg-soft);
  font-size:14px;
  line-height:1.8;
}

.footerInfo strong{
  color:var(--fg);
  font-weight:600;
}

.footerLinks{
  display:flex;
  flex-wrap:wrap;
  gap:12px 18px;
  margin-top:14px;
  font-size:13px;
}

.footerLinks a{
  color:inherit;
  text-decoration:none;
  opacity:.88;
}

.footerLinks a:hover{
  opacity:1;
}

.footerNote{
  margin-top:16px;
  font-size:12px;
  color:var(--fg-dim);
  line-height:1.7;
}

.contact{
  color:inherit;
  text-decoration:none;
}

.contact:hover{
  opacity:.7;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px){
  .posterHero{
    min-height:66svh;
    height:66svh;
    background-position:center center;
  }

  .heroWordmarkBlock{
    gap:10px;
    transform:translateY(14%);
    width:min(92%, 92vw);
  }

  .heroWordmark{
    font-size:clamp(42px, 11vw, 82px);
    letter-spacing:.10em;
  }

  .heroSubline{
    font-size: clamp(9px, 2.2vw, 11px);
    letter-spacing: .14em;
    padding: 0;
    max-width: 88vw;
    white-space: normal;
  }

  .featureFrame{
    grid-template-columns:1fr;
    min-height:auto;
  }

  .featureBody{
    border-left:none;
    border-top:1px solid rgba(200,162,77,.12);
    padding:28px 22px 24px;
  }

  .featureMedia{
    min-height:320px;
  }

  .archiveRail{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .traceCard{
    padding:34px 22px 40px;
    min-height:auto;
  }

  .traceCard::before{
    left:16px;
    right:16px;
    top:16px;
    bottom:16px;
    width:auto;
  }

  .traceCard > *{
    max-width:72ch;
  }
}
@media (max-width:720px){
  .posterHero{
    min-height:58svh;
    height:58svh;
    margin-top:20px;
    background:none !important;
  }

  .posterHero::after{
    inset:10px;
  }

  .heroWordmarkWrap{
    display:none !important;
  }

  .heroVideo{
    transform: scale(1.4);
    transform-origin: center center;
  }

  .heroWordmark{
    font-size:clamp(34px, 12.4vw, 64px);
    letter-spacing:.08em;
    line-height:.95;
  }

  .heroSubline{
    font-size:9px;
    letter-spacing:.14em;
    padding:0;
  }

  .principle{
    padding-top:16px;
  }

  .principleRow{
    grid-template-columns:1fr;
  }

  .principleItem{
    min-height:auto;
    padding:22px 18px 20px;
    border-left:none;
    border-top:1px solid rgba(200,162,77,.10);
  }

  .principleItem:first-child{
    border-top:none;
  }

  .feature{
    padding-top:16px;
    scroll-margin-top:6px;
  }

  .featureFrame{
    scroll-margin-top:6px;
    min-height:auto;
  }

  .featureMedia{
    min-height:34svh;
  }

  .featureTitle{
    font-size:32px;
    line-height:1.04;
    white-space:normal;
  }

  .featureDesc{
    font-size:14px;
    line-height:1.72;
  }

  .featureInfo{
    font-size:12px;
    line-height:1.72;
  }

  .featurePrice{
    font-size:28px;
    gap:8px;
    margin-top:22px;
  }

  .featurePrice span{
    font-size:15px;
    letter-spacing:.14em;
  }

  .featureActions{
    gap:8px;
    margin-top:14px;
  }

  .featureBtn{
    font-size:13px;
  }

  .microNote{
    display:block;
    width:100%;
    margin-top:10px;
    margin-left:auto;
    text-align:right !important;
    align-self:flex-end;
    white-space:normal;
    font-size:12px;
  }

  .archiveGrid{
    padding-top:16px;
  }

  .gridHead{
    margin:10px 0 10px;
  }

  .archiveRail{
    grid-template-columns:1fr;
    gap:14px;
  }

  .archiveCard{
    position:relative;
    overflow:hidden;
    min-height:24svh;
    border-radius:14px;
  }

  /* 모바일 카드 하단 글씨 가독성 보정 */
  .archiveCard::after{
    content:"";
    position:absolute;
    inset:0;
    background:
      linear-gradient(
        to top,
        rgba(0,0,0,.78) 0%,
        rgba(0,0,0,.52) 28%,
        rgba(0,0,0,.16) 58%,
        rgba(0,0,0,.02) 100%
      );
    pointer-events:none;
    z-index:1;
  }

  .archiveCard .cardFrame{
    inset:9px;
    border-radius:7px;
    z-index:2;
  }

  .cardMeta{
    position:absolute;
    left:14px;
    right:14px;
    bottom:14px;
    gap:5px;
    z-index:3;
  }

  .cardMetaTop{
    font-size:10px;
    letter-spacing:.1em;
    line-height:1.2;
    color:rgba(214,184,107,.96);
    text-transform:uppercase;
  }

  .cardMetaTitle{
    font-size:16px;
    line-height:1.08;
    color:rgba(247,242,232,.98);
    text-shadow:0 2px 10px rgba(0,0,0,.42);
  }

  .traceCard{
    min-height:auto;
    padding:28px 18px 26px;
    background-position:50% 40%;
    margin-top:16px;
  }

  .traceCard p{
    font-size:15px;
    line-height:1.7;
  }

  .traceCard .en{
    font-size:13px;
    line-height:1.66;
  }

  .footerInfo{
    font-size:13px;
    line-height:1.75;
  }

  .footerLinks{
    gap:10px 14px;
  }
}

@media (min-width:901px){
  header,
  .siteHeader,
  .topBar,
  .navbar{
    position:relative;
    z-index:9999;
  }

  .posterHero{
    width:100%;
    max-width:none;
    margin:18px 0 0;
    position:relative;
    z-index:1;
  }
}

/* =========================================
   MOBILE ARCHIVE CARD FIX (FINAL FORCE)
   ========================================= */
@media (max-width:720px){

  /* 카드 전체 */
  .archiveCard{
    position:relative !important;
    overflow:hidden !important;
    isolation:isolate !important;
  }

  /* 이미지 (JS로 들어가는 cardBg) */
  .archiveCard .cardBg{
    position:absolute !important;
    inset:0 !important;
    z-index:0 !important;

    background-size:cover !important;
    background-position:center !important;
    background-repeat:no-repeat !important;
  }

  /* 강제 오버레이 (텍스트 살리는 핵심) */
  .archiveCard::after{
    content:"" !important;
    position:absolute !important;
    inset:0 !important;
    z-index:1 !important;
    pointer-events:none !important;

    background:linear-gradient(
      to top,
      rgba(0,0,0,0.92) 0%,
      rgba(0,0,0,0.65) 28%,
      rgba(0,0,0,0.22) 55%,
      rgba(0,0,0,0.04) 100%
    ) !important;
  }

  /* 골드 프레임 */
  .archiveCard .cardFrame{
    position:absolute !important;
    inset:9px !important;
    z-index:2 !important;
    pointer-events:none !important;
  }

  /* 텍스트 영역 */
  .archiveCard .cardMeta{
    position:absolute !important;
    left:18px !important;
    right:18px !important;
    bottom:18px !important;

    display:flex !important;
    flex-direction:column !important;
    gap:6px !important;

    z-index:3 !important;

    opacity:1 !important;
    visibility:visible !important;
    transform:none !important;
  }

  /* 상단 라벨 */
  .archiveCard .cardMetaTop{
    display:block !important;
    opacity:1 !important;

    color:rgba(214,184,107,0.98) !important;
    font-size:11px !important;
    letter-spacing:0.14em !important;
    text-transform:uppercase !important;

    text-shadow:0 2px 8px rgba(0,0,0,0.5) !important;
  }

  /* 타이틀 */
  .archiveCard .cardMetaTitle{
    display:block !important;
    opacity:1 !important;

    color:rgba(247,242,232,0.99) !important;
    font-size:20px !important;
    line-height:1.05 !important;
    letter-spacing:0.02em !important;

    text-shadow:0 4px 14px rgba(0,0,0,0.65) !important;

    word-break:keep-all !important;
  }

  /* 버튼 자체 영향 제거 */
  .archivePicker{
    position:relative !important;
    z-index:0 !important;
  }
}
