/* ═══════════════════════════════════════
   한양립스 — shed.design inspired
   Extracted from shed.design:
     body: #1C1C1C text, white bg
     h1: OwnersWeb 600, ~16vw, uppercase, white on dark
     h2/label: SequelWeb 400, ~0.75vw, uppercase, letter-spacing +0.01em
     body-lg: SequelWeb 500, ~3.75vw, letter-spacing -0.02em
     accent: #3B15EB (blue/purple)
     Replaced with: Noto Sans KR / Inter, accent → #1a1a1a
   ═══════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --dark:#1c1c1c;
  --white:#fff;
  --gray:#888;
  --lgray:#e0e0e0;
  --accent:#1a1a1a;
  --pad:clamp(20px,3.5vw,56px);
  --font:'Inter','Noto Sans KR',sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}

html{font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100%}
body{font-family:var(--font);font-weight:400;color:var(--dark);background:var(--white);line-height:1.4;overflow-x:hidden;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,textarea{font-family:inherit;border:none;outline:none;background:none}
img{display:block;max-width:100%;height:auto}
ul{list-style:none}

/* ── Three.js bg ── */
#three-bg{position:fixed;top:0;left:0;width:100%;height:100vh;z-index:0;pointer-events:none;opacity:.03}

/* ── Loader ── */
.loader{position:fixed;inset:0;background:var(--dark);z-index:9999;display:flex;align-items:center;justify-content:center}
.loader-inner{text-align:center;color:var(--white)}
.loader-logo{font-size:clamp(22px,3vw,48px);font-weight:700;letter-spacing:.08em;margin-bottom:36px;opacity:0;transform:translateY(16px)}
.loader-bar-wrap{width:180px;height:1px;background:rgba(255,255,255,.12);margin:0 auto 14px}
.loader-bar{width:0;height:100%;background:var(--white);transition:width .05s linear}
.loader-pct{font-size:10px;letter-spacing:.05em;text-transform:uppercase;opacity:0}

/* ═══ HERO — full-screen dark image + huge white text ═══ */
.hero{position:relative;width:100%;height:100dvh;overflow:hidden;display:flex;flex-direction:column}

.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg-img{width:100%;height:100%;object-fit:cover}
.hero__bg::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.35)}

.header{position:relative;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:24px var(--pad)}
.header__logo{display:flex;align-items:center}
.header__logo-img{height:clamp(28px,3vw,48px);width:auto;filter:brightness(0) invert(1)}
.header__right{display:flex;align-items:center;gap:14px}
.header__menu{font-size:clamp(11px,.9vw,14px);font-weight:500;color:var(--white);letter-spacing:.02em;cursor:pointer}
.hd-tel{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--white);transition:opacity .3s}
.hd-tel:hover{opacity:.75}
.hd-tel svg{flex-shrink:0}
.hd-kakao{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#FEE500;border-radius:50%;color:#3B1E1E;transition:all .3s}
.hd-kakao:hover{background:#F5DC00;}

/* Hero marquee */
.hero__marquee{position:relative;z-index:10;overflow:hidden;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.15)}
.hero__marquee-track{display:flex;white-space:nowrap;animation:marquee 30s linear infinite}
.hero__marquee-track span{font-size:clamp(10px,.85vw,13px);font-weight:500;color:rgba(255,255,255,.6);letter-spacing:.01em;flex-shrink:0}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-33.333%)}}

/* Hero title wrap */
.hero__title-wrap{position:relative;z-index:10;margin:auto var(--pad) clamp(40px,5vw,80px)}
.hero__brand{display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:24px}
.hero__catchcopy{margin-bottom:12px;font-size:clamp(16px,2vw,24px);font-weight:700;color:#d4a853;letter-spacing:.08em;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.hero__brand-logo{height:clamp(75px,8.7vw,125px);width:auto;filter:brightness(0) invert(1)}
.hero__brand-name{font-size:clamp(20px,2.5vw,40px);font-weight:700;color:var(--white);letter-spacing:-.01em}

/* Hero title */
.hero__title{font-size:clamp(60px,10vw,140px);font-weight:800;line-height:.9;letter-spacing:-.01em;text-transform:uppercase;color:var(--white)}

/* Hero tel */
.hero-tel{display:inline-flex;align-items:center;gap:10px;margin-top:12px;color:var(--white);font-size:clamp(20px,1.8vw,28px);font-weight:700;letter-spacing:.02em;text-decoration:none;text-shadow:0 2px 12px rgba(0,0,0,.6);transition:opacity .3s}
.hero-tel:hover{opacity:.75}
.hero-tel svg{flex-shrink:0}
.hero-sale-type{margin-top:8px;color:var(--white);font-size:clamp(20px,1.8vw,28px);font-weight:700;letter-spacing:.15em;text-shadow:0 2px 12px rgba(0,0,0,.6);opacity:.85}

/* Hero bottom */
.hero__bottom{position:relative;z-index:10;display:flex;justify-content:space-between;align-items:flex-end;padding:20px var(--pad)}
.hero__thumb{width:clamp(60px,6vw,100px);height:clamp(45px,4.5vw,75px);overflow:hidden;border-radius:4px;border:2px solid rgba(255,255,255,.3)}
.hero__thumb img{width:100%;height:100%;object-fit:cover}
.hero__scroll{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--white);border:1px solid rgba(255,255,255,.4);border-radius:50px;padding:10px 20px;cursor:pointer;transition:background .3s var(--ease)}
.hero__scroll:hover{background:rgba(255,255,255,.15)}

/* ═══ SECTIONS ═══ */
.section{position:relative;z-index:1;padding:clamp(60px,8vw,120px) var(--pad)}

/* Section label (shed.design style: small uppercase + star icon) */
.section__label{display:flex;align-items:center;gap:8px;margin-bottom:clamp(20px,3vw,40px)}
.section__label span{font-size:clamp(10px,.85vw,13px);font-weight:500;letter-spacing:.01em;text-transform:uppercase}
.section__label--light span{color:var(--white)}
.label-star{flex-shrink:0}
.section__label--light .label-star{color:var(--white)}

/* ═══ INTRO ═══ */
.intro{background:var(--white)}
.intro__brand{font-size:clamp(11px,.75vw,13px);font-weight:600;color:#4a8c3f;letter-spacing:.04em;margin-bottom:8px}
.intro__headline{font-size:clamp(22px,3vw,42px);font-weight:800;line-height:1.25;letter-spacing:-.02em;color:var(--dark);margin-bottom:4px}
.intro__headline-main{font-size:clamp(32px,3.8vw,52px);font-weight:900}
.intro__headline em{font-style:normal;color:#4a8c3f}
.intro__sub-desc{font-size:clamp(14px,1.1vw,18px);font-weight:500;color:var(--gray);margin-top:0;margin-bottom:clamp(16px,2vw,28px)}

.intro__tags{display:grid;grid-template-columns:1fr 1fr;gap:clamp(6px,.8vw,10px);margin-bottom:clamp(24px,3vw,40px)}
.intro__tag{display:inline-flex;align-items:center;justify-content:center;gap:5px;font-size:clamp(11px,.75vw,13px);font-weight:500;color:var(--dark);border:1px solid rgba(0,0,0,.15);border-radius:50px;padding:6px 14px}
.intro__tag svg{color:#4a8c3f}

.intro__stats{display:flex;gap:clamp(16px,2.5vw,40px);margin-bottom:clamp(24px,3vw,40px)}
.intro__stat{display:flex;flex-direction:column}
.intro__stat-top{display:flex;align-items:baseline;gap:2px}
.intro__stat strong{font-size:clamp(26px,3.2vw,44px);font-weight:900;line-height:1;color:var(--dark);letter-spacing:-.02em}
.intro__stat span{font-size:clamp(12px,.85vw,15px);font-weight:600;color:var(--dark)}
.intro__stat small{font-size:clamp(10px,.65vw,12px);font-weight:400;color:var(--gray);margin-top:3px}

.intro__ctas{display:flex;gap:10px;flex-wrap:wrap}
.intro__cta-primary{display:inline-flex;align-items:center;font-size:clamp(13px,.9vw,15px);font-weight:700;color:var(--dark);background:rgba(74,140,63,.15);border:2px solid rgba(74,140,63,.4);border-radius:4px;padding:12px 24px;transition:all .3s var(--ease)}
.intro__cta-primary:hover{background:#4a8c3f;color:var(--white);border-color:#4a8c3f}
.intro__cta-secondary{display:inline-flex;align-items:center;font-size:clamp(13px,.9vw,15px);font-weight:600;color:var(--dark);border:1.5px solid var(--dark);border-radius:4px;padding:12px 24px;transition:all .3s var(--ease)}
.intro__cta-secondary:hover{background:var(--dark);color:var(--white)}
.intro__cta-kakao{display:inline-flex;align-items:center;gap:6px;font-size:clamp(13px,.9vw,15px);font-weight:700;color:#3B1E1E;background:#FEE500;border:2px solid #FEE500;border-radius:4px;padding:12px 24px;transition:all .3s var(--ease)}
.intro__cta-kakao:hover{background:#F5DC00;border-color:#F5DC00}
.intro__cta-kakao svg{flex-shrink:0;color:#3B1E1E}

/* ═══ ABOUT — 안심통학 초품아 (송암공원 스타일) ═══ */
.about{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.about__img{position:relative;overflow:hidden;touch-action:none}
.about__img img{width:100%;height:100%;object-fit:cover;display:block}
.about__content{background:var(--dark);color:var(--white);padding:clamp(40px,5vw,80px) clamp(30px,4vw,60px);display:flex;flex-direction:column;justify-content:center}

.about__label{font-size:clamp(11px,.75vw,13px);font-weight:500;color:rgba(255,255,255,.4);letter-spacing:.18em;text-transform:uppercase;margin-bottom:16px}
.about__title{font-size:clamp(28px,3.5vw,48px);font-weight:900;line-height:1.2;letter-spacing:-.02em;color:var(--white);margin-bottom:clamp(24px,3vw,40px)}

.about__desc{border-left:3px solid rgba(255,255,255,.15);padding-left:clamp(16px,1.5vw,24px);margin-bottom:clamp(28px,3.5vw,48px)}
.about__desc p{font-size:clamp(13px,1vw,16px);line-height:1.7;color:rgba(255,255,255,.6);margin-bottom:8px}
.about__desc p:last-child{margin-bottom:0}
.about__desc strong{color:rgba(255,255,255,.9);font-weight:600}

.about__cards{display:grid;grid-template-columns:1fr 1fr;gap:clamp(10px,1.2vw,16px)}
.about__card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:clamp(16px,1.5vw,24px);transition:border-color .3s}
.about__card:hover{border-color:rgba(74,140,63,.4)}
.about__card svg{margin-bottom:10px}
.about__card strong{display:block;font-size:clamp(13px,1vw,16px);font-weight:700;color:var(--white);margin-bottom:6px}
.about__card span{font-size:clamp(11px,.8vw,13px);line-height:1.5;color:rgba(255,255,255,.45)}

/* ═══ REEL ═══ */
.reel{background:var(--white);display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(24px,3vw,48px);align-items:start}
.reel__media{position:relative;overflow:hidden;border-radius:4px}
.reel__img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.reel__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);cursor:pointer;opacity:.8;transition:opacity .3s}
.reel__play:hover{opacity:1}
.reel__info{padding-top:clamp(10px,2vw,30px)}
.reel__desc{font-size:clamp(14px,1.2vw,20px);font-weight:400;line-height:1.5;letter-spacing:-.01em;margin-bottom:20px;max-width:400px}
.text-link{font-size:clamp(12px,1vw,16px);font-weight:600;letter-spacing:.01em;display:inline-block;border-bottom:1.5px solid currentColor;padding-bottom:2px;transition:opacity .3s}
.text-link:hover{opacity:.6}
.text-link--light{color:var(--white)}

/* ═══ SERVICES — accent bg with massive text list ═══ */
.services{background:var(--accent);color:var(--white);display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3vw,48px);overflow:hidden}
.services__desc{font-size:clamp(12px,.85vw,14px);font-weight:500;line-height:1.5;margin-bottom:8px;color:rgba(255,255,255,.5)}
.services__list{display:flex;flex-direction:column;justify-content:center}
.services__list li{font-size:clamp(36px,7.5vw,120px);font-weight:800;line-height:1;letter-spacing:-.02em;text-transform:uppercase;transition:opacity .3s}
.services__list li.services__head{font-size:clamp(44px,9vw,160px);font-weight:900}
.services__list:hover li{opacity:.3}
.services__list li:hover{opacity:1!important}

.services__gallery{display:grid;grid-template-columns:1fr 1fr 1fr;gap:clamp(16px,2vw,28px);padding:clamp(24px,4vw,48px) 0;grid-column:1/-1}
.services__card{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .3s var(--ease)}
.services__card:hover{transform:scale(1.02)}
.services__card img{width:100%;display:block;border-radius:8px}
.services__card-label{font-size:clamp(13px,1vw,16px);font-weight:600;color:rgba(255,255,255,.6);margin-top:8px;text-align:center}
.services__bottom-desc{grid-column:1/-1;font-size:clamp(13px,1vw,16px);font-weight:400;line-height:1.6;color:rgba(255,255,255,.55);margin-top:clamp(16px,2vw,28px)}

/* ═══ PROMO — 특별혜택 ═══ */
.promo{position:relative;z-index:1;background:#f4f4f2;padding:clamp(80px,10vw,160px) var(--pad);text-align:center;overflow:hidden}
.promo__inner{position:relative;max-width:900px;margin:0 auto}

.promo__badge{display:inline-block;font-size:clamp(18px,1.5vw,26px);font-weight:800;letter-spacing:.04em;color:#e53e3e;background:rgba(229,62,62,.08);border:2px solid #e53e3e;border-radius:12px;padding:14px 36px;margin-bottom:clamp(28px,3.5vw,52px);text-shadow:0 0 10px rgba(229,62,62,.4),0 0 30px rgba(229,62,62,.2);box-shadow:0 0 15px rgba(229,62,62,.3),0 0 40px rgba(229,62,62,.1);animation:badgeGlow 2s ease-in-out infinite alternate}
@keyframes badgeGlow{0%{box-shadow:0 0 15px rgba(229,62,62,.3),0 0 40px rgba(229,62,62,.1)}100%{box-shadow:0 0 25px rgba(229,62,62,.5),0 0 60px rgba(229,62,62,.2)}}

.promo__headline{font-size:clamp(24px,3.8vw,56px);font-weight:800;line-height:1.25;letter-spacing:-.02em;color:var(--dark);margin-bottom:12px}
.promo__headline em{font-style:normal;color:#4a8c3f;text-shadow:0 0 10px rgba(74,140,63,.5),0 0 30px rgba(74,140,63,.3),0 0 60px rgba(74,140,63,.15)}

.promo__sub{font-size:clamp(16px,1.4vw,22px);font-weight:600;color:var(--gray);margin-bottom:clamp(36px,5vw,64px);letter-spacing:-.01em}

.promo__cards{display:flex;justify-content:center;gap:clamp(12px,1.5vw,24px);margin-bottom:clamp(32px,4vw,56px)}
.promo-card{min-width:clamp(320px,40vw,560px)}
.promo-card{background:var(--white);border:2.5px solid var(--dark);border-radius:12px;padding:clamp(28px,3vw,48px) clamp(20px,2.5vw,36px);transition:border-color .3s var(--ease),transform .3s var(--ease)}
.promo-card:hover{border-color:var(--dark);transform:translateY(-2px)}
.promo-card__label{display:block;font-size:clamp(16px,1.2vw,20px);font-weight:800;letter-spacing:.04em;color:var(--dark);margin-bottom:clamp(12px,1.2vw,20px)}
.promo-card__value{font-size:clamp(22px,2.4vw,34px);font-weight:700;line-height:1.4;color:var(--dark)}
.promo-card__value strong{font-weight:900;font-size:1.6em}
.promo-card__notice{font-size:clamp(18px,1.4vw,22px);font-weight:700;color:#e53e3e;margin-top:clamp(12px,1.2vw,20px);letter-spacing:.02em}
.promo-card__value .accent{color:#4a8c3f;text-shadow:0 0 10px rgba(74,140,63,.5),0 0 30px rgba(74,140,63,.3),0 0 60px rgba(74,140,63,.15)}

.promo__checklist{display:flex;flex-direction:column;gap:clamp(12px,1.5vw,20px);margin-bottom:clamp(36px,4.5vw,60px);max-width:480px;margin-left:auto;margin-right:auto}
.promo__checklist li{display:flex;align-items:center;justify-content:center;gap:clamp(12px,1.2vw,18px)}
.promo__checklist li svg{flex-shrink:0;width:clamp(24px,2vw,32px);height:clamp(24px,2vw,32px)}
.promo__checklist li span{font-size:clamp(20px,1.8vw,28px);font-weight:500;color:var(--dark)}
.promo__checklist li em{font-style:normal;font-weight:600;color:#4a8c3f;text-shadow:0 0 8px rgba(74,140,63,.35)}

.promo__cta{display:inline-block;font-size:clamp(14px,1.1vw,17px);font-weight:700;letter-spacing:.01em;color:var(--white);background:var(--dark);border-radius:50px;padding:16px 48px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.promo__cta:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.15)}
.promo__cta-wrap{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap}
.promo__cta--kakao{background:#FEE500;color:#3B1E1E;display:inline-flex;align-items:center;gap:8px}
.promo__cta--kakao:hover{background:#F5DC00;box-shadow:0 8px 32px rgba(254,229,0,.3)}
.promo__cta--kakao svg{flex-shrink:0;color:#3B1E1E}

/* ═══ INTERIOR — 풀와이드 배너 ═══ */
.interior{position:relative;z-index:1;width:100%;overflow:hidden}
.interior__img{width:100%;height:auto;display:block}

/* ═══ SFP — 평형 안내 (Floor Plans) ═══ */
.sfp{background:var(--dark);position:relative;z-index:1}
.sfp-inner{width:100%;max-width:1480px;margin:0 auto;padding:100px 80px 60px}

.sfp-head{margin-bottom:36px}
.sfp-label{display:flex;align-items:center;gap:14px;font-size:12px;font-weight:500;color:#4a8c3f;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px}
.sfp-label-line{display:inline-block;width:40px;height:1px;background:#4a8c3f}
.sfp-head h2{font-size:clamp(30px,3.2vw,46px);font-weight:800;color:var(--white);letter-spacing:-.02em;margin-bottom:12px}
.sfp-tap-hint{display:none}
.sfp-sub{font-size:14px;color:rgba(255,255,255,.4);letter-spacing:.02em}

.sfp-tabs{display:flex;gap:0;margin-bottom:36px}
.sfp-tab{padding:11px 28px;font-family:var(--font);font-size:14px;font-weight:500;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.1);background:transparent;cursor:pointer;transition:all .3s;letter-spacing:.02em}
.sfp-tab:first-child{border-radius:4px 0 0 4px}
.sfp-tab:last-child{border-radius:0 4px 4px 0}
.sfp-tab+.sfp-tab{border-left:none}
.sfp-tab.active{background:#4a8c3f;color:var(--white);border-color:#4a8c3f;font-weight:700}
.sfp-tab:not(.active):hover{background:rgba(255,255,255,.05);color:var(--white)}

.sfp-panel{display:none;grid-template-columns:55fr 45fr;gap:52px;align-items:start}
.sfp-panel.active{display:grid}

.sfp-img{background:#111;border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.sfp-img img{width:100%;height:auto;display:block}

.sfp-info h3{font-size:clamp(30px,3vw,44px);font-weight:800;color:#4a8c3f;letter-spacing:-.02em;margin-bottom:16px;white-space:nowrap}
.sfp-info h3 .pyeong{font-size:.4em;font-weight:600;color:rgba(74,140,63,.7);margin-left:6px;letter-spacing:.06em}
.sfp-desc{font-size:16px;line-height:1.85;color:rgba(255,255,255,.65);margin-bottom:28px;font-weight:400}
.sfp-desc strong{font-weight:600;color:#4a8c3f}

.sfp-specs{margin-bottom:22px}
.sfp-spec{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.sfp-spec span{font-size:13px;font-weight:600;color:rgba(255,255,255,.5)}
.sfp-spec b{font-size:14px;font-weight:500;color:var(--white)}
.sfp-spec em{font-style:normal;font-size:24px;font-weight:700;color:#4a8c3f}

.sfp-features{margin-bottom:24px}
.sfp-feat-label{display:block;font-size:12px;font-weight:600;color:rgba(255,255,255,.45);letter-spacing:.05em;margin-bottom:12px}
.sfp-feat-list{display:flex;gap:8px;flex-wrap:wrap}
.sfp-feat{padding:8px 18px;font-size:13px;font-weight:600;color:#4a8c3f;background:rgba(74,140,63,.08);border:1px solid rgba(74,140,63,.3);border-radius:6px}

.sfp-cta{display:flex;align-items:center;justify-content:center;width:100%;padding:16px;background:#111;color:var(--white);font-family:var(--font);font-size:14px;font-weight:700;letter-spacing:.06em;border:1px solid rgba(255,255,255,.08);border-radius:2px;transition:background .3s,border-color .3s;cursor:pointer}
.sfp-cta:hover{background:#222;border-color:rgba(74,140,63,.3)}
.sfp-cta-wrap{display:flex;gap:8px}
.sfp-cta-wrap .sfp-cta{flex:1}
.sfp-cta--kakao{background:#FEE500!important;color:#3B1E1E!important;border-color:#FEE500!important;gap:6px}
.sfp-cta--kakao:hover{background:#F5DC00!important}
.sfp-cta--kakao svg{flex-shrink:0;color:#3B1E1E}

/* ═══ UPDATES — dark image cards ═══ */
.updates{background:var(--white)}
.updates__cards{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,32px) clamp(16px,2vw,32px)}
.update-card{display:block;transition:opacity .3s}
.update-card:hover{opacity:.85}
.update-card__img{position:relative;overflow:hidden;border-radius:4px;aspect-ratio:3/2;margin-bottom:12px}
.update-card__img img{width:100%;height:100%;object-fit:cover}
.update-card__tag{position:absolute;top:12px;left:12px;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;background:var(--white);color:var(--dark);padding:4px 10px 3px;border-radius:2px}
.update-card__text{font-size:clamp(12px,1vw,16px);line-height:1.45}
.update-card__text strong{font-weight:700}
.update-card__text span{font-weight:400;color:var(--gray)}

/* ═══ UPDATES HERO — 미래차 국가산단 ═══ */
.updates__hero{background:var(--dark);border-radius:12px;padding:clamp(28px,3.5vw,48px);margin-bottom:clamp(24px,3vw,40px);color:var(--white)}
.updates__hero-badge{display:inline-block;font-size:clamp(11px,.8vw,13px);font-weight:700;color:#4a8c3f;border:1.5px solid #4a8c3f;border-radius:50px;padding:6px 18px;margin-bottom:16px;letter-spacing:.04em}
.updates__hero-title{font-size:clamp(24px,3vw,40px);font-weight:900;letter-spacing:-.02em;margin-bottom:clamp(20px,2.5vw,32px)}
.updates__hero-stats{display:flex;gap:clamp(24px,3vw,48px);margin-bottom:clamp(20px,2.5vw,32px)}
.updates__hero-stat{display:flex;flex-direction:column}
.updates__hero-stat strong{font-size:clamp(28px,3.5vw,48px);font-weight:900;color:#4a8c3f;line-height:1;text-shadow:0 0 10px rgba(74,140,63,.4)}
.updates__hero-stat span{font-size:clamp(11px,.8vw,13px);font-weight:500;color:rgba(255,255,255,.5);margin-top:4px}
.updates__hero-desc{font-size:clamp(13px,1vw,16px);line-height:1.7;color:rgba(255,255,255,.6)}
.updates__hero-desc strong{color:var(--white);font-weight:700}

/* ═══ REGISTER ═══ */
.register{background:#272727;border-top:none;color:var(--white)}
.register .section__label span{color:var(--white)}
.register .section__label .label-star{color:var(--white)}
.register .section__label span{font-size:clamp(30px,2.5vw,39px);font-weight:800;letter-spacing:-.01em}
.register__sub{font-size:clamp(36px,3vw,48px);color:rgba(255,255,255,.85);margin-bottom:clamp(24px,3vw,40px);font-weight:500;line-height:1.4}
.register__contacts{display:flex;gap:0;margin-bottom:clamp(28px,3.5vw,48px);max-width:640px}
.register__contact-card{display:flex;align-items:center;gap:16px;flex:1;padding:16px 0;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);transition:padding-left .3s var(--ease)}
.register__contact-card:first-child{border-right:1px solid rgba(255,255,255,.1);padding-right:20px}
.register__contact-card:last-child{padding-left:20px}
.register__contact-card:hover{padding-left:6px}
.register__contact-card svg{width:40px;height:40px;padding:10px;border:1px solid rgba(74,140,63,.35);background:rgba(74,140,63,.1);border-radius:50%;color:#4a8c3f;flex-shrink:0;transition:border-color .3s,background .3s}
.register__contact-card:hover svg{border-color:#4a8c3f;background:rgba(74,140,63,.15)}
.register__contact-card--kakao svg{color:#FEE500;border-color:rgba(254,229,0,.35);background:rgba(254,229,0,.1);fill:#FEE500}
.register__contact-card--kakao:hover svg{border-color:#FEE500;background:rgba(254,229,0,.15)}
.register__contact-card small{display:block;font-size:10px;letter-spacing:.06em;color:rgba(255,255,255,.5);margin-bottom:3px}
.register__contact-card b{font-size:15px;font-weight:600;color:var(--white);letter-spacing:.02em}
.register__form{max-width:640px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,32px)}
.form-field{margin-bottom:clamp(16px,2vw,28px)}
.form-field label{display:block;font-size:clamp(13px,1vw,16px);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;color:rgba(255,255,255,.7)}
.form-field input,.form-field textarea{width:100%;padding:14px 0;font-size:clamp(18px,1.5vw,22px);font-weight:400;border-bottom:2px solid rgba(255,255,255,.3);transition:border-color .3s;color:var(--white);background:transparent}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(255,255,255,.4)}
.form-field input:focus,.form-field textarea:focus{border-bottom-color:var(--white)}
.form-field textarea{resize:vertical;min-height:80px;border:2px solid rgba(255,255,255,.3);padding:14px;margin-top:4px}
.form-field textarea:focus{border-color:var(--white)}
.form-submit{display:inline-flex;align-items:center;gap:8px;padding:16px 36px 14px;font-size:clamp(16px,1.2vw,20px);font-weight:700;background:var(--white);color:#272727;border-radius:2px;cursor:pointer;transition:background .3s var(--ease),color .3s var(--ease)}
.form-submit:hover{background:var(--dark);color:var(--white);outline:none}
.form-submit svg{transition:transform .3s var(--ease)}
.form-submit:hover svg{transform:translate(3px,-3px)}

/* ═══ 입지환경 데스크탑 ═══ */
@media(min-width:769px){
  .updates__hero{padding:clamp(40px,4vw,64px) clamp(40px,5vw,80px)}
  .updates__hero-title{font-size:clamp(32px,3.5vw,52px)}
  .updates__hero-stat strong{font-size:clamp(36px,4vw,60px)}
  .update-card__img{aspect-ratio:16/9;max-height:none}
  .updates__cards{grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,28px)}
  .update-card__text{font-size:20px;font-weight:700}
}

/* ═══ INTRO 데스크탑 중앙정렬 ═══ */
@media(min-width:769px){
  .intro{text-align:center}
  .intro__tags{grid-template-columns:repeat(4,auto);justify-content:center;max-width:900px;margin-left:auto;margin-right:auto}
  .intro__tag{font-size:clamp(14px,1vw,16px);padding:12px 28px;font-weight:600}
  .intro__stats{justify-content:center}
  .intro__ctas{justify-content:center}
  .intro__headline-main{font-size:clamp(40px,4.5vw,64px)}
  .intro__headline{font-size:clamp(28px,3.5vw,50px)}
}

/* ═══ FOOTER — 사업정보 ═══ */
.footer{position:relative;z-index:1;background:var(--dark);color:rgba(255,255,255,.55);padding:clamp(40px,5vw,60px) var(--pad) 0;border-top:1px solid rgba(255,255,255,.1)}
.footer__info{padding-bottom:clamp(24px,3vw,40px);border-bottom:1px solid rgba(255,255,255,.1)}
.footer__info p{font-size:clamp(12px,.85vw,14px);line-height:1.8;font-weight:400}
.footer__disclaimer{color:rgba(255,255,255,.35);font-size:clamp(11px,.75vw,12px)}
.footer__web-inquiry{font-size:clamp(14px,1.2vw,18px);font-weight:700;color:rgba(255,255,255,.55);margin-bottom:16px}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding:clamp(16px,2vw,24px) 0;font-size:clamp(11px,.75vw,12px);color:rgba(255,255,255,.3)}

/* ═══ Floating CTA Group ═══ */
.floating-cta-group{position:fixed;bottom:32px;right:32px;z-index:100;display:flex;flex-direction:column;gap:10px;opacity:0;pointer-events:none;transition:opacity .3s}
.floating-cta-group.visible{opacity:1;pointer-events:auto}
.floating-cta{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;padding:12px 20px;border-radius:50px;transition:transform .3s var(--ease),box-shadow .3s var(--ease);color:var(--white);text-decoration:none}
.floating-cta:hover{transform:translateY(-3px)}
.floating-cta svg{flex-shrink:0}
.floating-cta--reg{background:#4a8c3f;box-shadow:0 0 20px rgba(74,140,63,.4),0 0 60px rgba(74,140,63,.2);animation:ctaGlow 2s ease-in-out infinite alternate}
.floating-cta--reg:hover{box-shadow:0 0 30px rgba(74,140,63,.6),0 0 80px rgba(74,140,63,.3)}
.floating-cta--tel{background:var(--dark);border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 16px rgba(0,0,0,.3)}
.floating-cta--tel svg{color:var(--white)}
.floating-cta--tel:hover{box-shadow:0 8px 28px rgba(0,0,0,.4)}
.floating-cta--kakao{background:#FEE500;color:#3B1E1E;box-shadow:0 4px 16px rgba(254,229,0,.3)}
.floating-cta--kakao:hover{box-shadow:0 8px 28px rgba(254,229,0,.4)}
@keyframes ctaGlow{0%{box-shadow:0 0 20px rgba(74,140,63,.4),0 0 60px rgba(74,140,63,.15)}100%{box-shadow:0 0 30px rgba(74,140,63,.6),0 0 80px rgba(74,140,63,.3)}}

/* ═══ PREMIUM LIVING BANNER ═══ */
.plbanner{position:relative;z-index:1;background:var(--white);padding:clamp(30px,4vw,50px) var(--pad);overflow:hidden}
.plbanner__inner{display:flex;align-items:flex-end;justify-content:space-between}
.plbanner__text{font-size:clamp(48px,10vw,140px);font-weight:900;line-height:.88;letter-spacing:-.03em;text-transform:uppercase;color:var(--dark)}
.plbanner__right{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.plbanner__arrow{color:var(--dark)}
.plbanner__cta{display:inline-flex;align-items:center;gap:8px;font-size:clamp(14px,1.1vw,18px);font-weight:700;color:var(--white);background:#4a8c3f;border-radius:50px;padding:14px 28px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.plbanner__cta:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(74,140,63,.3)}

/* ═══ Lightbox ═══ */
.lightbox{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .3s ease}
.lightbox.open{pointer-events:auto;opacity:1}
.lightbox__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(6px)}
.lightbox__wrap{position:relative;z-index:1;max-width:92vw;max-height:90vh}
.lightbox__img{max-width:100%;max-height:90vh;display:block;border-radius:8px;transform:scale(.9);transition:transform .3s cubic-bezier(.22,1,.36,1)}
.lightbox.open .lightbox__img{transform:scale(1)}
.lightbox__close{position:absolute;top:-16px;right:-16px;width:40px;height:40px;background:rgba(255,255,255,.15);border:none;border-radius:50%;color:#fff;font-size:24px;line-height:40px;text-align:center;cursor:pointer}

/* ═══ Site Plan ═══ */
.siteplan{background:var(--white);padding:clamp(72px,10vw,140px) clamp(20px,5vw,80px)}
.siteplan__inner{max-width:1200px;margin:0 auto}
.siteplan__head{text-align:center;margin-bottom:clamp(36px,5vw,64px)}
.siteplan__label{display:flex;align-items:center;justify-content:center;gap:14px;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#4a8c3f;margin-bottom:16px}
.siteplan__label-line{display:block;width:36px;height:1px;background:#4a8c3f}
.siteplan__title{font-size:clamp(32px,5vw,64px);font-weight:900;letter-spacing:-.03em;color:var(--dark);margin-bottom:12px;line-height:1.05}
.siteplan__sub{font-size:clamp(14px,1.1vw,18px);color:var(--gray);font-weight:400}
.siteplan__img-wrap{position:relative;border-radius:20px;overflow:hidden;border:1px solid rgba(0,0,0,.07);box-shadow:0 24px 80px rgba(0,0,0,.1);margin-bottom:clamp(28px,4vw,52px)}
.siteplan__img{width:100%;height:auto;display:block}
.siteplan__img-badge{position:absolute;bottom:16px;right:16px;font-size:11px;font-weight:500;color:rgba(255,255,255,.8);background:rgba(0,0,0,.45);backdrop-filter:blur(8px);padding:5px 12px;border-radius:50px;letter-spacing:.04em}
.siteplan__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.5vw,20px)}
.siteplan__card{background:#f8f8f8;border-radius:16px;padding:clamp(20px,2.5vw,32px);border:1px solid rgba(0,0,0,.06);transition:box-shadow .3s,transform .3s}
.siteplan__card:hover{box-shadow:0 10px 32px rgba(0,0,0,.08);transform:translateY(-3px)}
.siteplan__card-dot{width:18px;height:18px;border-radius:4px;margin-bottom:14px}
.siteplan__card-type{display:block;font-size:clamp(15px,1.3vw,19px);font-weight:800;color:var(--dark);letter-spacing:-.01em;margin-bottom:4px}
.siteplan__card-pyeong{font-size:clamp(11px,.85vw,13px);color:var(--gray);font-weight:400;margin-bottom:12px}
.siteplan__card-num{font-size:clamp(32px,3.5vw,48px);font-weight:900;color:var(--dark);letter-spacing:-.03em;line-height:1}
.siteplan__card-num span{font-size:clamp(13px,1vw,16px);font-weight:500;color:var(--gray);margin-left:4px}
.siteplan__img-wrap{cursor:zoom-in}
.siteplan__img-badge{display:flex;align-items:center;gap:6px}
/* Siteplan zoom modal */
.sp-zoom-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .3s ease}
.sp-zoom-modal.open{pointer-events:auto;opacity:1}
.sp-zoom-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.92)}
.sp-zoom-close{position:fixed;top:16px;right:16px;z-index:2;width:42px;height:42px;background:rgba(255,255,255,.15);border:none;border-radius:50%;color:#fff;font-size:26px;line-height:42px;text-align:center;cursor:pointer;backdrop-filter:blur(8px)}
.sp-zoom-wrap{position:relative;z-index:1;width:100vw;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;touch-action:none}
.sp-zoom-img{max-width:100%;max-height:100%;object-fit:contain;transform-origin:center center;user-select:none;-webkit-user-drag:none}
.sp-zoom-hint{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:2;font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.04em;pointer-events:none}

/* ═══ Responsive ═══ */
@media(max-width:768px){
  :root{--pad:20px}
  .hero__title{font-size:60px}
  .hero__brand-logo{height:40px}
  .hero__catchcopy{font-size:14px;margin-bottom:8px}
  .hero__title-wrap{margin:auto var(--pad) 80px}
  .intro__stats{flex-wrap:wrap;gap:16px}
  .intro__stat{width:calc(33.33% - 12px)}
  .about{grid-template-columns:1fr;min-height:auto}
  .about__img{order:2;height:auto}
  .about__img img{width:100%;height:auto;object-fit:contain}
  .about__content{order:1}
  .about__cards{grid-template-columns:1fr 1fr;gap:8px}
  .reel{grid-template-columns:1fr}
  .services{grid-template-columns:1fr}
  .services__list li{font-size:clamp(20px,7vw,32px)}
  .services__list li.services__head{font-size:clamp(18px,5.5vw,28px)}
  .services__gallery{grid-template-columns:1fr;gap:40px}
  /* SFP 모바일 */
  .sfp-inner{padding:40px 20px}
  .sfp-head{margin-bottom:20px}
  .sfp-label{font-size:11px;margin-bottom:10px;gap:10px}
  .sfp-label-line{width:28px}
  .sfp-head h2{font-size:clamp(24px,6vw,34px)}
  .sfp-sub{font-size:13px}
  .sfp-tabs{display:none!important}
  .sfp-body{display:grid!important;grid-template-columns:1fr 1fr;gap:12px}
  .sfp-panel{display:block!important;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px;cursor:pointer}
  .sfp-panel.active{display:block!important}
  .sfp-img{border-radius:6px;margin-bottom:10px}
  .sfp-info h3{font-size:14px;margin-bottom:6px;white-space:normal}
  .sfp-info h3 .pyeong{font-size:11px}
  .sfp-desc{display:none}
  .sfp-specs{margin-bottom:0}
  .sfp-spec{display:none;padding:6px 0}
  .sfp-spec:last-child{display:flex;border:none}
  .sfp-spec span{font-size:10px;min-width:50px}
  .sfp-spec b{font-size:12px}
  .sfp-spec em{font-size:13px}
  .sfp-features{display:none}
  .sfp-cta{display:none}
  .sfp-cta-wrap{display:none}
  .sfp-tap-hint{display:inline-block;font-size:15px;font-weight:600;color:#ff3b3b;background:rgba(255,59,59,.15);border:1.5px solid rgba(255,59,59,.45);border-radius:24px;padding:6px 18px;margin-left:10px;vertical-align:middle;animation:sfpHintPulse 1.8s ease-in-out infinite}
  .siteplan{padding:52px 20px}
  .siteplan__cards{grid-template-columns:repeat(3,1fr);gap:8px}
  .siteplan__card{padding:12px;border-radius:10px}
  .siteplan__card-dot{width:14px;height:14px;margin-bottom:10px}
  .siteplan__card-pyeong{display:none}
  .siteplan__img-wrap{border-radius:12px}
  @keyframes sfpHintPulse{0%,100%{opacity:1}50%{opacity:.5}}

  /* SFP 모달 */
  .sfp-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:flex-end;justify-content:center;pointer-events:none;opacity:0;transition:opacity .3s ease}
  .sfp-modal.open{pointer-events:auto;opacity:1}
  .sfp-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px)}
  .sfp-modal-sheet{position:relative;z-index:1;width:100%;max-height:90vh;background:#1a1a1a;border-radius:20px 20px 0 0;padding:20px 20px 32px;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translateY(100%);transition:transform .35s cubic-bezier(.22,1,.36,1)}
  .sfp-modal.open .sfp-modal-sheet{transform:translateY(0)}
  .sfp-modal-close{position:sticky;top:0;float:right;z-index:2;width:36px;height:36px;background:rgba(255,255,255,.1);border:none;border-radius:50%;color:#fff;font-size:22px;line-height:36px;text-align:center;cursor:pointer}
  .sfp-modal-content .sfp-panel{background:none!important;border:none!important;padding:0!important;cursor:default!important}
  .sfp-modal-content .sfp-img{margin-bottom:16px}
  .sfp-modal-content .sfp-info h3{font-size:clamp(22px,5vw,30px)!important;margin-bottom:10px!important}
  .sfp-modal-content .sfp-info h3 .pyeong{font-size:14px!important}
  .sfp-modal-content .sfp-desc{display:block!important;font-size:13px;margin-bottom:18px;line-height:1.8;color:rgba(255,255,255,.7)}
  .sfp-modal-content .sfp-specs{display:block!important;margin-bottom:18px}
  .sfp-modal-content .sfp-spec{display:flex!important;padding:10px 0;font-size:13px;border-bottom:1px solid rgba(255,255,255,.08)}
  .sfp-modal-content .sfp-spec:last-child{border-bottom:none}
  .sfp-modal-content .sfp-spec span{font-size:12px!important;min-width:70px}
  .sfp-modal-content .sfp-spec b{font-size:13px!important}
  .sfp-modal-content .sfp-features{display:flex!important;flex-wrap:wrap;gap:8px;margin-bottom:20px;align-items:center}
  .sfp-modal-content .sfp-cta-wrap{display:flex!important;gap:8px}
  .sfp-modal-content .sfp-cta{display:flex!important;padding:15px;font-size:14px;text-align:center}
  .updates__cards{grid-template-columns:1fr 1fr}
  .promo__cards{flex-direction:column}
  .promo-card{min-width:unset}
  .promo__checklist{max-width:100%}
  .floating-cta-group{bottom:20px;right:14px;gap:12px;align-items:flex-end}
  .floating-cta{font-size:0;padding:0;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.35)}
  .floating-cta span{display:none}
  .floating-cta svg{width:22px;height:22px}
  .floating-cta--reg{width:56px;height:56px;box-shadow:0 0 20px rgba(74,140,63,.5),0 4px 20px rgba(0,0,0,.3)}
  .floating-cta--reg svg{width:24px;height:24px}
  .floating-cta--kakao{box-shadow:0 4px 20px rgba(254,229,0,.4)}
  .floating-cta--tel{box-shadow:0 4px 20px rgba(0,0,0,.5)}
  .hd-tel span{display:none}
  .hero-tel{font-size:18px;margin-top:10px}
  .register__contacts{flex-direction:column}
  .register__contact-card:first-child{border-right:none;padding-right:0}
  .register__contact-card:last-child{padding-left:0}
  .form-row{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;gap:8px;text-align:center}
}
