/* CE경영컨설팅 — 메인 페이지 전용 스타일 */
:root {
  --ce-primary: #0B2A5B;
  --ce-accent: #D9232E;
  --ce-graphite: #2B323A;
  --ce-mist: #EAF1FB;
  --ce-yellow: #ffeb3b;
}

/* ==== Hero (slider) ==== */
.ce-hero { position: relative; height: 720px; max-height: 88vh; overflow: hidden; color: #fff; background: #0a1d3f; }
.ce-hero__slides { position: absolute; inset: 0; }
.ce-hero__slide { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transform: scale(1.05); transition: opacity 1.2s ease, transform 7s ease; }
.ce-hero__slide.is-active { opacity: 1; transform: scale(1); }
.ce-hero__overlay { position: absolute; inset: 0; background: linear-gradient(105deg, rgba(11,42,91,.78) 0%, rgba(11,42,91,.45) 60%, rgba(0,0,0,.25) 100%); }

.ce-hero__inner { position: relative; max-width: 1200px; margin: 0 auto; padding: 0 24px; height: 100%; display: flex; align-items: center; }
.ce-hero__panel { position: absolute; left: 24px; right: 24px; max-width: 760px; opacity: 0; transform: translateY(20px); transition: opacity .8s ease .3s, transform .8s ease .3s; pointer-events: none; }
.ce-hero__panel.is-active { opacity: 1; transform: translateY(0); pointer-events: auto; }
.ce-hero__eyebrow { font-family: Inter, sans-serif; font-size: 18px; font-weight: 500; letter-spacing: .15em; color: #fff; text-shadow: 2px 2px 6px rgba(0,0,0,.4); margin-bottom: 18px; opacity: .92; }
.ce-hero__title { font-family: Inter, sans-serif; font-size: clamp(40px, 6vw, 76px); font-weight: 800; line-height: 1.1; letter-spacing: -.02em; color: var(--ce-yellow); text-shadow: 2px 2px 8px rgba(0,0,0,.45); margin-bottom: 22px; }
.ce-hero__sub { font-size: clamp(16px, 1.6vw, 22px); line-height: 1.55; color: #fff; opacity: .95; max-width: 720px; margin-bottom: 12px; }
.ce-hero__tag { font-size: clamp(22px, 2.4vw, 32px); font-weight: 800; color: #6BFFB8; text-shadow: 2px 2px 6px rgba(0,0,0,.5); margin-bottom: 28px; }
.ce-hero__cta { display: flex; gap: 12px; flex-wrap: wrap; }
.ce-hero__cta .btn--primary { background: var(--ce-accent); color: #fff; padding: 14px 30px; border-radius: 4px; font-weight: 700; text-decoration: none; transition: .2s; box-shadow: 0 8px 22px rgba(217,35,46,.35); }
.ce-hero__cta .btn--primary:hover { background: #b81d27; transform: translateY(-2px); }

.ce-hero__nav { position: absolute; top: 50%; transform: translateY(-50%); width: 52px; height: 52px; border-radius: 50%; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.3); color: #fff; display: flex; align-items: center; justify-content: center; cursor: pointer; backdrop-filter: blur(6px); transition: .2s; z-index: 5; }
.ce-hero__nav:hover { background: rgba(255,255,255,.25); }
.ce-hero__nav svg { width: 22px; height: 22px; }
.ce-hero__nav--prev { left: 28px; }
.ce-hero__nav--next { right: 28px; }
.ce-hero__dots { position: absolute; bottom: 36px; left: 50%; transform: translateX(-50%); display: flex; gap: 12px; z-index: 5; }
.ce-hero__dot { width: 14px; height: 14px; border-radius: 50%; border: 2px solid rgba(255,255,255,.6); background: transparent; cursor: pointer; transition: .2s; padding: 0; }
.ce-hero__dot.is-active { background: #fff; border-color: #fff; }

@media (max-width: 768px) {
  .ce-hero { height: 580px; }
  .ce-hero__nav { display: none; }
  .ce-hero__panel { right: 16px; left: 16px; }
}

/* ==== Sections ==== */
.ce-section { padding: 100px 0; }
.ce-section__eyebrow { font-family: Inter, sans-serif; font-size: 13px; font-weight: 600; letter-spacing: .25em; color: var(--ce-accent); margin-bottom: 14px; }
.ce-section__title { font-size: clamp(28px, 3.4vw, 40px); font-weight: 800; line-height: 1.25; letter-spacing: -.02em; color: var(--ce-primary); margin-bottom: 16px; }
.ce-section__head { text-align: center; margin-bottom: 60px; }
.ce-section__head .ce-section__title { margin: 0 auto 12px; }

/* About section */
.ce-section--intro { background: #fafbfd; }
.ce-about { display: grid; grid-template-columns: 1.1fr .9fr; gap: 60px; align-items: center; }
.ce-about__title { font-size: clamp(28px, 3.2vw, 38px); font-weight: 800; line-height: 1.3; color: var(--ce-primary); margin-bottom: 22px; }
.ce-about__lead { font-size: 17px; line-height: 1.75; color: #475061; margin-bottom: 28px; }
.ce-about__cta { display: flex; gap: 12px; flex-wrap: wrap; }
.ce-about__cta .btn--primary { background: var(--ce-primary); color: #fff; padding: 13px 28px; border-radius: 4px; text-decoration: none; font-weight: 600; transition: .2s; }
.ce-about__cta .btn--primary:hover { background: #0a2553; }
.ce-about__cta .btn--ghost-dark { color: var(--ce-primary); padding: 13px 28px; border: 1.5px solid var(--ce-primary); border-radius: 4px; text-decoration: none; font-weight: 600; transition: .2s; }
.ce-about__cta .btn--ghost-dark:hover { background: var(--ce-primary); color: #fff; }

.ce-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 0; }
.ce-stat { background: #fff; padding: 28px 24px; border-radius: 6px; border: 1px solid #e6ebf2; box-shadow: 0 4px 16px rgba(11,42,91,.04); }
.ce-stat dt { font-family: Inter, sans-serif; font-size: 11px; font-weight: 700; letter-spacing: .2em; color: var(--ce-accent); margin-bottom: 6px; }
.ce-stat dd { font-family: Inter, sans-serif; font-size: 32px; font-weight: 800; color: var(--ce-primary); margin: 0 0 8px; line-height: 1; }
.ce-stat p { font-size: 16px; line-height: 1.5; color: #6b7480; margin: 0; }
.ce-stat--accent { background: var(--ce-primary); color: #fff; border-color: transparent; }
.ce-stat--accent dt { color: #ffc2c7; }
.ce-stat--accent dd { color: #fff; }
.ce-stat--accent p { color: rgba(255,255,255,.78); }
@media (max-width: 900px) { .ce-about { grid-template-columns: 1fr; } }

/* Business cards */
.ce-section--business { background: #fff; }
.ce-cards { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.ce-card { background: #fff; border: 1px solid #e6ebf2; border-radius: 8px; transition: .25s; position: relative; overflow: hidden; display: flex; flex-direction: column; }
.ce-card::before { content: ''; position: absolute; left: 0; top: 0; width: 4px; height: 0; background: var(--ce-accent); transition: height .3s; z-index: 2; }
.ce-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(11,42,91,.14); border-color: var(--ce-primary); }
.ce-card:hover::before { height: 100%; }
.ce-card__media { display: block; width: 100%; aspect-ratio: 4 / 3; overflow: hidden; background: #f1f4f8; }
.ce-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; display: block; }
.ce-card:hover .ce-card__media img { transform: scale(1.06); }
.ce-card__body { padding: 24px 26px 26px; flex: 1; display: flex; flex-direction: column; }
.ce-card__num { font-family: Inter, sans-serif; font-size: 13px; font-weight: 700; letter-spacing: .2em; color: var(--ce-accent); margin: 0 0 12px; }
.ce-card__title { font-size: 22px; font-weight: 500; color: var(--ce-primary); margin: 0 0 10px; line-height: 1.35; }
.ce-card__desc { font-size: 14px; line-height: 1.6; color: #6b7480; margin: 0 0 22px; min-height: 44px; flex: 1; }
.ce-card__link { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--ce-primary); text-decoration: none; align-self: flex-start; }
.ce-card__link .arrow { transition: transform .2s; }
.ce-card__link:hover .arrow { transform: translateX(4px); }
@media (max-width: 1024px) { .ce-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .ce-cards { grid-template-columns: 1fr; } }

/* News grid */
.ce-section--news { background: #f5f7fa; }
.ce-news-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 24px; }
.ce-news-col { background: #fff; padding: 28px; border-radius: 6px; border: 1px solid #e6ebf2; }
.ce-news-col__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 18px; padding-bottom: 14px; border-bottom: 2px solid var(--ce-primary); }
.ce-news-col__head h3 { font-size: 19px; font-weight: 700; color: var(--ce-primary); margin: 0; }
.ce-news-col__head a { font-size: 13px; color: #6b7480; text-decoration: none; }
.ce-news-col__head a:hover { color: var(--ce-accent); }
.ce-news-list { list-style: none; padding: 0; margin: 0; }
.ce-news-list li { border-bottom: 1px solid #f0f3f7; }
.ce-news-list li:last-child { border-bottom: 0; }
.ce-news-list a { display: flex; justify-content: space-between; gap: 12px; padding: 12px 0; text-decoration: none; color: #2b323a; font-size: 14px; }
.ce-news-list a:hover .ce-news-list__title { color: var(--ce-accent); }
.ce-news-list__title { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; transition: color .15s; }
.ce-news-list__date { color: #9aa3b0; font-size: 12px; flex-shrink: 0; }
.ce-news-list__empty { padding: 24px 0; color: #9aa3b0; text-align: center; font-size: 14px; }
.ce-news-cta { background: linear-gradient(135deg, var(--ce-primary), #1a3d75); color: #fff; padding: 36px 30px; border-radius: 6px; display: flex; flex-direction: column; justify-content: center; }
.ce-news-cta h3 { font-size: 24px; font-weight: 700; margin: 0 0 10px; color: #fff; }
.ce-news-cta p { font-size: 14px; line-height: 1.5; opacity: .85; margin: 0 0 22px; }
.ce-news-cta .btn--light { display: inline-block; background: #fff; color: var(--ce-primary); padding: 12px 24px; border-radius: 4px; text-decoration: none; font-weight: 700; text-align: center; transition: .2s; }
.ce-news-cta .btn--light:hover { background: var(--ce-yellow); }
@media (max-width: 900px) { .ce-news-grid { grid-template-columns: 1fr; } }

/* Slider behavior helper (will be controlled by JS in main.js or inline) */

/* =========================================================
 * About-section pages (greeting, vision, history, organization,
 * clients, reviews, pride, location) — shared design language
 * ========================================================= */
.page-body { font-size: 16px; line-height: 1.75; color: #2b323a; }
.page-body h3 { font-size: 24px; color: var(--ce-primary); margin: 36px 0 16px; padding-bottom: 12px; border-bottom: 2px solid var(--ce-primary); }
.page-body h4 { font-size: 18px; color: var(--ce-primary); margin: 24px 0 12px; }
.page-body ul { padding-left: 20px; }
.page-body ul li { margin: 6px 0; }
.page-body em { font-style: italic; color: #475061; }
.page-body .ce-lead { font-size: 18px; line-height: 1.7; color: #475061; margin: 0 0 32px; }
.page-body .ce-meta { font-size: 13px; color: #9aa3b0; margin-top: 24px; }
.page-body blockquote { border-left: 4px solid var(--ce-accent); padding: 16px 20px; margin: 16px 0; background: #f8fafc; color: #2b323a; }

/* === 인사말 === */
/* PC line-break helper — visible only on desktop for visual rhythm */
.pc-br { display: none; }
@media (min-width: 768px) { .pc-br { display: inline; } }

.ce-greet-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #0a1f48 0%, var(--ce-primary) 45%, #1a3d75 100%);
  color: #fff;
  padding: 80px 40px;
  border-radius: 10px;
  margin-bottom: 40px;
  text-align: center;
  isolation: isolate;
}
.ce-greet-hero::after {
  /* subtle radial vignette */
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,0.35) 100%);
  pointer-events: none;
  z-index: 0;
}
.ce-greet-hero__bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  z-index: 0;
  pointer-events: none;
}
.ce-greet-hero__quote {
  position: relative;
  z-index: 2;
  font-size: clamp(18px, 2.4vw, 26px);
  font-weight: 500;
  line-height: 1.65;
  color: #ffc2c7;
  margin: 0;
  letter-spacing: -.01em;
  text-shadow: 0 2px 8px rgba(0,0,0,0.3);
}

/* SVG buildings: very subtle base, no animation */
.ce-greet-hero__buildings rect { transition: opacity .3s; }

/* SVG window lights: random flicker */
.ce-greet-hero__lights circle {
  opacity: 0;
  animation: ce-flicker 4s ease-in-out infinite;
}
.ce-greet-hero__lights circle:nth-child(2n)  { animation-delay: -0.7s; animation-duration: 5.2s; }
.ce-greet-hero__lights circle:nth-child(3n)  { animation-delay: -1.4s; animation-duration: 3.6s; }
.ce-greet-hero__lights circle:nth-child(4n)  { animation-delay: -2.1s; animation-duration: 6.0s; }
.ce-greet-hero__lights circle:nth-child(5n)  { animation-delay: -3.0s; animation-duration: 4.4s; }
@keyframes ce-flicker {
  0%, 100% { opacity: 0.25; }
  35% { opacity: 0.85; }
  60% { opacity: 0.55; }
}

/* SVG network lines: dashed flow + breathing opacity */
.ce-greet-hero__network line {
  stroke-dasharray: 4 5;
  animation: ce-flow 7s linear infinite, ce-fade 5s ease-in-out infinite;
}
.ce-greet-hero__network line:nth-child(2n) { animation-delay: -1s, -2s; animation-duration: 9s, 6s; }
.ce-greet-hero__network line:nth-child(3n) { animation-delay: -2s, -3s; animation-duration: 8s, 4.5s; }
@keyframes ce-flow { to { stroke-dashoffset: -18; } }
@keyframes ce-fade { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }

/* SVG network nodes: pulsing glow */
.ce-greet-hero__nodes circle {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-pulse 3s ease-in-out infinite;
}
.ce-greet-hero__nodes circle:nth-child(2n)  { animation-delay: -0.8s; }
.ce-greet-hero__nodes circle:nth-child(3n)  { animation-delay: -1.5s; }
.ce-greet-hero__nodes circle:nth-child(4n)  { animation-delay: -2.2s; }
@keyframes ce-pulse {
  0%, 100% { opacity: 0.55; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.6); }
}

/* Reduce motion support */
@media (prefers-reduced-motion: reduce) {
  .ce-greet-hero__lights circle,
  .ce-greet-hero__network line,
  .ce-greet-hero__nodes circle { animation: none !important; opacity: .6; }
}

/* === Greeting body two-column layout === */
.ce-greet-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 48px;
  align-items: start;
  margin-bottom: 48px;
}
.ce-greet-body p { margin: 0 0 18px; line-height: 1.85; font-size: 17px; color: #2b323a; }
.ce-greet-body em { color: #475061; font-style: italic; }
.ce-greet-thanks {
  margin-top: 32px !important;
  padding: 20px 24px;
  background: linear-gradient(90deg, rgba(217,35,46,0.04), transparent);
  border-left: 4px solid var(--ce-accent);
  border-radius: 0 6px 6px 0;
  font-size: 17px !important;
  font-weight: 500;
  color: var(--ce-primary);
}
.ce-greet-sign {
  text-align: right;
  margin-top: 28px;
  font-size: 17px;
  color: var(--ce-primary);
  letter-spacing: -.01em;
}
.ce-greet-sign span { font-weight: 400; color: #6b7480; }
.ce-greet-sign strong { font-weight: 700; }

.ce-greet-portrait { position: sticky; top: 100px; }
.ce-greet-portrait figure { margin: 0; }
.ce-greet-portrait img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 8px;
  box-shadow: 0 16px 40px rgba(11,42,91,0.18);
  display: block;
}
.ce-greet-portrait figcaption {
  background: var(--ce-primary);
  color: #fff;
  padding: 18px 22px;
  border-radius: 0 0 8px 8px;
  margin-top: -8px;
  position: relative;
  z-index: 1;
}
.ce-greet-portrait__role { font-family: Inter, sans-serif; font-size: 11px; letter-spacing: .25em; color: #ffc2c7; margin: 0 0 4px; }
.ce-greet-portrait__name { font-size: 22px; font-weight: 700; margin: 0 0 4px; color: #fff; }
.ce-greet-portrait__cred { font-size: 13px; color: rgba(255,255,255,0.78); margin: 0; }

@media (max-width: 900px) {
  .ce-greet-hero { padding: 56px 28px; }
  .ce-greet-layout { grid-template-columns: 1fr; gap: 28px; }
  .ce-greet-portrait { position: static; max-width: 320px; margin: 0 auto; }
  .ce-greet-body p { font-size: 16px; line-height: 1.8; }
}
@media (max-width: 560px) {
  .ce-greet-hero { padding: 44px 22px; border-radius: 8px; }
  .ce-greet-hero__quote { font-size: 17px; }
  .ce-greet-body p { font-size: 15.5px; }
  .ce-greet-thanks { padding: 16px 18px; font-size: 16px !important; }
  .ce-greet-sign { font-size: 16px; }
}

/* === CEO Profile section === */
.ce-profile { background: #f5f7fa; border-radius: 10px; padding: 36px 40px; margin-top: 48px; }
.ce-profile__head { display: grid; grid-template-columns: 96px 1fr; gap: 22px; align-items: center; margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid #e6ebf2; }
.ce-profile__head img { width: 96px; height: 96px; border-radius: 50%; object-fit: cover; box-shadow: 0 4px 14px rgba(11,42,91,0.12); }
.ce-profile__head h3 { font-size: 22px; margin: 0 0 4px; padding: 0; border: 0; color: var(--ce-primary); }
.ce-profile__eyebrow { font-family: Inter, sans-serif; font-size: 11px; letter-spacing: .25em; color: var(--ce-accent); margin: 0 0 6px; font-weight: 700; }
.ce-profile__lead { font-size: 14px; color: #6b7480; margin: 0; }
.ce-profile-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.ce-profile-grid h4 { color: var(--ce-accent); font-size: 13px; letter-spacing: .25em; margin: 0 0 12px; padding: 0; border: 0; font-weight: 700; }
.ce-profile-grid ul { padding: 0; list-style: none; font-size: 14px; line-height: 1.65; color: #475061; }
.ce-profile-grid ul li { padding: 6px 0; border-bottom: 1px dashed #d6dce5; }
.ce-profile-grid ul li:last-child { border-bottom: 0; }
@media (max-width: 900px) {
  .ce-profile { padding: 28px 24px; }
  .ce-profile__head { grid-template-columns: 80px 1fr; gap: 16px; }
  .ce-profile__head img { width: 80px; height: 80px; }
  .ce-profile-grid { grid-template-columns: 1fr; gap: 24px; }
}

/* === Business Overview (business/magnet) === */
.ce-biz-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #07173d 0%, var(--ce-primary) 45%, #1a3d75 100%);
  color: #fff;
  padding: 110px 40px;
  border-radius: 10px;
  margin-bottom: 0;
  text-align: center;
  isolation: isolate;
}
.ce-biz-hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; opacity: .55; }
/* Dark vignette behind text to ensure contrast over animated SVG */
.ce-biz-hero::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 70% at center, rgba(0,0,0,.55) 0%, rgba(0,0,0,.15) 60%, transparent 100%);
  z-index: 1;
  pointer-events: none;
}
.ce-biz-hero__inner { position: relative; z-index: 3; max-width: 980px; margin: 0 auto; }
.ce-biz-hero__eyebrow {
  font-family: Inter, sans-serif;
  font-size: clamp(14px, 1.3vw, 16px);
  font-weight: 700;
  letter-spacing: .3em;
  color: #ffd9dd;
  margin: 0 0 22px;
  text-shadow: 0 2px 8px rgba(0,0,0,.45);
}
.ce-biz-hero__title {
  color: #ffffff !important;
  font-size: clamp(30px, 4.6vw, 56px);
  font-weight: 800;
  line-height: 1.32;
  letter-spacing: -.02em;
  margin: 0 0 24px;
  text-shadow:
    0 2px 20px rgba(0,0,0,.7),
    0 1px 2px rgba(0,0,0,.55);
}
.ce-biz-hero__sub {
  font-size: clamp(16px, 1.8vw, 21px);
  color: #ffffff;
  font-weight: 500;
  line-height: 1.7;
  margin: 0;
  text-shadow: 0 2px 12px rgba(0,0,0,.55);
}
.ce-biz-hero__sub strong {
  color: #ffd9dd;
  font-weight: 700;
  border-bottom: 2px solid rgba(255,217,221,.5);
  padding-bottom: 1px;
}

/* SVG animations */
.ce-biz-hero__path {
  stroke-dasharray: 6 6;
  animation: ce-biz-path 8s linear infinite;
}
@keyframes ce-biz-path { to { stroke-dashoffset: -36; } }
.ce-biz-hero__bars rect {
  transform-origin: bottom center;
  transform-box: fill-box;
  animation: ce-biz-bar-rise 3.6s ease-in-out infinite alternate;
}
.ce-biz-hero__bars rect:nth-child(2n) { animation-delay: -0.6s; }
.ce-biz-hero__bars rect:nth-child(3n) { animation-delay: -1.2s; }
.ce-biz-hero__bars rect:nth-child(4n) { animation-delay: -1.8s; }
@keyframes ce-biz-bar-rise { 0% { transform: scaleY(.92); opacity: .55; } 100% { transform: scaleY(1.05); opacity: 1; } }
.ce-biz-hero__nodes circle {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-biz-node-pulse 2.6s ease-in-out infinite;
}
.ce-biz-hero__nodes circle:nth-child(2n) { animation-delay: -0.7s; }
.ce-biz-hero__nodes circle:nth-child(3n) { animation-delay: -1.4s; }
@keyframes ce-biz-node-pulse { 0%, 100% { opacity: .6; transform: scale(1); } 50% { opacity: 1; transform: scale(1.6); } }
.ce-biz-hero__arrow { animation: ce-biz-arrow-bob 2s ease-in-out infinite alternate; transform-origin: center; transform-box: fill-box; }
@keyframes ce-biz-arrow-bob { 0% { transform: translate(1140px, 60px); } 100% { transform: translate(1140px, 50px); } }
@media (prefers-reduced-motion: reduce) {
  .ce-biz-hero__path, .ce-biz-hero__bars rect, .ce-biz-hero__nodes circle, .ce-biz-hero__arrow { animation: none !important; }
}
@media (max-width: 900px) {
  .ce-biz-hero { padding: 80px 28px; }
  .ce-biz-hero__eyebrow { font-size: 13px; letter-spacing: .25em; }
}
@media (max-width: 480px) {
  .ce-biz-hero { padding: 60px 22px; border-radius: 8px; }
  .ce-biz-hero__eyebrow { font-size: 12px; margin-bottom: 16px; }
  .ce-biz-hero__title { font-size: 26px; line-height: 1.4; }
  .ce-biz-hero__sub { font-size: 15px; }
}

.ce-biz-lead {
  font-size: 17px;
  line-height: 1.9;
  color: #2b323a;
  text-align: left;            /* aligns with the section heading */
  max-width: none;
  margin: 0 0 40px;
  padding: 0;
}
.ce-biz-lead strong { color: var(--ce-primary); font-weight: 700; }

/* ====================================================================
 * Business Overview page (business/magnet) — UNIFIED TYPOGRAPHY
 *   중타이틀 (section h3 / card h4) = 22px (PC)
 *   본문 (p / li)                    = 17px (PC)
 *   모바일은 단계별로 축소
 * ==================================================================== */

/* Section headings (h3) — 사업 개요 및 철학 / 왜 CE인가 / 핵심 사업 분야 */
.ce-biz-hero ~ .ce-vision-block .ce-vision-block__head h3,
.ce-biz-hero ~ .ce-vision-stats .ce-vision-block__head h3 {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -.01em;
  line-height: 1.4;
}

/* Card titles (h4) — 모든 카드 제목 22px */
.ce-biz-hero ~ .ce-vision-block .ce-vision-cards h4,
.ce-biz-strengths article h4,
.ce-biz-area h4,
.ce-biz-cta h3 {
  font-size: 22px !important;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -.01em;
}

/* Body text — 본문 17px (CTA p는 별도 18px 규칙 사용) */
.ce-biz-lead,
.ce-biz-hero ~ .ce-vision-block .ce-vision-cards p,
.ce-biz-strengths article p,
.ce-biz-area ul li {
  font-size: 17px;
  line-height: 1.78;
}

/* Mobile (≤768px) */
@media (max-width: 768px) {
  .ce-biz-hero ~ .ce-vision-block .ce-vision-block__head h3,
  .ce-biz-hero ~ .ce-vision-stats .ce-vision-block__head h3,
  .ce-biz-hero ~ .ce-vision-block .ce-vision-cards h4,
  .ce-biz-strengths article h4,
  .ce-biz-area h4 {
    font-size: 20px !important;
  }
  .ce-biz-lead,
  .ce-biz-hero ~ .ce-vision-block .ce-vision-cards p,
  .ce-biz-strengths article p,
  .ce-biz-area ul li {
    font-size: 16px;
    line-height: 1.7;
  }
}

/* Mobile small (≤480px) */
@media (max-width: 480px) {
  .ce-biz-hero ~ .ce-vision-block .ce-vision-block__head h3,
  .ce-biz-hero ~ .ce-vision-stats .ce-vision-block__head h3,
  .ce-biz-hero ~ .ce-vision-block .ce-vision-cards h4,
  .ce-biz-strengths article h4,
  .ce-biz-area h4 {
    font-size: 18px !important;
  }
  .ce-biz-lead,
  .ce-biz-hero ~ .ce-vision-block .ce-vision-cards p,
  .ce-biz-strengths article p,
  .ce-biz-area ul li {
    font-size: 15px;
    line-height: 1.65;
  }
}

/* Strengths grid (3 stat-style cards inside ce-vision-stats wrapper) */
.ce-biz-strengths {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 32px;
}
.ce-biz-strengths article {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 10px;
  padding: 32px 26px;
  transition: .25s;
  text-align: left;
}
.ce-biz-strengths article:hover {
  background: rgba(255,194,199,0.1);
  border-color: rgba(255,194,199,0.4);
  transform: translateY(-3px);
}
.ce-biz-strengths__num {
  font-family: Inter, sans-serif;
  font-size: 44px;
  font-weight: 800;
  color: #ffc2c7;
  letter-spacing: -.03em;
  line-height: 1;
  margin: 0 0 14px;
}
.ce-biz-strengths__num sup { font-size: 22px; vertical-align: top; margin-left: 2px; }
.ce-biz-strengths article h4 {
  font-size: 22px;
  color: #fff;
  margin: 0 0 14px;
  padding: 0;
  border: 0;
  font-weight: 700;
  letter-spacing: -.01em;
}
@media (max-width: 768px) { .ce-biz-strengths article h4 { font-size: 20px; } }
@media (max-width: 480px) { .ce-biz-strengths article h4 { font-size: 19px; } }
.ce-biz-strengths article p {
  font-size: 17px;
  line-height: 1.75;
  color: rgba(255,255,255,0.92);
  margin: 0;
}
.ce-biz-strengths article p strong { color: #ffd9dd; font-weight: 700; }
@media (max-width: 900px) { .ce-biz-strengths { grid-template-columns: 1fr; gap: 14px; } }
@media (max-width: 768px) { .ce-biz-strengths article p { font-size: 16px; line-height: 1.7; } }
@media (max-width: 480px) { .ce-biz-strengths article p { font-size: 15px; line-height: 1.65; } }

/* Key business area cards (4 — link to detailed pages) */
.ce-biz-areas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-top: 24px;
}
.ce-biz-area {
  display: block;
  text-decoration: none;
  background: #fff;
  border: 1px solid #e6ebf2;
  border-radius: 10px;
  padding: 32px 30px;
  transition: .25s;
  position: relative;
  overflow: hidden;
  color: inherit;
}
.ce-biz-area::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--ce-accent);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform .3s;
}
.ce-biz-area:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(11,42,91,0.14);
  border-color: var(--ce-primary);
}
.ce-biz-area:hover::before { transform: scaleY(1); }
.ce-biz-area__num {
  font-family: Inter, sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .25em;
  color: var(--ce-accent);
  margin: 0 0 12px;
}
.ce-biz-area h4 {
  font-size: 22px;
  color: var(--ce-primary);
  margin: 0 0 6px;
  padding: 0;
  border: 0;
  font-weight: 700;
}
.ce-biz-area__en {
  font-family: Inter, sans-serif;
  font-size: 13px;
  color: #6b7480;
  margin: 0 0 16px;
  letter-spacing: -.005em;
}
.ce-biz-area ul {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
}
.ce-biz-area ul li {
  padding: 8px 0 8px 18px;
  position: relative;
  font-size: 17px;
  color: #475061;
  border-bottom: 1px dashed #eef1f5;
  line-height: 1.7;
}
@media (max-width: 768px) { .ce-biz-area ul li { font-size: 16px; line-height: 1.65; padding: 7px 0 7px 16px; } }
@media (max-width: 480px) { .ce-biz-area ul li { font-size: 15px; line-height: 1.6; padding: 6px 0 6px 14px; } }
.ce-biz-area ul li:last-child { border-bottom: 0; }
.ce-biz-area ul li::before {
  content: '·';
  position: absolute;
  left: 4px;
  color: var(--ce-accent);
  font-weight: 800;
  font-size: 18px;
  line-height: 1;
}
.ce-biz-area__more {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  color: var(--ce-primary);
  letter-spacing: -.01em;
  transition: transform .2s;
}
.ce-biz-area:hover .ce-biz-area__more { transform: translateX(4px); color: var(--ce-accent); }
@media (max-width: 768px) { .ce-biz-areas { grid-template-columns: 1fr; gap: 16px; } }

/* CTA at bottom — Title 22 / Body 18 / Pill 20 (PC) */
.ce-biz-cta {
  margin: 48px 0 0;
  padding: 40px 32px;
  background: linear-gradient(135deg, #f8fafc, #eef2f7);
  border-radius: 12px;
  border: 1px solid #e6ebf2;
  text-align: center;
}
.ce-biz-cta h3 {
  font-size: 22px;
  color: var(--ce-primary);
  margin: 0 0 12px;
  padding: 0;
  border: 0;
  font-weight: 700;
  letter-spacing: -.01em;
}
.ce-biz-cta p {
  font-size: 18px;
  color: #475061;
  margin: 0 0 26px;
  line-height: 1.72;
}
.ce-biz-cta__links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.ce-biz-cta__links a {
  display: inline-block;
  padding: 12px 26px;
  background: #fff;
  color: var(--ce-primary);
  border: 1px solid #d6dce5;
  border-radius: 999px;
  font-size: 20px;
  font-weight: 700;
  text-decoration: none;
  letter-spacing: -.01em;
  transition: .2s;
}
.ce-biz-cta__links a:hover {
  background: var(--ce-primary);
  color: #fff;
  border-color: var(--ce-primary);
  transform: translateY(-2px);
}

/* Tablet (≤768px) */
@media (max-width: 768px) {
  .ce-biz-cta { padding: 32px 24px; }
  .ce-biz-cta h3 { font-size: 20px; }
  .ce-biz-cta p { font-size: 16px; line-height: 1.68; margin-bottom: 22px; }
  .ce-biz-cta__links { gap: 8px; }
  .ce-biz-cta__links a { font-size: 17px; padding: 10px 22px; }
}
/* Mobile (≤480px) */
@media (max-width: 480px) {
  .ce-biz-cta { padding: 26px 18px; }
  .ce-biz-cta h3 { font-size: 18px; }
  .ce-biz-cta p { font-size: 15px; line-height: 1.62; margin-bottom: 20px; }
  .ce-biz-cta__links { gap: 8px; }
  .ce-biz-cta__links a { font-size: 15px; padding: 9px 18px; font-weight: 600; }
}

/* === Management Consulting page — 5 stripe service cards === */
.ce-mgmt-services {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 24px;
}
.ce-mgmt-service {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 28px;
  background: #fff;
  border: 1px solid #e6ebf2;
  border-radius: 10px;
  padding: 28px 30px;
  align-items: start;
  transition: .25s;
  position: relative;
  overflow: hidden;
}
.ce-mgmt-service::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--ce-accent);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform .3s;
}
.ce-mgmt-service:hover {
  transform: translateX(4px);
  box-shadow: 0 12px 32px rgba(11,42,91,0.1);
  border-color: var(--ce-primary);
}
.ce-mgmt-service:hover::before { transform: scaleY(1); }
.ce-mgmt-service__num {
  font-family: Inter, sans-serif;
  font-size: 56px;
  font-weight: 800;
  color: var(--ce-accent);
  letter-spacing: -.04em;
  line-height: 1;
  margin: 0;
  text-align: center;
}
.ce-mgmt-service__body { padding-top: 4px; }
.ce-mgmt-service__body h4 {
  font-size: 22px !important;
  color: var(--ce-primary);
  margin: 0 0 4px;
  padding: 0;
  border: 0;
  font-weight: 700;
  letter-spacing: -.01em;
}
.ce-mgmt-service__en {
  font-family: Inter, sans-serif;
  font-size: 14px;
  color: #6b7480;
  margin: 0 0 14px;
  letter-spacing: -.005em;
}
.ce-mgmt-service__body ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ce-mgmt-service__body ul li {
  position: relative;
  padding: 8px 0 8px 18px;
  font-size: 17px;
  line-height: 1.7;
  color: #475061;
  border-bottom: 1px dashed #eef1f5;
}
.ce-mgmt-service__body ul li:last-child { border-bottom: 0; }
.ce-mgmt-service__body ul li::before {
  content: '·';
  position: absolute;
  left: 4px;
  color: var(--ce-accent);
  font-weight: 800;
  font-size: 18px;
  line-height: 1;
}

/* Mobile (≤768px) */
@media (max-width: 768px) {
  .ce-mgmt-service { grid-template-columns: 64px 1fr; gap: 18px; padding: 22px 22px; }
  .ce-mgmt-service__num { font-size: 36px; }
  .ce-mgmt-service__body h4 { font-size: 20px !important; }
  .ce-mgmt-service__en { font-size: 13px; margin-bottom: 10px; }
  .ce-mgmt-service__body ul li { font-size: 16px; line-height: 1.65; padding: 7px 0 7px 16px; }
}
@media (max-width: 480px) {
  .ce-mgmt-service { grid-template-columns: 1fr; gap: 8px; padding: 20px 18px; }
  .ce-mgmt-service__num { text-align: left; font-size: 28px; }
  .ce-mgmt-service__body h4 { font-size: 18px !important; }
  .ce-mgmt-service__body ul li { font-size: 15px; line-height: 1.6; }
}

/* Management hero — strategic compass animations */
.ce-mgmt-hero__core { animation: ce-mgmt-core-breathe 4s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
@keyframes ce-mgmt-core-breathe { 0%, 100% { opacity: .55; } 50% { opacity: 1; } }
.ce-mgmt-hero__orbits circle { animation: ce-mgmt-orbit 80s linear infinite; transform-origin: 600px 180px; }
.ce-mgmt-hero__orbits circle:nth-child(2) { animation-duration: 110s; animation-direction: reverse; }
.ce-mgmt-hero__orbits circle:nth-child(3) { animation-duration: 150s; }
@keyframes ce-mgmt-orbit { to { transform: rotate(360deg); } }
.ce-mgmt-hero__nodes circle { animation: ce-mgmt-node-pulse 3s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
.ce-mgmt-hero__nodes circle:nth-child(2) { animation-delay: -0.6s; }
.ce-mgmt-hero__nodes circle:nth-child(3) { animation-delay: -1.2s; }
.ce-mgmt-hero__nodes circle:nth-child(4) { animation-delay: -1.8s; }
.ce-mgmt-hero__nodes circle:nth-child(5) { animation-delay: -2.4s; }
@keyframes ce-mgmt-node-pulse { 0%, 100% { opacity: .55; transform: scale(1); } 50% { opacity: 1; transform: scale(1.4); } }
.ce-mgmt-hero__links line { animation: ce-mgmt-link-flow 6s linear infinite; }
.ce-mgmt-hero__links line:nth-child(2n) { animation-direction: reverse; animation-duration: 8s; }
@keyframes ce-mgmt-link-flow { to { stroke-dashoffset: -20; } }
.ce-mgmt-hero__compass { animation: ce-mgmt-compass-spin 18s linear infinite; transform-origin: 600px 180px; }
@keyframes ce-mgmt-compass-spin { to { transform: translate(600px, 180px) rotate(360deg); } }
@media (prefers-reduced-motion: reduce) {
  .ce-mgmt-hero__core, .ce-mgmt-hero__orbits circle, .ce-mgmt-hero__nodes circle, .ce-mgmt-hero__links line, .ce-mgmt-hero__compass { animation: none !important; }
}

/* Apply same unified typography rules to mgmt page (using ce-biz-* classes already covers most) */
.ce-mgmt-strengths-wrap .ce-vision-block__head h3 { font-size: 22px; font-weight: 700; }

/* === Technology Consulting page — gear cluster animations === */
.ce-tech-hero__gear { transform-origin: center; transform-box: fill-box; }
.ce-tech-hero__gear--1 { animation: ce-tech-gear-cw 18s linear infinite; }
.ce-tech-hero__gear--2 { animation: ce-tech-gear-ccw 14s linear infinite; }
.ce-tech-hero__gear--3 { animation: ce-tech-gear-cw 11s linear infinite; }
@keyframes ce-tech-gear-cw  { to { transform: rotate(360deg); } }
@keyframes ce-tech-gear-ccw { to { transform: rotate(-360deg); } }

/* Conveyor items moving left to right */
.ce-tech-hero__items rect { animation: ce-tech-conveyor 8s linear infinite; transform-origin: center; transform-box: fill-box; }
@keyframes ce-tech-conveyor {
  0% { transform: translateX(0); opacity: 0; }
  10% { opacity: 1; }
  90% { opacity: 1; }
  100% { transform: translateX(160px); opacity: 0; }
}
.ce-tech-hero__items rect:nth-child(2) { animation-delay: -1s; }
.ce-tech-hero__items rect:nth-child(3) { animation-delay: -2s; }
.ce-tech-hero__items rect:nth-child(4) { animation-delay: -3s; }
.ce-tech-hero__items rect:nth-child(5) { animation-delay: -4s; }
.ce-tech-hero__items rect:nth-child(6) { animation-delay: -5s; }
.ce-tech-hero__items rect:nth-child(7) { animation-delay: -6s; }

/* Top connector nodes pulse */
.ce-tech-hero__nodes circle { transform-origin: center; transform-box: fill-box; animation: ce-tech-node-pulse 2.4s ease-in-out infinite; }
.ce-tech-hero__nodes circle:nth-child(2n) { animation-delay: -0.6s; }
.ce-tech-hero__nodes circle:nth-child(3n) { animation-delay: -1.2s; }
@keyframes ce-tech-node-pulse { 0%, 100% { opacity: .5; transform: scale(1); } 50% { opacity: 1; transform: scale(1.5); } }

/* Data flow dashed lines (top corners → gears) */
.ce-tech-hero__data line { stroke-dasharray: 3 5; animation: ce-tech-data-flow 5s linear infinite; }
@keyframes ce-tech-data-flow { to { stroke-dashoffset: -16; } }

@media (prefers-reduced-motion: reduce) {
  .ce-tech-hero__gear, .ce-tech-hero__items rect, .ce-tech-hero__nodes circle, .ce-tech-hero__data line { animation: none !important; }
}

/* ZERO/MAX accent inside hero title */
.ce-tech-hero__zero {
  display: inline-block;
  background: linear-gradient(135deg, #ffd9dd, #ffc2c7);
  color: var(--ce-primary);
  padding: 0 12px;
  border-radius: 6px;
  margin: 0 4px;
  letter-spacing: -.01em;
  text-shadow: none;
  font-weight: 800;
}
.ce-tech-hero__max {
  display: inline-block;
  background: linear-gradient(135deg, #6BFFB8, #34d399);
  color: #07173d;
  padding: 0 12px;
  border-radius: 6px;
  margin: 0 4px;
  letter-spacing: -.01em;
  text-shadow: none;
  font-weight: 800;
}
@media (max-width: 480px) {
  .ce-tech-hero__zero, .ce-tech-hero__max { padding: 0 8px; margin: 0 2px; }
}

/* === 경영이념 (vision) — redesigned === */

/* Hero with animated SVG */
.ce-vision-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #07173d 0%, var(--ce-primary) 40%, #1a3d75 100%);
  color: #fff;
  padding: 90px 40px;
  border-radius: 10px;
  margin-bottom: 0;
  text-align: center;
  isolation: isolate;
}
.ce-vision-hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; }
.ce-vision-hero__inner { position: relative; z-index: 2; }
.ce-vision-hero__eyebrow { font-family: Inter, sans-serif; font-size: 13px; letter-spacing: .3em; color: #ffc2c7; margin: 0 0 18px; }
.ce-vision-hero h2 { color: #fff; font-size: clamp(22px, 3.2vw, 36px); font-weight: 300; line-height: 1.45; letter-spacing: -.02em; border: 0; padding: 0; margin: 0; }
.ce-vision-hero h2 strong { font-weight: 800; color: #ffc2c7; }
.ce-vision-hero__tag { font-size: clamp(14px, 1.4vw, 16px); color: rgba(255,255,255,.85); margin: 16px 0 0; }

/* Hero animations */
.ce-vision-hero__glow { animation: ce-glow-breath 4s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
.ce-vision-hero__orbits circle { animation: ce-orbit-rotate 60s linear infinite; transform-origin: 600px 160px; }
.ce-vision-hero__orbits circle:nth-child(2) { animation-duration: 90s; animation-direction: reverse; }
.ce-vision-hero__orbits circle:nth-child(3) { animation-duration: 120s; }
.ce-vision-hero__symbol { animation: ce-float 5s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
.ce-vision-hero__symbol:nth-child(2) { animation-delay: -1.5s; animation-duration: 6s; }
.ce-vision-hero__symbol:nth-child(3) { animation-delay: -3s; animation-duration: 7s; }
.ce-vision-hero__links line { stroke-dasharray: 4 6; animation: ce-flow-slow 10s linear infinite; }
.ce-vision-hero__links line:nth-child(2n) { animation-duration: 14s; animation-direction: reverse; }
.ce-vision-hero__people g { animation: ce-people-bob 3.5s ease-in-out infinite; transform-origin: center bottom; transform-box: fill-box; }
.ce-vision-hero__people g:nth-child(2) { animation-delay: -1s; }
.ce-vision-hero__people g:nth-child(3) { animation-delay: -2s; }
.ce-vision-hero__people g:nth-child(4) { animation-delay: -1.5s; }

@keyframes ce-glow-breath { 0%, 100% { opacity: 0.5; transform: scale(1); } 50% { opacity: 1; transform: scale(1.15); } }
@keyframes ce-orbit-rotate { to { transform: rotate(360deg); } }
@keyframes ce-float { 0%, 100% { transform: translateY(0); opacity: 0.5; } 50% { transform: translateY(-10px); opacity: 0.8; } }
@keyframes ce-flow-slow { to { stroke-dashoffset: -20; } }
@keyframes ce-people-bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
@media (prefers-reduced-motion: reduce) {
  .ce-vision-hero__glow, .ce-vision-hero__orbits circle, .ce-vision-hero__symbol,
  .ce-vision-hero__links line, .ce-vision-hero__people g { animation: none !important; }
}
@media (max-width: 900px) {
  .ce-vision-hero { padding: 60px 24px; border-radius: 8px; }
}
@media (max-width: 560px) {
  .ce-vision-hero { padding: 48px 20px; }
}

/* Vision Slogan section */
.ce-vision-slogan {
  position: relative;
  background: linear-gradient(180deg, #f5f7fa, #fff);
  border: 1px solid #e6ebf2;
  border-radius: 10px;
  padding: 48px 40px;
  margin: 28px 0 56px;
  overflow: hidden;
  text-align: center;
}
.ce-vision-slogan__bg { position: absolute; inset: 0; opacity: .55; pointer-events: none; }
.ce-vision-slogan__bg svg { width: 100%; height: 100%; }
.ce-vision-slogan__rays line { animation: ce-rays-drift 18s linear infinite; }
@keyframes ce-rays-drift { 0% { transform: translateX(0); } 100% { transform: translateX(-40px); } }
.ce-vision-slogan__inner { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 8px; }
.ce-vision-slogan__label { font-family: Inter, sans-serif; font-size: 12px; letter-spacing: .35em; color: var(--ce-accent); margin: 0; font-weight: 700; }
.ce-vision-slogan__main { font-family: Inter, 'Spoqa Han Sans Neo', sans-serif; font-size: clamp(28px, 4.5vw, 48px); font-weight: 700; color: var(--ce-primary); letter-spacing: -.02em; margin: 8px 0 4px; padding: 0; border: 0; }
.ce-vision-slogan__sub { font-size: clamp(15px, 1.5vw, 18px); color: #475061; margin: 0; font-weight: 500; }
.ce-vision-slogan__bars { display: inline-flex; align-items: flex-end; gap: 8px; height: 60px; margin-top: 16px; }
.ce-vision-slogan__bars span {
  width: 18px;
  height: var(--h);
  background: linear-gradient(180deg, var(--ce-accent), #0066cc);
  border-radius: 3px 3px 0 0;
  display: block;
  animation: ce-bar-rise 2.5s ease-in-out infinite alternate;
  transform-origin: bottom center;
}
.ce-vision-slogan__bars span:nth-child(1) { background: linear-gradient(180deg, #1e88ff, #0050b3); animation-delay: -0.0s; }
.ce-vision-slogan__bars span:nth-child(2) { background: linear-gradient(180deg, #20c997, #0d9488); animation-delay: -0.6s; }
.ce-vision-slogan__bars span:nth-child(3) { background: linear-gradient(180deg, #4ade80, #16a34a); animation-delay: -1.2s; }
.ce-vision-slogan__bars span:nth-child(4) { background: linear-gradient(180deg, #fb923c, #ea580c); animation-delay: -1.8s; }
@keyframes ce-bar-rise { 0% { transform: scaleY(.85); } 100% { transform: scaleY(1.0); } }
@media (prefers-reduced-motion: reduce) {
  .ce-vision-slogan__rays line, .ce-vision-slogan__bars span { animation: none !important; }
}

/* Vision Block (generic section wrapper) */
.ce-vision-block { margin: 56px 0; }
.ce-vision-block__head { margin-bottom: 28px; padding: 0; border: 0; }
.ce-vision-block__head--center { text-align: center; }
.ce-vision-block__label { font-family: Inter, sans-serif; font-size: 12px; letter-spacing: .3em; color: var(--ce-accent); margin: 0 0 8px; font-weight: 700; }
.ce-vision-block__head h3 { font-size: clamp(22px, 2.6vw, 28px); color: var(--ce-primary); margin: 0; padding: 0; border: 0; letter-spacing: -.02em; }

/* Core Values Cards */
.ce-vision-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin: 0; }
.ce-vision-cards > div { background: #fff; border: 1px solid #e6ebf2; border-radius: 8px; padding: 32px 28px; transition: .2s; position: relative; overflow: hidden; }
.ce-vision-cards > div::before { content: ''; position: absolute; left: 0; top: 0; width: 100%; height: 4px; background: var(--ce-accent); transform: scaleX(0); transform-origin: left; transition: transform .3s; }
.ce-vision-cards > div:hover { transform: translateY(-3px); box-shadow: 0 16px 36px rgba(11,42,91,.12); border-color: var(--ce-primary); }
.ce-vision-cards > div:hover::before { transform: scaleX(1); }
.ce-vision-cards__num { font-family: Inter, sans-serif; font-size: 13px; font-weight: 700; letter-spacing: .25em; color: var(--ce-accent); margin: 0 0 12px; }
.ce-vision-cards h4 { font-size: 22px; color: var(--ce-primary); margin: 0 0 14px; padding: 0; border: 0; font-weight: 700; }
.ce-vision-cards p { font-size: 15px; line-height: 1.7; color: #475061; margin: 0; }
@media (max-width: 900px) { .ce-vision-cards { grid-template-columns: 1fr; gap: 14px; } }

/* Code of Conduct */
.ce-conduct { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.ce-conduct > div {
  position: relative;
  background: linear-gradient(160deg, #fff, #f8fafc);
  border: 1px solid #e6ebf2;
  border-radius: 8px;
  padding: 28px 22px 24px;
  transition: .25s;
  overflow: hidden;
}
.ce-conduct > div::after {
  content: '';
  position: absolute;
  right: -24px;
  bottom: -24px;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: rgba(217,35,46,0.07);
  transition: transform .3s;
}
.ce-conduct > div:hover { transform: translateY(-4px); border-color: var(--ce-accent); box-shadow: 0 14px 32px rgba(217,35,46,.1); }
.ce-conduct > div:hover::after { transform: scale(1.5); }
.ce-conduct span {
  font-family: Inter, sans-serif;
  font-size: 28px;
  font-weight: 800;
  color: var(--ce-accent);
  display: block;
  margin-bottom: 14px;
  letter-spacing: -.02em;
}
.ce-conduct p { margin: 0; font-size: 15px; line-height: 1.65; color: #2b323a; position: relative; z-index: 1; }
.ce-conduct strong { color: var(--ce-primary); font-weight: 700; }
@media (max-width: 900px) { .ce-conduct { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .ce-conduct { grid-template-columns: 1fr; } }

/* Stats grid */
.ce-vision-stats {
  background: linear-gradient(135deg, var(--ce-primary), #1a3d75);
  border-radius: 12px;
  padding: 56px 40px;
  margin: 56px 0;
  color: #fff;
}
.ce-vision-stats .ce-vision-block__head h3 { color: #fff; }
.ce-vision-stats .ce-vision-block__label { color: #ffc2c7; }
.ce-vision-stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 32px; }
.ce-vision-stats__grid > div {
  text-align: center;
  padding: 24px 16px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: rgba(255,255,255,.04);
  transition: .25s;
}
.ce-vision-stats__grid > div:hover { background: rgba(255,194,199,.1); border-color: rgba(255,194,199,.3); transform: translateY(-3px); }
.ce-vision-stats__grid strong {
  display: block;
  font-family: Inter, sans-serif;
  font-size: clamp(28px, 3.6vw, 40px);
  font-weight: 800;
  color: #ffc2c7;
  letter-spacing: -.02em;
  margin-bottom: 8px;
  line-height: 1;
}
.ce-vision-stats__grid span { font-size: 14px; color: rgba(255,255,255,.85); line-height: 1.55; }
@media (max-width: 900px) {
  .ce-vision-stats { padding: 36px 24px; }
  .ce-vision-stats__grid { grid-template-columns: 1fr 1fr; gap: 14px; }
}
@media (max-width: 480px) {
  .ce-vision-stats__grid { grid-template-columns: 1fr; }
}

/* CI Section */
.ce-vision-ci { margin-top: 56px; }
.ce-ci-grid { display: grid; grid-template-columns: 320px 1fr; gap: 48px; align-items: start; }
.ce-ci-grid__logo {
  background: #fff;
  border: 1px solid #e6ebf2;
  border-radius: 10px;
  padding: 36px 32px;
  text-align: center;
  position: sticky;
  top: 100px;
}
.ce-ci-grid__logo img {
  width: 100%;
  max-width: 200px;
  height: auto;
  display: block;
  margin: 0 auto 18px;
  border-radius: 4px;
}
.ce-ci-grid__caption { font-size: 13px; color: #6b7480; margin: 0; line-height: 1.55; }
.ce-ci-grid__text article {
  background: #f8fafc;
  border-left: 4px solid var(--ce-primary);
  border-radius: 0 8px 8px 0;
  padding: 22px 26px;
  margin-bottom: 16px;
}
.ce-ci-grid__text article:nth-child(2) { border-left-color: var(--ce-accent); }
.ce-ci-grid__text article:nth-child(3) { border-left-color: #0066cc; }
.ce-ci-grid__text h4 {
  font-size: 18px;
  color: var(--ce-primary);
  margin: 0 0 10px;
  padding: 0;
  border: 0;
  letter-spacing: -.01em;
}
.ce-ci-grid__text p { font-size: 15px; line-height: 1.75; color: #2b323a; margin: 0; }
@media (max-width: 900px) {
  .ce-ci-grid { grid-template-columns: 1fr; gap: 24px; }
  .ce-ci-grid__logo { position: static; max-width: 320px; margin: 0 auto; }
}

/* === 연혁 (history timeline) — redesigned === */
.ce-history-legend { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: #9aa3b0; margin-left: 10px; }
.ce-history-legend i { display: inline-block; width: 8px; height: 8px; border-radius: 2px; background: var(--ce-accent); }

.ce-timeline {
  position: relative;
  padding-left: 38px;
  margin-top: 40px;
}
.ce-timeline::before {
  content: '';
  position: absolute;
  left: 11px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--ce-accent) 0%, var(--ce-primary) 50%, #6b7480 100%);
}
.ce-timeline > section {
  position: relative;
  margin-bottom: 44px;
  padding: 0;
}
.ce-timeline > section::before {
  content: '';
  position: absolute;
  left: -38px;
  top: 7px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: #fff;
  border: 4px solid var(--ce-accent);
  box-shadow: 0 2px 10px rgba(217,35,46,0.28);
  z-index: 1;
}
.ce-timeline > section.ce-timeline-founding::before {
  background: var(--ce-accent);
  border-color: #fff;
  box-shadow: 0 0 0 4px var(--ce-accent), 0 4px 16px rgba(217,35,46,0.45);
}
.ce-timeline > section > h3 {
  font-family: Inter, 'Spoqa Han Sans Neo', sans-serif;
  font-size: 30px;
  font-weight: 800;
  color: var(--ce-primary);
  margin: 0 0 18px;
  padding: 0;
  border: 0;
  letter-spacing: -.02em;
  display: inline-block;
  position: relative;
}
.ce-timeline > section > h3::after {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  background: var(--ce-accent);
  margin-top: 6px;
}
.ce-timeline > section > ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ce-timeline > section > ul > li {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 14px;
  align-items: baseline;
  padding: 10px 14px 10px 0;
  border-bottom: 1px solid #eef1f5;
  transition: background .15s;
}
.ce-timeline > section > ul > li:last-child { border-bottom: 0; }
.ce-timeline > section > ul > li:hover { background: rgba(11,42,91,0.02); }
.ce-timeline > section > ul > li > .m {
  font-family: Inter, sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: #6b7480;
  letter-spacing: .08em;
  text-align: center;
  padding: 4px 0;
  border-right: 2px solid #e6ebf2;
}
.ce-timeline > section > ul > li > p {
  font-size: 15px;
  line-height: 1.65;
  color: #2b323a;
  margin: 0;
}
.ce-timeline > section > ul > li.is-red > .m {
  color: var(--ce-accent);
  border-right-color: var(--ce-accent);
}
.ce-timeline > section > ul > li.is-red > p {
  color: var(--ce-accent);
  font-weight: 700;
}
/* Highlight (presidential award) — extra prominent */
.ce-timeline > section > ul > li.ce-history-highlight {
  background: linear-gradient(90deg, rgba(217,35,46,0.06), transparent);
  border-radius: 6px;
  border-bottom: 0;
  padding: 14px 14px 14px 12px;
  margin-bottom: 4px;
}
.ce-timeline > section > ul > li.ce-history-highlight > p {
  font-size: 17px;
  font-weight: 800;
}
.ce-timeline > section > ul > li.ce-history-highlight > p::before {
  content: '★ ';
  color: var(--ce-accent);
}

/* === Mobile (≤640px): compact, vertical stack inside each row === */
@media (max-width: 640px) {
  .ce-timeline { padding-left: 26px; }
  .ce-timeline::before { left: 7px; }
  .ce-timeline > section::before { left: -26px; width: 18px; height: 18px; border-width: 3px; }
  .ce-timeline > section > h3 { font-size: 24px; }
  .ce-timeline > section > ul > li {
    grid-template-columns: 44px 1fr;
    gap: 10px;
    padding: 8px 0;
  }
  .ce-timeline > section > ul > li > .m {
    font-size: 12px;
    padding: 3px 0;
  }
  .ce-timeline > section > ul > li > p { font-size: 14px; line-height: 1.6; }
  .ce-timeline > section > ul > li.ce-history-highlight > p { font-size: 15px; }
}

@media (max-width: 380px) {
  .ce-timeline { padding-left: 22px; }
  .ce-timeline > section > ul > li {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 10px 0;
  }
  .ce-timeline > section > ul > li > .m {
    text-align: left;
    border-right: 0;
    border-bottom: 1px solid #e6ebf2;
    padding: 0 0 4px;
    width: max-content;
  }
  .ce-timeline > section > ul > li.is-red > .m { border-bottom-color: var(--ce-accent); }
}

/* === 조직구성 (organization chart) — rebuilt with REAL connector elements === */

.ce-orgchart {
  --org-line: #94a3b8;
  --org-line-w: 2px;
  --org-blue: #1e3a8a;
  --org-green: #0d9488;
  --org-brown: #b45309;
  --org-purple: #7c3aed;
  --org-purple-light: #a78bfa;
  --org-side-w: 168px;        /* width of R&D / Branch boxes & their columns */
  margin: 32px 0 48px;
  padding: 36px 24px 40px;
  background: #fafbfd;
  border-radius: 12px;
  border: 1px solid #e6ebf2;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ============ Connector primitives ============ */
.ce-orgchart__vline {
  width: var(--org-line-w);
  background: var(--org-line);
  align-self: center;
  flex-shrink: 0;
  margin: 0;
  padding: 0;
}
.ce-orgchart__vline--6   { height: 6px;  }
.ce-orgchart__vline--12  { height: 12px; }
.ce-orgchart__vline--14  { height: 14px; }
.ce-orgchart__vline--24  { height: 24px; }
.ce-orgchart__vline--32  { height: 32px; }

.ce-orgchart__hline {
  height: var(--org-line-w);
  background: var(--org-line);
  align-self: center;
  flex-shrink: 0;
  margin: 0;
  padding: 0;
}
.ce-orgchart__hline--64   { width: 64px; }
.ce-orgchart__hline--flex { flex: 1; min-width: 30px; max-width: 280px; }

/* Trunk pillar — vertical line that stretches to row height (passes through row center) */
.ce-orgchart__trunk {
  width: var(--org-line-w);
  background: var(--org-line);
  align-self: stretch;
  flex-shrink: 0;
}

/* ============ Boxes (nodes) ============ */
.ce-orgchart__node {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  padding: 12px 18px;
  border-radius: 6px;
  min-height: 48px;
  letter-spacing: -.01em;
  line-height: 1.35;
  box-shadow: 0 4px 14px rgba(0,0,0,0.08);
  transition: transform .2s, box-shadow .2s;
  margin: 0;
}
.ce-orgchart__node:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(0,0,0,0.14); }

.ce-orgchart__node--ceo {
  background: linear-gradient(135deg, var(--org-blue), #1e40af);
  font-size: 16px;
  padding: 16px 36px;
  min-width: 200px;
}
.ce-orgchart__node--sub {
  background: #f1f5f9;
  color: var(--org-blue);
  border: 1.5px dashed #94a3b8;
  box-shadow: none;
  font-size: 13px;
  padding: 10px 18px;
  min-height: 44px;
  font-weight: 700;
}
.ce-orgchart__node--green {
  background: linear-gradient(135deg, #14b8a6, var(--org-green));
  font-size: 15px;
  min-width: 140px;
}
.ce-orgchart__node--brown {
  background: linear-gradient(135deg, #d97706, var(--org-brown));
  width: var(--org-side-w);
  flex-shrink: 0;
}
.ce-orgchart__node--purple {
  background: linear-gradient(135deg, #8b5cf6, var(--org-purple));
  font-size: 14px;
  padding: 12px 16px;
  width: 100%;
  min-height: 56px;
}

/* Subsidiary label (positioned above the box without affecting alignment) */
.ce-orgchart__labeled { position: relative; flex-shrink: 0; }
.ce-orgchart__label {
  position: absolute;
  bottom: calc(100% + 4px);
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  font-family: Inter, sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .2em;
  color: var(--ce-accent);
}

/* ============ Rows ============ */
.ce-orgchart__row {
  display: flex;
  align-items: center;
  justify-content: center;
}
/* Tier 1: CEO must sit at chart center axis. Use 3-col grid: 1fr | CEO | 1fr.
   The right side (subsidiary group) lives in col 3 anchored to its left edge,
   so CEO's center stays exactly at chart center — vline below drops cleanly. */
.ce-orgchart__row--top {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  width: 100%;
  max-width: 880px;
  gap: 0;
}
.ce-orgchart__row--top > .ce-orgchart__node--ceo {
  grid-column: 2;
  justify-self: center;
}
.ce-orgchart__row--top > .ce-orgchart__row-right {
  grid-column: 3;
  justify-self: start;
  display: flex;
  align-items: center;
}

.ce-orgchart__row--bus {
  width: 100%;
  max-width: 880px;
}

/* Lead caption above the org chart — centered */
p.ce-lead:has(+ .ce-orgchart) {
  text-align: center;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
/* Fallback for browsers without :has() — use a class on the lead */
.page-body .ce-lead--center { text-align: center; max-width: 720px; margin-left: auto; margin-right: auto; }

/* ============ Below tier 3 (3-column grid for R&D teams | divisions | empty) ============ */
.ce-orgchart__below3 {
  display: grid;
  grid-template-columns: var(--org-side-w) 1fr var(--org-side-w);
  width: 100%;
  max-width: 880px;
  align-items: start;
  gap: 0;
}
.ce-orgchart__col-side, .ce-orgchart__col-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

/* Divisions: horizontal arm spans 2/3 of width to align with first/last division centers */
.ce-orgchart__divisions-arm {
  width: calc(100% * 2 / 3);
  height: var(--org-line-w);
  background: var(--org-line);
}
.ce-orgchart__divisions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  width: 100%;
  gap: 0;
  align-items: start;
}
.ce-orgchart__division {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 8px;
}
.ce-orgchart__division > .ce-orgchart__node--purple,
.ce-orgchart__division > .ce-orgchart__team--purple {
  width: 100%;
}

/* ============ Team boxes (small) ============ */
.ce-orgchart__team {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 13px;
  font-weight: 500;
  color: var(--org-brown);
  background: #fff;
  border: 1.5px solid var(--org-brown);
  border-radius: 5px;
  padding: 9px 12px;
  min-height: 42px;
  line-height: 1.35;
  width: 100%;
  transition: background .15s;
}
.ce-orgchart__team--purple {
  color: var(--org-purple);
  border-color: var(--org-purple-light);
}
.ce-orgchart__team:hover { background: rgba(180,83,9,.05); }
.ce-orgchart__team--purple:hover { background: rgba(124,58,237,.05); }

/* ============ Mobile (≤900px): stack vertically, hide trunk ============ */
@media (max-width: 900px) {
  .ce-orgchart { padding: 24px 16px; gap: 0; }
  .ce-orgchart__row {
    flex-wrap: wrap;
    width: 100%;
    gap: 12px;
  }
  /* Hide trunk and flex hlines on mobile (no horizontal arms make sense in stacked layout) */
  .ce-orgchart__trunk,
  .ce-orgchart__hline--flex,
  .ce-orgchart__hline--64 { display: none; }
  /* Replace tier1 horizontal layout with vertical stack */
  .ce-orgchart__row--top {
    flex-direction: column;
    gap: 24px;
  }
  /* Subsidiary on mobile: connect with short vline above */
  .ce-orgchart__row--top .ce-orgchart__labeled {
    margin-top: 24px;
    position: relative;
  }
  .ce-orgchart__row--top .ce-orgchart__labeled::before {
    content: '';
    position: absolute;
    top: -24px;
    left: 50%;
    width: var(--org-line-w);
    margin-left: calc(var(--org-line-w) * -0.5);
    height: 24px;
    background: var(--org-line);
  }
  .ce-orgchart__label {
    position: static;
    transform: none;
    display: block;
    margin-bottom: 6px;
  }
  /* Row--bus on mobile: stack the two outer boxes vertically with vlines */
  .ce-orgchart__row--bus {
    flex-direction: column;
    gap: 18px;
    max-width: 280px;
    margin: 0 auto;
  }
  .ce-orgchart__row--bus > .ce-orgchart__node {
    width: 100%;
    max-width: 280px;
  }
  /* Below tier 3: stack as single column */
  .ce-orgchart__below3 {
    grid-template-columns: 1fr;
    max-width: 320px;
    margin: 0 auto;
    gap: 18px;
  }
  .ce-orgchart__col-side--branch { display: none; }
  /* On mobile, the divisions arm becomes a vertical accent only — hide if not needed */
  .ce-orgchart__divisions-arm { display: none; }
  .ce-orgchart__divisions {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .ce-orgchart__division { padding: 0; }
}

/* Expert stats grid */
.ce-org-experts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 16px 0 24px; }
.ce-org-experts > div {
  background: #fff;
  border: 1px solid #e6ebf2;
  border-left: 4px solid var(--ce-accent);
  border-radius: 6px;
  padding: 22px 24px;
  text-align: left;
  transition: transform .2s, box-shadow .2s;
}
.ce-org-experts > div:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(11,42,91,0.1); }
.ce-org-experts__num {
  font-family: Inter, sans-serif;
  font-size: 32px;
  font-weight: 800;
  color: var(--ce-primary);
  letter-spacing: -.02em;
  margin: 0 0 6px;
  line-height: 1;
}
.ce-org-experts__label { font-size: 15px; font-weight: 700; color: var(--ce-primary); margin: 0 0 6px; }
.ce-org-experts__desc { font-size: 13px; color: #6b7480; margin: 0; line-height: 1.55; }
@media (max-width: 700px) { .ce-org-experts { grid-template-columns: 1fr; } }

/* === 주요고객사 (clients with tabs) === */
.ce-clients-tabs { margin: 32px 0 24px; }
.ce-clients-tabs__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0 0 0 0;
  margin-bottom: 24px;
  border-bottom: 2px solid #e6ebf2;
}
.ce-clients-tab {
  appearance: none;
  border: 0;
  background: transparent;
  font: inherit;
  color: #6b7480;
  padding: 12px 22px;
  cursor: pointer;
  font-size: 15px;
  font-weight: 600;
  border-radius: 6px 6px 0 0;
  transition: color .15s, background .15s, border .15s;
  position: relative;
  margin-bottom: -2px;
  border: 2px solid transparent;
  border-bottom: 0;
}
.ce-clients-tab:hover { color: var(--ce-primary); background: #f5f7fa; }
.ce-clients-tab.is-active {
  color: #fff;
  background: var(--ce-primary);
  border-color: var(--ce-primary);
}
.ce-clients-tab.is-active:hover { background: #0a2553; color: #fff; }

.ce-clients-tabs__panels { position: relative; }
.ce-clients-panel {
  display: none;
  animation: ce-fade-in .35s ease;
}
.ce-clients-panel.is-active { display: block; }
@keyframes ce-fade-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

.ce-clients-panel__title {
  font-size: 22px;
  color: var(--ce-primary);
  margin: 0 0 18px;
  padding: 0;
  border: 0;
  font-weight: 700;
}

/* Table on PC */
.ce-clients-table {
  border: 1px solid #e6ebf2;
  border-radius: 8px;
  overflow: hidden;
}
.ce-clients-table table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  line-height: 1.6;
}
.ce-clients-table thead th {
  background: var(--ce-primary);
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: -.01em;
  padding: 12px 14px;
  text-align: left;
  border-bottom: 0;
}
.ce-clients-table thead th:first-child { width: 80px; text-align: center; }
.ce-clients-table thead th:nth-child(2) { width: 200px; }
.ce-clients-table thead th:nth-child(4) { width: 200px; }
.ce-clients-table tbody td {
  padding: 12px 14px;
  border-top: 1px solid #eef1f5;
  vertical-align: top;
  color: #2b323a;
}
.ce-clients-table tbody td:first-child {
  text-align: center;
  font-weight: 700;
  color: var(--ce-accent);
  background: #fff;
  width: 80px;
}
.ce-clients-table tbody td:nth-child(2) {
  font-weight: 600;
  color: var(--ce-primary);
}
.ce-clients-table tbody tr:hover td { background: #f8fafc; }
.ce-clients-table tbody tr.is-year-start td { border-top: 2px solid var(--ce-accent); }
.ce-clients-table tbody tr.is-year-start td:first-child {
  background: linear-gradient(135deg, #fff5f5, #fff);
}

/* === Mobile (≤768px): table → card layout === */
@media (max-width: 768px) {
  .ce-clients-tabs__buttons {
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    border-bottom: 2px solid #e6ebf2;
    padding-bottom: 0;
    margin-bottom: 20px;
  }
  .ce-clients-tab {
    flex-shrink: 0;
    padding: 10px 16px;
    font-size: 14px;
  }
  .ce-clients-panel__title { font-size: 18px; }

  .ce-clients-table { border: 0; border-radius: 0; }
  .ce-clients-table table,
  .ce-clients-table thead,
  .ce-clients-table tbody,
  .ce-clients-table tr,
  .ce-clients-table td { display: block; }
  .ce-clients-table thead { display: none; } /* hide header row, use data-label */
  .ce-clients-table tbody tr {
    background: #fff;
    border: 1px solid #e6ebf2;
    border-radius: 8px;
    padding: 14px 16px;
    margin-bottom: 12px;
    box-shadow: 0 2px 8px rgba(11,42,91,0.04);
  }
  .ce-clients-table tbody tr.is-year-start {
    border-top: 4px solid var(--ce-accent);
  }
  .ce-clients-table tbody td {
    border: 0;
    padding: 6px 0;
    display: grid;
    grid-template-columns: 88px 1fr;
    gap: 12px;
    align-items: baseline;
  }
  .ce-clients-table tbody td:first-child {
    /* Year displayed as a top badge */
    grid-template-columns: 1fr;
    background: transparent !important;
    padding: 0 0 6px;
    margin-bottom: 4px;
    font-size: 16px;
    font-weight: 800;
    color: var(--ce-accent);
    border-bottom: 1px dashed #fbcfe8;
    text-align: left;
    width: auto;
  }
  /* Hide year cell on rows that don't start a new year (continuation rows) */
  .ce-clients-table tbody tr:not(.is-year-start) td:first-child {
    display: none;
  }
  .ce-clients-table tbody td:not(:first-child)::before {
    content: attr(data-label);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    color: #6b7480;
    text-transform: uppercase;
  }
  .ce-clients-table tbody td:nth-child(2) {
    color: var(--ce-primary);
    font-weight: 700;
    font-size: 15px;
  }
}
@media (max-width: 480px) {
  .ce-clients-table tbody td:not(:first-child) {
    grid-template-columns: 70px 1fr;
    gap: 10px;
  }
  .ce-clients-table tbody td:not(:first-child)::before {
    font-size: 10px;
  }
}

/* Pre-existing class still used by some places */
.ce-clients { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; margin: 24px 0; }
.ce-clients article { background: #fff; border: 1px solid #e6ebf2; border-radius: 8px; padding: 26px 24px; }
.ce-clients h4 { color: var(--ce-accent); font-size: 14px; letter-spacing: .15em; margin: 0 0 14px; padding: 0 0 12px; border-bottom: 2px solid var(--ce-primary); }
.ce-clients ul { padding: 0; list-style: none; font-size: 14px; line-height: 1.6; color: #2b323a; }
.ce-clients ul li { padding: 6px 0; border-bottom: 1px dashed #e6ebf2; }
.ce-clients ul li:last-child { border-bottom: 0; }
@media (max-width: 900px) { .ce-clients { grid-template-columns: 1fr; } }

/* === 고객리뷰 (testimonial cards) — redesigned === */
.ce-reviews {
  display: grid;
  grid-template-columns: 1fr;       /* single column for natural reading */
  gap: 28px;
  margin: 32px 0;
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
}
.ce-review {
  position: relative;
  background: #fff;
  border: 1px solid #e6ebf2;
  border-radius: 12px;
  padding: 36px 40px 32px;
  margin: 0;
  box-shadow: 0 4px 20px rgba(11,42,91,0.05);
  transition: transform .2s, box-shadow .2s;
  overflow: hidden;
}
.ce-review:hover { transform: translateY(-3px); box-shadow: 0 14px 36px rgba(11,42,91,0.1); }

/* Decorative left accent ribbon */
.ce-review::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 6px;
  background: linear-gradient(180deg, var(--ce-accent), var(--ce-primary));
  border-radius: 12px 0 0 12px;
}

/* Big quote mark in corner */
.ce-review::after {
  content: '\201C';
  position: absolute;
  top: 12px;
  right: 28px;
  font-size: 110px;
  color: rgba(217,35,46,0.08);
  font-family: Georgia, 'Times New Roman', serif;
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

.ce-review__quote {
  position: relative;
  z-index: 1;
}
.ce-review__quote p {
  font-size: 16px;
  line-height: 1.85;
  color: #2b323a;
  margin: 0 0 14px;
  letter-spacing: -.005em;
}
.ce-review__quote p:last-child { margin-bottom: 0; }
.ce-review__quote em { font-style: italic; color: #6b7480; }
.ce-review__quote strong { color: var(--ce-primary); font-weight: 700; }

.ce-review__cite {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 14px;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px dashed #d6dce5;
  position: relative;
  z-index: 1;
}
.ce-review__cite::before {
  content: '\2014';   /* em dash */
  color: var(--ce-accent);
  font-weight: 700;
  font-size: 18px;
}
.ce-review__cite strong {
  font-size: 16px;
  font-weight: 700;
  color: var(--ce-primary);
}
.ce-review__cite span {
  font-size: 13px;
  color: #6b7480;
  background: #f1f4f8;
  padding: 4px 12px;
  border-radius: 999px;
}

/* === Mobile (≤768px) === */
@media (max-width: 768px) {
  .ce-reviews { gap: 18px; margin: 24px 0; }
  .ce-review {
    padding: 28px 22px 22px;
    border-radius: 10px;
  }
  .ce-review::before { width: 5px; border-radius: 10px 0 0 10px; }
  .ce-review::after { font-size: 80px; top: 8px; right: 18px; }
  .ce-review__quote p { font-size: 15px; line-height: 1.75; }
  .ce-review__cite { gap: 8px; flex-direction: column; align-items: flex-start; padding-top: 16px; margin-top: 18px; }
  .ce-review__cite::before { display: none; }
  .ce-review__cite strong { font-size: 15px; }
  .ce-review__cite span { font-size: 12px; padding: 3px 10px; }
}
@media (max-width: 480px) {
  .ce-review { padding: 24px 18px 20px; }
  .ce-review::after { font-size: 64px; top: 4px; right: 12px; }
  .ce-review__quote p { font-size: 14.5px; }
}

/* === CE의 자랑 === */
.ce-pride { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin: 24px 0; }
.ce-pride__item { background: #fff; border: 1px solid #e6ebf2; border-radius: 8px; padding: 26px 24px; transition: .2s; position: relative; overflow: hidden; }
.ce-pride__item::before { content: ''; position: absolute; left: 0; top: 0; width: 100%; height: 4px; background: var(--ce-accent); transform: scaleX(0); transform-origin: left; transition: transform .25s; }
.ce-pride__item:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(11,42,91,.12); border-color: var(--ce-primary); }
.ce-pride__item:hover::before { transform: scaleX(1); }
.ce-pride__item--accent { background: var(--ce-primary); color: #fff; border-color: transparent; }
.ce-pride__item--accent::before { background: #ffc2c7; transform: scaleX(1); }
.ce-pride__item--accent .ce-pride__num { color: #ffc2c7; }
.ce-pride__item--accent h3 { color: #fff; }
.ce-pride__item--accent p { color: rgba(255,255,255,.85); }
.ce-pride__num { font-family: Inter, sans-serif; font-size: 13px; font-weight: 700; letter-spacing: .2em; color: var(--ce-accent); margin: 0 0 12px; }
.ce-pride__item h3 { font-size: 19px; color: var(--ce-primary); margin: 0 0 12px; padding: 0; border: 0; }
.ce-pride__item p { font-size: 14px; line-height: 1.6; color: #475061; margin: 0; }
@media (max-width: 900px) { .ce-pride { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .ce-pride { grid-template-columns: 1fr; } }

/* === 오시는 길 === */
.ce-location {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 32px;
  margin: 24px 0;
  align-items: stretch;   /* both columns share the same height on PC */
}
.ce-location__map {
  display: flex;
  min-height: 0;          /* allow flex/grid child to shrink properly */
}
.ce-location__map iframe {
  display: block;
  width: 100% !important;
  height: 100% !important;
  min-height: 380px;      /* baseline so map is never too short */
  border: 0;
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(11,42,91,.1);
}
.ce-location__info h3 { font-size: 17px; margin-top: 0; padding-bottom: 8px; }
.ce-location__info h3:not(:first-child) { margin-top: 28px; }
.ce-location__info ul { list-style: none; padding: 0; }
.ce-location__info li { padding: 4px 0; font-size: 15px; }
@media (max-width: 900px) {
  .ce-location { grid-template-columns: 1fr; align-items: start; gap: 22px; }
  .ce-location__map iframe {
    height: 360px !important;   /* fixed sensible height on mobile */
    min-height: 0;
  }
}
@media (max-width: 480px) {
  .ce-location__map iframe { height: 280px !important; }
}

/* === CE의 자랑 (pride gallery) === */
.ce-pride-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin: 28px 0 16px;
}
.ce-pride-gallery__item {
  margin: 0;
  position: relative;
  background: #fff;
  border: 1px solid #e6ebf2;
  border-radius: 8px;
  overflow: hidden;
  transition: transform .25s, box-shadow .25s;
}
.ce-pride-gallery__item:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 32px rgba(11,42,91,0.12);
  border-color: var(--ce-primary);
}
.ce-pride-gallery__item a {
  display: block;
  position: relative;
  aspect-ratio: 3 / 4;     /* certificate-friendly portrait ratio */
  background: #f4f6fb;
  overflow: hidden;
}
.ce-pride-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: contain;     /* keep entire certificate visible */
  display: block;
  transition: transform .35s ease;
}
.ce-pride-gallery__item:hover img { transform: scale(1.04); }
.ce-pride-gallery__zoom {
  position: absolute;
  right: 12px;
  bottom: 12px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(11,42,91,0.85);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .25s, transform .25s;
}
.ce-pride-gallery__zoom svg { width: 18px; height: 18px; }
.ce-pride-gallery__item:hover .ce-pride-gallery__zoom { opacity: 1; transform: translateY(0); }

@media (max-width: 900px) {
  .ce-pride-gallery { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (max-width: 480px) {
  .ce-pride-gallery { grid-template-columns: 1fr; gap: 14px; }
  .ce-pride-gallery__item a { aspect-ratio: 4 / 5; }   /* taller on phone */
  .ce-pride-gallery__zoom { opacity: 1; transform: none; width: 32px; height: 32px; }
}

/* Lightweight lightbox overlay (toggled by JS) */
.ce-lightbox {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.85);
  display: none;
  align-items: center; justify-content: center;
  z-index: 9999;
  padding: 24px;
  cursor: zoom-out;
}
.ce-lightbox.is-open { display: flex; animation: ce-fade-in .2s ease; }
.ce-lightbox img {
  max-width: 92vw;
  max-height: 92vh;
  object-fit: contain;
  border-radius: 6px;
  box-shadow: 0 16px 60px rgba(0,0,0,0.6);
}
.ce-lightbox__close {
  position: absolute;
  top: 24px; right: 24px;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  color: #fff;
  border: 0;
  font-size: 28px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  line-height: 1;
}
.ce-lightbox__close:hover { background: rgba(255,255,255,0.3); }

/* ==== Footer overrides: separate legal pair from family-site group ==== */
.site-footer__legal { flex-wrap: wrap; gap: 22px 24px; }
.site-footer__family {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  margin-left: 8px;
  padding-left: 24px;
  border-left: 1px solid rgba(255,255,255,.22);
}
.site-footer__family .site-footer__legal-link::before { display: none !important; }
.site-footer__family .site-footer__legal-link:first-child { font-weight: 500; color: rgba(255,255,255,.88); }
.site-footer__family .site-footer__legal-link + .site-footer__legal-link { margin-left: 0; }
@media (max-width: 720px) {
  .site-footer__family { margin-left: 0; padding-left: 0; border-left: 0; flex-basis: 100%; gap: 14px; }
}

/* =====================================================================
   business/cost — Cost Management Consulting
   Hero animations + Patent showcase section
   ===================================================================== */

/* --- Hero SVG animations --------------------------------------------- */
.ce-cost-hero__donut-seg {
  transform-origin: 0 0;
  transform-box: fill-box;
  animation: ce-cost-donut-rotate 24s linear infinite;
}
.ce-cost-hero__donut-seg--2 { animation-duration: 32s; animation-direction: reverse; }
.ce-cost-hero__donut-seg--3 { animation-duration: 40s; }

.ce-cost-hero__bar {
  transform-origin: bottom;
  transform-box: fill-box;
  animation: ce-cost-bar-rise 5s ease-in-out infinite;
}
.ce-cost-hero__bar--1 { animation-delay: 0s; }
.ce-cost-hero__bar--2 { animation-delay: -.5s; }
.ce-cost-hero__bar--3 { animation-delay: -1s; }
.ce-cost-hero__bar--4 { animation-delay: -1.5s; }

.ce-cost-hero__trend polyline {
  stroke-dasharray: 6 8;
  animation: ce-cost-trend-flow 6s linear infinite;
}
.ce-cost-hero__trend circle {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-cost-node-pulse 2.4s ease-in-out infinite;
}
.ce-cost-hero__trend circle:nth-child(2) { animation-delay: -.6s; }
.ce-cost-hero__trend circle:nth-child(3) { animation-delay: -1.2s; }
.ce-cost-hero__trend circle:nth-child(4) { animation-delay: -1.8s; }

.ce-cost-hero__down-arrow {
  animation: ce-cost-arrow-drop 2.6s ease-in-out infinite;
}

.ce-cost-hero__coin {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-cost-coin-float 5s ease-in-out infinite;
}
.ce-cost-hero__coin:nth-child(2) { animation-delay: -1s; animation-duration: 6s; }
.ce-cost-hero__coin:nth-child(3) { animation-delay: -2.5s; animation-duration: 7s; }
.ce-cost-hero__coin:nth-child(4) { animation-delay: -3.5s; animation-duration: 5.5s; }

@keyframes ce-cost-donut-rotate { to { transform: rotate(360deg); } }
@keyframes ce-cost-bar-rise {
  0%, 100% { transform: scaleY(.85); opacity: .7; }
  50%      { transform: scaleY(1);   opacity: 1; }
}
@keyframes ce-cost-trend-flow { to { stroke-dashoffset: -28; } }
@keyframes ce-cost-node-pulse {
  0%, 100% { transform: scale(1);   opacity: 1; }
  50%      { transform: scale(1.4); opacity: .7; }
}
@keyframes ce-cost-arrow-drop {
  0%, 100% { transform: translate(990px, 120px); opacity: .65; }
  50%      { transform: translate(990px, 130px); opacity: 1; }
}
@keyframes ce-cost-coin-float {
  0%, 100% { transform: translateY(0);   opacity: .85; }
  50%      { transform: translateY(-8px); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .ce-cost-hero__donut-seg, .ce-cost-hero__bar, .ce-cost-hero__trend polyline,
  .ce-cost-hero__trend circle, .ce-cost-hero__down-arrow, .ce-cost-hero__coin {
    animation: none !important;
  }
}

/* --- Patent showcase section ----------------------------------------- */
.ce-patent {
  margin: 56px 0 48px;
}
.ce-patent__info {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 28px;
  align-items: start;
  background: linear-gradient(135deg, #f7fafd 0%, #fdf3f5 100%);
  border: 1px solid rgba(255, 194, 199, 0.45);
  border-radius: 12px;
  padding: 32px 36px;
  margin-top: 28px;
  box-shadow: 0 4px 20px rgba(7, 23, 61, 0.05);
  position: relative;
  overflow: hidden;
}
.ce-patent__info::before {
  content: "";
  position: absolute;
  top: -40px; right: -40px;
  width: 180px; height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 194, 199, 0.25) 0%, transparent 70%);
  pointer-events: none;
}
.ce-patent__badge {
  width: 140px;
  height: 140px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ce-primary, #07173d);
  background: #fff;
  border-radius: 50%;
  border: 2px solid rgba(255, 194, 199, 0.5);
  box-shadow: 0 6px 18px rgba(7, 23, 61, 0.08);
  position: relative;
  z-index: 1;
}
.ce-patent__badge svg { width: 80px; height: 80px; }
.ce-patent__body { position: relative; z-index: 1; }
.ce-patent__name-label {
  font-family: Inter, sans-serif;
  font-size: 12px;
  letter-spacing: .25em;
  color: var(--ce-primary, #07173d);
  margin: 0 0 6px;
  font-weight: 700;
  opacity: .65;
}
.ce-patent__name {
  font-size: 22px !important;
  font-weight: 800;
  color: var(--ce-primary, #07173d);
  margin: 0 0 18px;
  line-height: 1.4;
  letter-spacing: -.01em;
  border: 0;
  padding: 0;
}
.ce-patent__meta {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 24px;
  margin: 0 0 18px;
  padding: 14px 18px;
  background: rgba(255, 255, 255, 0.7);
  border-radius: 8px;
  border: 1px solid rgba(255, 194, 199, 0.35);
}
.ce-patent__meta div { display: flex; align-items: baseline; gap: 10px; }
.ce-patent__meta dt {
  font-size: 13px;
  font-weight: 700;
  color: rgba(7, 23, 61, 0.6);
  min-width: 64px;
  flex-shrink: 0;
}
.ce-patent__meta dd {
  font-size: 15px;
  font-weight: 700;
  color: var(--ce-primary, #07173d);
  margin: 0;
  font-family: Inter, "Spoqa Han Sans Neo", sans-serif;
  letter-spacing: -.005em;
}
.ce-patent__desc {
  font-size: 17px;
  line-height: 1.7;
  color: rgba(7, 23, 61, 0.85);
  margin: 0;
  letter-spacing: -.005em;
}
.ce-patent__desc strong { color: var(--ce-primary, #07173d); font-weight: 700; }

/* PDF document cards */
.ce-patent__docs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 22px;
}
.ce-patent__doc {
  display: grid;
  grid-template-columns: 56px 1fr 32px;
  align-items: center;
  gap: 18px;
  padding: 20px 24px;
  background: #fff;
  border: 1.5px solid rgba(7, 23, 61, 0.08);
  border-radius: 10px;
  text-decoration: none !important;
  color: var(--ce-primary, #07173d);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position: relative;
  overflow: hidden;
}
.ce-patent__doc::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255, 194, 199, 0.12) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events: none;
}
.ce-patent__doc:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(7, 23, 61, 0.12);
  border-color: rgba(255, 194, 199, 0.7);
}
.ce-patent__doc:hover::before { opacity: 1; }
.ce-patent__doc-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #ffe5e8, #ffc2c7);
  color: var(--ce-primary, #07173d);
  border-radius: 8px;
  flex-shrink: 0;
}
.ce-patent__doc-icon svg { width: 30px; height: 38px; }
.ce-patent__doc-text { min-width: 0; position: relative; z-index: 1; }
.ce-patent__doc-label {
  font-family: Inter, sans-serif;
  font-size: 11px;
  letter-spacing: .25em;
  color: rgba(7, 23, 61, 0.55);
  font-weight: 700;
  margin: 0 0 4px;
}
.ce-patent__doc h4 {
  font-size: 18px !important;
  font-weight: 800;
  color: var(--ce-primary, #07173d) !important;
  margin: 0 0 4px !important;
  line-height: 1.3;
  letter-spacing: -.01em;
  border: 0 !important;
  padding: 0 !important;
}
.ce-patent__doc-meta {
  font-size: 13px;
  color: rgba(7, 23, 61, 0.65);
  margin: 0;
  font-family: Inter, "Spoqa Han Sans Neo", sans-serif;
}
.ce-patent__doc-action {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(7, 23, 61, 0.45);
  transition: color .25s ease, transform .25s ease;
}
.ce-patent__doc-action svg { width: 20px; height: 20px; }
.ce-patent__doc:hover .ce-patent__doc-action {
  color: var(--ce-primary, #07173d);
  transform: translate(2px, -2px);
}
.ce-patent__hint {
  margin: 14px 0 0;
  font-size: 13px;
  color: rgba(7, 23, 61, 0.55);
  text-align: center;
  letter-spacing: -.005em;
}

/* Mobile responsive */
@media (max-width: 900px) {
  .ce-patent__info {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 28px 24px;
    text-align: center;
  }
  .ce-patent__badge { margin: 0 auto; width: 120px; height: 120px; }
  .ce-patent__badge svg { width: 70px; height: 70px; }
  .ce-patent__meta { grid-template-columns: 1fr; gap: 8px; }
  .ce-patent__meta div { justify-content: center; }
  .ce-patent__docs { grid-template-columns: 1fr; gap: 14px; }
}
@media (max-width: 480px) {
  .ce-patent { margin: 40px 0 32px; }
  .ce-patent__info { padding: 22px 18px; }
  .ce-patent__name { font-size: 19px !important; }
  .ce-patent__desc { font-size: 16px; }
  .ce-patent__doc { grid-template-columns: 48px 1fr 24px; gap: 14px; padding: 16px 18px; }
  .ce-patent__doc-icon { width: 48px; height: 48px; }
  .ce-patent__doc-icon svg { width: 26px; height: 32px; }
  .ce-patent__doc h4 { font-size: 17px !important; }
  .ce-patent__doc-meta { font-size: 12px; }
}

/* =====================================================================
   business/safety — Safety & Disaster Prevention Consulting
   Hero animations (radar shield + hex mesh + hardhat + alerts)
   ===================================================================== */

/* Hex mesh subtle drift */
.ce-safety-hero__mesh { animation: ce-safety-mesh-drift 60s linear infinite; }
@keyframes ce-safety-mesh-drift {
  to { transform: translate(34px, 0); }
}

/* Concentric protection rings — pulse outward */
.ce-safety-hero__ring {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-safety-ring-pulse 4s ease-out infinite;
}
.ce-safety-hero__ring--1 { animation-delay: 0s; }
.ce-safety-hero__ring--2 { animation-delay: -1.3s; }
.ce-safety-hero__ring--3 { animation-delay: -2.6s; }
@keyframes ce-safety-ring-pulse {
  0%   { transform: scale(0.7); opacity: 0; }
  20%  { opacity: 0.9; }
  100% { transform: scale(1.25); opacity: 0; }
}

/* Central shield — gentle breathing */
.ce-safety-hero__shield {
  transform-origin: 600px 180px;
  animation: ce-safety-shield-breathe 5s ease-in-out infinite;
}
@keyframes ce-safety-shield-breathe {
  0%, 100% { transform: translate(600px, 180px) scale(1); }
  50%      { transform: translate(600px, 180px) scale(1.04); }
}

/* Check stroke draw-in */
.ce-safety-hero__check {
  stroke-dasharray: 70;
  stroke-dashoffset: 70;
  animation: ce-safety-check-draw 3s ease-in-out infinite;
}
@keyframes ce-safety-check-draw {
  0%   { stroke-dashoffset: 70; opacity: 0.3; }
  40%  { stroke-dashoffset: 0;  opacity: 1; }
  85%  { stroke-dashoffset: 0;  opacity: 1; }
  100% { stroke-dashoffset: 0;  opacity: 0.3; }
}

/* Radar sweep — full rotation */
.ce-safety-hero__sweep {
  transform-origin: 600px 180px;
  animation: ce-safety-sweep-rotate 6s linear infinite;
}
@keyframes ce-safety-sweep-rotate {
  to { transform: translate(600px, 180px) rotate(360deg); }
}

/* Hardhats — bobbing */
.ce-safety-hero__hat {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-safety-hat-bob 3.6s ease-in-out infinite;
}
.ce-safety-hero__hat--right,
.ce-safety-hero__hat:nth-of-type(2) { animation-delay: -1.8s; }

@keyframes ce-safety-hat-bob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

/* Warning alerts — blink */
.ce-safety-hero__alert {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-safety-alert-blink 2.4s ease-in-out infinite;
}
.ce-safety-hero__alert:nth-child(2) { animation-delay: -0.6s; }
.ce-safety-hero__alert:nth-child(3) { animation-delay: -1.2s; }
.ce-safety-hero__alert:nth-child(4) { animation-delay: -1.8s; }
@keyframes ce-safety-alert-blink {
  0%, 100% { opacity: 0.45; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.15); }
}

/* Connection lines — flow effect */
.ce-safety-hero__links line {
  stroke-dasharray: 4 6;
  animation: ce-safety-link-flow 5s linear infinite;
}
.ce-safety-hero__links line:nth-child(2n) {
  animation-direction: reverse;
  animation-duration: 7s;
}
@keyframes ce-safety-link-flow {
  to { stroke-dashoffset: -30; }
}

@media (prefers-reduced-motion: reduce) {
  .ce-safety-hero__mesh, .ce-safety-hero__ring, .ce-safety-hero__shield,
  .ce-safety-hero__check, .ce-safety-hero__sweep, .ce-safety-hero__hat,
  .ce-safety-hero__alert, .ce-safety-hero__links line {
    animation: none !important;
  }
}

/* =====================================================================
   business/esg — ESG Sustainable Management Consulting
   Hero animations (rotating globe + E·S·G orbiting badges + cycle + leaf + people)
   ===================================================================== */

/* Background dots — gentle twinkle */
.ce-esg-hero__dots circle {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-esg-twinkle 3.5s ease-in-out infinite;
}
.ce-esg-hero__dots circle:nth-child(2n) { animation-delay: -0.7s; }
.ce-esg-hero__dots circle:nth-child(3n) { animation-delay: -1.4s; }
.ce-esg-hero__dots circle:nth-child(5n) { animation-delay: -2.1s; }
@keyframes ce-esg-twinkle {
  0%, 100% { opacity: 0.3; transform: scale(0.85); }
  50%      { opacity: 1;   transform: scale(1.25); }
}

/* Sustainability cycle — rotating + flow */
.ce-esg-hero__cycle {
  transform-origin: 600px 180px;
  animation: ce-esg-cycle-rotate 28s linear infinite;
}
.ce-esg-hero__cycle path {
  stroke-dasharray: 5 8;
  animation: ce-esg-cycle-flow 8s linear infinite;
}
@keyframes ce-esg-cycle-rotate {
  to { transform: translate(600px, 180px) rotate(360deg); }
}
@keyframes ce-esg-cycle-flow {
  to { stroke-dashoffset: -52; }
}

/* Globe — slow gentle pulse */
.ce-esg-hero__globe {
  transform-origin: 600px 180px;
  animation: ce-esg-globe-breathe 6s ease-in-out infinite;
}
@keyframes ce-esg-globe-breathe {
  0%, 100% { transform: translate(600px, 180px) scale(1); }
  50%      { transform: translate(600px, 180px) scale(1.04); }
}

/* E·S·G orbiting — entire orbit rotates so badges revolve around globe */
.ce-esg-hero__orbit {
  transform-origin: 600px 180px;
  animation: ce-esg-orbit-rotate 36s linear infinite;
}
@keyframes ce-esg-orbit-rotate {
  to { transform: translate(600px, 180px) rotate(360deg); }
}

/* Each ESG badge counter-rotates so letters stay upright */
.ce-esg-hero__badge {
  transform-box: fill-box;
  animation: ce-esg-badge-counter-rotate 36s linear infinite;
}
.ce-esg-hero__badge--e { transform-origin: 0 -130px; }
.ce-esg-hero__badge--s { transform-origin: 113px 65px; }
.ce-esg-hero__badge--g { transform-origin: -113px 65px; }
@keyframes ce-esg-badge-counter-rotate {
  from { transform: rotate(0); }
  to   { transform: rotate(-360deg); }
}

/* Leaves — gentle sway */
.ce-esg-hero__leaf {
  transform-box: fill-box;
  animation: ce-esg-leaf-sway 4s ease-in-out infinite;
}
.ce-esg-hero__leaf--big   { transform-origin: 180px 200px; }
.ce-esg-hero__leaf--small { transform-origin: 160px 240px; animation-delay: -1.5s; animation-duration: 5s; }
@keyframes ce-esg-leaf-sway {
  0%, 100% { transform: rotate(-4deg); }
  50%      { transform: rotate(4deg); }
}

/* People — bobbing */
.ce-esg-hero__person {
  transform-origin: center bottom;
  transform-box: fill-box;
  animation: ce-esg-person-bob 3.2s ease-in-out infinite;
}
.ce-esg-hero__person:nth-child(2) { animation-delay: -1s; animation-duration: 3.6s; }
.ce-esg-hero__person:nth-child(3) { animation-delay: -2s; animation-duration: 3.4s; }
@keyframes ce-esg-person-bob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-4px); }
}

/* Governance pillars — alternating glow */
.ce-esg-hero__pillar {
  transform-origin: center bottom;
  transform-box: fill-box;
  animation: ce-esg-pillar-glow 3s ease-in-out infinite;
}
.ce-esg-hero__pillar:nth-child(2) { animation-delay: -1s; }
.ce-esg-hero__pillar:nth-child(3) { animation-delay: -2s; }
@keyframes ce-esg-pillar-glow {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .ce-esg-hero__dots circle, .ce-esg-hero__cycle, .ce-esg-hero__cycle path,
  .ce-esg-hero__globe, .ce-esg-hero__orbit, .ce-esg-hero__badge,
  .ce-esg-hero__leaf, .ce-esg-hero__person, .ce-esg-hero__pillar {
    animation: none !important;
  }
}

/* =====================================================================
   business/smart — Smart Factory Consulting
   Hero: factory + cloud + data streams + IoT sensors + dashboard + robot
   ===================================================================== */
.ce-smart-hero__win {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-smart-win-flicker 3s ease-in-out infinite;
}
.ce-smart-hero__win--2 { animation-delay: -0.6s; }
.ce-smart-hero__win--3 { animation-delay: -1.2s; }
.ce-smart-hero__win--4 { animation-delay: -1.8s; }
.ce-smart-hero__win--5 { animation-delay: -2.4s; }
@keyframes ce-smart-win-flicker {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 1; }
}

.ce-smart-hero__signal {
  transform-origin: 87px -100px;
  animation: ce-smart-signal-pulse 3s ease-out infinite;
}
.ce-smart-hero__signal--1 { animation-delay: 0s; }
.ce-smart-hero__signal--2 { animation-delay: -1s; }
.ce-smart-hero__signal--3 { animation-delay: -2s; }
@keyframes ce-smart-signal-pulse {
  0%   { transform: scale(0.6); opacity: 0; }
  20%  { opacity: 0.9; }
  100% { transform: scale(1.3); opacity: 0; }
}

.ce-smart-hero__streams line {
  stroke-dasharray: 4 6;
  animation: ce-smart-stream-flow 3s linear infinite;
}
.ce-smart-hero__streams line:nth-child(2) { animation-direction: reverse; animation-duration: 4s; }
.ce-smart-hero__streams line:nth-child(3) { animation-duration: 5s; }
@keyframes ce-smart-stream-flow {
  to { stroke-dashoffset: -30; }
}

.ce-smart-hero__packet {
  animation: ce-smart-packet-rise 3s linear infinite;
}
.ce-smart-hero__packet--1 { animation-delay: 0s;   transform: translate(540px, 240px); }
.ce-smart-hero__packet--2 { animation-delay: -1s;  transform: translate(600px, 220px); }
.ce-smart-hero__packet--3 { animation-delay: -2s;  transform: translate(660px, 240px); }
@keyframes ce-smart-packet-rise {
  0%   { transform: translate(540px, 240px); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translate(555px, 80px);  opacity: 0; }
}

.ce-smart-hero__dash-bar {
  transform-origin: bottom;
  transform-box: fill-box;
  animation: ce-smart-dash-bar 4s ease-in-out infinite;
}
.ce-smart-hero__dash-bar--1 { animation-delay: 0s; }
.ce-smart-hero__dash-bar--2 { animation-delay: -0.4s; }
.ce-smart-hero__dash-bar--3 { animation-delay: -0.8s; }
.ce-smart-hero__dash-bar--4 { animation-delay: -1.2s; }
.ce-smart-hero__dash-bar--5 { animation-delay: -1.6s; }
@keyframes ce-smart-dash-bar {
  0%, 100% { transform: scaleY(0.85); }
  50%      { transform: scaleY(1); }
}

.ce-smart-hero__robot-arm {
  transform-origin: 0 0;
  animation: ce-smart-robot-swing 4s ease-in-out infinite;
}
@keyframes ce-smart-robot-swing {
  0%, 100% { transform: rotate(-8deg); }
  50%      { transform: rotate(8deg); }
}

.ce-smart-hero__sensor {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-smart-sensor-pulse 2.4s ease-in-out infinite;
}
.ce-smart-hero__sensor:nth-child(2) { animation-delay: -0.4s; }
.ce-smart-hero__sensor:nth-child(3) { animation-delay: -0.8s; }
.ce-smart-hero__sensor:nth-child(4) { animation-delay: -1.2s; }
.ce-smart-hero__sensor:nth-child(5) { animation-delay: -1.6s; }
.ce-smart-hero__sensor:nth-child(6) { animation-delay: -2s; }
@keyframes ce-smart-sensor-pulse {
  0%, 100% { transform: scale(1);   opacity: 0.7; }
  50%      { transform: scale(1.5); opacity: 1; }
}

.ce-smart-hero__mesh line {
  animation: ce-smart-mesh-flow 6s linear infinite;
}
@keyframes ce-smart-mesh-flow {
  to { stroke-dashoffset: -28; }
}

@media (prefers-reduced-motion: reduce) {
  .ce-smart-hero__win, .ce-smart-hero__signal, .ce-smart-hero__streams line,
  .ce-smart-hero__packet, .ce-smart-hero__dash-bar, .ce-smart-hero__robot-arm,
  .ce-smart-hero__sensor, .ce-smart-hero__mesh line {
    animation: none !important;
  }
}

/* =====================================================================
   business/cert — Certification Consulting
   Hero: medal + ribbon + ISO badges + check marks + orbits
   ===================================================================== */
.ce-cert-hero__dots circle {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-cert-twinkle 3.5s ease-in-out infinite;
}
.ce-cert-hero__dots circle:nth-child(2n) { animation-delay: -0.7s; }
.ce-cert-hero__dots circle:nth-child(3n) { animation-delay: -1.4s; }
.ce-cert-hero__dots circle:nth-child(5n) { animation-delay: -2.1s; }
@keyframes ce-cert-twinkle {
  0%, 100% { opacity: 0.3; transform: scale(0.85); }
  50%      { opacity: 1;   transform: scale(1.25); }
}

.ce-cert-hero__medal {
  transform-origin: 600px 180px;
  animation: ce-cert-medal-shine 4s ease-in-out infinite;
}
@keyframes ce-cert-medal-shine {
  0%, 100% { transform: translate(600px, 180px) scale(1)    rotate(0); }
  50%      { transform: translate(600px, 180px) scale(1.04) rotate(-2deg); }
}

.ce-cert-hero__ribbon {
  transform-origin: 0 -100px;
  transform-box: fill-box;
  animation: ce-cert-ribbon-sway 3s ease-in-out infinite;
}
@keyframes ce-cert-ribbon-sway {
  0%, 100% { transform: rotate(-2deg); }
  50%      { transform: rotate(2deg); }
}

.ce-cert-hero__star {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-cert-star-glow 2.4s ease-in-out infinite;
}
@keyframes ce-cert-star-glow {
  0%, 100% { transform: scale(1);    opacity: 0.95; }
  50%      { transform: scale(1.12); opacity: 1; }
}

.ce-cert-hero__iso {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-cert-iso-bob 4s ease-in-out infinite;
}
.ce-cert-hero__iso--2 { animation-delay: -1s; animation-duration: 4.5s; }
.ce-cert-hero__iso--3 { animation-delay: -2s; animation-duration: 4.2s; }
.ce-cert-hero__iso--4 { animation-delay: -3s; animation-duration: 4.8s; }
@keyframes ce-cert-iso-bob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

.ce-cert-hero__orbit {
  transform-origin: 600px 180px;
  animation: ce-cert-orbit-rotate 30s linear infinite;
}
.ce-cert-hero__orbit--2 { animation-direction: reverse; animation-duration: 40s; }
@keyframes ce-cert-orbit-rotate {
  to { transform: translate(600px, 180px) rotate(360deg); }
}

.ce-cert-hero__check {
  stroke-dasharray: 60;
  stroke-dashoffset: 60;
  animation: ce-cert-check-draw 3s ease-in-out infinite;
}
.ce-cert-hero__check--2 { animation-delay: -0.6s; }
.ce-cert-hero__check--3 { animation-delay: -1.2s; }
.ce-cert-hero__check--4 { animation-delay: -1.8s; }
@keyframes ce-cert-check-draw {
  0%, 90%  { stroke-dashoffset: 0;  opacity: 1; }
  95%      { stroke-dashoffset: 0;  opacity: 0; }
  96%      { stroke-dashoffset: 60; opacity: 0; }
  100%     { stroke-dashoffset: 0;  opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .ce-cert-hero__dots circle, .ce-cert-hero__medal, .ce-cert-hero__ribbon,
  .ce-cert-hero__star, .ce-cert-hero__iso, .ce-cert-hero__orbit, .ce-cert-hero__check {
    animation: none !important;
  }
}

/* =====================================================================
   business/small — Small Business Consulting
   Hero: storefront + customers + hearts + speech bubbles
   ===================================================================== */
.ce-small-hero__window {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-small-win-glow 3.5s ease-in-out infinite;
}
.ce-small-hero__window--2 { animation-delay: -1.5s; }
@keyframes ce-small-win-glow {
  0%, 100% { opacity: 0.7; }
  50%      { opacity: 1; }
}

.ce-small-hero__customer {
  transform-origin: center bottom;
  transform-box: fill-box;
  animation: ce-small-customer-walk 3s ease-in-out infinite;
}
.ce-small-hero__customer--1 { animation-delay: 0s; }
.ce-small-hero__customer--2 { animation-delay: -0.8s; animation-duration: 3.4s; }
.ce-small-hero__customer--3 { animation-delay: -1.5s; animation-duration: 3.6s; }
.ce-small-hero__customer--4 { animation-delay: -2.2s; animation-duration: 3.2s; }
@keyframes ce-small-customer-walk {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-4px); }
}

.ce-small-hero__heart {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-small-heart-rise 4s ease-in-out infinite;
}
.ce-small-hero__heart--1 { animation-delay: 0s; }
.ce-small-hero__heart--2 { animation-delay: -1.3s; }
.ce-small-hero__heart--3 { animation-delay: -2.6s; }
@keyframes ce-small-heart-rise {
  0%   { transform: translateY(0)    scale(1);   opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { transform: translateY(-30px) scale(1.2); opacity: 0; }
}

.ce-small-hero__bubble {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-small-bubble-pop 4s ease-in-out infinite;
}
.ce-small-hero__bubble:nth-of-type(2) { animation-delay: -2s; }
@keyframes ce-small-bubble-pop {
  0%, 100% { transform: scale(1)    translateY(0); }
  50%      { transform: scale(1.04) translateY(-4px); }
}

.ce-small-hero__channel {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-small-channel-pulse 2.4s ease-in-out infinite;
}
.ce-small-hero__channel:nth-child(2) { animation-delay: -0.6s; }
.ce-small-hero__channel:nth-child(3) { animation-delay: -1.2s; }
.ce-small-hero__channel:nth-child(4) { animation-delay: -1.8s; }
@keyframes ce-small-channel-pulse {
  0%, 100% { transform: scale(1);   opacity: 0.7; }
  50%      { transform: scale(1.4); opacity: 1; }
}

.ce-small-hero__channel-links line {
  animation: ce-small-channel-flow 6s linear infinite;
}
@keyframes ce-small-channel-flow {
  to { stroke-dashoffset: -32; }
}

@media (prefers-reduced-motion: reduce) {
  .ce-small-hero__window, .ce-small-hero__customer, .ce-small-hero__heart,
  .ce-small-hero__bubble, .ce-small-hero__channel, .ce-small-hero__channel-links line {
    animation: none !important;
  }
}

/* =====================================================================
   System sub-hero — animated SVG layer (used by all sub-pages with photo bg)
   ===================================================================== */
.sub-hero { position: relative; isolation: isolate; }
.sub-hero--image { background-size: cover; background-position: center; background-repeat: no-repeat; }

.sub-hero__svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}
.sub-hero__inner { position: relative; z-index: 2; }

/* Floating sparks */
.sub-hero__svg .sub-hero__spark {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-sub-spark-float 5s ease-in-out infinite;
}
.sub-hero__svg .sub-hero__spark:nth-child(2n) { animation-delay: -1s;   animation-duration: 6s; }
.sub-hero__svg .sub-hero__spark:nth-child(3n) { animation-delay: -2s;   animation-duration: 7s; }
.sub-hero__svg .sub-hero__spark:nth-child(4n) { animation-delay: -3s;   animation-duration: 5.5s; }
.sub-hero__svg .sub-hero__spark:nth-child(5n) { animation-delay: -1.5s; animation-duration: 6.5s; }
@keyframes ce-sub-spark-float {
  0%, 100% { transform: translateY(0)     scale(1);   opacity: 0.55; }
  50%      { transform: translateY(-10px) scale(1.4); opacity: 1; }
}

/* Pulsing nodes */
.sub-hero__svg .sub-hero__node {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-sub-node-pulse 3s ease-in-out infinite;
}
.sub-hero__svg .sub-hero__node:nth-child(2) { animation-delay: -0.6s; }
.sub-hero__svg .sub-hero__node:nth-child(3) { animation-delay: -1.2s; }
.sub-hero__svg .sub-hero__node:nth-child(4) { animation-delay: -1.8s; }
.sub-hero__svg .sub-hero__node:nth-child(5) { animation-delay: -2.4s; }
@keyframes ce-sub-node-pulse {
  0%, 100% { transform: scale(1);   opacity: 0.6; }
  50%      { transform: scale(1.6); opacity: 1; }
}

/* Flowing lines */
.sub-hero__svg .sub-hero__flow {
  stroke-dasharray: 4 8;
  animation: ce-sub-flow-stream 8s linear infinite;
}
.sub-hero__svg .sub-hero__flow:nth-child(2n) { animation-direction: reverse; animation-duration: 10s; }
@keyframes ce-sub-flow-stream { to { stroke-dashoffset: -36; } }

/* Concentric expanding rings */
.sub-hero__svg .sub-hero__ring {
  transform-origin: center;
  transform-box: fill-box;
  animation: ce-sub-ring-expand 5s ease-out infinite;
}
.sub-hero__svg .sub-hero__ring--1 { animation-delay: 0s; }
.sub-hero__svg .sub-hero__ring--2 { animation-delay: -1.6s; }
.sub-hero__svg .sub-hero__ring--3 { animation-delay: -3.2s; }
@keyframes ce-sub-ring-expand {
  0%   { transform: scale(0.4); opacity: 0; }
  20%  { opacity: 0.75; }
  100% { transform: scale(1.3); opacity: 0; }
}

/* Diagonal streak */
.sub-hero__svg .sub-hero__streak {
  animation: ce-sub-streak-slide 9s linear infinite;
}
@keyframes ce-sub-streak-slide {
  0%   { transform: translateX(-200px); opacity: 0; }
  20%  { opacity: 0.4; }
  80%  { opacity: 0.4; }
  100% { transform: translateX(200px);  opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .sub-hero__svg .sub-hero__spark, .sub-hero__svg .sub-hero__node,
  .sub-hero__svg .sub-hero__flow, .sub-hero__svg .sub-hero__ring,
  .sub-hero__svg .sub-hero__streak {
    animation: none !important;
  }
}

/* =====================================================================
   education/consultant — Advanced Specialization cards (A·B·C)
   Light-background cards with sky-blue accents
   ===================================================================== */
.ce-cs-adv {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 32px;
}
.ce-cs-adv__card {
  background: linear-gradient(135deg, #f7fafd 0%, #fdf3f5 100%);
  border: 1px solid rgba(255, 194, 199, 0.45);
  border-radius: 10px;
  padding: 28px 26px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.ce-cs-adv__card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px rgba(7, 23, 61, 0.08);
  border-color: rgba(56, 189, 248, 0.55);
}
.ce-cs-adv__title {
  font-size: 22px !important;
  font-weight: 800;
  color: var(--ce-primary, #07173d) !important;
  margin: 0 0 14px !important;
  display: flex;
  align-items: center;
  gap: 12px;
  letter-spacing: -.01em;
  border: 0 !important;
  padding: 0 !important;
  white-space: nowrap;
}
.ce-cs-adv__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, #38bdf8, #0ea5e9);
  color: #fff;
  font-family: Inter, sans-serif;
  font-size: 17px;
  font-weight: 800;
  flex-shrink: 0;
  letter-spacing: 0;
  box-shadow: 0 3px 10px rgba(14, 165, 233, 0.25);
}
.ce-cs-adv__desc {
  font-size: 17px;
  line-height: 1.7;
  color: rgba(7, 23, 61, 0.85);
  margin: 0;
}
.ce-cs-adv__desc strong {
  color: #0284c7;
  font-weight: 700;
}
@media (max-width: 900px) {
  .ce-cs-adv { grid-template-columns: 1fr; gap: 14px; }
  .ce-cs-adv__title { white-space: normal; }
}
@media (max-width: 480px) {
  .ce-cs-adv__card { padding: 22px 20px; }
  .ce-cs-adv__title { font-size: 19px !important; }
  .ce-cs-adv__badge { width: 30px; height: 30px; font-size: 15px; }
  .ce-cs-adv__desc { font-size: 16px; }
}

/* =====================================================================
   Inquiry write form — Privacy consent + Spam captcha + Honeypot
   ===================================================================== */
.field__label-strong {
  display: block;
  font-weight: 700;
  margin-bottom: 8px;
  color: var(--ce-primary, #07173d);
  font-size: 15px;
}
.field__label-strong .req { color: #d23847; margin-left: 2px; }
.field__required-mark {
  font-style: normal;
  font-size: 12px;
  font-weight: 600;
  color: #d23847;
  letter-spacing: 0;
  margin-left: 4px;
}

.field--privacy {
  margin-top: 26px;
  padding-top: 22px;
  border-top: 1px solid rgba(7, 23, 61, 0.08);
}
.privacy-box {
  background: #f7fafd;
  border: 1px solid rgba(7, 23, 61, 0.1);
  border-radius: 8px;
  padding: 16px 18px;
  margin-bottom: 14px;
  max-height: 220px;
  overflow-y: auto;
}
.privacy-box__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  line-height: 1.6;
}
.privacy-box__table tr + tr th,
.privacy-box__table tr + tr td {
  border-top: 1px dashed rgba(7, 23, 61, 0.12);
}
.privacy-box__table th {
  text-align: left;
  width: 110px;
  font-weight: 700;
  color: var(--ce-primary, #07173d);
  padding: 8px 12px 8px 0;
  vertical-align: top;
  white-space: nowrap;
}
.privacy-box__table td {
  padding: 8px 0;
  color: rgba(7, 23, 61, 0.85);
  vertical-align: top;
}
.privacy-box__more {
  margin: 12px 0 0;
  padding-top: 12px;
  border-top: 1px dashed rgba(7, 23, 61, 0.12);
  font-size: 13px;
  color: rgba(7, 23, 61, 0.7);
}
.privacy-box__more a {
  color: #0284c7;
  font-weight: 700;
  text-decoration: underline;
}
.privacy-box__more a:hover { color: #0369a1; }

.privacy-agree {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: #fff;
  border: 1.5px solid rgba(255, 194, 199, 0.7);
  border-radius: 6px;
  cursor: pointer;
  font-size: 15px;
  font-weight: 500;
  color: var(--ce-primary, #07173d);
  transition: background .2s, border-color .2s;
}
.privacy-agree:hover {
  background: rgba(255, 194, 199, 0.08);
  border-color: rgba(255, 194, 199, 1);
}
.privacy-agree input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--ce-primary, #07173d);
  flex-shrink: 0;
  cursor: pointer;
}
.privacy-agree input[type="checkbox"]:checked + span {
  color: var(--ce-primary, #07173d);
}
.privacy-agree strong {
  color: #d23847;
  font-weight: 700;
  margin-left: 4px;
}

.field--captcha { margin-top: 18px; }
.captcha-box {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.captcha-box__q {
  display: inline-flex;
  align-items: center;
  font-family: Inter, "Spoqa Han Sans Neo", monospace;
  font-size: 22px;
  font-weight: 800;
  color: var(--ce-primary, #07173d);
  background: linear-gradient(135deg, #f7fafd 0%, #fdf3f5 100%);
  border: 1.5px solid rgba(7, 23, 61, 0.15);
  border-radius: 6px;
  padding: 10px 18px;
  letter-spacing: .04em;
  user-select: none;
  -webkit-user-select: none;
}
.captcha-box input[type="number"] {
  width: 120px;
  padding: 11px 14px;
  font-size: 17px;
  font-weight: 600;
  border: 1.5px solid rgba(7, 23, 61, 0.2);
  border-radius: 6px;
  text-align: center;
  font-family: Inter, "Spoqa Han Sans Neo", sans-serif;
}
.captcha-box input[type="number"]:focus {
  outline: 2px solid var(--ce-primary, #07173d);
  outline-offset: -1px;
  border-color: var(--ce-primary, #07173d);
}
/* Hide number input arrows for cleaner look */
.captcha-box input[type="number"]::-webkit-outer-spin-button,
.captcha-box input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.captcha-box input[type="number"] { -moz-appearance: textfield; }

@media (max-width: 480px) {
  .privacy-box__table th { width: 88px; font-size: 13px; }
  .privacy-box__table td { font-size: 13px; }
  .captcha-box__q { font-size: 19px; padding: 9px 14px; }
  .captcha-box input[type="number"] { width: 100px; font-size: 16px; }
}

/* =====================================================================
   Legal documents (Privacy Policy / Terms of Service)
   ===================================================================== */
.legal-doc {
  width: 100%;
  margin: 0;
  padding: 8px 0 32px;
  color: rgba(7, 23, 61, 0.92);
  font-size: 15.5px;
  line-height: 1.85;
  letter-spacing: -.005em;
}
.legal-doc__head {
  border-bottom: 1px solid rgba(7, 23, 61, 0.12);
  padding-bottom: 20px;
  margin-bottom: 28px;
  text-align: center;
}
.legal-doc__label {
  font-family: Inter, sans-serif;
  font-size: 12px;
  letter-spacing: .35em;
  color: #ffc2c7;
  font-weight: 700;
  margin: 0 0 12px;
}
.legal-doc__title {
  font-size: 30px;
  font-weight: 800;
  color: var(--ce-primary, #07173d) !important;
  margin: 0 0 10px !important;
  letter-spacing: -.02em;
  border: 0 !important;
  padding: 0 !important;
}
.legal-doc__date {
  font-size: 13px;
  color: rgba(7, 23, 61, 0.6);
  margin: 0;
  font-family: Inter, "Spoqa Han Sans Neo", sans-serif;
}
.legal-doc__intro {
  background: linear-gradient(135deg, #f7fafd 0%, #fdf3f5 100%);
  border-left: 4px solid #ffc2c7;
  border-radius: 0 8px 8px 0;
  padding: 20px 24px;
  margin: 0 0 32px;
}
.legal-doc__intro p {
  margin: 0;
  font-size: 16px;
  line-height: 1.8;
  color: rgba(7, 23, 61, 0.88);
}
.legal-doc__intro strong {
  color: var(--ce-primary, #07173d);
  font-weight: 700;
}
.legal-doc h3 {
  font-size: 19px;
  font-weight: 800;
  color: var(--ce-primary, #07173d) !important;
  margin: 36px 0 14px !important;
  padding: 0 !important;
  border: 0 !important;
  letter-spacing: -.01em;
  position: relative;
  padding-left: 14px !important;
}
.legal-doc h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 6px;
  width: 4px;
  background: linear-gradient(180deg, #ffc2c7, #ffd9dd);
  border-radius: 2px;
}
.legal-doc p {
  margin: 0 0 14px;
  font-size: 15.5px;
  line-height: 1.85;
  color: rgba(7, 23, 61, 0.86);
}
.legal-doc p strong {
  color: var(--ce-primary, #07173d);
  font-weight: 700;
}
.legal-doc a {
  color: #0284c7;
  text-decoration: underline;
  font-weight: 500;
}
.legal-doc a:hover { color: #0369a1; }

.legal-list {
  margin: 0 0 14px;
  padding-left: 24px;
}
.legal-list > li {
  margin-bottom: 8px;
  line-height: 1.8;
  color: rgba(7, 23, 61, 0.86);
}
.legal-list > li > .legal-list,
.legal-list ul.legal-list {
  margin-top: 8px;
  padding-left: 22px;
}
.legal-list > li > strong:first-child {
  color: var(--ce-primary, #07173d);
  font-weight: 700;
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  margin: 14px 0 18px;
  font-size: 14.5px;
  border: 1px solid rgba(7, 23, 61, 0.12);
  border-radius: 6px;
  overflow: hidden;
}
.legal-table thead {
  background: linear-gradient(135deg, #07173d 0%, #1a3d75 100%);
  color: #fff;
}
.legal-table thead th {
  padding: 12px 16px;
  text-align: left;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -.005em;
}
.legal-table tbody tr {
  border-top: 1px solid rgba(7, 23, 61, 0.08);
}
.legal-table tbody td,
.legal-table tbody th {
  padding: 12px 16px;
  vertical-align: top;
  line-height: 1.7;
}
.legal-table tbody th {
  background: #f7fafd;
  font-weight: 700;
  color: var(--ce-primary, #07173d);
  width: 30%;
  text-align: left;
}
.legal-table--contact { max-width: 640px; }
.legal-table--contact tbody th { width: 30%; }

.legal-doc__notice {
  margin: 36px 0 0 !important;
  padding: 16px 20px;
  background: rgba(255, 194, 199, 0.12);
  border-radius: 6px;
  font-size: 14px;
  color: var(--ce-primary, #07173d);
  text-align: center;
}
.legal-doc__notice strong { color: var(--ce-primary, #07173d); }

@media (max-width: 768px) {
  .legal-doc { font-size: 15px; padding: 4px 0 24px; }
  .legal-doc__title { font-size: 24px; }
  .legal-doc h3 { font-size: 17px; }
  .legal-table tbody th { width: auto; min-width: 100px; }
}
@media (max-width: 480px) {
  .legal-doc { font-size: 14.5px; }
  .legal-doc__intro { padding: 16px 18px; }
  .legal-doc__title { font-size: 22px; }
  .legal-doc h3 { font-size: 16px; padding-left: 10px !important; }
  .legal-list { padding-left: 20px; }
  .legal-table { font-size: 13px; }
  .legal-table thead th, .legal-table tbody td, .legal-table tbody th { padding: 10px 12px; }
}

/* =====================================================================
   Inquiry author fieldset + grid layout
   ===================================================================== */
.inquiry-fields {
  border: 1px solid rgba(7, 23, 61, 0.15);
  border-radius: 10px;
  padding: 18px 22px 8px;
  margin: 0 0 24px;
  background: linear-gradient(180deg, #fdfdfd 0%, #f7fafd 100%);
}
.inquiry-fields > legend {
  padding: 0 10px;
  font-weight: 800;
  color: var(--ce-primary, #07173d);
  font-size: 15px;
  letter-spacing: -.005em;
}
.inquiry-grid {
  display: grid;
  gap: 14px;
  margin-bottom: 4px;
}
.inquiry-grid--2 { grid-template-columns: 1fr 1fr; }
.inquiry-grid--3 { grid-template-columns: 1fr 1fr 1fr; }
.inquiry-fields .field { margin-bottom: 14px; }
.inquiry-fields .field label {
  display: block;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ce-primary, #07173d);
  margin-bottom: 6px;
  letter-spacing: -.005em;
}
.inquiry-fields .field input,
.inquiry-fields .field select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid rgba(7, 23, 61, 0.18);
  border-radius: 5px;
  font-size: 14.5px;
  background: #fff;
  font-family: inherit;
  color: var(--ce-primary, #07173d);
}
.inquiry-fields .field input:focus,
.inquiry-fields .field select:focus {
  outline: 2px solid var(--ce-primary, #07173d);
  outline-offset: -1px;
  border-color: var(--ce-primary, #07173d);
}
.inquiry-fields .field__hint {
  font-size: 12.5px;
  color: rgba(7, 23, 61, 0.65);
  margin-top: 6px;
  line-height: 1.55;
}
.inquiry-fields .req { color: #d23847; font-weight: 700; margin-left: 2px; }

@media (max-width: 768px) {
  .inquiry-grid--3 { grid-template-columns: 1fr 1fr; }
  .inquiry-fields { padding: 16px 16px 6px; }
}
@media (max-width: 480px) {
  .inquiry-grid--2,
  .inquiry-grid--3 { grid-template-columns: 1fr; }
}

/* =====================================================================
   Inquiry post — info-box at the top of post body when reading
   ===================================================================== */
.post__body table.inquiry-info {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 24px;
  background: linear-gradient(135deg, #f7fafd 0%, #fdf3f5 100%);
  border: 1px solid rgba(255, 194, 199, 0.55);
  border-radius: 10px;
  overflow: hidden;
}
.post__body table.inquiry-info tbody tr + tr th,
.post__body table.inquiry-info tbody tr + tr td {
  border-top: 1px dashed rgba(7, 23, 61, 0.12);
}
.post__body table.inquiry-info th {
  text-align: left;
  width: 150px;
  font-weight: 700;
  color: var(--ce-primary, #07173d);
  background: rgba(255, 194, 199, 0.18);
  padding: 12px 18px;
  vertical-align: top;
  font-size: 14.5px;
  white-space: nowrap;
}
.post__body table.inquiry-info td {
  padding: 12px 18px;
  color: rgba(7, 23, 61, 0.9);
  vertical-align: top;
  font-size: 15px;
  line-height: 1.6;
  word-break: break-word;
}
.post__body table.inquiry-info td a {
  color: #0284c7;
  font-weight: 600;
  text-decoration: underline;
  word-break: break-all;
}
.post__body table.inquiry-info td a:hover { color: #0369a1; }

.post__body .inquiry-message {
  padding: 8px 4px;
  font-size: 16px;
  line-height: 1.85;
  color: rgba(7, 23, 61, 0.9);
}

@media (max-width: 600px) {
  .post__body table.inquiry-info,
  .post__body table.inquiry-info tbody,
  .post__body table.inquiry-info tr {
    display: block;
    width: 100%;
  }
  .post__body table.inquiry-info th {
    display: block;
    width: 100%;
    padding: 10px 14px 4px;
    background: transparent;
    border-bottom: 0;
    font-size: 12.5px;
    letter-spacing: .04em;
    color: rgba(7, 23, 61, 0.65);
    text-transform: uppercase;
  }
  .post__body table.inquiry-info td {
    display: block;
    width: 100%;
    padding: 0 14px 12px;
    font-size: 15px;
  }
  .post__body table.inquiry-info tbody tr + tr {
    border-top: 1px dashed rgba(7, 23, 61, 0.12);
  }
  .post__body table.inquiry-info tbody tr + tr th,
  .post__body table.inquiry-info tbody tr + tr td {
    border-top: 0;
  }
}
.ce-edu-banner__inner {
  position: relative;
  z-index: 4;
  max-width: 1200px;
  margin: 0 auto;
}
.ce-edu-banner__eyebrow {
  font-family: Inter, sans-serif;
  font-size: 13px;
  letter-spacing: .35em;
  color: #ffc2c7;
  margin: 0 0 22px;
  font-weight: 700;
}
.ce-edu-banner__title {
  font-size: clamp(28px, 4vw, 46px);
  font-weight: 800;
  color: #fff;
  margin: 0 0 22px;
  letter-spacing: -.02em;
  line-height: 1.2;
  border: 0;
  padding: 0;
}
.ce-edu-banner__crumb {
  font-family: Inter, "Spoqa Han Sans Neo", sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .04em;
  color: rgba(255, 255, 255, 0.78);
  margin: 0;
}
.ce-edu-banner__crumb a {
  color: rgba(255, 255, 255, 0.78);
  text-decoration: none;
}
.ce-edu-banner__crumb a:hover { color: #ffc2c7; }
.ce-edu-banner__crumb span {
  display: inline-block;
  margin: 0 10px;
  color: rgba(255, 255, 255, 0.4);
}
@media (max-width: 900px) {
  .ce-edu-banner { padding: 70px 24px 60px; border-radius: 8px; }
  .ce-edu-banner__eyebrow { font-size: 12px; letter-spacing: .3em; margin-bottom: 16px; }
  .ce-edu-banner__title { font-size: clamp(24px, 5.5vw, 34px); margin-bottom: 16px; }
  .ce-edu-banner__crumb { font-size: 12px; }
  .ce-edu-banner__crumb span { margin: 0 6px; }
}
@media (max-width: 480px) {
  .ce-edu-banner { padding: 56px 20px 50px; }
  .ce-edu-banner__title { font-size: 24px; }
}

/* Education content blocks */
.ce-edu-lead { margin-top: 40px; }
.ce-edu-link {
  margin-top: 12px !important;
}
.ce-edu-link a {
  display: inline-block;
  font-size: 15px;
  font-weight: 700;
  color: var(--ce-primary, #07173d);
  text-decoration: none;
  padding: 6px 0;
  border-bottom: 2px solid rgba(255, 194, 199, 0.5);
  transition: border-color .2s, color .2s;
}
.ce-edu-link a:hover {
  color: #ffc2c7;
  border-color: #ffc2c7;
}

.ce-edu-record { margin-top: 32px; }
.ce-edu-record__list {
  list-style: none;
  padding: 0;
  margin: 22px 0 0;
  display: grid;
  gap: 14px;
}
.ce-edu-record__list li {
  background: linear-gradient(135deg, #f7fafd 0%, #fdf3f5 100%);
  border-left: 4px solid #ffc2c7;
  padding: 18px 22px;
  border-radius: 0 8px 8px 0;
  font-size: 17px;
  line-height: 1.7;
  color: rgba(7, 23, 61, 0.85);
}
.ce-edu-record__list li strong {
  display: block;
  color: var(--ce-primary, #07173d);
  font-weight: 800;
  margin-bottom: 4px;
  font-size: 16px;
  letter-spacing: -.005em;
}
.ce-edu-record__note {
  margin: 22px 0 0;
  font-size: 16px;
  color: var(--ce-primary, #07173d);
  font-weight: 600;
  text-align: center;
  padding: 14px 18px;
  background: rgba(255, 194, 199, 0.15);
  border-radius: 6px;
}
.ce-edu-record__note strong { color: var(--ce-primary, #07173d); }
@media (max-width: 480px) {
  .ce-edu-record__list li { padding: 14px 16px; font-size: 16px; }
  .ce-edu-record__note { font-size: 15px; }
}

