/* ============================================================
   P&W International — Global Stylesheet
   Aesthetic: warm-neutral, refined luxury (Aesop-inspired)
   Fonts: KoPubWorld Batang (serif display) / SUIT (sans body)
   ============================================================ */

/* ---- Webfonts ---------------------------------------------- */
/* SUIT (sans) — 안정적 CDN */
@import url('https://cdn.jsdelivr.net/gh/sunn-us/SUIT/fonts/variable/woff2/SUITVariable.css');
/* 라틴 세리프(영문 제목) */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&display=swap');
/* 한글 세리프 폴백 — 클라이언트 지정 KoPubWorld바탕체를 self-host 하면 아래 stack 맨 앞에서 자동 적용됨 */
@import url('https://fonts.googleapis.com/css2?family=Nanum+Myeongjo:wght@400;700;800&display=swap');

/* ---- Design Tokens ----------------------------------------- */
:root{
  /* palette */
  --paper:      #F6F3EC;   /* 가장 밝은 배경 */
  --cream:      #ECE7DD;   /* 기본 섹션 배경 */
  --sand:       #E0D8C9;   /* 보조 섹션 배경 */
  --taupe:      #C8BCA9;   /* 카드/구획 */
  --clay:       #8C7F6C;   /* 보조 텍스트 */
  --ink:        #2B2620;   /* 본문 텍스트 / 다크 섹션 */
  --espresso:   #1E1A15;   /* 푸터 */
  --line:       rgba(43,38,32,.16);
  --line-soft:  rgba(43,38,32,.08);
  --bronze:     #9A8253;   /* 절제된 포인트(링크/언더라인) */
  --on-dark:    #E9E2D5;   /* 다크 섹션 위 텍스트 */
  --on-dark-mut:rgba(233,226,213,.62);

  /* type */
  --serif: 'KoPubWorld Batang','Nanum Myeongjo','Cormorant Garamond',serif;
  --serif-en: 'Cormorant Garamond','KoPubWorld Batang','Nanum Myeongjo',serif;
  --sans: 'SUIT Variable','SUIT','Apple SD Gothic Neo','Malgun Gothic',sans-serif;

  /* metrics */
  --nav-h: 84px;
  --pad-x: clamp(20px, 6vw, 120px);
  --maxw: 1320px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---- Reset ------------------------------------------------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-weight:400;
  letter-spacing:-.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
ul{ list-style:none; }

/* ---- Utilities --------------------------------------------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad-x); }
.eyebrow{
  font-family:var(--serif-en);
  font-size:clamp(20px,2.4vw,30px);
  font-weight:500; font-style:italic;
  letter-spacing:.01em; color:var(--clay);
}
.serif{ font-family:var(--serif); }
.section{ padding-block:clamp(80px,11vw,160px); }

/* fade-in on scroll */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
[data-reveal].is-in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.12s; }
[data-reveal][data-delay="2"]{ transition-delay:.24s; }
[data-reveal][data-delay="3"]{ transition-delay:.36s; }

/* image placeholder (실제 사진 교체 전 표시) */
.ph{ background:var(--taupe) linear-gradient(135deg, rgba(255,255,255,.10), rgba(0,0,0,.05)); position:relative; overflow:hidden; }
.ph::after{
  content:attr(data-label); position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--sans); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(43,38,32,.40);
}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .5s var(--ease), box-shadow .5s var(--ease);
}
.header__inner{
  position:relative;
  width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad-x);
  display:flex; flex-direction:column; align-items:center; gap:14px;
  padding-top:26px; padding-bottom:22px;
  transition:padding .4s var(--ease), gap .4s var(--ease);
}
.logo{
  font-family:var(--serif-en); font-weight:600; font-size:31px; letter-spacing:.05em;
  color:var(--on-dark); transition:color .5s var(--ease), font-size .4s var(--ease);
}
.nav{ color:var(--on-dark); transition:color .5s var(--ease); }
/* 홈(밝은 히어로): 상단에서 헤더 다크 */
.home-light-hero .logo,
.home-light-hero .nav{ color:var(--ink); }
.nav__list{ display:flex; align-items:center; }
.nav__item{ display:flex; align-items:center; }
/* 메뉴 사이 | 구분선 */
.nav__item:not(:first-child)::before{
  content:""; width:1px; height:11px; background:currentColor; opacity:.42;
  margin:0 clamp(11px,1.5vw,19px);
}
.nav__link{
  position:relative; font-size:13.5px; font-weight:500; letter-spacing:.015em;
  color:inherit; padding-block:3px;
}
.nav__link::after{
  content:""; position:absolute; left:0; bottom:-1px; width:0; height:1px;
  background:currentColor; transition:width .4s var(--ease);
}
.nav__item:hover .nav__link::after{ width:100%; }

/* scrolled / solid state */
.header.is-solid{ background:var(--paper); box-shadow:0 1px 0 var(--line-soft); }
.header.is-solid .header__inner{ padding-top:15px; padding-bottom:13px; gap:9px; }
.header.is-solid .logo{ font-size:25px; }

/* hover state — 메뉴 호버 시 헤더 배경이 패널색(크림)으로 전환 */
.header.mega-open{ background:var(--paper); box-shadow:0 1px 0 var(--line-soft); }

/* solid·mega 상태에서는 항상 다크 텍스트 */
.header.is-solid .logo, .header.is-solid .nav,
.header.mega-open .logo, .header.mega-open .nav{ color:var(--ink); }
.header.is-solid .burger span, .header.mega-open .burger span{ background:var(--ink); }

/* mega dropdown (top은 JS가 헤더 높이에 맞춰 설정) */
.mega{
  position:fixed; left:0; right:0; top:120px;
  background:var(--paper); border-top:1px solid var(--line-soft);
  box-shadow:0 24px 40px -28px rgba(30,26,21,.4);
  opacity:0; visibility:hidden; transform:translateY(-8px);
  transition:opacity .35s var(--ease), transform .35s var(--ease), visibility .35s;
}
.header.mega-open .mega{ opacity:1; visibility:visible; transform:none; }
.mega__inner{
  max-width:var(--maxw); margin-inline:auto; padding:44px var(--pad-x) 54px;
  display:grid; grid-template-columns:repeat(7, minmax(0,1fr)); justify-content:start; gap:clamp(18px,2.4vw,40px);
}
/* 서브메뉴 없는 칸: 제목만 노출 */
.mega__col.is-empty h4{ opacity:.6; }
.mega__col h4{
  font-family:var(--serif-en); font-size:17px; font-weight:600; letter-spacing:.03em;
  color:var(--ink); margin-bottom:18px;
}
.mega__col h4 a{
  color:inherit; padding:0; display:inline-block;
  position:relative; transition:color .3s var(--ease);
}
.mega__col h4 a::after{
  content:""; position:absolute; left:0; right:0; bottom:-3px; height:1px;
  background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
.mega__col h4 a:hover{ color:var(--bronze); transform:none; }
.mega__col h4 a:hover::after{ transform:scaleX(1); }
.mega__col > a{
  display:block; font-size:13.5px; color:var(--clay); padding-block:7px;
  transition:color .3s var(--ease), transform .3s var(--ease);
}
.mega__col > a:hover{ color:var(--ink); transform:translateX(4px); }

/* burger (mobile) */
.burger{ position:absolute; right:var(--pad-x); top:24px; display:none; width:30px; height:18px; }
.header.is-solid .burger{ top:16px; }
.burger span{
  position:absolute; left:0; width:100%; height:1.5px; background:var(--on-dark);
  transition:transform .4s var(--ease), opacity .3s, background-color .5s var(--ease);
}
.home-light-hero .burger span{ background:var(--ink); }
.burger span:nth-child(1){ top:0; } .burger span:nth-child(2){ top:8px; } .burger span:nth-child(3){ top:16px; }
.is-menu-open .burger span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.is-menu-open .burger span:nth-child(2){ opacity:0; }
.is-menu-open .burger span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; height:100vh; min-height:640px; display:flex; align-items:center; color:#fff; overflow:hidden; }
.hero__media{
  position:absolute; inset:0; z-index:-2;
  transition:transform 1.4s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
}
.hero__media img,.hero__media video{
  width:100%; height:100%; object-fit:cover;
  transform-origin:center;
  animation:hero-ken-burns 22s var(--ease) infinite alternate;
  will-change:transform;
}
.hero__media .ph{ width:100%; height:100%; }
@keyframes hero-ken-burns{
  0%   { transform:scale(1)    translate(0,0); }
  100% { transform:scale(1.08) translate(-1.5%,-1%); }
}
.hero::before{ /* 가독성용 다크 워시 */
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(20,17,13,.55) 0%, rgba(20,17,13,.35) 48%, rgba(20,17,13,.55) 100%);
}
.hero__content{
  width:100%; text-align:center;
  transition:transform 1.4s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
}
.hero__title{
  font-family:var(--serif); font-weight:400; color:#fff;
  font-size:clamp(30px,5.4vw,68px); line-height:1.18; letter-spacing:-.01em;
  text-shadow:0 2px 24px rgba(0,0,0,.25);
}
/* 키네틱 타이포 — 글자 단위 stagger 리빌 */
.hero__title .ch{
  display:inline-block;
  opacity:0; transform:translateY(28px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
  transition-delay:calc(var(--i, 0) * 55ms + 120ms);
}
.hero.is-ready .hero__title .ch{ opacity:1; transform:none; }
.hero__sub{
  margin-top:22px; font-size:clamp(14px,1.4vw,18px); font-weight:400;
  color:rgba(255,255,255,.88); letter-spacing:.01em;
  text-shadow:0 1px 16px rgba(0,0,0,.25);
  opacity:0; transform:translateY(14px);
  transition:opacity 1s var(--ease) .9s, transform 1s var(--ease) .9s;
}
.hero.is-ready .hero__sub{ opacity:1; transform:none; }
.hero .btn-line{
  opacity:0; transform:translateY(14px);
  transition:opacity 1s var(--ease) 1.15s, transform 1s var(--ease) 1.15s,
             background-color .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease);
}
.hero.is-ready .btn-line{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .hero__media img,.hero__media video{ animation:none; }
  .hero__media,.hero__content{ transition:none; }
  .hero__title .ch,.hero__sub,.hero .btn-line{
    opacity:1; transform:none; transition:none;
  }
}
.btn-line{
  display:inline-flex; align-items:center; gap:10px; margin-top:40px;
  padding:15px 30px; border:1px solid rgba(255,255,255,.7);
  font-size:13px; letter-spacing:.08em; color:#fff;
  transition:background-color .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease);
}
.btn-line:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.btn-line.dark{ border-color:rgba(255,255,255,.7); color:#fff; }
.btn-line.dark:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.hero__scroll{
  position:absolute; left:50%; bottom:34px; transform:translateX(-50%);
  font-size:11px; letter-spacing:.2em; color:rgba(255,255,255,.78);
}
.hero__scroll::after{ content:""; display:block; width:1px; height:42px; margin:12px auto 0; background:rgba(255,255,255,.7); animation:scrollLine 2.4s var(--ease) infinite; transform-origin:top; }
@keyframes scrollLine{ 0%{transform:scaleY(0)} 40%{transform:scaleY(1)} 100%{transform:scaleY(0); transform-origin:bottom} }

/* ============================================================
   PHILOSOPHY (text + image, 2col)
   ============================================================ */
.philosophy{ background:var(--cream); }
.section.philosophy{ padding-block:0; }
.philosophy__grid{ max-width:none; padding-inline:0; display:grid; grid-template-columns:1fr 1fr; align-items:stretch; gap:0; }
.philosophy__copy{ padding-block:clamp(80px,11vw,150px); padding-left:var(--pad-x); padding-right:clamp(40px,5vw,80px); align-self:center; }
.philosophy__copy .eyebrow{
  display:block; margin-bottom:30px;
  font-style:normal; font-weight:600; color:var(--ink);
  font-size:clamp(26px,3.2vw,42px); letter-spacing:0;
}
.philosophy__copy p{ font-family:var(--serif); font-size:clamp(16px,1.55vw,20px); line-height:2; color:var(--ink); }
.philosophy__copy p + p{ margin-top:26px; }
.philosophy__media{ position:relative; min-height:560px; }
.philosophy__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }

/* ============================================================
   MEANING (P&W statement + 3 cards)
   ============================================================ */
.meaning{ background:var(--sand); text-align:center; }
.meaning__lead{
  font-family:var(--sans); font-weight:450;
  font-size:clamp(17px,2.1vw,25px); line-height:1.95; letter-spacing:-.01em; color:var(--ink);
  max-width:820px; margin-inline:auto;
}
.meaning__lead strong{ font-weight:700; }
.meaning__lead .accent{ color:var(--clay); }
.meaning__cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,40px); margin-top:clamp(50px,7vw,90px); text-align:center; }
.mcard .ph{ aspect-ratio:4/5; margin-bottom:24px; }
.mcard img{ width:100%; aspect-ratio:4/5; object-fit:cover; margin-bottom:24px; }
.mcard h3{ font-family:var(--serif-en); font-size:22px; font-weight:600; letter-spacing:.01em; margin-bottom:8px; }
.mcard .ko{ font-size:14px; color:var(--clay); margin-bottom:14px; letter-spacing:.02em; }
.mcard p{ font-size:14.5px; color:var(--ink); line-height:1.85; opacity:.85; }

/* ============================================================
   CAPABILITY (6-card hover grid)
   ============================================================ */
.capability{ background:var(--cream); }
.capability__head{ text-align:center; margin-bottom:clamp(48px,6vw,80px); }
.brandmark{ font-family:var(--serif-en); font-size:clamp(22px,2.6vw,32px); letter-spacing:.06em; margin-bottom:26px; }
.brandmark .amp{ font-style:normal; font-weight:500; margin:0 .04em; }
.capability__head h2{ font-family:var(--sans); font-size:clamp(22px,3vw,38px); line-height:1.45; font-weight:700; letter-spacing:-.01em; }
.capability__head p{ margin-top:20px; color:var(--clay); font-size:15px; max-width:560px; margin-inline:auto; }

.cap-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,34px); }
.cap{
  display:flex; flex-direction:column;
  background:var(--paper); border:1px solid var(--line-soft);
  transition:transform .55s var(--ease), box-shadow .55s var(--ease);
}
.cap:hover{ transform:translateY(-6px); box-shadow:0 30px 50px -34px rgba(30,26,21,.45); }
.cap__media{ aspect-ratio:16/11; overflow:hidden; }
.cap__media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.cap:hover .cap__media img{ transform:scale(1.06); }
.cap__body{ padding:30px 30px 26px; display:flex; flex-direction:column; flex:1; }
.cap h3{ font-family:var(--serif-en); font-size:21px; font-weight:600; letter-spacing:.02em; }
.cap .cap__list{ margin-top:14px; flex:1; }
.cap .cap__list li{ font-size:13.5px; color:var(--clay); line-height:1.85; }
/* 박스형 more + 버튼 */
.cap .more{
  align-self:flex-start; margin-top:24px;
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 18px; border:1px solid var(--line);
  font-size:11.5px; letter-spacing:.12em; color:var(--ink);
  transition:background-color .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease), gap .4s var(--ease);
}
.cap .more::after{ content:"+"; font-size:13px; }
.cap:hover .more{ background:var(--ink); color:var(--paper); border-color:var(--ink); gap:13px; }

/* ============================================================
   MARKETING CTA (dark band)
   ============================================================ */
.fmkt{ position:relative; background:var(--espresso); color:var(--on-dark); overflow:hidden; }
.fmkt__media{ position:absolute; inset:0; z-index:0; opacity:.32; }
.fmkt__media .ph{ width:100%; height:100%; }
.fmkt__media img{ width:100%; height:100%; object-fit:cover; }
.fmkt::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(30,26,21,.92) 0%, rgba(30,26,21,.55) 100%); z-index:1; }
.fmkt .wrap{ position:relative; z-index:2; }
.fmkt__inner{ max-width:640px; }
.fmkt h2{ font-family:var(--serif); font-size:clamp(22px,3vw,38px); line-height:1.55; font-weight:400; }
.fmkt p{ margin-top:24px; color:var(--on-dark-mut); font-size:15.5px; line-height:1.9; }
.fmkt__link{
  display:inline-flex; align-items:center; gap:18px; margin-top:38px;
  padding:17px 30px;
  border:1px solid rgba(233,226,213,.6); background:transparent;
  font-family:var(--sans); font-size:15px; font-weight:500; letter-spacing:.01em;
  color:var(--on-dark);
  transition:background-color .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease);
}
.fmkt__link .chev{ font-size:17px; line-height:1; transition:transform .4s var(--ease); }
.fmkt__link:hover{ background:var(--on-dark); color:var(--ink); border-color:var(--on-dark); }
.fmkt__link:hover .chev{ transform:translateX(4px); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--espresso); color:var(--on-dark); padding-block:64px 40px; border-top:1px solid rgba(233,226,213,.10); }
.footer__top{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:40px; align-items:flex-start; }
.footer__brand{ font-family:var(--serif-en); font-size:24px; letter-spacing:.05em; }
.footer__brand small{ display:block; font-family:var(--sans); font-size:11px; letter-spacing:.16em; color:var(--on-dark-mut); margin-top:8px; }
.footer__links{ display:flex; gap:26px; flex-wrap:wrap; }
.footer__links a{ font-size:13px; color:var(--on-dark-mut); transition:color .3s var(--ease); }
.footer__links a:hover{ color:var(--on-dark); }
.footer__info{ margin-top:40px; padding-top:26px; border-top:1px solid rgba(233,226,213,.12); font-size:12.5px; line-height:1.9; color:var(--on-dark-mut); }
.footer__info b{ font-weight:500; color:rgba(233,226,213,.8); }

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width:900px){
  :root{ --nav-h:68px; }
  .header{ height:var(--nav-h); }
  .logo{ font-size:22px; }
  .nav{ display:none; }
  .burger{ display:block; }
  .mega{ display:none; }

  /* mobile slide-out menu */
  .mnav{
    position:fixed; inset:0; z-index:90; background:var(--paper);
    padding:calc(var(--nav-h) + 18px) var(--pad-x) 80px;
    overflow-y:auto; -webkit-overflow-scrolling:touch;
    opacity:0; visibility:hidden; transform:translateY(-2%);
    transition:opacity .5s var(--ease), transform .5s var(--ease), visibility .5s;
  }
  .is-menu-open .mnav{ opacity:1; visibility:visible; transform:none; }
  .mnav__group{ padding:14px 0 10px; border-bottom:1px solid var(--line-soft); }
  .mnav__top{
    display:block; font-family:var(--serif); font-size:26px; line-height:1.3;
    color:var(--ink); padding:6px 0 4px;
  }
  .mnav__sub{
    display:block; font-family:var(--sans); font-size:13.5px;
    color:var(--clay); padding:7px 0 7px 14px; letter-spacing:.01em;
  }
  .mnav__sub:active{ color:var(--ink); }

  .philosophy__grid{ grid-template-columns:1fr; gap:0; }
  .philosophy__copy{ padding-inline:var(--pad-x); padding-block:clamp(64px,12vw,90px); }
  .philosophy__media{ min-height:0; aspect-ratio:4/3; }
  .meaning__cards{ grid-template-columns:1fr; }
  .cap-grid{ grid-template-columns:1fr; }
  .cap__body{ padding:26px 26px 24px; }
  .footer__top{ flex-direction:column; }
}
@media (min-width:901px){ .mnav{ display:none; } }
@media (max-width:600px){
  .hero{ min-height:560px; }
  .meaning__cards{ gap:36px; }
}

/* ============================================================
   SUB-PAGE COMPONENTS (About, Why Scenting, …)
   ============================================================ */
/* page hero banner (어두운 이미지 위 라이트 텍스트) */
.page-hero{ position:relative; min-height:clamp(380px,54vh,540px); display:flex; align-items:flex-end; color:#fff; overflow:hidden; }
.page-hero__media{ position:absolute; inset:0; z-index:-2; }
.page-hero__media img{ width:100%; height:100%; object-fit:cover; }
.page-hero::before{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(90deg, rgba(20,17,13,.72) 0%, rgba(20,17,13,.45) 55%, rgba(20,17,13,.28) 100%); }
.page-hero__inner{ padding-bottom:clamp(48px,6vw,82px); padding-top:calc(var(--nav-h) + 30px); }
.page-hero h1{ font-family:var(--serif-en); font-size:clamp(30px,4.4vw,52px); font-weight:600; letter-spacing:.02em; color:#fff; text-shadow:0 2px 24px rgba(0,0,0,.25); }
.page-hero p{ margin-top:16px; font-size:clamp(13px,1.25vw,16px); color:#fff; line-height:1.85; font-weight:300; text-shadow:0 1px 16px rgba(0,0,0,.3); }

/* split section (이미지 풀블리드 + 텍스트 가운데정렬) */
.split{ background:var(--cream); }
.section.split{ padding-block:0; }
.split__grid{ max-width:none; padding-inline:0; display:grid; grid-template-columns:1fr 1fr; align-items:stretch; gap:0; }
.split__media{ position:relative; min-height:540px; }
.split__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
/* 기본: 이미지 좌(좌측 끝까지) · 텍스트 우 */
.split__body{
  align-self:center; text-align:center;
  padding-block:clamp(70px,9vw,130px);
  padding-left:clamp(40px,5vw,80px); padding-right:var(--pad-x);
}
/* reverse: 이미지 우(우측 끝까지) · 텍스트 좌 */
.split--reverse .split__media{ order:2; }
.split--reverse .split__body{ order:1; padding-left:var(--pad-x); padding-right:clamp(40px,5vw,80px); }
.split__body .eyebrow-en{ font-family:var(--serif-en); font-size:clamp(22px,2.6vw,32px); font-weight:600; letter-spacing:.01em; color:var(--ink); }
.split__body .ko{ display:block; margin-top:4px; font-size:15px; color:var(--clay); letter-spacing:.02em; }
.split__body p{ margin-top:24px; font-size:clamp(14px,1.05vw,16px); line-height:1.95; color:var(--ink); opacity:.9; }
.split__body p + p{ margin-top:14px; }
/* split body 변형 — 라벨 + 굵은 고딕 헤딩 + 줄단위 본문 */
.split__body .split__label{ display:block; font-size:14px; color:var(--clay); letter-spacing:.02em; margin-bottom:14px; }
.split__body .split__title{ font-family:var(--sans); font-weight:700; font-size:clamp(20px,2.1vw,27px); line-height:1.5; letter-spacing:-.01em; color:var(--ink); }
.split__body .split__text{ margin-top:24px; font-size:clamp(13px,1vw,15px); line-height:1.95; color:var(--clay); }
/* 가장자리 정렬(에디토리얼) */
.split--alignR .split__body{ text-align:right; }
.split--alignL .split__body{ text-align:left; }

/* outline box button (라이트 배경용 다크 아웃라인) */
.btn-box{ display:inline-flex; align-items:center; gap:14px; margin-top:30px;
  padding:14px 26px; border:1px solid var(--line);
  font-family:var(--sans); font-size:13px; font-weight:500; letter-spacing:.04em; color:var(--ink);
  transition:background-color .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease); }
.btn-box .chev{ font-size:15px; line-height:1; transition:transform .4s var(--ease); }
.btn-box:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.btn-box:hover .chev{ transform:translateX(4px); }

/* full-width dark band */
.band{ position:relative; min-height:clamp(320px,44vh,480px); display:flex; align-items:center; color:var(--on-dark); overflow:hidden; }
.band__media{ position:absolute; inset:0; z-index:-2; }
.band__media img{ width:100%; height:100%; object-fit:cover; }
.band::before{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(90deg, rgba(28,24,19,.66) 0%, rgba(28,24,19,.34) 50%, rgba(28,24,19,.12) 100%); }
.band h2{ font-family:var(--serif-en); font-size:clamp(24px,3vw,40px); font-weight:600; letter-spacing:.02em; }
.band p{ margin-top:14px; font-size:clamp(13px,1.2vw,15px); color:rgba(233,226,213,.8); line-height:1.85; max-width:520px; }

/* cards grid (이미지 + 캡션) */
.cards-sec{ background:var(--cream); }
.cards-sec__head{ text-align:center; margin-bottom:clamp(46px,6vw,76px); }
.cards-sec__head .eyebrow-en{ font-family:var(--serif-en); font-size:clamp(22px,2.8vw,34px); font-weight:600; color:var(--ink); }
.cards-sec__head .ko{ display:block; margin-top:6px; font-size:15px; color:var(--clay); }
.cards-sec__head .lead{ margin-top:22px; font-family:var(--serif); font-size:clamp(17px,1.7vw,22px); line-height:1.7; color:var(--ink); }
.cards{ display:flex; flex-wrap:wrap; justify-content:center; text-align:center; column-gap:clamp(20px,2.6vw,40px); row-gap:clamp(40px,4vw,60px); }
.cards > *{ width:calc((100% - 2 * clamp(20px,2.6vw,40px)) / 3); }
.cards.cols-2 > *{ width:calc((100% - clamp(20px,2.6vw,40px)) / 2); }
.figure figcaption{ margin-top:18px; text-align:center; font-size:15px; color:var(--ink); letter-spacing:.01em; }
.figure img{ width:100%; aspect-ratio:4/3; object-fit:cover; }

@media (max-width:900px){
  .split__grid{ grid-template-columns:1fr; gap:0; }
  .split__media{ min-height:0; aspect-ratio:4/3; order:0 !important; }
  .split__body{ order:0 !important; padding-inline:var(--pad-x) !important; padding-block:clamp(56px,11vw,80px); }
  .split--alignR .split__body, .split--alignL .split__body{ text-align:left; }
  .cards > *{ width:100% !important; }
}
/* plain full-width image strip (텍스트 없는 다크 밴드) */
.imgstrip{ width:100%; height:clamp(300px,42vh,460px); overflow:hidden; }
.imgstrip img{ width:100%; height:100%; object-fit:cover; }

/* ============================================================
   CERTIFIED PAGE
   ============================================================ */
.cert-sec{ background:var(--cream); }
.cert-sec__head{ text-align:center; margin-bottom:clamp(48px,6vw,82px); }
.cert-sec__head h2{ font-family:var(--serif); font-size:clamp(24px,3vw,38px); font-weight:400; color:var(--ink); letter-spacing:.02em; }
.cert-sec__head .en{ display:block; margin-top:8px; font-family:var(--serif-en); font-size:15px; color:var(--clay); letter-spacing:.06em; }

.cert-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,2vw,30px); }
.cert{ position:relative; display:block; aspect-ratio:3/4.15; background:#fff; border:1px solid var(--line-soft); overflow:hidden;
  transition:box-shadow .5s var(--ease), transform .5s var(--ease); }
.cert:hover{ box-shadow:0 26px 44px -32px rgba(30,26,21,.5); transform:translateY(-4px); }
.cert img{ width:100%; height:100%; object-fit:cover; }
/* placeholder (실제 스캔 받기 전) */
.cert__ph{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; padding:18px; text-align:center; }
.cert__ph .ttl{ font-size:13px; color:var(--clay); letter-spacing:.04em; }
.cert__ph .sub{ font-size:11px; color:rgba(140,127,108,.6); letter-spacing:.1em; }
.cert__ph::before{ content:""; width:34px; height:34px; border:1px solid var(--line); border-radius:50%;
  display:flex; align-items:center; justify-content:center; margin-bottom:4px; }
/* hover overlay (각 링크) */
.cert__overlay{ position:absolute; inset:0; background:rgba(28,24,19,.5); color:var(--on-dark);
  display:flex; align-items:center; justify-content:center; gap:8px;
  font-size:11px; letter-spacing:.16em; opacity:0; transition:opacity .4s var(--ease); }
.cert:hover .cert__overlay{ opacity:1; }

@media (max-width:760px){ .cert-grid{ grid-template-columns:repeat(2,1fr); } }

/* ============================================================
   HISTORY (timeline)
   ============================================================ */
.history-head{ text-align:center; margin-bottom:clamp(50px,6vw,80px); }
.history-head h1{ font-family:var(--serif); font-size:clamp(24px,3vw,38px); font-weight:400; color:var(--ink); letter-spacing:.01em; }
.history-head .sub{ display:block; margin-top:8px; font-family:var(--serif-en); font-size:15px; color:var(--clay); letter-spacing:.05em; }
.tl{ position:relative; max-width:1000px; margin-inline:auto; }
.tl::before{ content:""; position:absolute; left:50%; top:6px; bottom:6px; width:1px; background:var(--line); transform:translateX(-50%); }
.tl__item{ position:relative; margin-bottom:clamp(36px,5vw,60px); }
.tl__item:last-child{ margin-bottom:0; }
.tl__year{ position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:58px; height:58px; border-radius:50%; background:var(--ink); color:var(--on-dark);
  display:flex; align-items:center; justify-content:center; font-size:13px; letter-spacing:.02em; z-index:2; }
.tl__c{ width:calc(50% - 64px); padding-top:6px; }
.tl__item--l .tl__c{ text-align:right; }
.tl__item--r .tl__c{ margin-left:calc(50% + 64px); text-align:left; }
.tl__c h3{ font-size:clamp(15px,1.25vw,18px); font-weight:700; color:var(--ink); line-height:1.45; }
.tl__c p{ margin-top:9px; font-size:13px; color:var(--clay); line-height:1.85; }

/* ============================================================
   PORTFOLIO
   ============================================================ */
.pf-tabs{ display:flex; justify-content:center; flex-wrap:wrap; border-bottom:1px solid var(--line-soft); background:var(--paper); }
.pf-tab{ padding:20px clamp(18px,4vw,56px); font-size:14px; letter-spacing:.03em; color:var(--clay); position:relative; transition:color .35s var(--ease); }
.pf-tab.is-active{ color:var(--ink); }
.pf-tab::after{ content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px; background:var(--ink); transform:scaleX(0); transition:transform .35s var(--ease); }
.pf-tab.is-active::after{ transform:scaleX(1); }
.pf-head{ text-align:center; margin-bottom:clamp(40px,5vw,64px); }
.pf-head h2{ font-family:var(--serif-en); font-size:clamp(22px,2.6vw,32px); font-weight:600; color:var(--ink); letter-spacing:.04em; }
.pf-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(12px,1.5vw,22px); }
.pf-item{ position:relative; display:block; aspect-ratio:1/1; background:#fff; overflow:hidden; border:1px solid var(--line-soft); }
.pf-item img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.pf-item:hover img{ transform:scale(1.05); }
.pf-item__ov{ position:absolute; inset:0; background:rgba(28,24,19,.30); opacity:0; transition:opacity .4s var(--ease);
  display:flex; align-items:flex-end; padding:16px; color:var(--on-dark); font-size:11px; letter-spacing:.14em; }
.pf-item:hover .pf-item__ov{ opacity:1; }
.pf-item.is-hidden{ display:none; }

@media (max-width:760px){
  .tl::before{ left:19px; }
  .tl__year{ left:19px; transform:none; width:48px; height:48px; font-size:12px; }
  .tl__c, .tl__item--r .tl__c{ width:auto; margin-left:66px; text-align:left; padding-top:4px; }
  .pf-grid{ grid-template-columns:repeat(2,1fr); }
}

/* ============================================================
   PROCESS (tabbed)
   ============================================================ */
.proc-tabs{ display:flex; justify-content:center; flex-wrap:wrap; border-bottom:1px solid var(--line-soft); background:var(--paper); }
.proc-tab{ padding:20px clamp(16px,3.5vw,50px); font-size:14px; letter-spacing:.02em; color:var(--clay); position:relative; transition:color .35s var(--ease); }
.proc-tab.is-active{ color:var(--ink); }
.proc-tab::after{ content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px; background:var(--ink); transform:scaleX(0); transition:transform .35s var(--ease); }
.proc-tab.is-active::after{ transform:scaleX(1); }
.proc-panel{ display:none; }
.proc-panel.is-active{ display:block; }

.proc-head{ text-align:center; margin-bottom:clamp(48px,6vw,76px); }
.proc-head h2{ font-family:var(--serif-en); font-size:clamp(22px,2.8vw,34px); font-weight:600; letter-spacing:.04em; color:var(--ink); }
.proc-head p{ margin-top:16px; color:var(--clay); font-size:14.5px; line-height:1.8; }

/* flow of icon steps */
.flow{ display:grid; grid-template-columns:repeat(5,1fr); gap:clamp(36px,4vw,52px) 0; }
.flow__step{ position:relative; text-align:center; padding-inline:10px; }
.flow__step:not(:nth-child(5n)):not(:last-child)::after{
  content:""; position:absolute; top:26px; right:-6px; width:12px; height:12px;
  border-top:1px solid var(--clay); border-right:1px solid var(--clay); transform:rotate(45deg); opacity:.6; }
.flow__ico{ width:54px; height:54px; margin:0 auto 16px; color:var(--ink); }
.flow__ico svg{ width:100%; height:100%; display:block; }
.flow__step h4{ font-family:var(--serif-en); font-size:15px; font-weight:600; letter-spacing:.01em; color:var(--ink); }
.flow__step .d{ margin-top:7px; font-size:12px; color:var(--clay); line-height:1.6; }
.flow + .flow{ margin-top:clamp(40px,5vw,64px); }

/* partnership uses .cards (이미 정의) */

/* FAQ accordion */
.faq{ max-width:860px; margin-inline:auto; }
.faq__item{ border-bottom:1px solid var(--line-soft); }
.faq__q{ width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:24px 4px; font-size:16px; color:var(--ink); font-weight:500; }
.faq__q .mark{ flex:0 0 auto; width:18px; height:18px; position:relative; transition:transform .4s var(--ease); }
.faq__q .mark::before,.faq__q .mark::after{ content:""; position:absolute; background:var(--clay); }
.faq__q .mark::before{ left:0; top:8px; width:18px; height:1.5px; }
.faq__q .mark::after{ left:8px; top:0; width:1.5px; height:18px; transition:transform .4s var(--ease); }
.faq__item.is-open .mark::after{ transform:rotate(90deg); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease); }
.faq__a p{ padding:0 4px 24px; color:var(--clay); font-size:14.5px; line-height:1.85; }
.faq__item.is-open .faq__a{ max-height:300px; }

/* dark CTA band */
.cta{ position:relative; min-height:clamp(300px,40vh,420px); display:flex; align-items:center; justify-content:center; text-align:center; color:var(--on-dark); overflow:hidden; }
.cta__media{ position:absolute; inset:0; z-index:-2; }
.cta__media img{ width:100%; height:100%; object-fit:cover; }
.cta::before{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg,rgba(28,24,19,.55),rgba(28,24,19,.4)); }
.cta h2{ font-family:var(--serif); font-size:clamp(22px,3vw,38px); font-weight:400; line-height:1.5; }
.btn-pill{ display:inline-flex; align-items:center; gap:10px; margin-top:28px; padding:14px 30px; border-radius:40px;
  background:var(--bronze); color:#fff; font-size:13.5px; letter-spacing:.04em;
  transition:background-color .4s var(--ease), transform .4s var(--ease); }
.btn-pill:hover{ background:#856f44; transform:translateY(-2px); }

@media (max-width:760px){
  .flow{ grid-template-columns:repeat(2,1fr); gap:34px 0; }
  .flow__step::after{ display:none !important; }
}

/* ============================================================
   COMING SOON
   ============================================================ */
.soon{
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  text-align:center; padding:calc(var(--nav-h) + 80px) var(--pad-x) 120px;
  background:var(--cream); color:var(--ink);
}
.soon__inner{ max-width:560px; }
.soon__eyebrow{ font-family:var(--serif-en); font-style:italic; font-size:clamp(18px,2vw,24px); color:var(--clay); letter-spacing:.02em; }
.soon h1{ font-family:var(--serif); font-size:clamp(34px,5.4vw,64px); font-weight:400; line-height:1.2; margin-top:18px; }
.soon p{ margin-top:26px; font-size:clamp(14px,1.2vw,16px); line-height:1.95; color:var(--clay); }
.soon .btn-box{ margin-top:38px; }
.soon__rule{ width:60px; height:1px; background:var(--line); margin:34px auto 0; }
