@import url('https://fonts.googleapis.com/css2?family=Pretendard:wght@300;400;500;600;700;800;900&family=Inter:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&display=swap');

:root{
  /* 2025 Warm Cream Palette */
  --cream:#FAF9F7;
  --cream2:#F3F1EE;
  --cream3:#EAE7E2;
  --sand:#D5CEC5;
  --stone:#8A8480;
  --text:#1A1917;
  --text2:#4A4744;
  --text3:#7A7774;

  /* Brand */
  --indigo:#3B5BDB;
  --indigo2:#2F4AC7;
  --indigo-l:#EEF2FF;
  --violet:#7048E8;
  --sky:#1098AD;
  --sky-l:#E3FAFC;
  --orange:#F76707;
  --orange-l:#FFF4E6;
  --green:#2F9E44;

  --nav:66px;
  --max:1400px;
  --r:16px;
  --r2:24px;
  --e:cubic-bezier(.22,1,.36,1);
  --e2:cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:'Pretendard','Inter',-apple-system,sans-serif;
  background:var(--cream);color:var(--text);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
::selection{background:var(--indigo);color:#fff}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--cream2)}
::-webkit-scrollbar-thumb{background:var(--indigo);border-radius:2px}

/* ══ NAV ══ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:9000;
  height:var(--nav);
  display:flex;align-items:center;
  padding:0 40px;
  background:rgba(250,249,247,0);
  transition:background .5s var(--e),box-shadow .5s;
}
.nav.bg{
  background:rgba(250,249,247,.88);
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  box-shadow:0 1px 0 rgba(0,0,0,.06)
}
.nav.solid{background:var(--cream);box-shadow:0 1px 0 rgba(0,0,0,.06)}

/* Logo */
.nav-logo{
  font-size:18px;font-weight:900;letter-spacing:-.5px;
  color:var(--text);margin-right:auto;
  display:flex;align-items:center;gap:10px;
  transition:opacity .2s;
}
.nav-logo:hover{opacity:.75}
.nav-logo-box{
  width:34px;height:34px;background:var(--indigo);
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  transition:transform .3s var(--e2),box-shadow .3s;
  box-shadow:0 2px 8px rgba(59,91,219,.25);
}
.nav-logo:hover .nav-logo-box{transform:rotate(-8deg) scale(1.08);box-shadow:0 6px 18px rgba(59,91,219,.4)}
.nav-logo-box svg{width:16px;height:16px}

/* nav items */
.nav-links{display:flex;align-items:center;gap:0}
.ni{position:relative}
.ni>a{
  display:flex;align-items:center;gap:5px;
  padding:0 15px;height:var(--nav);
  font-size:13.5px;font-weight:500;
  color:var(--text2);
  transition:color .2s;white-space:nowrap;
}
.ni>a:hover,.ni.on>a{color:var(--text)}
.chev{font-size:9px;opacity:.4;transition:transform .25s}
.ni:hover>a .chev{transform:rotate(180deg)}
.ndrop{
  position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(-6px);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  min-width:200px;border-radius:14px;
  box-shadow:0 16px 52px rgba(0,0,0,.11),0 0 0 1px rgba(0,0,0,.05);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .2s,transform .2s,visibility .2s;
}
.ni:hover .ndrop{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.ndrop a{
  display:block;padding:12px 18px;font-size:13.5px;font-weight:500;
  color:var(--text2);border-bottom:1px solid rgba(0,0,0,.05);
  transition:background .15s,color .15s,padding-left .15s;
}
.ndrop a:first-child{border-radius:14px 14px 0 0}
.ndrop a:last-child{border:none;border-radius:0 0 14px 14px}
.ndrop a:hover{background:var(--cream2);color:var(--text);padding-left:24px}
.ndrop a.on{color:var(--indigo);font-weight:600}

.nav-cta{
  margin-left:16px;
  background:var(--indigo);color:#fff;
  padding:10px 22px;border-radius:10px;
  font-size:13px;font-weight:700;letter-spacing:.1px;
  transition:background .2s,box-shadow .2s,transform .15s;
  box-shadow:0 2px 10px rgba(59,91,219,.25);flex-shrink:0;
}
.nav-cta:hover{background:var(--indigo2);box-shadow:0 8px 24px rgba(59,91,219,.35);transform:translateY(-1px)}

.burger{display:none;flex-direction:column;gap:5.5px;cursor:pointer;padding:8px;margin-left:auto}
.burger span{width:22px;height:1.5px;background:var(--text);display:block;transition:.3s var(--e2)}

/* ══ FULLSCREEN SECTION ══ */
.fs{
  position:relative;width:100%;height:100vh;min-height:660px;
  overflow:hidden;display:flex;flex-direction:column;
  align-items:center;justify-content:flex-end;
  text-align:center;
}
.fs-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
/* overlay varieties */
.ov-dark{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,8,.78) 0%,rgba(15,12,8,.32) 55%,rgba(15,12,8,.1) 100%)}
.ov-light{position:absolute;inset:0;background:linear-gradient(to top,rgba(250,249,247,.85) 0%,rgba(250,249,247,.45) 55%,rgba(250,249,247,.05) 100%)}
.ov-side{position:absolute;inset:0;background:linear-gradient(to right,rgba(15,12,8,.88) 0%,rgba(15,12,8,.62) 40%,rgba(15,12,8,.1) 70%,transparent 100%)}
.fs-content{position:relative;z-index:2;width:100%;padding:0 24px 88px}

/* ── hero titles ── */
.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.15);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.2);
  padding:9px 22px;border-radius:100px;
  font-size:14px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(255,255,255,.9);margin-bottom:20px;
}
.hero-tag.dk{background:rgba(59,91,219,.1);border-color:rgba(59,91,219,.2);color:var(--indigo)}
.hero-dot{width:6px;height:6px;background:var(--orange);border-radius:50%}

.hero-h{
  font-size:clamp(42px,6.5vw,88px);font-weight:900;
  letter-spacing:-3px;color:#fff;line-height:.92;
  margin-bottom:16px;
}
.hero-h.dk{color:var(--text)}
.hero-h em{font-style:normal}
.hero-sub{font-size:16px;color:rgba(255,255,255,.68);margin-bottom:32px;line-height:1.62;letter-spacing:.1px}
.hero-sub.dk{color:var(--text2)}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* scroll hint */
.scroll-hint{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;
}
.scroll-hint span{font-size:9px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.4)}
.scroll-pipe{width:1px;height:42px;background:rgba(255,255,255,.18);overflow:hidden;position:relative}
.scroll-pipe::after{content:'';position:absolute;top:-100%;width:100%;height:100%;background:rgba(255,255,255,.7);animation:scrollFlow 2.2s ease infinite}
@keyframes scrollFlow{0%{top:-100%}100%{top:100%}}

/* ══ STAT STRIP ══ */
.stat-strip{background:#fff;border-bottom:1px solid var(--cream3)}
.stat-inner{max-width:var(--max);margin:0 auto;display:flex}
.si{flex:1;padding:40px 28px;text-align:center;border-right:1px solid var(--cream3)}
.si:last-child{border:none}
.si-n{font-size:48px;font-weight:900;letter-spacing:-2.5px;line-height:1;color:var(--text)}
.si-n em{color:var(--indigo);font-style:normal}
.si-l{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--stone);margin-top:7px}
.si-s{font-size:11px;color:var(--sand);margin-top:3px}

/* ══ SIDE-BY-SIDE SPLIT ══ */
.split{display:grid;grid-template-columns:1fr 1fr}
.split-img{position:relative;overflow:hidden;min-height:520px}
.split-img img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--e)}
.split-img:hover img{transform:scale(1.04)}
.split-body{padding:88px 72px;display:flex;flex-direction:column;justify-content:center}
.split-cream{background:var(--cream)}
.split-white{background:#fff}
.split-dark{background:var(--text)}
.split-dark .sh{color:#fff}
.split-dark .sd{color:rgba(255,255,255,.5)}
.split-indigo{background:var(--indigo)}
.split-indigo .sh,.split-indigo .s-eye{color:#fff}
.split-indigo .sd{color:rgba(255,255,255,.6)}

/* ══ GLASS CARD SECTION ══ */
.glass-sec{
  position:relative;overflow:hidden;padding:100px 0;
}
.glass-sec .fs-bg{position:absolute}
.glass-sec-inner{position:relative;z-index:2}
.glass-row{display:flex;gap:2px;width:min(1200px,94vw);margin:0 auto}
.glass-card{
  flex:1;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.6);
  padding:40px 30px 36px;
  transition:background .25s,transform .25s var(--e),box-shadow .25s;
  border-radius:0;
}
.glass-card:first-child{border-radius:18px 0 0 18px}
.glass-card:last-child{border-radius:0 18px 18px 0}
.glass-card:hover{background:rgba(255,255,255,.9);transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.12)}
.gc-num{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--indigo);margin-bottom:12px}
.gc-icon{font-size:28px;margin-bottom:14px;display:block}
.gc-h{font-size:16px;font-weight:700;letter-spacing:-.2px;margin-bottom:8px;color:var(--text)}
.gc-p{font-size:13px;color:var(--text3);line-height:1.7}

/* ══ FEATURE GRID ══ */
.feat-sec{background:#fff;padding:96px 0}
.feat-inner{max-width:var(--max);margin:0 auto;padding:0 40px}
.feat-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:56px;gap:40px}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat-card{
  background:var(--cream);border-radius:var(--r2);padding:36px;
  border:1px solid transparent;
  transition:background .25s,box-shadow .3s var(--e),transform .3s var(--e),border-color .3s;
  position:relative;overflow:hidden;
}
.feat-card:hover{background:#fff;border-color:rgba(59,91,219,.15);box-shadow:0 16px 56px rgba(0,0,0,.07);transform:translateY(-5px)}
.feat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--indigo),var(--violet));
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--e2);
}
.feat-card:hover::before{transform:scaleX(1)}
.fc-num{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--indigo);margin-bottom:16px}
.fc-icon{
  width:52px;height:52px;border-radius:14px;background:var(--indigo-l);
  display:flex;align-items:center;justify-content:center;font-size:24px;
  margin-bottom:20px;
  transition:background .25s,transform .25s;
}
.feat-card:hover .fc-icon{background:var(--indigo);transform:rotate(-6deg) scale(1.05)}
.fc-h{font-size:18px;font-weight:700;letter-spacing:-.3px;margin-bottom:10px}
.fc-p{font-size:13.5px;color:var(--text3);line-height:1.72}

/* ══ BENTO GRID ══ */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto;gap:20px;max-width:var(--max);margin:0 auto;padding:0 40px}
.bento-card{border-radius:var(--r2);overflow:hidden;position:relative}
.bento-card img{width:100%;height:100%;object-fit:cover;display:block}
.bento-lg{grid-column:span 2;grid-row:span 2;min-height:400px}
.bento-md{grid-column:span 2;min-height:190px}
.bento-sm{grid-column:span 1;min-height:190px}
.bento-text{background:var(--indigo);padding:36px}
.bento-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.72) 0%,transparent 60%)}
.bento-label{position:absolute;bottom:0;left:0;right:0;padding:24px}
.bento-label h4{font-size:20px;font-weight:700;color:#fff;margin-bottom:4px}
.bento-label p{font-size:13px;color:rgba(255,255,255,.65)}

/* ══ TICKER ══ */
.ticker{background:var(--indigo);padding:14px 0;overflow:hidden}
.ticker-track{display:flex;white-space:nowrap;animation:tickgo 42s linear infinite}
.ti{display:inline-flex;align-items:center;gap:28px;padding:0 32px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.78)}
.ti::after{content:'✦';font-size:8px;color:rgba(255,255,255,.35);margin-left:28px}
@keyframes tickgo{to{transform:translateX(-50%)}}

/* ══ CERT SECTION ══ */
.cert-sec{background:var(--cream2);padding:96px 0}
.cert-inner{max-width:var(--max);margin:0 auto;padding:0 40px}
.cert-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:44px}
.cert-card{
  background:#fff;border-radius:var(--r);padding:30px;
  display:flex;gap:20px;align-items:flex-start;
  border:1px solid var(--cream3);
  transition:box-shadow .3s,border-color .3s,transform .3s var(--e);
}
.cert-card:hover{border-color:rgba(59,91,219,.2);box-shadow:0 12px 40px rgba(59,91,219,.08);transform:translateY(-3px)}
.cert-icon{
  width:50px;height:50px;background:var(--text);border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;
}
.cert-card h4{font-size:16px;font-weight:700;margin-bottom:8px}
.cert-card p{font-size:13px;color:var(--text3);line-height:1.65}

/* ══ CTA ══ */
.cta-sec{
  position:relative;overflow:hidden;
  min-height:90vh;display:flex;align-items:center;justify-content:center;
  text-align:center;
}
.cta-sec .W{position:relative;z-index:2}
.cta-h{font-size:clamp(36px,5.5vw,72px);font-weight:900;letter-spacing:-2.5px;color:#fff;margin-bottom:14px}
.cta-p{font-size:15.5px;color:rgba(255,255,255,.52);margin-bottom:18px}
.cta-phone{font-size:clamp(28px,4vw,54px);font-weight:900;letter-spacing:-1px;color:#fff;margin-bottom:36px}
.cta-phone em{color:rgba(255,220,100,1);font-style:normal}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ══ BUTTONS ══ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 28px;border-radius:10px;
  font-size:13.5px;font-weight:700;letter-spacing:.1px;
  transition:.25s var(--e);cursor:pointer;border:none;white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-indigo{background:var(--indigo);color:#fff;box-shadow:0 4px 16px rgba(59,91,219,.25)}
.btn-indigo:hover{background:var(--indigo2);box-shadow:0 8px 28px rgba(59,91,219,.4)}
.btn-white{background:#fff;color:var(--text)}
.btn-white:hover{background:var(--cream);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.btn-glass{background:rgba(255,255,255,.18);color:#fff;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2)}
.btn-glass:hover{background:rgba(255,255,255,.28)}
.btn-outline{background:transparent;border:1.5px solid var(--cream3);color:var(--text)}
.btn-outline:hover{border-color:var(--indigo);color:var(--indigo)}
.btn-dark{background:var(--text);color:#fff}
.btn-dark:hover{background:#2a2720}

/* ══ SECTION LABELS ══ */
.W{max-width:var(--max);margin:0 auto;padding:0 40px}
.s-eye{
  display:flex;align-items:center;gap:8px;
  font-size:11.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--indigo);margin-bottom:12px;
}
.s-eye::before{content:'';width:20px;height:1.5px;background:var(--indigo)}
.sh{font-size:clamp(26px,3.2vw,46px);font-weight:900;letter-spacing:-1.5px;line-height:1.06;margin-bottom:14px}
.sh em{font-style:normal;color:var(--indigo)}
.sh.white{color:#fff}
.sd{font-size:15px;color:var(--text3);line-height:1.8;max-width:560px}
.s-divider{border:none;height:1px;background:var(--cream3);margin:56px 0}

/* ══ SUBPAGE ══ */
.sub-hero{
  margin-top:var(--nav);
  position:relative;overflow:hidden;min-height:440px;
  display:flex;align-items:flex-end;
}
.sub-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.sub-hero-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,8,.85) 0%,rgba(15,12,8,.4) 55%,rgba(15,12,8,.15) 100%)}
.sub-hero-body{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:60px 40px 56px;width:100%}
.sub-eye{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.sub-eye::before{content:'';width:20px;height:1px;background:rgba(59,91,219,.7)}
.sub-hero-body h1{font-size:clamp(34px,5vw,64px);font-weight:900;letter-spacing:-2px;color:#fff;line-height:.95;margin-bottom:12px}
.sub-hero-body p{font-size:15px;color:rgba(255,255,255,.48);max-width:480px;line-height:1.7}

/* spec strip */
.spec-strip{background:#fff;border-bottom:1px solid var(--cream3)}
.spec-inner{max-width:var(--max);margin:0 auto;display:flex;flex-wrap:wrap}
.ssi{flex:1;min-width:25%;padding:32px 26px;text-align:center;border-right:1px solid var(--cream3)}
.ssi:last-child{border:none}
.ssin{font-size:42px;font-weight:900;letter-spacing:-2px;line-height:1}
.ssin em{color:var(--indigo);font-style:normal}
.ssil{font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--stone);margin-top:6px}
.ssis{font-size:11px;color:var(--sand);margin-top:2px}

/* BC */
.bc{background:var(--cream2);border-bottom:1px solid var(--cream3);padding:11px 0}
.bcw{max-width:var(--max);margin:0 auto;padding:0 40px;display:flex;align-items:center;gap:9px;font-size:12px}
.bcw a{color:var(--stone);transition:color .2s}
.bcw a:hover{color:var(--text)}
.bcs{color:var(--sand);font-size:10px}
.bcc{color:var(--text);font-weight:700}

/* two col */
.pg-body{padding:72px 0 100px;background:var(--cream)}
.two{display:grid;grid-template-columns:210px 1fr;gap:56px;align-items:start}
.snav{position:sticky;top:calc(var(--nav)+20px)}
.snav-h{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--sand);margin-bottom:14px}
.snav a{display:block;padding:10px 0;font-size:13.5px;font-weight:500;color:var(--stone);border-bottom:1px solid var(--cream3);transition:color .2s,padding-left .2s}
.snav a:last-child{border:none}
.snav a:hover{color:var(--text);padding-left:5px}
.snav a.on{color:var(--indigo);font-weight:700}

/* cards */
.cards{display:grid;gap:16px}
.c2{grid-template-columns:1fr 1fr}
.c3{grid-template-columns:1fr 1fr 1fr}
.card{
  background:#fff;border-radius:var(--r);padding:28px;
  border:1px solid var(--cream3);
  position:relative;overflow:hidden;
  transition:box-shadow .3s var(--e),transform .3s var(--e),border-color .3s;
}
.card:hover{box-shadow:0 12px 40px rgba(0,0,0,.07);transform:translateY(-4px);border-color:rgba(59,91,219,.15)}
.card-top{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--indigo),var(--violet));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--e2)}
.card:hover .card-top{transform:scaleX(1)}
.card-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;background:var(--indigo-l);color:var(--indigo);padding:3px 10px;border-radius:6px;margin-bottom:13px}
.card-tag-v{background:#F3EEFF;color:var(--violet)}
.card-tag-o{background:var(--orange-l);color:var(--orange)}
.card h4{font-size:17px;font-weight:700;letter-spacing:-.2px;margin-bottom:8px}
.card p{font-size:13.5px;color:var(--text3);line-height:1.72}

/* table */
.zt{width:100%;border-collapse:collapse;font-size:14px}
.zt thead th{background:var(--text);color:rgba(255,255,255,.82);padding:13px 18px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase}
.zt thead th:first-child{border-radius:10px 0 0 0}
.zt thead th:last-child{border-radius:0 10px 0 0}
.zt tbody tr{border-bottom:1px solid var(--cream3);transition:background .15s}
.zt tbody tr:hover{background:var(--indigo-l)}
.zt td{padding:13px 18px;color:var(--text2)}
.zt td:first-child{font-weight:700;color:var(--text)}
.better{color:var(--green);font-weight:700}
.cy{color:var(--green)}
.cn{color:var(--sand)}

/* flow */
.ftabs{display:flex;background:var(--cream2);border-radius:12px;padding:4px;margin-bottom:30px;width:fit-content;gap:2px}
.ftab{padding:10px 24px;font-size:13px;font-weight:600;color:var(--stone);cursor:pointer;background:transparent;border:none;border-radius:9px;transition:background .2s,color .2s,box-shadow .2s}
.ftab.on{background:#fff;color:var(--text);box-shadow:0 2px 10px rgba(0,0,0,.08)}
.fpanel{display:none}.fpanel.on{display:block}
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.fstep{background:var(--cream2);border-radius:12px;padding:22px 14px 18px;position:relative;text-align:center;transition:background .2s,box-shadow .2s;border:1.5px solid transparent}
.fstep:hover{background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.06)}
.fstep.hl{background:var(--indigo-l);border-color:var(--indigo)}
.fstep.sk{opacity:.35}
.fnum{position:absolute;top:11px;left:12px;font-size:10px;font-weight:700;letter-spacing:1px;color:var(--sand);text-transform:uppercase}
.fstep.hl .fnum{color:var(--indigo)}
.fic{font-size:24px;margin:10px auto 10px;display:block}
.fstep h5{font-size:13px;font-weight:700;margin-bottom:3px;color:var(--text)}
.fstep p{font-size:11.5px;color:var(--text3);line-height:1.45}
.farr{grid-column:span 3;text-align:center;color:var(--cream3);font-size:15px}

/* mockup */
.mockup{border-radius:14px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.14)}
.mbar{background:var(--text);padding:11px 16px;display:flex;align-items:center;gap:7px}
.mdot{width:10px;height:10px;border-radius:50%}
.mlabel{font-size:11px;color:rgba(255,255,255,.2);font-family:monospace;margin-left:5px}
.mockup img{width:100%;display:block}

/* ibox */
.ibox{background:#fff;border-radius:var(--r);padding:28px;border:1px solid var(--cream3)}
.irow{display:grid;grid-template-columns:150px 1fr;gap:12px;padding:12px 0;border-bottom:1px solid var(--cream3);font-size:14px;align-items:center}
.irow:last-child{border:none}
.ilabel{font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--stone)}

/* stat row */
.stat-row{display:flex;background:#fff;border-radius:var(--r);overflow:hidden;border:1px solid var(--cream3)}
.sr-item{flex:1;padding:28px 20px;text-align:center;border-right:1px solid var(--cream3)}
.sr-item:last-child{border:none}
.sr-n{font-size:38px;font-weight:900;letter-spacing:-1.5px;line-height:1}
.sr-n em{color:var(--indigo);font-style:normal}
.sr-l{font-size:10.5px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--stone);margin-top:6px}

/* timeline */
.tg{margin-bottom:36px}
.tyear{font-size:22px;font-weight:800;letter-spacing:-1px;margin-bottom:12px;display:flex;align-items:center;gap:14px}
.tyear::after{content:'';flex:1;height:1px;background:var(--cream3)}
.titem{padding:13px 16px 13px 20px;background:#fff;border-radius:10px;margin-bottom:9px;font-size:14px;color:var(--text2);line-height:1.65;border-left:3px solid var(--cream3);transition:border-color .2s,box-shadow .2s}
.titem:hover{border-color:var(--indigo);box-shadow:0 4px 16px rgba(59,91,219,.07)}

/* bhead */
.bhead{font-size:20px;font-weight:800;letter-spacing:-.3px;padding-bottom:13px;margin-bottom:18px;border-bottom:2px solid var(--text)}
.bbody{font-size:14.5px;color:var(--text2);line-height:1.88}
.bbody p{margin-bottom:14px}
.bbody strong{color:var(--text)}

/* footer */
.footer{background:#0D0C0A;padding:64px 0 0}
.footer-grid{max-width:var(--max);margin:0 auto;padding:0 40px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;padding-bottom:52px;border-bottom:1px solid rgba(255,255,255,.07)}
.fbrand-name{font-size:16px;font-weight:900;color:rgba(255,255,255,.75);display:flex;align-items:center;gap:9px;margin-bottom:14px;letter-spacing:-.2px}
.fbrand-dot{width:8px;height:8px;background:var(--indigo);border-radius:50%}
.fbrand p{font-size:12.5px;color:rgba(255,255,255,.28);line-height:1.85}
.fbrand address{font-style:normal;font-size:12px;color:rgba(255,255,255,.18);line-height:2;margin-top:12px}
.footer h5{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.22);margin-bottom:16px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:11px}
.footer ul a{font-size:13.5px;color:rgba(255,255,255,.38);transition:color .2s}
.footer ul a:hover{color:#fff}
.fbot{max-width:var(--max);margin:0 auto;padding:20px 40px;display:flex;justify-content:space-between;font-size:11.5px;color:rgba(255,255,255,.16)}

/* ANIM */
.up{opacity:0;transform:translateY(28px);transition:opacity .75s var(--e2),transform .75s var(--e2)}
.up.vis{opacity:1;transform:none}
.left{opacity:0;transform:translateX(-28px);transition:opacity .75s var(--e2),transform .75s var(--e2)}
.left.vis{opacity:1;transform:none}
.right{opacity:0;transform:translateX(28px);transition:opacity .75s var(--e2),transform .75s var(--e2)}
.right.vis{opacity:1;transform:none}
[data-d="1"]{transition-delay:.1s}[data-d="2"]{transition-delay:.2s}[data-d="3"]{transition-delay:.3s}[data-d="4"]{transition-delay:.4s}

/* RESPONSIVE */
@media(max-width:1100px){
  .W,.footer-grid,.bento{padding:0 28px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .fbot{padding:16px 28px}
  .c3{grid-template-columns:1fr 1fr}
  .two{grid-template-columns:1fr}
  .snav{display:none}
  .split{grid-template-columns:1fr}
  .split-img{min-height:320px;order:0}
  .split-body{padding:52px 36px}
  .glass-row{flex-wrap:wrap}
  .glass-card{min-width:calc(50% - 2px)}
  .glass-card:first-child,.glass-card:last-child{border-radius:var(--r)}
  .feat-grid{grid-template-columns:1fr 1fr}
  .stat-inner{flex-wrap:wrap}
  .si{min-width:50%}
  .bcw,.sub-hero-body,.feat-inner{padding-left:28px;padding-right:28px}
}
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .burger{display:flex}
  .nav-links.open{
    display:flex;flex-direction:column;
    position:fixed;inset:var(--nav) 0 0;
    background:rgba(250,249,247,.97);backdrop-filter:blur(24px);
    padding:12px 20px;z-index:9001;overflow-y:auto;gap:0;
  }
  .nav-links.open .ni>a{color:var(--text);padding:14px 8px;height:auto;border-bottom:1px solid var(--cream3);border-radius:0}
  .nav-links.open .ndrop{position:static;box-shadow:none;border-radius:0;border:none;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:var(--cream2);display:none}
  .nav-links.open .ni.open-m .ndrop{display:block}
  .nav-links.open .ni:hover .ndrop{display:block}
  .W,.bento{padding:0 20px}
  .feat-inner{padding:0 20px}
  .footer-grid{grid-template-columns:1fr;padding:0 20px}
  .fbot{flex-direction:column;gap:8px;text-align:center;padding:14px 20px}
  .c2,.c3{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
  .hero-h{font-size:40px;letter-spacing:-1.5px}
  .cta-h{font-size:32px}
  .glass-card{min-width:100%}
  .bento{display:flex;flex-direction:column}
  .fgrid{grid-template-columns:1fr 1fr}
  .bcw,.sub-hero-body{padding-left:20px;padding-right:20px}
  .cert-grid{grid-template-columns:1fr}
  /* 서브페이지 레이아웃 */
  .two{display:flex;flex-direction:column}
  .snav{display:none}
  .pg-body .W{padding:0 20px}
  .odt-hw-grid,.odt-str-grid{grid-template-columns:1fr !important}
  .ibox .irow{flex-direction:column;gap:4px}
  .ilabel{min-width:auto !important;font-size:11px}
  .stat-row{flex-wrap:wrap;gap:12px}
  .sr-item{min-width:80px}
  /* 하드웨어 표 */
  table.zt{font-size:12px}
  table.zt th,table.zt td{padding:8px 10px}
}
@media(max-width:520px){
  .fgrid{grid-template-columns:1fr}
  .hero-h{font-size:32px}
  .si{min-width:100%}
  .ssi{min-width:auto;flex:1 1 calc(50% - 8px)}
  table.zt td:nth-child(1){display:none}
}
