/* ═══════════════════════════════════════════════════════
   WHITECLIFF STUDIO WORK PAGE STYLES
═══════════════════════════════════════════════════════ */

/* ── Nav overrides for light page ── */
.nav--light { background: rgba(248,246,242,0.97); backdrop-filter: blur(12px); box-shadow: 0 1px 0 rgba(0,0,0,0.08); }
.nav--light-links a { color: var(--text-muted) !important; }
.nav--light-links a:hover { color: var(--charcoal) !important; }
.nav__active { color: var(--charcoal) !important; font-weight: 600 !important; }
.nav--light .nav__toggle span { background: var(--charcoal); }
.nav--light .logo-text { color: var(--charcoal); }

/* ── Page hero ── */
.page-hero {
  padding: calc(var(--nav-h) + 5rem) 0 3rem;
  background: var(--ivory);
  border-bottom: 1px solid var(--border);
}
.page-hero .container { max-width: 760px; }
.page-hero__title {
  font-family: var(--font-serif);
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin-bottom: 1.2rem;
}
.page-hero__sub {
  font-size: 1rem;
  color: var(--text-muted);
  line-height: 1.7;
  max-width: 600px;
}

.page-hero__filter {
  display: flex;
  gap: 0.5rem;
  padding: 2.5rem 5% 0;
  flex-wrap: wrap;
}

.filter-btn {
  padding: 0.5rem 1.2rem;
  border-radius: 100px;
  border: 1.5px solid var(--border);
  background: #fff;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.2s;
}
.filter-btn:hover { border-color: var(--charcoal); color: var(--charcoal); }
.filter-btn--active { background: var(--charcoal); color: #fff; border-color: var(--charcoal); }

/* ── Mockups grid ── */
.mockups-section { background: var(--warm-mid); padding: 4rem 5% 6rem; }

.mockups-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  max-width: 1400px;
  margin: 0 auto;
}

.mockup-card {
  background: #fff;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  transition: transform 0.35s var(--ease-out), box-shadow 0.35s;
  display: flex;
  flex-direction: column;
}
.mockup-card:hover { transform: translateY(-6px); box-shadow: 0 24px 60px rgba(0,0,0,0.12); }
.mockup-card--wide { grid-column: 1 / -1; }
.mockup-card--featured { grid-column: 1 / -1; background: var(--charcoal); border-color: transparent; }

/* ── Browser frame ── */
.browser {
  border-radius: var(--r-lg) var(--r-lg) 0 0;
  overflow: hidden;
  flex: 1;
}

.browser__bar {
  background: #f0ede8;
  padding: 8px 12px;
  display: flex;
  align-items: center;
  gap: 6px;
  border-bottom: 1px solid rgba(0,0,0,0.07);
}
.browser__bar--dark { background: #2a2a2a; border-bottom-color: rgba(255,255,255,0.06); }

.browser__dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.browser__dot--red    { background: #ff5f57; }
.browser__dot--yellow { background: #febc2e; }
.browser__dot--green  { background: #28c840; }

.browser__url {
  flex: 1;
  background: #fff;
  border-radius: 6px;
  padding: 3px 10px;
  font-size: 10px;
  color: #888;
  font-family: var(--font-sans);
  text-align: center;
  margin: 0 8px;
}
.browser__url--dark { background: #3a3a3a; color: #aaa; }

.browser__content { overflow: hidden; }

/* ── Mockup card info ── */
.mockup-card__info {
  padding: 1.5rem 2rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  border-top: 1px solid var(--border);
}
.mockup-card__info h3 { font-family: var(--font-serif); font-size: 1.3rem; font-weight: 400; margin-bottom: 0.3rem; }
.mockup-card__info p { font-size: 0.82rem; color: var(--text-muted); line-height: 1.5; max-width: 360px; }

.mockup-tag {
  display: inline-block;
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--taupe);
  margin-bottom: 0.4rem;
}
.mockup-tag--proto { color: var(--slate); }

.mockup-card__link {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--slate);
  white-space: nowrap;
  transition: color 0.2s;
  flex-shrink: 0;
}
.mockup-card__link:hover { color: var(--charcoal); }

/* ══════════════════════════════════
   SHARED MOCK UI COMPONENTS
══════════════════════════════════ */
.mock-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 18px;
  font-size: 9px;
}
.mock-nav--light  { background: #fff; border-bottom: 1px solid rgba(0,0,0,0.06); }
.mock-nav--dark   { background: #111; }
.mock-nav--blush  { background: #fdf6f0; border-bottom: 1px solid rgba(0,0,0,0.06); }
.mock-nav--navy   { background: #1a2744; }
.mock-nav--charcoal { background: #1a1a1a; }
.mock-nav--white-border { background: #fff; border-bottom: 1px solid rgba(0,0,0,0.08); }

.mock-logo { font-weight: 700; font-size: 11px; }
.mock-logo--serif { font-family: var(--font-serif); font-weight: 600; font-size: 13px; }
.mock-logo--bold  { font-weight: 900; letter-spacing: 0.1em; }
.mock-logo--white { color: #fff; }
.mock-logo--blush { color: #8c5a3a; }
.mock-logo--tracking { letter-spacing: 0.18em; font-size: 9px; }
.mock-logo small { font-family: var(--font-sans); font-size: 7px; font-weight: 400; letter-spacing: 0.05em; opacity: 0.7; margin-left: 2px; }

.mock-nav-links { display: flex; align-items: center; gap: 12px; color: #555; font-size: 9px; }
.mock-nav-links--white { color: rgba(255,255,255,0.7); }
.mock-nav-links--blush { color: #8c6a5a; }

.mock-nav-cta {
  background: #1a1a1a; color: #fff;
  padding: 4px 10px; border-radius: 100px;
}
.mock-nav-cta--accent  { background: #e94f37; }
.mock-nav-cta--blush   { background: #c17a5a; color: #fff; }
.mock-nav-cta--white   { background: #fff; color: #1a2744; }
.mock-nav-cta--gold    { background: #c5a028; color: #fff; }

.mock-nav-icon { font-size: 12px; }

.mock-hero {
  position: relative;
  height: 140px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  padding: 0 20px;
}
.mock-hero__overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.35);
}
.mock-hero__overlay--dark { background: rgba(0,0,0,0.55); }
.mock-hero__text { position: relative; z-index: 1; color: #fff; }
.mock-hero__text--center { width: 100%; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 6px; }
.mock-hero__text--right { margin-left: auto; }
.mock-hero__text--left-dark { color: #1a1a1a; max-width: 50%; }

.mock-eyebrow { font-size: 7px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; opacity: 0.75; margin-bottom: 4px; display: block; }
.mock-eyebrow--accent { color: #e94f37; opacity: 1; }
.mock-eyebrow--blush { color: #c17a5a; opacity: 1; }
.mock-eyebrow--gold { color: #c5a028; opacity: 1; }
.mock-eyebrow--slate { color: var(--slate); opacity: 1; }

.mock-hero h2, .mock-h2--white { font-family: var(--font-serif); font-size: 18px; font-weight: 400; line-height: 1.15; color: #fff; margin-bottom: 8px; }
.mock-h2--dark { font-family: var(--font-serif); font-size: 18px; font-weight: 400; line-height: 1.15; color: #1a1a1a; margin-bottom: 8px; }

.mock-hero__btns { display: flex; gap: 6px; flex-wrap: wrap; }
.mock-btn { display: inline-block; padding: 5px 12px; border-radius: 100px; font-size: 8px; font-weight: 600; cursor: default; }
.mock-btn--primary { background: #1a1a1a; color: #fff; }
.mock-btn--ghost { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,0.5); }
.mock-btn--accent { background: #e94f37; color: #fff; }
.mock-btn--blush { background: #c17a5a; color: #fff; }
.mock-btn--dark { background: #1a1a1a; color: #fff; }
.mock-btn--gold { background: #c5a028; color: #fff; }

/* ══ RESTAURANT ══ */
.mock-hero--restaurant {
  background-image: linear-gradient(rgba(0,0,0,0.1), rgba(0,0,0,0.5)),
    url('https://images.unsplash.com/photo-1414235077428-338989a2e8c0?w=600&q=70');
  background-size: cover; background-position: center;
}
.mock-strip--restaurant { background: #1a1a1a; padding: 6px 18px; }
.mock-tag-row { display: flex; gap: 16px; font-size: 7.5px; color: rgba(255,255,255,0.6); align-items: center; }
.mock-feature-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: #f0ede8; }
.mock-feature { background: #fff; padding: 8px; text-align: center; font-size: 8px; color: #555; }
.mock-feature p { margin-top: 5px; }
.mock-img { height: 55px; border-radius: 4px; background-size: cover; background-position: center; }
.mock-img--food1 { background-image: url('https://images.unsplash.com/photo-1565299624946-b28f40a0ae38?w=200&q=60'); background-color: #c8b89a; }
.mock-img--food2 { background-image: url('https://images.unsplash.com/photo-1546069901-ba9599a7e63c?w=200&q=60'); background-color: #d4c4a0; }
.mock-img--food3 { background-image: url('https://images.unsplash.com/photo-1510812431401-41d2bd2722f3?w=200&q=60'); background-color: #9a7a5a; }

/* ══ FITNESS ══ */
.mock-hero--fitness {
  background-image: url('https://images.unsplash.com/photo-1534438327276-14e5300c3a48?w=600&q=70');
  background-size: cover; background-position: center top;
  height: 150px;
}
.mock-stats-row { display: flex; background: #111; padding: 8px 18px; gap: 0; }
.mock-stat { flex: 1; text-align: center; border-right: 1px solid rgba(255,255,255,0.08); padding: 4px; }
.mock-stat:last-child { border: none; }
.mock-stat strong { display: block; font-size: 13px; color: #e94f37; font-weight: 700; }
.mock-stat span { font-size: 7px; color: rgba(255,255,255,0.4); display: block; }
.mock-class-row { display: flex; background: #1a1a1a; padding: 6px 12px; gap: 5px; }
.mock-class-card {
  flex: 1; border-radius: 6px; padding: 6px 4px; font-size: 8px; font-weight: 700;
  color: #fff; text-align: center; display: flex; flex-direction: column; gap: 2px;
}
.mock-class-card span { font-size: 7px; font-weight: 400; opacity: 0.6; }
.mock-class-card--hiit { background: #e94f37; }
.mock-class-card--yoga { background: #3d8b5e; }
.mock-class-card--spin { background: #1a6b9a; }
.mock-class-card--box  { background: #6b3a9a; }

/* ══ BEAUTY ══ */
/* ══ LUMIÈRE BEAUTY ══ */
.mock-nav--beauty-dark { background: #18120f; border-bottom: none; padding: 8px 16px; }
.mock-logo--lumiere { color: #e8d0b8; font-style: italic; font-size: 14px; }
.mock-nav-links--lumiere { color: rgba(255,255,255,0.5); font-size: 8px; gap: 10px; }
.mock-nav-cta--lumiere { border: 1px solid rgba(255,255,255,0.3); color: rgba(255,255,255,0.85); padding: 3px 9px; border-radius: 2px; font-size: 7px; background: transparent; }

.mock-beauty-hero {
  height: 148px;
  background-image: url('https://images.unsplash.com/photo-1570172619644-dfd03ed5d881?w=700&q=80');
  background-size: cover;
  background-position: center 25%;
  display: flex;
  align-items: flex-end;
  padding: 0 0 14px 18px;
  position: relative;
}
.mock-beauty-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(18,12,10,0.8) 0%, rgba(18,12,10,0.15) 55%, transparent);
}
.mock-beauty-hero__text { position: relative; z-index: 1; }
.mock-beauty-eyebrow { font-size: 6.5px; letter-spacing: 0.14em; text-transform: uppercase; color: #e0c0a0; margin-bottom: 5px; }
.mock-beauty-h2 { font-family: var(--font-serif); font-size: 18px; font-weight: 300; color: #fff; line-height: 1.1; margin-bottom: 9px; }
.mock-beauty-h2 em { font-style: italic; color: #e8c8a8; }
.mock-btn--lumiere { font-size: 7.5px; padding: 4px 12px; background: transparent; border: 1px solid rgba(255,255,255,0.55); color: #fff; border-radius: 2px; letter-spacing: 0.06em; display: inline-block; }

.mock-beauty-treatments { display: grid; grid-template-columns: repeat(4,1fr); background: #faf5f0; border-top: 1px solid #ede0d4; }
.mock-beauty-card { padding: 7px 5px; text-align: center; border-right: 1px solid #ede0d4; display: flex; flex-direction: column; align-items: center; gap: 4px; }
.mock-beauty-card:last-child { border-right: none; }
.mock-beauty-card__img { width: 28px; height: 28px; border-radius: 50%; background-size: cover; background-position: center; }
.mock-beauty-card__img--facial  { background-image: url('https://images.unsplash.com/photo-1616394584738-fc6e612e71b9?w=100&q=75'); background-color: #e8d8d0; }
.mock-beauty-card__img--massage { background-image: url('https://images.unsplash.com/photo-1544161515-4ab6ce6db874?w=100&q=75'); background-color: #d8e0d0; }
.mock-beauty-card__img--nails   { background-image: url('https://images.unsplash.com/photo-1604654894610-df63bc536371?w=100&q=75'); background-color: #e8d8e0; }
.mock-beauty-card__img--lashes  { background-image: url('https://images.unsplash.com/photo-1512290923902-8a9f81dc236c?w=100&q=75'); background-color: #e0d8e8; }
.mock-beauty-card strong { font-size: 8px; font-weight: 600; color: #1a1a1a; }
.mock-beauty-card span { font-size: 6.5px; color: #a07060; }

/* ══ REAL ESTATE ══ */
.mock-search-hero { background: #f5f3ef; padding: 14px 18px 10px; }
.mock-search-hero h2 { font-family: var(--font-serif); font-size: 16px; color: #1a1a1a; margin-bottom: 8px; font-weight: 400; }
.mock-search-hero em { color: var(--slate); }
.mock-search-bar { display: flex; align-items: center; background: #fff; border-radius: 8px; border: 1.5px solid rgba(0,0,0,0.1); overflow: hidden; gap: 0; }
.mock-search-input { flex: 1; padding: 6px 10px; display: flex; align-items: center; gap: 5px; font-size: 8px; color: #aaa; }
.mock-search-icon { font-size: 9px; }
.mock-search-sel { padding: 6px 10px; border-left: 1px solid rgba(0,0,0,0.08); font-size: 8px; color: #555; white-space: nowrap; }
.mock-search-btn { background: #1a2744; color: #fff; padding: 6px 14px; font-size: 8px; font-weight: 600; white-space: nowrap; }
.mock-property-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: #e8e4de; }
.mock-property-card { background: #fff; }
.mock-property-img { height: 60px; background-size: cover; background-position: center; }
.mock-property-img--1 { background-image: url('https://images.unsplash.com/photo-1568605114967-8130f3a36994?w=200&q=60'); background-color: #c8b89a; }
.mock-property-img--2 { background-image: url('https://images.unsplash.com/photo-1522708323590-d24dbb6b0267?w=200&q=60'); background-color: #b0a080; }
.mock-property-img--3 { background-image: url('https://images.unsplash.com/photo-1600596542815-ffad4c1539a9?w=200&q=60'); background-color: #d4c4a0; }
.mock-property-info { padding: 6px 8px; }
.mock-property-info strong { display: block; font-size: 10px; font-weight: 700; color: #1a1a1a; }
.mock-property-info span { display: block; font-size: 7px; color: #888; margin-bottom: 2px; }
.mock-property-info p { font-size: 7.5px; color: #555; line-height: 1.3; }

/* ══ E-COMMERCE ══ */
.mock-hero--ecom {
  background-image: url('https://images.unsplash.com/photo-1490481651871-ab68de25d43d?w=600&q=70');
  background-size: cover; background-position: center top;
  height: 140px;
}
.mock-product-strip { background: #fff; padding: 8px 14px 10px; }
.mock-section-label { font-size: 7px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: #aaa; margin-bottom: 6px; }
.mock-product-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 6px; }
.mock-product { display: flex; flex-direction: column; gap: 3px; }
.mock-product span { font-size: 7.5px; color: #555; }
.mock-product strong { font-size: 8px; font-weight: 600; color: #1a1a1a; }
.mock-product-img { height: 50px; border-radius: 4px; background-size: cover; background-position: top center; }
.mock-product-img--1 { background-image: url('https://images.unsplash.com/photo-1598300042247-d088f8ab3a91?w=150&q=60'); background-color: #e8e0d8; }
.mock-product-img--2 { background-image: url('https://images.unsplash.com/photo-1591369822096-ffd140ec948f?w=150&q=60'); background-color: #d8cfc5; }
.mock-product-img--3 { background-image: url('https://images.unsplash.com/photo-1543087903-1ac2364a7b02?w=150&q=60'); background-color: #e0d8ce; }
.mock-product-img--4 { background-image: url('https://images.unsplash.com/photo-1515372039744-b8f02a3ae446?w=150&q=60'); background-color: #c8c0b8; }

/* ══ LEGAL ══ */
.mock-legal-hero { background: #1a1a1a; padding: 16px 20px 12px; display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.mock-legal-content { flex: 1; }
.mock-legal-sub { font-size: 8px; color: rgba(255,255,255,0.5); line-height: 1.4; margin-bottom: 8px; max-width: 220px; }
.mock-legal-stats { display: flex; flex-direction: column; gap: 8px; flex-shrink: 0; }
.mock-legal-stat { text-align: right; }
.mock-legal-stat strong { display: block; font-size: 14px; color: #c5a028; font-weight: 700; }
.mock-legal-stat span { font-size: 7px; color: rgba(255,255,255,0.4); }
.mock-practice-row { display: flex; background: #f5f3ef; padding: 8px 18px; gap: 0; }
.mock-practice { flex: 1; text-align: center; padding: 5px 0; font-size: 7.5px; font-weight: 600; color: #333; border-right: 1px solid var(--border); }
.mock-practice:last-child { border: none; }

/* ══ APP PROTOTYPE ══ */
.mock-prototype { padding: 0; }
.mock-proto-split { display: grid; grid-template-columns: 1fr 1fr; height: 260px; }
.mock-proto-left { padding: 20px; display: flex; flex-direction: column; gap: 8px; justify-content: center; background: var(--ivory); }
.mock-proto-left h2 { font-family: var(--font-serif); font-size: 16px; font-weight: 400; line-height: 1.2; }
.mock-proto-desc { font-size: 8px; color: var(--text-muted); line-height: 1.5; }
.mock-proto-chips { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 4px; }
.mock-proto-chips span { font-size: 7px; font-weight: 600; padding: 2px 7px; border-radius: 100px; background: rgba(61,90,115,0.1); color: var(--slate); }
.mock-proto-phones { background: #e8e4de; display: flex; align-items: center; justify-content: center; gap: 10px; padding: 16px 12px; }

/* ── Large phone showcase ── */
.mock-phone-showcase {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 340px;
  background: #151a16;
  position: relative;
  overflow: hidden;
}
.mock-phone-showcase::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 60% 40%, rgba(255,255,255,0.04) 0%, transparent 65%);
  pointer-events: none;
}

.app-phone {
  width: 160px;
  height: 310px;
  background: #0e0e0e;
  border-radius: 30px;
  padding: 6px;
  box-shadow:
    0 0 0 1.5px #2a2a2a,
    0 0 0 3px #111,
    0 24px 60px rgba(0,0,0,0.7);
  position: relative;
  flex-shrink: 0;
}
.app-phone::before {
  content: '';
  position: absolute;
  top: 11px; left: 50%; transform: translateX(-50%);
  width: 36px; height: 5px;
  background: #000;
  border-radius: 3px;
  z-index: 10;
}
.app-phone::after {
  content: '';
  position: absolute;
  bottom: 10px; left: 50%; transform: translateX(-50%);
  width: 44px; height: 3px;
  background: rgba(255,255,255,0.2);
  border-radius: 2px;
  z-index: 10;
}
.app-phone__screen {
  background: #fff;
  border-radius: 25px;
  overflow: hidden;
  width: 100%;
  height: 100%;
}

/* Scaled-up app content (2× the mini-phone inner) */
.app-phone__app {
  width: 74px;
  height: 160px;
  transform: scale(2);
  transform-origin: top left;
  display: flex;
  flex-direction: column;
  padding-top: 12px;
  background: #fff;
}

/* Iframe (Every Birth live app) */
.app-phone__iframe {
  width: 390px;
  height: 844px;
  border: none;
  transform: scale(0.379);
  transform-origin: top left;
  display: block;
  pointer-events: none;
}

/* ── Mini phone shell: fixed proportions, clips content ── */
.mini-phone {
  width: 82px;
  height: 168px;
  flex-shrink: 0;
  background: #111;
  border-radius: 14px;
  padding: 4px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.35), inset 0 0 0 1px rgba(255,255,255,0.08);
  position: relative;
}
.mini-phone::before {
  content: '';
  position: absolute;
  top: 6px; left: 50%; transform: translateX(-50%);
  width: 20px; height: 4px;
  background: #222;
  border-radius: 3px;
  z-index: 2;
}
.mini-phone--1 { transform: rotate(-3deg); }
.mini-phone--2 { transform: rotate(3deg) translateY(6px); }
.mini-phone__screen {
  background: #fff;
  border-radius: 11px;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  padding-top: 12px;
}

/* ══ REDESIGNED APP SCREENS ══ */

/* Status bar */
.ms-stat { display:flex; justify-content:space-between; align-items:center; padding:4px 7px 2px; font-size:5px; font-weight:700; color:rgba(255,255,255,0.9); flex-shrink:0; }
.ms-stat--light { color:#1a1a1a; padding:4px 7px 2px; }
.ms-stat__icons { display:flex; gap:2.5px; align-items:center; }
.ms-stat__sig { display:flex; gap:1px; align-items:flex-end; }
.ms-stat__sig i { display:block; width:1.5px; background:currentColor; border-radius:0.5px; }
.ms-stat__sig i:nth-child(1){height:3px;} .ms-stat__sig i:nth-child(2){height:4.5px;} .ms-stat__sig i:nth-child(3){height:6px;}
.ms-stat__batt { width:9px; height:4.5px; border:0.8px solid currentColor; border-radius:1px; position:relative; opacity:0.8; }
.ms-stat__batt::before { content:''; position:absolute; left:0.8px; top:0.8px; width:55%; bottom:0.8px; background:currentColor; border-radius:0.2px; }
.ms-stat__batt::after { content:''; position:absolute; right:-2px; top:50%; transform:translateY(-50%); width:1.2px; height:2.5px; background:currentColor; opacity:0.6; }

/* Coloured app header zone (status + nav in brand colour) */
.ms-apphead { flex-shrink:0; padding:0 7px 6px; }
.ms-apphead__row { display:flex; align-items:center; justify-content:space-between; padding-top:2px; }
.ms-apphead__name { font-size:9.5px; font-weight:800; color:#fff; letter-spacing:-0.02em; }
.ms-apphead__btn { width:15px; height:15px; border-radius:8px; background:rgba(255,255,255,0.2); display:flex; align-items:center; justify-content:center; }
.ms-apphead__btnline { width:6px; height:1.5px; background:#fff; border-radius:1px; box-shadow:0 2px 0 #fff, 0 -2px 0 #fff; }
.ms-apphead__sub { font-size:5px; color:rgba(255,255,255,0.6); margin-top:2px; }

/* White nav bar (back screens) */
.ms-backhead { flex-shrink:0; background:#fff; border-bottom:0.5px solid rgba(0,0,0,0.08); padding:0 7px 5px; }
.ms-backhead__back { font-size:6px; font-weight:500; display:flex; align-items:center; gap:1px; padding-top:3px; padding-bottom:2px; }
.ms-backhead__caret { font-size:9px; line-height:1; }
.ms-backhead__title { font-size:7.5px; font-weight:700; color:#1a1a1a; text-align:center; }

/* Body */
.ms-body { flex:1; overflow:hidden; background:#f2f2f7; padding:5px 5px 0; display:flex; flex-direction:column; gap:3px; }

/* White card */
.ms-wcard { background:#fff; border-radius:8px; padding:5px 6px; box-shadow:0 0.5px 2px rgba(0,0,0,0.06); display:flex; align-items:center; gap:5px; flex-shrink:0; }
.ms-wcard--col { flex-direction:column; align-items:flex-start; gap:2px; }
.ms-wcard__dot { width:16px; height:16px; border-radius:5px; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.ms-wcard__label { font-size:5px; color:#888; text-transform:uppercase; letter-spacing:0.05em; }
.ms-wcard__title { font-size:7px; font-weight:700; color:#1a1a1a; line-height:1.2; }
.ms-wcard__sub { font-size:5.5px; color:#888; }
.ms-wcard__chevron { margin-left:auto; width:4px; height:4px; border-right:1px solid #ccc; border-top:1px solid #ccc; transform:rotate(45deg); flex-shrink:0; }

/* Gradient hero card */
.ms-herocard { border-radius:8px; padding:7px; color:#fff; display:flex; flex-direction:column; gap:2px; flex-shrink:0; }
.ms-herocard__label { font-size:5px; opacity:0.75; }
.ms-herocard__amount { font-size:14px; font-weight:800; line-height:1; letter-spacing:-0.03em; }
.ms-herocard__sub { font-size:5px; opacity:0.65; }

/* Tab bar */
.ms-tabs { display:flex; background:#fff; border-top:0.5px solid rgba(0,0,0,0.08); padding:3px 2px 5px; flex-shrink:0; }
.ms-tabitem { flex:1; display:flex; flex-direction:column; align-items:center; gap:2px; }
.ms-tabitem__bar { width:14px; height:3px; border-radius:2px; background:#e0e0e0; }
.ms-tabitem--on .ms-tabitem__bar { background:var(--tc,#005eb8); }
.ms-tabitem__lbl { font-size:4px; color:#aaa; }
.ms-tabitem--on .ms-tabitem__lbl { color:var(--tc,#005eb8); }

/* Action button pinned to bottom */
.ms-actbtn { border-radius:7px; padding:5px; text-align:center; font-size:7px; font-weight:700; color:#fff; flex-shrink:0; margin-top:auto; }

/* Calendar row */
.ms-calrow { display:flex; gap:1.5px; background:#fff; border-radius:8px; padding:4px; box-shadow:0 0.5px 2px rgba(0,0,0,0.06); flex-shrink:0; }
.ms-calday { flex:1; text-align:center; border-radius:5px; padding:2px 0; }
.ms-calday__n { font-size:4.5px; color:#888; display:block; }
.ms-calday__d { font-size:8px; font-weight:700; color:#1a1a1a; display:block; line-height:1.2; }
.ms-calday--sel { background:#005eb8; }
.ms-calday--sel .ms-calday__n { color:rgba(255,255,255,0.7); }
.ms-calday--sel .ms-calday__d { color:#fff; }

/* Time slot */
.ms-slot2 { background:#fff; border-radius:6px; padding:4px 6px; font-size:6px; color:#555; box-shadow:0 0.5px 2px rgba(0,0,0,0.06); flex-shrink:0; }
.ms-slot2--sel { background:#e8f0fa; color:#005eb8; font-weight:600; }

/* ── CareTrack (NHS blue) ── */
.ms-care .ms-apphead { background:#005eb8; }
.ms-care .ms-backhead__back { color:#005eb8; }

/* ── ShiftPay (green) ── */
.ms-shift .ms-apphead { background:linear-gradient(135deg,#2d6a4f,#3d8b63); }
.ms-shift .ms-backhead__back { color:#2d6a4f; }
.ms-shift .ms-herocard { background:linear-gradient(135deg,#2d6a4f,#52b788); }
.ms-shiftrow { background:#fff; border-radius:6px; padding:4px 6px; display:flex; align-items:center; box-shadow:0 0.5px 2px rgba(0,0,0,0.06); flex-shrink:0; }
.ms-shiftrow__day { font-size:6px; font-weight:600; color:#1a1a1a; flex:1; }
.ms-shiftrow__hrs { font-size:5.5px; padding:1px 4px; border-radius:3px; background:#e8f5ee; color:#2d6a4f; font-weight:600; margin-right:4px; }
.ms-shiftrow__amt { font-size:6px; font-weight:700; color:#1a1a1a; }
.ms-shiftrow--today { background:#f0f7f4; }

/* ── Plateful (orange) ── */
.ms-food .ms-apphead { background:linear-gradient(135deg,#e07b39,#f0955a); }
.ms-food .ms-backhead__back { color:#e07b39; }
.ms-foodloc { background:rgba(255,255,255,0.2); border-radius:5px; padding:2px 5px; display:flex; align-items:center; gap:2.5px; margin-top:3px; }
.ms-foodloc__text { font-size:5px; color:rgba(255,255,255,0.9); }
.ms-foodchips { display:flex; gap:2.5px; flex-shrink:0; }
.ms-chip { font-size:5px; padding:1.5px 5px; border-radius:10px; background:#eee; color:#666; }
.ms-chip--on { background:#e07b39; color:#fff; }
.ms-restcard { background:#fff; border-radius:7px; overflow:hidden; box-shadow:0 0.5px 2px rgba(0,0,0,0.06); flex-shrink:0; }
.ms-restcard__img { height:28px; background-size:cover; background-position:center; }
.ms-restcard__info { padding:3px 5px; display:flex; align-items:center; }
.ms-restcard__name { font-size:6px; font-weight:700; color:#1a1a1a; flex:1; }
.ms-restcard__time { font-size:5px; color:#e07b39; font-weight:600; }
.ms-menuitem { background:#fff; border-radius:6px; padding:4px 6px; display:flex; align-items:center; gap:4px; box-shadow:0 0.5px 2px rgba(0,0,0,0.06); flex-shrink:0; }
.ms-menuitem__swatch { width:12px; height:12px; border-radius:3px; flex-shrink:0; }
.ms-menuitem__name { font-size:6px; font-weight:600; color:#1a1a1a; flex:1; line-height:1.2; }
.ms-menuitem__price { font-size:5.5px; color:#888; }
.ms-menuitem__add { width:13px; height:13px; border-radius:4px; display:flex; align-items:center; justify-content:center; font-size:8px; font-weight:700; flex-shrink:0; }

/* ── Every Birth (rose) ── */
.ms-eb .ms-apphead { background:linear-gradient(150deg,#c97d7d,#e09898); }
.ms-eb-hero { border-radius:7px; overflow:hidden; position:relative; height:50px; flex-shrink:0; }
.ms-eb-hero img { width:100%; height:100%; object-fit:cover; object-position:top; }
.ms-eb-overlay { position:absolute; inset:0; background:linear-gradient(transparent 30%,rgba(0,0,0,0.55)); display:flex; flex-direction:column; justify-content:flex-end; padding:3px 5px; }
.ms-eb-tag { font-size:4px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; background:#c97d7d; color:#fff; padding:1px 3px; border-radius:2px; display:inline-block; width:fit-content; margin-bottom:1px; }
.ms-eb-title { font-size:5.5px; font-weight:600; color:#fff; line-height:1.2; }

/* ══ EVERY BIRTH FEATURED CARD ══ */
.mockup-eb-inner { display: grid; grid-template-columns: 1fr 1.1fr; align-items: center; padding: 3rem; gap: 3rem; }
.mockup-eb-text { display: flex; flex-direction: column; gap: 1rem; }
.mockup-eb-text .mockup-tag { color: rgba(255,255,255,0.45); }
.mockup-eb-text h3 { font-family: var(--font-serif); font-size: clamp(1.6rem, 3vw, 2.4rem); color: #fff; font-weight: 400; line-height: 1.15; }
.mockup-eb-text p { font-size: 0.88rem; color: rgba(255,255,255,0.6); line-height: 1.7; max-width: 420px; }
.mockup-eb-results { display: flex; gap: 2rem; padding-top: 1rem; border-top: 1px solid rgba(255,255,255,0.1); }
.mockup-eb-results div { display: flex; flex-direction: column; gap: 0.2rem; }
.mockup-eb-results strong { font-family: var(--font-serif); font-size: 1.5rem; color: #fff; }
.mockup-eb-results span { font-size: 0.72rem; color: rgba(255,255,255,0.4); }
.mockup-eb-visual { display: flex; align-items: center; gap: 1.5rem; justify-content: center; }
.mockup-eb-photo { width: 200px; height: 280px; border-radius: var(--r-md); overflow: hidden; flex-shrink: 0; box-shadow: 0 20px 50px rgba(0,0,0,0.4); }
.mockup-eb-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
.mockup-eb-phone { flex-shrink: 0; filter: drop-shadow(0 20px 40px rgba(0,0,0,0.5)); }
.phone-mockup__frame--sm { width: 140px; }
.phone-mockup__frame--sm .phone-mockup__screen { height: 260px; }

/* ── CTA strip ── */
.work-cta-strip { background: var(--charcoal); padding: 4rem 0; }
.work-cta-strip__inner { display: flex; justify-content: space-between; align-items: center; gap: 2rem; }
.work-cta-strip h2 { font-family: var(--font-serif); font-size: 2rem; color: #fff; font-weight: 400; margin-bottom: 0.5rem; }
.work-cta-strip p { color: rgba(255,255,255,0.55); font-size: 0.9rem; max-width: 400px; }

/* ── Screen reader only ── */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ── Responsive ── */
@media (max-width: 1024px) {
  .mockups-grid { grid-template-columns: 1fr; }
  .mockup-card--wide, .mockup-card--featured { grid-column: 1; }
  .mockup-eb-inner { grid-template-columns: 1fr; padding: 2rem; gap: 2rem; }
  .work-cta-strip__inner { flex-direction: column; text-align: center; }
  .mock-proto-split { grid-template-columns: 1fr; height: auto; }
  .mock-proto-phones { height: 200px; }
}

@media (max-width: 640px) {
  .page-hero__title { font-size: 2rem; }
  .mockup-card__info { flex-direction: column; align-items: flex-start; }
  .mock-property-row { grid-template-columns: 1fr; }
  .mock-product-row { grid-template-columns: repeat(2,1fr); }
  .mockup-eb-visual { flex-direction: column; }
}

/* ── Every Birth mini-screen ── */
.mini-screen--eb { background: #fdf6f0; }
.ms-header--rose { background: #c97d7d; }
.ms-icon--rose { background: #c97d7d22; color: #c97d7d; }
.ms-eb-hero { position: relative; height: 90px; border-radius: 6px; overflow: hidden; margin-bottom: 0.4rem; }
.ms-eb-hero img { width: 100%; height: 100%; object-fit: cover; }
.ms-eb-overlay { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(transparent, rgba(0,0,0,0.6)); padding: 0.4rem 0.4rem 0.3rem; }
.ms-eb-tag { font-size: 0.45rem; background: #c97d7d; color: #fff; padding: 0.1rem 0.3rem; border-radius: 3px; text-transform: uppercase; letter-spacing: 0.05em; }
.ms-eb-overlay p { color: #fff; font-size: 0.5rem; margin: 0.1rem 0 0; }
.mock-prototype--eb .mock-eyebrow--rose { color: #c97d7d; }

/* ── ShiftPay mini-screen ── */
.mini-screen--shift { background: #f0f7f4; }
.ms-header--green { background: #2d6a4f; }
.ms-icon--green { background: #2d6a4f22; color: #2d6a4f; }
.ms-balance-card { background: linear-gradient(135deg, #2d6a4f, #52b788); border-radius: 8px; padding: 0.6rem; margin-bottom: 0.4rem; color: #fff; text-align: center; }
.ms-balance-label { font-size: 0.45rem; opacity: 0.8; display: block; }
.ms-balance-amt { font-size: 1.1rem; font-weight: 700; display: block; }
.ms-balance-sub { font-size: 0.42rem; opacity: 0.7; display: block; }
.ms-shift-row { display: flex; align-items: center; gap: 0.3rem; padding: 0.3rem 0.4rem; font-size: 0.5rem; border-bottom: 1px solid rgba(0,0,0,0.06); }
.ms-shift-row span:first-child { flex: 1; color: #555; }
.ms-shift-hrs { background: #e8f5e9; padding: 0.1rem 0.3rem; border-radius: 3px; color: #2d6a4f; }
.ms-shift-row strong { margin-left: auto; color: #1a1a1a; }
.ms-shift-row--today { background: #f0f7f4; border-radius: 4px; }
.ms-confirm--green { background: #2d6a4f; }
.ms-icon--slate { background: #f0f0f0; color: #666; }

/* ── Plateful food mini-screen ── */
.mini-screen--food { background: #fff8f0; }
.ms-header--orange { background: #e07b39; }
.ms-icon--orange { background: #e07b3922; color: #e07b39; }
.ms-food-hero { text-align: center; font-size: 1.8rem; padding: 0.3rem 0; }
.ms-food-cats { display: flex; gap: 0.3rem; padding: 0.3rem 0.4rem; flex-wrap: wrap; }
.ms-food-cat { font-size: 0.45rem; padding: 0.15rem 0.4rem; border-radius: 20px; background: #eee; color: #666; }
.ms-food-cat--sel { background: #e07b39; color: #fff; }
.ms-food-item { display: flex; align-items: center; gap: 0.3rem; padding: 0.3rem 0.4rem; font-size: 0.5rem; border-bottom: 1px solid rgba(0,0,0,0.06); }
.ms-food-item span:first-child { font-size: 0.8rem; }
.ms-food-item div { flex: 1; }
.ms-food-item div strong { display: block; font-size: 0.5rem; }
.ms-food-item div span { font-size: 0.42rem; color: #888; }
.ms-food-item--sel { background: #fff8f0; }
.ms-add { background: #eee; color: #666; border-radius: 50%; width: 14px; height: 14px; display: flex; align-items: center; justify-content: center; font-size: 0.6rem; flex-shrink: 0; }
.ms-add--sel { background: #e07b39; color: #fff; }
.ms-confirm--orange { background: #e07b39; }

/* ── Brand Photo cards ── */
.mock-brand-photo { padding: 0; overflow: hidden; }
.mock-brand-grid { display: grid; grid-template-columns: 1.4fr 1fr; height: 100%; gap: 3px; background: #e0e0e0; }
.mock-brand-main { position: relative; overflow: hidden; }
.mock-brand-side { display: grid; grid-template-rows: 1fr 1fr; gap: 3px; }
.mock-brand-img { width: 100%; height: 100%; background-size: cover; background-position: center; }
.mock-brand-caption { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(transparent, rgba(0,0,0,0.7)); padding: 1rem 0.75rem 0.6rem; color: #fff; display: flex; flex-direction: column; gap: 0.2rem; }
.mock-brand-caption strong { font-size: 0.75rem; }

/* Tech / Kova brand images — 4-image grid */
.mock-brand-photo--kova .mock-brand-grid { grid-template-columns: 1.2fr 1fr; }
.mock-brand-photo--kova .mock-brand-side { grid-template-rows: 1fr 1fr 1fr; }
.mock-brand-img--tech1 { background-image: url('https://images.unsplash.com/photo-1600880292203-757bb62b4baf?w=600&q=80'); background-position: center top; }
.mock-brand-img--tech2 { background-image: url('https://images.unsplash.com/photo-1522071820081-009f0129c71c?w=400&q=80'); }
.mock-brand-img--tech3 { background-image: url('https://images.unsplash.com/photo-1551434678-e076c223a692?w=400&q=80'); }
.mock-brand-img--tech4 { background-image: url('https://images.unsplash.com/photo-1553877522-43269d4ea984?w=400&q=80'); }

/* Product / KetoKeto images */
.mock-brand-img--product1 { background-image: url('images/portfolio-product.jpg'); }
.mock-brand-img--product2 { background-image: url('https://images.unsplash.com/photo-1498837167922-ddd27525d352?w=400&q=80'); }
.mock-brand-img--product3 { background-image: url('https://images.unsplash.com/photo-1490645935967-10de6ba17061?w=400&q=80'); }

/* Tag colours */
.mockup-tag--brand { background: #c97d7d22; color: #8b3a3a; }
.mockup-tag--video { background: #1c1c2e22; color: #3a3a7a; }

/* ── Video Editing mockups ── */
.mock-video { padding: 0; overflow: hidden; height: 260px; }

/* Editing timeline card */
.mock-timeline { background: #1a1a2a; height: 100%; display: flex; flex-direction: column; }
.mock-tl-topbar { background: #111; padding: 6px 10px; display: flex; align-items: center; gap: 8px; border-bottom: 1px solid #2a2a3a; flex-shrink: 0; }
.mock-tl-logo { font-size: 8px; font-weight: 700; color: #9b8cff; letter-spacing: 0.05em; }
.mock-tl-tabs { display: flex; gap: 4px; }
.mock-tl-tab { font-size: 6px; color: rgba(255,255,255,0.35); padding: 2px 6px; border-radius: 3px; }
.mock-tl-tab--on { background: #2a2a3a; color: rgba(255,255,255,0.8); }
.mock-tl-body { display: grid; grid-template-columns: 1.2fr 1fr; flex: 1; overflow: hidden; gap: 2px; padding: 6px; }
.mock-tl-preview { background: #0d0d18; border-radius: 4px; position: relative; overflow: hidden; }
.mock-tl-preview-img { width: 100%; height: 70%; object-fit: cover; opacity: 0.85; }
.mock-tl-timecode { position: absolute; bottom: 4px; right: 5px; font-size: 6px; color: #fff; font-weight: 700; letter-spacing: 0.05em; }
.mock-tl-tracks { display: flex; flex-direction: column; gap: 3px; justify-content: center; }
.mock-tl-track { display: flex; align-items: center; gap: 4px; }
.mock-tl-track-label { font-size: 5px; color: rgba(255,255,255,0.4); width: 18px; text-align: right; flex-shrink: 0; }
.mock-tl-clips { flex: 1; height: 10px; position: relative; border-radius: 2px; overflow: hidden; background: #111; }
.mock-tl-clip { position: absolute; top: 0; height: 100%; border-radius: 2px; }

/* Platform showcase card */
.mock-platforms { background: #f8f7f5; height: 100%; display: flex; flex-direction: column; }
.mock-platforms-title { font-size: 7px; font-weight: 700; color: var(--slate); letter-spacing: 0.08em; text-transform: uppercase; padding: 10px 12px 6px; }
.mock-platforms-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; padding: 0 12px 10px; flex: 1; }
.mock-platform-card { border-radius: 6px; overflow: hidden; display: flex; flex-direction: column; }
.mock-platform-thumb { flex: 1; position: relative; overflow: hidden; }
.mock-platform-thumb img, .mock-platform-bg { width: 100%; height: 100%; object-fit: cover; }
.mock-platform-badge { position: absolute; bottom: 4px; left: 4px; font-size: 5px; font-weight: 700; color: #fff; padding: 1px 4px; border-radius: 2px; letter-spacing: 0.04em; }
.mock-platform-footer { background: #fff; padding: 3px 5px; }
.mock-platform-name { font-size: 5.5px; font-weight: 700; color: #1a1a1a; }
.mock-platform-stat { font-size: 4.5px; color: #888; }

/* TikTok / Reels vertical phone pair */
.mock-vertical-phones { background: #0d0d0d; height: 100%; display: flex; align-items: center; justify-content: center; gap: 12px; }
.mock-vert-phone { width: 68px; height: 130px; background: #1a1a1a; border-radius: 12px; overflow: hidden; position: relative; border: 1px solid #2a2a2a; flex-shrink: 0; }
.mock-vert-bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.mock-vert-overlay { position: absolute; inset: 0; background: linear-gradient(transparent 40%, rgba(0,0,0,0.7) 100%); }
.mock-vert-ui { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 6px 5px 5px; }
.mock-vert-topbar { display: flex; justify-content: space-between; align-items: center; }
.mock-vert-platform { font-size: 5px; font-weight: 800; color: #fff; letter-spacing: -0.02em; }
.mock-vert-live { font-size: 4px; background: #fe2c55; color: #fff; padding: 1px 3px; border-radius: 2px; font-weight: 700; }
.mock-vert-bottom { display: flex; flex-direction: column; gap: 3px; }
.mock-vert-caption { font-size: 4.5px; color: #fff; line-height: 1.3; font-weight: 500; }
.mock-vert-tags { font-size: 4px; color: rgba(255,255,255,0.7); }
.mock-vert-actions { position: absolute; right: 4px; bottom: 30px; display: flex; flex-direction: column; gap: 5px; align-items: center; }
.mock-vert-action { width: 14px; height: 14px; background: rgba(255,255,255,0.15); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.mock-vert-action-count { font-size: 3.5px; color: rgba(255,255,255,0.8); text-align: center; }

/* Facebook Ad mockup */
.mock-fb-ad { background: #f0f2f5; height: 100%; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 10px; }
.mock-fb-post { background: #fff; border-radius: 8px; overflow: hidden; width: 130px; flex-shrink: 0; box-shadow: 0 1px 4px rgba(0,0,0,0.1); }
.mock-fb-post-header { padding: 6px 8px; display: flex; align-items: center; gap: 5px; }
.mock-fb-avatar { width: 16px; height: 16px; border-radius: 50%; background: #c97d7d; flex-shrink: 0; }
.mock-fb-meta { display: flex; flex-direction: column; }
.mock-fb-name { font-size: 6px; font-weight: 700; color: #1a1a1a; }
.mock-fb-type { font-size: 5px; color: #65676b; }
.mock-fb-post-img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; }
.mock-fb-post-body { padding: 6px 8px; }
.mock-fb-ad-copy { font-size: 5.5px; color: #1a1a1a; line-height: 1.4; margin-bottom: 4px; }
.mock-fb-cta { background: #1877f2; color: #fff; font-size: 5px; font-weight: 700; padding: 3px 6px; border-radius: 4px; display: inline-block; }
.mock-fb-stats { display: flex; flex-direction: column; gap: 5px; }
.mock-fb-stat-row { background: #fff; border-radius: 6px; padding: 6px 8px; display: flex; flex-direction: column; gap: 1px; }
.mock-fb-stat-label { font-size: 5px; color: #65676b; }
.mock-fb-stat-val { font-size: 9px; font-weight: 700; color: #1a1a1a; }
.mock-fb-stat-delta { font-size: 4.5px; color: #42b883; font-weight: 600; }
