/* ========== 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: 1.5fr 1fr 1fr;
  gap: 0;
  align-items: start;
  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.15;
  letter-spacing: -0.02em;
  color: var(--ink);
  word-break: keep-all;
}
.snap-desc {
  font-size: 12px;
  color: var(--ink-soft);
  margin-top: 8px;
  line-height: 1.5;
}
@media (max-width: 780px) {
  .snapshot-bar { grid-template-columns: 1fr; padding-top: 20px; }
  .snap { border-right: none; border-bottom: 1px solid var(--line); padding: 16px 0; }
  .snap:not(:first-child) { padding-left: 0; }
  .snap:first-child { padding-top: 0; }
  .snap:last-child { border-bottom: none; padding-bottom: 0; }
}

.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: 920px; }
.case-content > p { max-width: 740px; }
.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(auto-fit, minmax(200px, 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; } }

/* ===== Partners World Map (dark theme) ===== */
.worldmap{margin-top:18px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.07);border-radius:18px;padding:18px}
.wm-inner{position:relative;width:100%;max-width:1000px;margin:0 auto;aspect-ratio:1000/389}
.wm-svg{width:100%;height:100%;display:block;overflow:visible}
.wm-land{fill:#1f2b4c;stroke:rgba(255,255,255,.08);stroke-width:.6}
.wm-region{fill:#26345b;stroke:rgba(255,255,255,.10);stroke-width:.5;cursor:pointer;transition:fill .25s,opacity .25s}
.wm-region:hover{fill:#324477}
.worldmap.has-active .wm-region{opacity:.4}
.worldmap.has-active .wm-region.active{opacity:1;fill:var(--c)}
.wm-pins{position:absolute;inset:0;pointer-events:none}
.wm-pin{position:absolute;transform:translate(-50%,-50%);background:none;border:0;padding:0;cursor:pointer;z-index:2;pointer-events:auto}
.wm-ring{position:absolute;left:50%;top:50%;width:var(--sz);height:var(--sz);transform:translate(-50%,-50%);border-radius:50%;background:var(--c);opacity:.22;animation:wmpulse 2.6s ease-out infinite}
.wm-dot{position:relative;display:flex;align-items:center;justify-content:center;width:var(--sz);height:var(--sz);border-radius:50%;background:var(--c);color:#0A1130;font-weight:800;font-size:13px;box-shadow:0 4px 14px rgba(0,0,0,.4);border:2px solid var(--bg);transition:transform .15s}
.wm-pin:hover .wm-dot,.wm-pin.active .wm-dot{transform:scale(1.14)}
.wm-pin.active .wm-dot{box-shadow:0 0 0 4px rgba(255,255,255,.14),0 6px 18px rgba(0,0,0,.5)}
.worldmap.has-active .wm-pin:not(.active){opacity:.35}
.wm-tip{position:absolute;left:50%;bottom:calc(100% + 9px);transform:translateX(-50%);white-space:nowrap;background:#0c1430;color:#fff;font-size:12px;padding:5px 9px;border-radius:7px;opacity:0;pointer-events:none;transition:opacity .15s;z-index:3;border:1px solid rgba(255,255,255,.12)}
.wm-tip b{font-weight:700;color:#fff}
.wm-pin:hover .wm-tip,.wm-pin.active .wm-tip{opacity:1}
@keyframes wmpulse{0%{transform:translate(-50%,-50%) scale(.7);opacity:.4}70%{opacity:0}100%{transform:translate(-50%,-50%) scale(1.9);opacity:0}}
@media (max-width:640px){.wm-dot{font-size:11px}.wm-tip{font-size:11px}}

/* ===== Solution architecture flow ===== */
.sol-arch{display:flex;flex-wrap:wrap;align-items:stretch;gap:10px;margin-top:18px}
.sol-arch .sa-node{flex:1 1 180px;min-width:160px;display:flex;flex-direction:column;justify-content:center;gap:4px;background:#f6f8fb;border:1px solid #e3e9f1;border-radius:12px;padding:16px 16px;font-weight:700;color:var(--ink);font-size:15px;text-align:center}
.sol-arch .sa-node small{display:block;font-weight:500;color:var(--ink-soft);font-size:12px;line-height:1.4}
.sol-arch .sa-arrow{display:flex;align-items:center;color:var(--accent-dark);font-size:22px;font-weight:700}
@media (max-width:760px){.sol-arch{flex-direction:column}.sol-arch .sa-arrow{transform:rotate(90deg);justify-content:center}}

/* ===== Product card icons (inline SVG) ===== */
.prod-card{display:flex;gap:14px;align-items:flex-start}
.prod-ico{flex:0 0 auto;width:50px;height:50px;border-radius:12px;background:var(--accent-soft,#eef3fb);display:flex;align-items:center;justify-content:center;color:var(--accent-dark,#2660c8);transition:background .15s,color .15s,transform .15s}
.prod-ico svg{width:28px;height:28px;display:block}
.prod-card:hover .prod-ico{background:var(--accent,#3b7de0);color:#fff;transform:translateY(-1px)}
.prod-card-body{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:6px}
.prod-card-body h3{margin:0}
@media (max-width:520px){.prod-ico{width:44px;height:44px}.prod-ico svg{width:24px;height:24px}}

/* ===== Our Solution — How Monnit Works ===== */
.hmw{display:flex;align-items:stretch;gap:14px;margin-top:18px;flex-wrap:wrap}
.hmw-step{flex:1 1 220px;position:relative;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:26px 22px 22px;text-align:center}
.hmw-badge{position:absolute;top:14px;left:16px;font-size:12px;font-weight:800;letter-spacing:.06em;color:var(--accent-dark)}
.hmw-ico{display:inline-flex;width:72px;height:72px;align-items:center;justify-content:center;border-radius:18px;background:var(--accent-soft);color:var(--accent-dark);margin-bottom:14px}
.hmw-ico svg{width:42px;height:42px}
.hmw-step h3{margin:0 0 6px;font-size:18px}
.hmw-step p{margin:0;color:var(--ink-soft);font-size:14px;line-height:1.55}
.hmw-note{display:block;margin-top:10px;font-size:11.5px;color:var(--ink-faint)}
.hmw-arrow{display:flex;align-items:center;justify-content:center;color:var(--accent);flex:0 0 auto}
.hmw-arrow svg{width:40px;height:22px}
@media (max-width:780px){.hmw{flex-direction:column}.hmw-arrow{transform:rotate(90deg)}}

/* software choices */
.sw-choices{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}
.sw-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:22px}
.sw-ico{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;border-radius:14px;background:var(--accent-soft);color:var(--accent-dark);margin-bottom:12px}
.sw-ico svg{width:32px;height:32px}
.sw-card h4{margin:0 0 6px;font-size:16px}
.sw-card p{margin:0;color:var(--ink-soft);font-size:13.5px;line-height:1.55}
@media (max-width:780px){.sw-choices{grid-template-columns:1fr}}

/* dashboard preview */
.dash{margin-top:16px;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;background:var(--bg-deep)}
.dash-top{display:flex;align-items:center;gap:10px;padding:11px 16px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.08)}
.dash-dots{display:flex;gap:6px}
.dash-dots i{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.18)}
.dash-title{font-size:13px;font-weight:600;color:var(--ink-mid)}
.dash-live{margin-left:auto;font-size:11px;font-weight:800;letter-spacing:.08em;color:#5FDDA0;display:flex;align-items:center;gap:6px}
.dash-live::before{content:"";width:7px;height:7px;border-radius:50%;background:#5FDDA0;box-shadow:0 0 0 0 rgba(95,221,160,.6);animation:dashpulse 1.8s infinite}
@keyframes dashpulse{0%{box-shadow:0 0 0 0 rgba(95,221,160,.5)}70%{box-shadow:0 0 0 7px rgba(95,221,160,0)}100%{box-shadow:0 0 0 0 rgba(95,221,160,0)}}
.dash-body{padding:18px;display:grid;grid-template-columns:1.1fr 1fr;gap:18px}
.dash-kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.kpi{display:flex;gap:11px;align-items:center;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:13px 14px}
.kpi-ic{flex:0 0 auto;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--accent-soft);color:var(--accent-dark)}
.kpi-ic.warn{background:rgba(235,192,98,.16);color:#EBC062}
.kpi-ic.alert{background:rgba(240,143,190,.16);color:#F08FBE}
.kpi-t b{display:block;font-size:18px;line-height:1.1}
.kpi-t small{color:var(--ink-soft);font-size:11.5px}
.dash-list{display:flex;flex-direction:column;gap:0;align-self:start;border:1px solid rgba(255,255,255,.07);border-radius:12px;overflow:hidden}
.dl-row{display:flex;align-items:center;gap:10px;padding:12px 14px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.06)}
.dl-row:last-child{border-bottom:0}
.dl-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.dl-dot.ok{background:#5FDDA0}.dl-dot.warn{background:#EBC062}.dl-dot.alert{background:#F08FBE}
.dl-x{flex:1 1 auto;color:var(--ink-mid)}
.dl-t{color:var(--ink-faint);font-size:11.5px}
@media (max-width:780px){.dash-body{grid-template-columns:1fr}.dash-kpis{grid-template-columns:1fr 1fr}}

/* condensed stats */
.sol-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:30px}
.sol-stats .ss{text-align:center;padding:18px 10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:14px}
.sol-stats .ss b{display:block;font-size:26px;color:var(--accent-dark);letter-spacing:-.02em}
.sol-stats .ss span{font-size:12.5px;color:var(--ink-soft)}
@media (max-width:640px){.sol-stats{grid-template-columns:1fr 1fr}}

/* ===== Solution: animated flow tags ===== */
.sol-stats-top{margin-top:18px;margin-bottom:8px}
.hmw-tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:12px}
.hmw-tags span{font-size:11px;color:var(--ink-mid);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:3px 9px}
.flowline{stroke-dasharray:6 6;animation:flowdash .9s linear infinite}
@keyframes flowdash{to{stroke-dashoffset:-12}}
.sol-mini{font-size:14.5px;margin-top:-4px}

/* ===== Battery calculator ===== */
.calc{display:grid;grid-template-columns:340px 1fr;gap:18px;margin-top:16px}
.calc-in,.calc-out{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px}
.calc-in label{display:block;font-size:12px;color:var(--ink-soft);margin:12px 0 5px;letter-spacing:.02em}
.calc-in label:first-child{margin-top:0}
.calc-in select{width:100%;background:var(--bg-deep);color:var(--ink);border:1px solid rgba(255,255,255,.14);border-radius:9px;padding:9px 10px;font-size:13.5px}
.calc-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stepper{display:flex;align-items:center;gap:0;border:1px solid rgba(255,255,255,.14);border-radius:9px;overflow:hidden}
.stepper button{flex:0 0 38px;height:38px;background:rgba(255,255,255,.05);color:var(--accent-dark);border:0;font-size:18px;cursor:pointer}
.stepper button:hover{background:var(--accent-soft)}
.stepper span{flex:1;text-align:center;font-weight:700;font-size:15px}
.calc-go{width:100%;margin-top:16px;background:var(--accent);color:#04121a;border:0;border-radius:10px;padding:12px;font-weight:800;font-size:14px;cursor:pointer;letter-spacing:.02em}
.calc-go:hover{background:var(--accent-dark)}
.calc-res{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;text-align:center}
.calc-res>div{background:var(--bg-deep);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:16px 8px}
.calc-res b{display:block;font-size:30px;color:var(--accent-dark);letter-spacing:-.02em;line-height:1}
.calc-res span{font-size:11.5px;color:var(--ink-soft)}
.calc-barwrap{margin-top:18px}
.calc-bar{display:flex;height:16px;border-radius:8px;overflow:hidden;background:var(--bg-deep)}
.power-seg{display:block;min-width:2px;transition:flex .4s}
.power-seg.s1{flex:60;background:#3a4a78}.power-seg.s2{flex:8;background:#5b6fb0}.power-seg.s3{flex:2;background:#8a93c4}.power-seg.s4{flex:30;background:var(--accent)}
.calc-leg{display:flex;flex-wrap:wrap;gap:14px;margin-top:12px}
.calc-leg span{font-size:11.5px;color:var(--ink-soft);display:flex;align-items:center;gap:6px}
.calc-leg i{width:10px;height:10px;border-radius:3px;display:inline-block}
.calc-leg i.s1{background:#3a4a78}.calc-leg i.s2{background:#5b6fb0}.calc-leg i.s3{background:#8a93c4}.calc-leg i.s4{background:var(--accent)}
.calc-leg em{color:var(--ink-mid);font-style:normal}
.calc-notes{margin-top:16px;font-size:12.5px;line-height:1.7;color:var(--ink-soft);border-top:1px solid rgba(255,255,255,.08);padding-top:14px}
.calc-notes b{color:var(--ink)}
@media (max-width:780px){.calc{grid-template-columns:1fr}}

/* ===== Dashboard tabs / panels ===== */
.soldash-tabs{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.soldash-tab{background:rgba(255,255,255,.04);color:var(--ink-mid);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:9px 18px;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s}
.soldash-tab:hover{border-color:var(--accent)}
.soldash-tab.active{background:var(--accent);color:#04121a;border-color:var(--accent)}
.soldash-panel{display:none;margin-top:14px}
.soldash-panel.active{display:block}
.dash-clock{margin-left:auto;font-size:12px;color:var(--ink-soft)}
.dash-mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.dash-live{margin-left:14px}
.kpi-ic.ok2{background:rgba(95,221,160,.16);color:#5FDDA0;font-weight:800;font-size:13px}
.kpi-ic.save{background:rgba(95,221,160,.16);color:#5FDDA0;font-weight:800;font-size:18px}
.kpi-ic{font-weight:800;font-size:13px}
.dash-foot{padding:11px 16px;border-top:1px solid rgba(255,255,255,.08);font-size:12.5px;color:var(--ink-soft);background:rgba(255,255,255,.02)}
.dash-zones{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;align-content:start}
.zone{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:9px;padding:9px 6px;text-align:center}
.zone b{display:block;font-size:15px;color:var(--accent-dark);line-height:1.1}
.zone small{font-size:10px;color:var(--ink-faint)}
.zone.hot{background:rgba(240,143,190,.12);border-color:rgba(240,143,190,.3)}
.zone.hot b{color:#F08FBE}
.zone.cool{background:rgba(133,182,255,.12);border-color:rgba(133,182,255,.3)}
.zone.cool b{color:#85B6FF}
@media (max-width:780px){.dash-zones{grid-template-columns:repeat(4,1fr)}}

/* ===== SCUBE — distinct control-center design ===== */
.scube{border:1px solid rgba(24,208,230,.25);border-radius:16px;overflow:hidden;background:linear-gradient(180deg,rgba(24,208,230,.05),var(--bg-deep) 40%)}
.scube-top{background:rgba(24,208,230,.08);border-bottom:1px solid rgba(24,208,230,.2)}
.scube-body{display:grid;grid-template-columns:1fr 320px;gap:0}
.scube-left{padding:18px;border-right:1px solid rgba(255,255,255,.08)}
.scube-counts{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.sc-c{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 6px;border-radius:11px;font-size:11.5px;color:var(--ink-soft);border:1px solid rgba(255,255,255,.08)}
.sc-c b{font-size:22px;line-height:1}
.sc-c.normal{background:rgba(95,221,160,.1)}.sc-c.normal b{color:#5FDDA0}
.sc-c.warning{background:rgba(235,192,98,.1)}.sc-c.warning b{color:#EBC062}
.sc-c.alert{background:rgba(240,143,190,.1)}.sc-c.alert b{color:#F08FBE}
.sc-c.offline{background:rgba(255,255,255,.04)}.sc-c.offline b{color:var(--ink-faint)}
.facility-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:5px}
.facility-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:8.5px;font-weight:700;border-radius:5px;color:rgba(255,255,255,.55);cursor:default;transition:transform .12s}
.facility-cell:hover{transform:scale(1.12)}
.facility-cell.normal{background:rgba(95,221,160,.22);color:#bff3da}
.facility-cell.warning{background:rgba(235,192,98,.32);color:#3a2e10}
.facility-cell.alert{background:rgba(240,143,190,.4);color:#3a0f25;animation:scblink 1.4s infinite}
.facility-cell.offline{background:rgba(255,255,255,.07);color:var(--ink-faint)}
@keyframes scblink{50%{opacity:.45}}
.scube-legend{display:flex;gap:14px;margin-top:12px}
.scube-legend span{font-size:11px;color:var(--ink-soft);display:flex;align-items:center;gap:5px}
.scube-legend i{width:10px;height:10px;border-radius:3px}
.scube-legend i.normal{background:#5FDDA0}.scube-legend i.warning{background:#EBC062}.scube-legend i.alert{background:#F08FBE}.scube-legend i.offline{background:rgba(255,255,255,.25)}
.scube-feed{padding:16px;display:flex;flex-direction:column;gap:10px}
.feed-title{font-size:12px;font-weight:700;color:var(--ink-mid);letter-spacing:.04em;margin-bottom:2px}
.feed-row{display:flex;gap:10px;align-items:flex-start;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:10px 11px}
.feed-row b{display:block;font-size:12.5px;color:var(--ink);line-height:1.4}
.feed-row small{font-size:10.5px;color:var(--ink-faint)}
.feed-tag{flex:0 0 auto;font-size:9.5px;font-weight:800;padding:3px 7px;border-radius:6px;letter-spacing:.04em}
.feed-row.crit .feed-tag{background:#ff5d6c;color:#2a0007}
.feed-row.warn .feed-tag{background:#EBC062;color:#2e2208}
.feed-row.info .feed-tag{background:rgba(24,208,230,.25);color:var(--accent-dark)}
.feed-row.crit{border-color:rgba(255,93,108,.4)}
@media (max-width:780px){.scube-body{grid-template-columns:1fr}.scube-left{border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}}

/* ===== AI control architecture ===== */
.ai-arch{margin-top:16px;display:flex;flex-direction:column;align-items:stretch;gap:0}
.ai-layer{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:16px 18px}
.ai-layer.edge{border-color:rgba(24,208,230,.35);background:rgba(24,208,230,.05)}
.ai-layer.act{border-color:rgba(95,221,160,.3);background:rgba(95,221,160,.05)}
.ai-ln{font-size:11.5px;font-weight:800;letter-spacing:.08em;color:var(--accent-dark)}
.ai-layer.act .ai-ln{color:#5FDDA0}
.ai-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.ai-chips span{font-size:12px;color:var(--ink-mid);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:5px 11px}
.ai-decision{margin-top:11px;font-size:12.5px;color:var(--ink-mid);background:var(--bg-deep);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;padding:9px 12px}
.ai-decision em{font-style:normal;color:var(--accent-dark);font-weight:700}
.ai-decision.cloud{border-left-color:#85B6FF}.ai-decision.cloud em{color:#85B6FF}
.ai-flow{display:flex;align-items:center;justify-content:center;gap:9px;font-size:11.5px;color:var(--ink-faint);padding:9px 0;position:relative}
.ai-flow::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(var(--accent),transparent);opacity:.4}
.ai-flow-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:aiflow 1.6s ease-in-out infinite;z-index:1}
@keyframes aiflow{0%{transform:translateY(-7px);opacity:.3}50%{opacity:1}100%{transform:translateY(7px);opacity:.3}}

/* AI feature cards */
.ai-feats{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-top:22px}
.ai-feat{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:18px}
.aif-badge{font-size:10.5px;font-weight:800;letter-spacing:.04em;color:var(--accent-dark);background:var(--accent-soft);border-radius:20px;padding:3px 10px;display:inline-block;margin-bottom:10px}
.ai-feat h4{margin:0 0 6px;font-size:14.5px}
.ai-feat p{margin:0;font-size:12.5px;color:var(--ink-soft);line-height:1.55}
@media (max-width:900px){.ai-feats{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.ai-feats{grid-template-columns:1fr}}

/* AI decision log (terminal) */
.ai-log{margin-top:18px;background:var(--bg-deep);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px 16px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.9;min-height:150px}
.ai-log-h{color:var(--accent-dark);font-weight:700;letter-spacing:.08em;margin-bottom:8px}
.ai-log-row{color:var(--ink-mid);animation:logfade .4s ease}
.ai-log-row .t{color:var(--ink-faint)}
.ai-log-row .k{color:var(--accent);font-weight:700}
@keyframes logfade{from{opacity:0;transform:translateY(4px)}to{opacity:1}}

/* ===== SCUBE map-based ===== */
.scube-body{display:grid;grid-template-columns:1fr 340px;gap:0}
.scube-map{padding:16px 10px 12px;border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:center}
.kmap-wrap{position:relative;width:100%;max-width:340px;margin:0 auto}
.kmap{width:100%;height:auto;display:block;overflow:visible}
.kmap-land{fill:#1c2a4d;stroke:rgba(120,160,255,.28);stroke-width:.7}
.kmap-pins{position:absolute;inset:0}
.kmark{position:absolute;transform:translate(-50%,-50%);background:none;border:0;padding:0;cursor:pointer;width:0;height:0}
.kmark-dot{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:13px;height:13px;border-radius:50%;border:2px solid var(--bg);z-index:2}
.kmark-ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:13px;height:13px;border-radius:50%;z-index:1;animation:kpulse 2.4s ease-out infinite}
.kmark.normal .kmark-dot{background:#5FDDA0}.kmark.normal .kmark-ring{background:#5FDDA0}
.kmark.warning .kmark-dot{background:#EBC062}.kmark.warning .kmark-ring{background:#EBC062}
.kmark.alert .kmark-dot{background:#FF5D6C}.kmark.alert .kmark-ring{background:#FF5D6C}
.kmark.alert .kmark-dot{animation:kblink 1.2s infinite}
@keyframes kpulse{0%{opacity:.5;transform:translate(-50%,-50%) scale(1)}70%{opacity:0;transform:translate(-50%,-50%) scale(3.2)}100%{opacity:0}}
@keyframes kblink{50%{opacity:.45}}
.kmark-tip{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);white-space:nowrap;background:#0c1430;border:1px solid rgba(255,255,255,.15);color:#fff;font-size:11px;padding:4px 8px;border-radius:6px;opacity:0;pointer-events:none;transition:opacity .15s;z-index:5}
.kmark:hover .kmark-tip{opacity:1}
.kmark:hover .kmark-dot{transform:translate(-50%,-50%) scale(1.25)}
.scube-side{display:flex;flex-direction:column;gap:12px;padding:16px}
.ksites{display:flex;flex-direction:column;gap:1px;border:1px solid rgba(255,255,255,.07);border-radius:10px;overflow:hidden}
.ksite{display:flex;align-items:center;gap:9px;padding:9px 11px;background:rgba(255,255,255,.02);font-size:12.5px}
.ksite-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}
.ksite.normal .ksite-dot{background:#5FDDA0}.ksite.warning .ksite-dot{background:#EBC062}.ksite.alert .ksite-dot{background:#FF5D6C}
.ksite-n{flex:1 1 auto;color:var(--ink-mid)}
.ksite-eq{display:flex;gap:5px}
.keq{width:18px;height:18px;color:var(--ink-faint)}
.keq svg{width:18px;height:18px;display:block}
.ksite.alert .keq{color:#FF8A95}.ksite.warning .keq{color:#EBC062}
@media (max-width:820px){.scube-body{grid-template-columns:1fr}.scube-map{border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}}

/* ===== HVAC AHU graphic ===== */
.hvac-body{display:grid;grid-template-columns:1fr 230px;gap:16px;padding:18px}
.ahu{background:var(--bg-deep);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:8px}
.ahu svg{width:100%;height:auto;display:block}
.ahu-duct{fill:rgba(24,208,230,.05);stroke:rgba(24,208,230,.3);stroke-width:1.5}
.ahu-flow{stroke:rgba(24,208,230,.35);stroke-width:2;stroke-dasharray:5 7;animation:flowdash 1s linear infinite}
.ahu-dot{fill:var(--accent)}
.ahu-arrow{stroke:var(--ink-soft);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ahu-sep{stroke:rgba(255,255,255,.12);stroke-width:1}
.ahu-ic{stroke:var(--ink-mid);stroke-width:1.6;fill:none;stroke-linecap:round}
.ahu-coil{fill:none;stroke-width:2.4;stroke-linecap:round}
.ahu-coil.cool{stroke:#5BA8FF}.ahu-coil.heat{stroke:#FF8A6B}
.ahu-stage{fill:var(--ink-mid);font-size:11px;text-anchor:middle;font-weight:600}
.ahu-mini{font-size:10px;text-anchor:middle}.ahu-mini.cool{fill:#5BA8FF}
.ahu-lab{fill:var(--ink-soft);font-size:11px;text-anchor:start}
.ahu-lab2{fill:var(--ink-faint);font-size:10.5px;text-anchor:middle}
.ahu-val{font-size:15px;font-weight:800;text-anchor:start}.ahu-val.cool{fill:#5BA8FF}.ahu-val.warm{fill:#FF8A6B}
.ahu-fan-r{fill:rgba(24,208,230,.08);stroke:rgba(24,208,230,.3);stroke-width:1.5}
.ahu-fan{transform-origin:440px 93px;animation:ahuspin 3s linear infinite}
@keyframes ahuspin{to{transform:rotate(360deg)}}
.ahu-return{fill:none;stroke:rgba(255,255,255,.18);stroke-width:1.5;stroke-dasharray:4 5}
.ahu-rdot{fill:var(--ink-soft)}
.hvac-side{display:flex;flex-direction:column;gap:14px}
.gauge{position:relative;width:130px;height:130px;margin:0 auto}
.gauge svg{transform:rotate(-90deg)}
.g-bg{fill:none;stroke:rgba(255,255,255,.08);stroke-width:9}
.g-fg{fill:none;stroke:#5FDDA0;stroke-width:9;stroke-linecap:round;transition:stroke-dashoffset 1s}
.g-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.g-c b{font-size:28px;color:#5FDDA0;line-height:1}
.g-c span{font-size:11px;color:var(--ink-soft)}
.hvac-kpis{display:flex;flex-direction:column;gap:8px}
.hk{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:9px 12px}
.hk b{display:block;font-size:16px;color:var(--accent-dark);line-height:1.1}
.hk span{font-size:11px;color:var(--ink-soft)}
@media (max-width:820px){.hvac-body{grid-template-columns:1fr}.gauge{margin:0}}

/* ===== AI layer icons + desc ===== */
.ai-lhead{display:flex;align-items:center;gap:12px;margin-bottom:4px}
.ai-lic{flex:0 0 auto;width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:11px;background:var(--accent-soft);color:var(--accent-dark)}
.ai-lic svg{width:24px;height:24px}
.ai-ld{display:block;font-size:12px;color:var(--ink-soft);margin-top:2px}

/* ===== SCUBE Seoul control-center additions ===== */
.kmap-wrap.seoul{max-width:480px}
.kmap-wrap.seoul .kmap-land{fill:#1e2c4f;stroke:rgba(120,160,255,.22);stroke-width:1}
.scube-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:0 16px 16px}
.ins-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:13px 14px}
.ins-card.hi{background:linear-gradient(180deg,rgba(24,208,230,.08),rgba(255,255,255,.02));border-color:rgba(24,208,230,.25)}
.ins-h{font-size:12px;font-weight:700;color:var(--accent-dark);letter-spacing:.02em;margin-bottom:9px}
.ins-card p{margin:0;font-size:12.5px;color:var(--ink-mid);line-height:1.6}
.ins-card.hi p b{color:#fff}
.vbar{display:flex;align-items:center;gap:9px;font-size:12px;margin:7px 0}
.vb-n{flex:0 0 116px;color:var(--ink-soft)}
.vb{flex:1 1 auto;height:7px;background:rgba(255,255,255,.07);border-radius:4px;overflow:hidden}
.vb i{display:block;height:100%;background:var(--accent);border-radius:4px}
.vbar.warn .vb i{background:#EBC062}.vbar.alert .vb i{background:#FF5D6C}
.vbar b{flex:0 0 auto;width:38px;text-align:right;color:var(--ink-mid);font-size:12px}
.stat-bars{display:flex;flex-direction:column;gap:8px}
.sb{display:flex;align-items:center;gap:9px;font-size:12px}
.sb span:first-child{flex:0 0 66px;color:var(--ink-soft)}
.sbar{flex:1 1 auto;height:8px;background:rgba(255,255,255,.07);border-radius:4px;overflow:hidden}
.sbar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),#85B6FF);border-radius:4px}
.sb em{flex:0 0 auto;width:34px;text-align:right;font-style:normal;color:var(--ink-mid)}
.disp-top{display:flex;gap:8px;margin-bottom:10px}
.disp-top span{flex:1;text-align:center;background:rgba(255,255,255,.04);border-radius:9px;padding:8px 4px;font-size:10.5px;color:var(--ink-soft)}
.disp-top b{display:block;font-size:17px;color:var(--accent-dark);line-height:1}
.disp-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-mid);padding:5px 0}
.disp-row em{margin-left:auto;font-style:normal;font-size:10.5px;color:var(--ink-faint);background:rgba(255,255,255,.05);padding:2px 8px;border-radius:10px}
.guide{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:7px}
.guide li{font-size:12px;color:var(--ink-soft);line-height:1.5}
.guide li b{color:var(--ink)}
@media (max-width:900px){.scube-row{grid-template-columns:1fr}}

/* ===== AHU optimization view ===== */
.ahu2{padding:10px 8px 4px}
.ahu2 svg{width:100%;height:auto;display:block}
.a2-arrow{stroke:var(--ink-soft);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.a2-io{fill:var(--ink-soft);font-size:11px}.a2-io.warm{fill:#FF8A6B}
.a2-line path{stroke:var(--ink-mid);stroke-width:1.5;fill:none;stroke-linecap:round}
.a2-coil path{fill:none;stroke-width:2.4;stroke-linecap:round}
.a2-coil.cool path{stroke:#5BA8FF}.a2-coil.heat path{stroke:#FF8A6B}
.a2-coil.off path{stroke:rgba(255,138,107,.3)}
.a2-flow{stroke:rgba(24,208,230,.35);stroke-width:2;stroke-dasharray:5 7;animation:flowdash 1s linear infinite}
.a2-dot{fill:var(--accent)}
.a2-fanbg{fill:rgba(24,208,230,.08);stroke:rgba(24,208,230,.3);stroke-width:1.5}
.a2-fan{transform-origin:588px 152px;animation:ahuspin 2.6s linear infinite}
.a2-fanblade{fill:none;stroke:#9fb4e6;stroke-width:1.8;stroke-linecap:round}
.a2-pin circle{fill:var(--accent);stroke:var(--bg);stroke-width:2}
.a2-pin text{fill:#04121a;font-size:11px;font-weight:800;text-anchor:middle}
.a2-pin.off circle{fill:#5a6486}
.ahu-status{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:14px 18px 4px}
.as{display:flex;gap:10px;align-items:flex-start;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:11px;padding:11px 12px}
.as-no{flex:0 0 auto;width:24px;height:24px;border-radius:7px;background:var(--accent);color:#04121a;font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center}
.as b{display:block;font-size:13px;color:var(--ink);line-height:1.35}
.as small{font-size:11px;color:var(--ink-soft);line-height:1.45}
.as.cool .as-no{background:#5BA8FF}
.as.off{opacity:.7}.as.off .as-no{background:#5a6486}
.as.save .as-no{background:#5FDDA0}
@media (max-width:860px){.ahu-status{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.ahu-status{grid-template-columns:1fr}}

/* ===== Vibration dashboard (motor + sensor) ===== */
.vib-body{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:18px}
.vib-motor{background:var(--bg-deep);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:8px;display:flex;align-items:center}
.vib-motor svg{width:100%;height:auto;display:block}
.vib-shake{transform-origin:center;animation:vibshake .14s linear infinite}
@keyframes vibshake{0%{transform:translate(0,0)}25%{transform:translate(.5px,-.4px)}50%{transform:translate(-.4px,.5px)}75%{transform:translate(.4px,.3px)}100%{transform:translate(0,0)}}
.vib-waves{opacity:.4;animation:vibwav 1.4s ease-in-out infinite}
@keyframes vibwav{50%{opacity:1}}
.vib-data{display:flex;flex-direction:column;gap:12px}
.vib-rms{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.vrms{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;text-align:center;position:relative}
.vrms .ax{position:absolute;top:8px;left:10px;font-size:11px;font-weight:800;color:var(--ink-faint)}
.vrms b{display:block;font-size:24px;letter-spacing:-.02em;line-height:1.4;color:var(--accent-dark)}
.vrms small{font-size:10.5px;color:var(--ink-soft)}
.vrms.warn b{color:#EBC062}.vrms.ok b{color:#5FDDA0}
.vib-spec{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 14px}
.vib-spec-h{font-size:11.5px;color:var(--ink-soft);margin-bottom:10px}
.vib-bars{display:flex;align-items:flex-end;gap:3px;height:64px}
.vib-bars i{flex:1;background:linear-gradient(180deg,var(--accent),rgba(24,208,230,.25));border-radius:2px 2px 0 0;height:30%;animation:vbar 1.1s ease-in-out infinite}
.vib-bars i:nth-child(3n){animation-duration:1.5s}.vib-bars i:nth-child(3n+1){animation-duration:.9s}
.vib-bars i:nth-child(2n){animation-delay:.2s}.vib-bars i:nth-child(5n){animation-delay:.45s}
.vib-bars i:nth-child(7){background:linear-gradient(180deg,#EBC062,rgba(235,192,98,.3))}
.vib-bars i:nth-child(8){background:linear-gradient(180deg,#EBC062,rgba(235,192,98,.3))}
@keyframes vbar{0%,100%{height:22%}50%{height:85%}}
.vib-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
.vib-meta div{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:10px 6px;text-align:center}
.vib-meta b{display:block;font-size:16px;color:var(--ink);line-height:1.1}
.vib-meta span{font-size:10.5px;color:var(--ink-soft)}
.vib-meta .warn2 b{color:#EBC062}
@media (max-width:820px){.vib-body{grid-template-columns:1fr}}

/* ===== HVAC AHU + duct schematic ===== */
.hvac2{padding:10px 8px 2px}
.hvac2 svg{width:100%;height:auto;display:block}
.h2-ai rect{fill:var(--accent)}
.h2-ai text{fill:#04121a;font-size:13px;font-weight:800}
.h2-room{fill:rgba(255,255,255,.02);stroke:rgba(120,160,255,.28);stroke-dasharray:5 5}
.h2-roomlab{fill:var(--ink-mid);font-size:13px;font-weight:600;text-anchor:middle}
.h2-roomsub{fill:var(--ink-soft);font-size:11px;text-anchor:middle}
.h2-arrow2 path{stroke:var(--accent);stroke-width:2.4;stroke-linecap:round}
.h2-arrow2.ret path{stroke:var(--ink-soft)}
.h2-arrow path{stroke:var(--ink-soft);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.h2-io{fill:var(--ink-soft);font-size:11px}
.h2-line path{stroke:var(--ink-mid);stroke-width:1.4;fill:none;stroke-linecap:round}
.h2-coil path{fill:none;stroke-width:2.2;stroke-linecap:round}
.h2-coil.cool path{stroke:#5BA8FF}.h2-coil.heat path{stroke:#FF8A6B}
.h2-fan{transform-origin:0 0;animation:ahuspin 2.6s linear infinite}
.h2-fan.f2{animation-duration:2s}
.h2-blade{fill:none;stroke:#9fb4e6;stroke-width:1.7;stroke-linecap:round}
.h2-duct{fill:none;stroke:rgba(24,208,230,.4);stroke-width:7}
.h2-duct.ret{stroke:rgba(255,255,255,.14)}
.h2-flow{stroke:var(--accent);stroke-width:2;stroke-dasharray:5 7;animation:flowdash 1s linear infinite}
.h2-dot{fill:var(--accent)}.h2-dot.ret{fill:var(--ink-soft)}
.h2-stage{fill:var(--ink-soft);font-size:10.5px;text-anchor:middle}
.h2-node circle{fill:var(--accent);stroke:var(--bg);stroke-width:2}
.h2-node text{fill:var(--ink-mid);font-size:10.5px;text-anchor:middle}
.hvac2-foot{display:flex;flex-wrap:wrap;gap:8px;padding:4px 18px 0}
.h2-chip{font-size:11.5px;color:var(--ink-mid);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:5px 12px}
.h2-chip.cool{color:#5BA8FF;border-color:rgba(91,168,255,.35)}
.h2-chip.save{color:#5FDDA0;border-color:rgba(95,221,160,.35)}

/* ===== Trust strip: protocols + certifications ===== */
.sol-trust{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.trust-col{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px 18px}
.trust-label{display:block;font-size:11px;font-weight:800;letter-spacing:.08em;color:var(--accent-dark);margin-bottom:12px}
.trust-items{display:flex;flex-wrap:wrap;gap:8px}
.proto{font-size:12.5px;color:var(--ink-mid);background:rgba(24,208,230,.08);border:1px solid rgba(24,208,230,.22);border-radius:8px;padding:6px 11px}
.cert{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-mid);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:5px 11px 5px 6px}
.cmark{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:22px;padding:0 6px;border-radius:5px;background:var(--ink);color:#0A1130;font-size:11px;font-weight:800;letter-spacing:.02em}
.cmark.ce{font-family:Georgia,serif;font-style:italic}
.cmark.ex i{font-style:italic;font-weight:800}
.cert.sec{color:var(--accent-dark);border-color:rgba(24,208,230,.3)}
.cert.sec svg{width:16px;height:16px}
@media (max-width:780px){.sol-trust{grid-template-columns:1fr}}

/* ===== Vibration: calmer motion + diagnosis + fleet ===== */
.vib-shake{animation:none!important}
.vib-waves{opacity:.55;animation:vibwav 1.8s ease-in-out infinite}
.vib-body{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:18px}
.vib-left{display:flex;flex-direction:column;gap:12px}
.vib-sel{font-size:12.5px;color:var(--ink-soft);text-align:center}
.vib-sel .bad-t{color:#FF5D6C;font-weight:700}
.vrms.bad b{color:#FF5D6C}
.vib-right{display:flex;flex-direction:column;gap:12px}
.diag-row{display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink-soft);padding:4px 0;border-top:1px solid rgba(255,255,255,.06)}
.diag-row b{color:var(--ink)}
.bad-t{color:#FF5D6C}
.diag-act{margin-top:9px;font-size:12px;color:var(--ink-mid);background:var(--bg-deep);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;padding:8px 11px}
.diag-act b{color:var(--accent-dark)}
.vib-bars{display:flex;align-items:flex-end;gap:3px;height:70px}
.vib-bars i{flex:1;background:rgba(24,208,230,.45);border-radius:2px 2px 0 0}
.vib-bars i.pk{background:var(--accent)}
.vib-bars i.bd{background:#EBC062}
.fft-cap{font-size:11px;color:var(--ink-soft);margin-top:8px}
.fft-cap .bd-t{color:#EBC062}
.vib-fleet{padding:0 18px 4px}
.vf-h{font-size:13px;font-weight:700;color:var(--ink-mid);margin-bottom:10px;display:flex;align-items:center;gap:10px}
.vf-sum{margin-left:auto;font-size:11.5px;color:var(--ink-soft);font-weight:400;display:flex;align-items:center;gap:6px}
.vf-sum .d{width:9px;height:9px;border-radius:50%;display:inline-block;margin-left:8px}
.d.ok,.vf-row.ok .vf-dot{background:#5FDDA0}.d.warn,.vf-row.warn .vf-dot{background:#EBC062}.d.bad,.vf-row.bad .vf-dot{background:#FF5D6C}
.vf-row{display:grid;grid-template-columns:14px 1.4fr 64px 92px 56px 2fr;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);margin-bottom:6px;font-size:12.5px}
.vf-dot{width:9px;height:9px;border-radius:50%}
.vf-n{color:var(--ink);font-weight:600}
.vf-badge{font-size:11px;font-weight:800;text-align:center;border-radius:20px;padding:3px 0}
.vf-row.ok .vf-badge{background:rgba(95,221,160,.16);color:#5FDDA0}
.vf-row.warn .vf-badge{background:rgba(235,192,98,.18);color:#EBC062}
.vf-row.bad .vf-badge{background:rgba(255,93,108,.2);color:#FF5D6C}
.vf-rms{color:var(--ink-mid);font-weight:700}.vf-rms small{font-size:9.5px;color:var(--ink-faint);font-weight:400;margin-left:2px}
.vf-t{color:var(--ink-soft)}
.vf-note{color:var(--ink-soft)}
.vf-row.bad{border-color:rgba(255,93,108,.35)}
@media (max-width:820px){.vib-body{grid-template-columns:1fr}.vf-row{grid-template-columns:14px 1fr 70px;gap:8px}.vf-t,.vf-note,.vf-rms{display:none}}

/* ===== HVAC: sensor data + problem + action ===== */
.h2-warnbox{fill:rgba(235,192,98,.1);stroke:#EBC062;stroke-width:2;stroke-dasharray:5 4;animation:scblink 1.6s infinite}
.h2-line.warn path{stroke:#EBC062}
.h2-stage.warn-t{fill:#EBC062;font-weight:700}
.h2-node.warn circle{fill:#EBC062}
.h2-node.warn text{fill:#EBC062;font-weight:700}
.hvac2-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:14px 18px 4px}
.hsens{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px}
.hsens-h{font-size:12px;font-weight:700;color:var(--accent-dark);margin-bottom:10px}
.hsens-list{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.hsv{display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:8px 10px}
.hsv span{font-size:11.5px;color:var(--ink-soft)}
.hsv b{font-size:13px;color:var(--ink)}
.hsv.warn b{color:#EBC062}.hsv.bad b{color:#FF5D6C}
.hsv.bad{border-color:rgba(255,93,108,.35)}.hsv.warn{border-color:rgba(235,192,98,.3)}
.hdiag p b{color:#fff}
.hopt{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px}
@media (max-width:820px){.hvac2-grid{grid-template-columns:1fr}.hsens-list{grid-template-columns:1fr 1fr}}

/* ===== Vibration trend chart (pretty) ===== */
.vchart{width:100%}
.vchart svg{width:100%;height:auto;display:block}
.vc-danger{fill:rgba(255,93,108,.06)}
.vc-grid{stroke:rgba(255,255,255,.06);stroke-width:1}
.vc-yl{fill:var(--ink-faint);font-size:8.5px;text-anchor:end}
.vc-xl{fill:var(--ink-faint);font-size:8.5px;text-anchor:middle}
.vc-thr{stroke:#FF5D6C;stroke-width:1.2;stroke-dasharray:5 4;opacity:.7}
.vc-thrl{fill:#FF8A95;font-size:9px;text-anchor:end}
.vc-area{fill:url(#vcFill)}
.vc-line{fill:none;stroke:url(#vcLine);stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:560;stroke-dashoffset:560;animation:vcdraw 1.6s ease-out forwards}
@keyframes vcdraw{to{stroke-dashoffset:0}}
.vc-end{fill:#FF5D6C}
.vc-endring{fill:none;stroke:#FF5D6C;stroke-width:2;opacity:.6;transform-origin:center;animation:vcpulse 2s ease-out infinite}
@keyframes vcpulse{0%{r:5;opacity:.6}70%{r:13;opacity:0}100%{opacity:0}}
.vc-endv{fill:#FF8A95;font-size:11px;font-weight:800;text-anchor:end}

/* ===== Composite vibration chart (X/Y/Z · Hz · mm/s) ===== */
.vib2 svg{width:100%;height:auto;display:block}
.vc-sec{fill:var(--ink-soft);font-size:9px;font-weight:700}
.vc-axis{stroke:rgba(255,255,255,.18);stroke-width:1}
.vc-leg text{fill:var(--ink-mid);font-size:9px}
.vc-leg circle{fill:#FF7A85}.vc-leg .ly{fill:#46E2F2}.vc-leg .lz{fill:#5FDDA0}
.wv{fill:none;stroke-width:1.6;stroke-linejoin:round;stroke-linecap:round;opacity:.95}
.wv.x{stroke:#FF7A85}.wv.y{stroke:#46E2F2;opacity:.85}.wv.z{stroke:#5FDDA0;opacity:.7}
.ft{fill:none;stroke-width:1.8;stroke-linejoin:round;stroke-linecap:round}
.ft.x{stroke:#FF7A85}.ft.y{stroke:#46E2F2}.ft.z{stroke:#5FDDA0}
.ft-area{fill:rgba(255,122,133,.1)}
.vc-peak{stroke:rgba(255,122,133,.45);stroke-width:1;stroke-dasharray:3 3}
.vc-pk{fill:var(--ink-mid);font-size:8.5px;text-anchor:middle}
.vc-pk.bd{fill:#EBC062}
.vc-xunit{fill:var(--ink-faint);font-size:8.5px;text-anchor:end}

/* ===== Top merged spec block (무선/보안/배터리 + 프로토콜·인증) ===== */
.sol-spec{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.spec-col{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px 18px;display:flex;flex-direction:column}
.spec-h{display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:700;color:var(--ink);margin-bottom:12px}
.spec-ic{width:34px;height:34px;border-radius:9px;background:var(--accent-soft);color:var(--accent-dark);display:flex;align-items:center;justify-content:center}
.spec-ic svg{width:20px;height:20px}
.spec-rows{display:flex;flex-direction:column;gap:1px}
.sp{display:flex;justify-content:space-between;align-items:baseline;gap:10px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:12.5px}
.sp span{color:var(--ink-soft);flex:0 0 auto}
.sp b{color:var(--ink-mid);text-align:right}
.spec-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.spec-chips .proto{font-size:11px;padding:4px 9px}
.spec-chips .cert{font-size:11px;padding:3px 9px 3px 4px}
.spec-note{margin-top:14px;font-size:12px;line-height:1.6;color:var(--ink-faint)}
@media (max-width:860px){.sol-spec{grid-template-columns:1fr}}

/* ===== AI feature cards (enriched) ===== */
.ai-feat{display:flex;flex-direction:column;gap:0}
.aif-ic{width:40px;height:40px;border-radius:11px;background:var(--accent-soft);color:var(--accent-dark);display:flex;align-items:center;justify-content:center;margin-bottom:11px}
.aif-ic svg{width:23px;height:23px}
.ai-feat h4{margin:0 0 7px;font-size:14.5px}
.ai-feat p{margin:0 0 13px;font-size:12.5px;color:var(--ink-soft);line-height:1.55;flex:1 1 auto}
.aif-badge{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:800;letter-spacing:.02em;color:var(--accent-dark);background:var(--accent-soft);border-radius:20px;padding:4px 11px;align-self:flex-start;margin-bottom:0}
.aif-badge .d{width:7px;height:7px;border-radius:50%}
.aif-badge .d.ok{background:#5FDDA0}.aif-badge .d.warn{background:#EBC062}.aif-badge .d.acc{background:var(--accent)}

/* ===== Colorful icon tiles (de-monotone) ===== */
.ic-cyan{background:linear-gradient(135deg,#22D3EE,#0E8FB0);color:#fff}
.ic-blue{background:linear-gradient(135deg,#5B8DEF,#3358D4);color:#fff}
.ic-violet{background:linear-gradient(135deg,#A78BFA,#6D4AE0);color:#fff}
.ic-green{background:linear-gradient(135deg,#34D399,#129E6E);color:#fff}
.ic-amber{background:linear-gradient(135deg,#FBBF45,#E0871C);color:#fff}
.ic-pink{background:linear-gradient(135deg,#FB7BA8,#E04680);color:#fff}
.ic-red{background:linear-gradient(135deg,#FB7185,#E0344F);color:#fff}
.ic-teal{background:linear-gradient(135deg,#2DD4BF,#0E9E8E);color:#fff}
/* 아이콘 글리프 흰색 + 약한 그림자로 또렷하게 */
.spec-ic.ic-cyan,.spec-ic.ic-blue,.spec-ic.ic-violet,.spec-ic.ic-green,.spec-ic.ic-amber,.spec-ic.ic-pink,
.ai-lic.ic-cyan,.ai-lic.ic-blue,.ai-lic.ic-violet,.ai-lic.ic-green,
.aif-ic.ic-violet,.aif-ic.ic-amber,.aif-ic.ic-blue,.aif-ic.ic-pink,
.hmw-ico.ic-cyan,.hmw-ico.ic-blue,.hmw-ico.ic-violet{box-shadow:0 4px 14px rgba(0,0,0,.25)}
.prod-ico.ic-cyan,.prod-ico.ic-blue,.prod-ico.ic-violet,.prod-ico.ic-green,.prod-ico.ic-amber,.prod-ico.ic-pink,.prod-ico.ic-red,.prod-ico.ic-teal{border:0}
.prod-card:hover .prod-ico{filter:brightness(1.12) saturate(1.15)}
.hmw-ico svg{filter:none}

/* ===== AHU photo (from attachment) ===== */

/* ===== Tab hardening ===== */
.soldash-panel:not(.active){display:none!important}

/* ============================================================
   VIBRATION DASHBOARD — live dark PdM screen (.vibx)
   ============================================================ */
.vibx{
  --vx-card:#121B3F; --vx-card2:#0E1635; --vx-line:#26305C; --vx-screen:#0A1130;
  --vx-ink:#EBEEF9; --vx-mid:#A6AECE; --vx-soft:#79839F;
  --vx-ok:#3FD79A; --vx-ok-bg:rgba(63,215,154,.14); --vx-ok-d:#5FE3AE;
  --vx-warn:#F2B544; --vx-warn-bg:rgba(242,181,68,.15); --vx-warn-d:#F6C868;
  --vx-bad:#FF5D72; --vx-bad-bg:rgba(255,93,114,.15); --vx-bad-d:#FF8190;
  --vx-info:#6F9BF2; --vx-info-bg:rgba(111,155,242,.16);
  background:var(--vx-screen); padding:18px; display:flex; flex-direction:column; gap:14px;
  font-family:var(--fb); color:var(--vx-ink);
}
.vibx .vx-card{background:var(--vx-card);border:1px solid var(--vx-line);border-radius:16px;box-shadow:0 1px 2px rgba(0,0,0,.2),0 10px 28px rgba(0,0,0,.25)}
.vibx .vx-card-h{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:15px;font-weight:800;color:var(--vx-ink);padding:16px 18px 0;letter-spacing:-.01em}
.vibx .vx-card-h.tracked{letter-spacing:.18em;font-size:12px;color:var(--vx-soft);font-weight:800}
.vibx .vx-upd{font-size:11.5px;font-weight:700;color:var(--vx-soft);letter-spacing:0;display:inline-flex;align-items:center;gap:7px}
.vx-livedot{width:7px;height:7px;border-radius:50%;background:var(--vx-bad);box-shadow:0 0 0 0 rgba(255,93,114,.6);animation:vxpulse 1.6s infinite}

/* KPI strip */
.vx-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.vx-kpi{background:var(--vx-card);border:1px solid var(--vx-line);border-radius:18px;padding:15px 17px 16px;box-shadow:0 8px 22px rgba(0,0,0,.22)}
.vx-kpi.ok{background:linear-gradient(180deg,rgba(63,215,154,.12),var(--vx-card));border-color:rgba(63,215,154,.3)}
.vx-kpi.warn{background:linear-gradient(180deg,rgba(242,181,68,.12),var(--vx-card));border-color:rgba(242,181,68,.3)}
.vx-kpi.bad{background:linear-gradient(180deg,rgba(255,93,114,.13),var(--vx-card));border-color:rgba(255,93,114,.32)}
.vx-kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.vx-ic{width:36px;height:36px;border-radius:11px;display:grid;place-items:center}
.vx-ic svg{width:18px;height:18px}
.vx-ic.neutral{background:rgba(255,255,255,.06);color:#9AA4C4}
.vx-ic.ok{background:var(--vx-ok-bg);color:var(--vx-ok-d)}
.vx-ic.warn{background:var(--vx-warn-bg);color:var(--vx-warn-d)}
.vx-ic.bad{background:var(--vx-bad-bg);color:var(--vx-bad-d)}
.vx-tag{font-size:11.5px;font-weight:800;padding:5px 10px;border-radius:20px;background:rgba(255,255,255,.07);color:#9AA4C4}
.vx-tag.ok{background:var(--vx-ok-bg);color:var(--vx-ok-d)}
.vx-tag.warn{background:var(--vx-warn-bg);color:var(--vx-warn-d)}
.vx-tag.bad{background:var(--vx-bad);color:#1A0A0E}
.vx-kpi-l{font-size:13px;color:var(--vx-mid);font-weight:600;margin-bottom:2px}
.vx-kpi-n{font-family:var(--fd);font-size:32px;font-weight:800;line-height:1;letter-spacing:-.02em;color:#fff}

/* HERO */
.vx-hero{display:grid;grid-template-columns:1.55fr 1fr;gap:14px;align-items:stretch}
.vx-asset{display:flex;flex-direction:column}
.vx-asset-h{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 4px}
.vx-asset-t{font-size:21px;font-weight:800;letter-spacing:-.02em}
.vx-asset-s{font-size:12.5px;color:var(--vx-soft);margin-top:2px}
.vx-asset-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.vx-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;letter-spacing:.04em;padding:6px 12px;border-radius:20px}
.vx-pill svg{width:15px;height:15px}
.vx-pill.bad{background:var(--vx-bad-bg);color:var(--vx-bad-d)}
.vx-id{font-family:var(--fm);font-size:12px;font-weight:600;color:var(--vx-mid);letter-spacing:.06em;padding:6px 12px;border:1px solid var(--vx-line);border-radius:20px;background:var(--vx-card2)}
.vx-stage{position:relative;margin:10px 16px 0;background:radial-gradient(120% 90% at 50% 30%,#152049,#0C1430);border:1px solid var(--vx-line);border-radius:14px;padding:8px 8px 84px;overflow:hidden}
.vx-motor{display:block;width:100%;height:auto}
.vx-dot circle{filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}
.vx-dot.bad circle{fill:var(--vx-bad)}
.vx-dot.warn circle{fill:var(--vx-warn)}
.vx-dot.ok circle{fill:var(--vx-ok)}
.vx-dot.bad:not(.sm){animation:vxglow 1.8s ease-out infinite}
@keyframes vxpulse{0%{box-shadow:0 0 0 0 rgba(255,93,114,.55)}70%{box-shadow:0 0 0 7px rgba(255,93,114,0)}100%{box-shadow:0 0 0 0 rgba(255,93,114,0)}}
@keyframes vxglow{0%{filter:drop-shadow(0 0 0 rgba(255,93,114,.6))}70%{filter:drop-shadow(0 0 13px rgba(255,93,114,0))}100%{filter:drop-shadow(0 0 0 rgba(255,93,114,0))}}
.vx-live{position:absolute;left:14px;right:14px;bottom:14px;background:rgba(20,28,60,.92);backdrop-filter:blur(4px);border:1px solid var(--vx-line);border-radius:14px;box-shadow:0 12px 28px rgba(0,0,0,.4);display:flex;align-items:center;gap:14px;padding:13px 16px}
.vx-live-ic{width:42px;height:42px;border-radius:12px;background:var(--vx-ok-bg);color:var(--vx-ok-d);display:grid;place-items:center;flex:none}
.vx-live-ic svg{width:22px;height:22px}
.vx-live-id b{display:block;font-size:14.5px;font-weight:800}
.vx-live-id small{font-size:12px;color:var(--vx-soft)}
.vx-live-v{margin-left:auto;text-align:right}
.vx-live-v b{font-family:var(--fd);font-size:26px;font-weight:800;letter-spacing:-.02em;color:#fff}
.vx-live-v b .u{font-size:14px;color:var(--vx-mid);font-weight:700}
.vx-live-v #vxLiveVal{display:inline-block;min-width:62px;transition:color .25s}
.vx-live-v small{display:block;font-size:10.5px;letter-spacing:.18em;color:var(--vx-soft);font-weight:700}
.vx-elec{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:16px}
.vx-el{background:var(--vx-card2);border:1px solid var(--vx-line);border-radius:12px;padding:11px 13px}
.vx-el span{font-size:11.5px;color:var(--vx-soft);font-weight:600}
.vx-el b{display:block;font-family:var(--fd);font-size:18px;font-weight:800;margin-top:3px;letter-spacing:-.01em;color:#fff}
.vx-el b i{font-size:11px;color:var(--vx-mid);font-weight:600;font-style:normal}
.vx-el b span{display:inline-block;min-width:54px}

/* 진단 (merged ISO + risk + faults) */
.vx-diag{display:flex;flex-direction:column;padding-bottom:16px}
.vx-seg{display:flex;background:rgba(255,255,255,.06);border-radius:10px;padding:3px}
.vx-seg button{border:0;background:none;color:var(--vx-soft);font-size:12px;font-weight:700;padding:5px 11px;border-radius:8px;cursor:pointer}
.vx-seg button.active{background:#EDEFF7;color:#0E1530}
.vx-diag-top{display:flex;align-items:center;gap:14px;padding:10px 18px 6px}
.vx-donut-wrap{display:grid;place-items:center;flex:none}
.vx-donut{width:128px;height:128px}
.vx-donut-c{font-family:var(--fd);font-size:30px;font-weight:800;fill:#fff}
.vx-donut-cl{font-size:9px;font-weight:700;letter-spacing:.1em;fill:var(--vx-soft)}
.vx-diag-side{flex:1;min-width:0}
.vx-diag-risk{display:flex;flex-direction:column;gap:1px;margin-bottom:14px}
.vx-diag-risk span{font-size:12px;color:var(--vx-soft);font-weight:600}
.vx-diag-risk b{font-family:var(--fd);font-size:30px;font-weight:800;color:var(--vx-bad-d);letter-spacing:-.02em;line-height:1}
.vx-iso-leg{display:flex;flex-direction:column;gap:8px}
.vx-iso-leg div{font-size:12px;font-weight:700;color:var(--vx-mid);display:flex;align-items:center;gap:8px}
.vx-iso-leg div span{width:9px;height:9px;border-radius:50%;flex:none}
.vx-iso-leg b{font-family:var(--fd);font-size:15px;color:#fff;margin-left:auto}
.vx-iso-leg .ok{background:var(--vx-ok)}.vx-iso-leg .warn{background:var(--vx-warn)}.vx-iso-leg .bad{background:var(--vx-bad)}
.vx-faults{display:flex;flex-direction:column;gap:11px;padding:8px 18px 4px}
.vx-fl-t{display:flex;justify-content:space-between;font-size:12.5px;font-weight:700;margin-bottom:6px}
.vx-fl-t b{font-family:var(--fd);font-weight:800;color:#fff}
.vx-fl-bar{height:6px;border-radius:6px;background:rgba(255,255,255,.07);overflow:hidden}
.vx-fl-bar i{display:block;height:100%;border-radius:6px}
.vx-fl-bar i.bad{background:var(--vx-bad)}.vx-fl-bar i.warn{background:var(--vx-warn)}.vx-fl-bar i.ok{background:var(--vx-ok)}
.vx-iso-btn{margin:14px 18px 0;background:#EDEFF7;color:#0E1530;border:0;border-radius:12px;padding:13px;font-size:13.5px;font-weight:800;cursor:pointer;transition:background .15s}
.vx-iso-btn:hover{background:#fff}

/* timeline + live chart */
.vx-tl-rows{display:flex;flex-direction:column;gap:9px;padding:16px 20px 4px}
.vx-tlr{display:flex;align-items:center;gap:14px}
.vx-tlr-l{width:48px;font-size:12.5px;font-weight:800;flex:none}
.vx-tlr.bad .vx-tlr-l{color:var(--vx-bad-d)}
.vx-tlr.warn .vx-tlr-l{color:var(--vx-warn-d)}
.vx-tlr.ok .vx-tlr-l{color:var(--vx-ok-d)}
.vx-tlr.learn .vx-tlr-l{color:var(--vx-info)}
.vx-tlr-track{position:relative;flex:1;height:11px;border-radius:8px;background:rgba(255,255,255,.06)}
.vx-tlr-track i{position:absolute;top:0;bottom:0;border-radius:8px}
.vx-tlr.bad i{background:var(--vx-bad)}.vx-tlr.warn i{background:var(--vx-warn)}.vx-tlr.ok i{background:var(--vx-ok)}.vx-tlr.learn i{background:var(--vx-info)}
.vx-tlr-m{position:absolute;left:-6px;top:50%;transform:translateY(-50%);width:14px;height:14px;border-radius:50%;background:#0E1635;border:3px solid currentColor;box-shadow:0 2px 5px rgba(0,0,0,.4)}
.vx-tlr.bad .vx-tlr-m{color:var(--vx-bad)}.vx-tlr.warn .vx-tlr-m{color:var(--vx-warn)}.vx-tlr.ok .vx-tlr-m{color:var(--vx-ok)}.vx-tlr.learn .vx-tlr-m{color:var(--vx-info)}
.vx-chart-leg{display:flex;flex-wrap:wrap;gap:16px;padding:12px 20px 0}
.vx-chart-leg span{font-size:11px;font-weight:700;color:var(--vx-mid);display:inline-flex;align-items:center;gap:7px}
.vx-chart-leg span::before{content:"";width:9px;height:9px;border-radius:50%}
.vx-chart-leg .s1::before{background:#9B8CFF}.vx-chart-leg .s2::before{background:#FF6FA6}
.vx-chart-leg .s3::before{background:#6F9BF2}.vx-chart-leg .s4::before{background:#8A93B5}
.vx-chart{padding:6px 12px 16px}
.vx-chart svg{width:100%;height:200px;display:block}
.vx-chart-yl{font-size:11px;font-weight:800;letter-spacing:.14em;fill:var(--vx-soft)}
.vx-grid{stroke:rgba(255,255,255,.07);stroke-width:1}
.vx-sp{fill:none;stroke-width:1.7;stroke-linecap:round;vector-effect:non-scaling-stroke;opacity:.9}
.vx-sp.s1{stroke:#9B8CFF}.vx-sp.s2{stroke:#FF6FA6}.vx-sp.s3{stroke:#6F9BF2}.vx-sp.s4{stroke:#8A93B5;opacity:.65}

/* alerts | fleet */
.vx-mid2{display:grid;grid-template-columns:.85fr 1.15fr;gap:14px;align-items:start}
.vx-alerts{padding-bottom:16px}
.vx-al{margin:12px 16px 0;background:var(--vx-card2);border:1px solid var(--vx-line);border-left-width:4px;border-radius:12px;padding:12px 14px}
.vx-al.bad{border-left-color:var(--vx-bad)}
.vx-al.warn{border-left-color:var(--vx-warn)}
.vx-al.info{border-left-color:var(--vx-info)}
.vx-al-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.vx-al-ic{width:24px;height:24px;border-radius:8px;display:grid;place-items:center}
.vx-al-ic svg{width:15px;height:15px}
.vx-al.bad .vx-al-ic{background:var(--vx-bad-bg);color:var(--vx-bad-d)}
.vx-al.warn .vx-al-ic{background:var(--vx-warn-bg);color:var(--vx-warn-d)}
.vx-al.info .vx-al-ic{background:var(--vx-info-bg);color:var(--vx-info)}
.vx-al-top b{font-size:12px;font-weight:800;letter-spacing:.12em}
.vx-al-top em{margin-left:auto;font-style:normal;font-size:11.5px;color:var(--vx-soft);font-weight:600}
.vx-al-t{font-size:14.5px;font-weight:800}
.vx-al-as{font-size:12.5px;font-weight:700;color:var(--vx-mid);margin-top:1px}
.vx-al-d{font-size:12px;color:var(--vx-soft);line-height:1.5;margin-top:6px}

.vx-fleet{padding-bottom:6px}
.vx-ftable{padding:14px 16px 16px;display:flex;flex-direction:column;gap:8px}
.vx-fleet-sum{display:flex;gap:14px;font-size:12px;font-weight:700;color:var(--vx-mid);letter-spacing:0}
.vx-fleet-sum i{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:middle}
.vx-fleet-sum i.ok{background:var(--vx-ok)}.vx-fleet-sum i.warn{background:var(--vx-warn)}.vx-fleet-sum i.bad{background:var(--vx-bad)}
.vx-fr{display:grid;grid-template-columns:12px 1.2fr 70px 96px 52px;align-items:center;gap:12px;padding:12px 16px;border:1px solid var(--vx-line);border-radius:12px;background:var(--vx-card2)}
.vx-fr.bad{border-color:rgba(255,93,114,.35);background:rgba(255,93,114,.08)}
.vx-fd{width:10px;height:10px;border-radius:50%}
.vx-fr.bad .vx-fd{background:var(--vx-bad)}.vx-fr.warn .vx-fd{background:var(--vx-warn)}.vx-fr.ok .vx-fd{background:var(--vx-ok)}
.vx-fn{font-size:14px;font-weight:800}
.vx-fb{font-size:11.5px;font-weight:800;text-align:center;padding:5px 0;border-radius:20px}
.vx-fb.bad{background:var(--vx-bad-bg);color:var(--vx-bad-d)}.vx-fb.warn{background:var(--vx-warn-bg);color:var(--vx-warn-d)}.vx-fb.ok{background:var(--vx-ok-bg);color:var(--vx-ok-d)}
.vx-frms{font-family:var(--fd);font-size:18px;font-weight:800;color:#fff}
.vx-frms small{font-size:11px;color:var(--vx-soft);font-weight:600;margin-left:3px}
.vx-ft{font-size:13.5px;font-weight:700;color:var(--vx-mid);text-align:right}

@media (max-width:900px){
  .vx-kpis{grid-template-columns:1fr 1fr}
  .vx-hero,.vx-mid2{grid-template-columns:1fr}
}
@media (max-width:620px){
  .vibx{padding:12px}
  .vx-elec{grid-template-columns:1fr 1fr}
  .vx-diag-top{flex-direction:column;text-align:center}
  .vx-diag-side{width:100%}
}
@media (prefers-reduced-motion:reduce){
  .vx-dot.bad:not(.sm),.vx-livedot{animation:none!important}
}


/* ============================================================
   HVAC — AHU schematic (replaces stock photo), dark theme
   ============================================================ */
.ahu-schem{margin:14px 16px 0;background:var(--bg-deep);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px 10px 6px}
.ahu-schem svg{width:100%;height:auto;display:block}
.as-case{fill:rgba(120,160,255,.04);stroke:rgba(120,160,255,.22);stroke-width:1.6}
.as-sep{stroke:rgba(255,255,255,.1);stroke-width:1.3}
.as-room{fill:rgba(95,221,160,.06);stroke:rgba(95,221,160,.32);stroke-width:1.6}
.as-flow{fill:none;stroke:rgba(24,208,230,.5);stroke-width:2.4;stroke-dasharray:6 9;stroke-linecap:round;animation:asflow 1s linear infinite}
@keyframes asflow{to{stroke-dashoffset:-15}}
.as-ret{fill:none;stroke:rgba(255,255,255,.16);stroke-width:1.5;stroke-dasharray:5 6}
.as-arrow{stroke:var(--ink-soft);stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.as-arrow.sa{stroke:#5FDDA0}
.as-damper{stroke:var(--ink-soft);stroke-width:2.4;stroke-linecap:round}
.as-filter{fill:none}
.as-filter rect{fill:rgba(235,192,98,.05);stroke:rgba(235,192,98,.45);stroke-width:1.6}
.as-filter path{stroke:rgba(235,192,98,.45);stroke-width:1.2}
.as-warn circle{fill:#EBC062;animation:aswarn 1.6s ease-in-out infinite}
@keyframes aswarn{0%,100%{opacity:1}50%{opacity:.45}}
.as-coil{fill:none;stroke-width:2.6;stroke-linecap:round}
.as-coil.cool{stroke:#5BA8FF}
.as-coil.heat{stroke:#FF8A6B;opacity:.55}
.as-fan-r{fill:rgba(24,208,230,.06);stroke:rgba(24,208,230,.3);stroke-width:1.6}
.as-fan{transform-origin:635px 124px;animation:asspin 2.4s linear infinite}
.as-fan path{fill:rgba(24,208,230,.65)}
.as-fan-hub{fill:var(--accent)}
@keyframes asspin{to{transform:rotate(360deg)}}
.as-stage{fill:var(--ink-mid);font-size:13px;text-anchor:middle;font-weight:700}
.as-stage.warn,.as-mini.warn{fill:#EBC062}
.as-stage.warn2,.as-mini.warn2{fill:#FFAE8C}
.as-mini{fill:var(--ink-faint);font-size:11.5px;text-anchor:middle}
.as-mini.cool{fill:#7FBCFF}
.as-lab{fill:var(--ink-soft);font-size:12px;text-anchor:start;font-weight:600}
.as-lab.sa{fill:#5FDDA0}
.as-val{font-size:15px;font-weight:800;text-anchor:start}
.as-val.cool{fill:#7FBCFF}.as-val.warm{fill:#FFAE8C}
.as-flab{fill:var(--ink-soft);font-size:11.5px;text-anchor:middle;font-weight:600}
.as-room-l{fill:var(--ink-mid);font-size:13px;text-anchor:middle;font-weight:700}
.as-room-v{fill:#5FDDA0;font-size:12.5px;text-anchor:middle;font-weight:700}
.ahu-schem-cap{text-align:center;font-size:11.5px;color:var(--ink-soft);padding:6px 8px 4px}
@media (prefers-reduced-motion:reduce){
  .as-flow,.as-warn circle,.as-fan,.vx-dot.bad:not(.sm){animation:none!important}
}
