/* Ant Biotech — Corporate Site
 * Brand: ANT Biyoteknoloji A.Ş. · Brand Book v2026
 * Aesthetic: refined editorial-clinical, IFU-derived voice
 * No gradients, no emoji, no marketing flash. Numbers do the talking.
 */

/* ── Fonts ──────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;900&family=Oswald:wght@300;400;500;600;700&display=swap');

/* ── Design tokens (brand book) ─────────────────────────────────────── */
:root {
  /* Solar Ember — master accent */
  --ember-50:   #fef3e9;
  --ember-100:  #ffd9bc;
  --ember-200:  #ffb073;
  --ember-500:  #f77614;   /* Brand master — CTA, eyebrow, divider */
  --ember-600:  #d4881a;
  --ember-700:  #a85a08;   /* Hover/active */

  /* Axiom Teal — secondary */
  --teal-50:    #f0f5f7;
  --teal-100:   #cce0e6;
  --teal-500:   #005d71;   /* Headings, links */
  --teal-700:   #003e4d;   /* Footer, dark hero */

  /* Soft Warm Sand — borders */
  --sand-50:    #faf6f1;
  --sand-100:   #f0e8df;
  --sand-200:   #e6d2c2;
  --sand-300:   #d4b89f;

  /* Warm Graphite — text */
  --graphite-100: #e8e8e8;
  --graphite-300: #aaaaaa;
  --graphite-500: #888888;
  --graphite-700: #4a4a4a;
  --graphite-900: #1a1a1a;

  /* Surfaces */
  --cream:      #fafaf6;   /* Page background — never pure white */
  --white:      #ffffff;   /* Cards/panels only */
  --sage:       #7fa8a3;   /* Tagline italic accent */

  /* Typography */
  --font-master:  'Poppins', -apple-system, sans-serif;
  --font-display: 'Oswald', 'Poppins', sans-serif;

  /* Type scale — 1.250 ratio, 16px base */
  --text-xs:    11px;
  --text-sm:    13px;
  --text-base:  16px;
  --text-md:    19px;     /* lead paragraph */
  --text-lg:    24px;
  --text-xl:    32px;     /* h3 */
  --text-2xl:   40px;     /* h2 */
  --text-3xl:   56px;     /* h1 */
  --text-4xl:   72px;     /* hero numerals */

  /* Spacing — 8pt grid */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;

  /* Radii */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-pill: 999px;

  /* Shadows — warm-tinted, never neutral grey */
  --shadow-xs: 0 1px 2px rgba(74, 42, 18, 0.04);
  --shadow-sm: 0 2px 8px rgba(74, 42, 18, 0.06);
  --shadow-md: 0 6px 20px rgba(74, 42, 18, 0.08);
  --shadow-lg: 0 16px 40px rgba(74, 42, 18, 0.10);
  --shadow-ember: 0 6px 18px rgba(247, 118, 20, 0.18);

  /* Layout */
  --content-max: 1200px;
  --prose-max:    760px;
  --header-h:     120px;

  /* Easing */
  --ease-out: cubic-bezier(0.2, 0.8, 0.2, 1);
  --duration: 200ms;
}

/* ── Base ───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-master);
  font-weight: 400;
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--graphite-700);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, svg { display: block; max-width: 100%; }
a { color: var(--teal-500); text-decoration: none; transition: color var(--duration) var(--ease-out); }
a:hover { color: var(--ember-500); }
button { font-family: inherit; cursor: pointer; }

/* ── Typography classes ─────────────────────────────────────────────── */
h1, h2, h3, h4 { font-family: var(--font-master); color: var(--graphite-900); margin: 0; line-height: 1.15; letter-spacing: -0.01em; }
h1 { font-size: var(--text-3xl); font-weight: 600; }
h2 { font-size: var(--text-2xl); font-weight: 600; }
h3 { font-size: var(--text-xl); font-weight: 500; }
h4 { font-size: var(--text-lg); font-weight: 500; }
p  { margin: 0 0 var(--space-4); }
.lead { font-size: var(--text-md); line-height: 1.55; color: var(--graphite-700); }

.eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ember-500);
  margin-bottom: var(--space-4);
}
.numeral { font-family: var(--font-display); font-weight: 500; font-feature-settings: 'tnum' 1; }
.italic-tag { font-style: italic; color: var(--sage); }

/* The IFU dot separator — only Unicode glyph allowed */
.dot-sep { color: var(--graphite-300); margin: 0 var(--space-2); }

/* ── Layout primitives ──────────────────────────────────────────────── */
.container { max-width: var(--content-max); margin: 0 auto; padding: 0 var(--space-5); }
.prose     { max-width: var(--prose-max); margin: 0 auto; padding: 0 var(--space-5); }
.section   { padding: var(--space-9) 0; }
.section-sm { padding: var(--space-7) 0; }

/* Section dividers — 3pt Solar Ember bar (lifted from IFU template) */
.divider-ember { height: 3px; background: var(--ember-500); width: 64px; margin: 0 0 var(--space-5); border: none; }

/* Background bands */
.band-cream { background: var(--cream); }
.band-sand  { background: var(--sand-50); border-top: 1px solid var(--sand-200); border-bottom: 1px solid var(--sand-200); }
.band-dark  { background: var(--teal-700); color: var(--cream); }
.band-dark h1, .band-dark h2, .band-dark h3 { color: var(--white); }
.band-dark .eyebrow { color: var(--ember-200); }
.band-dark a { color: var(--ember-200); }
.band-dark a:hover { color: var(--ember-100); }

/* ── Header ─────────────────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(250, 250, 246, 0.85);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 0.5px solid var(--sand-200);
  height: var(--header-h);
}
.site-header__inner {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 var(--space-5);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}
.site-header__brand img { height: 96px; width: auto; }
.site-nav { display: flex; gap: var(--space-6); align-items: center; }
.site-nav a {
  font-size: var(--text-sm);
  color: var(--graphite-700);
  font-weight: 500;
  letter-spacing: 0.01em;
  padding: var(--space-2) 0;
  border-bottom: 2px solid transparent;
}
.site-nav a:hover, .site-nav a[aria-current="page"] {
  color: var(--ember-500);
  border-bottom-color: var(--ember-500);
}
.lang-toggle {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--graphite-500);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-sm);
  background: transparent;
}

/* Dropdown menu (Ürünler kategorileri) */
.has-dropdown { position: relative; }
.has-dropdown__trigger {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--text-sm);
  color: var(--graphite-700);
  font-weight: 500;
  padding: var(--space-2) 0;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: color var(--duration) var(--ease-out);
}
.has-dropdown:hover .has-dropdown__trigger,
.has-dropdown:focus-within .has-dropdown__trigger {
  color: var(--ember-500);
  border-bottom-color: var(--ember-500);
}
.has-dropdown__caret {
  display: inline-block;
  font-size: 9px;
  transition: transform var(--duration) var(--ease-out);
}
.has-dropdown:hover .has-dropdown__caret { transform: rotate(180deg); }
.has-dropdown__menu {
  position: absolute;
  top: 100%; left: -8px;
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: var(--space-2);
  min-width: 260px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all 200ms var(--ease-out);
  z-index: 100;
  margin-top: var(--space-1);
}
.has-dropdown:hover .has-dropdown__menu,
.has-dropdown:focus-within .has-dropdown__menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.has-dropdown__menu a {
  display: block;
  padding: var(--space-3) var(--space-3);
  font-size: var(--text-sm);
  color: var(--graphite-700) !important;
  border-bottom: none !important;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  transition: all var(--duration) var(--ease-out);
}
.has-dropdown__menu a:hover {
  background: var(--ember-50);
  color: var(--ember-700) !important;
}
.has-dropdown__menu .menu-sub {
  font-size: 11px;
  color: var(--graphite-500);
  margin-left: var(--space-2);
  font-weight: 400;
}

/* ── Buttons ────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-master);
  font-size: var(--text-sm);
  font-weight: 500;
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  text-decoration: none;
  transition: all var(--duration) var(--ease-out);
  white-space: nowrap;
}
.btn-primary {
  background: var(--ember-500);
  color: var(--white);
  box-shadow: var(--shadow-ember);
}
.btn-primary:hover { background: var(--ember-700); color: var(--white); transform: translateY(-1px); box-shadow: 0 8px 22px rgba(247, 118, 20, 0.28); }
.btn-primary:active { transform: translateY(0); box-shadow: var(--shadow-sm); }
.btn-ghost {
  background: transparent;
  color: var(--teal-500);
  border-color: var(--teal-500);
}
.btn-ghost:hover { background: var(--teal-500); color: var(--white); }
.btn-lg { font-size: var(--text-base); padding: var(--space-4) var(--space-6); }

.arrow-r::after { content: '→'; font-family: var(--font-display); transform: translateY(-1px); }

/* ── Hero ───────────────────────────────────────────────────────────── */
.hero {
  padding: var(--space-9) 0 var(--space-10);
  position: relative;
  overflow: hidden;
}
.hero__pattern {
  position: absolute;
  top: -40px;
  right: -120px;
  width: 540px;
  opacity: 0.10;
  pointer-events: none;
  z-index: 0;
}
.hero__inner { position: relative; z-index: 1; }
/* Üst-eyebrow — IFU sayfa 1 stilindeki "UNİQPLEX" küçük başlık karşılığı */
.hero__upbrow {
  font-family: var(--font-display);
  font-size: var(--text-md);
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ember-500);
  margin-bottom: var(--space-3);
}
.hero__title {
  font-size: clamp(48px, 7vw, 88px);
  line-height: 1;
  letter-spacing: -0.025em;
  font-weight: 700;
  color: var(--graphite-900);
  margin: 0 0 var(--space-3);
}
.hero__tagline {
  font-family: var(--font-master);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--sage);
  font-weight: 400;
  margin-bottom: var(--space-5);
  letter-spacing: -0.005em;
}
.hero__lead {
  font-size: var(--text-md);
  line-height: 1.55;
  color: var(--graphite-700);
  max-width: 640px;
  margin-bottom: var(--space-6);
}
.hero__ctas { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-bottom: var(--space-8); }
.hero__kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); max-width: 700px; }
.hero__kpi { border-top: 3px solid var(--ember-500); padding-top: var(--space-3); }
.hero__kpi-num { font-size: var(--text-3xl); font-weight: 500; color: var(--teal-500); display: block; line-height: 1; }
.hero__kpi-lbl { font-size: var(--text-xs); color: var(--graphite-500); text-transform: uppercase; letter-spacing: 0.10em; margin-top: var(--space-2); display: block; }

/* ── Plate Editor Animation ─────────────────────────────────────────── */
.plate-anim-wrap {
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  margin: var(--space-6) auto;
  max-width: 980px;
}
.plate-anim-chrome {
  background: var(--cream);
  border-bottom: 1px solid var(--sand-200);
  padding: var(--space-3) var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  color: var(--graphite-500);
}
.plate-anim-chrome .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ember-500); }
.plate-anim-chrome strong { color: var(--graphite-900); font-weight: 600; }
.plate-anim-chrome .badge-prod {
  margin-left: auto;
  background: var(--ember-500); color: var(--white);
  padding: 2px 8px; border-radius: var(--radius-sm);
  font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase;
}
.plate-anim-body {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-4);
  padding: var(--space-4);
}
.plate-anim-panels {
  display: flex; flex-direction: column; gap: var(--space-2);
}
.plate-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: repeat(8, 1fr);
  grid-auto-flow: column;
  gap: 3px;
  padding: var(--space-2);
  background: var(--cream);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-sm);
  max-width: 640px;
}
.panel-card {
  border: 1px solid var(--sand-200);
  background: var(--white);
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  transition: all 0.4s var(--ease-out);
}
.panel-card strong { display: block; color: var(--graphite-900); font-weight: 600; margin-bottom: 2px; font-size: var(--text-sm); }
.panel-card span { color: var(--graphite-500); }
.panel-card[data-kit="rsp"] { animation: panel-hl-rsp 16s infinite; }
.panel-card[data-kit="gi"]  { animation: panel-hl-gi  16s infinite; }
.panel-card[data-kit="mng"] { animation: panel-hl-mng 16s infinite; }
.panel-card[data-kit="std"] { animation: panel-hl-std 16s infinite; }
@keyframes panel-hl-rsp {
  0%, 4%, 22%, 100% { border-color: var(--sand-200); background: var(--white); box-shadow: none; }
  8%, 18% { border-color: #f77614; background: #fef3e9; box-shadow: 0 4px 12px rgba(247,118,20,0.12); }
}
@keyframes panel-hl-gi {
  0%, 23%, 41%, 100% { border-color: var(--sand-200); background: var(--white); box-shadow: none; }
  27%, 37% { border-color: #1D9E75; background: #e8f5f0; box-shadow: 0 4px 12px rgba(29,158,117,0.12); }
}
@keyframes panel-hl-mng {
  0%, 42%, 60%, 100% { border-color: var(--sand-200); background: var(--white); box-shadow: none; }
  46%, 56% { border-color: #C04030; background: #fbeae6; box-shadow: 0 4px 12px rgba(192,64,48,0.12); }
}
@keyframes panel-hl-std {
  0%, 61%, 79%, 100% { border-color: var(--sand-200); background: var(--white); box-shadow: none; }
  65%, 75% { border-color: #534AB7; background: #eeedfe; box-shadow: 0 4px 12px rgba(83,74,183,0.12); }
}

.plate-grid-wrap { display: flex; flex-direction: column; gap: var(--space-3); }
.plate-grid-label { font-size: 10px; color: var(--graphite-500); letter-spacing: 0.10em; text-transform: uppercase; }
.plate-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: repeat(8, 1fr);
  grid-auto-flow: column;          /* HTML sırası kolon kolon */
  gap: 4px;
  padding: var(--space-3);
  background: var(--cream);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-sm);
}
.anim-well {
  aspect-ratio: 1;
  border-radius: 4px;
  border: 1px solid var(--sand-300);
  background: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 7px;
  letter-spacing: 0.02em;
  color: transparent;          /* başlangıçta gizli, animasyonla belirir */
  transition: none;
}
/* Kit bazlı fill — sıralı dolma, kolon yukarıdan aşağı cascade ile */
.anim-well[data-kit="rsp"] { animation: well-rsp 16s infinite; }
.anim-well[data-kit="gi"]  { animation: well-gi 16s infinite; }
.anim-well[data-kit="mng"] { animation: well-mng 16s infinite; }
.anim-well[data-kit="std"] { animation: well-std 16s infinite; }
@keyframes well-rsp {
  0%, 6% { background: var(--white); border-color: var(--sand-300); color: transparent; }
  10%, 90% { background: #ffd9bc; border-color: #f77614; color: #a85a08; }
  95%, 100% { background: var(--white); border-color: var(--sand-300); color: transparent; }
}
@keyframes well-gi {
  0%, 25% { background: var(--white); border-color: var(--sand-300); color: transparent; }
  29%, 90% { background: #c8e6dd; border-color: #1D9E75; color: #0d5e44; }
  95%, 100% { background: var(--white); border-color: var(--sand-300); color: transparent; }
}
@keyframes well-mng {
  0%, 44% { background: var(--white); border-color: var(--sand-300); color: transparent; }
  48%, 90% { background: #f5d1cc; border-color: #C04030; color: #7a2820; }
  95%, 100% { background: var(--white); border-color: var(--sand-300); color: transparent; }
}
@keyframes well-std {
  0%, 63% { background: var(--white); border-color: var(--sand-300); color: transparent; }
  67%, 90% { background: #d4d0f3; border-color: #534AB7; color: #2b2470; }
  95%, 100% { background: var(--white); border-color: var(--sand-300); color: transparent; }
}
/* Row bazlı cascade — A yukardan, H aşağıdan; her satır 80ms gecikme */
.anim-well[data-row="A"] { animation-delay: 0s; }
.anim-well[data-row="B"] { animation-delay: 0.08s; }
.anim-well[data-row="C"] { animation-delay: 0.16s; }
.anim-well[data-row="D"] { animation-delay: 0.24s; }
.anim-well[data-row="E"] { animation-delay: 0.32s; }
.anim-well[data-row="F"] { animation-delay: 0.40s; }
.anim-well[data-row="G"] { animation-delay: 0.48s; }
.anim-well[data-row="H"] { animation-delay: 0.56s; }

.plate-grid-status {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--text-xs);
  color: var(--graphite-500);
}
.plate-grid-status .pulse-btn {
  background: var(--ember-500);
  color: var(--white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 500;
  animation: btn-pulse 16s infinite;
}
@keyframes btn-pulse {
  0%, 78% { box-shadow: 0 0 0 0 rgba(247,118,20,0.5); transform: scale(1); }
  82% { box-shadow: 0 0 0 8px rgba(247,118,20,0); transform: scale(1.04); }
  86%, 100% { box-shadow: 0 0 0 0 rgba(247,118,20,0); transform: scale(1); }
}
.plate-anim-result {
  border-top: 1px solid var(--sand-200);
  padding: var(--space-3) var(--space-5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
  font-size: var(--text-xs);
  color: var(--graphite-500);
  opacity: 0;
  animation: result-fade 16s infinite;
}
@keyframes result-fade {
  0%, 86% { opacity: 0; transform: translateY(8px); }
  90%, 97% { opacity: 1; transform: translateY(0); }
  100% { opacity: 0; transform: translateY(8px); }
}
.plate-anim-result .badge-pos { background: var(--teal-50); color: var(--teal-700); border: 1px solid var(--teal-100); padding: 2px 8px; border-radius: var(--radius-pill); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; font-size: 10px; }
.plate-anim-result .badge-neg { background: var(--sand-100); color: var(--graphite-700); border: 1px solid var(--sand-200); padding: 2px 8px; border-radius: var(--radius-pill); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; font-size: 10px; }
.plate-anim-result svg { width: 100px; height: 32px; }

.plate-anim-caption {
  text-align: center;
  font-size: var(--text-xs);
  color: var(--graphite-500);
  font-style: italic;
  margin-top: var(--space-3);
}

@media (prefers-reduced-motion: reduce) {
  .panel-card, .anim-well, .pulse-btn, .plate-anim-result { animation: none !important; }
  .anim-well[data-kit="rsp"] { background: #ffd9bc; border-color: #f77614; color: #a85a08; }
  .anim-well[data-kit="gi"]  { background: #c8e6dd; border-color: #1D9E75; color: #0d5e44; }
  .anim-well[data-kit="mng"] { background: #f5d1cc; border-color: #C04030; color: #7a2820; }
  .anim-well[data-kit="std"] { background: #d4d0f3; border-color: #534AB7; color: #2b2470; }
  .plate-anim-result { opacity: 1; transform: none; }
}

/* ── Plate Result View (interaktif) ─────────────────────────────────── */
.plate-result-wrap {
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  margin: var(--space-6) 0;
}
.plate-result-body {
  display: grid;
  grid-template-columns: 180px 1fr 320px;
}
.plate-result-sidebar {
  padding: var(--space-4);
  border-right: 1px solid var(--sand-200);
  font-size: var(--text-xs);
  background: var(--cream);
}
.sidebar-section { margin-bottom: var(--space-5); }
.sidebar-section h4 {
  font-size: 10px;
  color: var(--graphite-500);
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-weight: 600;
  margin: 0 0 var(--space-2);
}
.sidebar-stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.sidebar-stat {
  background: var(--white);
  border: 0.5px solid var(--sand-200);
  border-radius: var(--radius-sm);
  padding: var(--space-2);
}
.sidebar-stat .num {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--graphite-900);
  line-height: 1;
}
.sidebar-stat .lbl {
  font-size: 10px;
  color: var(--graphite-500);
  margin-top: 2px;
}
.sidebar-stat.pos .num { color: #C04030; }
.sidebar-stat.neg .num { color: #1D9E75; }
.sidebar-coinf {
  font-size: 11px;
  color: var(--ember-700);
  background: var(--ember-50);
  border-left: 2px solid var(--ember-500);
  padding: var(--space-2) var(--space-3);
  margin-bottom: var(--space-4);
}
.sidebar-patogen-list {
  font-size: 11px;
}
.sidebar-patogen-row {
  display: flex;
  justify-content: space-between;
  padding: 4px 0;
  border-bottom: 0.5px solid var(--sand-200);
}
.sidebar-patogen-row:last-child { border-bottom: none; }
.sidebar-patogen-row .name { color: var(--graphite-700); }
.sidebar-patogen-row .count { font-family: var(--font-display); color: var(--graphite-500); }

.plate-result-center {
  padding: var(--space-4);
}
.legend-row {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  font-size: 10px;
  color: var(--graphite-700);
  margin-bottom: var(--space-3);
}
.legend-row .swatch {
  display: inline-block;
  width: 10px; height: 10px;
  border-radius: 2px;
  margin-right: 4px;
  vertical-align: middle;
}
.result-plate-grid {
  display: grid;
  grid-template-columns: 16px repeat(12, 1fr);
  grid-template-rows: 16px repeat(8, 1fr);
  gap: 3px;
}
.col-num {
  font-family: var(--font-display);
  font-size: 9px;
  color: var(--graphite-500);
  text-align: center;
}
.row-letter {
  font-family: var(--font-display);
  font-size: 10px;
  color: var(--graphite-500);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 500;
}
.result-well {
  aspect-ratio: 1;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 500;
  cursor: pointer;
  transition: transform 0.12s ease, box-shadow 0.12s ease, outline 0s;
  user-select: none;
  letter-spacing: 0;
}
.result-well:hover {
  transform: scale(1.10);
  z-index: 5;
  box-shadow: 0 4px 12px rgba(0,0,0,0.18);
  position: relative;
}
.result-well.selected {
  outline: 3px solid var(--graphite-900);
  outline-offset: 1px;
  transform: scale(1.05);
  z-index: 4;
  position: relative;
}
.result-well[data-status="pos"]      { background: #C04030; color: #fff; }
.result-well[data-status="pos-low"]  { background: #7A2820; color: #fff; }
.result-well[data-status="neg"]      { background: #1D9E75; color: #fff; }
.result-well[data-status="ic-warn"]  { background: #f77614; color: #fff; }
.result-well[data-status="border"]   { background: #f5c842; color: var(--graphite-900); }
.result-well[data-status="invalid"]  { background: #50130A; color: #fff; }
.result-well[data-status="ntc"]      { background: #888780; color: #fff; font-size: 8px; }
.result-well[data-status="pc"]       { background: #3C7FBF; color: #fff; font-size: 8px; }
.result-well[data-status="empty"]    { background: #fff; border: 1px solid var(--sand-300); color: transparent; cursor: default; }
.result-well[data-status="empty"]:hover { transform: none; box-shadow: none; }
.result-well[data-status="neg"]:not([data-well-id])     { cursor: default; }
.result-well[data-status="neg"]:not([data-well-id]):hover { transform: none; box-shadow: none; }
.plate-hint {
  font-size: 10px;
  color: var(--graphite-500);
  text-align: center;
  margin-top: var(--space-3);
  font-style: italic;
}
.plate-hint kbd {
  background: var(--sand-100);
  border: 1px solid var(--sand-300);
  border-radius: 3px;
  padding: 1px 5px;
  font-family: var(--font-display);
  font-size: 9px;
}

/* Detail panel */
.plate-result-detail {
  padding: var(--space-4);
  border-left: 1px solid var(--sand-200);
  background: var(--sand-50);
}
.detail-header {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--graphite-900);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--sand-200);
  font-family: var(--font-display);
  letter-spacing: 0.02em;
}
.detail-curve {
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-sm);
  padding: var(--space-2);
  margin-bottom: var(--space-3);
}
.detail-curve svg { width: 100%; height: auto; max-height: 140px; }
.detail-section { margin-bottom: var(--space-3); }
.detail-section-title {
  font-size: 10px;
  color: var(--graphite-500);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-2);
  font-weight: 600;
}
.detail-row {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  padding: 5px 0;
  border-bottom: 0.5px solid var(--sand-200);
}
.detail-row:last-child { border-bottom: none; }
.detail-row .key { color: var(--graphite-500); }
.detail-row .val { color: var(--graphite-900); font-family: var(--font-display); }
.detail-row .val.ic-valid { color: #0d5e44; }
.detail-row .val.ic-warn { color: #a85a08; }
.probe-list { display: flex; flex-direction: column; gap: var(--space-2); }
.probe-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 11px;
  padding: var(--space-2);
  background: var(--white);
  border: 0.5px solid var(--sand-200);
  border-radius: var(--radius-sm);
}
.probe-row .dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.probe-row .name { flex: 1; color: var(--graphite-900); }
.probe-row .ct { font-family: var(--font-display); color: var(--graphite-500); font-size: 10px; }
.probe-row .grade {
  font-family: var(--font-display); font-weight: 600;
  padding: 0 4px;
  color: var(--graphite-700);
}
.probe-row .badge-pos { background: #fbeae6; color: #7a2820; padding: 1px 6px; border-radius: var(--radius-pill); font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; }
.probe-row .badge-neg { background: #e8f5f0; color: #0d5e44; padding: 1px 6px; border-radius: var(--radius-pill); font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; }

@media (max-width: 900px) {
  .plate-result-body { grid-template-columns: 1fr; }
  .plate-result-sidebar, .plate-result-detail { border: none; border-bottom: 1px solid var(--sand-200); }
}

/* ── Tech grid (Uniqplex 7 differentiators) ─────────────────────────── */
.tech-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1px;                          /* hairline gutters */
  background: var(--sand-200);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.tech-cell {
  background: var(--white);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: background var(--duration) var(--ease-out);
}
.tech-cell:hover { background: var(--sand-50); }
.tech-cell__num {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.10em;
  color: var(--ember-500);
}
.tech-cell__title { font-size: var(--text-lg); font-weight: 500; color: var(--graphite-900); margin: 0; }
.tech-cell__body { font-size: var(--text-sm); line-height: 1.55; color: var(--graphite-700); margin: 0; }
.tech-cell__benefit {
  font-size: var(--text-xs);
  color: var(--teal-500);
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 0.5px solid var(--sand-200);
  letter-spacing: 0.02em;
}

/* ── Category cards (klinik kategoriler) ────────────────────────────── */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-4);
}
.cat-card {
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: all var(--duration) var(--ease-out);
  text-decoration: none;
  color: inherit;
}
.cat-card:hover {
  border-color: var(--ember-500);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
  color: inherit;
}
.cat-card svg { color: var(--ember-500); width: 28px; height: 28px; stroke-width: 1.5; }
.cat-card__title { font-size: var(--text-md); font-weight: 600; color: var(--teal-500); margin: 0; }
.cat-card__desc { font-size: var(--text-sm); color: var(--graphite-700); margin: 0; line-height: 1.5; }
.cat-card__count { font-size: var(--text-xs); color: var(--graphite-500); letter-spacing: 0.06em; text-transform: uppercase; margin-top: auto; padding-top: var(--space-3); }
.cat-card.featured {
  background: var(--teal-700);
  color: var(--cream);
  border-color: var(--teal-700);
  border-top: 3px solid var(--ember-500);
}
.cat-card.featured .cat-card__title { color: var(--white); }
.cat-card.featured .cat-card__desc { color: var(--teal-100); }
.cat-card.featured .cat-card__count { color: var(--ember-200); }
.cat-card.featured svg { color: var(--ember-200); }
.cat-card.featured:hover { transform: translateY(-2px); }

/* Coming soon kartları — pasif, ember kesikli border */
.cat-card.coming-soon {
  cursor: default;
  border-style: dashed;
  border-color: var(--ember-200);
  background: var(--ember-50);
  opacity: 0.85;
}
.cat-card.coming-soon:hover {
  transform: none;
  box-shadow: none;
  border-color: var(--ember-500);
  opacity: 1;
}
.cat-card.coming-soon .cat-card__title { color: var(--ember-700); }
.cat-card.coming-soon svg { color: var(--ember-500); opacity: 0.7; }
.cat-card.coming-soon .cat-card__count {
  color: var(--ember-700);
  font-weight: 600;
  letter-spacing: 0.10em;
}

/* ── Inline expand pattern (kit kartı içinde detay) ─────────────────── */
.kit-expand {
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
  overflow: hidden;
  transition: box-shadow var(--duration) var(--ease-out);
}
.kit-expand:hover { box-shadow: var(--shadow-md); }
.kit-expand.is-open { box-shadow: var(--shadow-md); border-color: var(--ember-200); }

.kit-expand__head {
  display: grid;
  grid-template-columns: 56px 1fr auto auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  cursor: pointer;
  user-select: none;
}
.kit-expand__icon {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  background: var(--ember-50);
  border-radius: var(--radius-md);
  color: var(--ember-500);
}
.kit-expand__icon svg { width: 28px; height: 28px; }
.kit-expand__title h3 {
  font-size: var(--text-md);
  margin: 0 0 4px;
  color: var(--graphite-900);
  font-weight: 600;
}
.kit-expand__title p {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--graphite-500);
  line-height: 1.45;
}
.kit-expand__ref {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  color: var(--graphite-500);
  background: var(--cream);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  border: 0.5px solid var(--sand-200);
  letter-spacing: 0.02em;
}
.kit-expand__caret {
  width: 32px; height: 32px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--graphite-500);
  transition: transform var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}
.kit-expand.is-open .kit-expand__caret { transform: rotate(180deg); background: var(--ember-50); color: var(--ember-500); }

.kit-expand__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s var(--ease-out);
  border-top: 0 solid var(--sand-200);
}
.kit-expand.is-open .kit-expand__body {
  max-height: 720px;
  border-top: 1px solid var(--sand-200);
}
.kit-expand__body-inner {
  padding: var(--space-5);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-6);
}
.kit-expand__targets {
  font-size: var(--text-xs);
}
.kit-expand__targets h4 {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--graphite-500);
  margin: 0 0 var(--space-3);
  font-weight: 600;
}
.kit-expand__targets table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
  table-layout: fixed;
}
.kit-expand__targets th:first-child,
.kit-expand__targets td:first-child { width: 9%; }
.kit-expand__targets th:not(:first-child),
.kit-expand__targets td:not(:first-child) { width: 18.2%; }
.kit-expand__targets td { word-wrap: break-word; overflow-wrap: anywhere; line-height: 1.35; }
.kit-expand__targets th {
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 600;
  text-align: left;
  padding: 6px 8px;
  color: var(--graphite-500);
  border-bottom: 1px solid var(--sand-200);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.kit-expand__targets td {
  padding: 6px 8px;
  border-bottom: 0.5px solid var(--sand-200);
  color: var(--graphite-700);
}
.kit-expand__targets td:first-child {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--ember-700);
  white-space: nowrap;
}
.kit-expand__targets tr:last-child td { border-bottom: none; }
.kit-expand__meta h4 {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--graphite-500);
  margin: 0 0 var(--space-3);
  font-weight: 600;
}
.kit-expand__meta dl {
  margin: 0;
  font-size: 11px;
}
.kit-expand__meta dt {
  color: var(--graphite-500);
  margin-bottom: 2px;
}
.kit-expand__meta dd {
  margin: 0 0 var(--space-3);
  color: var(--graphite-900);
  font-family: var(--font-display);
  font-weight: 500;
}
.kit-expand__meta dd:last-child { margin-bottom: 0; }
.kit-expand__actions {
  margin-top: var(--space-4);
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.kit-expand__actions .btn { font-size: var(--text-xs); padding: var(--space-2) var(--space-4); }

@media (max-width: 700px) {
  .kit-expand__head { grid-template-columns: 48px 1fr auto; gap: var(--space-3); padding: var(--space-3); }
  .kit-expand__icon { width: 48px; height: 48px; }
  .kit-expand__ref { display: none; }
  .kit-expand__body-inner { grid-template-columns: 1fr; gap: var(--space-4); padding: var(--space-4); }
}

/* ── Kit-simple: IFU detayı henüz hazır olmayan kitler için sade kart ── */
.kit-simple {
  display: grid;
  grid-template-columns: 56px 1fr auto auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
  transition: box-shadow var(--duration) var(--ease-out);
}
.kit-simple:hover { box-shadow: var(--shadow-sm); border-color: var(--sand-300); }
.kit-simple__icon {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  background: var(--cream);
  border-radius: var(--radius-md);
  color: var(--graphite-500);
}
.kit-simple__icon svg { width: 24px; height: 24px; }
.kit-simple__body h3 {
  font-size: var(--text-md);
  margin: 0 0 4px;
  color: var(--graphite-900);
  font-weight: 600;
}
.kit-simple__body p {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--graphite-500);
  line-height: 1.45;
}
.kit-simple__ref {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  color: var(--graphite-500);
  background: var(--cream);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  border: 0.5px solid var(--sand-200);
  letter-spacing: 0.02em;
}
.kit-simple__chip {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  color: var(--graphite-500);
  background: var(--cream);
  border: 0.5px solid var(--sand-200);
}
@media (max-width: 700px) {
  .kit-simple { grid-template-columns: 48px 1fr; gap: var(--space-3); padding: var(--space-3); }
  .kit-simple__icon { width: 48px; height: 48px; }
  .kit-simple__ref, .kit-simple__chip { display: none; }
}

/* ── UMS Özellikler altı 2-blok consolidasyonu ──────────────────────── */
.features-extras {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-7);
  margin-top: var(--space-8);
  padding-top: var(--space-7);
  border-top: 1px solid var(--sand-200);
}
.features-extras__block h3 {
  font-size: var(--text-md);
  margin: 0 0 var(--space-2);
  color: var(--graphite-900);
}
.features-extras__block .eyebrow { margin-bottom: var(--space-2); }
.features-extras__block > p {
  font-size: var(--text-sm);
  color: var(--graphite-700);
  line-height: 1.55;
  margin-bottom: var(--space-4);
}
@media (max-width: 800px) {
  .features-extras { grid-template-columns: 1fr; gap: var(--space-6); }
}

/* ── Kit list ───────────────────────────────────────────────────────── */
.kit-list {
  border-top: 1px solid var(--sand-200);
  margin-top: var(--space-6);
}
.kit-row {
  display: grid;
  grid-template-columns: 110px 1fr auto auto;
  gap: var(--space-5);
  align-items: center;
  padding: var(--space-5) 0;
  border-bottom: 1px solid var(--sand-200);
  text-decoration: none;
  color: inherit;
  transition: background var(--duration) var(--ease-out);
}
.kit-row:hover { background: var(--sand-50); color: inherit; padding-left: var(--space-3); padding-right: var(--space-3); margin-left: calc(var(--space-3) * -1); margin-right: calc(var(--space-3) * -1); border-radius: var(--radius-sm); }
.kit-expand__ref {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--graphite-500);
  letter-spacing: 0.05em;
}
.kit-row__name { font-weight: 500; color: var(--graphite-900); font-size: var(--text-base); margin: 0; }
.kit-row__sub  { font-size: var(--text-sm); color: var(--graphite-500); margin-top: 2px; }
.kit-row__targets {
  font-family: var(--font-display);
  font-size: var(--text-md);
  font-weight: 500;
  color: var(--teal-500);
  text-align: right;
}
.kit-row__targets span { font-size: var(--text-xs); color: var(--graphite-500); display: block; text-transform: uppercase; letter-spacing: 0.08em; }
.kit-row__chev { color: var(--graphite-300); transition: color var(--duration) var(--ease-out); }
.kit-row:hover .kit-row__chev { color: var(--ember-500); }

/* ── Badges ─────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px var(--space-3);
  border-radius: var(--radius-pill);
  border: 1px solid;
}
.badge-ivd  { background: var(--teal-50);  color: var(--teal-700); border-color: var(--teal-100); }
.badge-ce   { background: var(--ember-50); color: var(--ember-700); border-color: var(--ember-100); }
.badge-ruo  { background: #fef2f2;        color: #991b1b; border-color: #fecaca; }
.badge-quant { background: var(--sand-100); color: var(--graphite-700); border-color: var(--sand-200); }
.badge-ums  { background: var(--white);    color: var(--teal-500); border-color: var(--teal-500); }

/* ── Kit detail ─────────────────────────────────────────────────────── */
.kit-hero {
  padding: var(--space-7) 0 var(--space-6);
  border-bottom: 1px solid var(--sand-200);
}
.breadcrumb {
  font-size: var(--text-xs);
  color: var(--graphite-500);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: var(--space-5);
}
.breadcrumb a { color: var(--graphite-500); }
.breadcrumb a:hover { color: var(--ember-500); }
.kit-hero__ref {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--ember-500);
  letter-spacing: 0.10em;
  margin-bottom: var(--space-3);
}
.kit-hero__title { font-size: var(--text-2xl); font-weight: 600; margin-bottom: var(--space-3); }
.kit-hero__subtitle { font-size: var(--text-md); color: var(--graphite-700); margin-bottom: var(--space-5); }
.kit-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
  padding: var(--space-4) 0;
  border-top: 0.5px solid var(--sand-200);
  border-bottom: 0.5px solid var(--sand-200);
  font-size: var(--text-sm);
  color: var(--graphite-500);
}
.kit-detail-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-8);
  padding: var(--space-7) 0;
}
.kit-spec h3 { font-size: var(--text-lg); margin-top: var(--space-6); margin-bottom: var(--space-3); color: var(--teal-500); }
.kit-spec h3:first-child { margin-top: 0; }
.kit-spec table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.kit-spec td { padding: var(--space-3) 0; border-bottom: 0.5px solid var(--sand-200); }
.kit-spec td:first-child { color: var(--graphite-500); width: 200px; }
.kit-aside {
  background: var(--sand-50);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  position: sticky;
  top: calc(var(--header-h) + var(--space-5));
  height: fit-content;
}
.kit-aside h4 { font-size: var(--text-sm); text-transform: uppercase; letter-spacing: 0.08em; color: var(--graphite-500); font-weight: 600; margin-bottom: var(--space-3); }
.kit-aside .btn { width: 100%; justify-content: center; margin-bottom: var(--space-3); }

.target-list { list-style: none; padding: 0; margin: 0; }
.target-list li {
  padding: var(--space-3) 0;
  border-bottom: 0.5px solid var(--sand-200);
  font-size: var(--text-sm);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.target-list li:last-child { border-bottom: none; }
.target-list .channel {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  color: var(--ember-500);
  letter-spacing: 0.06em;
  margin-left: var(--space-3);
}

/* Cross-category links — when a kit appears in multiple categories */
.related-cats {
  background: var(--ember-50);
  border-left: 3px solid var(--ember-500);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-6) 0;
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.related-cats h4 { color: var(--ember-700); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: var(--space-3); }
.related-cats a { display: inline-block; margin-right: var(--space-4); font-size: var(--text-sm); color: var(--teal-500); border-bottom: 1px solid currentColor; }

/* ── UMS section / page ─────────────────────────────────────────────── */
.ums-banner {
  background: var(--teal-700);
  color: var(--cream);
  padding: var(--space-7) 0;
  position: relative;
  overflow: hidden;
}
.ums-banner__pattern { position: absolute; right: -100px; top: -50px; width: 400px; opacity: 0.06; pointer-events: none; }
.ums-banner__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 2fr 1fr; gap: var(--space-7); align-items: center; }
.ums-banner h2 { color: var(--white); font-size: var(--text-2xl); margin-bottom: var(--space-3); }
.ums-banner p { color: var(--teal-100); font-size: var(--text-md); margin-bottom: var(--space-5); }

.ums-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-5);
  padding: var(--space-7) 0;
}
.ums-feat {
  border-left: 2px solid var(--ember-500);
  padding-left: var(--space-5);
}
.ums-feat h4 { font-size: var(--text-md); font-weight: 500; color: var(--teal-500); margin-bottom: var(--space-2); }
.ums-feat p  { font-size: var(--text-sm); color: var(--graphite-700); margin: 0; }

/* Notice for UMS regulatory transparency */
.notice {
  background: var(--sand-50);
  border-left: 3px solid var(--graphite-500);
  padding: var(--space-4) var(--space-5);
  font-size: var(--text-sm);
  color: var(--graphite-700);
  margin: var(--space-6) 0;
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.notice strong { color: var(--graphite-900); }

/* ── Footer ─────────────────────────────────────────────────────────── */
.site-footer {
  background: var(--teal-700);
  color: var(--teal-100);
  padding: var(--space-8) 0 var(--space-5);
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-7);
}
.site-footer h5 {
  color: var(--white);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-weight: 600;
  margin: 0 0 var(--space-4);
}
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { margin-bottom: var(--space-2); font-size: var(--text-sm); }
.site-footer a { color: var(--teal-100); }
.site-footer a:hover { color: var(--ember-200); }
.site-footer__brand img { height: 64px; margin-bottom: var(--space-4); filter: brightness(0) invert(1); }
.site-footer__addr { font-size: var(--text-sm); line-height: 1.6; color: var(--teal-100); }
.site-footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.10);
  padding-top: var(--space-4);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.50);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
}

/* ── Technical mockups (UMS IFU stilinden) ──────────────────────────── */

/* Browser/app frame — Plate Editor, Dashboard mockup'ları için */
.app-frame {
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  background: var(--white);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  margin: var(--space-6) 0;
}
.app-frame__chrome {
  background: var(--cream);
  border-bottom: 1px solid var(--sand-200);
  padding: var(--space-3) var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  color: var(--graphite-500);
}
.app-frame__brand {
  display: flex; align-items: center; gap: var(--space-2);
  font-weight: 600; color: var(--graphite-900);
}
.app-frame__brand .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ember-500); }
.app-frame__chrome .badge-prod {
  margin-left: auto;
  background: var(--ember-500); color: var(--white);
  padding: 2px 8px; border-radius: var(--radius-sm);
  font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase;
}
.app-frame__tabs {
  display: flex; gap: var(--space-5);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--sand-200);
  font-size: var(--text-xs);
  color: var(--graphite-500);
}
.app-frame__tabs span { padding-bottom: var(--space-2); }
.app-frame__tabs .active { color: var(--ember-500); font-weight: 600; border-bottom: 2px solid var(--ember-500); margin-bottom: -1px; }
.app-frame__body { padding: var(--space-5); }

/* Curve showcase — amplification curve SVG showcase */
.curve-showcase {
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}
.curve-showcase__title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--teal-500);
  text-align: center;
  margin-bottom: var(--space-4);
  letter-spacing: 0.02em;
}
.curve-showcase svg { width: 100%; height: auto; max-height: 320px; }
.curve-showcase__caption {
  font-size: var(--text-xs);
  color: var(--graphite-500);
  text-align: center;
  margin-top: var(--space-4);
  font-style: italic;
}

/* 5-step workflow — UMS IFU sayfa 8 stilinde */
.workflow {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
  margin: var(--space-6) 0;
}
.workflow::before {
  content: '';
  position: absolute;
  top: 32px;
  left: 10%; right: 10%;
  height: 1px;
  background: var(--ember-500);
  opacity: 0.4;
  z-index: 0;
}
.workflow__step {
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 0 var(--space-2);
}
.workflow__num {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--ember-500);
  color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 500;
  margin: 0 auto var(--space-3);
  box-shadow: var(--shadow-ember);
}
.workflow__step:nth-child(even) .workflow__num {
  background: var(--white);
  color: var(--ember-500);
  border: 2px solid var(--ember-500);
  box-shadow: none;
}
.workflow__title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--graphite-900);
  margin-bottom: var(--space-1);
}
.workflow__sub {
  font-size: var(--text-xs);
  color: var(--graphite-500);
  font-family: var(--font-display);
  letter-spacing: 0.04em;
}
.workflow__arrow {
  display: none; /* arrows handled by ::before line + dots */
}

/* Mini tech glyphs inside Uniqplex 7-cell — small inline SVGs */
.tech-cell__glyph {
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: var(--space-2);
}
.tech-cell__glyph svg { height: 56px; width: auto; max-width: 100%; }

/* Stat cards — UMS IFU sayfa 18'deki büyük sayılar */
.stat-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1px;
  background: var(--sand-200);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin: var(--space-6) 0;
}
.stat-strip__cell {
  background: var(--white);
  padding: var(--space-5);
  text-align: center;
}
.stat-strip__num {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 500;
  color: var(--ember-500);
  line-height: 1;
  display: block;
  margin-bottom: var(--space-2);
}
.stat-strip__num .unit { font-size: 0.4em; color: var(--graphite-500); margin-left: 0.2em; }
.stat-strip__lbl {
  font-size: var(--text-xs);
  color: var(--graphite-500);
  text-transform: uppercase;
  letter-spacing: 0.10em;
}

/* Plate mockup — 96-well grid, dolu/boş daireler */
.plate-mockup {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 4px;
  max-width: 480px;
  padding: var(--space-3);
  background: var(--cream);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-sm);
}
.plate-mockup .well {
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid var(--sand-300);
  background: var(--white);
}
.plate-mockup .well.fill-ember { background: var(--ember-200); border-color: var(--ember-500); }
.plate-mockup .well.fill-teal { background: var(--teal-100); border-color: var(--teal-500); }

/* Trend chart — viral yük trendi */
.trend-chart {
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}
.trend-chart__head {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 0.5px solid var(--sand-200);
}
.trend-chart__patient { font-size: var(--text-sm); font-weight: 500; color: var(--graphite-900); }
.trend-chart__patient span { display: block; font-size: var(--text-xs); color: var(--graphite-500); margin-top: 2px; font-weight: 400; }
.trend-chart__latest {
  background: var(--ember-500); color: var(--white);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
}
.trend-chart__latest strong { display: block; font-family: var(--font-display); font-size: var(--text-base); margin-top: 2px; }
.trend-chart svg { width: 100%; height: auto; max-height: 240px; }

/* Org chart — UMS IFU sayfa 14 rol hiyerarşisi */
.org-chart {
  display: grid;
  grid-template-rows: auto auto auto;
  gap: var(--space-4);
  padding: var(--space-6) 0;
}
.org-chart__row {
  display: flex; justify-content: center; gap: var(--space-3); flex-wrap: wrap;
}
.org-card {
  background: var(--white);
  border: 1px solid var(--sand-300);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-5);
  text-align: center;
  min-width: 200px;
}
.org-card.role-super {
  background: var(--graphite-900); color: var(--white); border-color: var(--graphite-900);
}
.org-card.role-admin { background: var(--ember-50); border-color: var(--ember-200); }
.org-card.role-lab { background: var(--teal-50); border-color: var(--teal-100); }
.org-card.role-clin { background: #f0f9ff; border-color: #bae6fd; }
.org-card__role {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: lowercase;
  margin-bottom: 4px;
}
.org-card__name {
  font-size: var(--text-sm);
  font-weight: 500;
}
.org-card__sub {
  font-size: 11px;
  color: var(--graphite-500);
  margin-top: 4px;
}
.org-card.role-super .org-card__sub { color: var(--graphite-300); }

/* ── Reveal animations (page load only, single staggered burst) ─────── */
@keyframes reveal-up {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.reveal { opacity: 0; animation: reveal-up 600ms var(--ease-out) forwards; }
.reveal-d1 { animation-delay: 80ms; }
.reveal-d2 { animation-delay: 160ms; }
.reveal-d3 { animation-delay: 240ms; }
.reveal-d4 { animation-delay: 320ms; }

@media (prefers-reduced-motion: reduce) {
  .reveal { animation: none; opacity: 1; transform: none; }
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}

/* ── Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .section { padding: var(--space-7) 0; }
  .hero { padding: var(--space-7) 0; }
  .hero__title { font-size: 40px; }
  .hero__kpis { grid-template-columns: 1fr; gap: var(--space-4); }
  .ums-banner__inner { grid-template-columns: 1fr; }
  .kit-detail-grid { grid-template-columns: 1fr; }
  .kit-aside { position: static; }
  .site-footer__grid { grid-template-columns: 1fr 1fr; }
  .site-nav { gap: var(--space-4); }
  .site-nav a:not(.btn) { font-size: var(--text-sm); }
}
@media (max-width: 600px) {
  .site-nav { display: none; }       /* mobile menu would go here, MVP skip */
  .kit-row { grid-template-columns: 1fr auto; gap: var(--space-3); }
  .kit-expand__ref { display: none; }
  .site-footer__grid { grid-template-columns: 1fr; }
  .hero__title { font-size: 32px; }
}


/* ── Nav dropdown menu (Ürünler ▾) ──────────────────────────────────── */
.nav-menu {
  position: relative;
  display: inline-block;
}
.nav-menu__trigger {
  cursor: pointer;
  user-select: none;
}
.nav-menu__panel {
  position: absolute;
  top: calc(100% + var(--space-2));
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  background: var(--white);
  border: 1px solid var(--sand-200);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
  padding: var(--space-2);
  min-width: 280px;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration) var(--ease-out),
              transform var(--duration) var(--ease-out);
  z-index: 60;
}
.nav-menu:hover .nav-menu__panel,
.nav-menu:focus-within .nav-menu__panel {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav-menu__panel a {
  display: block;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  border-bottom: none;
  color: var(--graphite-700);
  font-size: var(--text-sm);
  font-weight: 500;
  white-space: nowrap;
}
.nav-menu__panel a:hover {
  background: var(--cream);
  color: var(--ember-500);
  border-bottom: none;
}
.nav-menu__panel a[aria-current="page"] {
  color: var(--ember-500);
  background: var(--ember-50);
  border-bottom: none;
}


/* ═══════════════════════════════════════════════════════════════════
   MOBİL UYUMLULUK
═══════════════════════════════════════════════════════════════════ */

/* Hamburger toggle button — desktop'ta gizli */
.nav-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  margin: 0;
  color: var(--graphite-900);
  align-items: center;
}
.nav-toggle svg { display: block; width: 28px; height: 28px; }

@media (max-width: 768px) {
  /* ─── Header & Logo ─── */
  .site-header__inner {
    padding: 0 var(--space-4);
    height: 72px;
  }
  .site-header { height: 72px; }
  .site-header__brand img { height: 48px; }
  .nav-toggle { display: flex; }

  /* ─── Nav — hamburger drop ─── */
  .site-nav {
    display: none;
    position: absolute;
    top: 72px;
    left: 0;
    right: 0;
    background: var(--white);
    border-bottom: 1px solid var(--sand-200);
    padding: var(--space-4);
    flex-direction: column;
    gap: 0;
    align-items: stretch;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    z-index: 55;
  }
  .site-nav.is-open { display: flex; }
  .site-nav > a {
    padding: var(--space-3) var(--space-2);
    border-bottom: 0.5px solid var(--sand-100);
    font-size: var(--text-md);
  }
  .lang-toggle { align-self: flex-start; margin-top: var(--space-2); }

  /* Nav dropdown - mobile'da inline list */
  .nav-menu { position: relative; }
  .nav-menu__trigger {
    padding: var(--space-3) var(--space-2);
    border-bottom: 0.5px solid var(--sand-100);
    font-weight: 600;
    pointer-events: none;
    display: block;
  }
  .nav-menu__panel {
    position: static;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    box-shadow: none;
    border: none;
    background: transparent;
    padding: 0 0 var(--space-2) var(--space-4);
    margin: 0;
    min-width: 0;
  }
  .nav-menu__panel a {
    padding: var(--space-2) var(--space-3) var(--space-2) var(--space-6);
    font-size: var(--text-sm);
    border-bottom: none;
    color: var(--graphite-700);
  }

  /* ─── Hero (anasayfa) ─── */
  .hero { padding-top: var(--space-7); padding-bottom: var(--space-6); }
  .hero h1 { font-size: 44px !important; line-height: 1.05; }
  .hero__sub { font-size: var(--text-lg); }
  .hero__kpis {
    grid-template-columns: 1fr;
    gap: var(--space-4);
    max-width: 100%;
  }
  .hero__kpi { padding: var(--space-3) 0; border-bottom: 0.5px solid var(--sand-200); }
  .hero__kpi:last-child { border-bottom: none; }

  /* ─── Kit hero (kategori sayfası) ─── */
  .kit-hero { padding: var(--space-6) 0 var(--space-4); }
  .kit-hero__title { font-size: 32px; line-height: 1.15; }
  .kit-hero__subtitle { font-size: var(--text-md); line-height: 1.55; }

  /* ─── Cat-grid - tek sütun ─── */
  .cat-grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-3) !important;
  }
  .cat-card { padding: var(--space-5); }

  /* ─── Kit-expand head ─── */
  .kit-expand__head {
    grid-template-columns: 48px 1fr 24px;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
  }
  .kit-expand__icon { width: 48px; height: 48px; }
  .kit-expand__icon svg { width: 22px; height: 22px; }
  .kit-expand__title h3 { font-size: var(--text-md); }
  .kit-expand__title p { font-size: 11px; line-height: 1.4; }
  .kit-expand__ref { display: none; }
  .kit-expand__caret { width: 24px; height: 24px; }

  /* Kit-expand body — tek sütun */
  .kit-expand__body-inner {
    grid-template-columns: 1fr;
    gap: var(--space-4);
    padding: var(--space-4);
  }

  /* Tablo — overflow scroll, küçük font */
  .kit-expand__targets {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .kit-expand__targets table {
    font-size: 10px;
    min-width: 480px;
  }
  .kit-expand__targets th { padding: 6px 4px; }
  .kit-expand__targets td { padding: 6px 4px; line-height: 1.3; }

  /* ─── Section padding ─── */
  .section { padding: var(--space-7) 0; }

  /* ─── Footer - tek sütun ─── */
  .site-footer__inner,
  .site-footer .container > div {
    grid-template-columns: 1fr !important;
    gap: var(--space-5) !important;
  }
  .site-footer__col { padding: 0; }
  .site-footer__bottom { flex-direction: column; gap: var(--space-2); text-align: center; }

  /* ─── İletişim section iki sütun → tek ─── */
  #iletisim .container { grid-template-columns: 1fr !important; gap: var(--space-5) !important; }

  /* ─── Teknoloji section / tech-grid → tek sütun ─── */
  .tech-grid { grid-template-columns: 1fr; }

  /* SVG ilüstrasyonların (timeline vb.) genişlik kontrolü */
  svg { max-width: 100%; height: auto; }
}

@media (max-width: 480px) {
  /* Çok dar telefonlar */
  .container { padding: 0 var(--space-4); }
  .hero h1 { font-size: 36px !important; }
  .hero__sub { font-size: var(--text-md); }
  .kit-hero__title { font-size: 26px; }
  .site-header__brand img { height: 40px; }
  .cat-card__title { font-size: var(--text-md); }
  .cat-card__lead { font-size: var(--text-sm); }
}


/* ── IVDR section mobil fix ─────────────────────────────────────────── */
@media (max-width: 768px) {
  /* IVDR regulatory section iki kolon → tek kolon */
  section .container > div[style*="grid-template-columns:1fr 1.1fr"],
  section .container > div[style*="grid-template-columns: 1fr 1.1fr"] {
    grid-template-columns: 1fr !important;
    gap: var(--space-5) !important;
  }
}


/* ── Hakkımızda mobil ek düzeltmeler ─────────────────────────────────── */
@media (max-width: 768px) {
  /* Belgelendirme/Standartlar 2-sütun → 1-sütun (inline style override) */
  section.band-sand .container > div[style*="grid-template-columns:1fr 1.2fr"],
  section.band-sand .container > div[style*="grid-template-columns: 1fr 1.2fr"] {
    grid-template-columns: 1fr !important;
    gap: var(--space-5) !important;
  }
  /* Stat-strip 4 sütun → 2 sütun (sertifika kartları mobile) */
  .stat-strip {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}


/* ── v2.4 footer link okunabilirlik + mobile dropdown sola taşma fix ── */
.site-footer__col h4 { color: var(--ember-200); font-size: var(--text-sm); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--space-3); }
.site-footer__col ul { list-style: none; padding: 0; margin: 0; }
.site-footer__col ul li { margin-bottom: var(--space-2); }
.site-footer__col ul li a { color: var(--cream); font-size: var(--text-sm); text-decoration: none; opacity: 0.85; transition: opacity 0.2s; }
.site-footer__col ul li a:hover { opacity: 1; color: var(--ember-200); }
.site-footer__about { color: var(--cream); opacity: 0.7; font-size: var(--text-sm); line-height: 1.6; margin-top: var(--space-4); }

/* Mobile dropdown panel sola taşma fix — desktop'taki left:50%/transform context'ini reset */
@media (max-width: 768px) {
  .nav-menu__panel {
    left: auto !important;
    right: auto !important;
    transform: none !important;
  }
  .nav-menu:hover .nav-menu__panel,
  .nav-menu:focus-within .nav-menu__panel {
    transform: none !important;
  }
}
