/* ============================================================
   STUDIO MADANG — 동탄역 디에트르 더 플레이스 '마당'
   "하루의 마당 / A Day in the Plaza" — 활기·플레이스 스토리보드
   Library lane: lottie-web (vendored)  ·  bespoke single-build
   ============================================================ */

:root{
  /* 정밀 팔레트 — 컬러풀하되 세련 (plaza palette) */
  --ink:#1d1730;            /* 자정 자두 (deep plum ink) */
  --ink-2:#2c2247;
  --paper:#fbf6ef;          /* 따뜻한 마당 종이 */
  --paper-2:#f3eadc;
  --paper-warm:#f4ebde;
  --coral:#ff5a5f;          /* 일렉트릭 코랄 (활기 키컬러) */
  --coral-deep:#e8434c;
  --gold:#ffb43a;           /* 플레이스 골드 (정오 햇살) */
  --mint:#19c2a0;           /* 민트 — 광장의 녹지 */
  --grape:#7b3fe4;          /* 자정 활성 보라 */
  --sky:#3da9fc;            /* 낮 하늘 */
  --line:rgba(29,23,48,.12);
  --ink-soft:rgba(29,23,48,.62);

  --display:"Fraunces","Bricolage Grotesque",ui-serif,Georgia,serif;
  --sans:"Plus Jakarta Sans","Pretendard",system-ui,-apple-system,"Apple SD Gothic Neo",sans-serif;
  --kr:"Pretendard","Noto Sans KR",system-ui,sans-serif;

  --wrap:1240px;
  --r:20px;
  --shadow:0 24px 60px -28px rgba(29,23,48,.4);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--kr);
  background:var(--paper);
  color:var(--ink);
  line-height:1.62;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--coral);color:#fff}

.wrap{width:min(100% - 40px,var(--wrap));margin-inline:auto}
.en{font-family:var(--sans)}

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

/* ---- scroll progress (the "day" line) ---- */
.dayline{
  position:fixed;left:0;top:0;height:4px;width:0%;z-index:120;
  background:linear-gradient(90deg,var(--sky),var(--gold),var(--coral),var(--grape));
}

/* ============ NAV ============ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(20px,4vw,40px);
  transition:background .4s var(--ease),box-shadow .4s,padding .4s;
}
.nav.solid{background:rgba(251,246,239,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);padding-block:11px}
.nav__brand{font-family:var(--display);font-weight:600;font-size:1.18rem;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.nav__brand .dot{width:10px;height:10px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 4px rgba(255,90,95,.2)}
.nav__brand b{color:var(--coral)}
.nav__menu{display:flex;gap:30px}
.nav__menu a{font-size:.92rem;font-weight:500;color:var(--ink-soft);position:relative;padding:4px 0}
.nav__menu a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--coral);transition:width .3s var(--ease)}
.nav__menu a:hover{color:var(--ink)}
.nav__menu a:hover::after{width:100%}
.nav__cta{
  font-family:var(--sans);font-weight:700;font-size:.9rem;
  background:var(--ink);color:var(--paper);padding:11px 22px;border-radius:999px;
  transition:transform .25s var(--ease),background .25s;
}
.nav__cta:hover{background:var(--coral);transform:translateY(-2px)}
.nav__burger{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.nav__burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

.drawer{position:fixed;inset:0;z-index:130;background:var(--ink);color:var(--paper);
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:40px;
  transform:translateX(100%);transition:transform .42s var(--ease)}
.drawer.open{transform:none}
.drawer a{font-family:var(--display);font-size:2rem;font-weight:500;padding:8px 0;opacity:.9}
.drawer a:hover{color:var(--gold)}
.drawer .x{position:absolute;top:24px;right:28px;background:none;border:0;color:var(--paper);font-size:2.4rem;cursor:pointer;line-height:1}

/* ============ HERO ============ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink)}
.hero__bg{position:absolute;inset:0}
.hero__bg .ph{position:absolute;inset:0;background:linear-gradient(165deg,#241a3e,#5e1f5b 55%,#e8434c);opacity:1;transition:opacity 1s}
.hero__bg .img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s var(--ease)}
.hero__bg .img.has-img{opacity:.62}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,15,35,.92) 4%,rgba(20,15,35,.2) 48%,rgba(20,15,35,.5))}

/* Lottie sky layer — the living plaza animation behind hero text */
#heroLottie{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.9}

.hero__inner{position:relative;z-index:2;width:min(100% - 40px,var(--wrap));margin-inline:auto;padding-block:0 clamp(60px,10vh,120px)}
.hero .kicker{font-family:var(--sans);font-weight:700;font-size:.8rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.hero h1{
  font-family:var(--display);font-weight:600;color:#fff;
  font-size:clamp(2.7rem,8vw,6rem);line-height:.98;letter-spacing:-.025em;
}
.hero h1 .glow{color:var(--coral);font-style:italic}
.hero h1 .ld{color:var(--gold)}
.hero .sub{color:rgba(255,255,255,.85);font-size:clamp(1rem,1.7vw,1.22rem);max-width:560px;margin-top:26px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}

/* hero 3-요소 칩 (사실/배지) */
.hero__chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:34px}
.chip{display:flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:.82rem;
  color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  padding:9px 15px;border-radius:999px;backdrop-filter:blur(6px)}
.chip .em{font-size:1rem}

.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;
  font-family:var(--sans);font-size:.7rem;letter-spacing:.3em;color:rgba(255,255,255,.7);text-transform:uppercase}
.hero__scroll::after{content:"";display:block;width:1px;height:34px;margin:10px auto 0;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:drop 1.8s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:.96rem;
  padding:14px 26px;border-radius:999px;border:0;cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s,background .25s}
.btn svg{width:18px;height:18px}
.btn--coral{background:var(--coral);color:#fff;box-shadow:0 14px 30px -12px rgba(255,90,95,.7)}
.btn--coral:hover{transform:translateY(-3px);box-shadow:0 20px 40px -12px rgba(255,90,95,.85)}
.btn--ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn--ghost:hover{background:#fff;color:var(--ink);transform:translateY(-3px)}
.btn--ink{background:var(--ink);color:var(--paper)}
.btn--ink:hover{background:var(--coral);transform:translateY(-3px)}

/* ============ TIME-OF-DAY RAIL + CHAPTERS ============ */
.kicker{font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:var(--coral);display:inline-flex;align-items:center;gap:10px}
.kicker::before{content:"";width:26px;height:2px;background:currentColor;display:inline-block}
.h2{font-family:var(--display);font-weight:600;font-size:clamp(1.9rem,4.6vw,3.3rem);line-height:1.04;letter-spacing:-.02em}
.lead{font-size:clamp(1rem,1.5vw,1.12rem);color:var(--ink-soft);line-height:1.75}

.section{padding-block:clamp(72px,11vw,140px);position:relative}
.section--ink{background:var(--ink);color:var(--paper)}
.section--ink .lead{color:rgba(255,255,255,.78)}
.section--ink .kicker{color:var(--gold)}
.section--warm{background:var(--paper-warm)}

/* chapter mast: small "time" tag */
.timetag{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px}
.timetag .clk{width:22px;height:22px}
.section--ink .timetag{color:rgba(255,255,255,.6)}

/* ============ STAT BAND ============ */
.statband{background:linear-gradient(120deg,var(--grape),var(--coral) 70%,var(--gold));color:#fff;padding-block:clamp(46px,7vw,80px)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{position:relative}
.stat .n{font-family:var(--display);font-weight:600;font-size:clamp(2rem,4.4vw,3.2rem);line-height:1;letter-spacing:-.02em}
.stat .l{font-size:.9rem;margin-top:10px;color:rgba(255,255,255,.86)}
.stat__lottie{width:46px;height:46px;margin-bottom:6px}

/* ============ SPLIT ============ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,80px);align-items:center}
.split--rev{grid-template-columns:.95fr 1.05fr}
.fig{position:relative;border-radius:var(--r);overflow:hidden;background:linear-gradient(150deg,#2a1b40,#0e0f1f);box-shadow:var(--shadow)}
.fig .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s var(--ease),transform 6s linear}
.fig .bg.has-img{opacity:1}
.fig:hover .bg.has-img{transform:scale(1.06)}
.fig figcaption{position:absolute;left:16px;bottom:14px;z-index:2;color:#fff;font-family:var(--sans);font-weight:600;font-size:.9rem;
  background:rgba(20,15,35,.5);padding:7px 13px;border-radius:999px;backdrop-filter:blur(5px)}

/* loc list */
.loc{list-style:none;margin-top:30px;display:grid;gap:0}
.loc li{display:flex;gap:16px;align-items:center;padding:16px 0;border-top:1px solid var(--line)}
.section--ink .loc li{border-color:rgba(255,255,255,.14)}
.loc li:last-child{border-bottom:1px solid var(--line)}
.section--ink .loc li:last-child{border-color:rgba(255,255,255,.14)}
.loc .pin{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  background:rgba(255,90,95,.14);color:var(--coral);font-family:var(--sans);font-weight:800;font-size:.82rem}
.section--ink .loc .pin{background:rgba(255,180,58,.18);color:var(--gold)}
.loc b{font-family:var(--sans);font-weight:700;margin-right:6px}
.loc .meta{color:var(--ink-soft);font-size:.92rem}
.section--ink .loc .meta{color:rgba(255,255,255,.66)}

/* ============ DEMAND CARDS ============ */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;position:relative;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .lot{width:56px;height:56px;margin-bottom:16px}
.card .no{position:absolute;top:18px;right:22px;font-family:var(--display);font-weight:600;font-size:2.4rem;color:var(--line)}
.card h3{font-family:var(--sans);font-weight:700;font-size:1.12rem;margin-bottom:8px}
.card p{font-size:.94rem;color:var(--ink-soft)}
.card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--coral),var(--gold));transition:width .4s var(--ease)}
.card:hover::before{width:100%}

/* ============ ANCHOR (megabox) ============ */
.anchor{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,64px);align-items:center}
.anchor .big{font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,7vw,5rem);line-height:.96;letter-spacing:-.03em;color:#fff}
.anchor .big em{color:var(--gold);font-style:italic}
.anchor .marquee{margin-top:30px;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.anchor .track{display:flex;gap:14px;width:max-content;animation:slidetrack 22s linear infinite}
@media (prefers-reduced-motion:reduce){.anchor .track{animation:none;flex-wrap:wrap;width:auto}}
.anchor .tag{font-family:var(--sans);font-weight:700;font-size:.86rem;color:#fff;border:1px solid rgba(255,255,255,.28);padding:9px 18px;border-radius:999px;white-space:nowrap}
@keyframes slidetrack{to{transform:translateX(-50%)}}
.anchorfig{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow)}
.anchorfig .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s}
.anchorfig .bg.has-img{opacity:1}
.anchorfig .play{position:absolute;left:20px;bottom:18px;z-index:2;width:64px;height:64px}

/* ============ MD MIX (plaza tiles) ============ */
.md-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.md{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:24px 16px;text-align:center;
  transition:transform .3s var(--ease),background .3s,color .3s}
.md:hover{transform:translateY(-6px) rotate(-1.5deg);background:var(--ink);color:#fff;border-color:transparent}
.md .lot{width:50px;height:50px;margin:0 auto 12px}
.md .nm{font-family:var(--sans);font-weight:700;font-size:.92rem}

/* ============ GALLERY ============ */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gal figure{position:relative;border-radius:16px;overflow:hidden;background:#241a3e}
.gal .g-a{grid-column:span 2;grid-row:span 2}
.gal .g-d{grid-column:span 2}
.gal .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s var(--ease),transform 1s var(--ease)}
.gal .bg.has-img{opacity:1}
.gal figure:hover .bg.has-img{transform:scale(1.07)}
.gal figcaption{position:absolute;left:14px;bottom:12px;z-index:2;color:#fff;font-family:var(--sans);font-weight:600;font-size:.86rem;
  background:rgba(20,15,35,.46);padding:6px 12px;border-radius:999px;backdrop-filter:blur(5px)}

/* ============ REGISTER FORM ============ */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:clamp(26px,4vw,40px);box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--sans);font-weight:700;font-size:.84rem;margin-bottom:8px}
.field input,.field select{width:100%;font-family:var(--kr);font-size:1rem;padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);transition:border-color .25s}
.field input:focus,.field select:focus{border-color:var(--coral);outline:none}
.agree{display:flex;gap:9px;align-items:flex-start;font-size:.9rem;color:var(--ink-soft);cursor:pointer}
.agree input{margin-top:4px;accent-color:var(--coral)}
.form-msg{margin-top:14px;font-size:.92rem;font-weight:600;color:var(--mint);display:none}
.form-msg.show{display:flex;align-items:center;gap:10px}
.form-msg .ok{width:30px;height:30px;flex-shrink:0}

/* ============ FOOTER ============ */
.footer{background:var(--ink);color:rgba(255,255,255,.8);padding:clamp(56px,8vw,84px) 0 40px}
.footer__brand{font-family:var(--display);font-weight:600;font-size:1.5rem;color:#fff;margin-bottom:18px}
.footer__brand b{color:var(--coral)}
.footer__legal{font-size:.92rem;line-height:1.9;color:rgba(255,255,255,.72)}
.footer__legal b{color:var(--gold)}
.footer__disc{margin-top:24px;padding-top:22px;border-top:1px solid rgba(255,255,255,.14);font-size:.78rem;line-height:1.8;color:rgba(255,255,255,.5)}

/* ============ STICKY QUICK CTA ============ */
.quick{position:fixed;right:18px;bottom:18px;z-index:90;display:flex;flex-direction:column;gap:10px}
.quick a{display:flex;align-items:center;gap:0;width:54px;height:54px;border-radius:999px;background:var(--ink);color:#fff;
  justify-content:center;box-shadow:var(--shadow);overflow:hidden;transition:width .3s var(--ease),background .3s;padding:0}
.quick a svg{width:22px;height:22px;flex-shrink:0}
.quick a .qt{font-family:var(--sans);font-weight:700;font-size:.86rem;white-space:nowrap;max-width:0;opacity:0;transition:.3s;overflow:hidden}
.quick a:hover{width:158px;background:var(--coral);gap:8px;padding:0 18px;justify-content:flex-start}
.quick a:hover .qt{max-width:120px;opacity:1}
.quick a.primary{background:var(--coral)}
.quick a.primary:hover{background:var(--grape)}

/* mobile sticky bar */
.mbar{display:none}

/* ============ POPUP ============ */
.popup-mask{position:fixed;inset:0;z-index:140;background:rgba(20,15,35,.6);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:24px}
.popup-mask.show{display:flex;animation:fade .3s}
@keyframes fade{from{opacity:0}}
.popup{background:var(--paper);border-radius:var(--r);max-width:380px;width:100%;overflow:hidden;box-shadow:0 30px 80px -20px rgba(0,0,0,.5)}
.popup__img{height:170px;background-size:cover;background-position:center;background:linear-gradient(150deg,var(--grape),var(--coral))}
.popup__body{padding:24px 26px 8px}
.popup__body .kicker{color:var(--coral)}
.popup__body h3{font-family:var(--display);font-weight:600;font-size:1.4rem;margin:10px 0;letter-spacing:-.02em}
.popup__body p{color:var(--ink-soft);font-size:.94rem}
.popup__foot{display:flex;align-items:center;justify-content:space-between;padding:14px 26px 20px;font-size:.84rem;color:var(--ink-soft)}
.popup__foot label{display:flex;gap:8px;align-items:center;cursor:pointer}
.popup__foot button{background:none;border:0;color:var(--ink-soft);cursor:pointer;font-size:.84rem}

/* ============ REVEAL ============ */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal=left]{transform:translateX(-40px)}
[data-reveal=right]{transform:translateX(40px)}
[data-reveal=left].in,[data-reveal=right].in{transform:none}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1!important;transform:none!important;transition:none}
  .hero__scroll::after{animation:none}
}

/* ============ RESPONSIVE ============ */
@media (max-width:980px){
  .stats{grid-template-columns:repeat(2,1fr);gap:30px 20px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .md-grid{grid-template-columns:repeat(3,1fr)}
  .anchor{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav__menu,.nav__cta{display:none}
  .nav__burger{display:flex}
  .split,.split--rev{grid-template-columns:1fr;gap:34px}
  .gal{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .gal .g-a{grid-row:span 1}
  .quick{display:none}
  .mbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:95;background:rgba(251,246,239,.95);backdrop-filter:blur(12px);
    border-top:1px solid var(--line);padding:10px 14px;gap:10px}
  .mbar a{flex:1;text-align:center;font-family:var(--sans);font-weight:700;font-size:.92rem;padding:13px;border-radius:12px}
  .mbar .tel{background:var(--paper-2);color:var(--ink)}
  .mbar .reg{background:var(--coral);color:#fff}
  body{padding-bottom:64px}
}
@media (max-width:520px){
  .cards,.md-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
}

/* 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}
