/* ============================================================
   JENNY KWON — F/W 2026 Lookbook
   Editorial / NYC agency aesthetic
   ============================================================ */

:root{
  --ink:#100f0c;
  --paper:#f2eee6;
  --paper-2:#e9e3d7;
  --muted:#5f594f;
  --hair:#d8d0c1;
  --accent:#a8421f;        /* used sparingly */

  --pad:clamp(18px,4.5vw,72px);
  --maxw:1640px;

  --f-sans:'Archivo','Pretendard','Pretendard Variable','Helvetica Neue',Arial,sans-serif;
  --f-kr:'Pretendard','Pretendard Variable','Apple SD Gothic Neo',sans-serif;
  --f-serif:'Bodoni Moda',Georgia,'Times New Roman',serif;

  --ease:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--f-sans);
  font-weight:450;
  line-height:1.55;
  overflow-x:hidden;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
::selection{background:var(--ink);color:var(--paper)}

.label,.section-head__meta,.section-head__num,.look__no,.nav__links a,.nav__meta,
.digitals__row b,.info__label,.statement__by,.section-sub,.runway__label,.campaign__media figcaption{
  font-size:.72rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:600;
}

/* ===================== INTRO ===================== */
.intro{
  position:fixed;inset:0;z-index:200;
  background:var(--ink);color:var(--paper);
  display:flex;align-items:center;justify-content:center;
  transition:transform 1s var(--ease);
}
.intro.is-done{transform:translateY(-101%)}
.intro__inner{
  display:flex;flex-direction:column;align-items:center;gap:.6rem;text-align:center;
}
.intro__kicker{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;opacity:.55}
.intro__name{
  font-family:var(--f-serif);font-weight:500;
  font-size:clamp(2.6rem,9vw,7rem);line-height:.95;letter-spacing:-.01em;
}
.intro__count{font-size:.8rem;letter-spacing:.3em;opacity:.5;font-variant-numeric:tabular-nums}

/* ===================== NAV ===================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:120;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.15rem var(--pad);
  mix-blend-mode:difference;color:#fff;
  transition:opacity .4s var(--ease),transform .55s var(--ease);
}
.nav.is-hidden{transform:translateY(-110%)}
.nav__brand{font-weight:700;letter-spacing:.16em;font-size:.84rem}
.nav__links{display:flex;gap:clamp(1rem,2.4vw,2.4rem)}
.nav__links a{position:relative;opacity:.92;transition:opacity .3s}
.nav__links a:hover{opacity:1}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-4px;width:100%;height:1px;
  background:currentColor;transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease);
}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__meta{font-variant-numeric:tabular-nums;opacity:.85}
.nav__right{display:flex;align-items:center;gap:.7rem}
.nav__cta{font-family:var(--f-kr);font-weight:700;font-size:.78rem;letter-spacing:.02em;border:1px solid currentColor;padding:.5rem 1.05rem;border-radius:999px;transition:opacity .3s}
.nav__cta:hover{opacity:.65}
.nav__lang{background:none;border:1px solid currentColor;color:inherit;font:inherit;font-weight:700;font-size:.72rem;letter-spacing:.08em;padding:.45rem .65rem;border-radius:999px;cursor:pointer;transition:opacity .3s}
.nav__lang:hover{opacity:.65}
@media(max-width:720px){
  .nav__links{display:none}
  .nav__cta{display:none}
}

/* ===================== HERO ===================== */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden;background:var(--ink)}
.hero__img{
  position:absolute;inset:0;width:100%;height:100%;
  object-position:center 22%;
  animation:heroIn 1.6s var(--ease) both;
}
@keyframes heroIn{from{transform:scale(1.08);opacity:.4}to{transform:scale(1);opacity:1}}
.hero__grain{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to bottom,rgba(0,0,0,.35),rgba(0,0,0,0) 28%,rgba(0,0,0,0) 55%,rgba(0,0,0,.5));
}
.hero__frame{position:absolute;inset:0;pointer-events:none;color:#fff;mix-blend-mode:difference}
.hero__kicker{
  position:absolute;top:calc(1.15rem + 3.4rem);left:var(--pad);
  font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;
}
.hero__vert{
  position:absolute;bottom:var(--pad);
  writing-mode:vertical-rl;
  font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;opacity:.9;
}
.hero__vert--l{left:var(--pad)}
.hero__vert--r{right:var(--pad);transform:rotate(180deg)}
.hero__title{
  position:absolute;left:var(--pad);right:var(--pad);bottom:clamp(2.5rem,7vh,5rem);
  color:#fff;mix-blend-mode:difference;
  font-family:var(--f-serif);font-weight:500;
  font-size:clamp(4.2rem,20vw,21rem);line-height:.82;letter-spacing:-.02em;
}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line span,.hero__title .line{will-change:transform}
.hero__title .line{animation:lineUp 1.1s var(--ease) both}
.hero__title .line:nth-child(2){animation-delay:.12s}
@keyframes lineUp{from{transform:translateY(105%)}to{transform:translateY(0)}}
.line--outline{
  -webkit-text-stroke:1.4px #fff;color:transparent;
  padding-left:.18em;
}
.hero__scroll{
  position:absolute;right:var(--pad);bottom:clamp(2.5rem,7vh,5rem);
  display:flex;flex-direction:column;align-items:center;gap:.7rem;
  color:#fff;mix-blend-mode:difference;
  font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;
}
.hero__scroll-line{width:1px;height:54px;background:#fff;position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;inset:0;background:var(--ink);animation:scrollLine 2s var(--ease) infinite}
@keyframes scrollLine{0%{transform:translateY(-100%)}60%,100%{transform:translateY(100%)}}
@media(max-width:720px){
  .hero__title{font-size:clamp(3.6rem,26vw,8rem)}
  .hero__scroll{display:none}
  .hero__vert{font-size:.56rem}
}

/* ===================== DIGITALS ===================== */
.digitals{border-bottom:1px solid var(--hair);padding:1.1rem var(--pad)}
.digitals__row{
  list-style:none;display:flex;flex-wrap:wrap;gap:1.4rem 2.6rem;align-items:baseline;
}
.digitals__row li{display:flex;gap:.55rem;align-items:baseline}
.digitals__row b{color:var(--muted);font-weight:500}
.digitals__row span{font-family:var(--f-serif);font-size:1.02rem}

/* ===================== STATEMENT ===================== */
.statement{
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(4.5rem,11vw,9rem) var(--pad) clamp(3.5rem,8vw,6rem);
}
.statement__lead{
  font-family:var(--f-serif);font-weight:500;
  font-size:clamp(1.5rem,3.6vw,2.9rem);line-height:1.28;letter-spacing:-.01em;
  max-width:24ch;
}
.statement__lead em{font-style:italic}
.statement__by{
  display:flex;gap:2rem;flex-wrap:wrap;margin-top:2.4rem;color:var(--muted);
}

/* ===================== SECTION HEADS ===================== */
.section-head{
  display:grid;grid-template-columns:auto 1fr auto;align-items:end;gap:1rem;
  max-width:var(--maxw);margin:0 auto;
  padding:0 var(--pad);
  border-bottom:1px solid var(--hair);padding-bottom:1.2rem;
}
.section-head__num{color:var(--muted)}
.section-head__title{
  font-family:var(--f-serif);font-weight:500;
  font-size:clamp(2.2rem,7vw,5.5rem);line-height:.9;letter-spacing:-.02em;
  grid-column:1 / -1;grid-row:2;
}
.section-head__num{grid-column:1;grid-row:1}
.section-head__meta{grid-column:3;grid-row:1;color:var(--muted);text-align:right}
.section-sub{
  max-width:var(--maxw);margin:clamp(3rem,7vw,6rem) auto 0;padding:0 var(--pad);
  display:flex;justify-content:space-between;color:var(--muted);
  border-top:1px solid var(--hair);padding-top:1rem;
}

/* ===================== LOOKBOOK ===================== */
.lookbook{padding-top:clamp(3rem,7vw,5rem)}
.look{position:relative}
.look__media{overflow:hidden;background:var(--paper-2);position:relative}
.look__media img{transition:transform 1.2s var(--ease)}
.look__media[data-zoom]{cursor:zoom-in}
.look__media:hover img{transform:scale(1.04)}
.look__media--tall{aspect-ratio:2/3}

.look__caption{padding:1rem 0 0}
.look__no{color:var(--muted)}
.look__name{font-family:var(--f-serif);font-weight:600;font-size:clamp(1.4rem,3vw,2.1rem);line-height:1.05;margin:.3rem 0 .4rem;letter-spacing:-.01em}
.look__desc{max-width:34ch;color:#33312b;font-size:.96rem;font-weight:450}
.lookbook__note{font-family:var(--f-kr);max-width:var(--maxw);margin:clamp(2.5rem,5vw,4rem) auto 0;padding:0 var(--pad);color:var(--muted);font-size:.95rem;line-height:1.6;word-break:keep-all}

/* feature */
.look--feature{
  max-width:var(--maxw);margin:clamp(3.5rem,8vw,7rem) auto;
  padding:0 var(--pad);
  display:grid;grid-template-columns:1.35fr .65fr;gap:clamp(1.5rem,4vw,4rem);align-items:end;
}
.look--feature .look__media{aspect-ratio:4/5;width:100%}
.look--feature.look--reverse{grid-template-columns:.65fr 1.35fr}
.look--feature.look--reverse .look__media{order:2}
.look--feature.look--reverse .look__caption{order:1;text-align:right}
.look--feature.look--reverse .look__desc{margin-left:auto}
@media(max-width:760px){
  .look--feature,.look--feature.look--reverse{grid-template-columns:1fr}
  .look--feature.look--reverse .look__caption{order:2;text-align:left}
  .look--feature.look--reverse .look__media{order:1}
  .look--feature.look--reverse .look__desc{margin-left:0}
}

/* duo / pair / trio */
.look-duo,.look-pair{
  max-width:var(--maxw);margin:clamp(2rem,5vw,4rem) auto;padding:0 var(--pad);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,4vw,4rem);align-items:start;
}
.look--offset{margin-top:clamp(2.5rem,8vw,7rem)}
.look-pair{align-items:start}
.look-trio{
  max-width:var(--maxw);margin:clamp(3rem,7vw,5.5rem) auto;padding:0 var(--pad);
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.5vw,2rem);
}
@media(max-width:760px){
  .look-duo,.look-pair{grid-template-columns:1fr;gap:2.5rem}
  .look--offset{margin-top:0}
  .look-trio{grid-template-columns:1fr 1fr;gap:1rem}
}

/* pull quote */
.pull{
  max-width:1100px;margin:clamp(4rem,10vw,8rem) auto;padding:0 var(--pad);
  font-family:var(--f-serif);font-weight:400;font-style:italic;
  font-size:clamp(1.7rem,4.6vw,3.6rem);line-height:1.18;text-align:center;letter-spacing:-.01em;
  position:relative;
}
.pull__mark{display:block;font-size:2.4em;line-height:.4;color:var(--muted);margin-bottom:.1em}

/* ===================== CAMPAIGN ===================== */
.campaign{
  background:var(--ink);color:var(--paper);
  margin-top:clamp(4rem,9vw,7rem);
  padding:clamp(4rem,9vw,8rem) 0;
}
.campaign ::selection{background:var(--paper);color:var(--ink)}
.campaign__intro{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(2.5rem,6vw,4.5rem);
  display:grid;gap:1rem;
}
.campaign__intro .section-head__num{color:#857d70}
.campaign__title{font-family:var(--f-serif);font-weight:500;font-size:clamp(2.4rem,8vw,6rem);line-height:.9;letter-spacing:-.02em}
.campaign__text{max-width:42ch;color:#cbc3b5;font-size:1.02rem;font-weight:450}
.campaign__grid{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,4vw,4rem);align-items:start;
}
.campaign__media{overflow:hidden}
.campaign__media img{aspect-ratio:4/5;transition:transform 1.2s var(--ease);cursor:zoom-in}
.campaign__media:hover img{transform:scale(1.04)}
.campaign__media--down{margin-top:clamp(2.5rem,9vw,8rem)}
.campaign__media figcaption{padding-top:.9rem;color:#9b9286}
@media(max-width:760px){
  .campaign__grid{grid-template-columns:1fr;gap:2.5rem}
  .campaign__media--down{margin-top:0}
}

/* ===================== RUNWAY ===================== */
.runway{position:relative;overflow:hidden}
.runway img{aspect-ratio:16/9;width:100%;object-position:center 30%}
.runway__label{
  position:absolute;left:var(--pad);bottom:var(--pad);
  color:#fff;mix-blend-mode:difference;
  display:flex;flex-direction:column;gap:.3rem;
}
.runway__label span:first-child{font-family:var(--f-serif);font-size:clamp(1.6rem,5vw,3rem);line-height:1}
.runway__label span:last-child{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase}

/* ===================== MARQUEE ===================== */
.marquee{
  overflow:hidden;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);
  padding:1.4rem 0;background:var(--paper);
}
.marquee__track{
  display:flex;align-items:center;gap:1.6rem;width:max-content;
  animation:marquee 34s linear infinite;
}
.marquee span{font-family:var(--f-serif);font-size:clamp(1.6rem,4vw,2.8rem);font-weight:400}
.marquee i{color:var(--accent);font-style:normal;font-size:1.2rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===================== INDEX ===================== */
.index{padding:clamp(4rem,9vw,7rem) 0}
.index__grid{
  max-width:var(--maxw);margin:clamp(2rem,5vw,3.5rem) auto 0;padding:0 var(--pad);
  display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(.6rem,1.4vw,1.1rem);
}
.index__cell{overflow:hidden;aspect-ratio:2/3;background:var(--paper-2);cursor:zoom-in;position:relative}
.index__cell img{filter:grayscale(1) contrast(1.02);transition:filter .6s var(--ease),transform 1s var(--ease)}
.index__cell:hover img{filter:grayscale(0);transform:scale(1.05)}
.index__cell span{
  position:absolute;top:.5rem;left:.55rem;color:#fff;mix-blend-mode:difference;
  font-size:.62rem;letter-spacing:.18em;
}
@media(max-width:900px){.index__grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.index__grid{grid-template-columns:repeat(2,1fr)}}

/* ===================== INFO / FOOTER ===================== */
.info{background:var(--ink);color:var(--paper);padding:clamp(4rem,9vw,8rem) var(--pad) 2rem}
.info ::selection{background:var(--paper);color:var(--ink)}
.info__top{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2.5rem,6vw,5rem);align-items:start;
}
.info__display{font-family:var(--f-serif);font-weight:500;font-size:clamp(3rem,11vw,8.5rem);line-height:.86;letter-spacing:-.02em}
.info__cols{display:grid;grid-template-columns:1fr 1fr;gap:2rem 1.5rem;align-self:end}
.info__col{display:flex;flex-direction:column;gap:.5rem}
.info__label{color:#857d70;margin-bottom:.4rem}
.info__col a,.info__col p{color:#e8e2d7;font-size:1.02rem;font-weight:450}
.info__col a{width:fit-content;border-bottom:1px solid transparent;transition:border-color .3s}
.info__col a:hover{border-color:#e8e2d7}
.info__bottom{
  max-width:var(--maxw);margin:clamp(3rem,7vw,5rem) auto 0;
  border-top:1px solid #2c2a25;padding-top:1.3rem;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  color:#857d70;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
}
.info__totop{background:none;border:none;color:#d9d2c6;cursor:pointer;font:inherit;letter-spacing:.14em;text-transform:uppercase}
.info__totop:hover{color:#fff}
@media(max-width:760px){
  .info__top{grid-template-columns:1fr;gap:2.5rem}
  .info__cols{grid-template-columns:1fr 1fr}
}

/* ===================== LIGHTBOX ===================== */
.lightbox{
  position:fixed;inset:0;z-index:300;background:rgba(15,14,12,.94);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;
  backdrop-filter:blur(4px);
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__img{
  max-width:min(86vw,720px);max-height:86vh;width:auto;height:auto;object-fit:contain;
  box-shadow:0 30px 80px rgba(0,0,0,.5);transform:scale(.97);transition:transform .4s var(--ease);
}
.lightbox.is-open .lightbox__img{transform:scale(1)}
.lightbox__close{
  position:absolute;top:1.4rem;right:var(--pad);background:none;border:none;color:#fff;
  cursor:pointer;font:inherit;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
}
.lightbox__nav{
  position:absolute;top:50%;transform:translateY(-50%);
  background:none;border:1px solid rgba(255,255,255,.3);color:#fff;
  width:48px;height:48px;border-radius:50%;cursor:pointer;font-size:1.1rem;
  transition:background .3s,border-color .3s;
}
.lightbox__nav:hover{background:rgba(255,255,255,.12);border-color:#fff}
.lightbox__nav--prev{left:var(--pad)}
.lightbox__nav--next{right:var(--pad)}
.lightbox__count{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);color:#fff;font-size:.7rem;letter-spacing:.18em}
@media(max-width:720px){.lightbox__nav{width:40px;height:40px}}

/* ===================== VALUE (pitch) ===================== */
.value{max-width:var(--maxw);margin:0 auto;padding:clamp(3.5rem,9vw,7.5rem) var(--pad) clamp(2.5rem,5vw,4rem)}
.value__kicker{display:block;color:var(--muted);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600}
.value__headline{
  font-family:var(--f-kr);font-weight:800;
  font-size:clamp(2.2rem,7vw,5.6rem);line-height:1.1;letter-spacing:-.035em;margin:1.2rem 0;
  word-break:keep-all;
}
.value__headline em{font-style:normal;color:var(--accent)}
.value__sub{font-family:var(--f-kr);font-size:clamp(1.05rem,2.2vw,1.4rem);max-width:44ch;color:#33312b;line-height:1.65;font-weight:450;word-break:keep-all}
.value__metrics{display:flex;flex-wrap:wrap;gap:clamp(1.8rem,6vw,5rem);margin-top:clamp(2.4rem,6vw,4rem);border-top:1px solid var(--hair);padding-top:2rem}
.value__metrics div{display:flex;flex-direction:column;gap:.4rem}
.value__metrics b{font-family:var(--f-serif);font-weight:600;font-size:clamp(2rem,5vw,3.4rem);line-height:1;letter-spacing:-.02em}
.value__metrics span{font-family:var(--f-kr);color:var(--muted);font-size:.82rem;letter-spacing:.1em;font-weight:600}

/* ===================== SERVICE ===================== */
.service{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,5rem) 0}
.service__grid{padding:0 var(--pad);margin-top:clamp(2.4rem,5vw,3.5rem);display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.6rem,3.5vw,3rem)}
.svc{border-top:1px solid var(--ink);padding-top:1.4rem;display:flex;flex-direction:column;gap:.7rem}
.svc__no{font-family:var(--f-serif);color:var(--muted);font-size:1.05rem}
.svc__title{font-family:var(--f-kr);font-weight:700;font-size:clamp(1.3rem,2.8vw,2rem);letter-spacing:-.02em}
.svc__text{font-family:var(--f-kr);color:#33312b;line-height:1.7;font-weight:450;max-width:46ch;word-break:keep-all}
.svc--accent .svc__title{color:var(--accent)}
.svc__cta{margin-top:.4rem;align-self:start;font-family:var(--f-kr);font-weight:700;font-size:.92rem;border-bottom:1.5px solid currentColor;padding-bottom:3px;transition:gap .3s}
.svc__cta:hover{opacity:.7}
@media(max-width:760px){.service__grid{grid-template-columns:1fr;gap:2rem}}

/* ===================== PROCESS ===================== */
.process{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,6rem) 0}
.process__steps{list-style:none;padding:0 var(--pad);margin-top:clamp(2.4rem,5vw,3.5rem);display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.6rem,4vw,3.5rem)}
.step{display:flex;flex-direction:column;gap:.85rem}
.step__no{font-family:var(--f-serif);font-weight:600;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1;border-bottom:1px solid var(--hair);padding-bottom:1rem}
.step__title{font-family:var(--f-kr);font-weight:700;font-size:clamp(1.2rem,2.6vw,1.75rem);letter-spacing:-.02em}
.step__text{font-family:var(--f-kr);color:#33312b;line-height:1.7;font-weight:450;word-break:keep-all}
@media(max-width:760px){.process__steps{grid-template-columns:1fr;gap:2rem}}

/* ===================== CTA (free sample) ===================== */
.cta{background:var(--ink);color:var(--paper);margin-top:clamp(4rem,9vw,7rem)}
.cta__inner{max-width:980px;margin:0 auto;padding:clamp(4rem,10vw,8rem) var(--pad);text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.3rem}
.cta__kicker{color:#9b9286;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;font-weight:600}
.cta__headline{font-family:var(--f-kr);font-weight:800;font-size:clamp(2.2rem,7.5vw,5rem);line-height:1.12;letter-spacing:-.035em;word-break:keep-all}
.cta__headline em{font-style:normal;color:#e7c9a0}
.cta__text{font-family:var(--f-kr);max-width:46ch;color:#cbc3b5;line-height:1.75;font-weight:450;font-size:1.06rem;word-break:keep-all}
.cta__btn{margin-top:1rem;background:var(--paper);color:var(--ink);font-family:var(--f-kr);padding:1.05rem 2.4rem;font-weight:700;font-size:.96rem;cursor:pointer;transition:transform .3s,opacity .3s}
.cta__btn:hover{transform:translateY(-3px);opacity:.92}

/* Korean form bits */
.info__sub{font-family:var(--f-kr)}
.form__field{font-family:var(--f-sans)}
.form__hint{font-weight:450;letter-spacing:0;text-transform:none;opacity:.7}
.form__btn{font-family:var(--f-kr)}
.form__note{font-family:var(--f-kr)}

/* ===================== ABOUT ===================== */
.about{
  max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,8vw,7rem) var(--pad);
  display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(1.6rem,5vw,5rem);align-items:center;
}
.about__media{overflow:hidden;background:var(--paper-2)}
.about__media img{height:auto;object-fit:contain;transition:transform 1.2s var(--ease);cursor:zoom-in}
.about__media:hover img{transform:scale(1.04)}
.about__title{font-family:var(--f-serif);font-weight:600;font-size:clamp(2.4rem,6vw,4.5rem);line-height:.95;letter-spacing:-.02em;margin:.7rem 0 1rem}
.about__lead{font-family:var(--f-kr);font-weight:600;font-size:clamp(1.2rem,2.3vw,1.65rem);line-height:1.45;max-width:30ch;margin-bottom:1rem;letter-spacing:-.01em;word-break:keep-all}
.about__text{font-family:var(--f-kr);max-width:46ch;color:#33312b;font-size:1rem;line-height:1.7;word-break:keep-all}
.about__facts{list-style:none;margin-top:2.2rem;border-top:1px solid var(--hair)}
.about__facts li{display:flex;gap:1.5rem;padding:.9rem 0;border-bottom:1px solid var(--hair)}
.about__facts b{flex:0 0 8rem;color:var(--muted);font-weight:600;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;padding-top:.3em}
.about__facts span{font-family:var(--f-kr);font-size:1rem;font-weight:500}
@media(max-width:760px){.about{grid-template-columns:1fr}}

/* ===================== DIGITALS / POLAROIDS ===================== */
.polaroids{padding:clamp(3rem,7vw,5rem) 0}
.polaroids__row{
  max-width:var(--maxw);margin:clamp(2rem,5vw,3.5rem) auto 0;padding:0 var(--pad);
  display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2.5vw,2.4rem);
}
.polaroid{
  background:#fdfcfa;padding:.7rem .7rem 0;
  box-shadow:0 14px 34px rgba(16,15,12,.10);transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.polaroid:nth-child(odd){transform:rotate(-1.3deg)}
.polaroid:nth-child(even){transform:rotate(1deg)}
.polaroid:hover{transform:rotate(0) translateY(-5px);box-shadow:0 22px 44px rgba(16,15,12,.16)}
.polaroid img{aspect-ratio:3/4;filter:grayscale(1) contrast(1.03);cursor:zoom-in}
.polaroid figcaption{padding:.85rem .2rem 1rem;text-align:center;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600}
.polaroids__note{max-width:var(--maxw);margin:2rem auto 0;padding:0 var(--pad);color:var(--muted);font-size:.85rem}
@media(max-width:760px){.polaroids__row{grid-template-columns:1fr 1fr;gap:1.2rem}}

/* ===================== INFO — lead + inquiry form ===================== */
.info__lead{display:flex;flex-direction:column}
.info__sub{color:#cbc3b5;margin-top:1.4rem;max-width:26ch;font-weight:450}
.form{display:flex;flex-direction:column;gap:1.15rem;align-self:start}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem}
.form__field{display:flex;flex-direction:column;gap:.5rem;color:#b3a99c;font-size:.82rem;letter-spacing:.01em;font-weight:600}
.form__field input,.form__field textarea{
  background:transparent;border:none;border-bottom:1px solid #3a382f;color:#f2eee6;
  font-family:var(--f-sans);font-size:1rem;font-weight:450;letter-spacing:0;text-transform:none;
  padding:.55rem 0;transition:border-color .3s;
}
.form__field input:focus,.form__field textarea:focus{outline:none;border-color:#e8e2d7}
.form__field textarea{resize:vertical;min-height:3.4em}
.form__btn{
  align-self:start;margin-top:.5rem;background:#f2eee6;color:#100f0c;border:none;
  padding:.95rem 1.9rem;font:inherit;font-weight:600;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  cursor:pointer;transition:opacity .3s,transform .3s;
}
.form__btn:hover{opacity:.88;transform:translateY(-2px)}
.form__note{color:#cbc3b5;font-size:.82rem;min-height:1em}
.info__cols{grid-template-columns:repeat(3,1fr);margin-top:clamp(3rem,6vw,4.5rem);border-top:1px solid #2c2a25;padding-top:2.2rem}
@media(max-width:760px){.form__row{grid-template-columns:1fr}.info__cols{grid-template-columns:1fr;gap:1.6rem}}

/* ===================== REVEAL ===================== */
[data-reveal]{opacity:0;transform:translateY(38px);transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
[data-reveal].is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  [data-reveal]{opacity:1;transform:none}
}
