/* =====================================================================
   MEBRIC · SITE-WIDE BASE STYLES
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;700&display=swap');
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@latest/dist/web/static/pretendard.css');

:root {
  --mebric-cream: #F9F6F0;
  --mebric-navy: #0F1B2D;
  --mebric-terra: #C85A3A;
  --mebric-ink: #192536;
  --mebric-muted: #8A7F6A;
  --mebric-line-dark: rgba(249,246,240,0.12);
  --mebric-line-light: rgba(15,27,45,0.08);
  --mebric-font-en: 'Space Grotesk', 'Inter', system-ui, -apple-system, sans-serif;
  --mebric-font-kr: 'Pretendard', 'Noto Sans KR', system-ui, sans-serif;
  --mebric-max: 1200px;
  --mebric-gutter: 24px;
}

/* =====================================================
   Design Tokens v2 — added 2026-04-19 (DP1)
   Scale: 8px grid / Motion: 120/220/420/640
   Shadow rgba base = --mebric-ink (#192536 → 25,37,54)
   Reference: DESIGN-POLISH-PLAN-2026-04-18/TRACK-1-DESIGN-TOKENS.md
   ===================================================== */

:root {
  /* Spacing scale (8px grid) */
  --space-0:   0;
  --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;

  /* Spacing — semantic */
  --space-card-padding:    var(--space-6);
  --space-card-gap:        var(--space-5);
  --space-section-y:       var(--space-9);
  --space-section-y-sm:    var(--space-7);
  --space-form-field-gap:  var(--space-4);

  /* Radius scale */
  --radius-0:    0;
  --radius-xs:   2px;
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   12px;
  --radius-pill: 9999px;

  /* Shadow scale (Cream bg tinted — rgba base = ink #192536) */
  --shadow-0:    none;
  --shadow-1:    0 2px 8px rgba(25, 37, 54, 0.06);
  --shadow-2:    0 8px 24px rgba(25, 37, 54, 0.10);
  --shadow-3:    0 16px 48px rgba(25, 37, 54, 0.14);
  --shadow-inset: inset 0 0 0 1px rgba(25, 37, 54, 0.08);

  /* Z-index scale */
  --z-base:      0;
  --z-raised:    10;
  --z-sticky:    100;
  --z-dropdown:  500;
  --z-modal:     1000;
  --z-toast:     1500;
  --z-tooltip:   2000;

  /* Motion — duration */
  --dur-fast:    120ms;
  --dur-base:    220ms;
  --dur-medium:  420ms;
  --dur-slow:    640ms;

  /* Motion — easing */
  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Motion — stagger */
  --stagger-base:    80ms;
  --stagger-delay-1: calc(var(--stagger-base) * 1);
  --stagger-delay-2: calc(var(--stagger-base) * 2);
  --stagger-delay-3: calc(var(--stagger-base) * 3);
  --stagger-delay-4: calc(var(--stagger-base) * 4);
  --stagger-delay-5: calc(var(--stagger-base) * 5);
  --stagger-delay-6: calc(var(--stagger-base) * 6);

  /* Motion — transition shortcuts */
  --tx-hover:    all var(--dur-fast) var(--ease-out);
  --tx-reveal:   opacity var(--dur-medium) var(--ease-out),
                 transform var(--dur-medium) var(--ease-out);
}

/* Reduced motion override — zero out durations so transitions collapse */
@media (prefers-reduced-motion: reduce) {
  :root {
    --dur-fast:    0ms;
    --dur-base:    0ms;
    --dur-medium:  0ms;
    --dur-slow:    0ms;
    --stagger-base: 0ms;
  }
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--mebric-font-kr);
  color: var(--mebric-ink);
  line-height: 1.6;
  font-weight: 400;
  background: var(--mebric-cream);
  -webkit-font-smoothing: antialiased;
  letter-spacing: -0.005em;
}

.mebric-page, .mebric-page * { box-sizing: border-box; }
.mebric-page {
  font-family: var(--mebric-font-kr);
  color: var(--mebric-ink);
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  letter-spacing: -0.005em;
}
.mebric-page h1, .mebric-page h2, .mebric-page h3, .mebric-page h4 {
  font-family: var(--mebric-font-kr);
  font-weight: 700;
  color: var(--mebric-navy);
  margin: 0;
  /* NOTE: line-height & letter-spacing intentionally NOT set here.
     They are defined per-headline (.hero__headline, .intro__headline, etc.)
     so that Figma-spec values (1.02 for hero, 1.4 for intro, -0.035em for hero, etc.)
     are not overridden by a blanket 1.25 / -0.02em rule (session 3-B P1 fix). */
}
.mebric-page p { margin: 0; }
.mebric-page a { color: inherit; text-decoration: none; }
.mebric-page ul { margin: 0; padding: 0; list-style: none; }

.mebric-sec { padding: 120px 0; position: relative; }
.mebric-sec--light { background: var(--mebric-cream); color: var(--mebric-ink); }
.mebric-sec--dark  { background: var(--mebric-navy); color: var(--mebric-cream); }
.mebric-sec--dark h1, .mebric-sec--dark h2, .mebric-sec--dark h3, .mebric-sec--dark h4 { color: var(--mebric-cream); }

.mebric-wrap { max-width: var(--mebric-max); margin: 0 auto; padding: 0 var(--mebric-gutter); }

.mebric-eyebrow {
  font-family: var(--mebric-font-en);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mebric-terra);
  display: inline-block; margin-bottom: 24px;
}
.mebric-eyebrow--muted { color: var(--mebric-muted); }

.mebric-h1 { font-size: clamp(36px, 5vw, 64px); line-height: 1.15; letter-spacing: -0.03em; font-weight: 700; }
.mebric-h2 { font-size: clamp(28px, 3.6vw, 44px); line-height: 1.2; letter-spacing: -0.025em; font-weight: 700; }
.mebric-h3 { font-size: clamp(20px, 2.2vw, 28px); line-height: 1.3; letter-spacing: -0.015em; font-weight: 700; }
.mebric-lead { font-size: clamp(16px, 1.4vw, 18px); line-height: 1.7; color: var(--mebric-ink); max-width: 640px; }
.mebric-sec--dark .mebric-lead { color: rgba(249,246,240,0.78); }
.mebric-small { font-size: 12px; line-height: 1.6; color: var(--mebric-muted); }
.mebric-metric { font-family: var(--mebric-font-en); font-variant-numeric: tabular-nums; font-weight: 300; }

.mebric-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 28px;
  font-family: var(--mebric-font-en); font-size: 14px; font-weight: 500;
  letter-spacing: 0.04em; border-radius: 2px;
  transition: transform 180ms ease, background 180ms ease, color 180ms ease;
  cursor: pointer; border: 1px solid transparent;
}
.mebric-btn--primary { background: var(--mebric-terra); color: #fff; }
.mebric-btn--primary:hover { background: #a8452a; transform: translateY(-1px); }
.mebric-btn--ghost-light { background: transparent; color: var(--mebric-cream); border-color: rgba(249,246,240,0.4); }
.mebric-btn--ghost-light:hover { background: var(--mebric-cream); color: var(--mebric-navy); }
.mebric-btn--ghost-dark { background: transparent; color: var(--mebric-navy); border-color: rgba(15,27,45,0.4); }
.mebric-btn--ghost-dark:hover { background: var(--mebric-navy); color: var(--mebric-cream); }

.mebric-nav {
  display: flex; justify-content: space-between; align-items: center;
  padding: 24px 0; border-bottom: 1px solid var(--mebric-line-light);
}
.mebric-nav-logo { font-family: var(--mebric-font-en); font-weight: 700; font-size: 20px; letter-spacing: 0.02em; color: var(--mebric-navy); }
.mebric-nav-links {
  /* Reset browser default <ul> styles since header lives outside .mebric-page wrapper.
     Without this, subpages get +32px header height (margin:16px 0) and disc bullets. */
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex; gap: 32px;
}
.mebric-nav-links a { font-family: var(--mebric-font-en); font-size: 13px; font-weight: 500; letter-spacing: 0.04em; color: var(--mebric-ink); transition: color 160ms ease; }
.mebric-nav-links a:hover, .mebric-nav-links a.active { color: var(--mebric-terra); }

.mebric-footer { background: var(--mebric-navy); color: var(--mebric-cream); padding: 96px 0 48px; }
.mebric-footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px;
  padding-bottom: 48px; border-bottom: 1px solid var(--mebric-line-dark);
}
.mebric-footer-logo { display: inline-block; margin-bottom: 20px; line-height: 0; }
.mebric-footer-logo img { height: 32px; width: auto; display: block; }
.mebric-footer-tagline { opacity: 0.7; font-size: 13px; max-width: 320px; line-height: 1.7; }
.mebric-footer-accent {
  font-family: var(--mebric-font-en);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--mebric-terra);
  margin-top: 20px;
  opacity: 0.85;
}
.mebric-footer-col-title { font-family: var(--mebric-font-en); font-size: 11px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mebric-terra); margin-bottom: 16px; }
/* Preventive reset for footer <ul> in case footer ends up outside .mebric-page wrapper */
.mebric-footer-col ul,
.mebric-footer-grid ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.mebric-footer-col li { margin-bottom: 10px; font-size: 13px; opacity: 0.75; }
.mebric-footer-col li a,
.mebric-footer-col li a:visited,
.mebric-footer-col li a:hover,
.mebric-footer-col li a:active {
  color: var(--mebric-cream);
  text-decoration: none;
  transition: opacity 160ms ease;
}
.mebric-footer-col li:hover { opacity: 1; }
.mebric-footer-bot { display: flex; justify-content: space-between; padding-top: 32px; font-size: 11px; opacity: 0.5; font-family: var(--mebric-font-en); letter-spacing: 0.06em; }

/* Global link color reset — prevent default :visited purple anywhere we use brand styles */
.link-underline,
.link-underline:visited { color: inherit; }

.mebric-img {
  width: 100%; background: var(--mebric-navy);
  background-size: cover; background-position: center;
  position: relative; overflow: hidden;
}
.mebric-img::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(15,27,45,0.4));
  z-index: 2; pointer-events: none;
}
.mebric-img-placeholder {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  font-family: var(--mebric-font-en); font-size: 11px; letter-spacing: 0.2em;
  color: rgba(249,246,240,0.35); text-transform: uppercase; z-index: 3;
}

/* Real <img> children fill the container like background-cover */
.mebric-img > img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  z-index: 1;
}
.mebric-img:has(> img) .mebric-img-placeholder { display: none; }
.mebric-img[style*="background-image"] .mebric-img-placeholder { display: none; }

@media (max-width: 768px) {
  .mebric-sec { padding: 72px 0; }
  .mebric-footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .mebric-page [style*="grid-template-columns: 1fr 1fr"],
  .mebric-page [style*="grid-template-columns: 2fr 1fr"],
  .mebric-page [style*="grid-template-columns: repeat(3"],
  .mebric-page [style*="grid-template-columns: repeat(4"] {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .mebric-page [style*="grid-template-columns: 120px 1fr 2fr"],
  .mebric-page [style*="grid-template-columns: 160px"],
  .mebric-page [style*="grid-template-columns: 80px"],
  .mebric-page [style*="grid-template-columns: 60px"],
  .mebric-page [style*="grid-template-columns: 320px 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .mebric-h1 { font-size: clamp(32px, 9vw, 44px); }
}

/* =====================================================================
   PR-D Stage 7 — Mobile hamburger drawer + global :focus-visible
   (fixes Stage 5/6 P1: mobile nav flex-wrap + no global focus ring)
   ===================================================================== */

/* Global focus ring — terra brand accent, visible on both cream & navy */
:focus-visible {
  outline: 2px solid var(--mebric-terra);
  outline-offset: 2px;
  border-radius: 1px;
}
/* Drop the default browser focus ring for mouse users, keep it for keyboard */
:focus:not(:focus-visible) { outline: none; }

/* Hamburger toggle — hidden on desktop */
.nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;   /* WCAG 2.5.5 AAA target size */
  padding: 0;
  background: transparent;
  border: 0;
  color: var(--mebric-navy);
  cursor: pointer;
}
.nav-toggle__icon,
.nav-toggle__icon::before,
.nav-toggle__icon::after {
  content: '';
  display: block;
  width: 22px;
  height: 2px;
  background: currentColor;
  transition: transform 200ms ease, opacity 160ms ease, top 200ms ease;
}
.nav-toggle__icon { position: relative; }
.nav-toggle__icon::before { position: absolute; top: -7px; left: 0; }
.nav-toggle__icon::after  { position: absolute; top:  7px; left: 0; }
/* Open state: middle bar fades, top/bottom form an X */
.nav-toggle[aria-expanded="true"] .nav-toggle__icon { background: transparent; }
.nav-toggle[aria-expanded="true"] .nav-toggle__icon::before { top: 0; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__icon::after  { top: 0; transform: rotate(-45deg); }

/* Overlay (shared across breakpoints but only active on mobile) */
.nav-overlay {
  position: fixed; inset: 0;
  background: rgba(15, 27, 45, 0.42);
  opacity: 0;
  pointer-events: none;
  transition: opacity 240ms ease;
  z-index: 55;   /* header is z-index 50 */
}

@media (max-width: 768px) {
  .nav-toggle { display: inline-flex; }

  /* Slide-in drawer on the right */
  .mebric-nav-links {
    position: fixed;
    top: 0; right: 0;
    height: 100vh;
    height: 100dvh;           /* avoids iOS address-bar jump */
    width: min(320px, 86vw);
    padding: 88px 28px 40px;
    background: var(--mebric-cream);
    box-shadow: -16px 0 40px rgba(15, 27, 45, 0.14);
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    transform: translateX(100%);
    transition: transform 260ms cubic-bezier(.2,.9,.3,1);
    z-index: 60;
    overflow-y: auto;
  }
  .mebric-nav-links li {
    width: 100%;
    border-bottom: 1px solid rgba(25, 37, 54, 0.08);
  }
  .mebric-nav-links a {
    display: block;
    padding: 18px 0;
    font-size: 16px;
    letter-spacing: 0.02em;
    line-height: 1.4;
  }

  /* Open state driven by body[data-nav-open="true"] (set by nav.js) */
  body[data-nav-open="true"] { overflow: hidden; }
  body[data-nav-open="true"] .mebric-nav-links { transform: translateX(0); }
  body[data-nav-open="true"] .nav-overlay { opacity: 1; pointer-events: auto; }
}

/* Reduced-motion: drop the slide, just fade */
@media (prefers-reduced-motion: reduce) {
  .mebric-nav-links,
  .nav-overlay,
  .nav-toggle__icon,
  .nav-toggle__icon::before,
  .nav-toggle__icon::after {
    transition: opacity 120ms ease !important;
    transform: none !important;
  }
  @media (max-width: 768px) {
    .mebric-nav-links {
      transform: translateX(100%) !important;
      transition: none !important;
    }
    body[data-nav-open="true"] .mebric-nav-links {
      transform: translateX(0) !important;
    }
  }
}

/* =====================================================================
   LANDING v2 — Motion, Hero, Cards, Ticker, Admin
   ===================================================================== */

/* Sticky translucent header — jitter-free (no layout-triggering transitions) */
.mebric-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(249,246,240,0.60);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid transparent;
  transition: background-color 200ms ease,
              border-color 200ms ease,
              box-shadow 200ms ease;
  will-change: background-color;
}
.mebric-header.is-scrolled {
  background: rgba(249,246,240,0.88);
  border-bottom-color: var(--mebric-line-light);
  box-shadow: 0 6px 30px rgba(15,27,45,0.06);
}
.mebric-header .mebric-nav { padding: 16px 0; border-bottom: 0; }
/* NOTE: no .is-scrolled padding rule — height stays constant to prevent jitter */

/* Logo lockup with svg */
.mebric-logo { display: inline-flex; align-items: center; gap: 10px; }
.mebric-logo img { height: 22px; width: auto; display: block; }
.mebric-logo__word { font-family: var(--mebric-font-en); font-weight: 700; font-size: 18px; letter-spacing: 0.02em; color: var(--mebric-navy); }

/* Hero v2 */
.hero {
  position: relative;
  /* P1-5 (2026-04-17): reduce top padding on laptop viewports (1440×900).
     Was clamp(64px, 10vw, 140px) — max 140 felt excessive with 60px header. */
  padding: clamp(56px, 7vw, 112px) 0 clamp(48px, 6vw, 96px);
  background: var(--mebric-cream);
  overflow: hidden;
}
/* On short viewports (<=900px height, common on 13–14" laptops) tighten further */
@media (max-height: 900px) and (min-width: 1024px) {
  .hero { padding-top: clamp(48px, 5.5vw, 88px); padding-bottom: clamp(40px, 5vw, 80px); }
}
.hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
  gap: clamp(32px, 5vw, 80px);
  align-items: end;
}
.hero__kicker {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mebric-font-en); font-size: 11px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--mebric-terra);
  margin-bottom: 28px;
}
.hero__kicker::before { content: ''; width: 28px; height: 1px; background: var(--mebric-terra); display: inline-block; }
.hero__headline {
  font-size: clamp(40px, 5.2vw, 76px);     /* Figma 76px */
  line-height: 1.02;
  letter-spacing: -0.035em;
  font-weight: 700;
  color: var(--mebric-navy);
  margin: 0;
  max-width: 720px;                         /* P1-1: prevent 3-line wrap at wide desktop */
  word-break: keep-all;                     /* P1-2: prevent Korean mid-word wrap */
  overflow-wrap: break-word;                /* P1-2: allow break on long latin sequences */
}
@media (max-width: 640px) {
  .hero__headline br { display: none; }    /* P1-1: allow natural wrap on mobile */
  .hero { padding-top: 88px; padding-bottom: 64px; }  /* P1-5: reduce mobile hero padding */
}
.hero__headline .accent { color: var(--mebric-terra); font-weight: 700; }
.hero__sub { margin-top: 28px; max-width: 520px; color: rgba(25,37,54,0.72); font-size: clamp(15px, 1.1vw, 17px); line-height: 1.65; }
.hero__cta { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
.hero__image {
  position: relative; aspect-ratio: 4 / 5;
  border-radius: 3px; overflow: hidden;
  background: var(--mebric-navy);
  transform: translateZ(0);
}
.hero__image img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 8s ease-out; }
.hero.is-ready .hero__image img { transform: scale(1.03); }

/* Hero dark variant */
.hero--dark { background: var(--mebric-navy); color: var(--mebric-cream); }
.hero--dark .hero__headline { color: var(--mebric-cream); }
/* P0 Polish 2026-04-17 — hero 첫 줄을 cream 으로 부드럽게 (WCAG AA 통과) */
.hero--dark .hero__headline .hero__headline--soft { color: var(--mebric-cream); }
.hero--dark .hero__sub { color: rgba(249, 246, 240, 0.78); }
.hero--dark .hero__image { background: rgba(249, 246, 240, 0.04); }

/* Option C 2026-04-17 — CTA bridge 섹션 (cream 배경, footer 직전 리듬 통일) */
.mebric-cta-bridge {
  background: var(--mebric-cream);
  border-top: 1px solid rgba(15, 27, 45, 0.08);
}
.mebric-cta-bridge .mebric-wrap {
  padding: 120px 0;
}
@media (max-width: 640px) {
  .mebric-cta-bridge .mebric-wrap { padding: 80px 0; }
}

.hero__kicker--dark { color: var(--mebric-terra); }
.hero__kicker--dark::before { background: var(--mebric-terra); }

.hero__meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 12px;
  margin-top: 56px;
  font-family: var(--mebric-font-en);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(249, 246, 240, 0.72);
}
.hero__meta-dot {
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--mebric-terra);
  display: inline-block;
}
.hero__meta-label { color: var(--mebric-cream); }
.hero__meta-sep { opacity: 0.3; }
.hero__meta-products { opacity: 0.85; }

@media (max-width: 600px) {
  .hero__meta { gap: 8px; font-size: 10px; }
  .hero__meta-sep { display: none; }
  .hero__meta-products { flex-basis: 100%; }
}

/* Intro eyebrow bar variant + image caption + headline */
.mebric-eyebrow--bar {
  display: inline-flex; align-items: center; gap: 10px;
}
.mebric-eyebrow--bar::before {
  content: ''; width: 28px; height: 1px;
  background: var(--mebric-terra);
  display: inline-block;
}
.intro__headline {
  font-size: clamp(32px, 3.2vw, 44px);    /* Figma 44px */
  line-height: 1.4;
  letter-spacing: -0.028em;
  color: var(--mebric-navy);
  font-weight: 700;                         /* Figma Bold */
  max-width: 640px;
  margin-top: 18px;
}
.intro__headline .u { background: linear-gradient(to bottom, transparent 62%, rgba(200,90,58,0.25) 62%); padding: 0 2px; }
.intro__sub { margin-top: 20px; max-width: 560px; color: rgba(25,37,54,0.72); font-size: clamp(15px, 1.1vw, 17px); line-height: 1.7; }
.intro__image-caption {
  font-family: var(--mebric-font-en);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mebric-terra);
  margin-top: 16px;
  opacity: 0.9;
}

@media (max-width: 900px) {
  .hero__grid { grid-template-columns: 1fr; gap: 40px; }
  .hero__image { aspect-ratio: 4 / 3; max-height: 480px; }
}

/* Ticker / marquee */
.ticker {
  border-top: 1px solid var(--mebric-line-light);
  border-bottom: 1px solid var(--mebric-line-light);
  padding: 20px 0; overflow: hidden;
  background: var(--mebric-cream);
}
.ticker__track {
  display: flex; gap: 60px; white-space: nowrap;
  animation: ticker-scroll 40s linear infinite;
  will-change: transform;
}
.ticker__item {
  font-family: var(--mebric-font-en); font-size: 14px; font-weight: 500;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--mebric-navy);
  display: inline-flex; align-items: center; gap: 24px;
}
.ticker__item .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--mebric-terra); }
@keyframes ticker-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.ticker:hover .ticker__track { animation-play-state: paused; }

/* Stats bar */
.stats {
  padding: 36px 0 80px;                     /* Figma 36/80 */
  border-top: 1px solid rgba(25,37,54,0.12);
  border-bottom: 1px solid rgba(25,37,54,0.12);
  background: var(--mebric-cream);
}
.stats__grid { display: grid; grid-template-columns: repeat(4, minmax(240px, 1fr)); gap: 32px; }
.stats__item {
  display: flex; flex-direction: column; gap: 8px;
  padding-left: 24px;
  border-left: 1px solid rgba(25, 37, 54, 0.12);
  min-width: 0;
}
.stats__item:first-child { padding-left: 0; border-left: none; }
@media (max-width: 768px) {
  .stats__item { padding-left: 0; border-left: none; }
  .stats__item:nth-child(odd) { padding-left: 0; }
  .stats__item:nth-child(even) { padding-left: 24px; border-left: 1px solid rgba(25, 37, 54, 0.12); }
}
.stats__num {
  font-family: var(--mebric-font-en);
  font-weight: 500;                         /* Figma Medium */
  font-size: clamp(28px, 2.4vw, 32px);     /* Figma 32px */
  line-height: 1;
  color: var(--mebric-navy);
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;                      /* P1-3: keep 'Mapo, Seoul' / 'Product Studio' on one line */
}
.stats__num .plus { color: var(--mebric-terra); }
.stats__prefix {                            /* P0-2: 'EST.' before the year */
  display: inline-block;
  margin-right: 0.35em;
  font-size: 0.5em;
  font-weight: 500;
  letter-spacing: 0.14em;
  color: rgba(25,37,54,0.45);
  vertical-align: 0.3em;
  text-transform: uppercase;
}
.stats__label {
  font-family: var(--mebric-font-en); font-size: 11px; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase; color: rgba(25,37,54,0.55);
  white-space: nowrap;                      /* P1-3 */
}
@media (max-width: 768px) { .stats__grid { grid-template-columns: repeat(2, 1fr); gap: 28px; } }

/* Brand equation (navy section) */
.equation {
  background: var(--mebric-navy); color: var(--mebric-cream);
  padding: clamp(96px, 12vw, 160px) 0;
  position: relative; overflow: hidden;
}
.equation__grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(40px, 6vw, 96px); align-items: center; }
.equation__copy h2 { color: var(--mebric-cream); font-size: clamp(28px, 3.8vw, 48px); line-height: 1.25; letter-spacing: -0.025em; margin-bottom: 24px; }
.equation__copy p { color: rgba(249,246,240,0.72); font-size: clamp(15px, 1.1vw, 17px); line-height: 1.75; max-width: 480px; }
.equation__figure { display: flex; flex-direction: column; gap: 16px; font-family: var(--mebric-font-en); }
.equation__line { font-size: clamp(28px, 4vw, 52px); font-weight: 300; letter-spacing: -0.02em; line-height: 1.15; color: var(--mebric-cream); }
.equation__line .eq-accent { color: var(--mebric-terra); font-weight: 500; }
.equation__line .eq-muted { color: rgba(249,246,240,0.4); }
.equation__note { margin-top: 24px; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(249,246,240,0.4); font-family: var(--mebric-font-en); }
@media (max-width: 900px) { .equation__grid { grid-template-columns: 1fr; gap: 40px; } }

/* Equation dark variant — ME = Measure / Metric / Meaning */
.equation--dark {
  background: var(--mebric-navy);
  color: var(--mebric-cream);
}
.equation--dark .equation__copy h2,
.equation--dark .equation__headline {
  color: var(--mebric-cream);
  font-size: clamp(40px, 4.2vw, 56px);   /* Figma 56px */
  letter-spacing: -0.03em;
  line-height: 1.1;
  font-weight: 700;                        /* Figma Bold */
  margin: 16px 0 24px;
}
.equation--dark .equation__sub {
  color: rgba(249,246,240,0.72);
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.7;
  max-width: 440px;
}
.equation--dark .eq-accent { color: var(--mebric-terra); }
.equation--dark .eq-muted { color: rgba(249,246,240,0.45); }

.equation__concepts {
  display: flex; flex-direction: column; gap: 32px;
  padding-left: clamp(0px, 4vw, 48px);
  border-left: 1px solid rgba(249,246,240,0.12);
}
.equation__concept-title {
  font-family: var(--mebric-font-en);
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 300;
  color: var(--mebric-cream);
  letter-spacing: -0.02em;
}
.equation__concept-desc {
  margin-top: 6px;
  font-size: 14px;
  color: rgba(249,246,240,0.65);
}

.equation__footer {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: clamp(48px, 6vw, 80px);
  padding-top: 24px;
  border-top: 1px solid rgba(249,246,240,0.08);
  font-family: var(--mebric-font-en);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: rgba(249,246,240,0.72);
  flex-wrap: wrap; gap: 16px;
}
.equation__footer-right { color: var(--mebric-terra); }

.mebric-eyebrow--on-dark,
.mebric-eyebrow--on-dark::before { color: var(--mebric-terra); }

@media (max-width: 900px) {
  .equation__concepts { padding-left: 0; border-left: none; border-top: 1px solid rgba(249,246,240,0.12); padding-top: 32px; margin-top: 32px; }
  .equation__footer { flex-direction: column; align-items: flex-start; }
}

/* Intro section with image tile */
.intro { padding: clamp(96px, 11vw, 140px) 0; background: var(--mebric-cream); }
.intro__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 100px); align-items: center; }
.intro__lead { font-size: clamp(32px, 3.2vw, 44px); line-height: 1.4; letter-spacing: -0.028em; color: var(--mebric-navy); font-weight: 700; max-width: 520px; }
.intro__lead .u { background: linear-gradient(to bottom, transparent 62%, rgba(200,90,58,0.25) 62%); padding: 0 2px; }
.intro__image { position: relative; aspect-ratio: 4 / 3; border-radius: 3px; overflow: hidden; }
.intro__image img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 900px) { .intro__grid { grid-template-columns: 1fr; gap: 40px; } }

/* Founders */
/* Founder — cream section, navy card island */
.founders { padding: clamp(96px, 11vw, 140px) 0; background: var(--mebric-cream); border-top: 1px solid var(--mebric-line-light); }
.founders__head { margin-bottom: clamp(32px, 4vw, 48px); }

/* Navy card */
.founders__card {
  background: var(--mebric-navy);
  color: var(--mebric-cream);
  padding: clamp(32px, 3.5vw, 48px);
  border-radius: 2px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-self: start;
}
.founders__card-portrait {                  /* P0-1 */
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border-radius: 4px;
  margin-bottom: 24px;
  background: rgba(249,246,240,0.04);
}
.founders__card-portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.founders__card-eyebrow {
  font-family: var(--mebric-font-en);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mebric-terra);
  margin-bottom: 8px;
}
.founders__name {
  font-family: var(--mebric-font-en);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--mebric-cream);
}
.founders__role {
  font-family: var(--mebric-font-en);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(249,246,240,0.6);
}
.founders__tagline {
  font-size: 15px;
  line-height: 1.7;
  color: rgba(249,246,240,0.85);
  border-top: 1px solid rgba(249,246,240,0.15);
  padding-top: 20px;
  margin-top: 20px;
}

/* Right content column */
.founders__content { display: flex; flex-direction: column; gap: clamp(32px, 4vw, 48px); }
.founders__title {
  font-size: clamp(28px, 3vw, 40px);     /* Figma 40px */
  letter-spacing: -0.04em;
  line-height: 1.2;
  color: var(--mebric-ink);                /* Figma #192536 */
  font-weight: 700;                        /* Figma Bold */
  margin: 0;
  max-width: 640px;
}

/* Grid */
.founders__grid {
  display: grid;
  grid-template-columns: minmax(280px, 380px) 1fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: start;
}

/* Career list (on cream bg) */
.founders__career {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column;
}
.founders__career-item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 20px;
  padding: 20px 0;
  border-top: 1px solid rgba(25,37,54,0.1);
  align-items: baseline;
}
.founders__career-item:last-child {
  border-bottom: 1px solid rgba(25,37,54,0.1);
}
.founders__career-index {
  font-family: var(--mebric-font-en);
  font-size: 13px; font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--mebric-terra);
  padding-top: 2px;
}
.founders__career-body { display: flex; flex-direction: column; gap: 4px; }
.founders__career-title {
  font-size: clamp(16px, 1.3vw, 19px);
  font-weight: 500;
  color: var(--mebric-navy);
  letter-spacing: -0.01em;
}
.founders__career-desc {
  font-size: 14px;
  line-height: 1.55;
  color: rgba(25,37,54,0.7);
}
.founders__career-meta {
  margin-top: 4px;
  font-family: var(--mebric-font-en);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(25,37,54,0.5);
}

/* Bottom stat */
.founders__stat {
  margin-top: clamp(48px, 6vw, 88px);
  padding-top: 24px;
  border-top: 1px solid rgba(25,37,54,0.1);
  font-family: var(--mebric-font-en);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: rgba(25,37,54,0.7);
  line-height: 1.8;
}

@media (max-width: 900px) {
  .founders__grid { grid-template-columns: 1fr; gap: 48px; }
  .founders__career-item { grid-template-columns: 40px 1fr; gap: 16px; }
}

/* Products 3-up (dark) */
.products {
  background: var(--mebric-navy); color: var(--mebric-cream);
  padding: clamp(96px, 12vw, 160px) 0;
  position: relative; overflow: hidden;
}
.products__head { display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; align-items: end; margin-bottom: 72px; }
.products__title { color: var(--mebric-cream); font-size: clamp(28px, 3.8vw, 48px); letter-spacing: -0.025em; line-height: 1.2; }
.products__sub { color: rgba(249,246,240,0.7); font-size: clamp(15px, 1.1vw, 17px); line-height: 1.7; max-width: 460px; }
.products__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.product-card {
  position: relative;
  background: rgba(249,246,240,0.03);
  border: 1px solid var(--mebric-line-dark);
  padding: 32px 32px 40px;
  display: flex; flex-direction: column; gap: 28px; min-height: 440px;
  transition: transform 340ms cubic-bezier(.2,.9,.3,1), background 340ms ease, border-color 340ms ease;
  overflow: hidden;
}
.product-card::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
  background: var(--mebric-terra); transform: scaleX(0); transform-origin: left;
  transition: transform 420ms cubic-bezier(.2,.9,.3,1);
}
.product-card:hover { transform: translateY(-4px); background: rgba(249,246,240,0.05); border-color: rgba(249,246,240,0.18); }
.product-card:hover::after { transform: scaleX(1); }
.product-card__label { font-family: var(--mebric-font-en); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--mebric-terra); }
.product-card__name { font-family: var(--mebric-font-en); font-weight: 700; font-size: 28px; letter-spacing: -0.01em; color: var(--mebric-cream); margin-top: 8px; }
.product-card__desc { font-size: 14px; line-height: 1.7; color: rgba(249,246,240,0.68); flex: 1; }
.product-card__meta { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px; font-size: 12px; color: rgba(249,246,240,0.55); padding-top: 20px; border-top: 1px solid var(--mebric-line-dark); }
.product-card__meta dt { font-family: var(--mebric-font-en); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(249,246,240,0.4); margin-bottom: 2px; }
.product-card__meta dd { margin: 0; font-family: var(--mebric-font-en); font-variant-numeric: tabular-nums; color: var(--mebric-cream); }
.product-card__arrow {
  position: absolute; top: 24px; right: 24px;
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid var(--mebric-line-dark); display: flex; align-items: center; justify-content: center;
  font-family: var(--mebric-font-en); transition: background 260ms ease, color 260ms ease, transform 260ms ease;
  color: rgba(249,246,240,0.6);
}
.product-card:hover .product-card__arrow { background: var(--mebric-terra); border-color: var(--mebric-terra); color: #fff; transform: rotate(-45deg); }
@media (max-width: 900px) { .products__head { grid-template-columns: 1fr; } .products__grid { grid-template-columns: 1fr; } }

/* Products · ME Blocks — Figma SSoT: warm cream bg (#F2ECDE) */
.products--blocks {
  background: #F2ECDE;
  color: var(--mebric-ink);
  padding-block: clamp(96px, 12vw, 160px);
}
.products--blocks .products__head {
  display: flex; flex-direction: column; gap: 12px;
  margin-bottom: clamp(48px, 6vw, 80px);
  max-width: 720px;
  grid-template-columns: none;
}
.products--blocks .products__title {
  font-size: clamp(36px, 3.6vw, 48px);   /* Figma 48px */
  letter-spacing: -0.02em;
  line-height: 1.3;
  font-weight: 700;                       /* Figma Bold */
  color: var(--mebric-navy);
}
.products--blocks .products__sub {
  font-size: clamp(14px, 1.05vw, 16px);
  line-height: 1.7;
  color: rgba(25,37,54,0.72);
  max-width: 560px;
}

/* Cream variant — invert all child colors */
.products--blocks .product-block {
  border-top: 1px solid rgba(25,37,54,0.1);
}
.products--blocks .product-block:first-child { border-top: 0; }

.products--blocks .product-block__mockup {
  background: rgba(15,27,45,0.04);
  border: 1px solid rgba(15,27,45,0.08);
}

.products--blocks .product-block__status { color: var(--mebric-terra); }
.products--blocks .product-block__since  { color: rgba(25,37,54,0.5); }
.products--blocks .product-block__label  { color: rgba(25,37,54,0.55); }

.products--blocks .product-block__name {
  color: var(--mebric-navy);
  font-weight: 500;
}

.products--blocks .product-block__problem { color: rgba(25,37,54,0.55); }
.products--blocks .product-block__solution {
  color: var(--mebric-navy);
  border-left-color: var(--mebric-terra);
}

.products--blocks .product-block__me {
  border-top: 1px solid rgba(25,37,54,0.12);
  border-bottom: 1px solid rgba(25,37,54,0.12);
}
.products--blocks .product-block__me dt { color: rgba(25,37,54,0.75); }
.products--blocks .product-block__me dt .accent { color: var(--mebric-terra); font-weight: 700; }
.products--blocks .product-block__me dd { color: rgba(25,37,54,0.65); }

.products--blocks .product-block__metrics dt { color: rgba(25,37,54,0.5); }
.products--blocks .product-block__metrics dd { color: var(--mebric-navy); }

.products--blocks .product-block__cta { color: var(--mebric-terra); }

.products__blocks { list-style: none; margin: 0; padding: 0; }

.product-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
  padding: clamp(64px, 7vw, 96px) 0;
  border-top: 1px solid rgba(249,246,240,0.1);
}
.product-block:first-child { border-top: 0; }
.product-block--reverse { direction: rtl; }
.product-block--reverse > * { direction: ltr; }

.product-block__mockup {
  background: rgba(15,27,45,0.5);
  border: 1px solid rgba(249,246,240,0.08);
  aspect-ratio: 4 / 5;
  overflow: hidden;
}
.product-block__mockup img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 9s ease-out;
}
.product-block.is-inview .product-block__mockup img { transform: scale(1.05); }

/* Blank placeholder — used while real product UI screenshots are being prepared */
.product-block__mockup--empty {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background:
    linear-gradient(135deg, rgba(249,246,240,0.02) 0%, rgba(249,246,240,0) 50%, rgba(249,246,240,0.02) 100%),
    repeating-linear-gradient(
      45deg,
      rgba(249,246,240,0.025) 0,
      rgba(249,246,240,0.025) 1px,
      transparent 1px,
      transparent 14px
    ),
    rgba(15,27,45,0.5);
}
.product-block__mockup--empty::before {
  content: "";
  position: absolute;
  inset: 20px;
  border: 1px dashed rgba(249,246,240,0.12);
  pointer-events: none;
}
.product-block__mockup-tag {
  font-family: var(--mebric-font-en);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(249,246,240,0.5);
}
.product-block__mockup-note {
  font-family: var(--mebric-font-en);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(249,246,240,0.28);
}

/* Cream variant — invert placeholder colors */
.products--blocks .product-block__mockup--empty {
  background:
    linear-gradient(135deg, rgba(15,27,45,0.02) 0%, rgba(15,27,45,0) 50%, rgba(15,27,45,0.02) 100%),
    repeating-linear-gradient(
      45deg,
      rgba(15,27,45,0.03) 0,
      rgba(15,27,45,0.03) 1px,
      transparent 1px,
      transparent 14px
    ),
    rgba(15,27,45,0.03);
}
.products--blocks .product-block__mockup--empty::before {
  border-color: rgba(15,27,45,0.12);
}
.products--blocks .product-block__mockup-tag { color: rgba(25,37,54,0.5); }
.products--blocks .product-block__mockup-note { color: rgba(25,37,54,0.3); }

/* Video/iPhone variant — centered mockup inside product-block mockup frame (2026-04-17) */
.product-block__mockup--video {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 20px;
  overflow: visible;
  background: linear-gradient(135deg, rgba(15,27,45,0.35) 0%, rgba(15,27,45,0.55) 100%);
}
.products--blocks .product-block__mockup--video {
  background: linear-gradient(135deg, rgba(15,27,45,0.04) 0%, rgba(15,27,45,0.08) 100%);
}
.product-block__mockup--video::before { content: none; }
.product-block__mockup--video .mebric-iphone {
  max-height: 100%;
}
@media (max-width: 640px) {
  .product-block__mockup--video { padding: 24px 12px; }
  .product-block__mockup--video .mebric-iphone--md { --iphone-w: 220px; }
}

.product-block__body { display: flex; flex-direction: column; gap: 20px; }
.product-block__meta {
  display: flex;
  gap: 16px;
  font-family: var(--mebric-font-en);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.product-block__status { color: var(--mebric-terra); }
.product-block__since { color: rgba(249,246,240,0.5); }

.product-block__label {
  font-family: var(--mebric-font-en);
  font-size: 12px;
  letter-spacing: 0.14em;
  color: rgba(249,246,240,0.55);
  text-transform: uppercase;
}
.product-block__name {
  font-family: var(--mebric-font-en);
  font-size: clamp(36px, 4.5vw, 56px);
  letter-spacing: -0.025em;
  color: var(--mebric-cream);
  margin: 0;
  line-height: 1;
  font-weight: 500;
}
.product-block__problem {
  font-size: 15px;
  color: rgba(249,246,240,0.55);
  line-height: 1.7;
  max-width: 480px;
  margin: 0;
}
.product-block__solution {
  font-size: clamp(17px, 1.4vw, 20px);
  color: var(--mebric-cream);
  line-height: 1.55;
  max-width: 480px;
  border-left: 2px solid var(--mebric-terra);
  padding-left: 16px;
  margin: 0;
}

.product-block__me {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 24px 0 0;
  padding: 24px 0;
  border-top: 1px solid rgba(249,246,240,0.12);
  border-bottom: 1px solid rgba(249,246,240,0.12);
}
.product-block__me > div { display: grid; grid-template-columns: 110px 1fr; gap: 16px; align-items: baseline; }
.product-block__me dt {
  font-family: var(--mebric-font-en);
  font-size: 13px;
  letter-spacing: -0.01em;
  color: rgba(249,246,240,0.7);
}
.product-block__me dt .accent { color: var(--mebric-terra); font-weight: 700; }
.product-block__me dd {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(249,246,240,0.65);
}

.product-block__metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 0;
}
.product-block__metrics dt {
  font-family: var(--mebric-font-en);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(249,246,240,0.5);
  margin-bottom: 6px;
}
.product-block__metrics dd {
  margin: 0;
  font-family: var(--mebric-font-en);
  font-size: 20px;
  letter-spacing: -0.01em;
  color: var(--mebric-cream);
  font-weight: 600;
}

.product-block__cta {
  align-self: flex-start;
  display: inline-flex;
  gap: 8px;
  color: var(--mebric-terra);
  text-decoration: none;
  font-family: var(--mebric-font-en);
  font-size: 14px;
  letter-spacing: 0.04em;
  padding-top: 16px;
  transition: gap 0.2s;
}
.product-block__cta:hover { gap: 14px; }

@media (max-width: 900px) {
  .product-block { grid-template-columns: 1fr; gap: 32px; }
  .product-block--reverse { direction: ltr; }
  .product-block__me > div { grid-template-columns: 1fr; gap: 4px; }
}

/* Big metric ($550+) */
.metric { padding: clamp(72px, 9vw, 120px) 0; background: var(--mebric-navy); color: var(--mebric-cream); border-top: 1px solid var(--mebric-line-dark); }
.metric__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.metric__num { font-family: var(--mebric-font-en); font-weight: 300; font-size: clamp(72px, 11vw, 160px); letter-spacing: -0.04em; line-height: 1; color: var(--mebric-cream); font-variant-numeric: tabular-nums; }
.metric__num .plus { color: var(--mebric-terra); }
.metric__copy { color: rgba(249,246,240,0.72); font-size: clamp(15px, 1.1vw, 17px); line-height: 1.7; max-width: 460px; }
@media (max-width: 900px) { .metric__grid { grid-template-columns: 1fr; gap: 24px; } }

/* Principles (우리가 일하는 방식) */
.principles { padding: clamp(96px, 12vw, 160px) 0; background: var(--mebric-cream); }
.principles__title { font-size: clamp(28px, 3.6vw, 44px); letter-spacing: -0.02em; color: var(--mebric-navy); margin-bottom: 64px; max-width: 640px; }
.principles__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px 64px; }
.principle { border-top: 1px solid var(--mebric-line-light); padding-top: 24px; transition: border-color 260ms ease; }
.principle:hover { border-color: var(--mebric-terra); }
.principle__num {
  font-family: var(--mebric-font-en);
  font-weight: 300;                        /* Figma Light */
  font-size: clamp(64px, 7vw, 96px);       /* Figma 96px */
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--mebric-terra);
  font-variant-numeric: tabular-nums;
  margin-bottom: 16px;
  display: block;
}
.principle__head { font-size: 22px; font-weight: 700; color: var(--mebric-navy); letter-spacing: -0.015em; margin: 0 0 12px; line-height: 1.3; }
.principle__body { font-size: 14px; line-height: 1.75; color: rgba(25,37,54,0.72); }
@media (max-width: 768px) { .principles__grid { grid-template-columns: 1fr; gap: 32px; } }

/* Principles — dark variant */
.principles--dark { background: var(--mebric-navy); color: var(--mebric-cream); }
.principles--dark .mebric-eyebrow--bar { color: var(--mebric-cream); }
.principles__head {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 48px;
  align-items: end;
  margin-bottom: 80px;
}
.principles--dark .principles__title {
  font-size: clamp(32px, 3.6vw, 48px);   /* Figma 48px */
  letter-spacing: -0.02em;
  line-height: 1.3;
  color: var(--mebric-cream);
  font-weight: 700;                        /* Figma Bold */
  max-width: 640px;
  margin-bottom: 0;
}
.principles--dark .principles__title .accent { color: var(--mebric-terra); }
.principles__lead {
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.75;
  color: rgba(249,246,240,0.7);
  max-width: 420px;
  justify-self: end;
}
.principles--dark .principles__grid {
  padding-bottom: 80px;
  border-bottom: 1px solid rgba(249,246,240,0.12);
}
.principles--dark .principle {
  border-top-color: rgba(249,246,240,0.12);
}
.principles--dark .principle:hover { border-color: var(--mebric-terra); }
.principles--dark .principle__num { color: var(--mebric-terra); }
.principles--dark .principle__head {
  font-size: clamp(18px, 1.6vw, 22px);
  color: var(--mebric-cream);
  letter-spacing: -0.01em;
}
.principles--dark .principle__body {
  font-size: 15px;
  line-height: 1.75;
  color: rgba(249,246,240,0.72);
  max-width: 480px;
}

/* Recently Shipped */
.recently-shipped { margin-top: 64px; }
.recently-shipped .mebric-eyebrow {
  font-family: var(--mebric-font-en);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mebric-terra);
  margin-bottom: 24px;
}
.recently-shipped__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0; }
.recently-shipped__item {
  display: grid;
  grid-template-columns: 100px 220px 1fr;
  gap: 24px;
  padding: 16px 0;
  border-top: 1px solid rgba(249,246,240,0.08);
  align-items: baseline;
}
.recently-shipped__item:last-child { border-bottom: 1px solid rgba(249,246,240,0.08); }
.recently-shipped__date {
  font-family: var(--mebric-font-en);
  font-size: 12px;
  letter-spacing: 0.1em;
  color: rgba(249,246,240,0.5);
}
.recently-shipped__name {
  font-size: 15px;
  color: var(--mebric-cream);
  font-weight: 600;
}
.recently-shipped__desc {
  font-size: 14px;
  color: rgba(249,246,240,0.6);
  line-height: 1.6;
}

@media (max-width: 900px) {
  .principles__head { grid-template-columns: 1fr; gap: 24px; align-items: start; }
  .principles__lead { justify-self: start; }
  .recently-shipped__item { grid-template-columns: 1fr; gap: 4px; padding: 12px 0; }
}

/* ===== Day At MEBRIC — Photo Banner ===== */
.day-at {
  position: relative;
  overflow: hidden;
  padding: clamp(120px, 14vw, 200px) 0;
  background: var(--mebric-navy);
  color: var(--mebric-cream);
}
.day-at__bg { position: absolute; inset: 0; z-index: 0; }
.day-at__bg img {
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0.55;
  transform: scale(1.02);
  transition: transform 9s ease-out;
}
.day-at.is-inview .day-at__bg img { transform: scale(1.08); }
.day-at__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(15,27,45,0.55) 0%, rgba(15,27,45,0.88) 100%);
}
.day-at__inner { position: relative; z-index: 1; max-width: 960px; }
.day-at__title {
  font-size: clamp(40px, 5.8vw, 80px);
  letter-spacing: -0.03em;
  line-height: 1.08;
  color: var(--mebric-cream);
  margin: 16px 0 48px;
  font-weight: 300;
}
.day-at__title .accent { color: var(--mebric-terra); }
.day-at__microdata {
  display: flex;
  gap: clamp(40px, 5vw, 80px);
  flex-wrap: wrap;
  margin: 0;
  padding-top: 32px;
  border-top: 1px solid rgba(249,246,240,0.2);
}
.day-at__microdata div { display: flex; flex-direction: column; gap: 6px; }
.day-at__microdata dt {
  font-family: var(--mebric-font-en);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(249,246,240,0.55);
}
.day-at__microdata dd {
  margin: 0;
  font-family: var(--mebric-font-en);
  font-size: 14px;
  letter-spacing: 0.04em;
  color: var(--mebric-cream);
}

/* Eyebrow light variant (for navy overlays) */
.mebric-eyebrow--light { color: var(--mebric-cream); }
.mebric-eyebrow--light::before { background: var(--mebric-terra); }

/* ===== Join The Team — Cream section w/ Now Hiring card ===== */
.join {
  background: var(--mebric-cream);
  padding: clamp(96px, 12vw, 160px) 0;
  border-top: 1px solid var(--mebric-line-light);
}
.join__grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: start;
}
.join__title {
  font-size: clamp(32px, 4vw, 52px);       /* Figma 52px */
  letter-spacing: -0.025em;
  line-height: 1.15;
  color: var(--mebric-navy);
  font-weight: 700;                         /* Figma Bold */
  margin: 24px 0;
  word-break: keep-all;                     /* P1-4: preserve Korean word integrity */
  overflow-wrap: break-word;
}
.join__title .accent { color: var(--mebric-terra); }
.join__sub {
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.75;
  color: rgba(25,37,54,0.75);
  max-width: 540px;
  margin-bottom: 32px;
}
.join__mail {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  border: 1px solid var(--mebric-navy);
  color: var(--mebric-navy);
  font-family: var(--mebric-font-en);
  font-size: 14px;
  letter-spacing: 0.04em;
  text-decoration: none;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.join__mail:hover { background: var(--mebric-navy); color: var(--mebric-cream); border-color: var(--mebric-navy); }

.join__hiring {
  background: var(--mebric-navy);
  color: var(--mebric-cream);
  padding: clamp(32px, 3.5vw, 48px);
  position: sticky;
  top: 120px;
}
.join__hiring-label {
  font-family: var(--mebric-font-en);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mebric-terra);
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(249,246,240,0.18);
  margin-bottom: 8px;
}
.join__hiring-list { list-style: none; margin: 0; padding: 0; }
.join__hiring-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  border-bottom: 1px solid rgba(249,246,240,0.12);
  font-size: 15px;
  cursor: pointer;
  transition: color 0.2s;
}
.join__hiring-item:last-child { border-bottom: 0; }
.join__hiring-item:hover { color: var(--mebric-terra); }
.join__hiring-arrow { color: var(--mebric-terra); font-family: var(--mebric-font-en); }

@media (max-width: 900px) {
  .join__grid { grid-template-columns: 1fr; }
  .join__hiring { position: static; }
  .day-at__microdata { gap: 32px; }
}

/* Motion reveal utilities */
.reveal { opacity: 0; transform: translateY(20px); transition: var(--tx-reveal); will-change: opacity, transform; }
.reveal.is-inview { opacity: 1; transform: translateY(0); }
.reveal--delay-1 { transition-delay: var(--stagger-delay-1); }
.reveal--delay-2 { transition-delay: var(--stagger-delay-2); }
.reveal--delay-3 { transition-delay: var(--stagger-delay-3); }
.reveal--delay-4 { transition-delay: var(--stagger-delay-4); }
.reveal--delay-5 { transition-delay: var(--stagger-delay-5); }
.reveal--delay-6 { transition-delay: var(--stagger-delay-6); }

/* ---------- Task B (#22) · data-motion reveal system --------------------
   Editorial motion tokens + opacity/transform-only patterns. Activated by
   motion.js once the element crosses the IO threshold (class: is-motion-in).
   Respects prefers-reduced-motion (see §7 of DESIGN-BRIEF-TASK-B).         */
:root {
  --motion-duration-instant: 100ms;
  --motion-duration-fast: 180ms;
  --motion-duration-base: 280ms;
  --motion-duration-slow: 480ms;
  --motion-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --motion-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --motion-ease-standard: cubic-bezier(0.2, 0, 0.2, 1);
  --motion-stagger: 60ms;
  --motion-y-offset: 16px;
}

[data-motion] {
  /* Initial state + transition are applied only when JS has armed the element
     via .is-motion-ready. Prevents FOIC on no-JS / reduced-motion fallbacks. */
  transition:
    opacity var(--motion-duration-base) var(--motion-ease-out),
    transform var(--motion-duration-base) var(--motion-ease-out);
  will-change: auto;
}
[data-motion].is-motion-ready { opacity: 0; }
[data-motion="fade-up"].is-motion-ready { transform: translateY(var(--motion-y-offset)); }
[data-motion="fade"].is-motion-ready { transform: none; }
[data-motion="grow-in"].is-motion-ready { transform: translateY(24px) scale(0.98); transition-duration: var(--motion-duration-slow); }

[data-motion].is-motion-in { opacity: 1; transform: none; }

/* Group stagger: children inherit transition but per-child --i index → delay */
[data-motion="fade-up-group"].is-motion-ready > * { opacity: 0; transform: translateY(var(--motion-y-offset)); transition: opacity var(--motion-duration-base) var(--motion-ease-out), transform var(--motion-duration-base) var(--motion-ease-out); }
[data-motion="fade-up-group"].is-motion-ready > * { transition-delay: calc(var(--i, 0) * var(--motion-stagger)); }
[data-motion="fade-up-group"].is-motion-in > * { opacity: 1; transform: none; }

/* Divider draw — only use on thin horizontal rules */
[data-motion="divider-draw"].is-motion-ready { width: 0 !important; opacity: 1; transition: width 600ms var(--motion-ease-out); }
[data-motion="divider-draw"].is-motion-in { width: 100% !important; }

/* Word-by-word hero stagger */
.split-words { display: inline; }
.split-words .word { display: inline-block; overflow: hidden; padding: 0 0.02em; }
.split-words .word > span { display: inline-block; transform: translateY(110%); transition: transform 900ms cubic-bezier(.2,.9,.3,1); }
.hero.is-ready .split-words .word > span { transform: translateY(0); }
.split-words .word:nth-child(1) > span { transition-delay: 60ms; }
.split-words .word:nth-child(2) > span { transition-delay: 140ms; }
.split-words .word:nth-child(3) > span { transition-delay: 220ms; }
.split-words .word:nth-child(4) > span { transition-delay: 300ms; }
.split-words .word:nth-child(5) > span { transition-delay: 380ms; }
.split-words .word:nth-child(6) > span { transition-delay: 460ms; }
.split-words .word:nth-child(7) > span { transition-delay: 540ms; }
.split-words .word:nth-child(8) > span { transition-delay: 620ms; }

/* Magnetic link underline */
.link-underline { position: relative; display: inline-block; }
.link-underline::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -3px;
  height: 1px; background: var(--mebric-terra);
  transform: scaleX(0); transform-origin: right;
  transition: transform 380ms cubic-bezier(.2,.9,.3,1);
}
.link-underline:hover::after { transform: scaleX(1); transform-origin: left; }

/* =====================================================================
   ADMIN — MEBRIC brand-aligned
   ===================================================================== */
.admin {
  min-height: 100vh;
  background: #FCFAF5;
  color: var(--mebric-navy);
  font-family: var(--mebric-font-kr);
  -webkit-font-smoothing: antialiased;
}
.admin a { color: inherit; text-decoration: none; }
.admin * { box-sizing: border-box; }

/* Top bar */
.admin-bar {
  position: sticky; top: 0; z-index: 40;
  background: rgba(252,250,245,0.86);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--mebric-line-light);
  padding: 16px 32px;
  display: flex; align-items: center; justify-content: space-between;
}
.admin-bar__brand { display: inline-flex; align-items: center; gap: 12px; }
.admin-bar__brand img { height: 20px; width: auto; }
.admin-bar__word { font-family: var(--mebric-font-en); font-weight: 700; font-size: 16px; letter-spacing: 0.02em; color: var(--mebric-navy); }
.admin-bar__tag {
  display: inline-block; padding: 2px 8px; border-radius: 2px;
  background: var(--mebric-navy); color: var(--mebric-cream);
  font-family: var(--mebric-font-en); font-size: 10px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
}
.admin-bar__nav { display: flex; gap: 28px; }
.admin-bar__nav a { font-family: var(--mebric-font-en); font-size: 12px; letter-spacing: 0.06em; color: rgba(25,37,54,0.65); transition: color 160ms ease; }
.admin-bar__nav a:hover, .admin-bar__nav a.is-active { color: var(--mebric-terra); }
/* B1 (2026-04-18): "coming soon" modules — styled muted until C1/C3/D1 land */
.admin-bar__nav a.admin-bar__nav-coming { color: rgba(25,37,54,0.28); }
.admin-bar__nav a.admin-bar__nav-coming:hover { color: rgba(25,37,54,0.5); }
.admin-bar__user { display: inline-flex; align-items: center; gap: 12px; font-size: 13px; color: rgba(25,37,54,0.7); }
.admin-bar__logout { font-family: var(--mebric-font-en); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(25,37,54,0.5); cursor: pointer; background: none; border: 0; padding: 0; transition: color 160ms ease; }
.admin-bar__logout:hover { color: var(--mebric-terra); }

/* Layout */
.admin-wrap { max-width: 1120px; margin: 0 auto; padding: 48px 32px 96px; }
.admin-wrap--narrow { max-width: 720px; }

/* Page head */
.admin-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 40px; gap: 24px; flex-wrap: wrap; }
.admin-head__kicker { font-family: var(--mebric-font-en); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--mebric-terra); margin-bottom: 10px; }
.admin-head__title { font-size: clamp(28px, 3.4vw, 40px); line-height: 1.2; letter-spacing: -0.02em; color: var(--mebric-navy); font-weight: 700; margin: 0; }
.admin-head__sub { font-size: 14px; line-height: 1.7; color: rgba(25,37,54,0.65); margin-top: 12px; max-width: 520px; }

/* Buttons */
.admin-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 20px;
  font-family: var(--mebric-font-en); font-size: 13px; font-weight: 500;
  letter-spacing: 0.04em; border-radius: 2px; cursor: pointer;
  border: 1px solid transparent; background: transparent;
  transition: transform 180ms ease, background 180ms ease, color 180ms ease, border-color 180ms ease;
  white-space: nowrap;
}
.admin-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.admin-btn--primary { background: var(--mebric-terra); color: #fff; }
.admin-btn--primary:hover:not(:disabled) { background: #a8452a; transform: translateY(-1px); }
.admin-btn--ghost { color: var(--mebric-navy); border-color: rgba(15,27,45,0.2); }
.admin-btn--ghost:hover:not(:disabled) { border-color: var(--mebric-navy); background: var(--mebric-navy); color: var(--mebric-cream); }
.admin-btn--danger { color: #B43838; border-color: rgba(180,56,56,0.3); }
.admin-btn--danger:hover:not(:disabled) { background: #B43838; color: #fff; border-color: #B43838; }
.admin-btn--sm { padding: 8px 14px; font-size: 11px; }

/* Cards */
.admin-card {
  background: #FFFFFF;
  border: 1px solid var(--mebric-line-light);
  border-radius: 4px;
  padding: 28px 32px;
  margin-bottom: 20px;
}
.admin-card--muted { background: #F5F1E8; }

/* Stats row */
.admin-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 40px; }
.admin-stat {
  background: #fff; border: 1px solid var(--mebric-line-light);
  padding: 20px 22px; border-radius: 4px;
}
.admin-stat__label { font-family: var(--mebric-font-en); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(25,37,54,0.55); }
.admin-stat__num { font-family: var(--mebric-font-en); font-weight: 300; font-size: 36px; line-height: 1.1; letter-spacing: -0.02em; color: var(--mebric-navy); margin-top: 8px; font-variant-numeric: tabular-nums; }
.admin-stat__num .plus { color: var(--mebric-terra); }
@media (max-width: 768px) { .admin-stats { grid-template-columns: repeat(2, 1fr); } }

/* Table */
.admin-table-wrap { background: #fff; border: 1px solid var(--mebric-line-light); border-radius: 4px; overflow: hidden; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.admin-table thead th {
  text-align: left; padding: 14px 20px;
  font-family: var(--mebric-font-en); font-size: 10px; font-weight: 500;
  letter-spacing: 0.14em; text-transform: uppercase; color: rgba(25,37,54,0.55);
  background: #FAF7F0; border-bottom: 1px solid var(--mebric-line-light);
}
.admin-table tbody td { padding: 18px 20px; border-bottom: 1px solid var(--mebric-line-light); vertical-align: middle; }
.admin-table tbody tr:last-child td { border-bottom: 0; }
.admin-table tbody tr { transition: background 140ms ease; }
.admin-table tbody tr:hover { background: #FAF7F0; }
.admin-table__title { font-weight: 600; color: var(--mebric-navy); letter-spacing: -0.005em; }
.admin-table__title a:hover { color: var(--mebric-terra); }
.admin-table__meta { font-family: var(--mebric-font-en); font-size: 11px; color: rgba(25,37,54,0.55); letter-spacing: 0.04em; }
.admin-table__actions { display: inline-flex; gap: 6px; justify-content: flex-end; }

/* Status pills */
.pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 2px;
  font-family: var(--mebric-font-en); font-size: 10px; font-weight: 500;
  letter-spacing: 0.14em; text-transform: uppercase;
}
.pill::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.pill--published { background: rgba(53,145,95,0.1); color: #35915F; }
.pill--draft { background: rgba(25,37,54,0.08); color: rgba(25,37,54,0.6); }
.pill--archived { background: rgba(25,37,54,0.05); color: rgba(25,37,54,0.4); }

/* Forms */
.admin-field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 24px; }
.admin-field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.admin-label { font-family: var(--mebric-font-en); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(25,37,54,0.55); }
.admin-input, .admin-select, .admin-textarea {
  width: 100%; padding: 12px 14px;
  font-family: var(--mebric-font-kr); font-size: 14px;
  color: var(--mebric-navy);
  background: #fff; border: 1px solid var(--mebric-line-light); border-radius: 3px;
  transition: border-color 160ms ease, box-shadow 160ms ease;
}
.admin-input:focus, .admin-select:focus, .admin-textarea:focus {
  outline: none;
  border-color: var(--mebric-terra);
  box-shadow: 0 0 0 3px rgba(200,90,58,0.12);
}
.admin-textarea { min-height: 320px; resize: vertical; font-family: ui-monospace, 'SF Mono', Menlo, monospace; font-size: 13px; line-height: 1.7; }
.admin-help { font-size: 12px; color: rgba(25,37,54,0.5); line-height: 1.6; }

/* Login */
.admin-login {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: var(--mebric-navy); color: var(--mebric-cream);
  padding: 24px; position: relative; overflow: hidden;
}
.admin-login::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at top right, rgba(200,90,58,0.18), transparent 55%);
  pointer-events: none;
}
.admin-login__card {
  position: relative; z-index: 1;
  width: 100%; max-width: 440px;
  background: rgba(249,246,240,0.03);
  border: 1px solid var(--mebric-line-dark);
  padding: 48px;
  border-radius: 4px;
  backdrop-filter: blur(20px);
}
.admin-login__brand { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 40px; }
.admin-login__brand img { height: 22px; filter: invert(1) brightness(2); }
.admin-login__word { font-family: var(--mebric-font-en); font-weight: 700; font-size: 18px; letter-spacing: 0.02em; color: var(--mebric-cream); }
.admin-login__tag { color: var(--mebric-terra); font-family: var(--mebric-font-en); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; margin-left: 4px; }
.admin-login h1 { font-size: 28px; letter-spacing: -0.02em; line-height: 1.25; margin: 0 0 8px; color: var(--mebric-cream); font-weight: 700; }
.admin-login__sub { font-size: 13px; color: rgba(249,246,240,0.55); margin-bottom: 36px; }
.admin-login .admin-label { color: rgba(249,246,240,0.5); }
.admin-login .admin-input {
  background: rgba(15,27,45,0.4);
  border-color: rgba(249,246,240,0.15);
  color: var(--mebric-cream);
}
.admin-login .admin-input:focus { background: rgba(15,27,45,0.6); border-color: var(--mebric-terra); }
.admin-login__error {
  font-size: 12px; color: #E28070; padding: 10px 12px;
  background: rgba(226,128,112,0.1); border-radius: 3px;
  margin-bottom: 16px; display: none;
}
.admin-login__error.is-shown { display: block; }
.admin-login__foot { margin-top: 32px; text-align: center; font-size: 11px; letter-spacing: 0.12em; color: rgba(249,246,240,0.35); font-family: var(--mebric-font-en); text-transform: uppercase; }

/* Editor layout */
.editor-grid { display: grid; grid-template-columns: 1fr 320px; gap: 24px; align-items: start; }
.editor-side { position: sticky; top: 96px; }
.editor-side .admin-card { padding: 24px; }
.editor-side h3 { font-family: var(--mebric-font-en); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(25,37,54,0.55); margin: 0 0 16px; font-weight: 500; }
@media (max-width: 900px) { .editor-grid { grid-template-columns: 1fr; } .editor-side { position: static; } }

/* Career public page */
.career-hero {
  padding: clamp(80px, 10vw, 140px) 0 clamp(56px, 7vw, 96px);
  background: var(--mebric-cream);
  border-bottom: 1px solid var(--mebric-line-light);
}
.career-hero h1 { font-size: clamp(36px, 5.4vw, 72px); line-height: 1.08; letter-spacing: -0.03em; color: var(--mebric-navy); font-weight: 700; margin: 20px 0 0; max-width: 820px; }
.career-hero__accent { color: var(--mebric-terra); }
.career-hero__sub { margin-top: 28px; font-size: clamp(15px, 1.1vw, 17px); line-height: 1.7; color: rgba(25,37,54,0.72); max-width: 520px; }

.jobs { padding: clamp(72px, 9vw, 120px) 0; background: var(--mebric-cream); }
.jobs__filters { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 48px; }
.jobs__filter {
  padding: 8px 16px; border: 1px solid var(--mebric-line-light);
  border-radius: 2px; background: transparent;
  font-family: var(--mebric-font-en); font-size: 12px; letter-spacing: 0.06em;
  color: rgba(25,37,54,0.65); cursor: pointer; transition: all 200ms ease;
}
.jobs__filter.is-active { background: var(--mebric-navy); color: var(--mebric-cream); border-color: var(--mebric-navy); }
.jobs__filter:hover:not(.is-active) { border-color: var(--mebric-navy); color: var(--mebric-navy); }

.job {
  display: grid; grid-template-columns: 160px 1fr auto;
  gap: 32px; align-items: center;
  padding: 28px 0; border-bottom: 1px solid var(--mebric-line-light);
  transition: background 180ms ease;
}
.job:first-child { border-top: 1px solid var(--mebric-line-light); }
.job:hover { background: rgba(15,27,45,0.02); }
.job:hover .job__title { color: var(--mebric-terra); }
.job:hover .job__arrow { transform: translateX(4px); color: var(--mebric-terra); }
.job__team { font-family: var(--mebric-font-en); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(25,37,54,0.55); }
.job__body { min-width: 0; }
.job__title { font-size: clamp(20px, 2vw, 26px); font-weight: 600; letter-spacing: -0.015em; color: var(--mebric-navy); transition: color 200ms ease; }
.job__meta { display: flex; gap: 12px; margin-top: 6px; font-size: 13px; color: rgba(25,37,54,0.6); font-family: var(--mebric-font-en); letter-spacing: 0.02em; }
.job__meta span::after { content: '·'; margin-left: 12px; color: rgba(25,37,54,0.3); }
.job__meta span:last-child::after { content: ''; }
.job__arrow { font-family: var(--mebric-font-en); font-size: 22px; color: rgba(25,37,54,0.35); transition: transform 260ms ease, color 200ms ease; }
.jobs__empty { padding: 48px 0; text-align: center; color: rgba(25,37,54,0.55); font-size: 14px; }
@media (max-width: 768px) {
  .job { grid-template-columns: 1fr; gap: 10px; padding: 24px 0; }
  .job__arrow { display: none; }
}

/* Accessibility: reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; }
  .hero.is-ready .split-words .word > span { transform: none; }
  .ticker__track { animation: none; }
  /* Task B (#22): force data-motion elements into final state at rest */
  [data-motion], [data-motion] > * {
    opacity: 1 !important;
    transform: none !important;
    width: auto !important;
  }
}

/* ---------- Admin · /admin/bookings additions (PR #21) ---------- */
.admin-filters {
  display: flex;
  gap: 20px;
  align-items: flex-end;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.admin-filter { display: flex; flex-direction: column; gap: 6px; }
.admin-filter__label {
  font-family: var(--mebric-font-en);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(25, 37, 54, 0.55);
}
.admin-filter .admin-input {
  min-width: 180px;
}
.admin-empty {
  text-align: center;
  padding: 48px;
  color: rgba(25, 37, 54, 0.5);
  font-size: 14px;
}
.badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  font-family: var(--mebric-font-en);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: lowercase;
}
.badge--confirmed            { background: #d1fae5; color: #065f46; }
.badge--pending              { background: #fef3c7; color: #78350f; }
.badge--cancelled            { background: #e5e7eb; color: #374151; }
.badge--cancelled_by_guest   { background: #e5e7eb; color: #374151; }
.badge--failed               { background: #fee2e2; color: #991b1b; }
.badge--reschedule_requested { background: #dbeafe; color: #1e40af; }
.badge--completed            { background: #ede9fe; color: #5b21b6; }
.badge--approved             { background: #d1fae5; color: #065f46; }
.badge--declined             { background: #fee2e2; color: #991b1b; }
.badge--expired              { background: #e5e7eb; color: #374151; }

/* Admin tabs (PR #22) */
.admin-tabs {
  display: flex;
  gap: 24px;
  margin: 24px 0 20px;
  border-bottom: 1px solid rgba(25, 37, 54, 0.08);
}
.admin-tabs a {
  padding: 10px 4px;
  text-decoration: none;
  color: rgba(25, 37, 54, 0.55);
  font-family: var(--mebric-font-en);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.06em;
  border-bottom: 2px solid transparent;
  transition: color 160ms, border-color 160ms;
}
.admin-tabs a:hover { color: var(--mebric-navy); }
.admin-tabs a.is-active {
  color: var(--mebric-navy);
  border-bottom-color: var(--mebric-terra);
}
.admin-tabs__pill {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 8px;
  border-radius: 999px;
  background: var(--mebric-terra);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0;
}

/* Reschedule request cards (PR #22) */
.rr-list {
  display: grid;
  gap: 16px;
  margin-top: 16px;
}
.rr-card {
  border: 1px solid rgba(25, 37, 54, 0.1);
  border-radius: 12px;
  padding: 20px;
  background: #fff;
}
.rr-card__head h3 {
  margin: 0 0 4px;
  font-family: var(--mebric-font-en);
  font-size: 16px;
  font-weight: 600;
}
.rr-card__head p {
  margin: 0;
  color: rgba(25, 37, 54, 0.6);
  font-size: 13px;
}
.rr-card__dl {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 4px 16px;
  margin: 14px 0 0;
  font-size: 13px;
}
.rr-card__dl dt {
  font-family: var(--mebric-font-en);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(25, 37, 54, 0.55);
  padding-top: 2px;
  margin: 0;
}
.rr-card__dl dd { margin: 0; color: var(--mebric-ink); }
.rr-actions {
  display: flex;
  gap: 10px;
  align-items: stretch;
  margin-top: 16px;
  flex-wrap: wrap;
}
.rr-note {
  flex: 1;
  min-width: 240px;
  min-height: 60px;
  resize: vertical;
  padding: 8px 10px;
  font-family: inherit;
  font-size: 13px;
  border: 1px solid rgba(25, 37, 54, 0.15);
  border-radius: 6px;
  background: #fff;
}
.rr-note:focus { outline: 2px solid var(--mebric-terra); outline-offset: 1px; border-color: transparent; }

/* =====================================================
   Motion v2 — added 2026-04-19 (DP2)
   Standardized hover/focus across CTA / Card / Link
   Arrow micro-interaction on .mebric-btn__arrow
   ===================================================== */

/* CTA hover pattern — translateY(-2px) + shadow-2 */
.mebric-cta,
.mebric-btn,
.mebric-cta-primary,
.mebric-cta-secondary,
.mebric-cta-tertiary {
  transition: var(--tx-hover);
  transform: translateY(0);
  will-change: transform, box-shadow;
}
.mebric-cta:hover,
.mebric-btn:hover,
.mebric-cta-primary:hover,
.mebric-cta-secondary:hover,
.mebric-cta-tertiary:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
}
.mebric-cta:active,
.mebric-btn:active,
.mebric-cta-primary:active,
.mebric-cta-secondary:active,
.mebric-cta-tertiary:active {
  transform: translateY(0);
  box-shadow: var(--shadow-1);
}

/* CTA arrow micro-interaction — translateX on hover/focus */
.mebric-cta__arrow,
.mebric-btn__arrow {
  display: inline-block;
  transition: transform var(--dur-fast) var(--ease-spring);
  margin-left: var(--space-2);
}
.mebric-cta:hover .mebric-cta__arrow,
.mebric-btn:hover .mebric-btn__arrow,
.mebric-cta:focus-visible .mebric-cta__arrow,
.mebric-btn:focus-visible .mebric-btn__arrow {
  transform: translateX(4px);
}

/* Card hover — terra border + lift */
.mebric-card,
.mebric-product-card,
.mebric-feature-card {
  transition: var(--tx-hover);
  border: 1px solid transparent;
  will-change: transform, box-shadow, border-color;
}
.mebric-card:hover,
.mebric-product-card:hover,
.mebric-feature-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-1);
  border-color: var(--mebric-terra);
}

/* Link — inline underline animation */
.mebric-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  transition: color var(--dur-fast) var(--ease-out);
}
.mebric-link::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-base) var(--ease-out);
}
.mebric-link:hover::after,
.mebric-link:focus-visible::after {
  transform: scaleX(1);
}

/* Focus visible — unified ring across interactive surfaces */
.mebric-cta:focus-visible,
.mebric-btn:focus-visible,
.mebric-card:focus-visible,
.mebric-link:focus-visible {
  outline: 2px solid var(--mebric-terra);
  outline-offset: 2px;
  border-radius: var(--radius-xs);
}

/* Reduced motion — disable transforms & transitions (durations already 0ms) */
@media (prefers-reduced-motion: reduce) {
  .mebric-cta,
  .mebric-btn,
  .mebric-card,
  .mebric-product-card,
  .mebric-feature-card {
    transform: none !important;
    transition: none !important;
  }
  .mebric-cta__arrow,
  .mebric-btn__arrow {
    transform: none !important;
  }
  .mebric-link::after {
    transform: scaleX(0) !important;
    transition: none !important;
  }
}

/* =====================================================
   Component Library v2 — added 2026-04-19 (DP3)
   Figma: Brand-Identity · DP3 Component Library v1 (node 659:11)
     btn-primary   659:26  · btn-secondary 659:39  · btn-tertiary 659:51
     card-default  659:64  · card-featured 659:77  · card-minimal 659:90
     form-input    659:106 · form-textarea 659:122
   Tokens: --space-*, --radius-xs, --shadow-1/2, --dur-fast, --ease-out/spring
   ===================================================== */

/* --- Button base + variants --- */
.mebric-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  min-height: 44px;
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-xs);
  border: 1.5px solid transparent;
  font-family: var(--mebric-font-en);
  font-size: 15px;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  background: transparent;
  color: var(--mebric-ink);
}

.mebric-btn--primary {
  background: var(--mebric-terra);
  color: var(--mebric-cream);
  border-color: var(--mebric-terra);
}
.mebric-btn--primary:hover {
  filter: brightness(1.08);
}
.mebric-btn--primary:active {
  filter: brightness(0.96);
}

.mebric-btn--secondary {
  background: transparent;
  color: var(--mebric-terra);
  border-color: var(--mebric-terra);
}
.mebric-btn--secondary:hover {
  background: rgba(200, 90, 58, 0.08);
}
.mebric-btn--secondary:active {
  background: rgba(200, 90, 58, 0.14);
}

.mebric-btn--tertiary {
  padding: var(--space-2) 0;
  min-height: 32px;
  position: relative;
  color: var(--mebric-ink);
  border-color: transparent;
  background: transparent;
}
.mebric-btn--tertiary::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 4px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-base) var(--ease-out);
}
.mebric-btn--tertiary:hover {
  color: var(--mebric-terra);
  transform: none;
  box-shadow: none;
  background: transparent;
}
.mebric-btn--tertiary:hover::after {
  transform: scaleX(1);
}

.mebric-btn:disabled,
.mebric-btn[aria-disabled="true"] {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

.mebric-btn--sm { min-height: 36px; padding: var(--space-2) var(--space-4); font-size: 14px; }
.mebric-btn--lg { min-height: 52px; padding: var(--space-4) var(--space-6); font-size: 16px; }

/* --- Card base + variants (Default / Featured / Minimal) --- */
.mebric-card {
  position: relative;
  background: var(--mebric-cream);
  border: 1px solid var(--mebric-line-light);
  border-radius: var(--radius-xs);
  padding: var(--space-card-padding);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.mebric-card__title {
  font-size: 20px;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--mebric-ink);
  margin: 0;
}
.mebric-card__body {
  font-size: 15px;
  line-height: 1.6;
  color: var(--mebric-muted);
  margin: 0;
}
.mebric-card__cta { margin-top: auto; }
.mebric-card__tag {
  display: inline-block;
  align-self: flex-start;
  padding: var(--space-1) var(--space-3);
  background: var(--mebric-terra);
  color: var(--mebric-cream);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  border-radius: var(--radius-xs);
  text-transform: uppercase;
}

/* Featured — navy bg, cream text, 4px terra accent bar on hover (Figma 659:77) */
.mebric-card--featured {
  background: var(--mebric-navy);
  border-color: transparent;
  overflow: hidden;
}
.mebric-card--featured::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: var(--mebric-terra);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform var(--dur-base) var(--ease-out);
}
.mebric-card--featured:hover::before,
.mebric-card--featured:focus-within::before {
  transform: scaleY(1);
}
.mebric-card--featured .mebric-card__title,
.mebric-card--featured .mebric-card__body {
  color: var(--mebric-cream);
}
.mebric-card--featured:hover {
  border-color: var(--mebric-terra);
  box-shadow: var(--shadow-2);
}

/* Minimal — borderless, terra 4% tint on hover */
.mebric-card--minimal {
  background: transparent;
  border: none;
  padding: var(--space-4) 0;
}
.mebric-card--minimal:hover {
  background: rgba(200, 90, 58, 0.04);
  transform: none;
  box-shadow: none;
  border: none;
}

/* --- Form --- */
.mebric-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-form-field-gap);
  max-width: 560px;
}
.mebric-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.mebric-field__label {
  font-size: 13px;
  font-weight: 500;
  color: var(--mebric-ink);
  letter-spacing: 0;
}
.mebric-field__required {
  color: var(--mebric-terra);
  margin-left: 2px;
}
.mebric-field__input,
.mebric-field__textarea,
.mebric-field__select {
  display: block;
  width: 100%;
  min-height: 44px;
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--mebric-line-light);
  border-radius: var(--radius-xs);
  background: var(--mebric-cream);
  color: var(--mebric-ink);
  font-family: inherit;
  font-size: 15px;
  line-height: 1.5;
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out),
              background-color var(--dur-fast) var(--ease-out);
}
.mebric-field__textarea {
  min-height: 120px;
  resize: vertical;
}
.mebric-field__input:focus,
.mebric-field__textarea:focus,
.mebric-field__select:focus {
  outline: none;
  border-color: var(--mebric-terra);
  box-shadow: 0 0 0 3px rgba(200, 90, 58, 0.15);
}
.mebric-field__input::placeholder,
.mebric-field__textarea::placeholder {
  color: var(--mebric-muted);
}
.mebric-field__helper {
  font-size: 12px;
  color: var(--mebric-muted);
  line-height: 1.5;
  margin: 0;
}

/* Error — Figma spec: terra border (same hue, no glow) + 4% terra tint bg */
.mebric-field--error .mebric-field__input,
.mebric-field--error .mebric-field__textarea,
.mebric-field--error .mebric-field__select {
  border-color: var(--mebric-terra);
  background: rgba(200, 90, 58, 0.04);
}
.mebric-field--error .mebric-field__input:focus,
.mebric-field--error .mebric-field__textarea:focus,
.mebric-field--error .mebric-field__select:focus {
  box-shadow: 0 0 0 3px rgba(200, 90, 58, 0.22);
}
.mebric-field__error {
  font-size: 12px;
  color: var(--mebric-terra);
  font-weight: 500;
  line-height: 1.5;
  margin: 0;
}

.mebric-field__input:disabled,
.mebric-field__textarea:disabled,
.mebric-field__select:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: rgba(25, 37, 54, 0.04);
}

/* --- /contact 3 CTA hierarchy grid layout (DP3) ---
   Primary + Secondary side-by-side (row 1), Tertiary full-width (row 2).
   Uses selector override to beat meet.css 3-col default. */
.contact-mail-grid.contact-cards {
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
  align-items: stretch;
}
@media (max-width: 900px) {
  .contact-mail-grid.contact-cards { grid-template-columns: 1fr; }
}
.contact-card--tertiary {
  grid-column: 1 / -1;
  margin-top: var(--space-6);
  padding: var(--space-4) 0 !important;
  border-top: 1px solid var(--mebric-line-light);
  border-bottom: none;
  border-radius: 0;
  background: transparent !important;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-6);
}
.contact-card--tertiary .mebric-card__title { font-size: 16px; }
.contact-card--tertiary .mebric-card__body { font-size: 13px; }
@media (max-width: 768px) {
  .contact-card--tertiary {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }
}

/* --- /products Thread section (DP4) — Minimal card grid on dark bg --- */
.mebric-thread {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-7);
}
@media (max-width: 900px) {
  .mebric-thread { grid-template-columns: 1fr; gap: var(--space-5); }
}
.products-thread__item {
  padding: var(--space-5) 0 0 !important;
  border-top: 1px solid var(--mebric-line-dark);
  border-radius: 0;
  gap: var(--space-3);
}
.products-thread__item:hover {
  background: rgba(200, 90, 58, 0.06) !important;
  padding: var(--space-5) var(--space-3) 0 !important;
}
.products-thread__eyebrow { margin-bottom: var(--space-1); }
.products-thread__headline {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.01em;
  color: var(--mebric-cream);
  margin: var(--space-1) 0 var(--space-2);
}
.products-thread__body {
  font-size: 14px;
  line-height: 1.7;
  color: rgba(249, 246, 240, 0.72);
  margin: 0;
}

/* --- /about Principles list (DP5) — Minimal cards on light bg --- */
.about-principles__item {
  padding: var(--space-6) 0 0 !important;
  border-top: 1px solid var(--mebric-line-light);
  border-radius: 0;
  gap: var(--space-3);
}
.about-principles__item:hover {
  background: rgba(200, 90, 58, 0.04) !important;
  padding: var(--space-6) var(--space-3) 0 !important;
}
.about-principles__number {
  font-size: 48px;
  color: var(--mebric-terra);
  line-height: 1;
  font-weight: 300;
  letter-spacing: -0.02em;
}
.about-principles__title {
  margin: var(--space-5) 0 var(--space-3) !important;
}
.about-principles__body {
  color: var(--mebric-ink);
  font-size: 14px;
  line-height: 1.7;
  margin: 0;
}
@media (max-width: 900px) {
  .about-principles { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 640px) {
  .about-principles { grid-template-columns: 1fr !important; }
}

/* --- /how-we-work Cadence phases (DP6) — Minimal cards on light --- */
.hww-cadence__item {
  padding: var(--space-5) 0 0 !important;
  border-top: 1px solid var(--mebric-line-light);
  border-radius: 0;
  gap: var(--space-2);
}
.hww-cadence__item:hover {
  background: rgba(200, 90, 58, 0.04) !important;
  padding: var(--space-5) var(--space-3) 0 !important;
}
.hww-cadence__title {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--mebric-ink);
  margin: var(--space-2) 0;
}
@media (max-width: 900px) {
  .hww-cadence { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 640px) {
  .hww-cadence { grid-template-columns: 1fr !important; }
}

/* --- /career Hiring Process list (DP7) — 4-step numbered semantic list --- */
.career-hiring__item {
  display: grid;
  grid-template-columns: 60px 200px 1fr;
  gap: var(--space-6);
  align-items: baseline;
  padding: var(--space-5) 0;
  border-top: 1px solid var(--mebric-line-light);
  transition: background-color var(--dur-fast) var(--ease-out);
}
.career-hiring__item--last { border-bottom: 1px solid var(--mebric-line-light); }
.career-hiring__item:hover {
  background: rgba(200, 90, 58, 0.03);
}
.career-hiring__number {
  font-family: var(--mebric-font-en);
  font-variant-numeric: tabular-nums;
  font-weight: 300;
  font-size: 20px;
  color: var(--mebric-muted);
  letter-spacing: 0.04em;
}
.career-hiring__name {
  font-size: 16px;
  font-weight: 700;
  color: var(--mebric-navy);
  letter-spacing: -0.01em;
}
.career-hiring__body {
  font-size: 14px;
  color: var(--mebric-ink);
  line-height: 1.7;
}
@media (max-width: 768px) {
  .career-hiring__item {
    grid-template-columns: 40px 1fr;
    gap: var(--space-3);
  }
  .career-hiring__body { grid-column: 1 / -1; margin-top: var(--space-2); }
}

/* --- /meet/book inline confirm (DP8) — slide-in acknowledgment --- */
.mebric-confirm {
  margin-top: var(--space-5);
  padding: var(--space-4) var(--space-5);
  background: rgba(25, 37, 54, 0.04);
  border-left: 3px solid var(--mebric-terra);
  border-radius: var(--radius-xs);
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  animation: mebric-confirm-slide-in var(--dur-medium) var(--ease-out);
}
@keyframes mebric-confirm-slide-in {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.mebric-confirm__check {
  width: 24px; height: 24px;
  border-radius: var(--radius-pill);
  background: var(--mebric-terra);
  color: var(--mebric-cream);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 14px;
  font-weight: 600;
}
.mebric-confirm__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: 14px;
  line-height: 1.5;
  color: var(--mebric-ink);
}
.mebric-confirm__body strong {
  font-size: 15px;
  color: var(--mebric-ink);
}
.mebric-confirm__note {
  color: var(--mebric-muted);
}
@media (prefers-reduced-motion: reduce) {
  .mebric-confirm { animation: none; }
}

/* --- /contact info grid (DP8, optional expansion) --- */
.mebric-contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin: 0;
  padding: var(--space-6) 0;
  border-top: 1px solid var(--mebric-line-light);
  border-bottom: 1px solid var(--mebric-line-light);
}
.mebric-contact-grid dt {
  font-size: 12px;
  color: var(--mebric-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}
.mebric-contact-grid dd {
  margin: 0;
  font-size: 16px;
  line-height: 1.5;
  color: var(--mebric-ink);
}
@media (max-width: 768px) { .mebric-contact-grid { grid-template-columns: 1fr; } }
