@charset "utf-8";

:root{
  --bg:#ffffff;
  --bg-soft:#f3f7fd;
  --sky:#e7f1fc;
  --ink:#15233d;
  --ink-soft:#586079;
  --muted:#5d6b82;
  --navy:#12244c;
  --blue:#1a5fd0;
  --blue-deep:#103a86;
  --blue-bright:#2f7bf0;
  --line:#e3eaf4;
  --line-blue:#cdddf3;
  --green:#3f7d4e;
  --maxw:1340px;
  --nav-h:68px;
}

/* ---------- 공통 ---------- */
.serif-en{font-family:"Merriweather",serif}
.eyebrow{letter-spacing:.34em;text-transform:uppercase;font-size:.82rem;color:var(--blue);font-weight:600;display:inline-block;}
h2.title{font-family:'SunmoonUniversity',serif;font-weight:500;font-size:clamp(1.9rem,4.6vw,3.6rem);line-height:1.28;letter-spacing:-.03em;color:var(--navy);margin:.55rem 0 1.3rem;}
h2.title em{color:var(--blue)}
.lead{color:var(--muted);font-size:clamp(.8rem,2.2vw,1.1rem);max-width:56ch}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}
section{position:relative;padding:clamp(72px,10vw,128px) 0}
.bg-soft{background:var(--bg-soft)}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.divider-ring{display:flex;justify-content:center;margin-bottom:30px}
.divider-ring img {width:64px;height:auto}
/* 반응형 */
@media(max-width:560px){
	.eyebrow{font-size:.6rem;}
}

/* ---------- progress ---------- */
#progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--blue),var(--blue-bright));z-index:200}

/* ---------- top nav ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:150;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(18px,5vw,40px);background:#fff;border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s;}
header.nav.scrolled{border-bottom-color:var(--line);box-shadow:0 4px 24px -16px rgba(16,40,90,.35)}
.logo-wrap{margin:0;padding:0;line-height:1;flex-shrink:0;}
.brandmark{display:block;width:clamp(160px, 18vw, 190px);aspect-ratio:380/60;background-image:url('../img/logo.png');background-repeat:no-repeat;background-position:center;background-size:contain;text-indent:-9999px;overflow:hidden;white-space:nowrap;flex-shrink:0;}
.menu{display:flex;align-items:center;gap:clamp(14px,2.4vw,30px)}
.menu a.mlink{position:relative;font-size:0.96rem;color:#3c4a63;font-weight:600;padding:6px 2px;transition:color .2s;white-space:nowrap}
.menu a.mlink::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--blue);transition:right .28s ease}
.menu a.mlink:hover{color:var(--blue)}
.menu a.mlink.active{color:var(--blue)}
.menu a.mlink.active::after{right:0}
.nav-cta{background:var(--blue);color:#fff;font-size:.88rem;font-weight:500;padding:10px 22px;border-radius:40px;letter-spacing:.01em;transition:background .25s,transform .2s;white-space:nowrap}
.nav-cta:hover{background:var(--blue-deep);transform:translateY(-1px)}
.hamb{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamb span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.3s}
.mobile-menu{display:none}
/* 반응형 */
@media(max-width:880px){
  .menu .mlink{display:none}
  .hamb{display:flex}
  .mobile-menu{display:block;position:fixed;top:var(--nav-h);left:0;right:0;z-index:149;background:#fff;border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .35s ease;box-shadow:0 12px 30px -18px rgba(16,40,90,.4);}
  .mobile-menu.open{max-height:520px;overflow-y:auto}
  .mobile-menu a{display:block;padding:14px clamp(20px,5vw,40px);color:#33415c;font-weight:500;border-top:1px solid var(--line)}
  .mobile-menu a:first-child{border-top:none}
  .mobile-menu a.active{color:var(--blue)}
}

/* ---------- 01 · HERO ---------- */
.hero{min-height:100vh;min-height:100svh;display:flex;align-items:center;padding-top:calc(var(--nav-h) + 140px);background:rgba(0,0,0,0.2);overflow:hidden;}
.hero-bg {position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg .slide1{background-image:url('../img/bg1.jpg');}
.hero-bg .slide2{background-image:url('../img/bg2.jpg');}
.hero-bg .hslide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;filter:blur(16px);transform:scale(1.08);transition:opacity 1.8s ease-in-out, filter 1.8s ease-in-out, transform 6.5s ease-out;will-change:opacity,filter,transform;}
.hero-bg .hslide.active{opacity:1;filter:blur(0);transform:scale(1)}
.hero-mask{position:absolute;inset:0;z-index:1;pointer-events:none;background:rgba(0,0,0,0.46);}
.hero-grid{display:block;max-width:900px;margin:0 auto;text-align:center;position:relative;z-index:2}
.hero .eyebrow {color:#bcd4f6}
.hero .h-title {font-family:'SunmoonUniversity',serif;font-weight:500;color:#fff;font-size:clamp(2rem,7vw,5.2rem);line-height:1.18;letter-spacing:-.025em;margin:18px 0 22px;text-shadow:0 2px 8px rgba(0,0,0,.2);}
.hero .sub {margin-left:auto;margin-right:auto;color:rgba(255,255,255,0.7);font-size:clamp(0.8rem,2vw,1.05rem);max-width:54ch;margin-bottom:80px}
.hero-stats{justify-content:center;display:flex;gap:clamp(20px,4vw,48px);flex-wrap:wrap;margin-bottom:38px}
.hero-stats .st .num{color:#fff;font-family: 'Pliant', sans-serif;font-size:clamp(2.1rem,5vw,3rem);font-weight:600;line-height:1;font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
.hero-stats .st .num span{color:#bcd4f6;font-size:.6em;font-weight:400;}
.hero-stats .st .num .cnt{color:#fff;font-family:'Pliant',sans-serif;font-weight:600;font-size:1em}
.hero-stats .st .lab{color:rgba(255,255,255,0.7);font-size:.8rem;letter-spacing:-0.02em;margin-top:7px}
.hero-cta{justify-content:center;display:flex;gap:14px;flex-wrap:wrap}
.btn-blue{background:var(--blue);color:#fff;font-weight:500;padding:15px 34px;border-radius:46px;font-size:1.1rem;letter-spacing:.01em;transition:transform .2s,background .25s,box-shadow .25s;border:none;cursor:pointer;box-shadow:0 14px 30px -12px rgba(26,95,208,.5)}
.btn-blue:hover{background:var(--blue-deep);transform:translateY(-2px)}
.btn-ghost{border:1px solid rgba(255,255,255,.55);color:#fff;font-weight:500;padding:14px 30px;border-radius:46px;font-size:1.1rem;transition:transform .2s,background .25s,box-shadow .25s;cursor:pointer;}
.btn-ghost:hover{color:#333;;background:#fff;transform:translateY(-2px)}
/* 반응형 */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr}
  /* 모바일 히어로: 화면 높이 100% 유지 + 상단여백 모바일에 맞게 축소 */
  .hero{min-height:100svh;padding-top:calc(var(--nav-h) + 48px);padding-bottom:48px}
  .hero .sub{margin-bottom:44px}
  .hero-mask{background:linear-gradient(180deg, rgba(7,13,26,.66) 0%, rgba(7,13,26,.46) 45%, rgba(7,13,26,.56) 75%, rgba(7,13,26,.76) 100%)}
}
@media(max-width:560px){
  .hero{padding-top:calc(var(--nav-h) + 28px);padding-bottom:40px}
  .hero .sub{margin-bottom:36px}
  .hero-stats{gap:22px}
  /* 히어로 버튼 한 줄 나란히 */
  .hero-cta{flex-wrap:nowrap;gap:10px}
  .hero-cta .btn-blue,.hero-cta .btn-ghost{flex:1 1 0;min-width:0;padding:13px 14px;font-size:.95rem;white-space:nowrap;text-align:center}
}

/* ---------- 02 · BRAND & HISTORY ---------- */
#brand{background:linear-gradient(180deg,rgba(255,255,255,.95) 0%,rgba(255,255,255,.84) 40%,rgba(255,255,255,.52) 74%,rgba(255,255,255,.3) 100%),url('../img/bg_h.jpg') center bottom / cover no-repeat #eef4fc;}
.tl{position:relative;margin-top:80px;max-width:760px;margin-left:auto;margin-right:auto}
.tl-row{display:grid;grid-template-columns:92px 1fr;gap:22px;padding:0 0 28px 28px;position:relative}
.tl-row::before{content:"";position:absolute;left:-7px;top:8px;width:11px;height:11px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 4px var(--sky);z-index:2}
.tl-row::after{content:"";position:absolute;left:-2px;top:8px;width:2px;bottom:-14px;background:var(--line-blue);z-index:1}
.tl-row:last-child::after{display:none}
.tl-row .yr{font-family:"Merriweather",serif;font-size:1.6rem;color:var(--blue);font-weight:600;line-height:1.3;}
.tl-row .ev{color:var(--muted);font-size:1.1rem}
.tl-row .ev b{color:var(--navy);font-weight:500}
.tl-row.now::before{background:var(--blue-bright);box-shadow:0 0 0 5px #d7e7fc}
.tl-row.now .ev b{color:var(--blue);font-weight:600;}
/* 반응형 */
@media(max-width:920px){
  #brand{background:linear-gradient(180deg,rgba(255,255,255,.97) 0%,rgba(255,255,255,.9) 46%,rgba(255,255,255,.66) 78%,rgba(255,255,255,.46) 100%),url('../img/bg_h.jpg') center bottom / 100% auto no-repeat #eef4fc;}
}
@media(max-width:560px){
   #brand{background:linear-gradient(180deg,rgba(255,255,255,.97) 0%,rgba(255,255,255,.9) 46%,rgba(255,255,255,.66) 78%,rgba(255,255,255,.46) 100%),url('../img/bg_h.jpg') center bottom / 100% auto no-repeat #fff;}
  .tl-row{grid-template-columns:58px 1fr;gap:14px;padding-left:20px}
  .tl{padding-left:12px;padding-right:12px}/* 히스토리(타임라인) 좌·우 여백 */
  .tl-row .yr{font-size:1.4rem;}
  .tl-row .ev{font-size:1rem}
}

/* ---------- 03 · GLOBAL COURSE ---------- */
#global .chip-row{justify-content:center;margin-top:24px}
#global .chip{color:var(--navy);border-color:var(--line-blue);background:#fff}
.chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.chip{font-size:.96rem;color:#eaf2ff;border:1px solid rgba(255,255,255,.3);border-radius:40px;padding:7px 16px;background:rgba(255,255,255,.07)}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px}
.gtile{position:relative;aspect-ratio:3/4;border-radius:16px;overflow:hidden;box-shadow:0 18px 40px -26px rgba(16,40,90,.5);transition:transform .35s;display:flex;align-items:flex-end;}
.gtile:hover{transform:translateY(-6px)}
.gtile .scene{position:absolute;inset:0}
.gtile .cap{position:relative;z-index:2;padding:60px 18px 20px;color:#fff;width:100%;background:linear-gradient(to top,rgba(8,24,56,.88) 0%,rgba(8,24,56,.7) 30%,rgba(8,24,56,.34) 80%,transparent 100%);}
.gtile .cap .cc{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;font-family:"Merriweather",serif;}
.gtile .cap .cn{font-family:"Noto Serif KR",serif;font-weight:500;font-size:1.3rem;line-height:1.3;margin-top:3px}
.gtile .cap .ct{font-size:.86rem;color:#bcd4f6;margin-top:4px}
.gnote{text-align:center;margin-top:50px;color:#9aa7bd;}
.gtile .scene{position:absolute;inset:0;background-size:cover;background-position:center;background-color:#cfe0f2}
/* 반응형 */
@media(max-width:920px){
  .gallery{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .gallery{grid-template-columns:1fr 1fr;gap:12px}
  .gtile .cap .cc{font-size:.6rem;}
  .gtile .cap .cn{font-size:1rem;}
  .gnote{font-size:0.8rem;}
}

/* ---------- 04 · INFRA ---------- */
.infra{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:18px}
.infra-charts{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:34px}
.chart-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 28px 18px;box-shadow:0 14px 36px -26px rgba(16,40,90,.4);transition:border-color .3s,transform .3s,box-shadow .3s}
.chart-card:hover{border-color:var(--line-blue);transform:translateY(-5px);box-shadow:0 24px 48px -26px rgba(16,40,90,.42)}
.chart-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.chart-pill{display:inline-block;background:var(--sky);color:var(--blue);font-weight:700;padding:7px 16px;border-radius:30px;letter-spacing:-.01em}
.chart-num{font-family:"Merriweather",serif;font-size:clamp(2rem,4.6vw,2.9rem);color:var(--navy);font-weight:600;line-height:1}
.chart-num span{color:var(--blue);font-size:.5em;font-weight:700;margin-left:2px}
.chart-sub{color:var(--muted);font-size:.99rem;margin:8px 0 0 8px;}
.chart-svg{width:100%;height:auto;display:block;margin-top:8px;overflow:visible}
.chart-svg text{}
/* 반응형 */
@media(max-width:1024px){
  .infra-charts{grid-template-columns:1fr}
}
@media(max-width:920px){
  .infra{grid-template-columns:1fr}
}
@media(max-width:560px){
	.chart-pill{font-size:0.86rem;font-weight:600;}
}

/* ---------- 05 · BUSINESS ---------- */
#business .grid{margin-top:clamp(28px,5vw,50px)}
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.fcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 28px;transition:border-color .3s,transform .3s,box-shadow .3s;box-shadow:0 10px 30px -22px rgba(16,40,90,.4);}
.fcard:hover{border-color:var(--line-blue);transform:translateY(-5px);box-shadow:0 22px 44px -24px rgba(16,40,90,.42)}
.fcard .ic{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--sky);color:var(--blue);margin-bottom:18px}
.fcard .ic svg{width:40px;height:40px}
.fcard h3{font-family:'SunmoonUniversity',serif;font-weight:500;color:var(--navy);font-size:1.5rem;margin-bottom:9px;letter-spacing:-.03em}
.fcard h3 .acc{color:var(--blue)}
.fcard p{color:var(--muted);font-size:.98rem}
/* 반응형 */
@media(max-width:920px){
  .g3{grid-template-columns:1fr}
}
@media(max-width:560px){
  .g2{grid-template-columns:1fr}
  .fcard{padding:20px 28px;}
  .fcard .ic{width:40px;height:40px;margin-bottom:10px}
.fcard .ic svg{width:30px;height:30px}
.fcard h3{font-size:1.2rem;margin-bottom:3px;}
.fcard p{font-size:.9rem}

}

/* ---------- 06 · AJGA EXCLUSIVE PARTNERSHIP ---------- */
.ajga{position:relative;overflow:hidden;color:#eafaf0;background:radial-gradient(120% 75% at 50% -12%, rgba(214,176,108,.16), transparent 58%),radial-gradient(80% 60% at 88% 18%, rgba(47,123,80,.20), transparent 70%),linear-gradient(165deg,#0f2a20 0%, #0d2730 52%, #0b1f30 100%);}
.ajga::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;background:radial-gradient(60% 50% at 12% 88%, rgba(26,95,208,.14), transparent 70%);}
.ajga .wrap{position:relative;z-index:2}
.ajga-eyebrow{display:inline-block;letter-spacing:.32em;text-transform:uppercase;font-size:.8rem;color:#e0bd7c;font-weight:600}
.ajga .title{color:#fff;margin-top:.7rem}
.ajga .title em{color:#ecc985;font-style:normal}
.ajga .lead{color:#bfe6cf;margin-left:auto;margin-right:auto}
.ajga-seal-row{display:flex;align-items:center;justify-content:center;gap:16px;margin:22px auto 8px;max-width:660px}
.ajga-seal{flex-shrink:0;width:74px;height:74px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:"Merriweather",serif;font-weight:700;letter-spacing:.06em;font-size:1.05rem;color:#173a2b;background:radial-gradient(circle at 38% 30%,#f6e4ad,#cda24f 62%,#a9802f);box-shadow:0 0 0 4px rgba(236,201,133,.18), 0 14px 30px -14px rgba(0,0,0,.7);}
.ajga-seal-tx{text-align:left;line-height:1.4}
.ajga-seal-tx b{display:block;color:#fff;font-weight:600;font-size:clamp(1rem,2.4vw,1.18rem);}
.ajga-seal-tx span{display:block;color:#9cc7b0;font-size:.78rem;letter-spacing:.04em;margin-top:3px;font-family:"Merriweather",serif}
.ajga-body{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(34px,5vw,64px);align-items:center;margin-top:54px}
.ajga-card-wrap{display:flex;flex-direction:column;align-items:center;gap:22px}
.ajga-card{position:relative;width:min(420px,90%);aspect-ratio:1.58/1;border-radius:20px;background:linear-gradient(150deg,#1d4a37 0%, #163a2c 55%, #102a20 100%);box-shadow:0 44px 80px -34px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.06);padding:clamp(20px,3.4vw,30px);display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;transition:transform .5s cubic-bezier(.2,.7,.2,1);}
.ajga-card:hover{transform:translateY(-6px) rotate(-.6deg)}
.ac-frame{position:absolute;inset:12px;border-radius:13px;border:1px solid rgba(214,176,108,.55);box-shadow:inset 0 0 0 1px rgba(214,176,108,.22);pointer-events:none}
.ac-shine{position:absolute;top:-60%;left:-30%;width:60%;height:220%;transform:rotate(20deg);pointer-events:none;background:linear-gradient(90deg,transparent,rgba(255,255,255,.10),transparent);}
.ac-top{position:relative;z-index:2;display:flex;align-items:center;gap:14px}
.ac-ajga{font-family:"Merriweather",serif;font-weight:700;font-size:clamp(1.4rem,3.6vw,1.9rem);letter-spacing:.04em;color:#f3e3b6;text-shadow:0 1px 0 rgba(0,0,0,.3)}
.ac-div{width:1px;height:30px;background:rgba(214,176,108,.6)}
.ac-plk{display:flex;flex-direction:column;line-height:1;font-family:"Pliant",sans-serif;font-weight:700;font-size:clamp(1.3rem,3.2vw,1.7rem);color:#fff;letter-spacing:.02em}
.ac-plk small{font-weight:400;font-size:.42em;letter-spacing:.12em;color:#bcd9c8;margin-top:5px}
.ac-seal{position:absolute;z-index:2;right:clamp(20px,3.4vw,30px);top:50%;transform:translateY(-50%);width:62px;height:62px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at 38% 30%,#f6e4ad,#cda24f 62%,#a9802f);color:#173a2b;box-shadow:0 8px 18px -8px rgba(0,0,0,.7), inset 0 0 0 2px rgba(255,255,255,.25)}
.ac-seal b{font-family:"Merriweather",serif;font-size:1.05rem;font-weight:700;line-height:1}
.ac-seal i{font-style:normal;font-size:.46rem;letter-spacing:.14em;margin-top:2px}
.ac-bottom{position:relative;z-index:2}
.ac-title{font-family:"Merriweather",serif;font-weight:700;letter-spacing:.12em;font-size:clamp(.9rem,2.2vw,1.18rem);color:#f3e3b6;line-height:1.25}
.ac-sub{font-size:.68rem;letter-spacing:.34em;color:#9cc7b0;margin-top:6px;font-family:"Merriweather",serif}
.ajga-chips{justify-content:center}
.ajga-chip{color:#eafaf0;border-color:rgba(214,176,108,.45);background:rgba(214,176,108,.10)}
.ajga-points{display:flex;flex-direction:column;gap:20px}
.ajga-intro{color:#cfe9da;font-size:clamp(.97rem,2.1vw,1.08rem);margin-bottom:6px}
.ajga-intro b{color:#fff;font-weight:600}
.ajga-pt{display:flex;gap:16px;align-items:flex-start;padding:18px 20px;border-radius:14px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);transition:border-color .3s,background .3s,transform .3s}
.ajga-pt:hover{border-color:rgba(214,176,108,.5);background:rgba(214,176,108,.07);transform:translateX(4px)}
.ajga-ck{flex-shrink:0;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 38% 30%,#f6e4ad,#cda24f 65%,#a9802f);color:#173a2b}
.ajga-ck svg{width:16px}
.ajga-pt-tx b{display:block;color:#f3e3b6;font-family:"Merriweather",serif;font-weight:700;letter-spacing:.06em;font-size:1.06rem;margin-bottom:5px}
.ajga-pt-tx p{color:#cfe9da;font-size:.95rem;line-height:1.6}
.ajga-pt-tx p em{color:#fff;font-style:normal;font-weight:600}
.ajga-quote{position:relative;text-align:center;margin:clamp(44px,6vw,68px) auto 0;max-width:760px;font-weight:500;color:#fff;letter-spacing:-.01em;line-height:1.5;font-size:clamp(1.15rem,3vw,1.7rem);padding-top:22px;border-top:1px solid rgba(214,176,108,.3)}
.ajga-quote b{color:#ecc985;font-weight:700}
.ajga-quote .q-mark{color:rgba(214,176,108,.7);font-family:"Merriweather",serif;font-size:1.1em;line-height:0}
/* 반응형 */
@media(max-width:920px){
  /* AJGA 파트너십: 모바일 1단 배치 */
  .ajga-body{grid-template-columns:1fr;gap:38px}
  .ajga-seal-row{flex-direction:column;text-align:center;gap:12px}
  .ajga-seal-tx{text-align:center}
}
@media(max-width:560px){
  .ajga-pt{padding:15px 16px}
}

/* ---------- 07 · DIGITAL PLATFORM ---------- */
.app-bg{overflow:hidden;background-image:linear-gradient(180deg,#fff 0%,rgba(255,255,255,.92) 57%,rgba(255,255,255,.5) 72%,rgba(255,255,255,0) 80%),url('../img/bg_app.jpg');background-repeat:no-repeat;background-position:center bottom;background-size:100% 100%,100% auto;padding-bottom:clamp(180px,28vw,440px);}
#app .wrap{position:relative;z-index:2}
#app .checks{width:fit-content;max-width:100%;margin-inline:auto;text-align:left} /* 체크리스트를 가운데로 묶음 */
/* 반응형 */
@media(max-width:920px){
  .app-bg{padding-bottom:210px;}
}
@media(max-width:560px){
  .app-bg{background-size:130% 130%,130% auto;}

}

/* ---------- 08 · MEMBERSHIP ---------- */
.cat-label{font-family:"Noto Serif KR",serif;font-weight:500;font-size:1.3rem;color:var(--navy);margin:42px 0 18px;display:flex;align-items:center;gap:14px}
.cat-label::after{content:"";flex:1;height:1px;background:var(--line-blue)}
.cat-label .tag{font-family:"Merriweather",serif;font-size:.74rem;letter-spacing:.16em;color:var(--blue);border:1px solid var(--line-blue);border-radius:30px;padding:4px 13px;text-transform:uppercase;background:#fff}
.prod-grid{display:grid;gap:20px}
.prod{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 26px;box-shadow:0 14px 36px -26px rgba(16,40,90,.4);position:relative;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s,border-color .3s;}
.prod:hover{transform:translateY(-5px);box-shadow:0 26px 52px -26px rgba(16,40,90,.45);border-color:var(--line-blue)}
.prod.feature{background:linear-gradient(165deg,#15428f,#0e2a63);border:none;color:#eaf2ff}
.prod.feature .p-name{color:#fff}
.prod.feature .p-comp{color:#bcd4f6}
.prod.feature .p-tier{color:#9fc2f3}
.prod.feature .p-fee{border-color:rgba(255,255,255,.18)}
.prod.feature .p-fee .k{color:#9fc2f3}
.prod.feature .p-fee .v{color:#fff}
.prod.feature .p-fee .v small{color:#bcd4f6}
.prod.feature .p-row{border-color:rgba(255,255,255,.14)}
.prod.feature .p-row .k{color:#a9c2e6}
.prod.feature .p-row .v{color:#eaf2ff}
.prod.feature .p-note{color:#9fc2f3}
.prod .p-tier{font-family:"Merriweather",serif;letter-spacing:.15em;font-size:.74rem;color:var(--blue);text-transform:uppercase}
.prod .p-name{font-family:'SunmoonUniversity',serif;font-weight:400 !important;font-size:2rem;color:var(--navy);margin:6px 0 4px;letter-spacing:-.01em}
.prod .p-comp{font-size:.86rem;color:var(--muted);letter-spacing:.02em}
.prod .p-fee{margin:18px 0 6px;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.prod .p-fee .k{font-size:.86rem;letter-spacing:.06em;color:var(--blue);padding-bottom:5px;}
.prod .p-fee .v{font-family:"Merriweather",serif;font-size:2.05rem;font-weight:600;color:var(--navy);line-height:1.1}
.prod .p-fee .v small{font-family:"Noto Sans KR";font-size:.8rem;color:var(--muted);font-weight:400;letter-spacing:.04em}
.prod .p-rows{margin-top:6px;flex:1}
.p-row{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px dashed var(--line);font-size:.96rem}
.p-row:last-child{border-bottom:none}
.p-row .k{color:var(--muted);flex-shrink:0}
.p-row .v{color:var(--ink);text-align:right}
.prod .p-note{margin-top:14px;font-size:.72rem;color:#9aa7bd;line-height:1.5}
.ribbon{position:absolute;top:18px;right:-1px;background:#fff;color:var(--blue);font-size:.86rem;letter-spacing:.04em;font-weight:600;padding:5px 14px;border-radius:30px 0 0 30px;box-shadow:0 4px 14px -6px rgba(0,0,0,.3)}
/* 반응형 */
@media(max-width:560px){
  .prod-grid.g3,.prod-grid.g2{grid-template-columns:1fr}
  .cat-label{font-size:1.1rem;line-height:1.3;}
  .cat-label .tag{font-size:.6rem;padding:4px 10px;}
  .ribbon{font-size:.7rem;letter-spacing:0;font-weight:500;padding:5px 7px 5px 10px;}
  .prod .p-name{font-size:1.5rem;}
  .prod .p-fee .v{font-size:1.7rem;font-weight:600;}
  .p-row{font-size:.9rem}
  .prod .p-tier{letter-spacing:0;font-size:.7rem;}
}

/* ---------- 09 · MANAGER ---------- */
.person-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:52px;align-items:center}
.person-photo{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 40px 80px -34px rgba(16,40,90,.5);}
.person-photo img{width:100%}
.person-photo .frame{position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(26,95,208,.18);border-radius:18px;pointer-events:none}
.person-info .role{color:var(--blue);letter-spacing:.16em;text-transform:uppercase;font-weight:500;margin-top:20px;}
.person-info .nm{font-size:2rem;color:var(--navy);font-weight:500;margin:0 0 2px}
.person-info .tel{font-family: 'Pliant', sans-serif;font-size:1.6rem;color:var(--blue);letter-spacing:.04em;margin:0 0 22px;font-weight:600}
.person-info p{color:var(--muted);font-size:.97rem;max-width:48ch}
.checks{display:flex;flex-direction:column;gap:13px;margin-top:45px}
.checks li{list-style:none;display:flex;gap:12px;align-items:flex-start;color:var(--ink);font-size:1.1rem;font-weight:500;}
.checks li .ck{width:24px;height:24px;border-radius:50%;background:var(--sky);color:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:3px;}
.checks li .ck svg{width:14px}
/* 반응형 */
@media(max-width:920px){
  .person-grid{grid-template-columns:1fr}
  .person-photo{max-width:380px;margin:0 auto}
}
@media(max-width:560px){
.checks li{font-size:1rem;}
.person-info .role{font-size:0.8rem;}
.person-info .nm{font-size:1.5rem;}
.person-info .tel{font-size:1.5rem;}
.person-info p{font-size:.9rem;}
}

/* ---------- 10 · APPLY ---------- */
.bg-form{background:linear-gradient(160deg,#15428f 0%, #0e2a63 100%);color:#eaf2ff}
.bg-form .eyebrow{color:#9fc2f3}
.bg-form h2.title{color:#fff}
.bg-form h2.title em{color:#bcd4f6}
.bg-form .lead{color:#cdddf3}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.form-intro .micro{display:flex;gap:28px;flex-wrap:wrap;margin-top:28px}
.form-intro .micro div .n{font-family: 'Pliant', sans-serif;font-size:2rem;color:#fff;font-weight:600;line-height:1;letter-spacing:0;}
.form-intro .micro div .n span{color:#bcd4f6;font-size:.98em;font-weight:400 !important;padding-left:3px;}
.form-intro .micro div .l{font-size:.86rem;color:#bcd4f6;letter-spacing:.05em;margin-top:5px}
.form-box{background:#fff;border-radius:20px;padding:clamp(28px,4vw,44px);box-shadow:0 50px 90px -40px rgba(8,20,50,.7);color:var(--ink)}
.form-box .fb-h{font-weight:600;font-size:1.5rem;color:var(--navy);margin-bottom:6px}
.form-box .fb-s{font-size:.96rem;color:var(--muted);margin-bottom:22px}
.form-box .fl{display:block;font-size:1rem;font-weight:500;color:var(--navy);margin:0 0 8px}
.form-box input[type=text],.form-box input[type=tel]{width:100%;background:#f7faff;border:1.5px solid var(--line);border-radius:11px;padding:15px 16px;color:var(--ink);font-family:inherit;font-size:1rem;margin-bottom:20px;transition:border-color .25s,background .25s}
.form-box input:focus{outline:none;border-color:var(--blue);background:#fff}
.form-box input::placeholder{color:#aab6c9;font-size:0.98rem;}
.form-box .agree{display:flex;gap:10px;align-items:flex-start;margin-bottom:30px;font-size:.86rem;color:var(--muted);line-height:1.5}
.form-box .agree input{width:20px;height:20px;accent-color:#0f3b8f;flex-shrink:0;margin-top:2px;}
.form-box .submit{width:100%;background:var(--blue);color:#fff;border:none;border-radius:46px;padding:17px;font-size:1.3rem;font-weight:600;cursor:pointer;transition:background .25s,transform .2s;font-family:inherit;box-shadow:0 16px 32px -14px rgba(26,95,208,.6)}
.form-box .submit:hover{background:var(--blue-deep);transform:translateY(-2px)}
.form-box .submit:disabled{background:var(--green);cursor:default;transform:none}
.form-msg{margin-top:16px;font-size:.9rem;min-height:1.2em;text-align:center;color:var(--green)}
/* 반응형 */
@media(max-width:920px){
  .form-grid{grid-template-columns:1fr}
}

/* ---------- footer ---------- */
footer{background:#0c1f47;color:#c4d3ea;padding:62px 0 40px}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:start}
.foot-brand .foot-logo{filter:grayscale(1) brightness(0) invert(1);opacity:.55;width:clamp(150px,20vw,200px)}
.foot-brand .foot-logo:hover{opacity:.75}
.foot-info{font-size:.86rem;color:#a9bcd9;line-height:2;margin-top:18px}
.foot-info b{color:#fff;font-weight:500}
.foot-mgr{display:flex;gap:16px;align-items:center;margin-top:22px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12)}
.foot-mgr img{width:66px;height:66px;border-radius:50%;object-fit:cover;border:2px solid rgba(159,194,243,.2)}
.foot-mgr .fm-t .r{font-size:.72rem;color:#9fc2f3;letter-spacing:.12em}
.foot-mgr .fm-t .n{color:#fff;font-size:1.04rem;font-weight:500}
.foot-mgr .fm-t .p{color:#c4d3ea;font-size:.88rem;letter-spacing:.04em}
.copyright{margin-top:42px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);font-size:.74rem;color:#7e93b5;letter-spacing:.02em;display:flex;justify-content:space-between;align-items:center;gap:20px;}
.madeby{white-space:nowrap;}
/* 반응형 */
@media(max-width:920px){
  .foot-grid{grid-template-columns:1fr}
}
@media(max-width:560px){
  .copyright{flex-direction:column;align-items:flex-start;gap:8px}   /* 카피라이트/제작사 각각 한 줄 */
}

/* ---------- back to top ---------- */
#toTop{
  position:fixed;right:clamp(16px,4vw,30px);bottom:clamp(16px,4vw,30px);z-index:140;
  width:52px;height:52px;border-radius:50%;border:none;cursor:pointer;
  background:var(--blue);color:#fff;box-shadow:0 16px 30px -10px rgba(16,40,90,.6);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transform:translateY(14px);transition:opacity .3s,transform .3s,visibility .3s,background .25s;
}
#toTop.show{opacity:1;visibility:visible;transform:none}
#toTop:hover{background:var(--blue-deep)}
#toTop svg{width:22px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .85s cubic-bezier(.2,.7,.2,1),transform .85s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
.slide-l{opacity:0;transform:translateX(-36px);transition:opacity .95s ease,transform .95s ease}
.slide-l.in{opacity:1;transform:none}
.slide-r{opacity:0;transform:translateX(36px);transition:opacity .95s ease,transform .95s ease}
.slide-r.in{opacity:1;transform:none}
/* 반응형 (모션 줄이기 선호) */
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal,.slide-l,.slide-r{transition:none!important;opacity:1!important;transform:none!important}
  .hero-bg .hslide{transition:none!important;filter:none!important;transform:none!important}
}


/* ---------- 개인정보 동의 [보기] + 레이어 모달 ---------- */
.agree-view{background:none;border:0;padding:0 2px;color:var(--blue);font-weight:600;text-decoration:underline;cursor:pointer;font-size:inherit;font-family:inherit}
.agree-view:hover{color:var(--blue-deep)}
.modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-dim{position:absolute;inset:0;background:rgba(0,0,0,.5)}
.modal-box{position:relative;z-index:2;width:min(560px,100%);max-height:82vh;display:flex;flex-direction:column;background:#fff;border-radius:18px;box-shadow:0 40px 90px -30px rgba(8,20,50,.6);overflow:hidden;animation:modalpop .28s cubic-bezier(.2,.7,.2,1)}
@keyframes modalpop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 24px;border-bottom:1px solid var(--line)}
.modal-head h3{font-family:"Noto Serif KR",serif;font-weight:600;color:var(--navy);font-size:1.18rem;letter-spacing:-0.1rem;}
.modal-x{background:none;border:0;font-size:1.7rem;line-height:1;color:var(--muted);cursor:pointer;padding:0 4px}
.modal-x:hover{color:var(--navy)}
.modal-body{padding:22px 24px;overflow-y:auto;color:var(--ink-soft);font-size:.92rem;line-height:1.7}
.modal-body p{margin-bottom:12px}
.modal-body strong{color:var(--navy)}
.modal-table{width:100%;border-collapse:collapse;margin:6px 0 16px;font-size:.88rem}
.modal-table th,.modal-table td{border:1px solid var(--line);padding:9px 12px;text-align:left;vertical-align:top}
.modal-table th{background:var(--bg-soft);color:var(--navy);font-weight:600;white-space:nowrap}
.modal-foot{padding:16px 24px;border-top:1px solid var(--line);text-align:right}
.modal-ok{background:var(--blue);color:#fff;border:0;border-radius:10px;padding:11px 26px;font-weight:600;cursor:pointer;font-size:.95rem}
.modal-ok:hover{background:var(--blue-deep)}