/* =========================================================
   PBS COLOR LAB — Renew
   퍼스널컬러 4계절 컬러 시스템 / 흰 여백 + 강렬한 컬러 포인트
   ========================================================= */
:root{
	--ink:#1a1a1a;
	--ink-2:#3a3a3a;
	--muted:#6b6b6b;
	--bg:#ffffff;
	--bg-soft:#fafafa;
	--line:#ececec;
	/* 4계절 */
	--spring:#FF6B5C; --spring-2:#FFB59E;
	--summer:#7B83EB; --summer-2:#A7C7E7;
	--autumn:#C75B39; --autumn-2:#D9A441;
	--winter:#2E3A8C; --winter-2:#8E2D4D;
	--wrap:1180px;
	--r:18px;
	--ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
	margin:0;
	font-family:'Pretendard','Pretendard Variable',-apple-system,'Apple SD Gothic Neo','Noto Sans KR',sans-serif;
	color:var(--ink);
	background:var(--bg);
	line-height:1.6;
	-webkit-font-smoothing:antialiased;
	letter-spacing:-.01em;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 24px;}
.center{text-align:center;}

/* ---------- 버튼 ---------- */
.btn{
	display:inline-flex;align-items:center;gap:.5em;
	padding:15px 30px;border-radius:999px;font-weight:700;font-size:1rem;
	transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;
	border:2px solid transparent;cursor:pointer;
}
.btn:hover{transform:translateY(-3px);}
.btn-dark{background:var(--ink);color:#fff;box-shadow:0 10px 26px rgba(0,0,0,.18);}
.btn-line{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-line:hover{background:var(--ink);color:#fff;}
.btn-light{background:#fff;color:var(--ink);box-shadow:0 10px 26px rgba(0,0,0,.16);}

/* ---------- 헤더 ---------- */
.site-header{
	position:sticky;top:0;z-index:100;
	background:rgba(255,255,255,.82);
	backdrop-filter:saturate(180%) blur(14px);
	border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;width:100%;padding:0 clamp(20px,3.5vw,52px);}
.brand{display:flex;align-items:center;font-size:1.12rem;letter-spacing:.04em;font-weight:600;}
.brand-text strong{font-weight:800;}
.site-nav{display:flex;align-items:center;gap:30px;font-weight:600;font-size:.97rem;}
.site-nav a{color:var(--ink-2);position:relative;transition:color .2s;}
.site-nav a:hover{color:var(--ink);}
.site-nav a:not(.nav-cta)::after{
	content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--ink);transition:width .25s var(--ease);
}
.site-nav a:not(.nav-cta):hover::after{width:100%;}
.site-nav a.nav-cta{background:var(--ink);color:#fff;padding:9px 20px;border-radius:999px;}
.site-nav a.nav-cta:hover{color:#fff;opacity:.88;}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:.3s;}

/* ---------- HERO : 풀스크린 컬러 그라데이션 (vinno형) ---------- */
.hero{
	position:relative;min-height:100vh;min-height:100svh;
	display:flex;color:#fff;overflow:hidden;isolation:isolate;
	background-color:#EEA98E;
	background:
		radial-gradient(80% 90% at 0% 100%, #C25CE0 0%, rgba(194,92,224,0) 60%),
		radial-gradient(70% 78% at 3% 2%, #FFCF3A 0%, rgba(255,207,58,0) 50%),
		radial-gradient(95% 100% at 100% 52%, #F4B58A 0%, rgba(244,181,138,0) 64%),
		linear-gradient(125deg, #F49E7E 0%, #EA9FA6 52%, #ECB98D 100%);
}

.hero-inner{position:relative;z-index:2;width:100%;max-width:none;margin:0;
	display:flex;flex-direction:column;justify-content:space-between;
	padding:152px 92px 64px clamp(20px,3.5vw,52px);}

.hero-copy{max-width:1000px;}
.hero-statement{margin:0;color:#fff;
	opacity:0;transform:translateY(26px);animation:heroUp 1s var(--ease) .15s forwards;}
.hero-kicker{display:block;font-size:clamp(.95rem,1.7vw,1.2rem);font-weight:700;letter-spacing:.01em;
	margin-bottom:18px;color:rgba(255,255,255,.96);text-shadow:0 1px 14px rgba(120,40,90,.18);}
.hero-big{display:block;font-weight:800;line-height:1.1;letter-spacing:-.01em;
	font-size:clamp(1.85rem,4.4vw,3.4rem);text-transform:uppercase;
	text-shadow:0 2px 34px rgba(120,40,90,.16);}
.hero-kr{margin:28px 0 0;max-width:560px;font-size:clamp(1rem,1.7vw,1.18rem);font-weight:500;
	color:rgba(255,255,255,.94);line-height:1.7;
	opacity:0;transform:translateY(20px);animation:heroUp 1s var(--ease) .45s forwards;}

.hero-nav{display:flex;flex-direction:column;align-items:flex-end;gap:8px;text-align:right;
	font-size:clamp(1.1rem,2vw,1.55rem);font-weight:800;letter-spacing:-.01em;
	opacity:0;transform:translateY(20px);animation:heroUp 1s var(--ease) .7s forwards;}
.hero-nav a{color:#fff;padding:1px 0;transition:opacity .2s,transform .25s var(--ease);}
.hero-nav a:hover{transform:translateX(-6px);opacity:.82;}

/* 우측 세로 라벨 (vinno의 우측 사이드바 오마주) */
.hero-side{position:absolute;top:0;right:0;bottom:0;width:46px;z-index:2;
	display:flex;align-items:center;justify-content:center;
	background:rgba(255,255,255,.12);border-left:1px solid rgba(255,255,255,.25);backdrop-filter:blur(2px);}
.hero-side-text{writing-mode:vertical-rl;font-size:.74rem;font-weight:700;letter-spacing:.22em;color:#fff;text-transform:uppercase;}

@keyframes heroUp{to{opacity:1;transform:none;}}

/* 홈: 헤더를 히어로 위 투명 오버레이로 */
/* 히어로 위: 배경 완전 투명 (블러·테두리 없음) */
.home .site-header{position:fixed;left:0;right:0;background:transparent;border-color:transparent;
	backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:none;transition:background .3s,box-shadow .3s,backdrop-filter .3s;}
.home .site-header .brand,.home .site-header .brand-text strong,.home .site-header .site-nav a{color:#fff;}
.home .site-header .site-nav a:not(.nav-cta)::after{background:#fff;}
.home .site-header .nav-toggle span{background:#fff;}
/* 문의하기 버튼: 히어로 위에선 배경 없이 외곽선만 */
.home .site-header .nav-cta{background:transparent;border:1px solid rgba(255,255,255,.7);color:#fff;}
.home .site-header .nav-cta:hover{background:rgba(255,255,255,.16);color:#fff;opacity:1;}

/* 히어로를 지난 뒤: 솔리드 화이트 */
.home .site-header.scrolled{background:#fff;border-color:var(--line);box-shadow:0 6px 24px rgba(0,0,0,.06);}
.home .site-header.scrolled .brand,.home .site-header.scrolled .brand-text strong{color:var(--ink);}
.home .site-header.scrolled .site-nav a{color:var(--ink-2);}
.home .site-header.scrolled .site-nav a:not(.nav-cta)::after{background:var(--ink);}
.home .site-header.scrolled .site-nav a.nav-cta{background:var(--ink);border-color:transparent;color:#fff;}
.home .site-header.scrolled .site-nav a.nav-cta:hover{opacity:.88;}
.home .site-header.scrolled .nav-toggle span{background:var(--ink);}

@media (prefers-reduced-motion:reduce){
	.hero{animation:none;}
	.hero-statement,.hero-kr,.hero-nav{animation:none;opacity:1;transform:none;}
}
@media (max-width:760px){
	.hero-side{display:none;}
	.hero-inner{padding:120px 22px 48px;gap:40px;}
	.hero-nav{align-items:flex-start;text-align:left;}
	.home .site-header .site-nav a{color:var(--ink-2);}
	.home .site-header .site-nav a:not(.nav-cta)::after{display:none;}
}

/* ---------- 섹션 공통 ---------- */
.section{padding:110px 0;}
.section:nth-of-type(even){background:var(--bg-soft);}
.eyebrow{font-size:.82rem;font-weight:800;letter-spacing:.16em;color:var(--muted);margin-bottom:16px;}
.section-title{font-size:clamp(1.9rem,4vw,2.9rem);font-weight:800;line-height:1.18;margin:0 0 18px;letter-spacing:-.02em;}
.section-head{max-width:680px;margin:0 auto 64px;text-align:center;}
.section-lead{font-size:1.1rem;color:var(--muted);margin:0;}

/* ---------- ABOUT ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.about-body p{font-size:1.15rem;color:var(--ink-2);margin:0 0 30px;}
.stat-row{list-style:none;display:flex;gap:30px;padding:0;margin:0;flex-wrap:wrap;}
.stat-row li{display:flex;flex-direction:column;}
.stat-row strong{font-size:2.4rem;font-weight:800;line-height:1;
	background:linear-gradient(120deg,var(--spring),var(--summer));-webkit-background-clip:text;background-clip:text;color:transparent;}
.stat-row span{font-size:.9rem;color:var(--muted);margin-top:6px;}

/* ---------- MATERIALS ---------- */
.parts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;}
.part-card{
	position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);
	padding:38px 34px;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.part-card::before{content:"";position:absolute;inset:0 0 auto 0;height:6px;background:linear-gradient(90deg,var(--c),var(--s));}
.part-card:hover{transform:translateY(-6px);box-shadow:0 26px 50px rgba(0,0,0,.10);}
.part-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.part-no{font-size:2.2rem;font-weight:800;color:var(--c);line-height:1;letter-spacing:-.04em;}
.part-season{display:flex;flex-direction:column;align-items:flex-end;font-size:.78rem;font-weight:800;letter-spacing:.12em;color:var(--c);}
.part-season em{font-style:normal;font-weight:600;font-size:.78rem;color:var(--muted);letter-spacing:0;margin-top:3px;}
.part-name{font-size:1.45rem;font-weight:800;margin:0 0 12px;letter-spacing:-.02em;}
.part-desc{color:var(--muted);margin:0 0 18px;font-size:.98rem;}
.part-topics{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-wrap:wrap;gap:8px;}
.part-topics li{font-size:.83rem;font-weight:600;color:var(--ink-2);background:color-mix(in srgb,var(--s) 22%,#fff);
	padding:6px 12px;border-radius:999px;}
.part-downloads{display:grid;gap:10px;}
.dl-btn{
	display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:12px;
	border:1.5px solid var(--line);font-weight:700;transition:.25s var(--ease);background:#fff;
}
.dl-btn .dl-ico{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;
	background:var(--c);color:#fff;font-weight:800;flex:none;transition:transform .25s var(--ease);}
.dl-btn span:nth-child(2){flex:1;}
.dl-btn em{font-style:normal;font-size:.72rem;font-weight:800;letter-spacing:.08em;color:var(--muted);}
.dl-btn:hover{border-color:var(--c);background:color-mix(in srgb,var(--s) 14%,#fff);}
.dl-btn:hover .dl-ico{transform:translateY(2px);}
.materials-note{margin:38px auto 0;text-align:center;font-size:.86rem;color:var(--muted);max-width:760px;}
.materials-note code{background:#f0f0f0;padding:2px 7px;border-radius:6px;font-size:.82rem;}

/* ---------- VIDEOS ---------- */
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-bottom:50px;}
.video-card{transition:transform .3s var(--ease);}
.video-card:hover{transform:translateY(-5px);}
.video-frame{position:relative;padding-top:56.25%;border-radius:14px;overflow:hidden;
	background:#000;box-shadow:0 14px 34px rgba(0,0,0,.12);}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;}
.video-title{font-size:1rem;font-weight:700;margin:16px 2px 0;line-height:1.45;
	display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* ---------- COURSE ---------- */
.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.course-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);
	padding:36px 30px;display:flex;flex-direction:column;transition:transform .35s var(--ease),box-shadow .35s var(--ease);}
.course-card:hover{transform:translateY(-6px);box-shadow:0 26px 50px rgba(0,0,0,.10);}
.course-level{display:inline-block;align-self:flex-start;font-size:.74rem;font-weight:800;letter-spacing:.12em;
	color:#fff;background:var(--c);padding:7px 14px;border-radius:999px;margin-bottom:18px;}
.course-name{font-size:1.3rem;font-weight:800;margin:0 0 12px;letter-spacing:-.02em;}
.course-desc{color:var(--muted);font-size:.95rem;margin:0 0 22px;flex:1;}
.course-meta{margin:0 0 24px;display:grid;gap:10px;}
.course-meta div{display:flex;gap:14px;font-size:.92rem;}
.course-meta dt{flex:none;width:42px;font-weight:800;color:var(--ink);}
.course-meta dd{margin:0;color:var(--ink-2);}
.course-apply{font-weight:800;color:var(--c);transition:gap .2s;}
.course-apply:hover{opacity:.78;}

/* ---------- CTA BANNER ---------- */
.cta-banner{padding:96px 0;text-align:center;color:#fff;
	background:linear-gradient(120deg,var(--winter),var(--summer) 45%,var(--spring) 100%);}
.cta-banner h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;margin:0 0 14px;letter-spacing:-.02em;}
.cta-banner p{font-size:1.1rem;opacity:.92;margin:0 0 30px;}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--ink);color:#cfcfcf;padding:72px 0 30px;}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid #333;}
.footer-brand .brand-text{font-size:1.3rem;color:#fff;letter-spacing:.04em;}
.footer-brand p{margin:16px 0 0;font-size:.95rem;line-height:1.7;}
.footer-col h4{color:#fff;font-size:1rem;margin:0 0 14px;}
.footer-col p{font-size:.92rem;margin:0 0 18px;line-height:1.7;}
.footer-link{display:block;margin-bottom:10px;font-weight:600;color:#dadada;transition:color .2s;}
.footer-link:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:.85rem;color:#8a8a8a;flex-wrap:wrap;gap:10px;}
.to-top{font-weight:700;color:#cfcfcf;}
.to-top:hover{color:#fff;}

/* ---------- 스크롤 리빌 ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ---------- 반응형 ---------- */
@media (max-width:980px){
	.about-grid{grid-template-columns:1fr;gap:30px;}
	.video-grid,.course-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:760px){
	.section{padding:76px 0;}
	.hero{padding:80px 0 70px;}
	.site-nav{position:fixed;inset:72px 0 auto 0;flex-direction:column;background:#fff;
		gap:0;padding:10px 0;border-bottom:1px solid var(--line);transform:translateY(-130%);
		transition:transform .35s var(--ease);box-shadow:0 16px 30px rgba(0,0,0,.08);}
	.site-nav.open{transform:none;}
	.site-nav a{padding:14px 24px;width:100%;}
	.site-nav a:not(.nav-cta)::after{display:none;}
	.nav-cta{margin:8px 24px;text-align:center;}
	.nav-toggle{display:flex;}
	.parts-grid,.video-grid,.course-grid{grid-template-columns:1fr;}
	.footer-grid{grid-template-columns:1fr;gap:30px;}
	.stat-row{gap:22px;}
}

/* =========================================================
   확장 섹션 (소개·진단·경력·프로그램·실적·글로벌·후기)
   ========================================================= */
/* ABOUT */
.title-list{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:9px;}
.title-list li{position:relative;padding-left:18px;color:var(--ink-2);font-weight:600;font-size:.98rem;}
.title-list li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;border-radius:50%;
	background:linear-gradient(135deg,var(--spring),var(--summer));}
.hl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:64px;}
.hl-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;
	transition:transform .35s var(--ease),box-shadow .35s var(--ease);}
.hl-card:hover{transform:translateY(-5px);box-shadow:0 22px 44px rgba(0,0,0,.08);}
.hl-dot{display:block;width:30px;height:30px;border-radius:50%;margin-bottom:16px;
	background:linear-gradient(135deg,var(--c),#fff);box-shadow:0 0 0 4px color-mix(in srgb,var(--c) 16%,#fff);}
.hl-card h3{margin:0 0 8px;font-size:1.1rem;font-weight:800;color:var(--c);}
.hl-card p{margin:0;color:var(--ink-2);font-size:.94rem;line-height:1.6;}

/* METHOD */
.method-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.method-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;
	border-top:5px solid var(--c);transition:transform .35s var(--ease),box-shadow .35s var(--ease);}
.method-card:hover{transform:translateY(-6px);box-shadow:0 24px 46px rgba(0,0,0,.09);}
.method-tag{font-size:.74rem;font-weight:800;letter-spacing:.1em;color:var(--c);margin-bottom:14px;}
.method-card h3{margin:0 0 10px;font-size:1.18rem;font-weight:800;}
.method-card p{margin:0;color:var(--muted);font-size:.93rem;line-height:1.65;}

/* CAREER */
.career-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:56px;align-items:start;}
.timeline{list-style:none;padding:0;margin:20px 0 0;}
.timeline li{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:16px 0;border-bottom:1px solid var(--line);}
.tl-year{font-weight:800;color:var(--ink);font-size:.92rem;}
.tl-body{display:flex;flex-direction:column;}
.tl-body strong{font-weight:700;}
.tl-body em{font-style:normal;color:var(--muted);font-size:.9rem;margin-top:3px;}
.award-list{list-style:none;padding:0;margin:20px 0 0;display:grid;gap:12px;}
.award-list li{position:relative;padding:14px 18px 14px 42px;background:#fff;border:1px solid var(--line);border-radius:12px;
	font-weight:600;color:var(--ink-2);font-size:.95rem;}
.award-list li::before{content:"🏆";position:absolute;left:15px;top:50%;transform:translateY(-50%);}

/* PROGRAMS */
.program-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.program-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 22px;
	transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;}
.program-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px rgba(0,0,0,.08);border-color:var(--c);}
.program-cat{display:inline-block;font-size:.72rem;font-weight:800;color:#fff;background:var(--c);
	padding:5px 11px;border-radius:999px;margin-bottom:14px;}
.program-card h3{margin:0 0 8px;font-size:1.05rem;font-weight:800;line-height:1.35;}
.program-card p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.55;}

/* REFERENCES + GLOBAL */
.client-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;}
.client-chip{font-weight:700;color:var(--ink-2);background:#fff;border:1px solid var(--line);
	padding:12px 20px;border-radius:999px;font-size:.95rem;transition:.25s var(--ease);}
.client-chip:hover{transform:translateY(-3px);border-color:var(--ink);color:var(--ink);box-shadow:0 10px 22px rgba(0,0,0,.06);}
.global-wrap{margin-top:56px;border-radius:24px;color:#fff;padding:48px clamp(28px,4vw,56px);
	background:linear-gradient(120deg,var(--winter),var(--summer) 50%,var(--spring));
	display:grid;grid-template-columns:1.1fr 1fr;gap:44px;align-items:center;}
.global-head h3{font-size:clamp(1.3rem,2.4vw,1.9rem);font-weight:800;margin:6px 0 14px;letter-spacing:-.01em;}
.global-head p{margin:0;font-size:1rem;line-height:1.7;color:rgba(255,255,255,.92);}
.global-list{list-style:none;padding:0;margin:0;display:grid;gap:14px;}
.global-list li{display:grid;grid-template-columns:104px 1fr;gap:14px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.25);}
.g-year{font-weight:800;font-size:.9rem;}
.g-body{display:flex;flex-direction:column;}
.g-body strong{font-weight:700;}
.g-body em{font-style:normal;font-size:.88rem;color:rgba(255,255,255,.82);margin-top:3px;}

/* REVIEWS */
.grad-num{background:linear-gradient(120deg,var(--spring),var(--summer));-webkit-background-clip:text;background-clip:text;color:transparent;}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.review-card{margin:0;background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 24px;
	font-size:1.02rem;font-weight:600;color:var(--ink-2);line-height:1.6;border-left:4px solid var(--c);}

/* CTA + FOOTER 확장 */
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7);}
.btn-ghost:hover{background:rgba(255,255,255,.16);transform:translateY(-3px);}
.footer-contact{display:block;color:#fff;font-weight:700;font-size:1.05rem;margin-bottom:10px;}
.footer-contact:hover{opacity:.85;}
.footer-note{font-size:.88rem;color:#9a9a9a;margin:14px 0 0;line-height:1.6;}

/* 반응형 (신규 섹션) */
@media (max-width:980px){
	.hl-grid,.method-grid,.program-grid{grid-template-columns:repeat(2,1fr);}
	.career-grid,.global-wrap{grid-template-columns:1fr;gap:32px;}
	.review-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:600px){
	.hl-grid,.method-grid,.program-grid,.review-grid{grid-template-columns:1fr;}
	.timeline li,.global-list li{grid-template-columns:84px 1fr;gap:12px;}
}

/* =========================================================
   멀티페이지 (서브페이지 배너 / 게이트웨이 / 폼 등)
   ========================================================= */
.page-banner{position:relative;overflow:hidden;color:#fff;padding:130px 0 60px;isolation:isolate;}
.page-banner .pb-bg{position:absolute;inset:0;z-index:-1;
	background:radial-gradient(70% 90% at 6% 6%,#FFD23F 0%,rgba(255,210,63,0) 42%),
		radial-gradient(80% 95% at 0% 100%,#C25CE0 0%,rgba(194,92,224,0) 52%),
		radial-gradient(95% 100% at 100% 60%,#F3B488 0%,rgba(243,180,136,0) 60%),
		linear-gradient(120deg,#F4A07F,#EA9FA6 50%,#ECB98D);}
.pb-en{color:rgba(255,255,255,.85)!important;}
.page-banner-title{font-size:clamp(2rem,5vw,3.4rem);font-weight:800;letter-spacing:-.02em;margin:0 0 12px;
	text-shadow:0 2px 24px rgba(120,40,90,.18);}
.page-banner-lead{font-size:clamp(1rem,1.8vw,1.2rem);color:rgba(255,255,255,.94);margin:0 0 20px;max-width:640px;}
.crumb{font-size:.85rem;font-weight:600;color:rgba(255,255,255,.85);}
.crumb a{color:#fff;} .crumb span{margin:0 8px;opacity:.7;}

/* 게이트웨이 카드 (홈) */
.gate-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.gate-card{display:block;position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);
	padding:34px 30px;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease);}
.gate-card::before{content:"";position:absolute;inset:0 0 auto 0;height:6px;background:linear-gradient(90deg,var(--c),color-mix(in srgb,var(--c) 40%,#fff));}
.gate-card:hover{transform:translateY(-6px);box-shadow:0 26px 50px rgba(0,0,0,.10);}
.gate-en{font-size:.74rem;font-weight:800;letter-spacing:.12em;color:var(--c);}
.gate-title{font-size:1.4rem;font-weight:800;margin:10px 0 10px;letter-spacing:-.02em;}
.gate-desc{color:var(--muted);font-size:.95rem;line-height:1.6;margin:0 0 20px;}
.gate-go{font-weight:800;color:var(--c);}

/* STEP / INFO */
.step-grid,.info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.step-card,.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 24px;border-top:5px solid var(--c);}
.step-no{display:inline-block;font-size:1.8rem;font-weight:800;color:var(--c);line-height:1;margin-bottom:12px;}
.step-card h3,.info-card h3{margin:0 0 8px;font-size:1.12rem;font-weight:800;}
.step-card p,.info-card p{margin:0;color:var(--muted);font-size:.92rem;line-height:1.6;}
.info-card h3{color:var(--c);}

/* FAQ */
.faq-list{display:grid;gap:12px;}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:4px 22px;}
.faq-item summary{cursor:pointer;font-weight:700;font-size:1.05rem;padding:18px 0;list-style:none;position:relative;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";position:absolute;right:0;top:16px;font-size:1.4rem;color:var(--muted);transition:transform .2s;}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-item p{margin:0 0 18px;color:var(--ink-2);line-height:1.7;}

/* REFERENCE 포맷 */
.ref-format{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:44px;}
.fmt-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 22px;border-left:4px solid var(--c);}
.fmt-card h3{margin:0 0 6px;font-size:1.05rem;font-weight:800;color:var(--c);}
.fmt-card p{margin:0;color:var(--muted);font-size:.9rem;}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:54px;align-items:start;}
.contact-list{list-style:none;padding:0;margin:22px 0 28px;display:grid;gap:16px;}
.contact-list li{display:flex;align-items:center;gap:14px;font-size:1.08rem;font-weight:600;color:var(--ink-2);}
.c-ico{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--bg-soft);flex:none;font-size:1.1rem;}
.channel-row{display:flex;gap:10px;flex-wrap:wrap;}
.contact-form{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px;display:grid;gap:16px;
	box-shadow:0 20px 44px rgba(0,0,0,.05);}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.contact-form label{display:flex;flex-direction:column;gap:7px;font-weight:700;font-size:.9rem;color:var(--ink-2);}
.contact-form input,.contact-form select,.contact-form textarea{font:inherit;padding:12px 14px;border:1.5px solid var(--line);
	border-radius:10px;background:#fff;color:var(--ink);font-weight:500;}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--summer);}
.cf-note{font-size:.84rem;color:var(--muted);margin:0;font-weight:500;}

@media (max-width:980px){
	.gate-grid{grid-template-columns:repeat(2,1fr);}
	.step-grid,.info-grid,.ref-format{grid-template-columns:repeat(2,1fr);}
	.contact-grid{grid-template-columns:1fr;gap:32px;}
}
@media (max-width:600px){
	.gate-grid,.step-grid,.info-grid,.ref-format{grid-template-columns:1fr;}
	.cf-row{grid-template-columns:1fr;}
}

/* 소개 페이지 프로필 (사진 + 소개) */
.profile-grid{display:grid;grid-template-columns:0.82fr 1.18fr;gap:56px;align-items:start;}
.profile-photo{position:relative;margin:0;}
.profile-photo::before{content:"";position:absolute;right:-16px;bottom:-16px;width:100%;height:100%;
	border-radius:22px;z-index:0;background:linear-gradient(135deg,var(--spring),var(--summer));}
.profile-photo img{position:relative;z-index:1;width:100%;height:auto;display:block;border-radius:20px;
	box-shadow:0 24px 52px rgba(0,0,0,.18);}
.profile-photo figcaption{position:relative;z-index:1;margin-top:18px;text-align:center;color:var(--muted);font-size:.95rem;}
.profile-photo figcaption strong{color:var(--ink);font-weight:800;}
.profile-text .section-title{margin-top:6px;}
.profile-lead{font-size:1.08rem;color:var(--ink-2);margin:0 0 18px;line-height:1.78;}
.profile-text .title-list{margin-top:26px;}
.profile-text .stat-row{margin-top:30px;}
@media (max-width:860px){
	.profile-grid{grid-template-columns:1fr;gap:34px;}
	.profile-photo{max-width:420px;}
	.profile-photo::before{right:-10px;bottom:-10px;}
}
