/* =========================================================================
   STUDIO LISIÈRE — 래미안 엘라비네
   숲의 가장자리(lisière). 모노크롬 차콜 + 딥 파인 그린.
   시네마틱 WebGL(Curtains.js) 히어로 + 차분한 스크롤 시퀀스.
   ========================================================================= */

:root{
  --bg:#0d0f0d;          /* 가장 깊은 숲그늘 */
  --bg-2:#141713;
  --paper:#f3f1ea;       /* 빛이 든 종이 */
  --paper-2:#e9e6db;
  --ink:#15170f;         /* 종이 위 글자 */
  --ink-soft:#5a5e4f;
  --line:rgba(255,255,255,.12);
  --line-dk:rgba(20,23,15,.14);
  --pine:#3f6b46;        /* 딥 파인 — 단 하나의 액센트 */
  --pine-2:#5b8c5f;
  --pine-glow:rgba(91,140,95,.5);
  --mist:#9aa089;        /* 흐린 이끼 회녹 */

  --ff-disp:"Apple SD Gothic Neo","Hiragino Mincho ProN",ui-serif,"Nanum Myeongjo",serif;
  --ff-serif:"Hiragino Mincho ProN",ui-serif,Georgia,"Nanum Myeongjo",serif;
  --ff-sans:"Apple SD Gothic Neo","Pretendard",-apple-system,"Helvetica Neue",sans-serif;
  --ff-mono:"SFMono-Regular",ui-monospace,Menlo,monospace;

  --wrap:1240px;
  --ease:cubic-bezier(.22,1,.36,1);
}

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

body{
  margin:0;
  background:var(--bg);
  color:var(--paper);
  font-family:var(--ff-sans);
  font-size:16px;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  letter-spacing:.01em;
  overflow-x:hidden;
}

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

.wrap{width:min(92%,var(--wrap));margin-inline:auto}
.eyebrow{
  font-family:var(--ff-mono);
  font-size:.68rem;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--mist);
  display:inline-block;
}
.serif{font-family:var(--ff-serif)}

/* ---- 포커스 가시 ---- */
a:focus-visible,button:focus-visible,input:focus-visible,
select:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--pine-2);
  outline-offset:3px;
  border-radius:2px;
}

/* =========================================================================
   내비
   ========================================================================= */
.lz-nav{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px clamp(18px,4vw,46px);
  transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s;
  border-bottom:1px solid transparent;
}
.lz-nav.shrink{
  background:rgba(13,15,13,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  padding-block:13px;
  border-bottom:1px solid var(--line);
}
.lz-brand{
  font-family:var(--ff-disp);font-weight:600;font-size:1.12rem;letter-spacing:.02em;
  display:flex;align-items:center;gap:.5em;
}
.lz-brand i{
  width:7px;height:7px;border-radius:50%;background:var(--pine-2);
  box-shadow:0 0 0 4px rgba(91,140,95,.18);
}
.lz-brand b{font-weight:600}
.lz-brand span{color:var(--mist);font-weight:400}
.lz-links{display:flex;gap:30px;align-items:center}
.lz-links a{
  font-size:.82rem;letter-spacing:.04em;color:#cdd0c2;position:relative;padding-block:4px;
  transition:color .3s;
}
.lz-links a::after{
  content:"";position:absolute;left:0;bottom:-1px;width:0;height:1px;background:var(--pine-2);
  transition:width .4s var(--ease);
}
.lz-links a:hover{color:var(--paper)}
.lz-links a:hover::after{width:100%}
.lz-cta{
  font-size:.8rem;letter-spacing:.06em;
  border:1px solid var(--line);padding:11px 22px;border-radius:999px;
  color:var(--paper);transition:.4s var(--ease);
}
.lz-cta:hover{background:var(--pine);border-color:var(--pine);transform:translateY(-1px)}
.lz-burger{display:none;background:none;border:0;cursor:pointer;width:30px;height:22px;position:relative}
.lz-burger span{position:absolute;left:0;height:1.6px;width:100%;background:var(--paper);transition:.4s var(--ease)}
.lz-burger span:nth-child(1){top:2px}
.lz-burger span:nth-child(2){top:10px}
.lz-burger span:nth-child(3){top:18px}

/* 드로어 */
.lz-drawer{
  position:fixed;inset:0;z-index:70;background:rgba(13,15,13,.97);
  backdrop-filter:blur(8px);display:flex;flex-direction:column;
  justify-content:center;gap:8px;padding:0 9vw;
  transform:translateY(-100%);transition:transform .6s var(--ease);
}
.lz-drawer.open{transform:translateY(0)}
.lz-drawer a{
  font-family:var(--ff-disp);font-size:clamp(1.7rem,7vw,2.4rem);font-weight:500;
  color:#d6d8cc;padding:10px 0;border-bottom:1px solid var(--line);
}
.lz-drawer a:last-of-type{border:0;color:var(--pine-2)}
.lz-drawer .lz-x{
  position:absolute;top:24px;right:26px;background:none;border:0;color:var(--paper);
  font-size:2rem;cursor:pointer;line-height:1;
}

/* =========================================================================
   히어로 — Curtains.js WebGL 플레인이 여기 위로 합성됨
   ========================================================================= */
.lz-hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  overflow:hidden;isolation:isolate;
}
/* WebGL canvas는 .curtains-canvas 로 주입 */
.curtains-canvas{
  position:fixed!important;inset:0;z-index:-1;pointer-events:none;
}
/* 정적 폴백 + WebGL 미가용 시의 실배경 */
.lz-hero__media{
  position:absolute;inset:0;z-index:0;
  background:linear-gradient(160deg,#1c2018,#3a4a31 55%,#11140e);
  background-size:cover;background-position:center;
  transition:opacity 1.1s var(--ease);
}
.lz-hero__media.has-img{opacity:1}
/* WebGL이 켜지면 DOM 이미지는 텍스처 소스로만 쓰고 화면에선 숨김 */
.webgl-on .lz-hero__media{opacity:0}
.lz-hero::after{   /* 가독 그라데이션 */
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to top,rgba(13,15,13,.92) 4%,rgba(13,15,13,.25) 42%,rgba(13,15,13,.55) 100%);
}
.lz-hero__inner{position:relative;z-index:3;width:min(92%,var(--wrap));margin-inline:auto;padding-bottom:clamp(70px,11vh,140px)}
.lz-hero__brandline{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.lz-hero__brandline .eyebrow{color:#c4c8b6}
.lz-hero__brandline .ln{flex:0 0 56px;height:1px;background:var(--mist);opacity:.6}
.lz-hero h1{
  font-family:var(--ff-disp);font-weight:500;
  font-size:clamp(2.9rem,8.2vw,7rem);line-height:.98;letter-spacing:-.01em;
  margin:0 0 .35em;
}
.lz-hero h1 em{font-style:normal;color:var(--pine-2);display:inline-block}
.lz-hero h1 .stroke{
  -webkit-text-stroke:1px var(--mist);color:transparent;
}
.lz-hero__sub{
  max-width:46ch;font-size:clamp(.96rem,1.5vw,1.12rem);color:#d9dccf;line-height:1.85;
}
.lz-hero__acts{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}
.lz-hero__scroll{
  position:absolute;left:50%;bottom:26px;z-index:3;transform:translateX(-50%);
  font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.4em;color:var(--mist);
  display:flex;flex-direction:column;align-items:center;gap:9px;
}
.lz-hero__scroll .bar{width:1px;height:42px;background:linear-gradient(var(--mist),transparent);animation:scrolldrip 2.4s var(--ease) infinite}
@keyframes scrolldrip{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}}

/* 버튼 */
.btn{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  font-size:.86rem;letter-spacing:.04em;font-family:var(--ff-sans);
  padding:15px 28px;border-radius:999px;border:1px solid transparent;
  transition:.45s var(--ease);
}
.btn svg{width:17px;height:17px;transition:transform .4s var(--ease)}
.btn--pine{background:var(--pine);color:var(--paper);box-shadow:0 10px 34px -14px var(--pine-glow)}
.btn--pine:hover{background:var(--pine-2);transform:translateY(-2px);box-shadow:0 16px 40px -14px var(--pine-glow)}
.btn--pine:hover svg{transform:translateX(5px)}
.btn--ghost{border-color:var(--line);color:var(--paper)}
.btn--ghost:hover{border-color:var(--paper);background:rgba(255,255,255,.05)}
.btn--ink{background:var(--ink);color:var(--paper)}
.btn--ink:hover{background:#262a1c;transform:translateY(-2px)}

/* =========================================================================
   공통 섹션 리듬
   ========================================================================= */
.sec{padding-block:clamp(86px,12vw,168px);position:relative}
.sec--paper{background:var(--paper);color:var(--ink)}
.sec--paper .eyebrow{color:var(--pine)}
.sec--paper-2{background:var(--paper-2);color:var(--ink)}
.sec--paper-2 .eyebrow{color:var(--pine)}
.sec-head{max-width:760px;margin-bottom:clamp(46px,6vw,80px)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-title{
  font-family:var(--ff-disp);font-weight:500;
  font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.06;letter-spacing:-.01em;
  margin:18px 0 0;
}
.sec-title em{font-style:normal;color:var(--pine)}
.sec--paper .sec-title em,.sec--paper-2 .sec-title em{color:var(--pine)}
.sec-lead{font-size:clamp(1rem,1.4vw,1.15rem);line-height:1.92;color:var(--ink-soft);margin-top:26px;max-width:60ch}
.sec--paper.center .sec-lead,.sec-head.center .sec-lead{margin-inline:auto}
.hairline{width:46px;height:2px;background:var(--pine);margin-top:24px}
.sec-head.center .hairline{margin-inline:auto}

/* =========================================================================
   스탯 밴드 (히어로 직후, 다크)
   ========================================================================= */
.lz-stats{border-block:1px solid var(--line);background:var(--bg-2)}
.lz-stats .grid{
  display:grid;grid-template-columns:repeat(4,1fr);
}
.lz-stat{padding:clamp(38px,5vw,64px) clamp(16px,3vw,40px);border-left:1px solid var(--line)}
.lz-stat:first-child{border-left:0}
.lz-stat .n{font-family:var(--ff-disp);font-weight:500;font-size:clamp(2.1rem,4.6vw,3.4rem);line-height:1;color:var(--paper)}
.lz-stat .n b{font-weight:500;color:var(--pine-2)}
.lz-stat .n .u{font-size:.42em;color:var(--mist);margin-left:.18em;letter-spacing:.02em}
.lz-stat .l{font-size:.78rem;letter-spacing:.04em;color:var(--mist);margin-top:14px}

/* =========================================================================
   사업개요 (split)
   ========================================================================= */
.lz-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,96px);align-items:center}
.lz-split--rev{grid-template-columns:.95fr 1.05fr}
.spec{border-top:1px solid var(--line-dk)}
.spec .row{
  display:grid;grid-template-columns:130px 1fr;gap:18px;
  padding:18px 4px;border-bottom:1px solid var(--line-dk);align-items:baseline;
}
.spec .k{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--pine)}
.spec .v{font-size:1.02rem;color:var(--ink);font-weight:500}

/* 미디어 프레임 (WebGL 디스토션 대상 — data-plane) */
.lz-frame{position:relative;overflow:hidden;border-radius:3px}
.lz-frame .img,.lz-frame img{
  width:100%;height:100%;object-fit:cover;display:block;
  background:linear-gradient(160deg,#2a3322,#3f6b46);background-size:cover;background-position:center;
}
.lz-frame .img{aspect-ratio:4/3;opacity:0;transition:opacity 1.1s var(--ease)}
.lz-frame .img.has-img{opacity:1}
.lz-frame figcaption{
  position:absolute;left:16px;bottom:14px;
  font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--paper);background:rgba(13,15,13,.55);padding:6px 12px;border-radius:2px;
  backdrop-filter:blur(4px);
}

/* =========================================================================
   프리미엄 — 4 포인트 (인덱스 리스트)
   ========================================================================= */
.lz-points{display:grid;gap:0;border-top:1px solid var(--line-dk)}
.lz-point{
  display:grid;grid-template-columns:90px 1fr auto;gap:clamp(18px,4vw,56px);
  align-items:center;padding:clamp(28px,4vw,46px) 6px;
  border-bottom:1px solid var(--line-dk);
  transition:background .5s var(--ease),padding-left .5s var(--ease);
}
.lz-point:hover{background:rgba(63,107,70,.05);padding-left:22px}
.lz-point .no{font-family:var(--ff-mono);font-size:1rem;color:var(--pine);letter-spacing:.06em}
.lz-point h3{font-family:var(--ff-disp);font-weight:500;font-size:clamp(1.3rem,2.6vw,1.85rem);margin:0 0 .35em;color:var(--ink)}
.lz-point p{margin:0;color:var(--ink-soft);font-size:.98rem;line-height:1.8;max-width:54ch}
.lz-point .mark{
  width:46px;height:46px;flex:none;border:1px solid var(--line-dk);border-radius:50%;
  display:grid;place-items:center;color:var(--pine);transition:.45s var(--ease);
}
.lz-point:hover .mark{background:var(--pine);color:var(--paper);border-color:var(--pine);transform:rotate(45deg)}
.lz-point .mark svg{width:18px;height:18px}

/* =========================================================================
   입지 (다크 split + 미디어)
   ========================================================================= */
.lz-loc-list{list-style:none;margin:30px 0 0;padding:0}
.lz-loc-list li{
  padding:16px 0 16px 30px;border-bottom:1px solid var(--line);position:relative;
  font-size:1rem;color:#d4d7c9;
}
.lz-loc-list li::before{
  content:"";position:absolute;left:2px;top:24px;width:9px;height:9px;border-radius:50%;
  background:var(--pine-2);box-shadow:0 0 0 4px rgba(91,140,95,.16);
}
.lz-loc-list li b{color:var(--paper);font-weight:600;margin-right:6px}

/* =========================================================================
   단지 갤러리 (모자이크)
   ========================================================================= */
.lz-gal{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:14px}
.lz-gal figure{position:relative;margin:0;overflow:hidden;border-radius:3px}
.lz-gal .ga{grid-column:span 4;grid-row:span 2}
.lz-gal .gb{grid-column:span 2;grid-row:span 1}
.lz-gal .gc{grid-column:span 2;grid-row:span 1}
.lz-gal .gd{grid-column:span 3;grid-row:span 1}
.lz-gal .ge{grid-column:span 3;grid-row:span 1}
.lz-gal figure .img{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.1s var(--ease),transform 1.2s var(--ease);
  background-color:#222a1c;
}
.lz-gal figure .img.has-img{opacity:1}
.lz-gal figure:hover .img{transform:scale(1.06)}
.lz-gal figcaption{
  position:absolute;left:14px;bottom:12px;z-index:2;
  font-family:var(--ff-mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--paper);
  text-shadow:0 1px 8px rgba(0,0,0,.6);
}
.lz-gal figure::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(13,15,13,.55),transparent 55%)}

/* =========================================================================
   평면/규모 카드
   ========================================================================= */
.lz-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.lz-card{
  border:1px solid var(--line-dk);border-radius:4px;padding:clamp(26px,3vw,40px);
  background:var(--paper);transition:.5s var(--ease);
}
.lz-card:hover{transform:translateY(-6px);border-color:var(--pine);box-shadow:0 24px 50px -28px rgba(63,107,70,.4)}
.lz-card .t{font-family:var(--ff-disp);font-weight:500;font-size:clamp(2.2rem,4vw,3rem);line-height:1;color:var(--ink)}
.lz-card .t b{font-weight:500;font-size:.42em;color:var(--pine);margin-left:.18em}
.lz-card .d{font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft);margin-top:16px}

/* =========================================================================
   일정 타임라인 (다크)
   ========================================================================= */
.lz-timeline{display:grid;gap:0;border-top:1px solid var(--line)}
.lz-step{
  display:grid;grid-template-columns:120px 1fr;gap:clamp(16px,4vw,48px);
  padding:clamp(22px,3vw,34px) 4px;border-bottom:1px solid var(--line);align-items:baseline;
  transition:background .5s var(--ease);
}
.lz-step:hover{background:rgba(63,107,70,.08)}
.lz-step .s{font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.16em;color:var(--pine-2)}
.lz-step .x{font-size:1.04rem;color:#d8dbcd;line-height:1.7}
.lz-note{margin-top:30px;font-size:.84rem;color:var(--mist)}

/* =========================================================================
   관심등록 폼
   ========================================================================= */
.lz-form{
  background:var(--bg-2);border:1px solid var(--line);border-radius:6px;
  padding:clamp(26px,4vw,44px);
}
.lz-field{margin-bottom:18px}
.lz-field label{display:block;font-size:.78rem;letter-spacing:.06em;color:var(--mist);margin-bottom:9px}
.lz-field input,.lz-field select{
  width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line);
  border-radius:4px;padding:14px 16px;color:var(--paper);font-family:inherit;font-size:.96rem;
  transition:.35s var(--ease);
}
.lz-field input::placeholder{color:#6a6e5e}
.lz-field input:focus,.lz-field select:focus{border-color:var(--pine-2);background:rgba(91,140,95,.07);outline:none}
.lz-field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239aa089' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;
}
.lz-agree{display:flex;gap:11px;align-items:flex-start;font-size:.82rem;color:var(--mist);line-height:1.6;margin:6px 0 20px;cursor:pointer}
.lz-agree input{margin-top:3px;accent-color:var(--pine)}
.lz-form__ok{
  display:none;text-align:center;padding:40px 10px;
}
.lz-form__ok.show{display:block;animation:okrise .6s var(--ease)}
@keyframes okrise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.lz-form__ok .ic{
  width:62px;height:62px;border-radius:50%;border:1.5px solid var(--pine-2);color:var(--pine-2);
  display:grid;place-items:center;margin:0 auto 22px;
}
.lz-form__ok .ic svg{width:26px;height:26px}
.lz-form__ok h3{font-family:var(--ff-disp);font-weight:500;font-size:1.5rem;margin:0 0 10px;color:var(--paper)}
.lz-form__ok p{color:var(--mist);margin:0}
.lz-reg-aside ul{list-style:none;padding:0;margin:28px 0 0}
.lz-reg-aside li{padding:14px 0;border-bottom:1px solid var(--line);font-size:.98rem;color:#d4d7c9}
.lz-reg-aside li b{color:var(--pine-2);font-weight:600;margin-right:8px}

/* =========================================================================
   푸터
   ========================================================================= */
.lz-footer{background:#090a09;border-top:1px solid var(--line);padding-block:clamp(54px,7vw,90px)}
.lz-footer__top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;padding-bottom:34px;border-bottom:1px solid var(--line)}
.lz-footer__brand{font-family:var(--ff-disp);font-weight:600;font-size:1.5rem}
.lz-footer__brand span{color:var(--mist);font-weight:400}
.lz-footer__legal{font-size:.84rem;color:#a3a796;line-height:1.85;margin:26px 0 0;max-width:80ch}
.lz-footer__disc{font-size:.78rem;color:#6f7363;line-height:1.8;margin:16px 0 0;max-width:90ch}
.lz-studio{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.24em;color:#52564a;text-transform:uppercase;margin-top:28px}

/* =========================================================================
   상시 sticky CTA (모바일 우선 + 데스크탑 퀵)
   ========================================================================= */
.lz-quick{
  position:fixed;right:18px;bottom:18px;z-index:55;display:flex;flex-direction:column;gap:10px;
}
.lz-quick a{
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;
  background:rgba(20,23,15,.9);border:1px solid var(--line);color:var(--paper);
  backdrop-filter:blur(8px);transition:.4s var(--ease);position:relative;
}
.lz-quick a svg{width:21px;height:21px}
.lz-quick a.prime{background:var(--pine);border-color:var(--pine);box-shadow:0 10px 30px -10px var(--pine-glow)}
.lz-quick a:hover{transform:translateY(-3px)}
.lz-quick a .tip{
  position:absolute;right:64px;top:50%;transform:translateY(-50%);white-space:nowrap;
  font-size:.74rem;background:var(--bg-2);border:1px solid var(--line);padding:7px 12px;border-radius:4px;
  opacity:0;pointer-events:none;transition:.3s var(--ease);
}
.lz-quick a:hover .tip{opacity:1;right:62px}

/* 모바일 바텀 CTA 바 */
.lz-mbar{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:56;
  background:rgba(13,15,13,.94);backdrop-filter:blur(12px);border-top:1px solid var(--line);
  padding:11px 14px;
}
.lz-mbar .btn{width:100%;justify-content:center}

/* =========================================================================
   팝업
   ========================================================================= */
.lz-popup-mask{
  position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;
  background:rgba(8,9,8,.72);backdrop-filter:blur(6px);padding:20px;
}
.lz-popup-mask.show{display:flex;animation:fadein .4s var(--ease)}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.lz-popup{
  width:min(420px,100%);background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  overflow:hidden;box-shadow:0 40px 90px -30px rgba(0,0,0,.7);
}
.lz-popup__img{height:200px;background:linear-gradient(160deg,#2a3322,#3f6b46);background-size:cover;background-position:center}
.lz-popup__body{padding:26px 26px 8px}
.lz-popup__body h3{font-family:var(--ff-disp);font-weight:500;font-size:1.45rem;margin:12px 0 8px;color:var(--paper)}
.lz-popup__body p{color:var(--mist);font-size:.94rem;margin:0 0 20px}
.lz-popup__body .btn{width:100%;justify-content:center}
.lz-popup__foot{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:16px 26px;border-top:1px solid var(--line);font-size:.8rem;color:var(--mist);
}
.lz-popup__foot label{display:flex;gap:8px;align-items:center;cursor:pointer}
.lz-popup__foot input{accent-color:var(--pine)}
.lz-popup__foot button{background:none;border:0;color:var(--mist);cursor:pointer;font-size:.8rem}
.lz-popup__foot button:hover{color:var(--paper)}

/* =========================================================================
   reveal (커스텀 IO — JS가 .in 토글)
   ========================================================================= */
[data-rise]{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
[data-rise].in{opacity:1;transform:none}
[data-rise][data-d="1"]{transition-delay:.1s}
[data-rise][data-d="2"]{transition-delay:.2s}
[data-rise][data-d="3"]{transition-delay:.3s}
[data-rise][data-d="4"]{transition-delay:.4s}

@media (prefers-reduced-motion:reduce){
  [data-rise]{opacity:1!important;transform:none!important;transition:none}
  .lz-hero__scroll .bar{animation:none}
  *{scroll-behavior:auto!important}
}

/* =========================================================================
   반응형
   ========================================================================= */
@media (max-width:1000px){
  .lz-links,.lz-nav .lz-cta{display:none}
  .lz-burger{display:block}
  .lz-split,.lz-split--rev{grid-template-columns:1fr;gap:42px}
  .lz-stats .grid{grid-template-columns:repeat(2,1fr)}
  .lz-stat:nth-child(3){border-left:0}
  .lz-stat:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .lz-gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .lz-gal .ga{grid-column:span 2;grid-row:span 2}
  .lz-gal .gb,.lz-gal .gc,.lz-gal .gd,.lz-gal .ge{grid-column:span 1;grid-row:span 1}
  .lz-cards{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .lz-point{grid-template-columns:1fr;gap:10px}
  .lz-point .mark{display:none}
  .lz-stats .grid{grid-template-columns:1fr 1fr}
  .lz-cards{grid-template-columns:1fr 1fr}
  .spec .row{grid-template-columns:96px 1fr;gap:12px}
  .lz-step{grid-template-columns:1fr;gap:4px}
  .lz-quick{display:none}
  .lz-mbar{display:block}
  body{padding-bottom:64px}
}

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

/* ── 예시 평면도(원본 도면 부재 시 대체) · 테마무관 ───────── */
.ex-plan{--plan-accent:currentColor;margin:30px 0 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__cap{max-width:720px;margin:13px auto 0;text-align:center;font-size:.82rem;opacity:.72}
.ex-plan__cap b{font-weight:700}
