/* ==========================================================================
   Mefami — site vitrine de lancement
   Palette + typo reprises de front/theme.ts et gestion-projet/02-design/tokens.jsx
   (purple = "toi" · coral = "l'autre parent"). Light + dark.
   ========================================================================== */

/* ---- Design tokens (light) ------------------------------------------------ */
:root {
  --purple:       #6C5CE7;
  --purple-deep:  #4B3FBE;
  --purple-soft:  #EFEBFF;
  --purple-ink:   #1B1740;

  --coral:        #FD7B5A;
  --coral-deep:   #E15B3A;
  --coral-soft:   #FFEDE6;

  --teal:         #00B894;
  --teal-soft:    #DCF6EE;
  --amber:        #F4B83D;
  --amber-soft:   #FFF4D9;
  --rose:         #E5446D;
  --rose-soft:    #FCE4EC;

  --bg:           #F6F4FB;
  --surface:      #FFFFFF;
  --surface-alt:  #F0EDF7;
  --border:       rgba(20,16,55,0.08);
  --border-strong:rgba(20,16,55,0.14);
  --ink:          #15123A;
  --ink-soft:     #5C5876;
  --ink-muted:    #8C88A6;

  --shadow-sm:    0 1px 3px rgba(20,16,55,0.05);
  --shadow-md:    0 1px 3px rgba(20,16,55,0.04), 0 12px 32px rgba(20,16,55,0.06);
  --shadow-lg:    0 18px 48px rgba(20,16,55,0.12);
  --shadow-purple:0 14px 32px rgba(75,63,190,0.30);

  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-full: 999px;

  --font: "Inter", -apple-system, "SF Pro", "Roboto", system-ui, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;

  --maxw: 1180px;
}

/* ---- Dark theme ----------------------------------------------------------- */
[data-theme="dark"] {
  --purple-soft:  rgba(108,92,231,0.18);
  --coral-soft:   rgba(253,123,90,0.16);
  --teal-soft:    rgba(0,184,148,0.16);
  --amber-soft:   rgba(244,184,61,0.16);
  --rose-soft:    rgba(229,68,109,0.18);

  --bg:           #0E0B22;
  --surface:      #181432;
  --surface-alt:  #231E45;
  --border:       rgba(255,255,255,0.08);
  --border-strong:rgba(255,255,255,0.16);
  --ink:          #F2EFFF;
  --ink-soft:     #A9A4C9;
  --ink-muted:    #7A7596;

  --shadow-sm:    0 1px 3px rgba(0,0,0,0.4);
  --shadow-md:    0 12px 32px rgba(0,0,0,0.45);
  --shadow-lg:    0 18px 48px rgba(0,0,0,0.55);
}

/* ---- Reset / base --------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; scroll-padding-top: 84px; }

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

body {
  margin: 0;
  font-family: var(--font);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  transition: background .3s ease, color .3s ease;
}

img, svg { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.container {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 24px;
}

.section { padding: 96px 0; }
.center { text-align: center; }

/* ---- Buttons -------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
  padding: 13px 22px;
  border-radius: var(--r-md);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn--primary {
  background: var(--purple);
  color: #fff;
  box-shadow: var(--shadow-purple);
}
.btn--primary:hover { background: var(--purple-deep); box-shadow: var(--shadow-lg); }
.btn--ghost {
  background: var(--surface);
  color: var(--purple);
  border-color: var(--border-strong);
}
.btn--ghost:hover { background: var(--surface-alt); }
.btn--lg { font-size: 16px; padding: 16px 28px; }
.btn-row { display: flex; flex-wrap: wrap; gap: 14px; }

/* ---- Nav ------------------------------------------------------------------ */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--border);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 68px;
  gap: 20px;
}
.brand { display: inline-flex; align-items: center; gap: 10px; }
.brand-mark { width: 34px; height: 34px; }
.brand-name {
  font-size: 21px; font-weight: 800; letter-spacing: -0.5px;
  color: var(--ink);
}
.brand-name span { color: var(--purple); }

.nav-links {
  display: flex;
  align-items: center;
  gap: 28px;
  list-style: none;
  margin: 0; padding: 0;
}
.nav-links a {
  font-size: 14.5px; font-weight: 600; color: var(--ink-soft);
  transition: color .15s ease;
  position: relative;
}
.nav-links a:hover, .nav-links a.active { color: var(--ink); }
.nav-links a.active::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -8px;
  height: 2px; border-radius: 2px; background: var(--purple);
}

.nav-right { display: flex; align-items: center; gap: 14px; }

.icon-btn {
  width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--r-full);
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--ink-soft);
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
.icon-btn:hover { color: var(--ink); background: var(--surface-alt); }

.lang {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 700; color: var(--ink-soft);
  background: var(--surface); border: 1px solid var(--border);
  padding: 8px 12px; border-radius: var(--r-full); cursor: pointer;
}
.lang strong { color: var(--purple); }

.nav-toggle {
  display: none;
  width: 42px; height: 42px;
  border-radius: var(--r-sm);
  background: var(--surface);
  border: 1px solid var(--border);
  cursor: pointer;
  color: var(--ink);
  align-items: center; justify-content: center;
}

/* ---- Hero ----------------------------------------------------------------- */
.hero { position: relative; padding: 64px 0 72px; overflow: hidden; }
.hero-bg {
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
}
.hero-bg::before {
  content: ""; position: absolute;
  width: 620px; height: 620px; left: -180px; top: -260px;
  background: radial-gradient(circle, color-mix(in srgb, var(--purple) 38%, transparent), transparent 64%);
  filter: blur(8px);
}
.hero-bg::after {
  content: ""; position: absolute;
  width: 520px; height: 520px; right: -160px; top: 40px;
  background: radial-gradient(circle, color-mix(in srgb, var(--coral) 30%, transparent), transparent 65%);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 56px;
  align-items: center;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 800; letter-spacing: 1.4px;
  text-transform: uppercase; color: var(--purple);
  background: var(--purple-soft);
  padding: 7px 14px; border-radius: var(--r-full);
}
.hero h1 {
  font-size: clamp(34px, 5.4vw, 56px);
  font-weight: 800; letter-spacing: -1.6px; line-height: 1.05;
  margin: 22px 0 0;
  text-wrap: balance;
}
.hero h1 em { font-style: normal; color: var(--purple); }
.hero-lede {
  font-size: 18px; color: var(--ink-soft); line-height: 1.6;
  margin: 22px 0 0; max-width: 540px;
}
.hero-actions { margin-top: 34px; }

.store-badges { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.store-badge {
  display: inline-flex; align-items: center;
  transition: transform .15s ease, box-shadow .2s ease;
  border-radius: 13px; box-shadow: var(--shadow-sm);
}
.store-badge:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
/* Badge « bientot » : visuel non cliquable (app pas encore publiee) — pas de hover trompeur. */
.store-badge.is-soon { cursor: default; }
.store-badge.is-soon:hover { transform: none; box-shadow: var(--shadow-sm); }
.store-badge img { height: 52px; }
.soon-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 700; color: var(--coral-deep);
  background: var(--coral-soft); border: 1px solid color-mix(in srgb, var(--coral) 30%, transparent);
  padding: 7px 13px; border-radius: var(--r-full);
}
.soon-pill .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--coral); }

.trust-row {
  display: flex; flex-wrap: wrap; gap: 18px 26px;
  margin-top: 34px;
}
.trust-row span {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13.5px; font-weight: 600; color: var(--ink-soft);
}
.trust-row svg { color: var(--teal); flex-shrink: 0; }

.hero-visual { display: flex; justify-content: center; }

/* ---- Section heads -------------------------------------------------------- */
.sec-head { max-width: 720px; margin: 0 auto 56px; }
.sec-head.left { margin-left: 0; }
.sec-eyebrow {
  font-size: 12px; font-weight: 800; letter-spacing: 1.6px;
  text-transform: uppercase; color: var(--coral-deep);
}
.sec-title {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 800; letter-spacing: -1px; line-height: 1.12;
  margin: 12px 0 0; text-wrap: balance;
}
.sec-lede {
  font-size: 17px; color: var(--ink-soft); line-height: 1.6;
  margin: 18px 0 0;
}

/* ---- Pourquoi / principe -------------------------------------------------- */
.why { background: var(--surface); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.principle {
  max-width: 880px; margin: 0 auto; text-align: center;
}
.principle p {
  font-size: clamp(24px, 3.4vw, 34px);
  font-weight: 800; letter-spacing: -0.8px; line-height: 1.3;
  text-wrap: balance; margin: 0;
}
.principle p .hl-p { color: var(--purple); }
.principle p .hl-c { color: var(--coral); }
.principle .sub {
  font-size: 17px; font-weight: 400; color: var(--ink-soft);
  letter-spacing: 0; margin-top: 26px; line-height: 1.65;
}
.pillars {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px;
  margin-top: 64px;
}
.pillar {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 28px 24px;
}
.pillar-ico {
  width: 48px; height: 48px; border-radius: 14px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.pillar h3 { font-size: 18px; font-weight: 800; letter-spacing: -0.3px; margin: 0 0 8px; }
.pillar p { font-size: 14.5px; color: var(--ink-soft); margin: 0; }

/* ---- Fonctionnalités ------------------------------------------------------ */
.feat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 28px 26px;
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.feat-ico {
  width: 50px; height: 50px; border-radius: 15px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.feat h3 { font-size: 18.5px; font-weight: 800; letter-spacing: -0.3px; margin: 0 0 9px; }
.feat p { font-size: 14.5px; color: var(--ink-soft); margin: 0; }
.feat-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 800; letter-spacing: 0.6px; text-transform: uppercase;
  color: var(--purple); background: var(--purple-soft);
  padding: 5px 11px; border-radius: var(--r-full);
  margin-bottom: 16px;
}
.feat--wide { grid-column: span 2; display: flex; flex-direction: column; }
.feat--wide.accent {
  background: linear-gradient(135deg, var(--purple) 0%, var(--purple-deep) 100%);
  color: #fff; border: none; position: relative; overflow: hidden;
}
.feat--wide.accent::after {
  content: ""; position: absolute; right: -60px; top: -60px;
  width: 220px; height: 220px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--coral) 55%, transparent), transparent 65%);
}
.feat--wide.accent h3 { font-size: 24px; }
.feat--wide.accent p { color: rgba(255,255,255,0.86); font-size: 15.5px; max-width: 460px; }
.feat--wide.accent .feat-tag { color: #fff; background: rgba(255,255,255,0.18); }
.feat--wide.accent .feat-ico { background: rgba(255,255,255,0.16); color: #fff; }

/* socle / pensé pour la vraie vie */
.socle {
  margin-top: 24px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.socle-item {
  display: flex; align-items: center; gap: 14px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 18px 20px;
}
.socle-item .feat-ico { width: 42px; height: 42px; border-radius: 12px; margin: 0; }
.socle-item b { font-size: 15px; font-weight: 800; display: block; }
.socle-item span { font-size: 13px; color: var(--ink-soft); }

/* ---- Captures / phones ---------------------------------------------------- */
.screens { background: var(--surface); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.phones {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  align-items: start;
}
.phone-wrap { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.phone {
  position: relative;
  width: 100%; max-width: 264px;
  /* Hauteur pilotée par le contenu (plancher min-height sur .phone-screen) : l'ecran
     d'accueil complet s'affiche en entier, sans coupe ni chevauchement de la tab bar. */
  background: #0E0B22;
  border-radius: 38px;
  padding: 11px;
  box-shadow: var(--shadow-lg), 0 0 0 2px rgba(20,16,55,0.06);
}
.phone-notch {
  position: absolute; top: 12px; left: 50%; transform: translateX(-50%);
  width: 96px; height: 22px; background: #0E0B22; border-radius: 0 0 14px 14px;
  z-index: 4;
}
.phone-screen {
  position: relative;
  width: 100%; min-height: 552px; height: auto;
  background: var(--bg);
  border-radius: 28px;
  overflow: hidden;
  display: flex; flex-direction: column;
  font-size: 11px;
}
.phone-caption {
  text-align: center;
}
.phone-caption b { font-size: 14.5px; font-weight: 800; display: block; letter-spacing: -0.2px; }
.phone-caption span { font-size: 12.5px; color: var(--ink-muted); }

/* status bar */
.mk-status {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 16px 2px; font-size: 10px; font-weight: 800; color: var(--ink);
}
.mk-status .dots { display: inline-flex; gap: 3px; align-items: center; }
.mk-status .dots i { width: 4px; height: 4px; border-radius: 50%; background: var(--ink-muted); display: inline-block; }

/* generic mock atoms */
.mk-avatar {
  width: 28px; height: 28px; border-radius: 50%; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; flex-shrink: 0;
}
.mk-mini { display: flex; }
.mk-mini i {
  width: 18px; height: 18px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 8px; font-weight: 800; color: #fff;
  border: 1.5px solid var(--surface);
}
.mk-mini i + i { margin-left: -7px; }
/* Bouton-icône circulaire (header dashboard / chrome calendrier / journal) */
.mk-ibtn {
  position: relative; width: 26px; height: 26px; border-radius: 50%;
  background: var(--surface); border: 1px solid var(--border);
  display: inline-flex; align-items: center; justify-content: center; color: var(--ink);
}
.mk-ibtn.add { background: var(--purple); border-color: transparent; box-shadow: var(--shadow-purple); }
.mk-ibtn .dot { position: absolute; top: 3px; right: 4px; width: 6px; height: 6px; border-radius: 50%; background: var(--coral); border: 1.5px solid var(--surface); }

/* ===== Pulpit / Dashboard (DashboardHeader + DashboardTodaySection + DashboardBalanceCard) ===== */
.mk-dhead { display: flex; align-items: center; justify-content: space-between; gap: 6px; padding: 6px 13px 8px; }
.mk-grouppill {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-full); padding: 3px 9px 3px 4px;
  font-size: 10px; font-weight: 700; color: var(--ink-soft);
}
.mk-grouppill svg { color: var(--ink-muted); }
.mk-dbtns { display: flex; align-items: center; gap: 5px; }

/* Fioletowa karta „Dziś” (hero) */
.mk-today {
  margin: 2px 13px 0; border-radius: 18px; padding: 13px 14px 14px;
  color: #fff; position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--purple) 0%, var(--purple-deep) 100%);
  box-shadow: var(--shadow-purple);
}
.mk-today::after {
  content: ""; position: absolute; right: -28px; top: -28px;
  width: 110px; height: 110px; border-radius: 50%; background: rgba(255,255,255,0.10);
}
.mk-today-top { display: flex; align-items: center; justify-content: space-between; position: relative; }
.mk-today-kicker { font-size: 9px; font-weight: 800; letter-spacing: 1px; color: rgba(255,255,255,0.78); }
.mk-weekchip {
  display: inline-flex; align-items: center; gap: 4px;
  background: rgba(255,255,255,0.18); border-radius: var(--r-full);
  padding: 3px 8px; font-size: 9px; font-weight: 700;
}
.mk-today-greet { font-size: 20px; font-weight: 800; letter-spacing: -0.6px; margin-top: 8px; position: relative; }
.mk-today-focal { display: flex; align-items: center; gap: 8px; margin-top: 9px; position: relative; }
.mk-today-avs { display: flex; background: rgba(255,255,255,0.18); border-radius: var(--r-full); padding: 3px 6px 3px 5px; }
.mk-today-avs i {
  width: 20px; height: 20px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 800; color: #fff; border: 1.5px solid rgba(255,255,255,0.65);
}
.mk-today-avs i + i { margin-left: -6px; }
.mk-today-line { flex: 1; font-size: 11px; font-weight: 600; color: rgba(255,255,255,0.85); line-height: 1.3; }

/* Biała karta salda (atomy współdzielone z .mk-balcard / .mk-bal-head) */
.mk-bal-bubble {
  width: 34px; height: 34px; border-radius: 11px; background: var(--purple-soft);
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.mk-bal-body { flex: 1; min-width: 0; }
.mk-bal-kicker { font-size: 9px; font-weight: 800; letter-spacing: 1px; color: var(--ink-muted); }
.mk-bal-primary { font-size: 13px; font-weight: 800; letter-spacing: -0.2px; margin-top: 2px; color: var(--ink); }
.mk-bal-primary mark { background: transparent; color: var(--purple); }

/* Nota „w trakcie zatwierdzania” + saldo projektowane (BalancePendingNote) */
.mk-pending {
  margin: 8px 13px 0; background: var(--surface); border: 1px solid var(--border);
  border-radius: 12px; padding: 9px 11px;
}
.mk-pending-title { display: flex; align-items: flex-start; gap: 6px; font-size: 10px; font-weight: 700; color: var(--amber); line-height: 1.3; }
.mk-pending-title svg { color: var(--amber); flex-shrink: 0; margin-top: 1px; }
.mk-pending-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 6px; }
.mk-pending-proj { font-size: 10px; font-weight: 600; color: var(--ink-soft); }
.mk-pending-go { font-size: 9.5px; font-weight: 800; color: var(--ink); border: 1px solid var(--border); border-radius: var(--r-full); padding: 4px 9px; white-space: nowrap; }

/* tab bar */
.mk-tabbar {
  margin-top: auto;
  display: flex; align-items: center; background: var(--surface);
  border-top: 1px solid var(--border);
  padding: 7px 0 9px;
}
.mk-tab { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px; color: var(--ink-muted); }
.mk-tab span { font-size: 8px; font-weight: 700; }
.mk-tab.active { color: var(--purple); }
/* FAB centralny (+) wzniesiony nad pasek — jak w aplikacji */
.mk-fab {
  flex-shrink: 0; width: 34px; height: 34px; border-radius: 50%;
  background: var(--purple); display: inline-flex; align-items: center; justify-content: center;
  margin: -16px 6px 0; box-shadow: var(--shadow-purple);
}

/* ===== Entête d'écran réutilisé (Dépenses / Journal) : retour + titre ===== */
.mk-xhead { display: flex; align-items: center; justify-content: space-between; padding: 8px 13px 4px; }
.mk-back {
  width: 26px; height: 26px; border-radius: 50%; background: var(--surface); border: 1px solid var(--border);
  display: inline-flex; align-items: center; justify-content: center; color: var(--ink);
}
.mk-xtitle { font-size: 13px; font-weight: 800; letter-spacing: -0.3px; color: var(--ink); }

/* ===== Kalendarz / Calendar (CalChromeV2 + CalMonthGrid) ===== */
.mk-calchrome { display: flex; align-items: center; gap: 8px; padding: 6px 13px 6px; }
.mk-calapp { width: 26px; height: 26px; border-radius: 9px; background: var(--purple); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: var(--shadow-purple); }
.mk-caltitle { flex: 1; font-size: 13px; font-weight: 800; letter-spacing: -0.3px; color: var(--ink); }
.mk-calutils { display: flex; gap: 5px; }
.mk-calnav { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 0 13px 8px; }
.mk-calperiod b { font-size: 14px; font-weight: 800; letter-spacing: -0.4px; display: block; color: var(--ink); }
.mk-calperiod span { font-size: 9px; font-weight: 600; color: var(--ink-soft); }
.mk-calnavbtns { display: flex; align-items: center; gap: 5px; }
.mk-calnavbtns .nb { width: 22px; height: 22px; border-radius: 50%; background: var(--surface); border: 1px solid var(--border); display: inline-flex; align-items: center; justify-content: center; color: var(--ink-soft); }
.mk-calnavbtns .now { font-size: 9px; font-weight: 800; letter-spacing: 0.5px; color: var(--purple); background: var(--purple-soft); padding: 5px 8px; border-radius: var(--r-full); }
.mk-calswitch { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 0 13px 8px; }
.mk-viewseg { display: flex; background: var(--surface-alt); border-radius: 9px; padding: 3px; }
.mk-viewseg span { font-size: 8.5px; font-weight: 800; padding: 4px 7px; border-radius: 6px; color: var(--ink-muted); }
.mk-viewseg span.on { background: var(--surface); color: var(--ink); box-shadow: var(--shadow-sm); }
.mk-legend3 { display: flex; gap: 8px; flex-wrap: wrap; }
.mk-legend3 span { display: inline-flex; align-items: center; gap: 4px; font-size: 8.5px; font-weight: 700; color: var(--ink-soft); }
.mk-legend3 i { width: 8px; height: 8px; border-radius: 2.5px; }
.mk-week { display: grid; grid-template-columns: repeat(7,1fr); padding: 0 11px; }
.mk-week span { text-align: center; font-size: 8px; font-weight: 800; color: var(--ink-muted); padding: 2px 0; }
.mk-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 3px; padding: 0 11px; }
/* Komórka dnia (d'après capture) : numer u góry-lewej + kolorowy pasek opieki na
   dole (corail = mama, fiolet = Ty) ; dni „Ty" mają lekkie lawendowe tło ; dziś =
   pełny kolor rodzica w opiece (corail dla 30) z białym numerem. */
.mk-day {
  aspect-ratio: 0.8; border-radius: 8px; position: relative;
  display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start;
  padding: 4px 5px; font-size: 11px; font-weight: 800; color: var(--ink);
  background: var(--surface); border: 0.5px solid var(--border); overflow: hidden;
}
.mk-day.you { background: color-mix(in srgb, var(--purple) 9%, var(--surface)); }
.mk-day .barb { position: absolute; left: 5px; right: 5px; bottom: 4px; height: 2px; border-radius: 2px; }
.mk-day.them .barb { background: var(--coral); }
.mk-day.you .barb { background: var(--purple); }
.mk-day.today { color: #fff; border-color: transparent; box-shadow: var(--shadow-purple); }
.mk-day.today.them { background: var(--coral); }
.mk-day.today.you { background: var(--purple); }
.mk-day.today .barb { display: none; }

/* ===== Dziennik / Journal (JournalScreen : trust banner + spine timeline) ===== */
.mk-jhead { display: flex; align-items: center; gap: 8px; padding: 8px 13px 6px; }
.mk-jhead .mk-xtitle { flex: 1; }
.mk-jacts { display: flex; gap: 5px; }
.mk-trust {
  margin: 4px 13px 0; display: flex; align-items: center; gap: 9px;
  background: var(--teal-soft); border: 1px solid color-mix(in srgb, var(--teal) 28%, transparent);
  border-radius: 13px; padding: 10px 11px;
}
.mk-trust .ic { width: 28px; height: 28px; border-radius: 8px; background: var(--teal); color: #fff; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mk-trust-txt { flex: 1; min-width: 0; }
.mk-trust-txt b { font-size: 11px; font-weight: 800; display: block; color: var(--ink); }
.mk-trust-txt span { font-size: 9px; color: var(--ink-soft); }
.mk-trust-cta { font-size: 9.5px; font-weight: 800; color: var(--teal); background: var(--surface); border: 1px solid var(--border); border-radius: 9px; padding: 6px 9px; white-space: nowrap; flex-shrink: 0; }
.mk-jday { font-size: 9px; font-weight: 800; letter-spacing: 0.8px; color: var(--ink-soft); padding: 13px 14px 6px; }
.mk-jrow { position: relative; display: flex; gap: 10px; align-items: flex-start; padding: 0 14px 8px; }
/* Spine = pionowa linia łącząca kropki na osi czasu (ukryta na ostatnim wpisie). */
.mk-jspine { position: absolute; left: 25px; top: 24px; bottom: -2px; width: 1.5px; background: var(--border); }
.mk-jspine.last { display: none; }
.mk-jdot { width: 24px; height: 24px; border-radius: 50%; border: 2px solid var(--teal); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; z-index: 1; margin-top: 2px; }
.mk-jcard { flex: 1; min-width: 0; background: var(--surface); border: 1px solid var(--border); border-radius: 11px; padding: 8px 10px; }
.mk-jcard .t { font-size: 9px; font-weight: 700; color: var(--ink-soft); }
.mk-jcard b { font-size: 11px; font-weight: 700; display: block; margin-top: 1px; color: var(--ink); }
.mk-jcard span { font-size: 9.5px; color: var(--ink-soft); }

/* ---- Guide / manuel ------------------------------------------------------- */
.steps {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 20px 40px;
  counter-reset: step;
  max-width: 980px; margin: 0 auto;
}
.step {
  position: relative; display: flex; gap: 18px; align-items: flex-start;
  padding: 22px; background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
}
.step-num {
  flex-shrink: 0; width: 42px; height: 42px; border-radius: 13px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 17px; font-weight: 800; color: #fff;
  background: linear-gradient(135deg, var(--purple), var(--purple-deep));
  box-shadow: var(--shadow-purple);
}
.step h3 { font-size: 16.5px; font-weight: 800; margin: 2px 0 6px; letter-spacing: -0.2px; }
.step p { font-size: 14px; color: var(--ink-soft); margin: 0; }

/* ---- Téléchargement ------------------------------------------------------- */
.download { }
.dl-card {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--purple) 0%, var(--purple-deep) 100%);
  border-radius: 32px; padding: 56px 48px; color: #fff;
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: center;
  box-shadow: var(--shadow-lg);
}
.dl-card::after {
  content: ""; position: absolute; right: -80px; bottom: -120px;
  width: 360px; height: 360px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--coral) 50%, transparent), transparent 64%);
}
.dl-card h2 { font-size: clamp(26px, 3.4vw, 36px); font-weight: 800; letter-spacing: -0.8px; margin: 0; position: relative; }
.dl-card p { font-size: 16px; color: rgba(255,255,255,0.85); margin: 16px 0 28px; position: relative; max-width: 440px; }
.dl-card .store-badges { position: relative; }
.dl-card .store-badge img { height: 54px; }
.dl-qr {
  position: relative; justify-self: center; text-align: center;
}
.dl-qr .frame {
  background: #fff; padding: 14px; border-radius: 20px; box-shadow: var(--shadow-lg);
  width: 168px; height: 168px; display: flex; align-items: center; justify-content: center;
}
.dl-qr .frame img { width: 100%; height: 100%; }
.dl-qr .cap { font-size: 12.5px; font-weight: 700; color: rgba(255,255,255,0.9); margin-top: 14px; }

/* ---- Notify / lista oczekujących (waitlist, dans la carte téléchargement) --- */
.notify { position: relative; margin-top: 26px; max-width: 460px; }
.notify-label { display: block; font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 10px; }
.notify-row { display: flex; gap: 10px; flex-wrap: wrap; }
.notify-input {
  flex: 1 1 220px; min-width: 0; font-family: inherit; font-size: 15px; color: var(--ink);
  background: #fff; border: 1.5px solid transparent; border-radius: var(--r-md);
  padding: 13px 16px; outline: none; transition: box-shadow .2s ease;
}
.notify-input::placeholder { color: var(--ink-muted); }
.notify-input:focus { box-shadow: 0 0 0 3px rgba(253,123,90,0.45); }
.notify-btn {
  flex: 0 0 auto; font-family: inherit; font-size: 15px; font-weight: 700; line-height: 1;
  padding: 13px 22px; border: none; border-radius: var(--r-md); cursor: pointer;
  background: var(--coral); color: #fff; box-shadow: 0 10px 24px rgba(225,91,58,0.35);
  transition: transform .15s ease, background .2s ease;
}
.notify-btn:hover { background: var(--coral-deep); }
.notify-btn:active { transform: translateY(1px); }
.notify-hint { font-size: 13px !important; color: rgba(255,255,255,0.72) !important; margin: 12px 0 0 !important; max-width: none !important; }
.notify-msg { font-size: 13.5px; font-weight: 600; margin: 12px 0 0 !important; max-width: none !important; }
.notify-msg.ok  { color: #C9F6E9; }
.notify-msg.err { color: #FFD9CE; }
@media (max-width: 560px) {
  .notify-row { flex-direction: column; }
  .notify-btn { width: 100%; }
}

/* ---- Footer --------------------------------------------------------------- */
.footer { background: var(--surface); border-top: 1px solid var(--border); padding: 64px 0 32px; }
.footer-grid {
  display: grid; grid-template-columns: 1.6fr repeat(2, 1fr); gap: 40px;
  padding-bottom: 40px; border-bottom: 1px solid var(--border);
}
.footer-brand .brand { margin-bottom: 16px; }
.footer-brand p { font-size: 14px; color: var(--ink-soft); max-width: 320px; margin: 0 0 18px; }
.footer-col h4 { font-size: 12px; font-weight: 800; letter-spacing: 0.8px; text-transform: uppercase; color: var(--ink-muted); margin: 0 0 16px; }
.footer-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.footer-col a { font-size: 14px; color: var(--ink-soft); transition: color .15s ease; }
.footer-col a:hover { color: var(--ink); }
.footer-bottom {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: 16px; padding-top: 24px;
}
.footer-bottom p { font-size: 13px; color: var(--ink-muted); margin: 0; }
.footer-bottom .langs { display: flex; gap: 8px; }
.footer-bottom .langs button {
  font-family: inherit; font-size: 12px; font-weight: 700; cursor: pointer;
  background: var(--bg); border: 1px solid var(--border); color: var(--ink-soft);
  padding: 6px 12px; border-radius: var(--r-full);
}
.footer-bottom .langs button.active { background: var(--purple); color: #fff; border-color: var(--purple); }

/* ---- Reveal on scroll ----------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity: 1; transform: none; }

/* ---- Responsive ----------------------------------------------------------- */
@media (max-width: 1080px) {
  .feat-grid { grid-template-columns: repeat(2, 1fr); }
  .feat--wide { grid-column: span 2; }
  .phones { grid-template-columns: repeat(2, 1fr); gap: 40px 28px; }
  .socle { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 860px) {
  .section { padding: 72px 0; }
  .nav-links, .nav-cta { display: none; }
  .nav-toggle { display: inline-flex; }
  body.nav-open .nav-links {
    display: flex; position: absolute; top: 68px; left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--surface); border-bottom: 1px solid var(--border);
    padding: 8px 0; box-shadow: var(--shadow-md);
  }
  body.nav-open .nav-links li { padding: 0 24px; }
  body.nav-open .nav-links a { display: block; padding: 14px 0; border-bottom: 1px solid var(--border); }
  body.nav-open .nav-links a.active::after { display: none; }

  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-visual { order: -1; }
  .pillars { grid-template-columns: 1fr; }
  .steps { grid-template-columns: 1fr; }
  .dl-card { grid-template-columns: 1fr; text-align: center; padding: 44px 28px; }
  .dl-card p { margin-left: auto; margin-right: auto; }
  .dl-card .store-badges { justify-content: center; }
  .dl-qr { margin-top: 8px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-brand { grid-column: span 2; }
}

/* ---- Icons (sprite <use>) ------------------------------------------------- */
.ico {
  width: 22px; height: 22px;
  fill: none; stroke: currentColor; stroke-width: 1.8;
  stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0; display: block;
}
.feat-ico .ico, .pillar-ico .ico { width: 24px; height: 24px; }
.brand-mark { border-radius: 9px; }

/* ---- Language switch (général) -------------------------------------------- */
.langs { display: inline-flex; gap: 6px; }
.langs button {
  font-family: inherit; font-size: 12.5px; font-weight: 800; cursor: pointer;
  background: var(--surface); border: 1px solid var(--border); color: var(--ink-soft);
  padding: 7px 12px; border-radius: var(--r-full);
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.langs button:hover { color: var(--ink); }
.langs button.active { background: var(--purple); color: #fff; border-color: var(--purple); }

/* ---- Theme toggle icon swap ----------------------------------------------- */
#theme-toggle .ico-sun { display: none; }
[data-theme="dark"] #theme-toggle .ico-moon { display: none; }
[data-theme="dark"] #theme-toggle .ico-sun  { display: block; }

/* ---- Feature accent card (différenciateur) -------------------------------- */
.card.feat.accent {
  background: linear-gradient(135deg, var(--purple) 0%, var(--purple-deep) 100%);
  color: #fff; border: none; position: relative; overflow: hidden;
  box-shadow: var(--shadow-purple);
}
.card.feat.accent::after {
  content: ""; position: absolute; right: -60px; top: -60px;
  width: 200px; height: 200px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--coral) 55%, transparent), transparent 65%);
}
.card.feat.accent h3, .card.feat.accent p, .card.feat.accent .feat-tag { position: relative; }
.card.feat.accent p { color: rgba(255,255,255,0.88); }
.card.feat.accent .feat-ico { background: rgba(255,255,255,0.16); color: #fff; }
.card.feat.accent .feat-tag { color: #fff; background: rgba(255,255,255,0.20); }
.card.feat.accent:hover { box-shadow: var(--shadow-lg); border-color: transparent; }

@media (max-width: 560px) {
  .container { padding: 0 18px; }
  .feat-grid { grid-template-columns: 1fr; }
  .feat--wide, .feat--wide.accent { grid-column: span 1; }
  .phones { grid-template-columns: 1fr; }
  .phone { max-width: 280px; margin: 0 auto; }
  .socle { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-brand { grid-column: span 1; }
  .hero h1 { letter-spacing: -1px; }
}

/* ==========================================================================
   Marque réelle Mefami (front/assets/icon.png) + reprise identité BootSplash
   ========================================================================== */

/* Logo applicatif en pastille (nav / footer) : ombre douce de marque. */
.brand-mark {
  border-radius: 9px;
  box-shadow: 0 2px 8px rgba(75,63,190,0.18);
}

/* Lockup de marque du hero : logo réel + halo (cf. BootSplash) + wordmark. */
.hero-brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}
.hero-logo {
  position: relative;
  width: 56px; height: 56px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
/* Halo : teinte de marque purple en radial doux, « allumé » derrière le logo. */
.hero-logo::before {
  content: "";
  position: absolute;
  width: 150px; height: 150px;
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--purple) 30%, transparent), transparent 66%);
  z-index: 0;
  pointer-events: none;
}
.hero-logo img {
  position: relative; z-index: 1;
  width: 56px; height: 56px;
  border-radius: 15px;
  box-shadow: 0 12px 28px rgba(75,63,190,0.30);
}
.hero-wordmark {
  font-size: 30px; font-weight: 800; letter-spacing: -0.9px;
  color: var(--ink);
}

/* Lockup hero : compacte sous le breakpoint mobile. */
@media (max-width: 560px) {
  .hero-logo, .hero-logo img { width: 48px; height: 48px; }
  .hero-wordmark { font-size: 26px; }
}

/* ==========================================================================
   Écrans fidèles d'après les captures réelles (capture/*.PNG)
   ========================================================================== */

/* ---- Accueil / Dashboard : carte solde + nota + zadania + prośby ---------- */
.mk-balcard {
  margin: 10px 13px 0; background: var(--surface); border: 1px solid var(--border);
  border-radius: 14px; padding: 11px; display: flex; flex-direction: column; gap: 9px;
}
.mk-bal-head { display: flex; align-items: center; gap: 10px; }
.mk-bal-sub { font-size: 10px; color: var(--ink-muted); margin-top: 2px; }
.mk-pending-acts { display: inline-flex; align-items: center; gap: 9px; flex-shrink: 0; }
.mk-pending-list { font-size: 9.5px; font-weight: 800; color: var(--purple); white-space: nowrap; }

.mk-taskcard {
  margin: 8px 13px 0; display: flex; align-items: center; gap: 10px;
  background: var(--purple-soft); border-radius: 13px; padding: 10px 11px;
}
.mk-tc-bubble { width: 32px; height: 32px; border-radius: 10px; background: var(--surface); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mk-tc-body { flex: 1; min-width: 0; }
.mk-tc-kicker { font-size: 9px; font-weight: 800; letter-spacing: 1px; color: var(--ink-muted); }
.mk-tc-title { font-size: 12px; font-weight: 800; color: var(--ink); margin-top: 1px; }
.mk-tc-sub { font-size: 9.5px; color: var(--ink-soft); }

.mk-awaitcard {
  margin: 8px 13px 0; display: flex; align-items: center; gap: 10px;
  background: var(--surface); border: 1px solid var(--border); border-radius: 13px; padding: 9px 11px;
}
.mk-aw-bubble { position: relative; width: 30px; height: 30px; border-radius: 9px; background: var(--purple-soft); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mk-aw-badge { position: absolute; top: -6px; left: -6px; font-size: 7.5px; font-weight: 800; color: #fff; background: var(--purple); border-radius: var(--r-full); padding: 1px 4px; }
.mk-aw-txt { flex: 1; font-size: 11px; font-weight: 600; color: var(--ink); }

/* ---- Dépenses (lista) : zielona banda + kategorie + wiersze ---------------- */
.mk-balband {
  margin: 8px 13px 0; display: flex; align-items: center; justify-content: space-between; gap: 8px;
  background: var(--teal-soft); border-radius: 12px; padding: 9px 12px;
}
.mk-bb-txt { font-size: 11px; font-weight: 600; color: var(--ink); line-height: 1.35; }
.mk-bb-txt .me { color: var(--purple); font-weight: 800; }
.mk-bb-txt mark { background: transparent; color: var(--teal); font-weight: 800; }
.mk-bb-txt em { font-style: normal; color: var(--ink-muted); }
.mk-bb-cta { font-size: 11px; font-weight: 800; color: var(--teal); background: var(--surface); padding: 6px 12px; border-radius: var(--r-full); white-space: nowrap; flex-shrink: 0; }
.mk-cattabs { display: flex; gap: 14px; padding: 12px 13px 8px; overflow: hidden; }
.mk-cattabs .ct { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; color: var(--ink-muted); white-space: nowrap; padding-bottom: 5px; }
.mk-cattabs .ct.on { color: var(--purple); border-bottom: 2px solid var(--purple); }
.mk-daylbl { font-size: 9px; font-weight: 800; letter-spacing: 1px; color: var(--ink-muted); padding: 8px 14px 4px; }
.mk-exprow { display: flex; align-items: center; gap: 10px; padding: 9px 14px; border-bottom: 1px solid var(--border); }
.mk-exp-ic { width: 30px; height: 30px; border-radius: 9px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mk-exp-body { flex: 1; min-width: 0; }
.mk-exp-body > b { font-size: 12px; font-weight: 800; color: var(--ink); display: block; }
.mk-exp-body .paid { display: inline-flex; align-items: center; gap: 5px; font-size: 9.5px; color: var(--ink-soft); margin-top: 1px; }
.mk-exp-body .paid i { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.mk-exp-amt { text-align: right; flex-shrink: 0; }
.mk-exp-amt > b { font-size: 12px; font-weight: 800; color: var(--ink); display: block; }
.mk-exp-amt .neg { font-size: 10.5px; font-weight: 700; color: var(--coral-deep); }
.mk-exp-amt .pos { font-size: 10.5px; font-weight: 700; color: var(--teal); }

/* ---- Calendrier : légende avion + cartes garde/rythme --------------------- */
.mk-legend3 .plane { font-size: 9px; line-height: 1; }
.mk-gardecard { margin: 8px 13px 0; display: flex; align-items: center; gap: 9px; border-radius: 12px; padding: 8px 10px; }
.mk-gardecard.amber { background: var(--amber-soft); }
.mk-gardecard.violet { background: var(--purple-soft); }
.mk-gardecard .gc-ic { width: 28px; height: 28px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mk-gardecard .gc-txt { flex: 1; min-width: 0; }
.mk-gardecard .gc-txt b { font-size: 11px; font-weight: 800; color: var(--ink); display: block; }
.mk-gardecard .gc-txt span { font-size: 9.5px; color: var(--ink-soft); }

/* ---- Garde des vacances : entête + qui commence + suggérer + inbox -------- */
.mk-gvhead { display: flex; align-items: flex-start; gap: 9px; padding: 8px 13px 8px; }
.mk-gvhead-txt { flex: 1; min-width: 0; }
.mk-gvhead-txt b { font-size: 14px; font-weight: 800; color: var(--ink); display: block; letter-spacing: -0.3px; }
.mk-gvhead-txt span { font-size: 9.5px; color: var(--ink-soft); }
.mk-gvlabel { font-size: 11px; font-weight: 700; color: var(--ink-soft); padding: 4px 14px 6px; }
.mk-gvtoggle { display: flex; gap: 8px; margin: 0 13px; }
.mk-gvtoggle .gvt {
  flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  border: 1px solid var(--border); border-radius: 12px; padding: 11px 0;
  font-size: 11px; font-weight: 800; color: var(--ink-soft);
}
.mk-gvtoggle .gvt i { width: 8px; height: 8px; border-radius: 50%; }
.mk-gvtoggle .gvt.on { border-color: var(--purple); background: var(--purple-soft); color: var(--ink); }
.mk-gvsuggest {
  margin: 12px 13px 0; background: var(--surface); border: 1px solid var(--border);
  border-radius: 16px; padding: 14px 14px 16px; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 7px;
}
.mk-gvsuggest .gvs-ic { width: 36px; height: 36px; border-radius: 10px; background: var(--amber-soft); display: inline-flex; align-items: center; justify-content: center; }
.mk-gvsuggest > b { font-size: 13px; font-weight: 800; color: var(--ink); }
.mk-gvsuggest .gvs-body { font-size: 10px; color: var(--ink-soft); line-height: 1.4; max-width: 200px; }
.mk-gvsuggest .gvs-cta { display: inline-flex; align-items: center; gap: 6px; background: var(--amber); color: #fff; font-size: 12px; font-weight: 800; padding: 9px 22px; border-radius: var(--r-full); margin-top: 4px; box-shadow: 0 8px 18px rgba(244,184,61,0.4); }
.mk-gvsection { font-size: 9.5px; font-weight: 800; letter-spacing: 0.6px; color: var(--ink-soft); padding: 14px 14px 6px; }
.mk-gvcard { margin: 0 13px; background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 11px 12px; }
.mk-gvcard .gvc-top { display: inline-flex; align-items: center; gap: 6px; }
.mk-gvcard .gvc-top b { font-size: 12px; font-weight: 800; color: var(--ink); }
.mk-gvcard .gvc-dates { font-size: 10px; color: var(--ink-soft); margin-top: 4px; }
.mk-gvcard .gvc-by { font-size: 10px; color: var(--ink-soft); margin-top: 3px; }
.mk-gvcard .gvc-by b { color: var(--ink); font-weight: 800; }
.mk-gvcard .gvc-badge { display: inline-flex; align-items: center; gap: 5px; margin-top: 9px; background: var(--amber-soft); color: #c8860a; font-size: 9.5px; font-weight: 800; padding: 5px 9px; border-radius: var(--r-full); }
.mk-gvcard .gvc-badge svg { color: var(--amber); }

/* ---- Accueil : chevron de la rangée focale + section « Wkrótce » ---------- */
.mk-today-avs { align-items: center; }
.mk-today-avs .chev { width: 16px; height: 16px; border-radius: 50%; background: rgba(255,255,255,0.25); display: inline-flex; align-items: center; justify-content: center; margin-left: 4px; }
.mk-soonhd { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px 2px; }
.mk-soonhd b { font-size: 9px; font-weight: 800; letter-spacing: 1px; color: var(--ink-muted); }
.mk-soonhd em { font-style: normal; font-size: 9.5px; font-weight: 800; color: var(--purple); }
.mk-soonrow { display: flex; align-items: center; gap: 10px; padding: 7px 13px 0; }
.mk-soon-ic { width: 30px; height: 30px; border-radius: 9px; background: var(--teal-soft); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mk-soon-body { flex: 1; min-width: 0; }
.mk-soon-body b { font-size: 12px; font-weight: 800; color: var(--ink); display: block; }
.mk-soon-body span { font-size: 9.5px; color: var(--ink-soft); }

/* ==========================================================================
   Porady / Tips — articles bien-être enfant & coparentalité
   ========================================================================== */
.tips { background: var(--surface); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.tips-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.tip {
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 28px 26px; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.tip:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.tip-ico {
  width: 50px; height: 50px; border-radius: 15px;
  display: inline-flex; align-items: center; justify-content: center; margin-bottom: 18px;
}
.tip h3 { font-size: 18px; font-weight: 800; letter-spacing: -0.3px; margin: 0 0 9px; line-height: 1.25; }
.tip p { font-size: 14.5px; color: var(--ink-soft); margin: 0; line-height: 1.6; }
@media (max-width: 1080px) { .tips-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .tips-grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   Écrans additionnels d'après captures : Zadania · Tryb pilny · Profil dziecka
   ========================================================================== */

/* Spacer qui équilibre l'entête retour+titre pour centrer le titre (pas d'actions). */
.mk-hspacer { width: 26px; flex-shrink: 0; }

/* ---- Zadania / Tasks : label « à faire » + carte tâche -------------------- */
.mk-tasklbl { font-size: 9px; font-weight: 800; letter-spacing: 1px; color: #c8860a; padding: 14px 14px 8px; }
.mk-taskitem {
  margin: 0 13px; display: flex; align-items: flex-start; gap: 11px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 14px; padding: 12px; box-shadow: var(--shadow-sm);
}
.mk-taskitem .mk-avatar { margin-top: 2px; }
.mk-ti-body { flex: 1; min-width: 0; }
.mk-ti-title { font-size: 12.5px; font-weight: 800; color: var(--ink); }
.mk-ti-sub { font-size: 10px; color: var(--ink-soft); margin-top: 2px; }
.mk-ti-date { font-size: 10px; color: var(--ink-soft); margin-top: 3px; }
.mk-ti-kid {
  display: inline-flex; align-items: center; gap: 4px; margin-top: 8px;
  background: var(--teal-soft); color: var(--teal);
  font-size: 9.5px; font-weight: 800; padding: 3px 8px; border-radius: var(--r-full);
}
.mk-ti-kid svg { color: var(--teal); }
.mk-taskitem > svg { margin-top: 4px; flex-shrink: 0; }

/* ---- Tryb pilny / Emergency : titre + cartes corail + bouton alerte ------- */
.mk-emgtitle { font-size: 17px; font-weight: 800; letter-spacing: -0.4px; color: var(--ink); padding: 12px 14px 4px; }
.mk-emgsub { font-size: 10.5px; color: var(--ink-soft); line-height: 1.45; padding: 0 14px 12px; }
.mk-emgcard {
  margin: 0 13px 9px; display: flex; align-items: center; gap: 11px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 14px; padding: 11px; box-shadow: var(--shadow-sm);
}
.mk-emgcard .emg-ic {
  width: 36px; height: 36px; border-radius: 11px; background: var(--coral);
  color: #fff; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.mk-emgcard .emg-body { flex: 1; min-width: 0; }
.mk-emgcard .emg-body b { font-size: 12.5px; font-weight: 800; color: var(--ink); display: block; }
.mk-emgcard .emg-body span { font-size: 9.5px; color: var(--ink-soft); line-height: 1.35; display: block; margin-top: 2px; }
.mk-emgcard > svg { flex-shrink: 0; }
.mk-emgbtn {
  margin: 6px 13px 0; background: var(--coral); color: #fff;
  font-size: 12.5px; font-weight: 800; text-align: center; padding: 12px; border-radius: 14px;
  box-shadow: 0 8px 18px rgba(253,123,90,0.4);
}
.mk-emgnote { font-size: 9.5px; color: var(--ink-soft); text-align: center; padding: 9px 16px 0; line-height: 1.35; }

/* ---- Profil dziecka / Child profile : entête + onglets + allergie + actions */
.mk-cphead { display: flex; align-items: center; gap: 9px; padding: 8px 13px 8px; }
.mk-cphead .mk-cpname { flex: 1; min-width: 0; }
.mk-cphead .mk-cpname b { font-size: 14px; font-weight: 800; color: var(--ink); display: block; letter-spacing: -0.3px; }
.mk-cphead .mk-cpname span { font-size: 9.5px; color: var(--ink-soft); }
.mk-cphead .mk-cpacts { display: flex; gap: 5px; flex-shrink: 0; }
.mk-cptabs { display: flex; gap: 14px; padding: 4px 13px 0; overflow: hidden; border-bottom: 1px solid var(--border); }
.mk-cptabs .cpt { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; color: var(--ink-muted); white-space: nowrap; padding-bottom: 8px; }
.mk-cptabs .cpt.on { color: var(--purple); border-bottom: 2px solid var(--purple); margin-bottom: -1px; }
.mk-alrgcard {
  margin: 14px 13px 0; display: flex; align-items: center; gap: 10px;
  background: var(--coral-soft); border: 1px solid color-mix(in srgb, var(--coral) 25%, transparent);
  border-radius: 13px; padding: 11px;
}
.mk-alrgcard .al-ic { width: 30px; height: 30px; border-radius: 9px; background: var(--coral); color: #fff; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mk-alrgcard b { flex: 1; font-size: 12.5px; font-weight: 800; color: var(--ink); }
.mk-alrgcard .al-acts { display: inline-flex; align-items: center; gap: 9px; color: var(--ink-muted); flex-shrink: 0; }
.mk-cpadds { display: flex; flex-wrap: wrap; gap: 9px; padding: 14px 13px 0; }
.mk-cpadd { display: inline-flex; align-items: center; gap: 6px; background: var(--purple-soft); color: var(--purple); font-size: 11px; font-weight: 800; padding: 9px 14px; border-radius: var(--r-full); }
.mk-cpadd svg { color: var(--purple); }
.mk-cparchive {
  margin: 16px 13px 0; display: flex; align-items: center; justify-content: center; gap: 8px;
  border: 1px solid var(--border); border-radius: 12px; padding: 11px;
  color: var(--coral-deep); font-size: 12px; font-weight: 800;
}
.mk-cparchive svg { color: var(--coral-deep); }
