/* ===== Tokens ===== */
:root{
  --primary: #145CE6;
  --primary-2: #3D7DFF;
  --primary-deep: #0E47B8;
  --primary-soft: #E8EFFE;
  --grad: linear-gradient(135deg, #145CE6 0%, #3D7DFF 100%);
  --grad-soft: linear-gradient(135deg, #EEF3FE 0%, #E8EFFE 100%);
  --ink: #0B1530;
  --ink-2: #1E293B;
  --body: #475569;
  --muted: #64748B;
  --line: #E5E7EB;
  --line-2: #EEF2F6;
  --bg: #FFFFFF;
  --bg-tint: #F6F8FC;
  --bg-deep: #0A1330;
  --warn: #F59E0B;
  --violet: #6366F1;
  --shadow-sm: 0 1px 2px rgba(15,23,42,.06), 0 2px 8px rgba(15,23,42,.04);
  --shadow-md: 0 4px 12px rgba(15,23,42,.06), 0 18px 36px -12px rgba(15,23,42,.10);
  --shadow-lg: 0 12px 32px rgba(15,23,42,.10), 0 40px 80px -20px rgba(15,23,42,.18);
  --radius: 14px;
  --radius-lg: 22px;
  --radius-pill: 999px;
  --container: 1200px;
  --t: cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
[hidden]{display:none !important}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, system-ui, 'Apple SD Gothic Neo', 'Noto Sans KR', sans-serif;
  color: var(--ink-2);
  background: var(--bg);
  font-size: 16px;
  line-height: 1.65;
  letter-spacing: -0.01em;
  -webkit-font-smoothing: antialiased;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:0; background:none; color:inherit}
ul{list-style:none; padding:0; margin:0}
p{margin:0}

.container{max-width:var(--container); margin:0 auto; padding:0 24px}

.skip{position:absolute; left:-9999px; top:0}
.skip:focus{left:8px; top:8px; background:#000; color:#fff; padding:8px 12px; border-radius:6px; z-index:1000}

.hide-sm{display:inline}
@media (max-width:640px){ .hide-sm{display:none} }

/* ===== Buttons ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 20px; border-radius:var(--radius-pill);
  font-weight:600; font-size:14.5px; letter-spacing:-0.01em;
  transition: transform .2s var(--t), box-shadow .2s var(--t), background .2s var(--t), color .2s var(--t), border-color .2s var(--t);
  white-space:nowrap;
}
.btn-primary{background:var(--grad); color:#fff; box-shadow: 0 8px 18px -6px rgba(61,125,255,.55)}
.btn-primary:hover{transform: translateY(-1px); box-shadow: 0 12px 24px -8px rgba(61,125,255,.7)}
.btn-outline{background:#fff; color:var(--ink); border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--primary); color:var(--primary-deep)}
.btn-ghost{background: rgba(15,23,42,.04); color:var(--ink); padding:10px 16px}
.btn-ghost:hover{background: rgba(15,23,42,.08)}
.btn-lg{padding:15px 26px; font-size:15.5px}
.btn.block{display:flex; width:100%}

/* ===== Header ===== */
.site-header{
  position:sticky; top:0; left:0; right:0; z-index:50;
  background: rgba(255,255,255,.85);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .2s var(--t), background .2s var(--t);
}
.site-header.is-scrolled{border-bottom-color: var(--line); background: rgba(255,255,255,.95)}
.header-inner{display:flex; align-items:center; gap:24px; height:72px}
.brand{display:flex; align-items:center; gap:11px; flex-shrink:0}
.brand-logo{width:auto; height:36px; display:block; flex-shrink:0}
.brand-text{white-space:nowrap}
.brand-text strong{display:block; font-size:17px; font-weight:800; letter-spacing:-0.02em; color:var(--ink); line-height:1.2}
.brand-text em{display:block; font-style:normal; font-size:10.5px; letter-spacing:.18em; color: var(--primary); font-weight:700; line-height:1.2; margin-top:2px}
.foot-logo{display:block; height:32px; width:auto; margin-bottom:10px}
@media (max-width: 480px){
  .brand-logo{height:30px}
  .brand-text strong{font-size:15px}
  .brand-text em{font-size:9.5px; letter-spacing:.14em}
}

.nav{margin-left:auto}
.nav ul{display:flex; gap:6px}
.nav a{
  display:inline-block; padding:10px 14px; border-radius:10px;
  font-size:14.5px; font-weight:500; color:var(--ink-2);
  transition: background .15s var(--t), color .15s var(--t);
}
.nav a:hover{background: rgba(20,92,230,.08); color:var(--primary-deep)}

.header-cta{display:flex; gap:8px; align-items:center}

.nav-toggle{
  display:none; width:40px; height:40px; border-radius:10px;
  background: rgba(15,23,42,.04);
  flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.nav-toggle span{display:block; width:18px; height:2px; background:var(--ink); border-radius:2px; transition: transform .2s var(--t), opacity .2s var(--t)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform: translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform: translateY(-7px) rotate(-45deg)}

.mobile-nav{
  display:none; flex-direction:column; gap:4px;
  padding:12px 24px 20px; border-top: 1px solid var(--line);
  background:#fff;
}
.mobile-nav a{padding:14px 12px; border-radius:10px; font-weight:500}
.mobile-nav a:hover{background: rgba(20,92,230,.08)}

@media (max-width: 1024px){
  .nav{display:none}
  .header-cta .btn-ghost{display:none}
  .nav-toggle{display:flex}
  .mobile-nav.is-open{display:flex}
}

/* ===== Hero ===== */
.hero{ position:relative; overflow:hidden; padding: 64px 0 96px}
.hero-bg{
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(900px 500px at 85% 0%, rgba(61,125,255,.18), transparent 60%),
    radial-gradient(700px 500px at 0% 50%, rgba(20,92,230,.16), transparent 60%),
    linear-gradient(180deg, #F7FCFD 0%, #FFFFFF 100%);
}
.hero-bg::before{
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(15,23,42,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,23,42,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(900px 600px at 70% 30%, #000 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(900px 600px at 70% 30%, #000 0%, transparent 80%);
  opacity: .8;
}
.hero-inner{
  display:grid; grid-template-columns: 1.15fr 1fr; gap: 56px;
  align-items:center;
}
.eyebrow{
  display:inline-block; padding:6px 14px; border-radius:var(--radius-pill);
  background: rgba(20,92,230,.12); color:var(--primary-deep);
  font-size:13px; font-weight:600; letter-spacing:-0.01em;
  margin-bottom:18px;
}
.hero h1{
  font-size: clamp(34px, 4.6vw, 56px); line-height:1.18; letter-spacing:-0.035em;
  font-weight:800; color:var(--ink); margin: 0 0 22px;
}
.grad{
  background: var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.lead{font-size: clamp(15px, 1.2vw, 18px); color: var(--body); margin-bottom: 32px}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap; margin-bottom: 36px}
.hero-badges{display:flex; flex-wrap:wrap; gap:8px}
.hero-badges li{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-pill);
  padding:8px 14px; font-size:13px; color:var(--ink-2); box-shadow: var(--shadow-sm);
}
.hero-badges strong{color:var(--primary-deep); margin-right:4px}

.hero-card{
  background:#fff; border-radius: var(--radius-lg); padding: 28px;
  box-shadow: var(--shadow-lg); border:1px solid var(--line-2);
  position:relative;
}
.hero-card::before{
  content:''; position:absolute; inset:0; border-radius: var(--radius-lg);
  padding:1.5px; background: var(--grad); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity:.18; pointer-events:none;
}
.hero-card-inner{display:grid; grid-template-columns: 1fr 1fr; gap: 18px}
.hero-stat{padding:18px; border-radius: 14px; background: var(--grad-soft)}
.hero-stat-num{font-size: 28px; font-weight:800; letter-spacing:-0.03em; color: var(--ink); display:flex; align-items:baseline; flex-wrap:wrap; line-height:1.15}
.hero-stat-num small{font-size:13px; font-weight:700; color:var(--primary); margin-left:5px}
.hero-stat-label{font-size: 13px; color: var(--muted); margin-top: 4px}
.hero-card-foot{
  display:flex; align-items:center; gap:8px;
  margin-top: 22px; padding-top: 18px; border-top:1px dashed var(--line);
  font-size: 13.5px; color: var(--muted);
}
.dot{display:inline-block; width:8px; height:8px; border-radius:50%; background: #22C55E; box-shadow:0 0 0 3px rgba(34,197,94,.18)}

@media (max-width: 900px){
  .hero{padding: 40px 0 64px}
  .hero-inner{grid-template-columns: 1fr; gap: 36px}
}
@media (max-width: 480px){
  .hero-card-inner{grid-template-columns: 1fr 1fr}
  .hero-stat-num{font-size: 30px}
}

/* ===== Trust strip ===== */
.strip{ background:#0B1220; color:#fff }
.strip-inner{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  padding: 22px 24px;
}
.strip-inner > div{
  display:flex; flex-direction:column; gap:4px;
  padding: 4px 18px; border-right:1px solid rgba(255,255,255,.08);
}
.strip-inner > div:last-child{border-right:none}
.strip-inner b{font-size:11.5px; letter-spacing:.18em; color: var(--primary); font-weight:700}
.strip-inner span{font-size:14.5px; color:#E2E8F0; font-weight:500}
@media (max-width: 720px){
  .strip-inner{grid-template-columns: 1fr 1fr}
  .strip-inner > div{padding: 10px 14px; border-right:none; border-bottom:1px solid rgba(255,255,255,.06)}
}

/* ===== Section base ===== */
.section{padding: 96px 0}
.section-tinted{background: var(--bg-tint)}
.sec-head{text-align:center; max-width: 780px; margin: 0 auto 56px}
.kicker{
  display:inline-block; padding:5px 12px; border-radius:var(--radius-pill);
  background:#fff; border:1px solid var(--line); color: var(--primary-deep);
  font-size:11.5px; font-weight:700; letter-spacing:.2em; margin-bottom: 14px;
}
.sec-head h2{
  font-size: clamp(26px, 3vw, 38px); line-height:1.25; letter-spacing:-0.03em;
  font-weight:800; color:var(--ink); margin: 0 0 14px;
}
.sec-head h2 em{font-style:normal; background: var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
.sec-sub{color: var(--body); font-size: 15.5px}
@media (max-width: 720px){ .section{padding: 64px 0} .sec-head{margin-bottom:40px} }

/* ===== Features grid ===== */
.grid-4{display:grid; grid-template-columns: repeat(4, 1fr); gap: 18px}
.grid-2{display:grid; grid-template-columns: 1fr 1fr; gap: 22px}
@media (max-width: 1024px){ .grid-4{grid-template-columns: 1fr 1fr} }
@media (max-width: 600px){ .grid-4{grid-template-columns: 1fr} .grid-2{grid-template-columns: 1fr} }

.feature{
  background:#fff; border:1px solid var(--line-2); border-radius: var(--radius-lg);
  padding: 28px; transition: transform .25s var(--t), box-shadow .25s var(--t), border-color .25s var(--t);
}
.feature:hover{transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--primary)}
.feature-ico{
  width: 48px; height: 48px; border-radius: 14px;
  display:inline-flex; align-items:center; justify-content:center;
  background: var(--grad-soft); color: var(--primary-deep);
  margin-bottom: 18px;
}
.feature-ico svg{width:24px; height:24px}
.feature h3{font-size:17.5px; margin: 0 0 8px; letter-spacing:-0.02em; color:var(--ink); font-weight:700}
.feature p{color: var(--body); font-size:14.5px; line-height:1.65}

/* ===== Courses ===== */
.course-grid{display:grid; grid-template-columns: repeat(3, 1fr); gap: 22px}
@media (max-width: 1024px){ .course-grid{grid-template-columns: 1fr} }

.course{
  position:relative; background:#fff; border:1px solid var(--line-2);
  border-radius: var(--radius-lg); padding: 32px;
  display:flex; flex-direction:column;
  transition: transform .25s var(--t), box-shadow .25s var(--t);
}
.course:hover{transform: translateY(-4px); box-shadow: var(--shadow-md)}
.course.featured{
  background: linear-gradient(180deg, #EEF3FE 0%, #FFFFFF 60%);
  border-color: rgba(20,92,230,.45);
  box-shadow: 0 12px 32px -16px rgba(20,92,230,.4);
}
.course-tag{
  position:absolute; top:18px; right:18px;
  background: var(--ink); color:#fff;
  padding: 5px 12px; border-radius: var(--radius-pill);
  font-size:11.5px; font-weight:700; letter-spacing:.04em;
}
.course-tag.tag-cyan, .course-tag.tag-blue{background: var(--primary)}
.course-tag.tag-violet{background: var(--violet)}
.course h3{font-size:21px; margin: 4px 0 10px; letter-spacing:-0.025em; color:var(--ink); font-weight:800}
.course-desc{font-size:14.5px; color:var(--body); margin-bottom: 22px; line-height:1.65}
.course-meta{display:grid; grid-template-columns: 1fr 1fr; gap:0; margin-bottom:24px; border-top:1px solid var(--line-2)}
.course-meta li{
  display:flex; justify-content:space-between; align-items:center;
  padding: 10px 0; border-bottom:1px solid var(--line-2);
  font-size: 14px;
}
.course-meta li:nth-child(odd){padding-right: 18px; border-right:1px solid var(--line-2)}
.course-meta li:nth-child(even){padding-left: 18px}
.course-meta span{color:var(--muted); font-size:12.5px; font-weight:500}
.course-meta b{font-weight:700; color:var(--ink); font-size: 14px}
.course .btn{margin-top:auto}

/* ===== Curriculum tabs ===== */
.tabs{
  display:flex; gap:4px; padding: 6px;
  background:#fff; border:1px solid var(--line); border-radius: var(--radius-pill);
  width: fit-content; margin: 0 auto 36px;
  box-shadow: var(--shadow-sm); flex-wrap:wrap;
}
.tab{
  padding: 10px 22px; border-radius: var(--radius-pill);
  font-size: 14px; font-weight:600; color:var(--muted);
  transition: background .15s var(--t), color .15s var(--t);
}
.tab:hover{color: var(--ink)}
.tab.is-active{background: var(--ink); color:#fff}

.tab-panel{display:none; animation: fade .25s var(--t)}
.tab-panel.is-active{display:block}
@keyframes fade{ from{opacity:0; transform: translateY(4px)} to{opacity:1; transform:none} }

.cur-head{
  display:grid; grid-template-columns: 1fr auto; gap: 32px;
  padding: 28px 32px; background: var(--grad-soft);
  border-radius: var(--radius-lg); margin-bottom: 28px;
}
.cur-head h3{font-size: 22px; margin: 0 0 6px; letter-spacing:-0.02em; color:var(--ink); font-weight:800}
.cur-head p{font-size: 14.5px; color:var(--body); line-height:1.7}
.cur-stat{display:flex; gap: 24px; align-items:center}
.cur-stat > div{text-align:center}
.cur-stat b{display:block; font-size: 26px; color:var(--ink); font-weight:800; letter-spacing:-0.02em}
.cur-stat span{font-size: 12.5px; color:var(--muted)}
@media (max-width: 720px){
  .cur-head{grid-template-columns: 1fr; padding: 22px}
  .cur-stat{justify-content:flex-start; gap: 20px}
}

.cur-block{
  background:#fff; border:1px solid var(--line-2); border-radius: var(--radius-lg);
  padding: 22px 24px; margin-bottom: 18px;
}
.cur-block h4{
  display:flex; align-items:center; gap:10px;
  font-size: 16px; margin: 0 0 14px; color:var(--ink); font-weight:700;
}
.cur-block h4 em{font-style:normal; color:var(--muted); font-size:13.5px; font-weight:500; margin-left:auto}
.dot-cyan, .dot-violet{display:inline-block; width:10px; height:10px; border-radius:50%}
.dot-cyan{background: var(--primary)}
.dot-violet{background: var(--violet)}

.cur-table{width:100%; border-collapse:collapse; font-size: 14px}
.cur-table thead th{
  text-align:left; font-size: 12.5px; font-weight:700;
  color: var(--muted); padding: 10px 12px; background: #FAFBFC;
  border-bottom:1px solid var(--line); letter-spacing:.04em;
}
.cur-table th.num, .cur-table td.num{text-align:right; white-space:nowrap}
.cur-table tbody td{padding: 14px 12px; border-bottom:1px solid var(--line-2); color:var(--ink-2)}
.cur-table tbody tr:hover{background: #FAFCFD}
.cur-table tbody tr:last-child td{border-bottom:0}
.cur-table .emph{color:var(--ink); font-weight:700}
.cur-note{
  background: #FFF8E1; border-left:3px solid var(--warn);
  padding: 14px 18px; border-radius: 8px;
  font-size: 14px; color: var(--ink-2); margin-top: 16px;
}
@media (max-width: 600px){
  .cur-table thead{display:none}
  .cur-table tr{display:block; padding:10px 0; border-bottom:1px solid var(--line-2)}
  .cur-table td{display:flex; justify-content:space-between; padding: 6px 0; border:0}
  .cur-table td::before{content: attr(data-label); color:var(--muted); font-size:12.5px; margin-right:12px}
}

/* ===== Instructors ===== */
.ins-grid{max-width: 880px; margin: 0 auto}
.ins{
  display:grid; grid-template-columns: 132px 1fr; gap: 22px;
  background:#fff; border:1px solid var(--line-2); border-radius: var(--radius-lg);
  padding: 26px;
}
.ins-photo{
  width:132px; height:132px; border-radius: 18px;
  background: var(--grad);
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.ins-photo.alt{background: linear-gradient(135deg, #6366F1 0%, #145CE6 100%)}
.ins-photo .initial{
  font-size: 56px; font-weight:800; color:#fff; letter-spacing:-0.04em;
  text-shadow: 0 2px 12px rgba(0,0,0,.15);
}
.ins-photo::after{
  content:''; position:absolute; inset:0;
  background: radial-gradient(120px 80px at 30% 20%, rgba(255,255,255,.4), transparent 70%);
}
.ins h3{font-size: 19px; margin: 6px 0 4px; color:var(--ink); font-weight:800; letter-spacing:-0.02em}
.ins h3 em{font-style:normal; font-size:13px; color:var(--muted); font-weight:600; margin-left:6px}
.ins-role{font-size: 13.5px; color:var(--primary-deep); font-weight:600; margin-bottom:14px}
.ins-tags{display:flex; flex-wrap:wrap; gap:6px}
.ins-tags li{
  background: #F1F5F9; color: var(--ink-2);
  padding: 5px 10px; border-radius: 8px;
  font-size: 12.5px; font-weight:500;
}
@media (max-width: 600px){
  .ins{grid-template-columns: 1fr; text-align:center}
  .ins-photo{margin: 0 auto}
  .ins-tags{justify-content:center}
}

/* ===== Gallery ===== */
.gallery{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: 240px 240px;
  gap: 14px;
}
.g{position:relative; overflow:hidden; border-radius: var(--radius-lg); display:block; cursor:zoom-in}
.g img{width:100%; height:100%; object-fit:cover; transition: transform .5s var(--t)}
.g:hover img{transform: scale(1.05)}
.g::after{
  content:''; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 50%, rgba(15,23,42,.6) 100%);
  pointer-events:none;
}
.g-cap{
  position:absolute; left:16px; bottom:14px; z-index:2;
  color:#fff; font-size:13.5px; font-weight:600; letter-spacing:-0.01em;
  text-shadow: 0 2px 8px rgba(0,0,0,.4);
}
.g-1{grid-column: 1 / span 2; grid-row: 1 / span 2}
.g-2{grid-column: 3; grid-row: 1}
.g-3{grid-column: 4; grid-row: 1}
.g-4{grid-column: 3; grid-row: 2}
.g-5{grid-column: 4; grid-row: 2}
@media (max-width: 900px){
  .gallery{grid-template-columns: 1fr 1fr; grid-template-rows: 220px 180px 180px}
  .g-1{grid-column: 1 / span 2; grid-row: 1}
  .g-2{grid-column: 1; grid-row: 2}
  .g-3{grid-column: 2; grid-row: 2}
  .g-4{grid-column: 1; grid-row: 3}
  .g-5{grid-column: 2; grid-row: 3}
}
@media (max-width: 480px){
  .gallery{grid-template-columns: 1fr; grid-template-rows: repeat(5, 200px)}
  .g-1, .g-2, .g-3, .g-4, .g-5{grid-column: 1; grid-row: auto}
}

.fa-foot{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  margin-top: 28px; padding: 22px; border-radius: var(--radius-lg);
  background: #fff; border:1px solid var(--line-2);
}
.fa-foot > div{display:flex; flex-direction:column; gap:4px; padding: 6px 14px; border-right:1px solid var(--line-2)}
.fa-foot > div:last-child{border-right:none}
.fa-foot b{font-size:12.5px; letter-spacing:.06em; color:var(--primary-deep); font-weight:700}
.fa-foot span{font-size: 14px; color:var(--ink-2); font-weight:600}
@media (max-width: 720px){
  .fa-foot{grid-template-columns: 1fr 1fr}
  .fa-foot > div{border-right:none; border-bottom:1px solid var(--line-2); padding: 10px 14px}
}

/* ===== Apply (CTA) ===== */
.section-cta{
  background: linear-gradient(135deg, #0A1330 0%, #145CE6 130%);
  color: #fff; position:relative; overflow:hidden;
}
.section-cta::before{
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(700px 400px at 100% 0%, rgba(61,125,255,.25), transparent 60%),
    radial-gradient(500px 400px at 0% 100%, rgba(20,92,230,.2), transparent 60%);
  pointer-events:none;
}
.apply-grid{position:relative; display:grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items:center}
.apply-copy .kicker{background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.2); color: var(--primary)}
.apply-copy h2{font-size: clamp(28px, 3vw, 38px); line-height:1.25; letter-spacing:-0.03em; margin:0 0 18px; color:#fff; font-weight:800}
.apply-copy h2 em{font-style:normal; background: linear-gradient(135deg, #93B8FF, #BCD5FF); -webkit-background-clip:text; background-clip:text; color:transparent}
.apply-copy p{color: rgba(226,232,240,.9); font-size:15.5px; margin-bottom: 24px}
.apply-bullets{display:flex; flex-direction:column; gap: 10px}
.apply-bullets li{
  display:flex; align-items:center; gap:10px; font-size: 14.5px; color: #E2E8F0;
}
.apply-bullets li::before{
  content:''; width:18px; height:18px; border-radius:50%;
  background: var(--primary); flex-shrink:0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230B1220' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-position: center; background-repeat: no-repeat; background-size: 11px;
}

.apply-form{
  background:#fff; color:var(--ink-2);
  border-radius: var(--radius-lg); padding: 28px;
  display:grid; grid-template-columns: 1fr 1fr; gap: 14px;
  box-shadow: var(--shadow-lg);
}
.apply-form h3{
  grid-column: span 2;
  font-size: 19px; margin: 0 0 4px; color:var(--ink); font-weight:800; letter-spacing:-0.02em;
}
.apply-form label{
  display:flex; flex-direction:column; gap:6px;
  font-size:13px; color:var(--muted); font-weight:600;
}
.apply-form label.full{grid-column: span 2}
.apply-form input[type="text"], .apply-form input[type="tel"],
.apply-form select, .apply-form textarea{
  font: inherit; font-size: 14.5px; color:var(--ink); font-weight:500;
  padding: 12px 14px; border-radius: 10px;
  border: 1.5px solid var(--line); background: #fff;
  transition: border-color .15s var(--t), box-shadow .15s var(--t);
}
.apply-form input:focus, .apply-form select:focus, .apply-form textarea:focus{
  outline:none; border-color: var(--primary);
  box-shadow: 0 0 0 4px rgba(20,92,230,.15);
}
.apply-form .check{flex-direction:row; align-items:center; gap:8px; font-size:13px; color:var(--muted); font-weight:500}
.apply-form .check input{width:16px; height:16px; accent-color: var(--primary)}
.apply-form button[type="submit"]{grid-column: span 2; margin-top: 6px}
.apply-fallback{grid-column: span 2; text-align:center; font-size:13px; color:var(--muted); margin-top:6px}
.apply-fallback a{color: var(--primary-deep); font-weight:700}
.apply-form .honey{
  position:absolute !important; left:-9999px !important; top:auto !important;
  width:1px !important; height:1px !important; overflow:hidden !important;
  opacity:0 !important; pointer-events:none !important;
}
.apply-status{
  grid-column: span 2; min-height: 0; padding: 0 14px;
  font-size: 13.5px; line-height: 1.55; text-align:center;
  border-radius: 10px; transition: padding .15s var(--t), background .15s var(--t);
}
.apply-status:empty{display:none}
.apply-status.is-loading{padding: 12px 14px; background: rgba(20,92,230,.08); color: var(--primary-deep); font-weight:600}
.apply-status.is-success{padding: 12px 14px; background: rgba(34,197,94,.12); color: #15803D; font-weight:600}
.apply-status.is-error{padding: 12px 14px; background: rgba(239,68,68,.10); color: #B91C1C; font-weight:600}

@media (max-width: 1024px){
  .apply-grid{grid-template-columns: 1fr; gap: 32px}
}
@media (max-width: 480px){
  .apply-form{grid-template-columns: 1fr; padding: 22px}
  .apply-form h3, .apply-form label.full, .apply-form button[type="submit"], .apply-fallback, .apply-status{grid-column: 1}
}

/* ===== FAQ ===== */
.faq-wrap{max-width: 880px}
.faq{display:flex; flex-direction:column; gap: 10px}
.faq details{
  background:#fff; border:1px solid var(--line-2); border-radius: 14px;
  padding: 4px 22px; transition: box-shadow .2s var(--t), border-color .2s var(--t);
}
.faq details[open]{box-shadow: var(--shadow-md); border-color: rgba(20,92,230,.4)}
.faq summary{
  list-style:none; cursor:pointer;
  padding: 18px 0; font-weight:700; color:var(--ink); letter-spacing:-0.01em;
  display:flex; align-items:center; gap:14px;
  font-size: 15.5px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:'+'; margin-left:auto; font-size: 22px; color: var(--primary-deep); font-weight:300;
  transition: transform .2s var(--t);
}
.faq details[open] summary::after{transform: rotate(45deg)}
.faq p{padding: 0 0 18px; color:var(--body); font-size: 14.5px; line-height:1.75}

/* ===== Contact ===== */
.contact-grid{display:grid; grid-template-columns: 1fr 1.2fr; gap: 32px}
@media (max-width: 1024px){ .contact-grid{grid-template-columns: 1fr} }
.contact-info{
  background:#fff; border:1px solid var(--line-2); border-radius: var(--radius-lg);
  padding: 28px; display:flex; flex-direction:column; gap: 20px;
}
.ci{display:grid; grid-template-columns: 44px 1fr; gap: 14px; align-items:flex-start}
.ci-ico{
  width:44px; height:44px; border-radius:12px;
  background: var(--grad-soft); color: var(--primary-deep);
  display:flex; align-items:center; justify-content:center; font-size:20px;
}
.ci b{display:block; font-size: 12px; color: var(--muted); letter-spacing:.06em; font-weight:700; margin-bottom:2px}
.ci p{font-size: 14.5px; color:var(--ink-2); font-weight:500}
.ci a{color:var(--primary-deep); font-weight:600}
.ci-cta{display:flex; gap:10px; margin-top:6px; padding-top:18px; border-top:1px solid var(--line-2)}

.map{
  border-radius: var(--radius-lg); overflow:hidden;
  border:1px solid var(--line-2); min-height: 380px; background: #EEF2F6;
}
.map iframe{width:100%; height:100%; min-height: 380px; border:0}

/* ===== Footer ===== */
.site-footer{background: var(--bg-deep); color: #CBD5E1; margin-top: 0}
.foot-grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.4fr; gap: 36px;
  padding: 64px 24px 40px;
}
.foot-brand strong{display:block; font-size: 18px; color:#fff; font-weight:800; letter-spacing:-0.02em}
.foot-brand small{display:block; font-size: 11.5px; color: var(--primary); letter-spacing:.18em; font-weight:700; margin-top:4px}
.foot-desc{font-size: 13.5px; color: #94A3B8; line-height:1.7; margin-top:14px}
.site-footer h4{font-size: 13px; color:#fff; font-weight:700; letter-spacing:.04em; margin: 4px 0 16px}
.site-footer ul li{font-size: 13.5px; padding: 5px 0; color: #94A3B8}
.site-footer ul li a:hover{color: var(--primary)}
.site-footer .biz li{display:grid; grid-template-columns: 88px 1fr; gap:8px; padding: 4px 0}
.site-footer .biz span{color: #64748B; font-size: 12.5px}
.foot-bottom{border-top: 1px solid rgba(255,255,255,.06); padding: 20px 0}
.foot-bottom .container{display:flex; justify-content:space-between; gap: 16px; flex-wrap:wrap}
.foot-bottom small{font-size: 12px; color: #64748B}
@media (max-width: 900px){ .foot-grid{grid-template-columns: 1fr 1fr; gap: 28px} }
@media (max-width: 540px){ .foot-grid{grid-template-columns: 1fr} }

/* ===== Lightbox ===== */
.lightbox{
  position:fixed; inset:0; z-index:200;
  background: rgba(8,12,22,.92);
  display:flex; align-items:center; justify-content:center;
  padding: 32px;
  animation: fade .2s var(--t);
}
.lightbox figure{margin:0; max-width: 1100px; width:100%}
.lightbox img{width:100%; max-height: 80vh; object-fit:contain; border-radius: 8px}
.lightbox figcaption{text-align:center; color:#CBD5E1; font-size: 14px; margin-top: 14px}
.lightbox-close{
  position:absolute; top: 22px; right: 24px; width:44px; height:44px;
  border-radius:50%; background: rgba(255,255,255,.08);
  color:#fff; font-size: 28px; line-height:1;
  display:flex; align-items:center; justify-content:center;
  transition: background .15s var(--t);
}
.lightbox-close:hover{background: rgba(255,255,255,.18)}

/* ===== Float CTA ===== */
.float-cta{
  position:fixed; right: 22px; bottom: 22px; z-index: 40;
  background: var(--grad); color:#fff;
  padding: 14px 22px; border-radius: var(--radius-pill);
  display:flex; flex-direction:column; align-items:flex-start;
  box-shadow: 0 16px 32px -10px rgba(15,23,42,.4), 0 0 0 4px rgba(20,92,230,.15);
  animation: pulse 2.4s ease-in-out infinite;
  transition: transform .2s var(--t);
}
.float-cta:hover{transform: translateY(-2px)}
.float-cta span{font-size:14.5px; font-weight:800; letter-spacing:-0.02em; line-height:1.1}
.float-cta small{font-size:11.5px; opacity:.92; letter-spacing:.02em; margin-top:2px}
@keyframes pulse{
  0%, 100%{box-shadow: 0 16px 32px -10px rgba(15,23,42,.4), 0 0 0 4px rgba(20,92,230,.15)}
  50%{box-shadow: 0 16px 32px -10px rgba(15,23,42,.4), 0 0 0 10px rgba(20,92,230,.0)}
}
@media (max-width: 480px){
  .float-cta{padding: 12px 18px; right: 14px; bottom: 14px}
}

/* ===== Reveal on scroll ===== */
.reveal{opacity:0; transform: translateY(16px); transition: opacity .6s var(--t), transform .6s var(--t)}
.reveal.is-in{opacity:1; transform:none}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{transition:none !important; animation:none !important}
  html{scroll-behavior:auto}
}
