/* ================================================================
   LAWON — base.css  (rewritten from ORE real measurements)
   Source: docs/04_ORE_실측값.md
   Rule: 12px base everywhere · single font · hierarchy via space.
   ================================================================ */

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body { min-height: 100vh; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img, picture, video { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; color: inherit; }
button { background: none; border: 0; cursor: pointer; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4, h5, h6 { font-weight: inherit; }
ol, ul { list-style: none; }

/* ---------- Root tokens (extracted from ORE) ---------- */
:root {
  /* Color — 5 only */
  --color-text:        #000000;
  --color-text-soft:   #555555;
  --color-text-softer: #707070;
  --color-bg:          #FFFFFF;
  --color-bg-soft:     #FAFAFA;
  --color-bg-input:    #EFEFEF;
  --color-line:        #D3D3D3;
  --color-line-soft:   #ECECEC;
  --color-overlay:     rgba(0, 0, 0, 0.8);
  --color-on-dark:     #FFFFFF;

  /* Typography — single family, 12px rule */
  --font-family: "Pretendard Variable", -apple-system, BlinkMacSystemFont,
                 "Helvetica Neue", "Segoe UI", Arial, sans-serif;
  --font-family-italic: "Fraunces", "Times New Roman", Times, serif;

  --fs-12: 12px;          /* 본문·네비·헤딩 거의 전부 */
  --fs-13: 13px;          /* 폼 input 등 미세 차이 */
  --fs-25: 25px;          /* 진짜 강조 — 페이지에 1~2회만 */
  --fs-40: 40px;          /* Hero 단독 헤드라인 */
  --fs-56: 56px;          /* Hero 한국어 부분 등 (옵션) */

  --fw-regular: 400;
  --fw-bold:    700;

  --lh-tight: 1;
  --lh-base:  1.2;
  --lh-loose: 1.5;

  --tracking-tight: -0.01em;
  --tracking-base: 0;
  --tracking-label: 0.05em;
  --tracking-eyebrow: 0.15em;

  /* Spacing — 8px scale, ORE-observed values inserted */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  16px;
  --space-4:  24px;
  --space-5:  32px;   /* ORE h2 margin-bottom */
  --space-6:  48px;
  --space-7:  64px;
  --space-8:  96px;
  --space-9:  120px;
  --space-10: 160px;

  /* Layout */
  --container-max: 1408px;   /* ORE: width 1408 in 1440 viewport */
  --container-pad: 32px;
  --container-pad-mobile: 20px;

  /* Motion — ORE pattern: simple fade only */
  --t-base: color 0.3s ease, opacity 0.3s ease, background-color 0.3s ease;
  --t-quick: 0.2s ease;

  /* Z */
  --z-header: 100;
  --z-switcher: 200;
}

/* ---------- Base ---------- */
body {
  font-family: var(--font-family);
  font-size: var(--fs-12);
  font-weight: var(--fw-regular);
  line-height: var(--lh-base);
  color: var(--color-text);
  background: var(--color-bg);
  transition: background var(--t-quick), color var(--t-quick);
}

a { transition: var(--t-base); }
a:hover { opacity: 0.6; }

/* ---------- Container & section ---------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}
@media (max-width: 720px) {
  .container { padding-inline: var(--container-pad-mobile); }
}
.section {
  padding-block: var(--space-9);
}
@media (max-width: 720px) {
  .section { padding-block: var(--space-7); }
}

/* ---------- Eyebrow (small label above section) ---------- */
.eyebrow {
  display: inline-block;
  font-size: var(--fs-12);
  font-weight: var(--fw-regular);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text);
  margin-bottom: var(--space-5);
}

/* ---------- Section header ---------- */
.section-header {
  margin-bottom: var(--space-7);
  max-width: 720px;
}
.section-title {
  font-size: var(--fs-25);
  font-weight: var(--fw-regular);
  line-height: var(--lh-base);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-4);
}
.section-lead {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  color: var(--color-text-soft);
  max-width: 56ch;
}

/* ---------- CTA (text-link style, ORE pattern) ---------- */
.cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-12);
  font-weight: var(--fw-regular);
  letter-spacing: var(--tracking-label);
  color: var(--color-text);
  padding: 0;
  position: relative;
  background: none;
}
.cta::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 1px;
  background: currentColor;
  transition: transform var(--t-quick);
  transform-origin: right;
}
.cta:hover { opacity: 1; }
.cta:hover::after { transform: scaleX(0); transform-origin: left; }
.cta .arrow { transition: transform var(--t-quick); }
.cta:hover .arrow { transform: translateX(4px); }

.cta--primary {
  padding: 14px 24px;
  background: var(--color-text);
  color: var(--color-bg);
  letter-spacing: var(--tracking-label);
}
.cta--primary::after { display: none; }
.cta--primary:hover { opacity: 1; background: var(--color-text-soft); }

.cta--header {
  padding: 8px 14px;
  background: var(--color-text);
  color: var(--color-bg);
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-label);
}
.cta--header::after { display: none; }
.cta--header:hover { background: var(--color-text-soft); opacity: 1; }

/* ---------- Tone Switcher (dev preview only) ---------- */
.tone-switcher {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: var(--z-switcher);
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(10px);
  border: 1px solid var(--color-line);
  padding: 12px;
  font-family: var(--font-family);
  font-size: var(--fs-12);
}
.tone-switcher__label {
  display: block;
  font-size: 10px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin-bottom: 8px;
  text-align: center;
}
.tone-switcher__group { display: flex; flex-direction: column; gap: 2px; }
.tone-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  font-size: 11px;
  color: var(--color-text);
  text-align: left;
  transition: background var(--t-quick);
}
.tone-btn:hover { background: var(--color-bg-soft); }
.tone-btn.is-active { background: var(--color-text); color: var(--color-bg); }
.tone-btn__letter { display: inline-block; width: 16px; text-align: center; font-weight: var(--fw-bold); }
.tone-btn__name { font-size: 11px; }

/* ---------- Header ---------- */
/* 사장님 피드백 2026-05-16: Hero 위에서는 헤더 투명 + MUSEIA 흰색.
   스크롤(>30px)하면 cream 솔리드 + 다크 텍스트로 자연 전환. */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: var(--z-header);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px var(--container-pad);
  background: transparent;
  color: #fff;
  transition:
    background-color 0.4s ease,
    color 0.4s ease,
    border-color var(--t-quick);
  border-bottom: 1px solid transparent;
}
/* 투명 상태일 때 가독성 보조 — 미세한 텍스트 그림자 */
.site-header:not(.is-scrolled) .brand__mark,
.site-header:not(.is-scrolled) .brand__tag,
.site-header:not(.is-scrolled) .site-nav a,
.site-header:not(.is-scrolled) .cta--header {
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.25);
}
.site-header.is-scrolled {
  background: var(--color-bg);
  color: var(--color-text);
  border-bottom-color: var(--color-line-soft);
}
.brand { display: flex; flex-direction: column; line-height: 1; gap: 6px; }
/* MUSEIA — 로고 격으로 키움 + 자간 넓힘 (사장님 피드백 2026-05-16) */
.brand__mark {
  font-size: 18px;
  font-weight: var(--fw-regular);
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.brand__tag {
  font-size: 10px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  opacity: 0.6;
}
.site-nav {
  display: flex;
  gap: var(--space-5);
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-label);
}
.site-nav a { position: relative; padding: 4px 0; }
.site-nav a::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t-quick);
}
.site-nav a:hover::after { transform: scaleX(1); }
.site-nav a:hover { opacity: 1; }

.menu-toggle {
  display: none;
  flex-direction: column;
  gap: 3px;
  padding: 8px;
}
.menu-toggle span { display: block; width: 18px; height: 1px; background: currentColor; }

@media (max-width: 900px) {
  .site-nav, .cta--header { display: none; }
  .menu-toggle { display: flex; }
  .site-header.is-menu-open { background: var(--color-bg); color: var(--color-text); }
  .site-header.is-menu-open .site-nav,
  .site-header.is-menu-open .cta--header {
    display: flex;
    flex-direction: column;
    position: absolute;
    inset: 100% 0 auto 0;
    background: var(--color-bg);
    padding: var(--space-5);
    border-bottom: 1px solid var(--color-line-soft);
    gap: var(--space-3);
  }
}

/* ---------- 1. Hero — full-bleed slideshow (3 cross-fade slides) ---------- */
/* 사장님 피드백 (2026-05-16):
   - 가운데 텍스트 오버레이 제거 (브랜드는 헤더 MUSEIA로 단독 노출)
   - 3장 슬라이드 cross-fade, 자동 6초, 도트 클릭으로 점프
   - 슬라이드 src는 추후 관리자에서 교체 */
.hero {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 600px;
  max-height: 1080px;
  overflow: hidden;
}
.hero__slides {
  position: absolute;
  inset: 0;
  background: var(--color-bg);   /* fade-out 사이 보이는 결 = 페이지 cream 톤, 자연스러운 비움 */
}
.hero__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  /* 사장님 피드백 (2026-05-16): cross-fade 대신 사라졌다가 나오는 결.
     fade 1s + 잠깐 비움 0.2s + fade-in 1s = 약 2.2s 전환. */
  transition: opacity 1s ease;
  pointer-events: none;
}
.hero__slide.is-active {
  opacity: 1;
  pointer-events: auto;
}
.hero__slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
/* 슬라이드 인디케이터 — 미니멀 라인 (도트 X). 에디토리얼 결. */
.hero__dots {
  position: absolute;
  left: 50%;
  bottom: calc(var(--space-7) + 60px);
  transform: translateX(-50%);
  display: flex;
  gap: 12px;
  z-index: 2;
}
.hero__dot {
  width: 28px;
  height: 1px;
  background: rgba(255, 255, 255, 0.4);
  border: 0;
  border-radius: 0;
  padding: 12px 0;        /* 클릭 영역만 키움 */
  background-clip: content-box;
  cursor: pointer;
  transition: background 0.4s ease;
}
.hero__dot:hover { background: rgba(255, 255, 255, 0.7); background-clip: content-box; }
.hero__dot.is-active {
  background: #fff;
  background-clip: content-box;
}
/* 슬라이드 1장만 있을 때는 도트 숨김 (관리자에서 단일 사진 모드 지원) */
.hero[data-single] .hero__dots { display: none; }
.hero__scroll {
  position: absolute;
  left: 50%;
  bottom: var(--space-7);
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 48px;
  color: var(--color-text-soft);
  transition: color var(--t-quick);
  z-index: 1;
}
.hero__scroll:hover { color: var(--color-text); }
.hero__scroll-arrow {
  display: block;
  width: 1px;
  height: 36px;
  background: currentColor;
  position: relative;
}
.hero__scroll-arrow::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 50%;
  width: 8px;
  height: 8px;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: translateX(-50%) translateY(-2px) rotate(45deg);
  transform-origin: center;
}

/* ---------- 2. Manifesto ---------- */
.manifesto { padding-block: var(--space-9); }
.manifesto .eyebrow { margin-bottom: var(--space-7); }
.manifesto__body {
  font-size: var(--fs-25);
  font-weight: var(--fw-regular);
  line-height: 1.3;
  max-width: 18ch;
  margin-bottom: var(--space-6);
  letter-spacing: var(--tracking-tight);
}
.manifesto__body em {
  font-style: italic;
  font-family: var(--font-family-italic);
}
.manifesto__sub {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  max-width: 56ch;
  margin-bottom: var(--space-2);
  color: var(--color-text);
}
.manifesto__sub-ko {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  color: var(--color-text-soft);
  margin-bottom: var(--space-6);
  max-width: 56ch;
}
.manifesto__body-2 {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  max-width: 60ch;
  color: var(--color-text-soft);
}
.manifesto__body-2 em {
  font-style: italic;
  font-family: var(--font-family-italic);
  color: var(--color-text);
}

/* ---------- 2b. About (회사 소개 + 대표 소개, 좌우 양분, 이미지+텍스트, 한·영 병기) ---------- */
/* 2026-05-15 미팅 명시:
   - 페이지 초반 About 섹션
   - Desktop 좌우 50:50, 한글+영문 같이
   - 각 컬럼 안에 이미지 1장 + 텍스트 (회사=아틀리에, 대표=작업 컷)
*/
.about {
  padding: var(--space-9, 6rem) 0;
}
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8, 5rem);
  align-items: start;
}
.about-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.about-col__image {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  background: var(--color-bg-soft);
}
.about-col__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.about-col:hover .about-col__image img { transform: scale(1.02); }
.about-col__text { padding-top: var(--space-2); }
.about-col .eyebrow {
  display: block;
  margin-bottom: var(--space-4);
}
.about__body {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  max-width: 48ch;
  color: var(--color-text);
}
.about__body--en { margin-bottom: var(--space-3); }
.about__body--ko { color: var(--color-text-soft); }
.about__body em {
  font-style: italic;
  font-family: var(--font-family-italic);
  color: var(--color-text);
}
@media (max-width: 800px) {
  .about-grid {
    grid-template-columns: 1fr;
    gap: var(--space-7, 4rem);
  }
}

/* ---------- 3. Capabilities (Zigzag Layout) ---------- */
/* 미팅 명시 (2026-05-15): 3x2 그리드 X → 좌우 교차 지그재그 배치.
   이미지가 자기 원본 비율 그대로 살아나도록 강제 크롭(aspect-ratio + cover) 제거.
   이미지 크게, 폰트 작게 — 이미지가 주연. */
.cap-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-9, 6rem);
}
.cap-card {
  display: grid;
  grid-template-columns: 7fr 5fr;   /* 이미지가 텍스트보다 큼 */
  align-items: center;
  gap: var(--space-6);
}
/* 짝수번째 행 좌우 교차 — 지그재그 */
.cap-card:nth-child(even) {
  grid-template-columns: 5fr 7fr;
}
.cap-card:nth-child(even) .cap-card__image { order: 2; }
.cap-card:nth-child(even) .cap-card__body  { order: 1; }

.cap-card__image {
  position: relative;
  overflow: hidden;
  background: var(--color-bg-soft);
}
.cap-card__image img {
  display: block;
  width: 100%;
  height: auto;                      /* 원본 비율 유지, 강제 크롭 X */
  transition: opacity 0.4s ease, transform 0.6s ease;
}
.cap-card:hover .cap-card__image img {
  opacity: 0.9;
  transform: scale(1.02);
}
.cap-card__body {
  padding: 0 var(--space-4);
}
.cap-card__body h3 {
  font-size: var(--fs-12);           /* 작게 유지 */
  font-weight: var(--fw-regular);
  margin-bottom: var(--space-2);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
}
.cap-card__body p {
  font-size: var(--fs-12);           /* 작게 유지 */
  color: var(--color-text-soft);
  line-height: var(--lh-loose);
  max-width: 32ch;                   /* 작은 본문 가독성 */
}

/* 태블릿 — 지그재그 유지, 컬럼 비율만 살짝 균등에 가깝게 */
@media (max-width: 900px) {
  .cap-card,
  .cap-card:nth-child(even) {
    grid-template-columns: 6fr 5fr;
  }
}
/* 모바일 — 1컬럼 적층, 이미지 위 / 텍스트 아래 통일 (지그재그 의미 약함) */
@media (max-width: 640px) {
  .cap-grid { gap: var(--space-7, 4rem); }
  .cap-card,
  .cap-card:nth-child(even) {
    grid-template-columns: 1fr;
  }
  .cap-card:nth-child(even) .cap-card__image { order: 0; }
  .cap-card:nth-child(even) .cap-card__body  { order: 0; }
  .cap-card__body { padding: 0; }
}

/* ---------- 4. Detail Gallery ---------- */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
}
@media (max-width: 900px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } }
.gallery-item {
  position: relative;
  aspect-ratio: 4 / 5;             /* matches source dimensions across all sets */
  overflow: hidden;
  background: var(--color-bg-soft);
}
.gallery-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  image-rendering: -webkit-optimize-contrast;
  transition: opacity 0.4s ease;
}
.gallery-item:hover img { opacity: 0.88; }
.gallery-item figcaption {
  position: absolute;
  inset: auto 0 0 0;
  padding: var(--space-3);
  font-size: var(--fs-12);
  background: linear-gradient(0deg, rgba(0,0,0,0.65), transparent);
  color: var(--color-on-dark);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.gallery-item:hover figcaption { opacity: 1; }

/* ---------- 5. Numbers ---------- */
.num-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
  border-top: 1px solid var(--color-line);
  padding-top: var(--space-6);
}
@media (max-width: 900px) { .num-grid { grid-template-columns: repeat(2, 1fr); } }
.num { display: flex; flex-direction: column; gap: var(--space-3); }
.num__value {
  font-size: var(--fs-25);
  font-weight: var(--fw-regular);
  letter-spacing: var(--tracking-tight);
  line-height: 1;
}
.num__label {
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
}

/* ---------- 6. Selected Clients (텍스트 라인만 — 미니멀 톤 유지) ---------- */
/* 2026-05-15 미팅: 로고 X, 영문 텍스트만. */
.client-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  align-items: center;
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
  padding: var(--space-7, 4rem) 0;
}
.client-name {
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  text-align: center;
  color: var(--color-text-soft);
  transition: color 0.3s ease;
}
.client-name:hover { color: var(--color-text); }
.clients__note {
  margin-top: var(--space-4);
  color: var(--color-text-soft);
  font-size: var(--fs-12);
  text-align: center;
}

/* ---------- 7. Process ---------- */
.process-steps {
  display: flex;
  flex-direction: column;
}
.process-step {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: var(--space-5);
  padding-block: var(--space-5);
  border-top: 1px solid var(--color-line);
}
.process-step:last-child { border-bottom: 1px solid var(--color-line); }
.process-step__num {
  font-size: var(--fs-25);
  font-weight: var(--fw-regular);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text-soft);
  line-height: 1;
}
.process-step__body h3 {
  font-size: var(--fs-12);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-2);
  letter-spacing: var(--tracking-label);
}
.process-step__body p {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  color: var(--color-text-soft);
  max-width: 60ch;
}

/* ---------- 8. Certifications ---------- */
.cert-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  padding-block: var(--space-6);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}
.cert {
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-label);
  color: var(--color-text-soft);
}
.certs__note {
  margin-top: var(--space-4);
  color: var(--color-text-soft);
  font-size: var(--fs-12);
}

/* ---------- 9. Contact / RFQ ---------- */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-7);
}
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } }

.contact-info h3 {
  font-size: var(--fs-12);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-label);
  margin-bottom: var(--space-3);
  text-transform: uppercase;
}
.contact-info__title-2 { margin-top: var(--space-6); }
.contact-list {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: var(--space-2) var(--space-3);
  margin-bottom: var(--space-4);
  font-size: var(--fs-12);
}
.contact-list dt {
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
}
.contact-info p { font-size: var(--fs-12); line-height: var(--lh-loose); }
.contact-info__hours { color: var(--color-text-soft); margin-top: var(--space-2); }

.rfq-form {
  display: flex; flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-bg-soft);
}
.rfq-form h3 {
  font-size: var(--fs-25);
  font-weight: var(--fw-regular);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-2);
}
.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field label {
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
}
.field__hint { text-transform: none; letter-spacing: 0; font-style: italic; margin-left: 4px; }
.field input, .field textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--color-line);
  background: var(--color-bg);
  font-size: var(--fs-13);
  transition: border-color var(--t-quick);
  border-radius: 0;
}
.field input:focus, .field textarea:focus {
  outline: 0;
  border-color: var(--color-text);
}
.checkbox-group {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
}
@media (max-width: 560px) { .checkbox-group { grid-template-columns: repeat(2, 1fr); } }
.checkbox {
  display: flex; align-items: center; gap: 8px;
  font-size: var(--fs-12);
  letter-spacing: 0;
  text-transform: none;
  color: var(--color-text);
  cursor: pointer;
}
.rfq-form__note { font-size: var(--fs-12); color: var(--color-text-soft); margin-top: var(--space-1); }
.rfq-form__success {
  padding: var(--space-3);
  background: var(--color-bg);
  border: 1px solid var(--color-line);
  font-size: var(--fs-12);
}

/* ---------- Footer ---------- */
.site-footer {
  padding-block: var(--space-7) var(--space-5);
  border-top: 1px solid var(--color-line);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-5);
}
@media (max-width: 900px) { .footer-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-col h4 {
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin-bottom: var(--space-3);
  font-weight: var(--fw-regular);
}
.footer-col p {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  color: var(--color-text-soft);
  margin-bottom: 4px;
}
.footer-brand {
  display: block;
  font-size: var(--fs-12);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.footer-tag {
  display: block;
  font-size: 10px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin-bottom: var(--space-4);
}
.footer-line { font-style: italic; font-family: var(--font-family-italic); }
.footer-copy { font-size: var(--fs-12); color: var(--color-text-soft); }
.footer-col--end { display: flex; align-items: flex-end; justify-content: flex-end; }
@media (max-width: 900px) { .footer-col--end { justify-content: flex-start; } }

/* ---------- Reveal animations (subtle, ORE-faithful) ---------- */
.reveal {
  opacity: 0;
  transition: opacity 0.8s ease;
}
.reveal.is-visible { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1; }
}

/* ================================================================
   Catalog pages (product/list.html, product/detail.html)
   Phase 1 — static fixture provider via assets/js/catalog.js
   ORE-faithful: 12px-base type, low decoration, image-first, hairline lines.
   ================================================================ */

body.catalog-page main { padding-top: 96px; }   /* under fixed header */

/* ---- Catalog list header ---- */
.catalog-header {
  padding: var(--space-7, 4rem) var(--container-pad) var(--space-6, 3rem);
  border-bottom: 1px solid var(--color-line);
  margin-bottom: var(--space-7, 4rem);
}
.catalog-header__breadcrumb {
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin-bottom: var(--space-4);
}
.catalog-header__breadcrumb a:hover { color: var(--color-text); }
.catalog-header__sep { margin: 0 6px; opacity: 0.5; }
.catalog-header__title {
  font-size: clamp(28px, 3.6vw, 40px);
  font-weight: var(--fw-regular);
  letter-spacing: -0.01em;
  line-height: 1.1;
  margin: 0 0 var(--space-3);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 14px;
}
.catalog-header__title-ko {
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
  font-weight: var(--fw-regular);
}
.catalog-header__desc {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  max-width: 60ch;
  color: var(--color-text);
  margin: 0;
}
.catalog-header__desc--ko { color: var(--color-text-soft); margin-top: 4px; }
.catalog-header__meta {
  margin-top: var(--space-4);
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
}

/* ---- Product grid ---- */
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-7, 4rem) var(--space-4);
  margin-bottom: var(--space-9);
}
@media (max-width: 900px) { .catalog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .catalog-grid { grid-template-columns: 1fr; } }

.pcard {
  display: flex;
  flex-direction: column;
  color: inherit;
  text-decoration: none;
}
.pcard__media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  background: var(--color-bg-soft);
  margin-bottom: var(--space-3);
}
.pcard__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 0.4s ease, transform 0.6s ease;
}
.pcard:hover .pcard__media img {
  opacity: 0.92;
  transform: scale(1.015);
}
.pcard__tag {
  position: absolute;
  left: 10px;
  top: 10px;
  font-size: 10px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  background: rgba(255, 255, 255, 0.7);
  padding: 4px 8px;
}
.pcard__name {
  font-size: var(--fs-12);
  font-weight: var(--fw-regular);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  margin: 0 0 4px;
}
.pcard__sub {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  color: var(--color-text-soft);
  margin: 0 0 6px;
  max-width: 36ch;
}
.pcard__meta {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin: 0;
}

/* ---- Catalog foot ---- */
.catalog-foot {
  border-top: 1px solid var(--color-line);
  padding: var(--space-7, 4rem) var(--container-pad);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.catalog-foot p {
  margin: 0;
  font-size: var(--fs-12);
  color: var(--color-text-soft);
  max-width: 56ch;
}
.catalog-foot em {
  font-style: italic;
  font-family: var(--font-family-italic);
  color: var(--color-text);
}

/* ---- Catalog empty / unknown / error ---- */
.catalog-empty {
  padding: var(--space-9, 7rem) var(--container-pad);
  text-align: left;
  max-width: 720px;
  margin: 0 auto;
}
.catalog-empty .eyebrow {
  display: block;
  margin-bottom: var(--space-3);
}
.catalog-empty h1 {
  font-size: clamp(24px, 2.8vw, 32px);
  font-weight: var(--fw-regular);
  line-height: 1.2;
  margin: 0 0 var(--space-4);
}
.catalog-empty p {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  color: var(--color-text);
  margin: 0 0 var(--space-4);
}
.catalog-empty code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  background: var(--color-bg-soft);
  padding: 2px 6px;
  font-size: 11px;
}

/* ---- Product detail layout ---- */
.pdetail { padding-bottom: var(--space-9); }
.pdetail__head {
  padding: var(--space-7, 4rem) 0 var(--space-5, 2rem);
  border-bottom: 1px solid var(--color-line);
  margin-bottom: var(--space-7, 4rem);
}
.pdetail__breadcrumb {
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin: 0 0 var(--space-4);
}
.pdetail__breadcrumb span { margin: 0 6px; opacity: 0.5; }
.pdetail__breadcrumb a:hover { color: var(--color-text); }
.pdetail__name {
  font-size: clamp(28px, 3.6vw, 40px);
  font-weight: var(--fw-regular);
  letter-spacing: -0.01em;
  margin: 0 0 8px;
  line-height: 1.15;
}
.pdetail__sub {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  color: var(--color-text);
  margin: 0 0 6px;
  max-width: 60ch;
}
.pdetail__season {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin: 0;
}
.pdetail__status {
  display: inline-block;
  margin-top: var(--space-3);
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  background: var(--color-bg-soft);
  padding: 4px 8px;
}

.pdetail__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--space-7, 4rem);
  align-items: flex-start;
}
@media (max-width: 900px) {
  .pdetail__layout { grid-template-columns: 1fr; gap: var(--space-6); }
}

.pdetail__gallery {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.pdetail__shot {
  margin: 0;
  background: var(--color-bg-soft);
  overflow: hidden;
}
.pdetail__shot img {
  display: block;
  width: 100%;
  height: auto;
}

.pdetail__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}
.pdetail__panel {
  border-top: 1px solid var(--color-line);
  padding-top: var(--space-5, 2rem);
}
.pdetail__panel:first-child { border-top: 0; padding-top: 0; }
.pdetail__panel-title {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  font-weight: var(--fw-regular);
  margin: 0 0 var(--space-3);
}
.pdetail__panel-body {
  font-size: var(--fs-12);
  line-height: var(--lh-loose);
  color: var(--color-text);
  margin: 0 0 var(--space-3);
  max-width: 56ch;
}
.pdetail__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
}
.pdetail__list li {
  font-size: var(--fs-12);
  color: var(--color-text);
  background: var(--color-bg-soft);
  padding: 4px 10px;
  letter-spacing: 0.02em;
}
.pdetail__muted { color: var(--color-text-soft); background: transparent; padding: 0; }
.pdetail__dl {
  margin: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: var(--space-4);
  row-gap: 8px;
}
.pdetail__dl dt {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
}
.pdetail__dl dd { font-size: var(--fs-12); color: var(--color-text); margin: 0; }

.pdetail__panel--cta { padding-bottom: var(--space-5, 2rem); }
.pdetail__panel--cta .cta { margin-top: var(--space-2); }

/* ---- Capability cards become links (catalog routing) ---- */
.cap-card[href] {
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}
.cap-card[href]:hover .cap-card__body h3 { text-decoration: underline; text-underline-offset: 4px; }

/* ================================================================
   Admin (Local preview) — /admin/index.html
   NOT production. Honesty banner + clear "in-browser only" copy.
   Pretendard 12px-base discipline preserved.
   ================================================================ */

body.admin-page {
  background: var(--color-bg);
  color: var(--color-text);
}

/* Banner */
.admin-banner {
  position: sticky;
  top: 0;
  z-index: 10;
  background: #2a221a;
  color: #f8f3e8;
  padding: 10px 16px;
  font-size: 12px;
  line-height: 1.55;
  letter-spacing: 0.01em;
}
.admin-banner strong { color: #ffdca8; margin-right: 6px; }
.admin-banner code { background: rgba(255,255,255,0.08); padding: 1px 6px; }
.admin-banner em { color: #ffdca8; font-style: italic; font-family: var(--font-family-italic); }

/* Top bar */
.admin-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 24px;
  border-bottom: 1px solid var(--color-line);
}
.admin-brand { display: flex; flex-direction: column; line-height: 1; gap: 4px; }
.admin-brand__mark {
  font-size: 14px;
  font-weight: var(--fw-regular);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.admin-brand__tag {
  font-size: 10px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
}
.admin-nav { display: flex; gap: 8px; }

/* Buttons */
.admin-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 32px;
  padding: 0 12px;
  border: 1px solid var(--color-line);
  background: #fff;
  color: var(--color-text);
  font-size: 12px;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease;
}
.admin-btn:hover { background: var(--color-bg-soft); }
.admin-btn--ghost { background: transparent; }
.admin-btn--solid {
  background: #1a1612;
  color: #fff;
  border-color: #1a1612;
}
.admin-btn--solid:hover { background: #000; }

/* Toolbar */
.admin-main { padding: 24px 0 96px; }
.admin-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--color-line);
  margin-bottom: 24px;
}
.admin-toolbar__left { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.admin-toolbar__right { display: flex; gap: 8px; }
.admin-count {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin: 0;
}

/* Field */
.admin-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
}
.admin-field > span {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
}
.admin-field input,
.admin-field select,
.admin-field textarea {
  height: 32px;
  border: 1px solid var(--color-line);
  background: #fff;
  padding: 0 10px;
  font: inherit;
  font-size: 12px;
  color: var(--color-text);
  width: 100%;
  box-sizing: border-box;
}
.admin-field textarea { height: auto; padding: 8px 10px; line-height: 1.55; resize: vertical; }
.admin-field select { padding-right: 24px; cursor: pointer; }
.admin-hint {
  display: block;
  font-size: 11px;
  color: var(--color-text-soft);
  margin-top: 2px;
}
.admin-hint code { background: var(--color-bg-soft); padding: 1px 4px; }

/* List */
.admin-list { display: flex; flex-direction: column; gap: 0; }
.admin-empty {
  padding: 48px 0;
  text-align: center;
  font-size: 12px;
  color: var(--color-text-soft);
}
.admin-row {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid var(--color-line-soft, #f0eee9);
}
.admin-row__media {
  width: 80px;
  height: 100px;
  background: var(--color-bg-soft);
  overflow: hidden;
}
.admin-row__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.admin-row__cat {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin: 0 0 2px;
}
.admin-row__name {
  font-size: 14px;
  font-weight: var(--fw-regular);
  margin: 0 0 2px;
}
.admin-row__sub {
  font-size: 12px;
  color: var(--color-text-soft);
  margin: 0 0 4px;
  max-width: 60ch;
}
.admin-row__id {
  font-size: 11px;
  color: var(--color-text-soft);
  margin: 0;
}
.admin-row__id code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  background: var(--color-bg-soft);
  padding: 1px 6px;
}
.admin-status {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 7px;
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 1px solid var(--color-line);
  color: var(--color-text-soft);
}
.admin-status--published { color: #2c5e2c; border-color: #c9deca; background: #f0f6f0; }
.admin-status--draft     { color: #6b5f52; background: #f6f3ec; border-color: #e7e1d3; }
.admin-status--archived  { color: #7a3a3a; background: #f7eded; border-color: #e6cccc; }
.admin-status--sample    { color: #5a4a2a; background: #f6efde; border-color: #e6d8b3; }

.admin-row__actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.admin-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  cursor: pointer;
}
.admin-toggle input { accent-color: #1a1612; }
.admin-row__order { display: inline-flex; gap: 2px; }
.admin-row__order button {
  width: 26px;
  height: 26px;
  border: 1px solid var(--color-line);
  background: #fff;
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
}
.admin-row__order button[disabled] { opacity: 0.3; cursor: not-allowed; }
.admin-row__order button:not([disabled]):hover { background: var(--color-bg-soft); }

/* Drawer */
.admin-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 16, 12, 0.32);
  z-index: 40;
}
.admin-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: min(560px, 100%);
  height: 100vh;
  background: #fff;
  z-index: 50;
  border-left: 1px solid var(--color-line);
  display: flex;
  flex-direction: column;
  transform: translateX(20px);
  opacity: 0;
  transition: transform 0.25s ease, opacity 0.25s ease;
}
.admin-drawer.is-open { transform: translateX(0); opacity: 1; }
.admin-drawer__head {
  position: relative;
  padding: 20px 24px 14px;
  border-bottom: 1px solid var(--color-line);
}
.admin-drawer__eyebrow {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin: 0 0 6px;
}
.admin-drawer__title { font-size: 18px; font-weight: var(--fw-regular); margin: 0; line-height: 1.2; }
.admin-icon {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 28px;
  height: 28px;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  color: var(--color-text-soft);
}
.admin-icon:hover { color: var(--color-text); }

/* Form */
.admin-form {
  padding: 18px 24px 24px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1 1 auto;
}
.admin-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.admin-form__actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding-top: 12px;
  margin-top: 6px;
  border-top: 1px solid var(--color-line);
}
.admin-form__actions [data-action="delete-product"] {
  margin-right: auto;
  color: #7a3a3a;
}
.admin-form__feedback {
  font-size: 12px;
  background: #f0f6f0;
  border: 1px solid #c9deca;
  color: #2c5e2c;
  padding: 8px 10px;
  margin: 0;
}
.admin-form__feedback.is-error {
  background: #f7eded;
  border-color: #e6cccc;
  color: #7a3a3a;
}

/* Small screens */
@media (max-width: 720px) {
  .admin-toolbar { flex-direction: column; align-items: stretch; }
  .admin-row { grid-template-columns: 60px 1fr; }
  .admin-row__media { width: 60px; height: 75px; }
  .admin-row__actions { grid-column: 1 / -1; flex-wrap: wrap; }
  .admin-form__row { grid-template-columns: 1fr; }
}

/* ================================================================
   Admin · Home editor (admin/home.html)
   Tabs in top bar, slides editor, About 2-column form.
   Same in-browser-only contract.
   ================================================================ */

.admin-tabs {
  display: flex;
  gap: 0;
  border: 1px solid var(--color-line);
}
.admin-tab {
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 14px;
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  background: #fff;
  cursor: pointer;
  text-decoration: none;
}
.admin-tab + .admin-tab { border-left: 1px solid var(--color-line); }
.admin-tab:hover { color: var(--color-text); background: var(--color-bg-soft); }
.admin-tab.is-active {
  background: #1a1612;
  color: #fff;
}
.admin-nav__divider {
  width: 1px;
  height: 22px;
  background: var(--color-line);
  margin: 0 4px;
}
.admin-nav { align-items: center; }

/* Section blocks */
.admin-section {
  padding-top: 32px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--color-line);
}
.admin-section--preview { border-bottom: 0; }
.admin-section__head {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 20px;
}
.admin-section__eyebrow {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin: 0;
}
.admin-section__title {
  font-size: 18px;
  font-weight: var(--fw-regular);
  margin: 0;
}
.admin-section__lead {
  font-size: 12px;
  color: var(--color-text-soft);
  max-width: 64ch;
  margin: 0;
  line-height: 1.55;
}
.admin-section__actions {
  display: flex;
  gap: 16px;
  align-items: flex-end;
  margin-top: 8px;
  flex-wrap: wrap;
}
.admin-field--inline { width: 200px; }

/* Slide list */
.admin-slides {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.admin-slide {
  display: grid;
  grid-template-columns: 120px 1fr auto;
  gap: 16px;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--color-line);
}
.admin-slide__media {
  position: relative;
  width: 120px;
  height: 150px;
  background: var(--color-bg-soft);
  overflow: hidden;
}
.admin-slide__media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.admin-slide__num {
  position: absolute;
  left: 6px; bottom: 6px;
  font-size: 10px;
  letter-spacing: 0.04em;
  color: #fff;
  background: rgba(20,16,12,0.7);
  padding: 2px 6px;
}
.admin-slide__form {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}
.admin-slide__actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
  min-width: 90px;
}
.admin-slide__actions button[data-act="up"],
.admin-slide__actions button[data-act="down"] {
  height: 26px;
  border: 1px solid var(--color-line);
  background: #fff;
  cursor: pointer;
  font-size: 13px;
}
.admin-slide__actions button[disabled] { opacity: 0.3; cursor: not-allowed; }

/* About 2-column form */
.admin-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.admin-grid-2__foot {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  padding-top: 8px;
  border-top: 1px solid var(--color-line);
}
.admin-grid-2__foot .admin-form__feedback { margin-right: auto; }

.admin-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  border: 1px solid var(--color-line);
  background: #fff;
  padding: 16px;
}
.admin-card legend {
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
  padding: 0 6px;
}

@media (max-width: 900px) {
  .admin-grid-2 { grid-template-columns: 1fr; }
  .admin-slide { grid-template-columns: 80px 1fr; }
  .admin-slide__media { width: 80px; height: 100px; }
  .admin-slide__actions { grid-column: 1 / -1; flex-direction: row; }
}

/* Admin navigation fix — keep Products/Home tabs clickable even when the edit drawer is open. */
.admin-page .admin-banner {
  z-index: 80;
}
.admin-page .admin-header {
  position: sticky;
  top: 0;
  z-index: 70;
  background: var(--color-bg);
}
.admin-page .admin-tabs,
.admin-page .admin-tab {
  position: relative;
  z-index: 71;
}

/* ================================================================
   Admin · Home full (sec-hero..sec-contact) — 2026-05-16 dispatch
   Adds: jump nav, .admin-item rows for repeating editor sections.
   ================================================================ */

/* In-page section jump nav */
.admin-jump {
  position: sticky;
  top: 44px; /* below honesty banner */
  z-index: 8;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  padding: 10px 0;
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-line);
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-soft);
}
.admin-jump a {
  text-decoration: none;
  color: var(--color-text-soft);
}
.admin-jump a:hover { color: var(--color-text); }

/* Repeating item rows used by capabilities / gallery / process / clients / numbers / certs / contact channels */
.admin-items {
  list-style: none;
  padding: 0;
  margin: 16px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.admin-items--compact { gap: 6px; }

.admin-item {
  display: grid;
  grid-template-columns: 100px 1fr auto;
  gap: 14px;
  padding: 12px;
  border: 1px solid var(--color-line);
  background: #fff;
  align-items: start;
}
.admin-item--text { grid-template-columns: 1fr auto; }
.admin-item__media {
  width: 100px;
  height: 125px;
  background: var(--color-bg-soft);
  overflow: hidden;
}
.admin-item__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.admin-item__form {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}
.admin-item__actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: stretch;
  min-width: 90px;
}
.admin-item__actions button[data-act="up"],
.admin-item__actions button[data-act="down"] {
  height: 26px;
  border: 1px solid var(--color-line);
  background: #fff;
  cursor: pointer;
  font-size: 13px;
}
.admin-item__actions button[disabled] { opacity: 0.3; cursor: not-allowed; }

/* Tighter inline field used inside item forms */
.admin-section-head-form {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

@media (max-width: 720px) {
  .admin-item { grid-template-columns: 1fr; }
  .admin-item__media { width: 100%; height: 180px; }
  .admin-item__actions { flex-direction: row; flex-wrap: wrap; }
  .admin-jump { gap: 10px; }
}
