/* ============================================================
   STUDIO CRÉMA PÂLE — 애비뉴 933 상가
   아틀리에 갤러리 월(Bricks.js masonry) · 페일 큐레이션 무드
   고유 스타일시트. 공유 시그니처 미사용.
   ============================================================ */

:root{
  /* 페일 큐레이션 팔레트 — 정밀 컬러 네가(저채도) */
  --paper:#f4f1ea;        /* 도록 종이 */
  --paper-2:#ece7dc;      /* 한 톤 더 깊은 페일 */
  --canvas:#e4ddcf;       /* 캔버스 베이지 */
  --ink:#23211d;          /* 잉크(거의 검정, 따뜻) */
  --ink-soft:#4a463e;     /* 본문 잉크 */
  --mute:#8a8478;         /* 캡션 그레쥬 */
  --line:#d8d1c2;         /* 괘선 */
  --line-2:#c9c0ad;
  --amber:#b07b35;        /* 황동 — 단 하나의 액센트 */
  --amber-deep:#8c5f25;
  --white:#fbf9f4;

  --serif:"Cormorant Garamond",Georgia,"Nanum Myeongjo",serif;
  --sans:"Jost","Helvetica Neue",-apple-system,"Apple SD Gothic Neo","Noto Sans KR",sans-serif;
  --kr:"Noto Sans KR",-apple-system,"Apple SD Gothic Neo",sans-serif;

  --gut:clamp(20px,5vw,64px);
  --maxw:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--kr);
  color:var(--ink-soft);
  background:var(--paper);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--amber);color:var(--white)}

:focus-visible{outline:2px solid var(--amber);outline-offset:3px;border-radius:2px}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.eyebrow{
  font-family:var(--sans);font-size:.72rem;letter-spacing:.42em;
  text-transform:uppercase;color:var(--amber-deep);font-weight:500;
}
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--white);
  padding:10px 16px;z-index:999;font-size:.85rem}
.skip:focus{left:8px;top:8px}

/* ---------- 스크롤 진행 ---------- */
.prog{position:fixed;top:0;left:0;height:2px;width:0;background:var(--amber);z-index:200}

/* ---------- 내비 ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:150;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--gut);
  background:rgba(244,241,234,.0);transition:background .4s var(--ease),box-shadow .4s var(--ease);
}
.nav.solid{background:rgba(244,241,234,.92);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line)}
.nav__brand{font-family:var(--serif);font-size:1.4rem;font-weight:600;letter-spacing:.02em;color:var(--ink)}
.nav__brand b{color:var(--amber-deep);font-weight:600}
.nav__menu{display:flex;gap:30px}
.nav__menu a{font-family:var(--sans);font-size:.82rem;letter-spacing:.1em;color:var(--ink-soft);
  position:relative;padding:4px 0}
.nav__menu a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
  background:var(--amber);transition:width .35s var(--ease)}
.nav__menu a:hover::after{width:100%}
.nav__cta{
  font-family:var(--sans);font-size:.78rem;letter-spacing:.12em;
  border:1px solid var(--ink);color:var(--ink);padding:9px 18px;border-radius:999px;
  transition:background .3s var(--ease),color .3s var(--ease);
}
.nav__cta:hover{background:var(--ink);color:var(--paper)}
.nav__burger{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.nav__burger span{width:24px;height:1.5px;background:var(--ink);display:block;transition:.3s}

@media(max-width:860px){
  .nav__menu{
    position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:var(--paper-2);
    flex-direction:column;justify-content:center;gap:26px;padding:40px;
    transform:translateX(100%);transition:transform .4s var(--ease);box-shadow:-20px 0 60px rgba(0,0,0,.1);
  }
  .nav__menu.open{transform:none}
  .nav__menu a{font-size:1.05rem}
  .nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__burger.x span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .nav__burger.x span:nth-child(2){opacity:0}
  .nav__burger.x span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}

/* ---------- 히어로 ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  background:var(--canvas);overflow:hidden}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.2s var(--ease)}
.hero__bg.has-img{opacity:1}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(35,33,29,.28) 0%,rgba(35,33,29,.05) 40%,rgba(244,241,234,.0) 70%,rgba(244,241,234,.86) 100%)}
.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;
  padding:0 var(--gut) clamp(40px,8vh,90px)}
.hero__tag{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.hero__tag .line{height:1px;width:46px;background:var(--amber)}
.hero__tag span{font-family:var(--sans);font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;color:var(--ink)}
.hero h1{font-family:var(--serif);color:var(--ink);font-weight:500;
  font-size:clamp(2.6rem,8.5vw,6.2rem);line-height:.98;letter-spacing:-.01em;margin-bottom:8px}
.hero h1 em{font-style:italic;color:var(--amber-deep)}
.hero__sub{font-family:var(--kr);font-size:clamp(1rem,2.4vw,1.35rem);color:var(--ink);
  font-weight:400;max-width:34ch;margin-top:10px}
.hero__three{display:flex;flex-wrap:wrap;gap:0;margin-top:34px;border-top:1px solid var(--line-2);max-width:720px}
.hero__three div{flex:1 1 0;min-width:140px;padding:18px 22px 4px 0;border-right:1px solid var(--line-2)}
.hero__three div:last-child{border-right:0}
.hero__three dt{font-family:var(--sans);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:6px}
.hero__three dd{font-family:var(--serif);font-size:clamp(1.15rem,2.6vw,1.6rem);color:var(--ink);font-weight:600;line-height:1.2}
.hero__scroll{position:absolute;right:var(--gut);bottom:clamp(40px,8vh,90px);z-index:2;
  writing-mode:vertical-rl;font-family:var(--sans);font-size:.66rem;letter-spacing:.3em;color:var(--ink);
  display:flex;align-items:center;gap:14px;text-transform:uppercase}
.hero__scroll::after{content:"";width:1px;height:40px;background:var(--ink);animation:drip 2.2s var(--ease) infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}
  55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media(max-width:560px){.hero__scroll{display:none}}

/* ---------- 섹션 공통 ---------- */
section{position:relative}
.sec-head{margin-bottom:clamp(34px,6vw,64px);max-width:760px}
.sec-head .idx{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--amber-deep);display:block;margin-bottom:10px}
.sec-head h2{font-family:var(--serif);font-weight:500;color:var(--ink);
  font-size:clamp(2rem,5.2vw,3.4rem);line-height:1.06;letter-spacing:-.01em;margin:6px 0 16px}
.sec-head p{font-size:1rem;color:var(--ink-soft);max-width:56ch}
.pad{padding-block:clamp(70px,11vw,140px)}

/* 리빌 */
.rv{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){.rv{opacity:1!important;transform:none!important;transition:none!important}
  .hero__bg{transition:none}.hero__scroll::after{animation:none}}

/* ---------- ABOUT ---------- */
#about{background:var(--paper)}
.about__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center}
@media(max-width:840px){.about__grid{grid-template-columns:1fr;gap:34px}}
.about__txt p{font-size:1.05rem;color:var(--ink-soft);margin-bottom:18px}
.about__txt p.lead{font-family:var(--serif);font-size:clamp(1.4rem,3vw,1.9rem);
  color:var(--ink);line-height:1.35;font-weight:500;margin-bottom:24px}
.about__txt p.lead em{font-style:italic;color:var(--amber-deep)}
.about__fig{position:relative;aspect-ratio:4/5;background:var(--canvas);overflow:hidden}
.about__fig .ph{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;
  transform:scale(1.06);transition:opacity 1s var(--ease),transform 6s var(--ease)}
.about__fig .ph.has-img{opacity:1;transform:none}
.about__fig figcaption{position:absolute;left:0;bottom:0;background:var(--paper);color:var(--mute);
  font-family:var(--sans);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;padding:9px 14px}

/* ---------- 갤러리 월 (Bricks.js masonry) — 시그니처 ---------- */
#wall{background:var(--paper-2)}
.wall{margin-top:8px}
.wall .brick{
  width:calc(100% - 18px);margin-bottom:18px;position:relative;background:var(--canvas);
  overflow:hidden;cursor:default;
}
/* Bricks.js sizes columns; we set widths via media queries below */
.brick__media{position:relative;overflow:hidden}
.brick__media .ph{background-size:cover;background-position:center;width:100%;
  opacity:0;transform:scale(1.05);transition:opacity .9s var(--ease),transform 1.2s var(--ease)}
.brick__media .ph.has-img{opacity:1;transform:none}
.brick:hover .brick__media .ph.has-img{transform:scale(1.05)}
.brick__plate{
  position:absolute;left:12px;bottom:12px;right:12px;
  background:rgba(244,241,234,.94);backdrop-filter:blur(4px);
  padding:11px 14px;border-left:2px solid var(--amber);
  transform:translateY(8px);opacity:0;transition:.45s var(--ease);
}
.brick:hover .brick__plate{transform:none;opacity:1}
.brick__plate .no{font-family:var(--serif);font-style:italic;color:var(--amber-deep);font-size:.85rem}
.brick__plate .ti{font-family:var(--kr);color:var(--ink);font-weight:500;font-size:.95rem;line-height:1.3;margin-top:2px}
.brick__plate .ds{font-size:.78rem;color:var(--mute);margin-top:3px}
/* aspect variety for curation rhythm */
.brick--tall .brick__media .ph{aspect-ratio:3/4}
.brick--wide .brick__media .ph{aspect-ratio:16/10}
.brick--sq .brick__media .ph{aspect-ratio:1/1}
.brick--port .brick__media .ph{aspect-ratio:4/5}
/* a text card woven into the wall */
.brick--note{background:var(--ink);color:var(--paper);display:flex;flex-direction:column;justify-content:center;
  padding:28px 24px;aspect-ratio:4/5}
.brick--note .no{font-family:var(--serif);font-style:italic;color:var(--amber);font-size:1rem}
.brick--note p{font-family:var(--serif);font-size:1.35rem;line-height:1.3;margin-top:10px;color:var(--white)}
.brick--note small{font-family:var(--sans);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-top:14px;display:block}

/* ---------- LOCATION ---------- */
#location{background:var(--paper)}
.loc{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:stretch}
@media(max-width:840px){.loc{grid-template-columns:1fr}}
.loc__fig{position:relative;min-height:340px;background:var(--canvas);overflow:hidden}
.loc__fig .ph{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s var(--ease)}
.loc__fig .ph.has-img{opacity:1}
.loc__fig .badge{position:absolute;left:16px;top:16px;background:var(--amber);color:var(--white);
  font-family:var(--sans);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;padding:7px 12px}
.loc__list{display:flex;flex-direction:column;justify-content:center;gap:0}
.loc__row{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:20px 0;border-bottom:1px solid var(--line);align-items:baseline}
.loc__row:first-child{padding-top:0}
.loc__row .k{font-family:var(--serif);font-style:italic;color:var(--amber-deep);font-size:1.05rem;white-space:nowrap}
.loc__row .v strong{display:block;font-family:var(--kr);color:var(--ink);font-weight:600;font-size:1.05rem;margin-bottom:3px}
.loc__row .v span{font-size:.92rem;color:var(--ink-soft)}

/* ---------- PREMIUM ---------- */
#premium{background:var(--ink);color:var(--paper)}
#premium .sec-head h2{color:var(--white)}
#premium .sec-head .idx{color:var(--amber)}
#premium .sec-head p{color:#b9b2a4}
.prem{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}
@media(max-width:860px){.prem{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.prem{grid-template-columns:1fr}}
.prem__c{background:var(--ink);padding:32px 26px 38px;position:relative;transition:background .4s var(--ease)}
.prem__c:hover{background:#2c2922}
.prem__c .no{font-family:var(--serif);font-style:italic;font-size:2.4rem;color:var(--amber);line-height:1}
.prem__c h3{font-family:var(--kr);font-weight:600;color:var(--white);font-size:1.15rem;margin:18px 0 10px}
.prem__c p{font-size:.92rem;color:#aaa294;line-height:1.65}

/* ---------- FLOOR ---------- */
#floor{background:var(--paper-2)}
.floor{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:840px){.floor{grid-template-columns:1fr}}
.floor__c{background:var(--paper);border:1px solid var(--line);padding:28px 26px 30px;position:relative;overflow:hidden}
.floor__c::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--amber);
  transform:scaleY(0);transform-origin:top;transition:transform .5s var(--ease)}
.floor__c:hover::before{transform:scaleY(1)}
.floor__lv{font-family:var(--serif);font-style:italic;font-size:2.2rem;color:var(--ink);line-height:1}
.floor__lv b{color:var(--amber-deep);font-style:normal;font-weight:600}
.floor__c h3{font-family:var(--kr);font-weight:600;color:var(--ink);font-size:1.05rem;margin:16px 0 8px}
.floor__c p{font-size:.92rem;color:var(--ink-soft)}
.floor__note{margin-top:22px;font-size:.82rem;color:var(--mute);font-style:italic}

/* ---------- REGISTER ---------- */
#register{background:var(--paper);position:relative}
.reg{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:start}
@media(max-width:840px){.reg{grid-template-columns:1fr;gap:36px}}
.reg__left .lead{font-family:var(--serif);font-size:clamp(1.6rem,3.4vw,2.4rem);color:var(--ink);
  line-height:1.25;font-weight:500;margin-bottom:20px}
.reg__left .lead em{font-style:italic;color:var(--amber-deep)}
.reg__left .tel{display:inline-flex;align-items:center;gap:12px;margin-top:8px;
  font-family:var(--serif);font-size:1.5rem;color:var(--ink)}
.reg__left .tel small{font-family:var(--sans);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute)}
.form{background:var(--white);border:1px solid var(--line);padding:clamp(24px,4vw,38px)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--sans);font-size:.72rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);margin-bottom:7px}
.field label .req{color:var(--amber-deep)}
.field input,.field select{width:100%;border:0;border-bottom:1px solid var(--line-2);background:transparent;
  padding:10px 2px;font-family:var(--kr);font-size:1rem;color:var(--ink);transition:border-color .3s var(--ease)}
.field input:focus,.field select:focus{outline:none;border-color:var(--amber)}
.field input::placeholder{color:#bdb6a8}
.consent{display:flex;align-items:flex-start;gap:10px;font-size:.86rem;color:var(--ink-soft);margin:6px 0 22px}
.consent input{margin-top:4px;accent-color:var(--amber);width:16px;height:16px;flex-shrink:0}
.btn{width:100%;border:0;background:var(--ink);color:var(--paper);font-family:var(--sans);
  font-size:.86rem;letter-spacing:.14em;text-transform:uppercase;padding:16px;cursor:pointer;
  transition:background .3s var(--ease)}
.btn:hover{background:var(--amber-deep)}
.form__ok{display:none;text-align:center;padding:30px 10px}
.form__ok.show{display:block;animation:pop .5s var(--ease)}
@keyframes pop{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.form__ok .mark{width:54px;height:54px;border-radius:50%;border:1.5px solid var(--amber);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--amber-deep);font-size:1.6rem}
.form__ok h3{font-family:var(--serif);font-size:1.6rem;color:var(--ink);margin-bottom:8px}
.form__ok p{font-size:.95rem;color:var(--ink-soft)}
.form.sent .field,.form.sent .consent,.form.sent .btn,.form.sent h3.fh,.form.sent .fsub{display:none}
.form h3.fh{font-family:var(--serif);font-size:1.5rem;color:var(--ink);margin-bottom:6px}
.form .fsub{font-size:.88rem;color:var(--mute);margin-bottom:24px}

/* ---------- 스티키 CTA ---------- */
.sticky-cta{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(140%);
  z-index:140;display:flex;align-items:center;gap:16px;
  background:var(--ink);color:var(--paper);padding:12px 14px 12px 22px;border-radius:999px;
  box-shadow:0 14px 40px rgba(35,33,29,.32);transition:transform .5s var(--ease);max-width:calc(100vw - 24px)}
.sticky-cta.show{transform:translateX(-50%) translateY(0)}
.sticky-cta span{font-family:var(--sans);font-size:.78rem;letter-spacing:.06em}
.sticky-cta b{font-family:var(--serif);font-style:italic;color:var(--amber)}
.sticky-cta a{background:var(--amber);color:var(--white);font-family:var(--sans);font-size:.76rem;
  letter-spacing:.1em;text-transform:uppercase;padding:10px 18px;border-radius:999px;white-space:nowrap;
  transition:background .3s var(--ease)}
.sticky-cta a:hover{background:var(--amber-deep)}
@media(max-width:480px){.sticky-cta span{display:none}.sticky-cta{padding:10px 12px 10px 16px}}

/* ---------- FOOTER ---------- */
.foot{background:var(--paper-2);border-top:1px solid var(--line);padding-block:clamp(40px,7vw,70px)}
.foot__top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:30px;align-items:flex-start;margin-bottom:40px}
.foot__brand .nav__brand{font-size:1.7rem}
.foot__brand p{font-size:.9rem;color:var(--mute);margin-top:10px;max-width:40ch}
.foot__meta{display:flex;gap:50px;flex-wrap:wrap}
.foot__meta dt{font-family:var(--sans);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:6px}
.foot__meta dd{font-size:.95rem;color:var(--ink);margin-bottom:14px}
.foot__disc{border-top:1px solid var(--line);padding-top:22px;font-size:.78rem;color:var(--mute);line-height:1.7}
.foot__disc .small{display:block;margin-top:8px;font-size:.74rem}

/* PLOT-KO-WRAP: 한글 어절 단위 줄바꿈 + 오버플로 방지 (어떤 폭에서도 자연스럽게) */
:where(html){word-break:keep-all;overflow-wrap:break-word}

/* 예시 평면/배치도(원본 도면 부재 시 대체) · 테마무관 */
.ex-plan{--plan-accent:currentColor;margin:30px auto 4px}
.ex-plan>svg{display:block;width:100%;max-width:720px;margin:0 auto;background:color-mix(in srgb,currentColor 5%,transparent);border:1px solid color-mix(in srgb,currentColor 20%,transparent);border-radius:16px;padding:14px}
.ex-plan--wide>svg{max-width:880px}
.ex-plan--sec{padding:clamp(48px,8vw,90px) clamp(18px,5vw,40px)}
.ex-plan__h{max-width:880px;margin:0 auto 20px;text-align:center;font-size:clamp(1.3rem,2.6vw,1.9rem);font-weight:700;letter-spacing:-.01em}
.ex-plan__why{max-width:760px;margin:16px auto 0;text-align:center;font-size:.94rem;opacity:.85;line-height:1.65}
.ex-plan__cap{max-width:880px;margin:8px auto 0;text-align:center;font-size:.8rem;opacity:.6}
.ex-plan__cap b,.ex-plan__why b{font-weight:700}
