/* ========== SHARED DESIGN TOKENS ========== */
:root {
  --fd: 'Archivo','Pretendard',system-ui,sans-serif;
  --fb: 'Pretendard',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --fm: 'IBM Plex Mono', ui-monospace, monospace;

  --bg: #0A1130;
  --bg-deep: #070B22;
  --surface: #131A3F;
  --surface-2: #1C2552;
  --ink: #F3F5FC;
  --ink-mid: #C6CAE0;
  --ink-soft: #9095B8;
  --ink-faint: #898FBE;
  --line: #2C3366;
  --line-strong: #424A85;
  --accent: #18D0E6;
  --accent-dark: #46E2F2;
  --accent-soft: rgba(24,208,230,0.16);
  --btn-bg: #0C7C8E;       /* darker teal for CTA fills so white text stays readable */
  --btn-bg-h: #0A6675;     /* CTA hover (darker) */

  --r-na-bg:rgba(90,150,230,.16); --r-na-fg:#85B6FF;
  --r-sa-bg:rgba(60,190,130,.16); --r-sa-fg:#5FDDA0;
  --r-eu-bg:rgba(225,170,70,.16); --r-eu-fg:#EBC062;
  --r-as-bg:rgba(255,120,80,.16); --r-as-fg:#FF9E78;
  --r-af-bg:rgba(170,150,120,.18);--r-af-fg:#CFBE9C;
  --r-oc-bg:rgba(225,110,160,.16);--r-oc-fg:#F08FBE;

  --tag-mfg-bg:rgba(120,120,150,.18);    --tag-mfg-fg:#B9B9D4;
  --tag-it-bg:rgba(90,150,230,.16);      --tag-it-fg:#85B6FF;
  --tag-auto-bg:rgba(140,140,150,.18);   --tag-auto-fg:#C2C2CE;
  --tag-energy-bg:rgba(225,170,70,.16);  --tag-energy-fg:#EBC062;
  --tag-bio-bg:rgba(160,120,230,.16);    --tag-bio-fg:#BCA0F0;
  --tag-retail-bg:rgba(110,200,110,.16); --tag-retail-fg:#84D884;
  --tag-food-bg:rgba(255,120,80,.16);    --tag-food-fg:#FF9E78;
  --tag-bldg-bg:rgba(90,170,200,.16);    --tag-bldg-fg:#74C4DC;
  --tag-edu-bg:rgba(60,190,130,.16);     --tag-edu-fg:#5FDDA0;
  --tag-hotel-bg:rgba(225,110,160,.16);  --tag-hotel-fg:#F08FBE;
  --tag-pub-bg:rgba(150,150,160,.18);    --tag-pub-fg:#C2C2CE;
  --tag-defense-bg:rgba(90,120,90,.18);  --tag-defense-fg:#9ECF9E;
  --tag-power-bg:rgba(225,140,60,.16);   --tag-power-fg:#F0B070;

  --tag-leadership-bg:rgba(225,170,70,.16);  --tag-leadership-fg:#EBC062;
  --tag-industrial-bg:rgba(255,120,80,.16);  --tag-industrial-fg:#FF9E78;
  --tag-vertical-bg:rgba(60,190,130,.16);    --tag-vertical-fg:#5FDDA0;
  --tag-product-bg:rgba(90,150,230,.16);     --tag-product-fg:#85B6FF;
  --tag-excellence-bg:rgba(90,170,200,.16);  --tag-excellence-fg:#74C4DC;
  --tag-innovation-bg:rgba(160,120,230,.16); --tag-innovation-fg:#BCA0F0;
  --tag-engineering-bg:rgba(120,120,150,.18);--tag-engineering-fg:#B9B9D4;
  --tag-platform-bg:rgba(225,110,160,.16);   --tag-platform-fg:#F08FBE;
  --tag-state-bg:rgba(150,150,160,.18);      --tag-state-fg:#C2C2CE;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--fb);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* Keep Korean from breaking mid-word; wrap at natural word/phrase boundaries */
body, h1, h2, h3, h4, h5, h6, p, li, dt, dd, a, span, em, strong, button, figcaption,
.headline, .cap, .lead, .home-lede, .flow-label, .flow-sub, .flow-desc, .t-lbl, .s-unit, .why-unit {
  word-break: keep-all;
  overflow-wrap: break-word;
}

.wrap { max-width: 1240px; margin: 0 auto; padding: 0 32px; }
.wrap-mid { max-width: 1140px; margin: 0 auto; padding: 0 32px; }

/* ========== TOP NAVIGATION ========== */
.topnav {
  position: sticky;
  top: 0;
  z-index: 200;
  background: rgba(0, 0, 26, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}

.topnav-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 16px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.brand {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 24px;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-decoration: none;
  cursor: pointer;
}
.brand { display: inline-flex; align-items: center; gap: 10px; }
.brand-logo { height: 30px; width: auto; display: block; }
.brand-kr { font-family: var(--fm); font-size: 12px; color: var(--accent); letter-spacing: 0.12em; font-weight: 500; }
@media (max-width: 760px) { .brand-logo { height: 24px; } }

.nav-links {
  display: flex;
  gap: 4px;
  list-style: none;
}

.nav-link {
  font-family: var(--fb);
  font-size: 14px;
  font-weight: 500;
  padding: 9px 16px;
  color: var(--ink-soft);
  background: transparent;
  border: none;
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.18s ease;
  letter-spacing: -0.005em;
}

.nav-link:hover {
  color: var(--ink);
  background: var(--bg-deep);
}

.nav-link.active {
  color: var(--bg);
  background: var(--ink);
}

.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fm);
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 10px 16px;
  background: var(--btn-bg);
  color: #fff;
  text-decoration: none;
  border: none;
  cursor: pointer;
  border-radius: 2px;
  transition: background 0.2s ease;
}
.nav-cta:hover { background: var(--btn-bg-h); }
.nav-cta::after { content: '→'; font-size: 14px; }

@media (max-width: 760px) {
  .topnav-inner { padding: 12px 20px; flex-wrap: wrap; gap: 12px; }
  .brand { font-size: 20px; }
  .nav-cta { display: none; }
  .nav-link { padding: 7px 12px; font-size: 13px; }
}

/* ========== VIEW SYSTEM ========== */
.view { display: none; }
.view.active { display: block; }

/* ========== STORIES HERO ========== */
/* gentle pulse for hero signal-ring decorations */
@keyframes heroRingPulse {
  0%, 100% { transform: scale(0.92); opacity: 0.45; }
  50%      { transform: scale(1.06); opacity: 0.95; }
}
@keyframes heroGlowPulse {
  0%, 100% { opacity: 0.65; }
  50%      { opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .home-hero::before, .home-hero::after,
  .stories-hero::before, .stories-hero::after,
  .apps-hero::before, .apps-hero::after { animation: none !important; }
}

/* scroll reveal (fade-up) — only active once JS adds .reveal-on */
.reveal-on .reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
  will-change: opacity, transform;
}
.reveal-on .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal-on .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ---- hero scroll cue ---- */
.scroll-cue {
  display: flex; flex-direction: column; align-items: center; gap: 11px;
  margin: 70px auto 0; padding: 6px 10px;
  background: none; border: none; cursor: pointer;
  position: relative; z-index: 2;
}
.scroll-cue .sc-label {
  font-family: var(--fm); font-size: 10px; letter-spacing: 0.3em;
  color: var(--ink-soft); transition: color .2s ease;
}
.scroll-cue .sc-track {
  position: relative; width: 1px; height: 48px;
  background: linear-gradient(180deg, var(--line-strong), transparent);
  overflow: hidden;
}
.scroll-cue .sc-dot {
  position: absolute; top: 0; left: 50%; width: 4px; height: 4px; margin-left: -2px;
  border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px var(--accent);
  animation: scrollDot 1.9s cubic-bezier(.5,0,.5,1) infinite;
}
@keyframes scrollDot {
  0%   { transform: translateY(-6px); opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { transform: translateY(48px); opacity: 0; }
}
.scroll-cue:hover .sc-label { color: var(--accent); }
@media (prefers-reduced-motion: reduce) {
  .scroll-cue .sc-dot { animation: none; top: 20px; }
}

/* ---- elegant center-fading section dividers (home) ---- */
.home-hero, .strengths-section, .fac-band, .why-section,
.home-gateway, .home-awards-strip, .logo-marquee-section {
  border-bottom-style: solid;
  border-bottom-width: 1px;
  border-image: linear-gradient(90deg, transparent 3%, rgba(24,208,230,.20) 50%, transparent 97%) 1;
}

/* ---- unified premium card hover (match value-card) ---- */
.cat-card { transition: background .2s ease, transform .3s ease, box-shadow .3s ease; }
.cat-card:hover {
  background: var(--bg-deep);
  transform: translateY(-5px);
  box-shadow: 0 18px 44px rgba(0,0,0,.45);
}
.home-case-card { border-radius: 14px; }
.home-case-card:hover {
  transform: translateY(-5px);
  border-color: var(--line-strong);
  box-shadow: 0 18px 44px rgba(0,0,0,.45);
}

/* ============================================================ */
/* SUPPORT PAGES — pulse decoration + design polish            */
/* ============================================================ */

/* contact heading: keep "상담 신청" together */
#view-contact .cpage h1 em { white-space: nowrap; }
/* blog & newsletter: long mixed titles — allow full width, no mid-phrase break */
#view-blog .cpage h1, #view-newsletter .cpage h1 { max-width: none; }
#view-blog .cpage h1 em { white-space: nowrap; }
#view-newsletter .cpage h1 .nw { white-space: nowrap; }

/* pulsing signal-ring decoration (top-right) on all Support pages */
#view-contact .cpage, #view-faqs .cpage, #view-knowledgebase .cpage {
  position: relative;
  overflow: hidden;
}
#view-contact .cpage::before, #view-faqs .cpage::before, #view-knowledgebase .cpage::before {
  content: ''; position: absolute; top: -200px; right: -200px;
  width: 600px; height: 600px; border-radius: 50%;
  background: radial-gradient(circle at 50% 50%,
    rgba(24,208,230,.16) 0%, rgba(70,110,235,.06) 42%, transparent 68%);
  filter: blur(7px); pointer-events: none; z-index: 0;
  animation: heroGlowPulse 7s ease-in-out infinite;
}
#view-contact .cpage::after, #view-faqs .cpage::after, #view-knowledgebase .cpage::after {
  content: ''; position: absolute; top: -90px; right: -150px;
  width: 500px; height: 500px; border-radius: 50%;
  background: repeating-radial-gradient(circle at 50% 50%,
    transparent 0 54px, rgba(24,208,230,.12) 54px 55px);
  -webkit-mask: radial-gradient(circle at 50% 50%, #000 6%, transparent 70%);
          mask: radial-gradient(circle at 50% 50%, #000 6%, transparent 70%);
  pointer-events: none; z-index: 0; transform-origin: center;
  animation: heroRingPulse 7s ease-in-out infinite;
}
#view-contact .cpage > .wrap-mid,
#view-faqs .cpage > .wrap-mid,
#view-knowledgebase .cpage > .wrap-mid { position: relative; z-index: 1; }
@media (prefers-reduced-motion: reduce) {
  #view-contact .cpage::before, #view-contact .cpage::after,
  #view-faqs .cpage::before, #view-faqs .cpage::after,
  #view-knowledgebase .cpage::before, #view-knowledgebase .cpage::after { animation: none !important; }
}

/* FAQ — hover + open accent */
.faq-item { transition: background .25s ease; }
.faq-q { transition: color .2s ease; }
.faq-q:hover { color: var(--accent-dark); }
.faq-item.open .faq-q { color: var(--accent-dark); }
.faq-q::after { transition: color .2s ease, transform .25s ease; }
.faq-q:hover::after { color: var(--accent-dark); transform: translateY(-50%) scale(1.18); }
.faq-item.open { background: linear-gradient(90deg, rgba(24,208,230,.055), transparent 58%); }

/* Knowledgebase cards — unified premium hover + accent bar */
.kb-card { position: relative; overflow: hidden;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease; }
.kb-card:hover { border-color: var(--accent); transform: translateY(-5px); box-shadow: 0 18px 44px rgba(0,0,0,.45); }
.kb-card::after { content: ''; position: absolute; left: 0; top: 0; height: 3px; width: 0;
  background: var(--accent); transition: width .25s ease; }
.kb-card:hover::after { width: 100%; }

/* Contact figure — taller + subtle hover zoom */
.contact-figure { max-height: 300px !important; }
.contact-figure img { height: 300px !important; transition: transform .5s ease; }
.contact-figure:hover img { transform: scale(1.04); }

/* ---- 핵심 강점 · Why Monnit : 박스형 헤어라인 그리드 → 깔끔한 라운드 카드 ---- */
.strength-grid, .why-grid {
  background: transparent !important;
  border: none !important;
  gap: 20px !important;
}
.strength-card, .why-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: linear-gradient(180deg, var(--surface), var(--bg-deep));
  transition: transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}
.strength-card:hover, .why-card:hover {
  transform: translateY(-4px);
  border-color: var(--line-strong);
  box-shadow: 0 16px 40px rgba(0,0,0,.42);
  background: linear-gradient(180deg, var(--surface), var(--bg-deep));
}

/* ---- pagination ---- */
.pager{ display:flex; justify-content:center; gap:6px; margin:34px 0 4px; flex-wrap:wrap; }
.pager .pg-btn{ min-width:36px; height:36px; padding:0 11px; border:1px solid var(--line);
  background:var(--surface); color:var(--ink-mid); border-radius:9px; font-family:var(--fm);
  font-size:13px; cursor:pointer; transition:all .18s ease; }
.pager .pg-btn:hover:not(:disabled){ border-color:var(--accent); color:var(--accent); }
.pager .pg-btn.active{ background:var(--accent); border-color:var(--accent); color:#04222a; font-weight:700; }
.pager .pg-btn:disabled{ opacity:.35; cursor:default; }

/* ---- blog main photo ---- */
.blog-thumb.has-img{ padding:0; background:var(--bg-deep); }
.blog-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }

/* ---- knowledge base: search + category tiles ---- */
.kb-search-wrap{ position:relative; margin:34px 0 8px; }
.kb-search-wrap .kb-search-ico{ position:absolute; left:18px; top:50%; transform:translateY(-50%); color:var(--ink-soft); font-size:18px; pointer-events:none; }
.kb-search-wrap input{ width:100%; padding:15px 46px; background:var(--surface); border:1px solid var(--line);
  border-radius:12px; color:var(--ink); font-size:15px; font-family:var(--fb); transition:border-color .2s ease; }
.kb-search-wrap input:focus{ outline:none; border-color:var(--accent); }
.kb-search-wrap #kbSearchClear{ position:absolute; right:14px; top:50%; transform:translateY(-50%); background:none; border:none;
  color:var(--ink-soft); font-size:15px; cursor:pointer; padding:6px; }
.kb-search-wrap #kbSearchClear:hover{ color:var(--accent); }
.kb-cat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:24px; }
.kb-cat-tile{ position:relative; overflow:hidden; background:linear-gradient(180deg,var(--surface),var(--bg-deep)); border:1px solid var(--line); border-radius:16px;
  padding:24px 22px; cursor:pointer; text-align:left; transition:transform .26s ease, border-color .26s ease, box-shadow .26s ease;
  display:flex; flex-direction:column; gap:5px; }
.kb-cat-tile::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--ic,var(--accent)); opacity:.9; }
.kb-cat-tile:hover{ transform:translateY(-5px); border-color:color-mix(in srgb, var(--ic,var(--accent)) 60%, transparent); box-shadow:0 18px 44px rgba(0,0,0,.45); }
.kb-cat-tile .kb-ico{ display:inline-flex; align-items:center; justify-content:center; width:46px; height:46px; border-radius:13px; margin-bottom:11px;
  color:var(--ic,var(--accent)); background:color-mix(in srgb, var(--ic,var(--accent)) 15%, transparent);
  border:1px solid color-mix(in srgb, var(--ic,var(--accent)) 32%, transparent); transition:transform .26s ease; }
.kb-cat-tile .kb-ico svg{ width:25px; height:25px; }
.kb-cat-tile:hover .kb-ico{ transform:scale(1.08) rotate(-3deg); }
.kb-cat-tile .nm{ font-size:16.5px; font-weight:600; color:var(--ink); }
.kb-cat-tile .ct{ font-family:var(--fm); font-size:12.5px; color:var(--ink-soft); letter-spacing:.04em; }
.kb-cat-tile .arr{ margin-top:6px; color:var(--ic,var(--accent)); font-size:13px; opacity:.92; }
.kb-list-head{ display:flex; align-items:center; gap:14px; margin:26px 0 4px; flex-wrap:wrap; }
.kb-list-head .kb-back{ background:none; border:1px solid var(--line); color:var(--ink-mid); border-radius:9px;
  padding:7px 14px; font-size:13px; cursor:pointer; transition:all .18s ease; }
.kb-list-head .kb-back:hover{ border-color:var(--accent); color:var(--accent); }
.kb-list-head .kb-title{ font-size:18px; font-weight:700; color:var(--ink); }
.kb-list-head .kb-count{ font-family:var(--fm); font-size:12.5px; color:var(--ink-soft); }
.kb-card .kb-more{ display:inline-block; margin-top:12px; font-size:12.5px; font-weight:600; color:var(--accent); }
button.kb-card{ width:100%; font:inherit; text-align:left; cursor:pointer; }
.kb-article{ background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:30px 34px; max-width:880px; margin-top:24px; }
.kb-article .kb-back{ background:none; border:1px solid var(--line); color:var(--ink-mid); border-radius:9px; padding:7px 14px; font-size:13px; cursor:pointer; transition:all .18s ease; margin-bottom:18px; }
.kb-article .kb-back:hover{ border-color:var(--accent); color:var(--accent); }
.kb-article .kb-cat{ font-family:var(--fm); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.kb-art-title{ font-size:24px; font-weight:700; color:var(--ink); margin:8px 0 18px; line-height:1.3; }
.kb-art-body{ color:var(--ink-mid); font-size:14.5px; line-height:1.85; }
.kb-art-body p{ margin:0 0 14px; }
.kb-art-body h4{ font-size:16px; font-weight:700; color:var(--ink); margin:24px 0 8px; }
.kb-art-body h5{ font-size:14.5px; font-weight:700; color:var(--ink); margin:18px 0 6px; }
.kb-art-body ul, .kb-art-body ol{ margin:0 0 14px; padding-left:22px; }
.kb-art-body li{ margin:6px 0; }
.kb-art-body a{ color:var(--accent-dark); text-decoration:underline; word-break:break-all; }
.kb-art-body img{ max-width:100%; height:auto; display:block; margin:16px 0; border-radius:10px; border:1px solid var(--line); }
.kb-art-body figure{ margin:16px 0; } .kb-art-body figcaption{ font-size:12.5px; color:var(--ink-soft); margin-top:6px; text-align:center; }
@media (max-width:900px){ .kb-cat-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .kb-cat-grid{ grid-template-columns:1fr; } }

.stories-hero {
  padding: 96px 0 80px;
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.stories-hero::before {
  content: '';
  position: absolute;
  top: -170px; right: -170px;
  width: 560px; height: 560px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%,
    rgba(24,208,230,.18) 0%, rgba(70,110,235,.07) 42%, transparent 68%);
  filter: blur(6px);
  pointer-events: none;
  z-index: 0;
  animation: heroGlowPulse 7s ease-in-out infinite;
}
.stories-hero::after {
  content: '';
  position: absolute;
  top: -70px; right: -110px;
  width: 460px; height: 460px;
  border-radius: 50%;
  background: repeating-radial-gradient(circle at 50% 50%,
    transparent 0 49px, rgba(24,208,230,.13) 49px 50px);
  -webkit-mask: radial-gradient(circle at 50% 50%, #000 6%, transparent 70%);
          mask: radial-gradient(circle at 50% 50%, #000 6%, transparent 70%);
  pointer-events: none;
  z-index: 0;
  transform-origin: center;
  animation: heroRingPulse 7s ease-in-out infinite;
}
.stories-hero > .wrap { position: relative; z-index: 1; }

.kicker {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.kicker::before {
  content: '';
  width: 24px; height: 1px;
  background: var(--accent);
}

.stories-hero h1 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(40px, 6vw, 72px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 24px 0 24px;
  max-width: 900px;
}
.stories-hero h1 em {
  font-style: italic;
  font-weight: 500;
  color: var(--accent-dark);
}

.stories-hero .lede {
  font-size: 18px;
  color: var(--ink-soft);
  max-width: 620px;
  margin-bottom: 56px;
}

.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line-strong);
}

.stat {
  padding: 28px 24px 28px 0;
  border-right: 1px solid var(--line);
  position: relative;
}
.stat:last-child { border-right: none; padding-right: 0; }
.stat:not(:first-child) { padding-left: 24px; }

.stat .num {
  font-family: var(--fd);
  font-size: 48px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.stat .lbl {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 12px;
}

/* ========== SECTION HEADER ========== */
.section { padding: 96px 0; border-bottom: 1px solid var(--line); }

.section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 56px;
  flex-wrap: wrap;
  gap: 16px;
}

.section-head h2 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.section-head .meta {
  font-family: var(--fm);
  font-size: 12px;
  color: var(--ink-soft);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ========== FEATURED CARDS ========== */
.featured-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 20px;
  align-items: stretch;
  padding: 14px 0 40px;
}

.featured-card {
  background: var(--surface);
  padding: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 14px;
  position: relative;
  transition: background 0.3s ease, border-color 0.3s ease, transform 0.25s ease;
  display: flex;
  flex-direction: column;
  cursor: pointer;
}
.featured-card:hover { background: var(--bg-deep); border-color: var(--ink-soft); transform: translateY(-3px); }

/* contained photo banner — fixed height so every card crops identically */
.featured-card .fc-media {
  position: relative;
  width: 100%;
  height: 190px;
  flex: 0 0 190px;
  overflow: hidden;
  background: linear-gradient(150deg, var(--ind-c, var(--accent)) 0%, var(--bg-deep) 100%);
}
.featured-card .fc-img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.5s ease;
}
.featured-card:hover .fc-img { transform: scale(1.045); }
.featured-card .fc-body {
  padding: 28px 32px 32px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.featured-card .num {
  font-family: var(--fm);
  font-size: 12.5px;
  color: var(--ink-faint);
  letter-spacing: 0.12em;
  margin-bottom: 14px;
}

.featured-card .logo {
  font-family: var(--fd);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: 16px;
}

.tag {
  display: inline-block;
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 2px;
  margin-bottom: 24px;
}

.featured-card .headline {
  font-family: var(--fd);
  font-size: 20px;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: -0.01em;
  margin-bottom: 24px;
  color: var(--ink);
}

.app-list {
  list-style: none;
  margin-top: auto;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}

.app-list li {
  font-size: 14px;
  color: var(--ink-mid);
  padding: 8px 0;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.app-list li::before {
  content: '';
  flex-shrink: 0;
  width: 6px; height: 6px;
  background: var(--accent);
  border-radius: 50%;
  margin-top: 9px;
}

.cta-link {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: 24px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  transition: gap 0.25s ease;
}
.cta-link:hover { gap: 14px; }
.cta-link::after { content: '→'; }

/* ========== FILTERS ========== */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 48px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
}

.filter-btn {
  font-family: var(--fb);
  font-size: 13px;
  font-weight: 400;
  padding: 8px 18px;
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--ink-mid);
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.2s ease;
  letter-spacing: -0.005em;
}
.filter-btn:hover { border-color: var(--ink); color: var(--ink); }
.filter-btn.active { background: var(--ink); border-color: var(--ink); color: var(--bg); }

.filter-count {
  font-family: var(--fm);
  font-size: 12.5px;
  color: var(--ink-faint);
  margin-left: 6px;
}
.filter-btn.active .filter-count { color: var(--ink-faint); }

/* ========== CASE CARDS GRID ========== */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
}

.case-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 28px 24px 24px;
  position: relative;
  transition: all 0.25s ease;
  display: flex;
  flex-direction: column;
  min-height: 280px;
  cursor: default;
}

.case-card.clickable { cursor: pointer; }
.case-card.clickable:hover {
  border-color: var(--line-strong);
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(0,0,0,.34);
}

.case-card .logo {
  font-family: var(--fd);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: 12px;
  color: var(--ink);
}

.case-card .headline {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--ink);
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
}

.case-card .apps {
  list-style: none;
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.9;
  flex: 1;
}

.case-card .apps li {
  position: relative;
  padding-left: 14px;
}

.case-card .apps li::before {
  content: '';
  position: absolute;
  left: 0; top: 11px;
  width: 6px; height: 1px;
  background: var(--accent);
}

/* Industry tag colors */
.tag-mfg     { background: var(--tag-mfg-bg);    color: var(--tag-mfg-fg); }
.tag-it      { background: var(--tag-it-bg);     color: var(--tag-it-fg); }
.tag-auto    { background: var(--tag-auto-bg);   color: var(--tag-auto-fg); }
.tag-energy  { background: var(--tag-energy-bg); color: var(--tag-energy-fg); }
.tag-bio     { background: var(--tag-bio-bg);    color: var(--tag-bio-fg); }
.tag-retail  { background: var(--tag-retail-bg); color: var(--tag-retail-fg); }
.tag-food    { background: var(--tag-food-bg);   color: var(--tag-food-fg); }
.tag-bldg    { background: var(--tag-bldg-bg);   color: var(--tag-bldg-fg); }
.tag-edu     { background: var(--tag-edu-bg);    color: var(--tag-edu-fg); }
.tag-hotel   { background: var(--tag-hotel-bg);  color: var(--tag-hotel-fg); }
.tag-pub     { background: var(--tag-pub-bg);    color: var(--tag-pub-fg); }
.tag-defense { background: var(--tag-defense-bg); color: var(--tag-defense-fg); }
.tag-power   { background: var(--tag-power-bg);   color: var(--tag-power-fg); }

.case-card.hidden { display: none; }

/* ===== Use-case (stories) topic differentiation by industry colour ===== */
:root{
  --i-mfg:#B9B9D4; --i-it:#85B6FF; --i-auto:#C2C2CE; --i-energy:#EBC062;
  --i-bio:#BCA0F0; --i-retail:#84D884; --i-food:#FF9E78; --i-bldg:#74C4DC;
  --i-edu:#5FDDA0; --i-hotel:#F08FBE; --i-pub:#C2C2CE;
}
.featured-card,.case-card{ position:relative; }
.featured-card::before,.case-card::before{
  content:''; position:absolute; left:0; top:0; height:3px; width:100%; z-index:2;
  background:var(--ind-c,var(--accent)); opacity:.85;
}
.case-card::before{ border-radius:4px 4px 0 0; }
/* per-industry photo on case-study listing cards (pre-entry)
   — unified indigo-navy duotone so all 8 photos share one palette and
     melt into the dark theme instead of competing with each other */
.featured-card::after{
  content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  display: var(--card-disp, none);
  background:
    linear-gradient(180deg, rgba(10,17,48,.62) 0%, rgba(10,17,48,.88) 100%),
    linear-gradient(160deg, #2f5aa0 0%, #0c1740 100%),
    var(--card-img) center/cover no-repeat;
  background-blend-mode: normal, color, normal;
  opacity:.6;
  transition: opacity .45s ease;
}
.featured-card:hover::after{
  opacity:.82;
}
.featured-card > *{ position:relative; z-index:1; }
.featured-card[data-industry="mfg"],.case-card[data-industry="mfg"]{ --ind-c:var(--i-mfg); }
.featured-card[data-industry="it"],.case-card[data-industry="it"]{ --ind-c:var(--i-it); }
.featured-card[data-industry="auto"],.case-card[data-industry="auto"]{ --ind-c:var(--i-auto); }
.featured-card[data-industry="energy"],.case-card[data-industry="energy"]{ --ind-c:var(--i-energy); }
.featured-card[data-industry="bio"],.case-card[data-industry="bio"]{ --ind-c:var(--i-bio); }
.featured-card[data-industry="retail"],.case-card[data-industry="retail"]{ --ind-c:var(--i-retail); }
.featured-card[data-industry="food"],.case-card[data-industry="food"]{ --ind-c:var(--i-food); }
.featured-card[data-industry="bldg"],.case-card[data-industry="bldg"]{ --ind-c:var(--i-bldg); }
.featured-card[data-industry="edu"],.case-card[data-industry="edu"]{ --ind-c:var(--i-edu); }
.featured-card[data-industry="hotel"],.case-card[data-industry="hotel"]{ --ind-c:var(--i-hotel); }
.featured-card[data-industry="pub"],.case-card[data-industry="pub"]{ --ind-c:var(--i-pub); }
.case-card.clickable:hover::before,.featured-card:hover::before{ opacity:1; }
.case-card .logo,.featured-card .logo{ color:var(--ink); }

/* ========== LOGO WALL ========== */
.logo-wall-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 0;
  border: 1px solid var(--line);
  background: var(--line);
}

.logo-cell {
  background: var(--surface);
  height: 96px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fd);
  font-size: 15px;
  font-weight: 500;
  color: var(--ink-faint);
  letter-spacing: -0.01em;
  transition: all 0.3s ease;
  text-align: center;
  padding: 8px 12px;
}

.logo-cell:hover {
  color: var(--accent);
  background: var(--bg-deep);
}

/* ========== CTA BLOCK ========== */
.cta-block {
  background: var(--ink);
  color: var(--bg);
  padding: 92px 0;
  margin-top: 116px;
}

.cta-block .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}

.cta-block h2 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(28px, 3.5vw, 42px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  max-width: 600px;
}
.cta-block h2 em {
  font-style: italic;
  color: var(--accent);
  font-weight: 500;
}

.big-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: var(--btn-bg);
  color: #fff;
  padding: 18px 32px;
  border: none;
  font-family: var(--fm);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 2px;
  cursor: pointer;
  transition: background 0.2s ease;
}
.big-cta-btn:hover { background: var(--btn-bg-h); }
.big-cta-btn::after { content: '→'; font-size: 16px; }

/* ========== AWARDS VIEW ========== */
.awards-hero { padding: 64px 0 44px; border-bottom: 1px solid var(--line); }
.awards-hero-lede {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-mid);
  max-width: 680px;
  margin-top: 20px;
}

.hero-top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 20px;
  gap: 16px;
  flex-wrap: wrap;
}

.inline-stats {
  font-family: var(--fm);
  font-size: 12.5px;
  color: var(--ink-faint);
  letter-spacing: 0.08em;
}
.inline-stats strong { color: var(--ink); font-weight: 500; }

.awards-hero h1, .partners-hero h1 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink);
  max-width: 800px;
}
.awards-hero h1 em, .partners-hero h1 em {
  font-style: italic;
  color: var(--accent);
  font-weight: 500;
}

.dist { padding: 28px 0 32px; border-bottom: 1px solid var(--line); }

.dist-title, .map-title, .partners-head .label, .awards-head .label {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.dist-title::before, .map-title::before {
  content:''; width:20px; height:1px; background: var(--ink-faint);
}
.dist-title .hint, .map-title .hint {
  margin-left: auto;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: none;
}

/* Legacy chart hidden (replaced by Featured Recognition marquee) */
.dist { display: none; }

/* ===== FEATURED RECOGNITION MARQUEE ===== */
.featured-recognition {
  padding: 56px 0 64px;
  border-bottom: 1px solid var(--line);
}

.fr-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 32px;
  gap: 16px;
  flex-wrap: wrap;
}

.fr-meta {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

.fr-grid {
  display: grid;
  grid-template-columns: 1.7fr 1fr 1fr 1fr;
  gap: 12px;
  align-items: stretch;
}

.fr-card {
  background: var(--surface);
  border: 1px solid var(--line);
  padding: 30px 26px 22px;
  display: flex;
  flex-direction: column;
  position: relative;
  min-height: 280px;
  transition: all 0.25s ease;
  overflow: hidden;
}

.fr-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--cat-color, var(--ink));
}

.fr-card:hover {
  transform: translateY(-2px);
  border-color: var(--ink-soft);
}

.fr-card.feature {
  background: var(--bg-deep);
  padding: 36px 32px 26px;
}

.fr-ornament {
  position: absolute;
  top: 22px;
  right: 26px;
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.fr-ornament::before {
  content: '★';
  font-family: var(--fd);
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
}

.fr-year {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 500;
  font-size: 58px;
  line-height: 0.95;
  letter-spacing: -0.035em;
  color: var(--ink);
  margin-bottom: 24px;
}

.fr-card.feature .fr-year {
  font-size: 96px;
  color: var(--accent);
  margin-bottom: 28px;
}

.fr-name {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 17px;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--ink);
}

.fr-card.feature .fr-name {
  font-size: 28px;
  font-weight: 500;
  line-height: 1.18;
  letter-spacing: -0.02em;
}

.fr-note {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  margin-top: 16px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.fr-note::before {
  content: '★';
  font-family: var(--fd);
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
}

.fr-cat {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-soft);
  padding-top: 18px;
  margin-top: auto;
  border-top: 1px solid var(--line);
  font-weight: 500;
}

.fr-card.feature .fr-cat {
  border-top-color: var(--line-strong);
  padding-top: 20px;
}

.fr-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cat-color, var(--ink-soft));
  flex-shrink: 0;
}

/* Sticky filter (awards + partners) */
.sub-filter-bar {
  position: sticky;
  top: 65px;
  z-index: 50;
  background: rgba(248, 244, 237, 0.94);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}

.sub-filter-inner {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px 16px;
  padding: 12px 0;
  align-items: center;
}

.filter-label {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-faint);
  text-align: right;
  min-width: 70px;
}

.chip-row { display: flex; gap: 4px; flex-wrap: wrap; }

.chip {
  font-family: var(--fm);
  font-size: 12.5px;
  font-weight: 500;
  padding: 4px 10px;
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--ink-mid);
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.15s ease;
  letter-spacing: 0.03em;
  white-space: nowrap;
}
.chip:hover { border-color: var(--ink); color: var(--ink); }
.chip.active { background: var(--ink); border-color: var(--ink); color: var(--bg); }
.chip .ct { margin-left: 4px; color: var(--ink-faint); font-size: 12px; }
.chip.active .ct { color: var(--ink-faint); }

.awards-section { padding: 28px 0 80px; }

.awards-head, .partners-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line-strong);
}

.awards-head .count, .partners-head .count {
  font-family: var(--fm);
  font-size: 12.5px;
  color: var(--ink);
  font-weight: 500;
}

.awards-list {
  list-style: none;
  columns: 2;
  column-gap: 48px;
  column-rule: 1px solid var(--line);
}

.award {
  border-bottom: 1px solid var(--line);
  break-inside: avoid;
}
.award-link {
  display: grid;
  grid-template-columns: 36px 6px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: background 0.15s ease;
}
.award-more {
  font-family: var(--fm);
  font-size: 10.5px;
  color: var(--accent);
  margin-left: 8px;
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.15s ease;
}
.award-link:hover .award-more { opacity: 1; }

.award-link:hover .award-name { color: var(--accent); }
.award-link:hover { background: rgba(24, 208, 230, 0.05); }
.award.hidden { display: none; }

.award-year {
  font-family: var(--fm);
  font-size: 12px;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
}

.award-dot { width: 6px; height: 6px; border-radius: 50%; }

.award-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.005em;
  transition: color 0.15s ease;
  line-height: 1.35;
}
.award-name .note {
  font-size: 12.5px;
  color: var(--ink-soft);
  margin-left: 6px;
  font-weight: 400;
}

.award .tag {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 2px;
  white-space: nowrap;
  margin: 0;
}

.dot-leadership { background: var(--tag-leadership-fg); }
.dot-industrial { background: var(--tag-industrial-fg); }
.dot-vertical { background: var(--tag-vertical-fg); }
.dot-product { background: var(--tag-product-fg); }
.dot-excellence { background: var(--tag-excellence-fg); }
.dot-innovation { background: var(--tag-innovation-fg); }
.dot-engineering { background: var(--tag-engineering-fg); }
.dot-platform { background: var(--tag-platform-fg); }
.dot-state { background: var(--tag-state-fg); }

.tag-leadership  { background: var(--tag-leadership-bg);  color: var(--tag-leadership-fg); }
.tag-industrial  { background: var(--tag-industrial-bg);  color: var(--tag-industrial-fg); }
.tag-vertical    { background: var(--tag-vertical-bg);    color: var(--tag-vertical-fg); }
.tag-product     { background: var(--tag-product-bg);     color: var(--tag-product-fg); }
.tag-excellence  { background: var(--tag-excellence-bg);  color: var(--tag-excellence-fg); }
.tag-innovation  { background: var(--tag-innovation-bg);  color: var(--tag-innovation-fg); }
.tag-engineering { background: var(--tag-engineering-bg); color: var(--tag-engineering-fg); }
.tag-platform    { background: var(--tag-platform-bg);    color: var(--tag-platform-fg); }
.tag-state       { background: var(--tag-state-bg);       color: var(--tag-state-fg); }

.empty {
  padding: 40px 0;
  text-align: center;
  color: var(--ink-faint);
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* ========== PARTNERS / WORLD MAP ========== */
.partners-hero { padding: 56px 0 36px; border-bottom: 1px solid var(--line); }

.region-section { padding: 28px 0 20px; border-bottom: 1px solid var(--line); }
.region-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:18px;
}
.region-card{
  position:relative; text-align:left; cursor:pointer; font-family:inherit;
  background:var(--surface); border:1px solid var(--line); border-radius:14px;
  padding:22px 22px 20px; overflow:hidden;
  transition:transform .2s, border-color .2s, background .2s;
}
.region-card:hover{ transform:translateY(-4px); border-color:var(--line-strong); }
.region-card::before{ content:''; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--rc-color,var(--accent)); }
.region-card.active{ border-color:var(--rc-color); background:var(--bg-deep); }
.region-card .rc-top{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; }
.region-card .rc-name{ font-family:var(--fd); font-weight:500; font-size:19px; letter-spacing:-0.01em; color:var(--ink); }
.region-card .rc-ko{ font-size:12px; color:var(--ink-soft); margin-top:3px; }
.region-card .rc-count{ font-family:var(--fd); font-weight:500; font-size:34px; line-height:1; color:var(--rc-color,var(--accent)); }
.region-card .rc-count span{ font-size:14px; color:var(--ink-soft); margin-left:3px; }
.region-card .rc-bar{ height:5px; border-radius:3px; background:var(--line); margin-top:18px; overflow:hidden; }
.region-card .rc-bar i{ display:block; height:100%; background:var(--rc-color,var(--accent)); border-radius:3px; }
.region-card .rc-share{ font-family:var(--fm); font-size:12px; letter-spacing:.06em; color:var(--ink-faint); margin-top:8px; }
@media(max-width:860px){ .region-grid{ grid-template-columns:repeat(2,1fr);} }
@media(max-width:520px){ .region-grid{ grid-template-columns:1fr;} }

.map-section { padding: 24px 0 16px; border-bottom: 1px solid var(--line); }

.map-title .reset {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: transparent;
  border: none;
  color: var(--accent);
  cursor: pointer;
  padding: 0;
  display: none;
}
.map-title .reset.visible { display: inline-block; }
.map-title .reset::before { content:'×'; margin-right: 4px; font-size: 14px; }

.map-container { position: relative; width: 100%; margin-top: 4px; }

.world-map {
  display: block;
  width: 100%;
  height: auto;
  max-height: 460px;
}

.map-grid line {
  stroke: var(--line);
  stroke-width: 0.5;
  stroke-dasharray: 1 6;
}

.continent .hit { fill: transparent; cursor: pointer; }
.continent { cursor: pointer; outline: none; }

.continent circle {
  r: 2.2;
  fill: var(--ink-mid);
  cursor: pointer;
  transition: fill 0.25s ease, r 0.2s ease, opacity 0.25s ease;
  pointer-events: none;
}

.continent[data-region="na"]:hover circle,
.continent[data-region="na"].active circle { fill: var(--r-na-fg); r: 2.6; }
.continent[data-region="sa"]:hover circle,
.continent[data-region="sa"].active circle { fill: var(--r-sa-fg); r: 2.6; }
.continent[data-region="eu"]:hover circle,
.continent[data-region="eu"].active circle { fill: var(--r-eu-fg); r: 2.6; }
.continent[data-region="af"]:hover circle,
.continent[data-region="af"].active circle { fill: var(--r-af-fg); r: 2.6; }
.continent[data-region="as"]:hover circle,
.continent[data-region="as"].active circle { fill: var(--r-as-fg); r: 2.6; }
.continent[data-region="oc"]:hover circle,
.continent[data-region="oc"].active circle { fill: var(--r-oc-fg); r: 2.6; }

.world-map.has-active .continent:not(.active) circle { opacity: 0.2; }

.continent text { pointer-events: none; }

.continent-name {
  font-family: var(--fm);
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  fill: var(--ink);
  text-anchor: middle;
  transition: fill 0.25s ease;
  font-weight: 500;
}

.continent-count {
  font-family: var(--fd);
  font-size: 38px;
  font-weight: 500;
  fill: var(--ink);
  text-anchor: middle;
  letter-spacing: -0.02em;
  transition: fill 0.25s ease;
}

.continent:hover .continent-count,
.continent.active .continent-count { fill: var(--accent); }
.continent:hover .continent-name,
.continent.active .continent-name { fill: var(--accent); }

.world-map.has-active .continent:not(.active) text { opacity: 0.3; }

.partners-section { padding: 28px 0 64px; }

.partners-list {
  list-style: none;
  columns: 2;
  column-gap: 40px;
  column-rule: 1px solid var(--line);
}

.partner {
  border-bottom: 1px solid var(--line);
  break-inside: avoid;
}
.partner-link {
  display: grid;
  grid-template-columns: 8px 1fr auto;
  align-items: start;
  gap: 12px;
  padding: 11px 0;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: background 0.15s ease;
}
.partner-more {
  font-family: var(--fm);
  font-size: 10.5px;
  color: var(--accent);
  margin-left: 8px;
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.15s ease;
}
.partner-link:hover .partner-more { opacity: 1; }

.partner-link:hover .partner-name { color: var(--accent); }
.partner-link:hover { background: rgba(24, 208, 230, 0.05); }
.partner.hidden { display: none; }

.partner-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  margin-top: 6px;
}

.partner-body { display: flex; flex-direction: column; gap: 1px; min-width: 0; }

.partner-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.005em;
  transition: color 0.15s ease;
  line-height: 1.35;
}

.partner-desc {
  font-size: 12.5px;
  color: var(--ink-soft);
  line-height: 1.4;
}

.partner .tag {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 2px;
  white-space: nowrap;
  margin: 2px 0 0 0;
}

.dot-na { background: var(--r-na-fg); }
.dot-sa { background: var(--r-sa-fg); }
.dot-eu { background: var(--r-eu-fg); }
.dot-as { background: var(--r-as-fg); }
.dot-af { background: var(--r-af-fg); }
.dot-oc { background: var(--r-oc-fg); }

.tag-na { background: var(--r-na-bg); color: var(--r-na-fg); }
.tag-sa { background: var(--r-sa-bg); color: var(--r-sa-fg); }
.tag-eu { background: var(--r-eu-bg); color: var(--r-eu-fg); }
.tag-as { background: var(--r-as-bg); color: var(--r-as-fg); }
.tag-af { background: var(--r-af-bg); color: var(--r-af-fg); }
.tag-oc { background: var(--r-oc-bg); color: var(--r-oc-fg); }

/* Join / Partner CTA */
.join { background: var(--ink); color: var(--bg); padding: 56px 0; }

.join-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}

.join-text { flex: 1; min-width: 280px; }

.join h2 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
.join h2 em { font-style: italic; color: #0C6F7E; font-weight: 600; }
.join-figure { flex: 0 0 40%; min-width: 280px; margin: 0; }
.join-figure img { width: 100%; display: block; border-radius: 12px; box-shadow: 0 18px 50px rgba(0,0,0,.22); }
.join-body { flex: 1; min-width: 280px; display: flex; flex-direction: column; align-items: flex-start; gap: 22px; }
@media (max-width: 720px){ .join-figure { flex-basis: 100%; } }

.join p { font-size: 14px; opacity: 0.75; max-width: 520px; }

.join-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--btn-bg);
  color: #fff;
  padding: 14px 24px;
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 2px;
  transition: background 0.2s ease;
}
.join-btn:hover { background: var(--btn-bg-h); }
.join-btn::after { content: '→'; font-size: 14px; }

/* ========== CASE STUDY DETAIL VIEW ========== */
.case-page {
  max-width: 960px;
  margin: 0 auto;
  background: var(--surface);
}

.case-back {
  max-width: 960px;
  margin: 0 auto;
  padding: 24px 56px 0;
  background: var(--surface);
}

.case-back button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: color 0.15s;
}
.case-back button:hover { color: var(--accent); }

.case-page .top-band {
  color: #fff;
  padding: 14px 56px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.case-page .top-band .label { opacity: 0.85; }

.case-page .hero {
  padding: 64px 56px 48px;
  border-bottom: 1px solid var(--line);
  position: relative;
}

.case-page .hero .meta {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.16em;
  color: var(--ink-faint);
  margin-bottom: 32px;
}

.case-page .hero .case-logo {
  font-family: var(--fd);
  font-size: 28px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: 32px;
  display: inline-block;
  padding-bottom: 6px;
}

.case-page .hero h1 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: 52px;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
}
.case-page .hero h1 em { font-style: italic; font-weight: 500; }

.case-page .hero .tagline {
  font-size: 17px;
  color: var(--ink-soft);
  max-width: 620px;
  margin-bottom: 48px;
}

.qs-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--line-strong);
  margin-top: 24px;
}

.qs { padding: 24px 24px 8px 0; border-right: 1px solid var(--line); }
.qs:not(:first-child) { padding-left: 24px; }
.qs:last-child { border-right: none; padding-right: 0; }

.qs-num {
  font-family: var(--fd);
  font-size: 40px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.02em;
}

.qs-lbl {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 10px;
}

.sec {
  padding: 48px 56px;
  border-bottom: 1px solid var(--line);
}

.sec-label {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.sec-label::before {
  content: '';
  width: 32px;
  height: 1px;
  background: currentColor;
}

.sec h2 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: 32px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
  color: var(--ink);
}

.sec p.body { font-size: 16px; color: var(--ink-mid); max-width: 760px; }

.ch-list { list-style: none; margin-top: 8px; }

.ch-list li {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
}
.ch-list li:last-child { border-bottom: none; }

.ch-num {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.08em;
  flex-shrink: 0;
  margin-top: 4px;
  min-width: 32px;
}

.ch-txt { font-size: 15px; color: var(--ink-mid); }

.sol-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  margin-top: 8px;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}

.sol-card {
  padding: 24px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--surface);
  transition: background 0.2s ease;
}

.sol-num {
  font-family: var(--fm);
  font-size: 12.5px;
  color: var(--ink-faint);
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}

.sol-card h4 {
  font-family: var(--fd);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: 8px;
  color: var(--ink);
}

.sol-card p { font-size: 13px; color: var(--ink-soft); line-height: 1.55; }

.arch {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 16px;
  align-items: stretch;
  position: relative;
}

.arch-node {
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 20px 16px;
  text-align: center;
  position: relative;
}

.arch-node .ico {
  font-family: var(--fd);
  font-size: 24px;
  margin-bottom: 8px;
  font-weight: 500;
}

.arch-node .name { font-size: 13px; font-weight: 500; color: var(--ink); }

.arch-node .desc {
  font-size: 12.5px;
  color: var(--ink-soft);
  margin-top: 4px;
  font-family: var(--fm);
  letter-spacing: 0.04em;
}

.arch-arrow {
  position: absolute;
  right: -10px; top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
  font-weight: 500;
  z-index: 2;
  background: var(--surface);
  width: 20px; height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.res-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: 16px;
  border-top: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
}

.res { padding: 28px 20px 28px 0; border-right: 1px solid var(--line); }
.res:not(:first-child) { padding-left: 20px; }
.res:last-child { border-right: none; padding-right: 0; }

.res-num {
  font-family: var(--fd);
  font-size: 44px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.02em;
}

.res-lbl {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 10px;
}

.quote-sec {
  padding: 56px;
  text-align: center;
}

.quote-sec blockquote {
  font-family: var(--fd);
  font-style: italic;
  font-size: 22px;
  line-height: 1.5;
  color: var(--ink);
  max-width: 700px;
  margin: 0 auto 20px;
  letter-spacing: -0.01em;
}

.quote-sec blockquote::before {
  content: '"';
  display: block;
  font-size: 64px;
  line-height: 0.5;
  margin-bottom: 24px;
  font-weight: 600;
}

.quote-sec cite {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-style: normal;
}

.case-footer {
  padding: 40px 56px;
  background: var(--ink);
  color: var(--bg);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  max-width: 960px;
  margin: 0 auto;
}

.case-footer .ft-logo {
  font-family: var(--fd);
  font-size: 18px;
  font-weight: 500;
}

.case-footer .ft-meta {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.7;
}

/* ========== APPLICATIONS VIEW ========== */
.apps-hero {
  padding: 96px 0 56px;
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.apps-hero::before {
  content: '';
  position: absolute;
  top: -170px; right: -170px;
  width: 560px; height: 560px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%,
    rgba(24,208,230,.18) 0%, rgba(70,110,235,.07) 42%, transparent 68%);
  filter: blur(6px);
  pointer-events: none;
  z-index: 0;
  animation: heroGlowPulse 7s ease-in-out infinite;
}
.apps-hero::after {
  content: '';
  position: absolute;
  top: -70px; right: -110px;
  width: 460px; height: 460px;
  border-radius: 50%;
  background: repeating-radial-gradient(circle at 50% 50%,
    transparent 0 49px, rgba(24,208,230,.13) 49px 50px);
  -webkit-mask: radial-gradient(circle at 50% 50%, #000 6%, transparent 70%);
          mask: radial-gradient(circle at 50% 50%, #000 6%, transparent 70%);
  pointer-events: none;
  z-index: 0;
  transform-origin: center;
  animation: heroRingPulse 7s ease-in-out infinite;
}
.apps-hero > .wrap { position: relative; z-index: 1; }

.apps-controls {
  position: sticky;
  top: 65px;
  z-index: 50;
  background: rgba(0, 0, 26, 0.82);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  padding: 16px 0 14px;
}

.apps-controls-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
}

.search-wrap { position: relative; max-width: 360px; width: 100%; }
.search-wrap svg {
  position: absolute; left: 14px; top: 50%;
  transform: translateY(-50%);
  color: var(--ink-faint);
}
.search-wrap input {
  width: 100%;
  font-family: var(--fb);
  font-size: 13px;
  padding: 10px 14px 10px 40px;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 100px;
  color: var(--ink);
  outline: none;
  transition: border-color 0.15s;
}
.search-wrap input:focus { border-color: var(--ink); }
.search-wrap input::placeholder { color: var(--ink-faint); }

.sort-wrap { display: flex; align-items: center; gap: 12px; }
.sort-wrap label {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.sort-wrap select {
  font-family: var(--fb);
  font-size: 13px;
  padding: 7px 30px 7px 14px;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  color: var(--ink);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%231A1815' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  outline: none;
}

.cat-bar {
  display: flex;
  gap: 8px;
  margin-top: 14px;
  flex-wrap: wrap;
}

.cat-pill {
  font-family: var(--fb);
  font-size: 12px;
  font-weight: 500;
  padding: 6px 14px;
  background: transparent;
  border: 1px solid var(--line-strong);
  border-radius: 100px;
  color: var(--ink-mid);
  cursor: pointer;
  transition: all 0.15s ease;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.cat-pill:hover { border-color: var(--ink); color: var(--ink); }
.cat-pill.active { background: var(--ink); border-color: var(--ink); color: var(--bg); }
.cat-pill .count {
  font-family: var(--fm);
  font-size: 12px;
  padding: 1px 6px;
  background: var(--bg-deep);
  color: var(--ink-soft);
  border-radius: 100px;
  font-weight: 500;
}
.cat-pill.active .count { background: rgba(255,255,255,0.18); color: var(--bg); }

.apps-results-meta {
  padding: 28px 0 16px;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.apps-results-meta h2 {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.apps-results-meta .count-label {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
}

.apps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  margin-bottom: 80px;
}

.app-card {
  background: var(--surface);
  padding: 28px 26px 24px;
  cursor: pointer;
  border: none;
  font-family: inherit;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 220px;
  transition: background 0.18s;
}
.app-card:hover { background: var(--bg-deep); }
.app-card:hover .arrow { opacity: 1; transform: translateX(0); }

.app-card-top {
  display: flex; align-items: center; justify-content: space-between;
}

/* App-category color tags */
.app-tag {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  font-weight: 500;
}
.app-tag.env    { background:rgba(34,201,166,.16);  color:var(--c-env); }
.app-tag.cold   { background:rgba(59,142,240,.16);  color:var(--c-cold); }
.app-tag.health { background:rgba(155,107,232,.18); color:#B79BF2; }
.app-tag.indus  { background:rgba(255,123,69,.16);  color:var(--c-indus); }
.app-tag.fac    { background:rgba(39,176,214,.16);  color:var(--c-fac); }
.app-tag.agri   { background:rgba(122,194,60,.18);  color:var(--c-agri); }

/* ===== Category accent colours (used across apps, cat-pills, cat-cards, related) ===== */
:root{
  --c-env:#22C9A6;   --c-cold:#3B8EF0;   --c-health:#9B6BE8;
  --c-indus:#FF7B45;  --c-fac:#27B0D6;   --c-agri:#7AC23C;
}
/* coloured left edge per app category */
.app-card{ position:relative; border-left:3px solid transparent; }
.app-card::before{ content:''; position:absolute; left:0; top:0; bottom:0; width:3px; background:transparent; transition:width .18s; }
.app-card.env::before    { background:var(--c-env); }
.app-card.cold::before   { background:var(--c-cold); }
.app-card.health::before { background:var(--c-health); }
.app-card.indus::before  { background:var(--c-indus); }
.app-card.fac::before    { background:var(--c-fac); }
.app-card.agri::before   { background:var(--c-agri); }
.app-card:hover::before  { width:6px; }
.app-card.env:hover    { background:rgba(34,201,166,.07); }
.app-card.cold:hover   { background:rgba(59,142,240,.07); }
.app-card.health:hover { background:rgba(155,107,232,.07); }
.app-card.indus:hover  { background:rgba(255,123,69,.08); }
.app-card.fac:hover    { background:rgba(39,176,214,.07); }
.app-card.agri:hover   { background:rgba(122,194,60,.08); }

/* category filter pills get a colour dot + coloured active state */
.cat-pill[data-cat]::before{ content:''; width:8px; height:8px; border-radius:50%; background:var(--line-strong); flex:none; }
.cat-pill[data-cat="env"]::before    { background:var(--c-env); }
.cat-pill[data-cat="cold"]::before   { background:var(--c-cold); }
.cat-pill[data-cat="health"]::before { background:var(--c-health); }
.cat-pill[data-cat="indus"]::before  { background:var(--c-indus); }
.cat-pill[data-cat="fac"]::before    { background:var(--c-fac); }
.cat-pill[data-cat="agri"]::before   { background:var(--c-agri); }
.cat-pill[data-cat="all"]::before    { background:linear-gradient(135deg,var(--c-env),var(--c-indus)); }
.cat-pill.active[data-cat="env"]    { background:var(--c-env);   border-color:var(--c-env);   color:#04201B; }
.cat-pill.active[data-cat="cold"]   { background:var(--c-cold);  border-color:var(--c-cold);  color:#06203F; }
.cat-pill.active[data-cat="health"] { background:var(--c-health);border-color:var(--c-health);color:#fff; }
.cat-pill.active[data-cat="indus"]  { background:var(--c-indus); border-color:var(--c-indus); color:#311104; }
.cat-pill.active[data-cat="fac"]    { background:var(--c-fac);   border-color:var(--c-fac);   color:#04222B; }
.cat-pill.active[data-cat="agri"]   { background:var(--c-agri);  border-color:var(--c-agri);  color:#142608; }
.cat-pill.active[data-cat] .count   { background:rgba(0,0,0,.18); color:inherit; }

/* inactive pills were nearly invisible (only a tiny dot) — give each a clear,
   colour-coded fill / border / text so categories are easy to tell apart */
.cat-pill[data-cat="env"]:not(.active)    { background:rgba(34,201,166,.12);  border-color:rgba(34,201,166,.65);  color:var(--c-env); }
.cat-pill[data-cat="cold"]:not(.active)   { background:rgba(59,142,240,.13);  border-color:rgba(59,142,240,.65);  color:var(--c-cold); }
.cat-pill[data-cat="health"]:not(.active) { background:rgba(155,107,232,.14); border-color:rgba(155,107,232,.65); color:#B79BF2; }
.cat-pill[data-cat="indus"]:not(.active)  { background:rgba(255,123,69,.13);  border-color:rgba(255,123,69,.65);  color:var(--c-indus); }
.cat-pill[data-cat="fac"]:not(.active)    { background:rgba(39,176,214,.12);  border-color:rgba(39,176,214,.65);  color:var(--c-fac); }
.cat-pill[data-cat="agri"]:not(.active)   { background:rgba(122,194,60,.14);  border-color:rgba(122,194,60,.65);  color:var(--c-agri); }
.cat-pill[data-cat="all"]:not(.active)    { background:rgba(255,255,255,.05); border-color:var(--ink-soft);       color:var(--ink); }
.cat-pill[data-cat]:not(.active):hover    { filter:brightness(1.18); border-color:currentColor; }
.cat-pill[data-cat]:not(.active) .count   { background:rgba(0,0,0,.28); color:inherit; }

.new-badge {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
}
.doc-badge {
  font-family: var(--fm);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--accent-dark);
  font-weight: 600;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 2px 9px;
}

.app-name {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin-top: auto;
}

.app-desc {
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink-soft);
}

.app-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 2px;
}

.app-sensors {
  font-family: var(--fm);
  font-size: 12px;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
}

.arrow {
  font-size: 15px;
  color: var(--ink);
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 0.2s, transform 0.2s;
}

.apps-empty {
  grid-column: 1 / -1;
  background: var(--surface);
  padding: 64px 40px;
  text-align: center;
}
.apps-empty h3 {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 22px;
  color: var(--ink);
  margin-bottom: 8px;
}
.apps-empty p { font-size: 13px; color: var(--ink-soft); margin-bottom: 18px; }
.apps-empty button {
  font-family: var(--fb);
  font-size: 13px;
  font-weight: 500;
  padding: 9px 18px;
  background: var(--ink);
  color: var(--bg);
  border: none;
  border-radius: 100px;
  cursor: pointer;
}

/* ========== APP DETAIL VIEW ========== */
.app-detail-hero {
  padding: 56px 0 56px;
  border-bottom: 1px solid var(--line);
}

.back-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  background: none; border: none;
  cursor: pointer; padding: 0;
  margin-bottom: 32px;
  transition: color 0.15s;
  font-weight: 500;
}
.back-link:hover { color: var(--accent); }

.app-detail-hero .app-tag {
  font-size: 12.5px; padding: 4px 10px;
  display: inline-block; margin-bottom: 18px;
}
.app-detail-hero h1 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--ink);
  max-width: 900px;
  margin-bottom: 22px;
}
.app-detail-hero .lede {
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink-mid);
  max-width: 680px;
}

.snapshot-bar {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--line-strong);
  margin-top: 40px;
  padding-top: 24px;
}
.snap {
  border-right: 1px solid var(--line);
  padding-right: 28px;
}
.snap:not(:first-child) { padding-left: 28px; }
.snap:last-child { border-right: none; padding-right: 0; }
.snap-label {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 8px;
}
.snap-value {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 26px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.snap-desc {
  font-size: 12px;
  color: var(--ink-soft);
  margin-top: 8px;
  line-height: 1.5;
}

.case-section {
  padding: 64px 0;
  border-bottom: 1px solid var(--line);
}

.case-row {
  display: grid;
  grid-template-columns: 210px 1fr;
  gap: 56px;
  align-items: start;
}
.case-row .side {
  position: sticky;
  top: 100px;
}
.case-step {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
}
.case-side-title {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 12px;
}
.case-side-desc {
  font-size: 12.5px;
  color: var(--ink-soft);
  line-height: 1.55;
}
.case-content { max-width: 720px; }
.case-lead {
  font-family: var(--fd);
  font-weight: 400;
  font-size: 21px;
  line-height: 1.4;
  color: var(--ink);
  letter-spacing: -0.015em;
  margin-bottom: 22px;
}
.case-content p {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-mid);
  margin-bottom: 16px;
}
.case-content p.muted { color: var(--ink-soft); }
.case-content strong { color: var(--ink); font-weight: 600; }

.pain-list {
  list-style: none;
  margin: 22px 0;
  border-left: 2px solid var(--accent);
  padding-left: 22px;
}
.pain-list li {
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}
.pain-list li:last-child { border-bottom: none; }
.pain-list li strong {
  display: block;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 3px;
  font-size: 14.5px;
}
.pain-list li span {
  font-size: 13.5px;
  color: var(--ink-soft);
}

.sensor-tags {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin: 18px 0 22px;
  padding: 14px 18px;
  background: var(--bg-deep);
  border-left: 2px solid var(--accent);
}
.sensor-tags-label {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  width: 100%;
  margin-bottom: 3px;
}
.sensor-tag {
  font-family: var(--fm);
  font-size: 11.5px;
  padding: 3px 9px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 3px;
  color: var(--ink);
  font-weight: 500;
}

.phases {
  margin: 24px 0;
  border-top: 1px solid var(--line);
}
.phase {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 20px;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.phase-tag {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.1em;
  color: var(--accent);
  font-weight: 500;
}
.phase-title {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 16px;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin-bottom: 3px;
}
.phase-desc {
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.55;
}
.phase-duration {
  font-family: var(--fm);
  font-size: 12px;
  color: var(--ink-faint);
  margin-top: 4px;
  letter-spacing: 0.04em;
}

.roi-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  margin: 24px 0;
}
.roi-card {
  background: var(--surface);
  padding: 26px 22px;
}
.roi-num {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 34px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--accent);
  margin-bottom: 10px;
}
.roi-desc {
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--ink-mid);
}

.comparison {
  margin: 24px 0;
  padding: 20px 22px;
  background: var(--bg-deep);
}
.compare-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px;
}
.compare-side h5 {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 8px;
  font-weight: 600;
}
.compare-side.before h5 { color: var(--ink-soft); }
.compare-side.after h5 { color: var(--accent); }
.compare-side p {
  font-size: 13.5px;
  line-height: 1.6;
  margin: 0;
}
.compare-side.before p { color: var(--ink-soft); }
.compare-side.after p { color: var(--ink); }

/* "이 솔루션 도입 고객사" - app detail's customers section */
.app-customers-section {
  padding: 64px 0;
  border-bottom: 1px solid var(--line);
  background: var(--bg-deep);
}
.app-customers-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 28px;
}
.app-customers-head h3 {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 26px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.app-customers-head .meta {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
}

.app-customers-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
}

.app-customer-card {
  background: var(--surface);
  border: 1px solid var(--line);
  padding: 22px 20px 18px;
  display: flex; flex-direction: column; gap: 10px;
  transition: all 0.2s ease;
}
.app-customer-card.clickable {
  cursor: pointer;
}
.app-customer-card.clickable:hover {
  border-color: var(--ink);
  transform: translateY(-2px);
}
.app-customer-card .ac-name {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.app-customer-card .ac-headline {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--ink-soft);
}
.app-customer-card .ac-link {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: 4px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: gap 0.2s;
}
.app-customer-card.clickable:hover .ac-link { gap: 10px; }
.app-customer-card .ac-link::after { content: '→'; }

/* "관련 어플리케이션" - case study's related apps section */
.related-apps-section {
  padding: 56px 56px 0;
  background: var(--bg-deep);
  border-top: 1px solid var(--line);
}
.related-apps-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding-bottom: 22px;
  margin-bottom: 22px;
  border-bottom: 1px solid var(--line);
}
.related-apps-head h3 {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.related-apps-head .meta {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.related-apps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 10px;
  padding-bottom: 56px;
}
.related-app-card {
  background: var(--surface);
  border: 1px solid var(--line);
  padding: 18px 16px;
  cursor: pointer;
  transition: all 0.18s ease;
  display: flex; flex-direction: column; gap: 8px;
}
.related-app-card:hover { border-color: var(--ink); }
.related-app-card .ra-name {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 15px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.related-app-card .ra-desc {
  font-size: 12px;
  color: var(--ink-soft);
  line-height: 1.5;
}

/* Application CTA */
.app-cta {
  padding: 80px 0;
  background: var(--ink);
  color: var(--bg);
}
.app-cta .wrap {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
}
.app-cta h2 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(28px, 3.5vw, 38px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  max-width: 680px;
}
.app-cta h2 em { font-style: italic; color: var(--accent-soft); font-weight: 500; }
.app-cta p {
  font-size: 14px;
  color: rgba(248, 244, 237, 0.7);
  margin-top: 12px;
  max-width: 520px;
}
.app-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--btn-bg);
  color: #fff;
  padding: 16px 28px;
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 2px;
  transition: background 0.2s;
  white-space: nowrap;
}
.app-cta-btn:hover { background: var(--btn-bg-h); }
.app-cta-btn::after { content: '→'; font-size: 14px; }

/* ==================================================== */
/* HOME PAGE                                              */
/* ==================================================== */

/* HERO */
.home-hero {
  padding: 96px 0 96px;
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.home-hero::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 640px; height: 640px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%,
    rgba(24,208,230,.16) 0%, rgba(70,110,235,.06) 42%, transparent 68%);
  filter: blur(8px);
  pointer-events: none;
  z-index: 0;
  animation: heroGlowPulse 7s ease-in-out infinite;
}
.home-hero::after {
  content: '';
  position: absolute;
  top: -90px; right: -150px;
  width: 540px; height: 540px;
  border-radius: 50%;
  background: repeating-radial-gradient(circle at 50% 50%,
    transparent 0 57px, rgba(24,208,230,.12) 57px 58px);
  -webkit-mask: radial-gradient(circle at 50% 50%, #000 6%, transparent 70%);
          mask: radial-gradient(circle at 50% 50%, #000 6%, transparent 70%);
  pointer-events: none;
  z-index: 0;
  transform-origin: center;
  animation: heroRingPulse 7s ease-in-out infinite;
}

.home-headline {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(44px, 7vw, 92px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 28px 0 28px;
  max-width: 900px;
  position: relative;
  z-index: 2;
}
.home-headline em {
  font-style: italic;
  font-weight: 500;
  color: var(--accent-dark);
}

.home-lede {
  font-size: 18px;
  line-height: 1.7;
  color: var(--ink-mid);
  max-width: 1000px;
  margin-bottom: 52px;
  position: relative;
  z-index: 2;
  text-wrap: balance;
}
.home-lede strong {
  color: var(--ink);
  font-weight: 600;
}

.home-cta-row {
  display: flex;
  gap: 12px;
  margin-bottom: 80px;
  flex-wrap: wrap;
  position: relative;
  z-index: 2;
}

.cta-primary {
  font-family: var(--fb);
  font-size: 14px;
  font-weight: 500;
  padding: 14px 28px;
  background: var(--btn-bg);
  color: #fff;
  border: none;
  border-radius: 2px;
  cursor: pointer;
  transition: background 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.cta-primary:hover { background: var(--btn-bg-h); }
.cta-primary::after { content: '→'; font-size: 15px; }

.cta-ghost {
  font-family: var(--fb);
  font-size: 14px;
  font-weight: 500;
  padding: 14px 28px;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.cta-ghost:hover { background: var(--ink); color: var(--bg); }
.cta-ghost::after { content: '→'; font-size: 15px; }

.cta-download {
  font-family: var(--fb);
  font-size: 14px;
  font-weight: 500;
  padding: 14px 28px;
  background: transparent;
  color: var(--accent-dark);
  border: 1px solid var(--accent);
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.cta-download:hover { background: rgba(24, 208, 230, 0.12); color: var(--accent-dark); }
.cta-download::after { content: '↓'; font-size: 16px; font-weight: 700; }

.home-trust {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: clamp(40px, 6vw, 68px);
  padding-top: 10px;
  border-top: 1px solid var(--line-strong);
  position: relative;
  z-index: 2;
}

.trust-item {
  padding: 38px 24px 30px 0;
  border-right: 1px solid var(--line);
}
.trust-item:last-child { border-right: none; padding-right: 0; }
.trust-item:not(:first-child) { padding-left: 24px; }

/* ===== Customer logo marquee ===== */
.logo-marquee-section{ padding:64px 0 56px; border-bottom:1px solid var(--line); background:var(--bg-deep); overflow:hidden; }
.logo-marquee-section .lm-head{ text-align:center; margin-bottom:36px; }
.logo-marquee-section .lm-head h2{ font-family:var(--fd); font-weight:400; font-size:clamp(24px,3vw,34px); letter-spacing:-0.02em; color:var(--ink); margin-top:10px; }
.logo-marquee{ position:relative; width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.logo-track{ display:flex; align-items:stretch; gap:28px; width:max-content; animation:logoScroll 50s linear infinite; padding:4px 0; }
.logo-marquee:hover .logo-track{ animation-play-state:paused; }
.logo-slide{ display:flex; flex-direction:column; align-items:center; gap:9px; flex:none; }
.logo-slide img{ height:74px; width:auto; min-width:128px; max-width:172px; object-fit:contain;
  background:#F4F6FA; border-radius:14px; padding:16px 24px; box-sizing:border-box;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 2px 0 rgba(255,255,255,.04) inset, 0 8px 22px rgba(0,0,0,.30);
  opacity:.9; transition:transform .25s, box-shadow .25s, opacity .25s; }
.logo-slide:hover img{ transform:translateY(-4px); opacity:1; box-shadow:0 14px 30px rgba(0,0,0,.42); }
.logo-slide span{ font-family:var(--fm); font-size:12px; letter-spacing:.04em; color:var(--ink-faint); }
@keyframes logoScroll{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
@media(max-width:760px){ .logo-track{ gap:18px; } .logo-slide img{ height:60px; min-width:104px; max-width:140px; padding:12px 18px; } }

.t-num {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 44px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.t-plus {
  font-size: 24px;
  color: var(--accent);
  margin-left: 2px;
  font-weight: 500;
}

.t-lbl {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 12px;
}

/* ===== HOW IT WORKS ===== */
.how-section {
  padding: 96px 0;
  border-bottom: 1px solid var(--line);
}

.how-grid {
  display: grid;
  grid-template-columns: 1fr 32px 1fr 32px 1fr;
  gap: 0;
  align-items: stretch;
}

.how-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  color: var(--accent);
  font-family: var(--fd);
  font-weight: 400;
  padding-top: 100px;
}

.how-step {
  background: var(--surface);
  border: 1px solid var(--line);
  padding: 32px 28px 28px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: all 0.25s ease;
}
.how-step:hover { border-color: var(--ink-soft); transform: translateY(-2px); }

.how-step-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 32px;
}

.how-num {
  font-family: var(--fd);
  font-weight: 500;
  font-style: italic;
  font-size: 32px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--accent);
}

.how-tag {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 600;
  padding: 4px 10px;
  background: var(--bg-deep);
  border-radius: 2px;
}

.how-icon {
  font-family: var(--fd);
  font-size: 56px;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 28px;
  font-weight: 500;
}

.how-name {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 26px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 16px;
}

.how-desc {
  font-size: 14px;
  line-height: 1.65;
  color: var(--ink-soft);
  margin-bottom: 24px;
}

.how-feats {
  list-style: none;
  margin-top: auto;
  border-top: 1px solid var(--line);
  padding-top: 18px;
}

.how-feats li {
  display: flex;
  justify-content: space-between;
  font-family: var(--fm);
  font-size: 12.5px;
  padding: 6px 0;
  border-bottom: 1px solid var(--line);
}
.how-feats li:last-child { border-bottom: none; }

.f-k { color: var(--ink-soft); letter-spacing: 0.04em; text-transform: uppercase; font-size: 12px; }
.f-v { color: var(--ink); font-weight: 500; text-align: right; }

/* ===== WHY MONNIT ===== */
.why-section {
  padding: 96px 0;
  border-bottom: 1px solid var(--line);
  background: var(--bg-deep);
}

.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}

.why-card {
  background: var(--surface);
  padding: 36px 28px 32px;
  display: flex;
  flex-direction: column;
  transition: background 0.25s ease;
}
.why-card:hover { background: var(--bg-deep); }

.why-num {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 48px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--accent);
  margin-bottom: 6px;
  display: inline-flex;
  align-items: baseline;
}
.why-unit {
  font-size: 17px;
  color: var(--ink);
  margin-left: 4px;
  font-weight: 500;
  font-family: var(--fb);
  letter-spacing: 0;
}

.why-card h4 {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 18px;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 14px 0 10px;
}

.why-card p {
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--ink-soft);
}

/* ===== HOME GATEWAYS (apps & stories) ===== */
.home-gateway {
  padding: 96px 0;
  border-bottom: 1px solid var(--line);
}

.home-gateway .section-head h2 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(32px, 4vw, 44px);
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.home-gateway .section-head h2 em {
  font-style: italic;
  font-weight: 500;
  color: var(--accent-dark);
}

.link-btn {
  font-family: var(--fm);
  font-size: 12.5px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: transparent;
  border: none;
  color: var(--accent);
  cursor: pointer;
  padding: 6px 0;
  transition: color 0.15s;
  white-space: nowrap;
}
.link-btn:hover { color: var(--accent-dark); }

/* Category cards on home (apps gateway) */
.cat-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}

.cat-card {
  background: var(--surface);
  padding: 30px 26px 26px;
  cursor: pointer;
  border: none;
  font-family: inherit;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: background 0.2s ease;
  position: relative;
}
.cat-card:hover { background: var(--bg-deep); }
.cat-card:hover .cc-arrow { opacity: 1; transform: translateX(0); }
/* top accent bar per category */
.cat-card::after{ content:''; position:absolute; left:0; top:0; height:4px; width:0; background:var(--c-env); transition:width .25s ease; }
.cat-card[data-cat="env"]::after    { background:var(--c-env); }
.cat-card[data-cat="cold"]::after   { background:var(--c-cold); }
.cat-card[data-cat="health"]::after { background:var(--c-health); }
.cat-card[data-cat="indus"]::after  { background:var(--c-indus); }
.cat-card[data-cat="fac"]::after    { background:var(--c-fac); }
.cat-card[data-cat="agri"]::after   { background:var(--c-agri); }
.cat-card:hover::after{ width:100%; }
.cat-card[data-cat="env"]    .cc-tag{ background:rgba(34,201,166,.16);  color:var(--c-env); }
.cat-card[data-cat="cold"]   .cc-tag{ background:rgba(59,142,240,.16);  color:var(--c-cold); }
.cat-card[data-cat="health"] .cc-tag{ background:rgba(155,107,232,.16); color:var(--c-health); }
.cat-card[data-cat="indus"]  .cc-tag{ background:rgba(255,123,69,.18);  color:var(--c-indus); }
.cat-card[data-cat="fac"]    .cc-tag{ background:rgba(39,176,214,.16);  color:var(--c-fac); }
.cat-card[data-cat="agri"]   .cc-tag{ background:rgba(122,194,60,.18);  color:var(--c-agri); }
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cc-tag {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 4px 9px;
  border-radius: 2px;
}
.cc-count {
  font-family: var(--fm);
  font-size: 12px;
  color: var(--ink-faint);
  letter-spacing: 0.06em;
}

.cc-name {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: var(--ink);
}

.cc-desc {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.55;
  margin-bottom: 4px;
}

.cc-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.cc-foot-label {
  font-family: var(--fm);
  font-size: 12px;
  color: var(--ink-soft);
  letter-spacing: 0.04em;
}

.cc-arrow {
  font-size: 15px;
  color: var(--accent);
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 0.2s, transform 0.2s;
}

/* Customer story cards on home */
.home-gateway-stories {
  background: var(--bg-deep);
}

.home-cases {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.home-case-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 0;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: all 0.25s ease;
  position: relative;
  min-height: 320px;
  overflow: hidden;
}
.home-case-card:hover {
  transform: translateY(-3px);
  border-color: var(--ink-soft);
  box-shadow: 0 18px 40px -24px rgba(0,0,0,.55);
}
.home-case-card:hover .hcc-cta { gap: 12px; }

/* photo banner on home case cards */
.hcc-media {
  position: relative;
  width: 100%;
  height: 180px;
  flex: 0 0 180px;
  overflow: hidden;
  background: linear-gradient(150deg, var(--accent) 0%, var(--bg-deep) 100%);
}
.hcc-img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.5s ease;
}
.home-case-card:hover .hcc-img { transform: scale(1.05); }
.hcc-media::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.30) 100%);
}
.hcc-body {
  padding: 26px 26px 26px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.hcc-num {
  font-family: var(--fm);
  font-size: 12px;
  color: var(--ink-faint);
  letter-spacing: 0.16em;
  margin-bottom: 14px;
}

.hcc-logo {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 26px;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin-bottom: 14px;
}

.hcc-tag {
  display: inline-block;
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  margin-bottom: 20px;
  align-self: flex-start;
}

.hcc-headline {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 17px;
  line-height: 1.35;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 22px;
}

.hcc-result {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.hcc-result-num {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--accent);
}

.hcc-result-lbl {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 8px;
}

.hcc-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: 18px;
  transition: gap 0.25s ease;
}
.hcc-cta::after { content: '→'; }

/* ===== AWARDS STRIP ===== */
.home-awards-strip {
  padding: 100px 0;
  border-bottom: 1px solid var(--line);
}

.awards-strip-inner {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 56px;
  align-items: center;
}

.aws-text h2 {
  font-family: var(--fd);
  font-weight: 400;
  font-size: clamp(28px, 3.5vw, 38px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.aws-text h2 em {
  font-style: italic;
  color: var(--accent-dark);
  font-weight: 500;
}
.aws-text p {
  font-size: 14px;
  color: var(--ink-soft);
  margin-top: 18px;
  line-height: 1.65;
}

.aws-badges {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 8px;
}

.aws-badge {
  background: var(--surface);
  border: 1px solid var(--line);
  padding: 22px 20px 18px;
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 180px;
}
.aws-badge::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--accent);
}

.aws-badge.feature {
  background: var(--bg-deep);
  padding: 26px 22px 22px;
}

.aws-year {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 500;
  font-size: 42px;
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--ink);
  margin-bottom: 18px;
}
.aws-badge.feature .aws-year {
  font-size: 56px;
  color: var(--accent);
}

.aws-name {
  font-family: var(--fd);
  font-weight: 500;
  font-size: 13.5px;
  line-height: 1.3;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.aws-badge.feature .aws-name {
  font-size: 17px;
  margin-bottom: auto;
}

.aws-cat {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

/* ========== GLOBAL RESPONSIVE ========== */
@media (max-width: 900px) {
  .wrap, .wrap-mid { padding: 0 24px; }
  .stories-hero { padding: 64px 0 56px; }
  .section { padding: 64px 0; }
  .home-hero { padding: 64px 0 64px; }
  .home-headline { font-size: 48px; }
  .home-trust { grid-template-columns: repeat(2, 1fr); }
  .trust-item { padding: 20px 16px 20px 0 !important; border-bottom: 1px solid var(--line); }
  .trust-item:nth-child(2) { border-right: none; padding-right: 0; }
  .trust-item:nth-child(3), .trust-item:nth-child(4) { padding-top: 20px; }
  .how-section, .why-section, .home-gateway { padding: 64px 0; }
  .how-grid { grid-template-columns: 1fr; gap: 16px; }
  .how-arrow { display: none; }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
  .cat-cards { grid-template-columns: repeat(2, 1fr); }
  .home-cases { grid-template-columns: 1fr; }
  .awards-strip-inner { grid-template-columns: 1fr; gap: 32px; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .stat { padding: 24px 16px 24px 0 !important; border-bottom: 1px solid var(--line); }
  .stat:nth-child(2) { border-right: none; padding-right: 0; }
  .stat:nth-child(3), .stat:nth-child(4) { padding-top: 24px; }
  .featured-card { padding: 0; }
  .featured-grid { gap: 16px; }
  .featured-card:hover { transform: translateY(-3px); }
  .featured-card .fc-media { height: 170px; flex-basis: 170px; }
  .hcc-media { height: 168px; flex-basis: 168px; }
  .featured-card .fc-body { padding: 24px 22px 26px; }
  .dist-rows { grid-template-columns: 1fr; }
  .fr-grid { grid-template-columns: 1fr 1fr; }
  .fr-card.feature { grid-column: 1 / -1; }
  .fr-card.feature .fr-year { font-size: 72px; }
  .fr-card.feature .fr-name { font-size: 24px; }
  .awards-list, .partners-list { columns: 1; }
  .world-map { max-height: 320px; }
}

@media (max-width: 760px) {
  .case-page .hero, .sec { padding: 32px 24px; }
  .case-page .top-band, .case-footer, .case-back { padding: 12px 24px; }
  .case-back { padding-top: 16px; }
  .case-page .hero h1 { font-size: 34px; }
  .qs-row, .res-grid { grid-template-columns: repeat(3, 1fr); }
  .res-grid { grid-template-columns: repeat(2, 1fr); }
  .sol-grid { grid-template-columns: 1fr; }
  .arch { grid-template-columns: repeat(2, 1fr); }
  .arch-arrow { display: none; }
}

@media (max-width: 600px) {
  .stories-hero h1 { font-size: 36px; }
  .home-headline { font-size: 38px; }
  .home-lede { font-size: 16px; }
  .why-grid { grid-template-columns: 1fr; }
  .cat-cards { grid-template-columns: 1fr; }
  .aws-badges { grid-template-columns: 1fr; }
  .home-cta-row .cta-primary, .home-cta-row .cta-ghost, .home-cta-row .cta-download { width: 100%; justify-content: center; }
  .awards-hero h1, .partners-hero h1 { font-size: 28px; }
  .featured-grid { grid-template-columns: 1fr; }
  .fr-grid { grid-template-columns: 1fr; }
  .fr-card.feature .fr-year { font-size: 64px; }
  .fr-card.feature .fr-name { font-size: 22px; }
  .cards-grid { grid-template-columns: 1fr; }
  .cta-block .wrap { flex-direction: column; align-items: flex-start; }
  .sub-filter-inner { grid-template-columns: 1fr; }
  .filter-label { text-align: left; min-width: auto; }
  .chip-row { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; }
  .chip-row::-webkit-scrollbar { display: none; }
  .award-link { grid-template-columns: 32px 6px 1fr; gap: 8px; }
  .award-link .tag { grid-column: 3; justify-self: end; margin-top: 4px; font-size: 12px; }
  .partner-link { grid-template-columns: 8px 1fr; }
  .partner-link .tag { grid-column: 2; justify-self: start; margin-top: 4px; }
  .continent-name { font-size: 12px; }
  .continent-count { font-size: 18px; }
  .join { padding: 40px 0; }
  .join-inner { flex-direction: column; align-items: flex-start; }
}

/* ============================================================ */
/* ==========  FULL-SITE ADDITIONS (Monnit Korea)  ============ */
/* ============================================================ */

/* ----- Dropdown navigation ----- */
.nav-item { position: relative; }
.nav-link.has-caret::after { content: '▾'; font-size: 12px; margin-left: 5px; opacity: 0.6; }
.nav-dd {
  position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%) translateY(6px);
  min-width: 220px; background: var(--surface); border: 1px solid var(--line);
  border-radius: 10px; padding: 8px; box-shadow: 0 18px 48px rgba(26,24,21,0.14);
  opacity: 0; visibility: hidden; transition: all 0.2s ease; z-index: 300;
}
.nav-item:hover .nav-dd { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.nav-dd button {
  display: block; width: 100%; text-align: left; background: none; border: none; cursor: pointer;
  font-family: var(--fb); font-size: 14px; color: var(--ink-mid);
  padding: 10px 14px; border-radius: 7px; transition: all 0.15s ease;
}
.nav-dd button:hover { background: var(--bg-deep); color: var(--accent-dark); }
.nav-dd .dd-meta { font-family:var(--fm); font-size:12px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-faint); padding:6px 14px 4px; }

.nav-toggle { display: none; background:none; border:none; cursor:pointer; font-size: 22px; color: var(--ink); }

/* ----- Home key-strengths ----- */
.strengths-section { padding: 112px 0; border-bottom: 1px solid var(--line); background: var(--bg-deep); }
.strength-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: 40px; }
.strength-card { background: var(--surface); padding: 38px 34px; position: relative; }
.strength-card .s-num { font-family:var(--fd); font-weight:500; font-size:52px; line-height:1; letter-spacing:-0.02em; color: var(--accent-dark); }
.strength-card .s-ico { width:58px; height:58px; object-fit:contain; object-position:left center; display:block; margin-bottom:20px; opacity:.95; }
.strength-card .s-num .s-unit { font-size: 22px; color: var(--ink-soft); margin-left: 4px; }
.strength-card h4 { font-family:var(--fb); font-size: 18px; font-weight: 600; margin: 16px 0 8px; color: var(--ink); }
.strength-card p { font-size: 14.5px; color: var(--ink-soft); line-height: 1.65; }
.strength-card .s-tag { position:absolute; top:34px; right:34px; font-family:var(--fm); font-size:12px; letter-spacing:0.14em; color:var(--accent); }

/* ----- Generic content page ----- */
.cpage { padding: 80px 0 110px; }
.cpage .crumb { font-family:var(--fm); font-size:12.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--accent); margin-bottom:18px; }
.cpage h1 { font-family:var(--fd); font-weight:400; font-size: clamp(36px, 5.5vw, 64px); line-height:1.04; letter-spacing:-0.02em; color: var(--ink); max-width: 14ch; }
.cpage h1 em { font-style: italic; font-weight: 500; color: var(--accent-dark); }
.cpage .lead { font-size: 19px; line-height: 1.75; color: var(--ink-mid); max-width: 760px; margin-top: 26px; }
.cpage .body-prose { max-width: 760px; margin-top: 30px; }
.cpage .body-prose p { font-size: 16px; line-height: 1.85; color: var(--ink-mid); margin-bottom: 18px; }
.cpage .body-prose strong { color: var(--ink); font-weight: 600; }
.cpage h2 { font-family:var(--fd); font-weight:500; font-size: 30px; letter-spacing:-0.01em; color: var(--ink); margin: 60px 0 8px; }
.cpage h2 .sub { display:block; font-family:var(--fm); font-size:12.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-faint); margin-top:8px; font-weight:400; }

/* domain / service grids */
.domain-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top: 34px; }
.domain-cell { background: var(--surface); padding: 26px 22px; transition: background 0.2s ease; }
.domain-cell:hover { background: var(--bg-deep); }
.domain-cell .d-ico { font-size: 22px; color: var(--accent); }
.domain-cell .d-name { font-weight: 600; font-size: 15.5px; margin-top: 14px; color: var(--ink); }
.domain-cell .d-desc { font-size: 13px; color: var(--ink-soft); margin-top: 6px; line-height:1.55; }

.svc-list { margin-top: 34px; border-top: 1px solid var(--line-strong); }
.svc-row { display: grid; grid-template-columns: 56px 1fr; gap: 24px; padding: 26px 0; border-bottom: 1px solid var(--line); align-items: start; }
.svc-row .svc-n { font-family:var(--fd); font-size: 26px; color: var(--accent); line-height:1; }
.svc-row h4 { font-size: 17px; font-weight: 600; color: var(--ink); }
.svc-row p { font-size: 14.5px; color: var(--ink-soft); margin-top: 6px; line-height: 1.65; max-width: 760px; }

/* spec table (Our solution) */
.spec-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:34px; }
.spec-cell { background: var(--surface); padding: 28px 24px; }
.spec-cell .sp-k { font-family:var(--fm); font-size:12.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-faint); }
.spec-cell .sp-v { font-family:var(--fd); font-size: 30px; color: var(--ink); margin-top: 8px; line-height:1.1; }
.spec-cell .sp-d { font-size: 13px; color: var(--ink-soft); margin-top: 8px; line-height:1.55; }

/* CEO signature at the end of the About prose */
.about-sign{ margin-top:30px; text-align:right; font-family:var(--fm);
  font-size:12.5px; letter-spacing:.10em; color:var(--ink-faint); }
.about-sign strong{ font-family:var(--fd); font-weight:500; font-size:22px;
  color:var(--ink); letter-spacing:.04em; margin-left:12px; }

/* "숫자로 보는 Monnit" — lift the flat stat grid with accent numbers + hover */
.nums-grid .spec-cell{ position:relative; overflow:hidden;
  background:linear-gradient(165deg, var(--surface) 0%, #0e1640 100%);
  transition:background .28s ease; }
.nums-grid .spec-cell::before{ content:''; position:absolute; left:0; top:0;
  height:3px; width:0; background:linear-gradient(90deg, var(--accent), #46E2F2);
  transition:width .4s ease; }
.nums-grid .spec-cell:hover{ background:linear-gradient(165deg, var(--surface-2) 0%, #111a44 100%); }
.nums-grid .spec-cell:hover::before{ width:100%; }
.nums-grid .sp-k{ color:var(--ink-faint); }
.nums-grid .sp-v{ font-size:clamp(40px, 4.2vw, 50px); line-height:1; margin-top:14px;
  color:var(--accent); letter-spacing:-0.02em;
  text-shadow:0 0 24px rgba(24,208,230,.22); }
.nums-grid .sp-d{ margin-top:14px; }
/* compact summary rows for Our Solution */
.sol-lead { max-width: 820px; margin-top: 26px; font-size: 17px; line-height: 1.7; color: var(--ink-mid); }
.sol-lead strong { color: var(--ink); font-weight: 600; }
.sol-points { margin-top: 26px; border-top: 1px solid var(--line); }
.sol-points .spr { display: grid; grid-template-columns: 220px 1fr; gap: 24px; padding: 18px 4px; border-bottom: 1px solid var(--line); align-items: baseline; }
.sol-points .spr-k { font-family: var(--fm); font-size: 13px; letter-spacing: 0.04em; color: var(--accent); font-weight: 500; }
.sol-points .spr-v { font-size: 15px; line-height: 1.6; color: var(--ink-mid); }
.sol-points .spr-v strong { color: var(--ink); font-weight: 600; }
@media (max-width: 720px){ .sol-points .spr { grid-template-columns: 1fr; gap: 6px; } }

/* blog */
.blog-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 40px; }
.blog-card { background: var(--surface); border:1px solid var(--line); border-radius: 12px; overflow:hidden; display:flex; flex-direction:column; transition: all 0.2s ease; }
.blog-card:hover { border-color: var(--line-strong); transform: translateY(-3px); box-shadow: 0 14px 36px rgba(26,24,21,0.08); }
.blog-thumb { aspect-ratio: 16/9; background: linear-gradient(135deg, var(--accent-soft), var(--bg-deep)); display:flex; align-items:center; justify-content:center; font-size: 40px; color: var(--accent-dark); }
.blog-body { padding: 24px; display:flex; flex-direction:column; flex:1; }
.blog-date { font-family:var(--fm); font-size: 12.5px; letter-spacing:0.1em; color: var(--ink-faint); }
.blog-card h3 { font-family:var(--fd); font-weight:500; font-size: 21px; line-height:1.25; margin: 12px 0 10px; color: var(--ink); }
.blog-card p { font-size: 14px; color: var(--ink-soft); line-height: 1.6; flex:1; }
.blog-card .b-link { margin-top: 16px; font-size: 13px; font-weight: 600; color: var(--accent); }
a.res-link{ text-decoration:none; color:inherit; cursor:pointer; }
a.blog-card.res-link, a.wp-card.res-link, a.svc-row.res-link{ display:flex; }
a.blog-card.res-link{ flex-direction:column; }
a.wp-card.res-link, a.svc-row.res-link{ display:grid; }
a.res-link:hover .b-link{ text-decoration:underline; }

/* FAQ accordion */
.faq-list { margin-top: 40px; max-width: 860px; border-top: 1px solid var(--line-strong); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q { width:100%; text-align:left; background:none; border:none; cursor:pointer; padding: 24px 44px 24px 0; position:relative; font-family:var(--fb); font-size: 17px; font-weight: 500; color: var(--ink); }
.faq-q::after { content:'+'; position:absolute; right:6px; top:50%; transform:translateY(-50%); font-size:24px; color:var(--accent); font-weight:300; transition: transform 0.2s ease; }
.faq-item.open .faq-q::after { content:'−'; }
.faq-a { max-height:0; overflow:hidden; transition: max-height 0.3s ease; }
.faq-a-inner { padding: 0 44px 26px 0; font-size: 15px; line-height: 1.75; color: var(--ink-mid); }
.faq-item.open .faq-a { max-height: 480px; }

/* KB cards */
.kb-grid { display:grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin-top: 40px; }
.kb-card { background: var(--surface); border:1px solid var(--line); border-radius: 10px; padding: 26px 24px; transition: all 0.2s ease; }
.kb-card:hover { border-color: var(--accent); }
.kb-card .kb-cat { font-family:var(--fm); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color: var(--accent); }
.kb-card h3 { font-size: 17px; font-weight: 600; margin: 12px 0 8px; color: var(--ink); }
.kb-card p { font-size: 14px; color: var(--ink-soft); line-height:1.6; }

/* contact / forms */
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 64px; margin-top: 48px; align-items:start; }
.contact-info dt { font-family:var(--fm); font-size:12.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-faint); margin-top: 26px; }
.contact-info dd { font-size: 18px; color: var(--ink); margin-top: 6px; }
.contact-info dd a { color: var(--accent-dark); text-decoration:none; }
.form-card { background: var(--surface); border:1px solid var(--line); border-radius: 14px; padding: 34px; }
.form-card label { display:block; font-size: 13px; font-weight:500; color: var(--ink-mid); margin: 18px 0 7px; }
.form-card input, .form-card textarea, .form-card select { width:100%; padding: 12px 14px; border:1px solid var(--line-strong); border-radius: 7px; background: var(--bg); font-family:var(--fb); font-size: 14px; color: var(--ink); }
.form-card select { appearance:none; -webkit-appearance:none; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%23888' stroke-width='1.6'/></svg>"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; cursor:pointer; }
.form-card input:focus, .form-card textarea:focus, .form-card select:focus { outline:none; border-color: var(--accent); }
.form-btn { margin-top: 24px; width:100%; padding: 14px; background: var(--btn-bg); color:#fff; border:none; border-radius: 7px; font-family:var(--fb); font-size: 15px; font-weight:600; cursor:pointer; transition: background 0.2s ease; }
.form-btn:hover { background: var(--btn-bg-h); }
.form-note { font-size: 12px; color: var(--ink-faint); margin-top: 14px; line-height:1.5; }

/* newsletter / whitepaper hero band */
.band { background: linear-gradient(135deg,var(--surface-2),var(--surface)); border:1px solid var(--line-strong); color: var(--ink); border-radius: 16px; padding: 56px; margin-top: 44px; }
.band h3 { font-family:var(--fd); font-weight:500; font-size: 30px; color: #fff; }
.band p { color: #C8C2B6; font-size: 16px; line-height:1.7; margin-top: 14px; max-width: 620px; }
.band .inline-form { display:flex; gap:10px; margin-top: 26px; flex-wrap:wrap; }
.band .inline-form input { flex:1; min-width: 240px; padding: 14px 16px; border:none; border-radius: 7px; font-family:var(--fb); font-size:14px; }
.band .inline-form select { flex:1.3; min-width: 240px; padding: 14px 16px; border:none; border-radius: 7px; font-family:var(--fb); font-size:14px; background-color:#fff; color:#15192e; cursor:pointer; appearance:none; -webkit-appearance:none; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%23888' stroke-width='1.6'/></svg>"); background-repeat:no-repeat; background-position:right 16px center; padding-right:38px; }
.band .inline-form select option { color:#15192e; background:#fff; }
.band .inline-form button { padding: 14px 26px; background: var(--btn-bg); color:#fff; border:none; border-radius:7px; font-weight:500; cursor:pointer; font-family:var(--fb); }
.band .inline-form button:hover { background: var(--btn-bg-h); }

.wp-list { margin-top: 40px; display:grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
/* 카드 = [미디어 섹션] + [본문]. 미디어에 어떤 비율의 사진을 넣어도 박스에 맞춰 자동 크롭(cover) */
.wp-card { display:grid; grid-template-columns: 116px 1fr; gap: 0; background: var(--surface); border:1px solid var(--line); border-radius:14px; overflow:hidden; align-items:stretch; }
.wp-card .wp-media { position:relative; align-self:stretch; min-height:132px; background: linear-gradient(160deg,var(--accent),var(--accent-dark)); overflow:hidden; display:flex; align-items:center; justify-content:center; }
.wp-card .wp-glyph { color:#fff; font-size:30px; line-height:1; }
.wp-card .wp-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.wp-card .wp-body { padding: 22px 24px; align-self:center; }
.wp-card h4 { font-size: 16px; font-weight:600; color:var(--ink); }
.wp-card p { font-size: 13.5px; color: var(--ink-soft); margin-top:6px; line-height:1.6; }
button.wp-card.wp-pick { width:100%; text-align:left; font-family:inherit; color:inherit; appearance:none; -webkit-appearance:none; transition: transform .2s ease, box-shadow .25s ease, border-color .25s ease; }
button.wp-card.wp-pick:hover { transform: translateY(-3px); border-color: var(--accent); box-shadow: 0 14px 30px -20px rgba(0,0,0,.5); }
button.wp-card.wp-pick:hover .wp-dl-hint { text-decoration: underline; }
.wp-card .wp-dl-hint { color: var(--accent); font-weight:600; }
.band-flash { animation: bandFlash 1.3s ease; }
@keyframes bandFlash { 0%,100%{ box-shadow:0 0 0 0 rgba(0,0,0,0); } 25%{ box-shadow:0 0 0 3px var(--accent); } }

/* site footer */
.join-btn, .app-cta-btn { border: none; cursor: pointer; }
.site-footer { background: var(--bg-deep); color: var(--ink-soft); padding: 72px 0 40px; }
.site-footer .wrap { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr; gap: 40px; }
.site-footer .brand-col .fb-logo { font-family:var(--fd); font-size: 26px; color:#fff; }
.site-footer .brand-col .fb-logo { display:flex; align-items:center; gap:10px; }
.fb-logo-img { height:26px; width:auto; display:block; }
.site-footer .brand-col p { font-size: 13.5px; line-height:1.7; margin-top: 16px; max-width: 320px; color:#9A938A; }
.site-footer h5 { font-family:var(--fm); font-size:12.5px; letter-spacing:0.14em; text-transform:uppercase; color:#C8C2B6; margin-bottom: 16px; }
.site-footer ul { list-style:none; }
.site-footer li { margin-bottom: 10px; }
.site-footer li button { background:none; border:none; cursor:pointer; color:#9A938A; font-family:var(--fb); font-size: 13.5px; padding:0; transition: color 0.15s ease; }
.site-footer li button:hover { color:#fff; }
.footer-base { border-top:1px solid #33302B; margin-top: 56px; padding-top: 28px; font-size: 12px; color:#6B665E; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-base .wrap { display:flex; justify-content:space-between; grid-template-columns:none; }

@media (max-width: 920px) {
  .strength-grid, .domain-grid, .spec-grid, .blog-grid, .kb-grid, .wp-list { grid-template-columns: 1fr; }
  /* 모바일: 사진이 있는 백서 카드는 위쪽 배너(16:9)로, 아이콘 카드는 좌측 레일 유지 */
  .wp-card.has-photo { grid-template-columns: 1fr; }
  .wp-card.has-photo .wp-media { width:100%; align-self:start; aspect-ratio: 16 / 9; min-height: 160px; max-height: 220px; }
  .wp-card.has-photo .wp-body { padding: 18px 22px 22px; }
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .site-footer .wrap { grid-template-columns: 1fr 1fr; }
  .nav-toggle { display: block; font-size: 26px; padding: 4px 10px; }
  .nav-links {
    display: none; position: absolute; top: 64px; left: 0; right: 0; flex-direction: column;
    background: var(--surface); border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line-strong); padding: 12px; gap: 2px;
    box-shadow: 0 26px 52px rgba(0,0,0,0.62);
    max-height: calc(100vh - 64px); overflow-y: auto;
  }
  .nav-links.open { display: flex; }
  .nav-item { width: 100%; }
  .nav-item + .nav-item { border-top: 1px solid var(--line); }
  .nav-link {
    display: block; width: 100%; text-align: left;
    padding: 16px 14px; font-size: 16px; font-weight: 500;
    color: var(--ink); border-radius: 10px;
  }
  .nav-link:hover, .nav-link:active, .nav-link.active { background: var(--bg-deep); color: var(--ink); }
  .nav-link.has-caret::after { float: right; font-size: 15px; opacity: 0.7; }
  .nav-item.m-open > .nav-link.has-caret { color: var(--accent); }
  .nav-dd { position: static; transform: none; opacity:1; visibility:visible; box-shadow:none; border:none; background:transparent; padding: 2px 0 10px 10px; min-width:auto; display:none; }
  .nav-item.m-open .nav-dd { display:block; }
  /* touch fires :hover → desktop translateX(-50%) was shoving the submenu off-screen */
  .nav-item:hover .nav-dd, .nav-item:focus-within .nav-dd { transform: none; left: auto; }
  .nav-dd button { padding: 14px 16px; font-size: 15px; color: var(--ink); border-radius: 8px; }
  .nav-dd button:hover, .nav-dd button:active { background: var(--bg-deep); color: var(--accent-dark); }
  .nav-dd .dd-meta { padding: 10px 16px 4px; color: var(--ink-soft); }
  .band { padding: 36px 28px; }
  .domain-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .domain-grid { grid-template-columns: 1fr; }
  .site-footer .wrap { grid-template-columns: 1fr; }
}

/* ===== DARK THEME · IMAGES · MAP (redesign) ===== */
.hero-figure img{width:100%;display:block;border-radius:16px;border:1px solid var(--line-strong);box-shadow:0 30px 90px rgba(0,0,0,.55);}
.home-hero{padding:76px 0 100px;}
.hero-sub{font-size:18px;line-height:1.7;color:var(--ink-mid);max-width:760px;margin-top:30px;}
.hero-sub strong{color:var(--ink);font-weight:600;}
.home-cta-row{margin-top:36px;margin-bottom:88px;}

.awards-hero-img .award-banner img{width:100%;display:block;border-radius:14px;border:1px solid var(--line-strong);margin:22px 0 26px;box-shadow:0 20px 60px rgba(0,0,0,.45);}
.awards-hero-img .inline-stats{display:block;margin-top:10px;}

/* industries */
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:34px;}
.ind-card{background:var(--surface);border:1px solid var(--line);border-radius:13px;overflow:hidden;transition:transform .22s,border-color .22s,box-shadow .22s;}
.ind-card:hover{transform:translateY(-5px);border-color:var(--accent);box-shadow:0 18px 44px rgba(0,0,0,.45);}
.ind-card img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;}
.ind-card .ind-photo{ position:relative; }
.ind-card .ind-photo::after{ content:''; position:absolute; left:0; right:0; bottom:0; height:48%;
  background:linear-gradient(180deg, rgba(7,11,34,0) 0%, rgba(7,11,34,.28) 45%, rgba(7,11,34,.88) 100%);
  pointer-events:none; }
.ind-card .ind-name{ position:absolute; left:16px; bottom:14px; z-index:1; color:#fff;
  font-family:var(--fb); font-weight:700; font-size:19px; letter-spacing:-0.01em;
  text-shadow:0 2px 10px rgba(0,0,0,.55); }
.ind-card .cap{padding:14px 16px;font-size:13px;color:var(--ink-mid);line-height:1.55;border-top:1px solid var(--line);min-height:62px;}
@media(max-width:920px){.ind-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.ind-grid{grid-template-columns:1fr;}}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px;}
.svc-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:transform .22s,border-color .22s,box-shadow .22s;}
.svc-card:hover{transform:translateY(-5px);border-color:var(--accent);box-shadow:0 18px 44px rgba(0,0,0,.45);}
.svc-card .ph{position:relative;aspect-ratio:4/3;overflow:hidden;}
.svc-card .ph img{width:100%;height:100%;object-fit:cover;display:block;}
.svc-card .ph::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,28,.6),transparent 55%);}
.svc-card .n{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--fd);font-weight:800;font-size:18px;color:#fff;background:var(--accent);width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(0,0,0,.4);}
.svc-card .tx{padding:20px 22px 24px;flex:1;}
.svc-card h4{font-size:16.5px;font-weight:700;color:var(--ink);line-height:1.35;}
.svc-card p{font-size:14px;color:var(--ink-soft);margin-top:9px;line-height:1.65;}
.ind-card.clickable,.svc-card.clickable{cursor:pointer;}
.ind-card.clickable .cap{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.ind-card.clickable .cap::after{content:'→';color:var(--accent);font-weight:600;opacity:0;transform:translateX(-4px);transition:all .2s;}
.ind-card.clickable:hover .cap::after{opacity:1;transform:translateX(0);}
.svc-card.clickable .tx{display:flex;flex-direction:column;}
.svc-card.clickable .tx::after{content:'문의하기 →';font-family:var(--fm);font-size:12.5px;letter-spacing:.04em;color:var(--accent);margin-top:14px;opacity:.6;transition:opacity .2s;}
.svc-card.clickable:hover .tx::after{opacity:1;}
@media(max-width:920px){.svc-grid{grid-template-columns:1fr;}}

/* world map (rebuilt) */
.world-map .land{fill:var(--surface-2);stroke:var(--line-strong);stroke-width:1;stroke-linejoin:round;transition:fill .25s,stroke .25s,opacity .25s;}
.continent{cursor:pointer;outline:none;}
.continent:hover .land,.continent.active .land{fill:var(--accent-soft);stroke:var(--accent);}
.world-map.has-active .continent:not(.active) .land{opacity:.4;}
.world-map .mk{fill:var(--accent);r:6;}
.world-map .mk-pulse{fill:var(--accent);opacity:.5;}
.world-map.has-active .continent:not(.active) .mk,
.world-map.has-active .continent:not(.active) .mk-pulse,
.world-map.has-active .continent:not(.active) .cc,
.world-map.has-active .continent:not(.active) .cn{opacity:.25;}
.continent .cc{fill:#fff;font-family:var(--fd);font-weight:800;font-size:27px;text-anchor:middle;}
.continent .cn{fill:var(--ink-soft);font-family:var(--fm);font-size:13px;letter-spacing:.1em;text-transform:uppercase;text-anchor:middle;}
.continent:hover .cc,.continent.active .cc{fill:var(--accent);}
.continent .mk,.continent .mk-pulse,.continent .cc,.continent .cn{pointer-events:none;}
.ocean-grid line{stroke:var(--line);stroke-width:1;opacity:.45;}
.map-container{background:linear-gradient(160deg,var(--surface),var(--bg-deep));border:1px solid var(--line);border-radius:16px;padding:20px;}

/* dark fixes */
.site-footer{background:var(--bg-deep);border-top:1px solid var(--line);}
.topnav{border-bottom:1px solid var(--line);}
.nav-dd{box-shadow:0 18px 48px rgba(0,0,0,.5);}
body{font-size:16px;}
.home-headline,.cpage h1,.stories-hero h1,.awards-hero h1,.partners-hero h1{letter-spacing:-0.03em;}


/* ===== dark panel fixes for inverted sections ===== */
.cta-block{background:linear-gradient(135deg,var(--surface-2),var(--surface));color:var(--ink);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.join{background:linear-gradient(135deg,var(--surface-2),var(--surface));color:var(--ink);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.cta-block h2,.join h2,.join-text h2,.cta-block,.join{color:var(--ink);}
.case-footer{background:var(--bg-deep);color:var(--ink);border-top:1px solid var(--line);}
.sub-filter-bar{background:rgba(0,0,26,0.9);border-bottom:1px solid var(--line);}


/* ===== TURN-3: lighter premium atmosphere + de-box ===== */
body{
  background:
    radial-gradient(1100px 620px at 78% -8%, rgba(24,208,230,.10), transparent 60%),
    radial-gradient(900px 600px at 8% 4%, rgba(70,110,235,.10), transparent 58%),
    radial-gradient(1200px 900px at 50% 120%, rgba(24,208,230,.06), transparent 60%),
    var(--bg);
  background-attachment: fixed;
}
.home-headline{ font-size:clamp(40px,6.4vw,82px); margin:34px 0 34px; max-width:960px; line-height:1.06;}
.hero-sub{display:none;}

/* soften the rectangular surfaces site-wide */
.strength-card,.why-card,.spec-cell,.domain-cell,.blog-card,.kb-card,.fr-card,
.app-card,.case-card,.cat-card,.form-card,.wp-card{
  border-radius:14px;
}
.strength-grid,.why-grid,.spec-grid{ background:transparent; gap:14px; }
.strength-card,.why-card{ background:linear-gradient(180deg,var(--surface),var(--bg-deep)); }

/* ===== flow diagram ===== */
.hero-flow{ margin:56px 0 8px; position:relative; z-index:2;}
/* 4 core-value cards (replaces the sensor→gateway→platform flow) */
.hero-values{ margin:84px 0 0; position:relative; z-index:2;
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.value-card{ background:var(--surface); border:1px solid var(--line);
  border-radius:14px; overflow:hidden; display:flex; flex-direction:column;
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease; }
.value-card:hover{ transform:translateY(-5px); border-color:var(--line-strong);
  box-shadow:0 18px 44px rgba(0,0,0,.45); }
.vc-photo{ position:relative; aspect-ratio:3/2; overflow:hidden; }
.vc-photo img{ width:100%; height:100%; object-fit:cover; display:block;
  filter:saturate(.96); transition:transform .5s ease; }
.value-card:hover .vc-photo img{ transform:scale(1.05); }
.vc-photo::after{ content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,17,48,0) 42%, rgba(10,17,48,.55) 100%); }
.vc-body{ padding:22px 22px 26px; display:flex; flex-direction:column; gap:8px; }
.vc-no{ font-family:var(--fm); font-size:12.5px; letter-spacing:.14em; color:var(--accent); }
.vc-body h3{ font-family:var(--fd); font-weight:500; font-size:21px;
  letter-spacing:-0.01em; line-height:1.2; color:var(--ink); }
.vc-body p{ font-size:14px; line-height:1.65; color:var(--ink-soft); }
@media (max-width:1000px){ .hero-values{ grid-template-columns:repeat(2,1fr); gap:16px; } }
@media (max-width:560px){ .hero-values{ grid-template-columns:1fr; } }
/* 4 icon strengths (replaces the numeric trust strip under the hero) */
.hero-strengths{ margin-top: clamp(60px, 7vw, 96px); padding-top: 42px;
  border-top: 1px solid var(--line-strong); position:relative; z-index:2;
  display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.hero-strengths .hs-item{ padding: 4px 26px 4px 0; border-right:1px solid var(--line); }
.hero-strengths .hs-item:last-child{ border-right:none; }
.hero-strengths .hs-item:not(:first-child){ padding-left:26px; }
.hs-ico{ width:46px; height:46px; object-fit:contain; object-position:left center; display:block; margin-bottom:16px; opacity:.95; }
.hs-t{ font-family:var(--fb); font-weight:600; font-size:16px; color:var(--ink); line-height:1.35; letter-spacing:-0.01em; }
.hs-d{ font-size:13px; color:var(--ink-soft); line-height:1.55; margin-top:7px; }
@media (max-width:900px){
  .hero-strengths{ grid-template-columns:repeat(2,1fr); gap:0; }
  .hero-strengths .hs-item{ padding:22px 20px 22px 0 !important; border-bottom:1px solid var(--line); }
  .hero-strengths .hs-item:nth-child(2){ border-right:none; }
  .hero-strengths .hs-item:nth-child(odd){ padding-left:0 !important; }
  .hero-strengths .hs-item:nth-child(3),.hero-strengths .hs-item:nth-child(4){ padding-bottom:0 !important; border-bottom:none; }
}
@media (max-width:560px){
  .hero-strengths{ grid-template-columns:1fr; }
  .hero-strengths .hs-item{ border-right:none; border-bottom:1px solid var(--line); padding:20px 0 !important; }
  .hero-strengths .hs-item:last-child{ border-bottom:none; }
}
.flow-wrap{ margin:28px 0 8px; }
.flow-svg{ width:100%; height:auto; max-width:1000px; display:block; margin:0 auto;
  overflow:visible;}
/* modern device card */
.flow-svg .card-bg{ fill:var(--surface); stroke:var(--line-strong); stroke-width:1.4;}
.flow-svg .card-glow{ fill:url(#cardGlow); }
.flow-svg .ic{ fill:none; stroke:var(--accent-dark); stroke-width:2.6;
  stroke-linejoin:round; stroke-linecap:round; }
.flow-svg .ic .accentfill{ fill:var(--accent); stroke:none; }
.flow-svg .ic .softfill{ fill:var(--accent); stroke:none; opacity:.18;}
.flow-svg .ic .dot{ fill:var(--accent-dark); stroke:none;}
.flow-svg .ic .spark{ stroke:var(--accent-dark); }
.flow-svg .ic .muted{ stroke:var(--ink-soft); }
.flow-svg .step-no{ fill:var(--accent); font-family:var(--fm); font-weight:500;
  font-size:12px; letter-spacing:.18em; text-anchor:middle;}
.flow-svg .flow-label{ fill:var(--ink); font-family:var(--fd); font-weight:500;
  font-size:22px; text-anchor:middle; }
.flow-svg .flow-sub{ fill:var(--accent); font-family:var(--fm); font-size:12px;
  letter-spacing:.12em; text-anchor:middle; text-transform:uppercase;}
.flow-svg .flow-desc{ fill:var(--ink-mid); font-family:var(--fb); font-size:13.5px;
  text-anchor:middle;}
.flow-svg .flow-bead{ fill:var(--accent); filter:drop-shadow(0 0 6px var(--accent));}
@media(max-width:760px){
  .flow-svg .flow-label{ font-size:30px;}
  .flow-svg .flow-desc{ font-size:18px;}
  .flow-svg .flow-sub{ font-size:14px;}
  .flow-svg .step-no{ font-size:16px;}
}

/* ===== facility band (home) ===== */
.fac-band{ padding:108px 0; border-bottom:1px solid var(--line);}
/* ----- 설계 → 제조 단계 (사진 + 설명 카드) ----- */
.step-flow{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:40px;}
.step-card{ margin:0; display:flex; flex-direction:column; border-radius:18px; overflow:hidden;
  border:1px solid var(--line-strong); background:var(--surface);
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease, border-color .4s ease;}
.step-card:hover{ transform:translateY(-6px); border-color:var(--accent); box-shadow:0 26px 60px rgba(0,0,0,.48);}
.step-media{ position:relative; aspect-ratio:16/10; overflow:hidden;}
.step-media img{ width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);}
.step-card:hover .step-media img{ transform:scale(1.06);}
.step-body{ padding:19px 21px 23px;}
.step-top{ display:flex; align-items:center; gap:11px; margin-bottom:11px;}
.step-idx{ font-family:var(--fm); font-size:14px; font-weight:700; letter-spacing:.02em; color:var(--accent);
  position:relative; padding-right:11px;}
.step-idx::after{ content:''; position:absolute; right:0; top:50%; transform:translateY(-50%);
  width:1px; height:12px; background:var(--line-strong);}
.step-kicker{ font-family:var(--fm); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft);}
.step-title{ margin:0; font-family:var(--fb); font-size:19px; font-weight:700; color:var(--ink); letter-spacing:-.01em; line-height:1.2;}
.step-desc{ margin:8px 0 0; font-size:12.5px; line-height:1.6; color:var(--ink-mid);}
@media(max-width:900px){ .step-flow{ grid-template-columns:1fr; gap:16px;} .step-media{ aspect-ratio:16/9;} }

/* prose + contact figures */
.prose-figure{ margin:34px 0 10px; border-radius:16px; overflow:hidden;
  border:1px solid var(--line-strong);}
/* Two-column About intro (text + photo) */
.about-intro{ display:grid; grid-template-columns:1.02fr .98fr; gap:48px; align-items:center; margin-top:34px; }
.about-intro .body-prose{ margin-top:0; max-width:none; }
.about-intro .prose-figure{ margin:0; }
.about-intro .prose-figure img{ max-height:none; aspect-ratio:4/3; }
@media(max-width:920px){ .about-intro{ grid-template-columns:1fr; gap:26px; } .about-intro .prose-figure img{ aspect-ratio:16/9; } }
/* ALTA sensor-type chips */
.sensor-chips{ display:flex; flex-wrap:wrap; gap:9px; margin:18px 0 8px; max-width:820px; }
.sensor-chips span{ font-family:var(--fm); font-size:12px; letter-spacing:.01em; color:var(--ink-mid);
  background:var(--surface); border:1px solid var(--line); border-radius:100px; padding:7px 15px; }
.prose-figure img{ width:100%; display:block; max-height:380px; object-fit:cover;}
.prose-figure figcaption{ font-family:var(--fm); font-size:12.5px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--ink-soft); padding:12px 4px 0;}
.contact-figure{ margin:0 0 26px; border-radius:16px; overflow:hidden;
  border:1px solid var(--line-strong); max-height:240px;}
.contact-figure img{ width:100%; display:block; height:240px; object-fit:cover;}

/* ===== honors timeline (awards) ===== */
.honors-strip{ padding:52px 0 60px; border-bottom:1px solid var(--line);}
/* ===== Awards statistics (replaces timeline) ===== */
.astat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:30px; }
.astat{ background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:24px 22px; }
.astat-n{ font-family:var(--fd); font-weight:500; font-size:clamp(30px,4vw,42px); line-height:1; color:var(--ink); letter-spacing:-0.02em; }
.astat-n span{ color:var(--accent); font-size:.62em; margin-left:2px; }
.astat-l{ font-family:var(--fb); font-size:13px; color:var(--ink-soft); margin-top:12px; line-height:1.45; }
.astat-l em{ font-style:normal; font-family:var(--fm); font-size:12.5px; letter-spacing:.04em; color:var(--ink-faint); display:block; margin-top:2px; }
.astat-bars-head{ font-family:var(--fd); font-weight:500; font-size:18px; color:var(--ink); margin-top:42px; display:flex; align-items:baseline; gap:12px; }
.astat-bars-head .abh-sub{ font-family:var(--fm); font-size:12.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); }
.astat-bars{ margin-top:18px; display:flex; flex-direction:column; gap:11px; }
.astat-bar{ display:grid; grid-template-columns:130px 1fr 34px; align-items:center; gap:14px; }
.astat-bar .ab-label{ font-family:var(--fm); font-size:11.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-soft); text-align:right; }
.astat-bar .ab-track{ height:9px; border-radius:100px; background:var(--bg-deep); border:1px solid var(--line); overflow:hidden; }
.astat-bar .ab-fill{ display:block; height:100%; border-radius:100px; background:var(--cat-color,var(--accent)); opacity:.85; }
.astat-bar .ab-num{ font-family:var(--fm); font-size:13px; color:var(--ink); text-align:left; }
@media(max-width:760px){
  .astat-grid{ grid-template-columns:repeat(2,1fr); }
  .astat-bar{ grid-template-columns:104px 1fr 28px; gap:10px; }
  .astat-bar .ab-label{ font-size:12px; }
}
.honors-rail{ list-style:none; margin:28px 0 0; padding:0; position:relative;
  display:flex; flex-direction:column; }
.honors-rail::before{ content:''; position:absolute; left:62px; top:6px; bottom:6px;
  width:1px; background:linear-gradient(180deg,transparent,var(--line-strong),transparent);}
.hr-item{ position:relative; display:grid;
  grid-template-columns:62px 1fr auto; align-items:center; gap:18px;
  padding:14px 4px 14px 0; border-bottom:1px solid var(--line);}
.hr-item:last-child{ border-bottom:none;}
.hr-year{ font-family:var(--fm); font-size:13px; color:var(--ink-soft); text-align:right;}
.hr-item.lead .hr-year{ color:var(--accent); font-weight:600;}
.hr-name{ font-family:var(--fb); font-size:15.5px; color:var(--ink); position:relative; padding-left:30px;}
.hr-name::before{ content:''; position:absolute; left:-8px; top:50%; transform:translateY(-50%);
  width:9px; height:9px; border-radius:50%; background:var(--cat-color,var(--accent));
  box-shadow:0 0 0 4px rgba(24,208,230,.10);}
.hr-item.lead .hr-name{ font-weight:600; font-size:16.5px;}
.hr-note{ color:var(--accent); font-size:13px;}
.hr-cat{ font-family:var(--fm); font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-soft); display:inline-flex; align-items:center; gap:7px; white-space:nowrap;}
.hr-cat .hr-dot{ width:7px; height:7px; border-radius:50%; background:var(--cat-color,var(--accent));}
@media(max-width:620px){
  .hr-item{ grid-template-columns:48px 1fr; }
  .honors-rail::before{ left:48px;}
  .hr-cat{ display:none;}
}

/* ===== partners map — pill labels, smoother ===== */
.world-map .land{ stroke-width:1.1; }
.world-map .mk-ring{ fill:none; stroke:var(--accent); stroke-width:1.6; opacity:.65;}
.world-map .mk{ fill:var(--accent); filter:drop-shadow(0 0 8px rgba(24,208,230,.7));}
.world-map .mk-stem{ stroke:var(--accent); stroke-width:1.4; opacity:.55;}
.world-map .pill-bg{ fill:rgba(10,17,48,.92); stroke:var(--line-strong); stroke-width:1;}
.world-map .pill-num-bg{ fill:var(--accent); }
.world-map .cc{ fill:#06121f; font-family:var(--fm); font-weight:700; font-size:14px;
  text-anchor:middle; dominant-baseline:middle;}
.world-map .cn{ fill:var(--ink); font-family:var(--fb); font-weight:600; font-size:15px;
  text-anchor:start; dominant-baseline:middle;}
.world-map .continent{ cursor:pointer; transition:opacity .25s;}
.world-map .continent:hover .land{ fill:var(--accent-soft); stroke:var(--accent);}
.world-map .continent:hover .pill-bg{ stroke:var(--accent);}
.world-map.has-active .continent:not(.active) .pill,
.world-map.has-active .continent:not(.active) .mk-ring,
.world-map.has-active .continent:not(.active) .mk-stem{ opacity:.22;}
.world-map .continent.active .pill-bg{ stroke:var(--accent); }
.map-container{ background:
  radial-gradient(700px 380px at 50% 40%, rgba(24,208,230,.06), transparent 70%);}

/* =========================================================
   READABILITY & SPACING PATCH (added)
   Loosens cramped areas: card paragraphs, list items,
   spec cells, prose blocks, headings.
   ========================================================= */
.why-card p, .strength-card p, .svc-card p, .how-desc,
.cc-desc, .app-desc, .ra-desc { line-height: 1.7; }
.why-card, .strength-card { padding: 30px 28px; }
.why-card h4, .strength-card h4 { margin-bottom: 10px; line-height: 1.3; }
.why-grid, .strength-grid { gap: 24px; }
.app-list li, .apps li, .how-feats li { padding: 7px 0; line-height: 1.5; }
.spec-cell { padding: 20px 20px 22px; }
.spec-cell .sp-d { line-height: 1.6; margin-top: 8px; }
.body-prose p, .lead, .home-lede { letter-spacing: -0.003em; }
.cpage h1 { line-height: 1.1; margin-bottom: 16px; }
.cpage .lead { margin-bottom: 36px; }
.cpage h2 { margin-top: 56px; }
.section-head { margin-bottom: 48px; }
.case-card, .featured-card { line-height: 1.6; }
.case-card .headline, .featured-card .headline { margin-bottom: 18px; }
.t-lbl { margin-top: 8px; line-height: 1.4; }
.honors-rail li { line-height: 1.5; }
.partner-desc { line-height: 1.55; }
.aws-text p { line-height: 1.7; margin-top: 12px; }
@media (max-width: 760px){
  .home-trust { grid-template-columns: repeat(2,1fr); }
  .trust-item:nth-child(-n+2){ border-bottom: 1px solid var(--line); }
}
/* ===== Field photo gallery (Applications & Case studies) ===== */
.photo-section .ph-head { display:flex; justify-content:space-between; align-items:flex-end; gap:20px; flex-wrap:wrap; margin-bottom:8px; }
.ph-wrap { margin-top: 22px; }
.ph-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap:14px; }
.ph-item { position:relative; margin:0; border-radius:10px; overflow:hidden; border:1px solid var(--line); background:var(--surface); aspect-ratio:4/3; }
.ph-item img { width:100%; height:100%; object-fit:cover; display:block; }
.ph-del { position:absolute; top:8px; right:8px; width:28px; height:28px; border-radius:50%; border:none; cursor:pointer;
  background:rgba(7,11,34,0.72); color:#fff; font-size:18px; line-height:1; display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .18s ease; }
.ph-item:hover .ph-del { opacity:1; }
.ph-add { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; cursor:pointer;
  border:1.5px dashed var(--line-strong); border-radius:10px; background:var(--surface); color:var(--ink-soft);
  aspect-ratio:4/3; transition:border-color .18s ease, color .18s ease, background .18s ease; }
.ph-add:hover { border-color:var(--accent); color:var(--accent); background:var(--surface-2); }
.ph-add.busy { opacity:.6; pointer-events:none; }
.ph-add-ico { font-size:26px; line-height:1; }
.ph-add-tx { font-family:var(--fm); font-size:12px; letter-spacing:0.06em; }
.ph-note { font-size:12.5px; color:var(--ink-faint); margin-top:14px; line-height:1.6; }
.ph-cap { font-size:12.5px; color:var(--ink-soft,var(--ink-faint)); padding:8px 10px 2px; line-height:1.5; }
.ph-item figcaption.ph-cap { background:var(--surface-2,transparent); }

/* ----- 언어 토글 버튼 ----- */
#langToggle{
  margin-right:14px; padding:7px 13px; min-width:42px;
  font-family:var(--fm); font-size:12px; font-weight:600; letter-spacing:.06em;
  color:var(--ink); background:transparent;
  border:1px solid var(--line-strong); border-radius:999px;
  cursor:pointer; transition:border-color .2s ease, color .2s ease, background .2s ease;
}
#langToggle:hover{ border-color:var(--accent); color:var(--accent); }
@media(max-width:820px){ #langToggle{ margin-right:8px; padding:6px 11px; font-size:11px; } }

/* ========== PRODUCTS PAGE ========== */
#view-products #productsRoot{ padding: 8px 0 84px; }
.prod-cat{ padding: 34px 0 6px; }
.prod-cat-head{ display:flex; align-items:center; gap:13px; margin:0 0 22px; padding-bottom:15px;
  border-bottom:2px solid color-mix(in srgb, var(--cat) 38%, transparent); }
.prod-cat-ico{ display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:11px;
  color:var(--cat); background:color-mix(in srgb, var(--cat) 14%, transparent);
  border:1px solid color-mix(in srgb, var(--cat) 30%, transparent); flex:none; }
.prod-cat-ico svg{ width:23px; height:23px; }
.prod-cat-head h2{ font-family:var(--fd); font-weight:500; font-size:clamp(24px,3vw,33px); letter-spacing:-0.01em; margin:0; color:var(--ink); }
.prod-count{ font-family:var(--fm); font-size:13px; color:var(--cat);
  background:color-mix(in srgb, var(--cat) 12%, transparent); border:1px solid color-mix(in srgb, var(--cat) 28%, transparent);
  border-radius:999px; padding:2px 11px; }
/* sensor sub-groups */
.prod-group{ margin:0 0 24px; }
.prod-group-head{ display:flex; align-items:center; gap:9px; margin:0 0 13px; font-family:var(--fb); font-weight:600;
  font-size:13.5px; letter-spacing:0.01em; color:var(--ink); text-transform:none; }
.prod-grp-dot{ width:9px; height:9px; border-radius:50%; background:var(--grp); flex:none;
  box-shadow:0 0 0 4px color-mix(in srgb, var(--grp) 18%, transparent); }
.prod-grp-n{ font-family:var(--fm); font-size:11.5px; color:var(--grp);
  background:color-mix(in srgb, var(--grp) 12%, transparent); border-radius:999px; padding:1px 8px; }
.prod-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(266px,1fr)); gap:15px; }
/* cards — themed by category (--cat) and, inside sensor groups, by group (--grp) */
.prod-card{ position:relative; display:flex; flex-direction:column; gap:7px; text-decoration:none; overflow:hidden;
  background:var(--card); border:1px solid var(--line); border-radius:14px; padding:22px 20px 17px;
  transition:transform .16s ease, border-color .16s ease, box-shadow .16s ease; }
.prod-card::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:var(--grp, var(--cat)); opacity:.85; }
.prod-card:hover{ transform:translateY(-3px); border-color:color-mix(in srgb, var(--grp, var(--cat)) 55%, transparent);
  box-shadow:0 12px 30px rgba(0,0,0,0.20); }
.prod-card h3{ font-family:var(--fb); font-weight:600; font-size:16.5px; line-height:1.3; margin:0; color:var(--ink); }
.prod-card p{ font-size:13.5px; line-height:1.55; color:var(--ink-soft); margin:0; flex:1; }
.prod-ds{ margin-top:7px; font-family:var(--fm); font-size:12px; letter-spacing:0.02em;
  color:var(--grp, var(--cat)); opacity:.92; }
.prod-card:not(.has-ds) .prod-ds{ color:var(--ink-soft); opacity:.7; }
.prod-card:hover .prod-ds{ text-decoration:underline; }
@media (max-width:640px){ .prod-grid{ grid-template-columns:1fr; } }
