  :root {
    /* Palette dérivée du logo Djooni officiel */
    --calico:    #F4EADA;   /* fond crème chaud, plus clair */
    --calico-2: #EADCC2;   /* fond crème ombré */
    --burgundy:  #4A2418;   /* corps café du personnage Djooni */
    --burgundy-2:#2E140C;
    --orange:    #E25A2E;   /* coral/persimmon, plus fluide */
    --orange-2:  #C24A22;   /* persimmon foncé pour ombres */
    --gold:      #E8B547;   /* or doux */
    --indigo:    #1B3A5C;   /* utilisé en accent froid mineur */
    --forest:    #2D5A3D;
    --ocre:      var(--gold);
    --brick:     var(--orange-2);
    --ink:       #2A1810;
    --line:      rgba(42,24,16,.16);

    --display: "Bricolage Grotesque", "Helvetica Neue", sans-serif;
    --sans:    "DM Sans", system-ui, sans-serif;
    --hand:    "Caveat", cursive;
    --mono:    "JetBrains Mono", ui-monospace, monospace;

    --gutter: clamp(20px, 4vw, 56px);
    --max:    1480px;
  }
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html, body { background: var(--calico); color: var(--ink); }
  body {
    font-family: var(--sans);
    font-size: 16px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
  }
  a { color: inherit; text-decoration: none; }
  button { font: inherit; color: inherit; background: transparent; border: 0; cursor: pointer; }
  img, svg { display: block; max-width: 100%; }

  .wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--gutter); position: relative; }

  /* ==================== KENTE STRIPE BAND ==================== */
  .kente-bar {
    height: 16px;
    width: 100%;
    background: repeating-linear-gradient(
      90deg,
      var(--burgundy) 0 36px,
      var(--gold)     36px 56px,
      var(--orange)   56px 72px,
      var(--burgundy) 72px 96px,
      var(--gold)     96px 108px,
      var(--orange-2) 108px 144px,
      var(--calico)   144px 152px,
      var(--orange)   152px 176px,
      var(--gold)     176px 184px,
      var(--burgundy) 184px 220px,
      var(--orange-2) 220px 240px
    );
    position: relative;
  }
  .kente-bar::after {
    content: "";
    position: absolute; inset: 0;
    background-image:
      repeating-linear-gradient(0deg, rgba(239,228,208,.18) 0 1px, transparent 1px 4px);
    pointer-events: none;
  }

  /* ==================== HEADER ==================== */
  :where(section[id]) { scroll-margin-top: 92px; }
  html { scroll-behavior: smooth; }
  header.site {
    position: sticky;
    top: 0;
    z-index: 60;
    background: var(--calico);
    border-bottom: 1px solid var(--ink);
  }
  header.site .top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 80px;
    gap: 24px;
  }
  .wordmark {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    line-height: 1;
    color: var(--ink);
    text-decoration: none;
  }
  .seal-icon {
    display: inline-block;
    width: 56px;
    height: 36px;
    overflow: hidden;
    flex: 0 0 auto;
    line-height: 0;
  }
  .seal-icon img {
    width: 56px;
    height: auto;
    display: block;
    object-fit: contain;
    object-position: top center;
    margin-top: -1px;
  }
  .seal-icon.lg { width: 64px; height: 42px; }
  .seal-icon.lg img { width: 64px; }
  /* pill wordmark: mimics the brown rounded pill from the brand logo,
     but with hollow O's (no orange fill inside) */
  .word-pill {
    display: inline-flex;
    align-items: center;
    background: #3a1d12;
    color: #f4eada;
    font-family: var(--display);
    font-weight: 800;
    font-size: 22px;
    letter-spacing: .005em;
    line-height: 1;
    padding: 9px 14px 10px;
    border-radius: 11px;
    text-decoration: none;
  }
  .word-pill.sm { font-size: 18px; padding: 7px 12px 8px; border-radius: 9px; }
  .word-pill.lg { font-size: 28px; padding: 11px 18px 12px; border-radius: 13px; }
  nav.main { display: flex; gap: 28px; }
  nav.main a {
    font-family: var(--sans);
    font-weight: 500;
    font-size: 15px;
    color: var(--ink);
    transition: color .2s;
    padding: 6px 0;
    position: relative;
  }
  nav.main a:hover { color: var(--brick); }
  nav.main a:hover::after {
    content: "";
    position: absolute;
    inset: auto 0 -2px 0;
    height: 6px;
    background-image: radial-gradient(var(--ocre) 1px, transparent 1.5px);
    background-size: 6px 6px;
    background-repeat: repeat-x;
  }
  .header-right { display: flex; align-items: center; gap: 14px; }
  .lang-pill {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    border: 1px solid var(--ink);
    padding: 8px 12px;
    background: var(--calico);
    transition: background .2s, color .2s;
  }
  .lang-pill:hover { background: var(--ink); color: var(--calico); }
  .login-link {
    font-family: var(--mono);
    font-size: 11.5px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--ink);
    text-decoration: none;
    padding: 8px 12px;
    border: 1px solid var(--ink);
    border-radius: 999px;
    background: var(--calico);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: background .2s, color .2s;
    white-space: nowrap;
  }
  .login-link i { font-size: 14px; }
  .login-link:hover { background: var(--ink); color: var(--calico); }
  .btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--display);
    font-weight: 700;
    font-size: 14px;
    letter-spacing: -.005em;
    padding: 11px 18px;
    background: var(--burgundy);
    color: var(--calico);
    border: 1px solid var(--burgundy);
    border-radius: 999px;
    transition: background .2s, color .2s, transform .15s;
  }
  .btn:hover { background: var(--orange); color: var(--calico); border-color: var(--orange); }
  .btn.outline { background: var(--calico); color: var(--ink); }
  .btn.outline:hover { background: var(--ink); color: var(--calico); }
  .btn.brick { background: var(--brick); border-color: var(--brick); }
  .btn.brick:hover { background: var(--ink); color: var(--calico); border-color: var(--ink); }

  /* ==================== HERO ==================== */
  .hero {
    position: relative;
    padding: 64px 0 96px;
    overflow: hidden;
    border-bottom: 1px solid var(--ink);
  }
  .hero .medallion {
    position: absolute;
    top: 60px;
    right: -260px;
    width: 580px;
    max-width: 50vw;
    z-index: 0;
    opacity: .55;
    pointer-events: none;
  }
  .hero .grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: clamp(32px, 5vw, 80px);
    align-items: end;
  }
  .hero h1 {
    font-family: var(--display);
    font-weight: 800;
    font-size: clamp(64px, 9.4vw, 152px);
    line-height: .9;
    letter-spacing: -.025em;
    color: var(--ink);
  }
  .hero h1 .ind { color: var(--burgundy); }
  .hero h1 .br  { color: var(--orange); }
  .hand-accent {
    font-family: var(--hand);
    font-weight: 700;
    color: var(--orange);
    transform: rotate(-3deg);
    display: inline-block;
    line-height: .9;
    font-size: clamp(56px, 8vw, 132px);
    letter-spacing: -.005em;
  }
  .hero-meta {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding-bottom: 18px;
  }
  .hero-meta .lede {
    font-size: 19px;
    font-weight: 500;
    line-height: 1.5;
    max-width: 38ch;
    color: var(--ink);
  }
  .hero-meta .lede em { font-style: normal; color: var(--brick); font-weight: 700; }
  .hero-meta .ctas { display: flex; gap: 12px; flex-wrap: wrap; }
  .hero-meta .micro {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    padding-top: 18px;
    border-top: 1px solid var(--line);
  }
  .micro-cell {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--ink);
  }
  .micro-cell b {
    display: block;
    font-family: var(--display);
    font-weight: 800;
    font-size: 32px;
    line-height: 1;
    color: var(--burgundy);
    margin-bottom: 6px;
    letter-spacing: -.02em;
  }
  .micro-cell.alt b { color: var(--orange); }
  .micro-cell.alt2 b { color: var(--forest); }

  /* hero photo strip below */
  .hero-strip {
    position: relative;
    z-index: 2;
    margin-top: 72px;
    display: grid;
    grid-template-columns: 1fr 1.2fr 1fr;
    gap: 18px;
  }
  .ph-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--ink);
    background: var(--calico-2);
    transition: transform .25s ease;
  }
  .ph-card:hover { transform: translateY(-4px); }
  .ph-card .ph {
    aspect-ratio: 4/5;
    width: 100%;
    background-color: var(--calico-2);
    background-image: repeating-linear-gradient(135deg, transparent 0 8px, rgba(58,22,20,.10) 8px 9px);
    position: relative;
  }
  .ph-card .mascot-bg {
    background-color: var(--burgundy);
    background-image:
      radial-gradient(circle at 18% 22%, rgba(245,180,40,.25) 0 1px, transparent 1.5px),
      repeating-linear-gradient(135deg, transparent 0 10px, rgba(245,180,40,.06) 10px 11px);
    background-size: 14px 14px, auto;
    display: flex; align-items: center; justify-content: center;
  }
  .ph-card .mascot-art {
    width: 80%; height: 80%;
    object-fit: contain;
    filter: drop-shadow(0 8px 0 rgba(0,0,0,.15));
  }
  .ph-card .mascot-bg .ph-stamp { background: var(--gold); color: var(--burgundy); border-color: var(--burgundy); }
  .ph-card .mascot-bg .ph-pin { background: var(--burgundy); color: var(--gold); border-color: var(--gold); }
  .ph-card.wide .ph { aspect-ratio: 16/11; }
  .ph-card .ph-pin {
    position: absolute;
    top: 12px; left: 12px;
    font-family: var(--mono);
    font-size: 10.5px;
    letter-spacing: .12em;
    text-transform: uppercase;
    background: var(--calico);
    border: 1px solid var(--ink);
    padding: 4px 8px;
  }
  .ph-card .ph-stamp {
    position: absolute;
    bottom: 12px; right: 12px;
    font-family: var(--mono);
    font-size: 10.5px;
    letter-spacing: .12em;
    text-transform: uppercase;
    background: var(--ocre);
    border: 1px solid var(--ink);
    padding: 4px 8px;
  }
  .ph-card .cap {
    padding: 10px 14px;
    border-top: 1px solid var(--ink);
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .06em;
    text-transform: uppercase;
    background: var(--calico);
    display: flex;
    justify-content: space-between;
  }
  .ph-card .cap b { color: var(--brick); }

  /* ==================== BOGOLAN DIVIDER ==================== */
  .bogolan-row {
    height: 36px;
    width: 100%;
    border-top: 1px solid var(--ink);
    border-bottom: 1px solid var(--ink);
    background: var(--ink);
    overflow: hidden;
    position: relative;
  }
  .bogolan-row svg { width: 100%; height: 100%; display: block; }

  /* ==================== SECTION HEAD ==================== */
  .sec-head {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 32px;
    padding: 88px 0 48px;
    align-items: end;
  }
  .sec-head .nm {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--orange);
    border-top: 2px solid var(--orange);
    padding-top: 12px;
  }
  .sec-head h2 {
    font-family: var(--display);
    font-weight: 800;
    font-size: clamp(40px, 5.6vw, 88px);
    line-height: .92;
    letter-spacing: -.02em;
    max-width: 18ch;
  }
  .sec-head h2 .ind { color: var(--burgundy); }
  .sec-head h2 .br  { color: var(--orange); }
  .sec-head h2 .hand {
    font-family: var(--hand);
    font-weight: 700;
    color: var(--orange);
    transform: rotate(-2deg);
    display: inline-block;
  }

  /* ==================== SERVICES (motif tickets) ==================== */
  section.services {
    padding-bottom: 96px;
    border-bottom: 1px solid var(--ink);
  }
  .services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
  }
  .svc {
    grid-column: span 1;
    background: var(--calico);
    border: 1px solid var(--ink);
    padding: 20px 20px 18px;
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: background .2s, color .2s, transform .2s;
    min-height: 220px;
    overflow: hidden;
  }
  .svc:hover { background: var(--burgundy); color: var(--calico); transform: translateY(-4px); }
  .svc:hover .svc-num { color: var(--ocre); }
  .svc:hover .svc-motif path,
  .svc:hover .svc-motif circle,
  .svc:hover .svc-motif rect,
  .svc:hover .svc-motif polygon { stroke: var(--ocre); }
  .svc:hover .svc-motif .fillp { fill: var(--ocre); }
  .svc:hover .svc-foot { border-top-color: rgba(239,228,208,.3); }
  .svc:hover .svc-pill { background: var(--ocre); color: var(--ink); border-color: var(--ocre); }
  .svc-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
  }
  .svc-num {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--brick);
    transition: color .2s;
  }
  .svc-motif {
    width: 40px;
    height: 40px;
    flex: 0 0 auto;
  }
  .svc h3 {
    font-family: var(--display);
    font-weight: 800;
    font-size: 28px;
    line-height: .95;
    letter-spacing: -.018em;
  }
  .svc p {
    font-size: 13.5px;
    line-height: 1.5;
    max-width: 32ch;
  }
  .svc-foot {
    margin-top: auto;
    border-top: 1px solid var(--line);
    padding-top: 14px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    font-family: var(--mono);
    font-size: 11.5px;
    letter-spacing: .06em;
    text-transform: uppercase;
  }
  .svc-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border: 1px solid var(--ink);
    padding: 6px 10px;
    border-radius: 999px;
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
    transition: background .2s, color .2s, border-color .2s;
  }
  .svc-pill i { font-size: 14px; }

  .services .sec-head { padding: 64px 0 32px; }
  .services .sec-head h2 { font-size: clamp(36px, 4.6vw, 64px); }
  section.services { padding-bottom: 64px; }
  /* feature variants disabled — all cards equal in compact 3×2 grid */
  .svc.feat { grid-column: span 1; }
  .svc.feat h3 { font-size: 28px; }
  .svc.bg-burgundy { background: var(--burgundy); color: var(--calico); }
  .svc.bg-burgundy .svc-num { color: var(--gold); }
  .svc.bg-burgundy .svc-foot { border-top-color: rgba(242,231,210,.3); }
  .svc.bg-burgundy .svc-pill { border-color: var(--calico); color: var(--calico); }
  .svc.bg-burgundy:hover { background: var(--calico); color: var(--ink); }
  .svc.bg-burgundy:hover .svc-num { color: var(--orange); }
  .svc.bg-burgundy:hover .svc-pill { background: var(--ink); color: var(--calico); border-color: var(--ink); }
  .svc.bg-burgundy:hover .svc-motif path,
  .svc.bg-burgundy:hover .svc-motif circle,
  .svc.bg-burgundy:hover .svc-motif rect,
  .svc.bg-burgundy:hover .svc-motif polygon { stroke: var(--burgundy); }

  .svc.bg-indigo { background: var(--indigo); color: var(--calico); }
  .svc.bg-indigo .svc-num { color: var(--ocre); }
  .svc.bg-indigo .svc-foot { border-top-color: rgba(239,228,208,.3); }
  .svc.bg-indigo .svc-pill { border-color: var(--calico); color: var(--calico); }
  .svc.bg-indigo:hover { background: var(--calico); color: var(--ink); }
  .svc.bg-indigo:hover .svc-num { color: var(--brick); }
  .svc.bg-indigo:hover .svc-pill { background: var(--ink); color: var(--calico); border-color: var(--ink); }
  .svc.bg-indigo:hover .svc-motif path,
  .svc.bg-indigo:hover .svc-motif circle,
  .svc.bg-indigo:hover .svc-motif rect,
  .svc.bg-indigo:hover .svc-motif polygon { stroke: var(--brick); }

  .svc.bg-orange { background: var(--orange); color: var(--burgundy-2); }
  .svc.bg-orange .svc-num { color: var(--burgundy); }
  .svc.bg-orange .svc-foot { border-top-color: rgba(58,22,20,.3); }
  .svc.bg-orange .svc-pill { border-color: var(--burgundy); color: var(--burgundy); }
  .svc.bg-orange:hover { background: var(--burgundy); color: var(--gold); }
  .svc.bg-orange:hover .svc-num { color: var(--gold); }
  .svc.bg-orange:hover .svc-pill { background: var(--gold); color: var(--burgundy); border-color: var(--gold); }
  .svc.bg-orange:hover .svc-motif path,
  .svc.bg-orange:hover .svc-motif circle,
  .svc.bg-orange:hover .svc-motif rect,
  .svc.bg-orange:hover .svc-motif polygon { stroke: var(--gold); }

  .svc.bg-gold { background: var(--gold); color: var(--burgundy-2); }
  .svc.bg-gold .svc-num { color: var(--burgundy); }
  .svc.bg-gold .svc-foot { border-top-color: rgba(58,22,20,.3); }
  .svc.bg-gold .svc-pill { border-color: var(--burgundy); color: var(--burgundy); }
  .svc.bg-gold:hover { background: var(--burgundy); color: var(--gold); }
  .svc.bg-gold:hover .svc-num { color: var(--gold); }
  .svc.bg-gold:hover .svc-pill { background: var(--gold); color: var(--burgundy); border-color: var(--gold); }
  .svc.bg-gold:hover .svc-motif path,
  .svc.bg-gold:hover .svc-motif circle,
  .svc.bg-gold:hover .svc-motif rect,
  .svc.bg-gold:hover .svc-motif polygon { stroke: var(--gold); }

  .svc.bg-ocre { background: var(--ocre); }
  .svc.bg-ocre:hover { background: var(--ink); color: var(--calico); }
  .svc.bg-ocre:hover .svc-motif path,
  .svc.bg-ocre:hover .svc-motif circle,
  .svc.bg-ocre:hover .svc-motif rect,
  .svc.bg-ocre:hover .svc-motif polygon { stroke: var(--ocre); }

  .svc.bg-forest { background: var(--forest); color: var(--calico); }
  .svc.bg-forest .svc-num { color: var(--ocre); }
  .svc.bg-forest .svc-foot { border-top-color: rgba(239,228,208,.3); }
  .svc.bg-forest .svc-pill { border-color: var(--calico); color: var(--calico); }
  .svc.bg-forest:hover { background: var(--ocre); color: var(--ink); }
  .svc.bg-forest:hover .svc-num { color: var(--ink); }
  .svc.bg-forest:hover .svc-pill { background: var(--ink); color: var(--ocre); border-color: var(--ink); }
  .svc.bg-forest:hover .svc-motif path,
  .svc.bg-forest:hover .svc-motif circle,
  .svc.bg-forest:hover .svc-motif rect,
  .svc.bg-forest:hover .svc-motif polygon { stroke: var(--ink); }

  .svc.bg-brick { background: var(--brick); color: var(--calico); }
  .svc.bg-brick .svc-num { color: var(--ocre); }
  .svc.bg-brick .svc-foot { border-top-color: rgba(239,228,208,.3); }
  .svc.bg-brick .svc-pill { border-color: var(--calico); color: var(--calico); }

  /* ==================== PROCESS ==================== */
  section.process {
    padding-bottom: 96px;
    border-bottom: 1px solid var(--ink);
    background: var(--calico-2);
    position: relative;
  }
  .process .sec-head h2 .hand { color: var(--brick); }
  .steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    border-top: 2px solid var(--ink);
  }
  .step {
    position: relative;
    padding: 40px 28px 32px 0;
    border-right: 1px solid var(--ink);
  }
  .step:last-child { border-right: 0; padding-right: 0; }
  .step:first-child { padding-left: 0; }
  .step:not(:first-child) { padding-left: 28px; }
  .step .step-icon {
    width: 84px; height: 84px;
    margin-bottom: 22px;
  }
  .step .step-num {
    font-family: var(--display);
    font-weight: 800;
    font-size: 132px;
    line-height: .8;
    letter-spacing: -.04em;
    margin-bottom: 18px;
    color: var(--indigo);
  }
  .step .step-num.alt { color: var(--brick); }
  .step .step-num.alt2 { color: var(--forest); }
  .step .lab {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--brick);
    margin-bottom: 12px;
  }
  .step h4 {
    font-family: var(--display);
    font-weight: 800;
    font-size: 32px;
    line-height: 1;
    letter-spacing: -.02em;
    margin-bottom: 14px;
    max-width: 14ch;
  }
  .step p {
    font-size: 14.5px;
    line-height: 1.55;
    max-width: 32ch;
    color: var(--ink);
  }
  .step .hand {
    font-family: var(--hand);
    color: var(--brick);
    font-weight: 700;
    font-size: 28px;
    margin-top: 16px;
    transform: rotate(-2deg);
    display: inline-block;
    line-height: 1;
  }

  /* ==================== HERITAGE (BONUS) ==================== */
  section.heritage {
    background: var(--indigo);
    color: var(--calico);
    padding: 0 0 96px;
    border-bottom: 1px solid var(--ink);
    position: relative;
    overflow: hidden;
  }
  .heritage .sec-head h2 { color: var(--calico); }
  .heritage .sec-head h2 .ind { color: var(--ocre); }
  .heritage .sec-head h2 .br { color: var(--brick); }
  .heritage .sec-head h2 .hand { color: var(--ocre); }
  .heritage .sec-head .nm { color: var(--ocre); border-top-color: var(--ocre); }

  .heritage-grid {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: clamp(32px, 5vw, 72px);
    align-items: start;
  }
  .heritage-photo {
    position: relative;
    border: 1px solid var(--ocre);
    background: var(--indigo-2);
    overflow: hidden;
  }
  .heritage-photo .ph {
    aspect-ratio: 5/4;
    background-color: var(--indigo-2);
    background-image: repeating-linear-gradient(135deg, transparent 0 9px, rgba(217,164,65,.18) 9px 10px);
    position: relative;
  }
  .heritage-photo .ph-pin {
    position: absolute;
    top: 12px; left: 12px;
    font-family: var(--mono);
    font-size: 10.5px;
    letter-spacing: .12em;
    text-transform: uppercase;
    background: var(--indigo);
    border: 1px solid var(--ocre);
    padding: 4px 8px;
    color: var(--ocre);
  }
  .heritage-photo .ph-stamp {
    position: absolute;
    bottom: 12px; right: 12px;
    font-family: var(--mono);
    font-size: 10.5px;
    letter-spacing: .12em;
    text-transform: uppercase;
    background: var(--ocre);
    color: var(--ink);
    padding: 4px 8px;
  }
  .heritage-photo .cap {
    padding: 10px 14px;
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .06em;
    text-transform: uppercase;
    border-top: 1px solid var(--ocre);
    color: var(--calico);
    display: flex;
    justify-content: space-between;
  }
  .heritage-photo .cap b { color: var(--ocre); }

  .heritage-cards {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .heritage-card {
    background: var(--calico);
    color: var(--ink);
    padding: 22px;
    display: grid;
    grid-template-columns: 56px 1fr auto;
    gap: 18px;
    align-items: center;
    border: 1px solid var(--ocre);
    transition: background .2s, color .2s;
  }
  .heritage-card:hover { background: var(--ocre); }
  .heritage-card .icn { width: 56px; height: 56px; }
  .heritage-card h5 {
    font-family: var(--display);
    font-weight: 800;
    font-size: 20px;
    line-height: 1;
    margin-bottom: 4px;
    letter-spacing: -.01em;
  }
  .heritage-card .desc {
    font-size: 13.5px;
    color: var(--ink);
    max-width: 36ch;
    line-height: 1.45;
    opacity: .85;
  }
  .heritage-card .arr i { font-size: 22px; }

  .heritage-quote {
    margin-top: 56px;
    padding: 36px 28px;
    border-top: 1px solid var(--ocre);
    border-bottom: 1px solid var(--ocre);
    text-align: center;
  }
  .heritage-quote q {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(28px, 3.6vw, 48px);
    line-height: 1.15;
    letter-spacing: -.012em;
    color: var(--calico);
    quotes: "« " " »";
    max-width: 30ch;
    display: inline-block;
  }
  .heritage-quote q::before, .heritage-quote q::after { color: var(--ocre); }
  .heritage-quote .auth {
    font-family: var(--mono);
    font-size: 11.5px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--ocre);
    margin-top: 18px;
  }
  .heritage-quote .auth b { color: var(--calico); font-weight: 500; }

  /* ==================== FAMILY ==================== */
  section.family {
    padding-bottom: 96px;
    border-bottom: 1px solid var(--ink);
    background: var(--calico);
    position: relative;
  }
  .family .sec-head h2 .ind { color: var(--burgundy); }
  .family-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
  }
  .brand-card {
    background: var(--calico);
    border: 1px solid var(--ink);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: transform .25s ease;
  }
  .brand-card:hover { transform: translateY(-4px); }
  .brand-thumb {
    aspect-ratio: 4/3;
    background: var(--calico-2);
    background-image:
      radial-gradient(circle at 20% 30%, rgba(58,22,20,.08) 0 1px, transparent 1.5px),
      repeating-linear-gradient(135deg, transparent 0 10px, rgba(58,22,20,.06) 10px 11px);
    background-size: 14px 14px, auto;
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: 1px solid var(--ink);
    position: relative;
  }
  .brand-thumb.dark {
    background-color: var(--ink);
    background-image:
      radial-gradient(circle at 20% 30%, rgba(245,180,40,.18) 0 1px, transparent 1.5px),
      repeating-linear-gradient(135deg, transparent 0 10px, rgba(245,180,40,.05) 10px 11px);
    background-size: 14px 14px, auto;
  }
  .brand-thumb img {
    width: 70%; height: 70%;
    object-fit: contain;
  }
  .brand-meta {
    padding: 22px 22px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
  }
  .brand-tag {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--orange);
  }
  .brand-card h3 {
    font-family: var(--display);
    font-weight: 800;
    font-size: 44px;
    line-height: .95;
    letter-spacing: -.02em;
    color: var(--burgundy);
  }
  .brand-card p {
    font-size: 15px;
    line-height: 1.55;
    max-width: 36ch;
    color: var(--ink);
  }
  .brand-foot {
    margin-top: auto;
    padding-top: 14px;
    border-top: 1px solid var(--line);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }
  .brand-pill {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
    border: 1px solid var(--ink);
    padding: 6px 10px;
    border-radius: 999px;
    color: var(--ink);
  }
  .brand-arr {
    width: 38px; height: 38px;
    border: 1px solid var(--ink);
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--burgundy);
    color: var(--calico);
    transition: background .2s, color .2s, transform .2s;
  }
  .brand-arr:hover { background: var(--orange); transform: rotate(45deg); }
  @media (max-width: 980px) {
    .family-grid { grid-template-columns: 1fr; }
  }

  /* ==================== STATS BAR ==================== */
  section.stats {
    border-bottom: 1px solid var(--ink);
    background: var(--ink);
    color: var(--calico);
  }
  .stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
  }
  .stat {
    padding: 36px 28px;
    border-right: 1px solid rgba(244,234,218,.18);
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .stat:last-child { border-right: 0; }
  .stat .num {
    font-family: var(--display);
    font-weight: 800;
    font-size: clamp(40px, 4.5vw, 64px);
    line-height: .95;
    letter-spacing: -.02em;
    color: var(--gold);
  }
  .stat .num em {
    font-style: normal;
    color: var(--orange);
  }
  .stat .lab {
    font-family: var(--mono);
    font-size: 11.5px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--calico);
    opacity: .85;
  }

  /* ==================== CITIES ==================== */
  section.cities {
    padding-bottom: 96px;
    border-bottom: 1px solid var(--ink);
    background: var(--calico);
  }
  .cities-grid {
    display: grid;
    grid-template-columns: 1.15fr 1fr;
    gap: 56px;
    align-items: stretch;
  }
  .cities-map {
    border: 1px solid var(--ink);
    background: var(--calico-2);
    background-image: repeating-linear-gradient(135deg, transparent 0 12px, rgba(74,36,24,.05) 12px 13px);
    aspect-ratio: 5/4;
    position: relative;
    overflow: hidden;
  }
  .cities-map svg { position: absolute; inset: 0; width: 100%; height: 100%; }
  .city-pin {
    position: absolute;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .city-pin .dot {
    width: 14px; height: 14px;
    border-radius: 999px;
    background: var(--orange);
    border: 2px solid var(--calico);
    box-shadow: 0 0 0 2px var(--burgundy);
  }
  .city-pin.coming .dot { background: var(--calico); box-shadow: 0 0 0 2px var(--burgundy); }
  .city-pin .nm {
    font-family: var(--mono);
    font-size: 11.5px;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: var(--calico);
    border: 1px solid var(--ink);
    padding: 3px 7px;
  }
  .cities-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
  }
  .city-row {
    display: grid;
    grid-template-columns: 50px 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 18px 0;
    border-bottom: 1px solid var(--line);
  }
  .city-row:first-child { border-top: 2px solid var(--ink); padding-top: 22px; }
  .city-row .ix {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: .12em;
    color: var(--orange);
  }
  .city-row .nm {
    font-family: var(--display);
    font-weight: 800;
    font-size: 26px;
    line-height: 1;
    letter-spacing: -.015em;
    color: var(--burgundy);
  }
  .city-row .nm small {
    display: block;
    font-family: var(--sans);
    font-weight: 500;
    font-size: 13px;
    color: var(--ink);
    opacity: .7;
    margin-top: 4px;
    letter-spacing: 0;
  }
  .city-row .st {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 5px 9px;
    border: 1px solid var(--ink);
    border-radius: 999px;
  }
  .city-row .st.live { background: var(--burgundy); color: var(--calico); }
  .city-row .st.soon { color: var(--ink); }
  @media (max-width: 980px) {
    .cities-grid { grid-template-columns: 1fr; }
  }

  /* ==================== SAFETY ==================== */
  section.safety {
    padding-bottom: 96px;
    border-bottom: 1px solid var(--ink);
    background: var(--calico-2);
    color: var(--ink);
    position: relative;
  }
  .safety-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
  }
  .safe-card {
    background: var(--calico);
    border: 1px solid var(--ink);
    padding: 26px 22px 22px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 280px;
  }
  .safe-card.feat {
    grid-column: span 2;
    background: var(--burgundy);
    color: var(--calico);
  }
  .safe-card.feat .safe-num { color: var(--gold); }
  .safe-card.feat .safe-foot { border-top-color: rgba(244,234,218,.25); }
  .safe-card .safe-num {
    font-family: var(--mono);
    font-size: 11.5px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--orange);
  }
  .safe-card h4 {
    font-family: var(--display);
    font-weight: 800;
    font-size: 26px;
    line-height: 1;
    letter-spacing: -.01em;
  }
  .safe-card.feat h4 { font-size: 38px; line-height: .95; }
  .safe-card p {
    font-size: 14.5px;
    line-height: 1.55;
    max-width: 32ch;
  }
  .safe-foot {
    margin-top: auto;
    border-top: 1px solid var(--line);
    padding-top: 12px;
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
    display: flex;
    justify-content: space-between;
  }
  .safe-icn {
    width: 44px; height: 44px;
  }
  @media (max-width: 980px) {
    .safety-grid { grid-template-columns: 1fr 1fr; }
    .safe-card.feat { grid-column: span 2; }
  }

  /* ==================== PARTNERS ==================== */
  section.partners {
    padding-bottom: 96px;
    border-bottom: 1px solid var(--ink);
    background: var(--ink);
    color: var(--calico);
    position: relative;
    overflow: hidden;
  }
  section.partners .sec-head h2 { color: var(--calico); }
  section.partners .sec-head h2 .ind { color: var(--gold); }
  section.partners .sec-head h2 .hand { color: var(--orange); }
  section.partners .sec-head .nm {
    color: var(--gold);
    border-top-color: var(--gold);
  }
  .partners-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
  }
  .ptn {
    background: rgba(244,234,218,.04);
    border: 1px solid rgba(244,234,218,.2);
    padding: 28px 24px 22px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    transition: background .2s, border-color .2s, transform .2s;
  }
  .ptn:hover {
    background: var(--calico);
    color: var(--ink);
    border-color: var(--calico);
    transform: translateY(-4px);
  }
  .ptn:hover .ptn-num { color: var(--orange); }
  .ptn:hover .ptn-foot { border-top-color: var(--line); }
  .ptn:hover .ptn-pill { background: var(--burgundy); color: var(--calico); border-color: var(--burgundy); }
  .ptn-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .ptn-num {
    font-family: var(--mono);
    font-size: 11.5px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--gold);
  }
  .ptn h4 {
    font-family: var(--display);
    font-weight: 800;
    font-size: 32px;
    line-height: .95;
    letter-spacing: -.015em;
  }
  .ptn p {
    font-size: 14.5px;
    line-height: 1.55;
    max-width: 32ch;
  }
  .ptn-bullets {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 4px;
  }
  .ptn-bullets li {
    list-style: none;
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: .04em;
    display: flex;
    gap: 10px;
    align-items: baseline;
  }
  .ptn-bullets li::before {
    content: "→";
    color: var(--orange);
    font-family: var(--display);
  }
  .ptn-foot {
    margin-top: auto;
    padding-top: 14px;
    border-top: 1px solid rgba(244,234,218,.18);
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .ptn-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border: 1px solid currentColor;
    padding: 7px 12px;
    border-radius: 999px;
    font-family: var(--mono);
    font-size: 11.5px;
    letter-spacing: .08em;
    text-transform: uppercase;
    transition: background .2s, color .2s, border-color .2s;
  }
  @media (max-width: 980px) {
    .partners-grid { grid-template-columns: 1fr; }
  }

  /* ==================== APP SHOWCASE ==================== */
  section.app-show {
    padding-bottom: 96px;
    border-bottom: 1px solid var(--ink);
    background: var(--calico);
  }
  .app-show-grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 64px;
    align-items: center;
  }
  .app-screens {
    position: relative;
    aspect-ratio: 5/4;
  }
  .phone {
    position: absolute;
    width: 36%;
    aspect-ratio: 9/19;
    background: var(--ink);
    border: 8px solid var(--ink);
    border-radius: 32px;
    box-shadow: 0 30px 60px -20px rgba(74,36,24,.3);
    overflow: hidden;
  }
  .phone .scr {
    width: 100%; height: 100%;
    background: var(--calico);
    position: relative;
    display: flex;
    flex-direction: column;
  }
  .phone-1 { left: 4%; top: 8%; transform: rotate(-7deg); z-index: 1; }
  .phone-2 { left: 32%; top: 0%; z-index: 3; transform: scale(1.06); }
  .phone-3 { right: 2%; top: 12%; transform: rotate(6deg); z-index: 2; }
  .scr-bar {
    background: var(--burgundy);
    color: var(--calico);
    padding: 16px 14px 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: var(--mono);
    font-size: 9px;
    letter-spacing: .08em;
    text-transform: uppercase;
  }
  .scr-bar .lo { color: var(--gold); }
  .scr-body {
    flex: 1;
    padding: 12px 12px 14px;
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .scr-tile {
    background: var(--calico-2);
    border: 1px solid var(--line);
    padding: 8px;
    border-radius: 6px;
    font-family: var(--mono);
    font-size: 8.5px;
    letter-spacing: .04em;
    color: var(--ink);
  }
  .scr-tile.hi {
    background: var(--orange);
    color: var(--burgundy-2);
    border-color: var(--orange);
    font-weight: 700;
  }
  .scr-tile.gold {
    background: var(--gold);
    color: var(--burgundy-2);
    border-color: var(--gold);
  }
  .scr-tile.dark {
    background: var(--burgundy);
    color: var(--gold);
    border-color: var(--burgundy);
  }
  .scr-h {
    font-family: var(--display);
    font-weight: 800;
    font-size: 14px;
    color: var(--burgundy);
    line-height: 1;
    margin-bottom: 4px;
  }
  .qr-block {
    margin-top: 24px;
    border: 1px solid var(--ink);
    background: var(--calico-2);
    padding: 14px 16px;
    display: flex;
    align-items: center;
    gap: 14px;
    max-width: 360px;
  }
  .qr-block .qr {
    width: 64px; height: 64px;
    background:
      conic-gradient(from 0deg at 50% 50%, var(--ink) 0 25%, transparent 0 50%, var(--ink) 0 75%, transparent 0),
      var(--calico);
    background-size: 8px 8px, auto;
    border: 1px solid var(--ink);
    flex: 0 0 auto;
  }
  .qr-block .qr-txt {
    font-family: var(--mono);
    font-size: 11px;
    line-height: 1.4;
    letter-spacing: .04em;
  }
  .qr-block .qr-txt b {
    display: block;
    font-family: var(--display);
    font-weight: 800;
    font-size: 14px;
    letter-spacing: -.01em;
    color: var(--burgundy);
    margin-bottom: 2px;
  }
  @media (max-width: 980px) {
    .app-show-grid { grid-template-columns: 1fr; gap: 36px; }
  }

  /* ==================== TESTIMONIALS ==================== */
  section.voices {
    padding-bottom: 96px;
    border-bottom: 1px solid var(--ink);
    background: var(--calico-2);
  }
  .voices-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
  }
  .voice {
    background: var(--calico);
    border: 1px solid var(--ink);
    padding: 26px 24px 22px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: relative;
  }
  .voice .quote-mk {
    font-family: var(--display);
    font-weight: 800;
    font-size: 56px;
    line-height: .8;
    color: var(--orange);
  }
  .voice q {
    font-family: var(--display);
    font-weight: 500;
    font-size: 19px;
    line-height: 1.35;
    letter-spacing: -.01em;
    color: var(--ink);
    quotes: "« " " »";
    flex: 1;
  }
  .voice .by {
    display: flex;
    gap: 12px;
    align-items: center;
    border-top: 1px solid var(--line);
    padding-top: 14px;
  }
  .voice .av {
    width: 44px; height: 44px;
    border-radius: 999px;
    background: var(--burgundy);
    color: var(--gold);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--display);
    font-weight: 800;
    font-size: 16px;
    flex: 0 0 auto;
  }
  .voice .meta {
    font-family: var(--mono);
    font-size: 11.5px;
    letter-spacing: .04em;
    line-height: 1.45;
  }
  .voice .meta b {
    display: block;
    font-family: var(--display);
    font-weight: 800;
    font-size: 16px;
    letter-spacing: -.01em;
    color: var(--burgundy);
    margin-bottom: 2px;
  }
  @media (max-width: 980px) {
    .voices-grid { grid-template-columns: 1fr; }
  }

  /* ==================== FAQ ==================== */
  section.faq {
    padding-bottom: 96px;
    border-bottom: 1px solid var(--ink);
    background: var(--calico);
  }
  .faq-grid {
    display: grid;
    grid-template-columns: 1.05fr 1.4fr;
    gap: 56px;
    align-items: start;
  }
  .faq-aside {
    border: 1px solid var(--ink);
    background: var(--burgundy);
    color: var(--calico);
    padding: 32px 28px;
    position: sticky;
    top: 100px;
  }
  .faq-aside .nm {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 14px;
  }
  .faq-aside h3 {
    font-family: var(--display);
    font-weight: 800;
    font-size: 36px;
    line-height: .95;
    letter-spacing: -.015em;
    margin-bottom: 12px;
  }
  .faq-aside h3 .hand { color: var(--orange); font-family: var(--hand); transform: rotate(-2deg); display: inline-block; }
  .faq-aside p { font-size: 14px; line-height: 1.55; opacity: .9; margin-bottom: 22px; }
  .faq-aside .helpline {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: .08em;
    border-top: 1px solid rgba(244,234,218,.25);
    padding-top: 18px;
  }
  .faq-aside .helpline b {
    display: block;
    font-family: var(--display);
    font-weight: 800;
    font-size: 22px;
    letter-spacing: -.01em;
    color: var(--gold);
    margin-bottom: 4px;
  }
  .faq-list { display: flex; flex-direction: column; }
  .faq-item {
    border-top: 1px solid var(--ink);
    padding: 22px 0;
    cursor: pointer;
  }
  .faq-item:last-child { border-bottom: 1px solid var(--ink); }
  .faq-item summary {
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
    font-family: var(--display);
    font-weight: 700;
    font-size: 22px;
    line-height: 1.2;
    letter-spacing: -.012em;
    color: var(--burgundy);
  }
  .faq-item summary::-webkit-details-marker { display: none; }
  .faq-item summary::after {
    content: "+";
    flex: 0 0 auto;
    font-family: var(--display);
    font-weight: 700;
    color: var(--orange);
    transition: transform .25s;
    line-height: 1;
  }
  .faq-item[open] summary::after { content: "−"; }
  .faq-item .ans {
    font-size: 15px;
    line-height: 1.6;
    color: var(--ink);
    margin-top: 14px;
    max-width: 60ch;
  }
  @media (max-width: 980px) {
    .faq-grid { grid-template-columns: 1fr; }
    .faq-aside { position: static; }
  }

  /* ==================== APPS ==================== */
  section.apps {
    background: var(--ink);
    color: var(--calico);
    padding: 96px 0;
    border-bottom: 1px solid var(--ink);
    position: relative;
    overflow: hidden;
  }
  .apps-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 56px;
    align-items: end;
    position: relative;
    z-index: 2;
  }
  .apps h2 {
    font-family: var(--display);
    font-weight: 800;
    font-size: clamp(48px, 7vw, 112px);
    line-height: .9;
    letter-spacing: -.022em;
  }
  .apps h2 .ocr { color: var(--ocre); }
  .apps h2 .br  { color: var(--brick); }
  .apps h2 .hand { color: var(--ocre); }
  .apps .deck {
    margin-top: 22px;
    font-size: 18px;
    line-height: 1.5;
    max-width: 38ch;
    color: rgba(239,228,208,.85);
  }
  .stores { display: flex; flex-direction: column; gap: 12px; }
  .store {
    display: grid;
    grid-template-columns: 32px 1fr auto;
    gap: 18px;
    align-items: center;
    padding: 18px 22px;
    border: 1px solid var(--ocre);
    color: var(--calico);
    transition: background .2s, color .2s, border-color .2s;
  }
  .store:hover { background: var(--ocre); color: var(--ink); border-color: var(--ocre); }
  .store i { font-size: 24px; }
  .store .name { font-family: var(--display); font-weight: 800; font-size: 22px; letter-spacing: -.01em; }
  .store .sub {
    display: block;
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .1em;
    text-transform: uppercase;
    margin-top: 4px;
    color: rgba(239,228,208,.75);
  }
  .store:hover .sub { color: rgba(26,22,17,.7); }
  .store .arr i { font-size: 22px; }

  .apps-deco {
    position: absolute;
    bottom: -120px;
    left: -80px;
    width: 460px;
    opacity: .15;
    z-index: 1;
    pointer-events: none;
  }

  /* ==================== FOOTER ==================== */
  footer.site {
    background: var(--calico);
    padding: 64px 0 28px;
    color: var(--ink);
  }
  .foot-grid {
    display: grid;
    grid-template-columns: 1.4fr repeat(4, 1fr);
    gap: 32px;
  }
  .foot-grid h6 {
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--brick);
    margin-bottom: 16px;
    border-bottom: 1px solid var(--brick);
    padding-bottom: 8px;
    font-weight: 500;
  }
  .foot-grid ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
  .foot-grid a { font-family: var(--sans); font-size: 14.5px; }
  .foot-grid a:hover { color: var(--brick); }
  .foot-mark {
    font-family: var(--display);
    font-weight: 800;
    font-size: 56px;
    line-height: .9;
    letter-spacing: -.022em;
    margin-bottom: 14px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
  }
  .foot-mark .seal { width: 46px; height: 46px; }
  .foot-tag {
    font-family: var(--hand);
    color: var(--brick);
    font-size: 28px;
    line-height: 1.1;
    transform: rotate(-1deg);
    display: inline-block;
    margin-bottom: 8px;
  }
  .foot-sub {
    font-size: 14px;
    color: var(--ink);
    max-width: 30ch;
    line-height: 1.5;
    opacity: .8;
  }
  .colophon {
    margin-top: 56px;
    padding-top: 18px;
    border-top: 1px solid var(--ink);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 14px;
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--ink);
  }
  .colophon b { color: var(--brick); }

  /* ==================== RESPONSIVE ==================== */
  @media (max-width: 1100px) {
    .services-grid { grid-template-columns: repeat(2, 1fr); }
    .svc, .svc.feat { grid-column: span 1; }
  }
  @media (max-width: 880px) {
    .hero .grid { grid-template-columns: 1fr; }
    .hero .medallion { right: -40%; top: 0; opacity: .6; }
    .hero-strip { grid-template-columns: 1fr; }
    nav.main { display: none; }
    .lang-pill { display: none; }
    .login-link span, .login-link { font-size: 0; padding: 8px; }
    .login-link i { font-size: 16px; }
    .sec-head { grid-template-columns: 1fr; gap: 12px; }
    .services-grid { grid-template-columns: 1fr; }
    .svc, .svc.feat { grid-column: span 1; }
    .steps { grid-template-columns: 1fr; }
    .step { border-right: 0; border-bottom: 1px solid var(--ink); padding: 32px 0; }
    .step:last-child { border-bottom: 0; }
    .step:not(:first-child) { padding-left: 0; }
    .heritage-grid { grid-template-columns: 1fr; }
    .apps-grid { grid-template-columns: 1fr; }
    .foot-grid { grid-template-columns: 1fr 1fr; }
    .hero-meta .micro { grid-template-columns: 1fr 1fr; }
  }
  @media (max-width: 520px) {
    .foot-grid { grid-template-columns: 1fr; }
  }

/* ====================================================================
 * ====== SERVICE PAGES — additions au-dessus de djooni-wax base ======
 * ==================================================================== */

/* Skip-to-content link for accessibility */
.skip-to-content {
  position: absolute; top: -40px; left: 0;
  background: var(--burgundy); color: var(--calico);
  padding: 8px 16px; z-index: 100;
  font-family: var(--mono); font-size: 12px;
  text-decoration: none; letter-spacing: .08em;
}
.skip-to-content:focus { top: 0; }

/* Focus styles for accessibility */
*:focus-visible { outline: 3px solid var(--orange); outline-offset: 2px; }
button:focus-visible, .btn:focus-visible, .login-link:focus-visible { outline-offset: 4px; }

/* Active nav state */
nav.main a.active {
  color: var(--brick);
  position: relative;
}
nav.main a.active::after {
  content: "";
  position: absolute;
  inset: auto 0 -2px 0;
  height: 6px;
  background-image: radial-gradient(var(--ocre) 1px, transparent 1.5px);
  background-size: 6px 6px;
  background-repeat: repeat-x;
}

/* ============ BREADCRUMB ============ */
.breadcrumb {
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: .7;
  margin-bottom: 22px;
  display: flex;
  gap: 10px;
  align-items: center;
}
.breadcrumb a {
  color: var(--ink);
  border-bottom: 1px dashed var(--line);
  padding-bottom: 1px;
}
.breadcrumb a:hover { color: var(--brick); border-color: var(--brick); }
.breadcrumb span { opacity: .5; }
.breadcrumb [aria-current="page"] { color: var(--brick); opacity: 1; border: 0; }

/* ============ SERVICE HERO ============ */
section.svc-hero {
  background: var(--calico);
  border-bottom: 1px solid var(--ink);
  padding: 56px 0 64px;
  position: relative;
  overflow: hidden;
}
.svc-hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: end;
}
.svc-hero h1 {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(44px, 6.4vw, 96px);
  line-height: .94;
  letter-spacing: -.022em;
  color: var(--ink);
  margin-bottom: 18px;
}
.svc-hero h1 .hand {
  font-family: var(--hand);
  font-weight: 700;
  color: var(--orange);
  transform: rotate(-3deg);
  display: inline-block;
  font-size: 1.05em;
}
.svc-hero h1 .br { color: var(--brick); }
.svc-hero h1 .ind { color: var(--burgundy); }
.svc-hero .lede {
  font-size: 17px;
  line-height: 1.5;
  max-width: 50ch;
  margin-bottom: 28px;
  color: var(--ink);
}
.svc-hero .lede em { font-style: normal; color: var(--brick); font-weight: 700; }

/* Hero CTA card (address, calculator, etc) */
.action-card {
  border: 1px solid var(--ink);
  background: var(--calico);
  padding: 24px 26px 22px;
  margin-top: 14px;
}
.action-card .lab {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: .8;
  margin-bottom: 14px;
}
.action-row {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--ink);
  background: var(--calico-2);
  padding: 6px 6px 6px 12px;
}
.action-row .pin {
  width: 32px; height: 32px;
  background: var(--burgundy);
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}
.action-row input,
.action-row select {
  border: 0;
  background: transparent;
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink);
  outline: none;
  padding: 12px 8px;
  width: 100%;
}
.action-row input::placeholder { color: rgba(74, 36, 24, 0.5); }
.action-go {
  background: var(--burgundy);
  color: var(--calico);
  font-family: var(--display);
  font-weight: 700;
  font-size: 14px;
  padding: 12px 18px;
  border: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: background .2s;
}
.action-go:hover { background: var(--orange); }

/* Quick filter pills under action card */
.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 16px;
}
.pill-row .lab2 {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: .7;
}
.qpill {
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .06em;
  text-transform: uppercase;
  border: 1px solid var(--ink);
  background: var(--calico);
  color: var(--ink);
  padding: 7px 12px;
  border-radius: 999px;
  cursor: pointer;
  transition: background .2s, color .2s;
}
.qpill:hover { background: var(--ink); color: var(--calico); }
.qpill.on { background: var(--burgundy); color: var(--calico); border-color: var(--burgundy); }

/* Hero art (illustration to the right of hero text) */
.svc-hero-art {
  position: relative;
  aspect-ratio: 1/1;
  background-color: var(--burgundy);
  background-image:
    radial-gradient(circle at 20% 30%, rgba(245,180,40,.18) 0 1px, transparent 1.5px),
    repeating-linear-gradient(135deg, transparent 0 10px, rgba(245,180,40,.06) 10px 11px);
  background-size: 14px 14px, auto;
  border: 1px solid var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.svc-hero-art .icon-big {
  width: 50%; height: auto;
  color: var(--gold);
  font-size: 200px;
  line-height: 1;
}
.svc-hero-art .deco-1, .svc-hero-art .deco-2 {
  position: absolute;
  background: var(--calico);
  border: 1px solid var(--ink);
  padding: 12px 16px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink);
}
.svc-hero-art .deco-1 { top: 18px; left: 18px; }
.svc-hero-art .deco-2 { bottom: 18px; right: 18px; }
.svc-hero-art .deco-1 b, .svc-hero-art .deco-2 b {
  display: block;
  font-family: var(--display);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -.01em;
  color: var(--burgundy);
  margin-bottom: 2px;
}

/* ============ TRUST STRIP (4 key arguments band) ============ */
section.trust {
  background: var(--ink); color: var(--calico);
  border-bottom: 1px solid var(--ink);
}
.trust-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.trust-cell {
  padding: 22px 24px;
  border-right: 1px solid rgba(244,234,218,.18);
  display: flex; gap: 14px; align-items: center;
}
.trust-cell:last-child { border-right: 0; }
.trust-cell .ti {
  font-size: 28px;
  color: var(--gold);
}
.trust-cell b {
  display: block;
  font-family: var(--display);
  font-weight: 800;
  font-size: 18px;
  line-height: 1.1;
}
.trust-cell small {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .1em;
  text-transform: uppercase;
  opacity: .8;
}

/* ============ CATEGORIES GRID (services types) ============ */
section.cats {
  background: var(--calico);
  padding: 72px 0 56px;
  border-bottom: 1px solid var(--ink);
}
.cat-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}
.cat {
  background: var(--calico);
  border: 1px solid var(--ink);
  padding: 20px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  cursor: pointer;
  transition: background .2s, color .2s, transform .2s;
  text-align: left;
  font-family: var(--sans);
  color: var(--ink);
}
.cat:hover { background: var(--burgundy); color: var(--calico); transform: translateY(-3px); }
.cat:hover .cat-num, .cat:hover .ct { color: var(--ocre); }
.cat .cat-icn { font-size: 28px; color: var(--brick); }
.cat:hover .cat-icn { color: var(--ocre); }
.cat .cat-num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--brick);
}
.cat .nm {
  font-family: var(--display);
  font-weight: 800;
  font-size: 18px;
  line-height: 1.05;
  letter-spacing: -.012em;
}
.cat .ct {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .06em;
  color: var(--ink);
  opacity: .7;
  margin-top: 4px;
}

/* ============ COVERAGE (zones desservies for service pages) ============ */
section.coverage {
  background: var(--calico-2);
  padding: 72px 0 64px;
  border-bottom: 1px solid var(--ink);
}
.coverage-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.coverage-card {
  background: var(--calico);
  border: 1px solid var(--ink);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.coverage-card .nm {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--brick);
}
.coverage-card h4 {
  font-family: var(--display);
  font-weight: 800;
  font-size: 28px;
  line-height: 1;
  letter-spacing: -.015em;
  color: var(--ink);
}
.coverage-card p {
  font-size: 14.5px;
  line-height: 1.55;
}
.coverage-card .areas {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
.coverage-card .areas li {
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .06em;
  text-transform: uppercase;
  background: var(--calico-2);
  border: 1px solid var(--ink);
  padding: 5px 10px;
}

/* ============ HOW IT WORKS (3-step variant for service pages) ============ */
section.svc-how {
  background: var(--calico);
  padding: 72px 0 64px;
  border-bottom: 1px solid var(--ink);
}
.svc-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 2px solid var(--ink);
}
.svc-step {
  padding: 32px 24px 28px 0;
  border-right: 1px solid var(--ink);
}
.svc-step:last-child { border-right: 0; padding-right: 0; }
.svc-step:first-child { padding-left: 0; }
.svc-step:not(:first-child) { padding-left: 24px; }
.svc-step .num {
  font-family: var(--display);
  font-weight: 800;
  font-size: 96px;
  line-height: .8;
  letter-spacing: -.04em;
  margin-bottom: 14px;
  color: var(--burgundy);
}
.svc-step .num.alt { color: var(--brick); }
.svc-step .num.alt2 { color: var(--forest); }
.svc-step .lab {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--brick);
  margin-bottom: 8px;
}
.svc-step h4 {
  font-family: var(--display);
  font-weight: 800;
  font-size: 24px;
  line-height: 1;
  letter-spacing: -.015em;
  margin-bottom: 10px;
  max-width: 16ch;
}
.svc-step p {
  font-size: 14px;
  line-height: 1.55;
  max-width: 32ch;
}

/* ============ PRICING (forfait/tarif blocks for service pages) ============ */
section.pricing {
  background: var(--calico);
  padding: 72px 0 64px;
  border-bottom: 1px solid var(--ink);
}
.price-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
.price-card {
  background: var(--calico);
  border: 1px solid var(--ink);
  padding: 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
  transition: background .2s, color .2s;
}
.price-card:hover { background: var(--burgundy); color: var(--calico); }
.price-card:hover .nm, .price-card:hover .price-foot { color: var(--gold); }
.price-card .nm {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--brick);
}
.price-card h4 {
  font-family: var(--display);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -.015em;
}
.price-card .amount {
  font-family: var(--display);
  font-weight: 800;
  font-size: 32px;
  letter-spacing: -.02em;
  color: var(--burgundy);
}
.price-card:hover .amount { color: var(--gold); }
.price-card .amount small {
  display: block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 500;
  margin-top: 4px;
  color: var(--ink);
  opacity: .7;
}
.price-card:hover .amount small { color: var(--calico); opacity: .85; }
.price-card p { font-size: 13px; line-height: 1.5; }
.price-card .price-foot {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink);
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}

/* ============ RESPONSIVE — service pages ============ */
@media (max-width: 980px) {
  .svc-hero-grid { grid-template-columns: 1fr; }
  .svc-hero-art { display: none; }
  .trust-grid { grid-template-columns: 1fr 1fr; }
  .trust-cell { border-bottom: 1px solid rgba(244,234,218,.18); }
  .trust-cell:nth-child(2) { border-right: 0; }
  .coverage-grid { grid-template-columns: 1fr; }
  .svc-steps { grid-template-columns: 1fr; }
  .svc-step { border-right: 0; border-bottom: 1px solid var(--ink); padding: 24px 0; }
  .svc-step:last-child { border-bottom: 0; }
  .svc-step:not(:first-child) { padding-left: 0; }
}
@media (max-width: 520px) {
  .trust-grid { grid-template-columns: 1fr; }
  .trust-cell { border-right: 0; }
  .action-row { grid-template-columns: 1fr; gap: 8px; padding: 12px; }
  .action-go { width: 100%; justify-content: center; }
}

/* ============ Reduced motion (accessibility) ============ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .ph-card:hover { transform: none; }
  .svc:hover { transform: none; }
  .brand-card:hover { transform: none; }
  .ptn:hover { transform: none; }
}

/* ============ Print styles ============ */
@media print {
  header.site, footer.site, .kente-bar, .bogolan-row, .apps, section.faq, .login-link, .btn { display: none !important; }
  body { background: white; color: black; }
  .wrap { max-width: 100%; padding: 0 16px; }
}

/* ====================================================================
 * ====== RESTAURANT PAGE — CSS manquant (Restauration.html source) ===
 * ==================================================================== */

/* Filters bar */
section.list-block { background: var(--calico-2); padding: 72px 0 96px; border-bottom: 1px solid var(--ink); }
.filters { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; padding: 0 0 28px; border-bottom: 1px dashed var(--line); margin-bottom: 28px; }
.filt-pill { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; border: 1px solid var(--ink); background: var(--calico); padding: 8px 12px; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: background .2s, color .2s; }
.filt-pill:hover, .filt-pill.on { background: var(--ink); color: var(--calico); }
.filt-pill .ti { font-size: 14px; }
.filt-sep { width: 1px; height: 20px; background: var(--line); margin: 0 4px; }
.filt-meta { margin-left: auto; font-family: var(--mono); font-size: 11px; letter-spacing: .08em; color: var(--ink); opacity: .7; text-transform: uppercase; }

/* Restaurant grid */
.resto-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.resto { background: var(--calico); border: 1px solid var(--ink); display: flex; flex-direction: column; transition: transform .2s, box-shadow .2s; cursor: pointer; overflow: hidden; }
.resto:hover { transform: translateY(-4px); box-shadow: 6px 6px 0 var(--ink); }
.resto .ph { aspect-ratio: 4/3; background-color: var(--calico-2); background-image: repeating-linear-gradient(135deg, transparent 0 9px, rgba(74,36,24,.08) 9px 10px); position: relative; border-bottom: 1px solid var(--ink); }
.resto .ph .ti-photo { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); font-size: 36px; color: var(--ink); opacity: .25; }
.resto .ph-pin { position: absolute; top: 10px; left: 10px; font-family: var(--mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; background: var(--calico); border: 1px solid var(--ink); padding: 3px 7px; }
.resto .ph-pin.live { background: var(--burgundy); color: var(--calico); border-color: var(--burgundy); }
.resto .ph-pin.promo { background: var(--orange); color: var(--burgundy-2); border-color: var(--burgundy-2); }
.resto .ph-rate { position: absolute; top: 10px; right: 10px; background: var(--calico); border: 1px solid var(--ink); padding: 4px 8px; font-family: var(--display); font-weight: 800; font-size: 13px; display: inline-flex; gap: 4px; align-items: center; }
.resto .ph-rate .ti { color: var(--orange); font-size: 13px; }
.resto .meta { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.resto .row { font-family: var(--mono); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink); opacity: .8; display: flex; gap: 6px; align-items: baseline; flex-wrap: wrap; }
.resto .row .dot { opacity: .4; }
.resto h4 { font-family: var(--display); font-weight: 800; font-size: 22px; line-height: 1; letter-spacing: -.012em; color: var(--ink); }
.resto .desc { font-size: 13.5px; line-height: 1.45; color: var(--ink); opacity: .85; }
.resto .foot { margin-top: auto; padding-top: 12px; border-top: 1px dashed var(--line); display: flex; justify-content: space-between; align-items: center; font-family: var(--mono); font-size: 11px; letter-spacing: .06em; text-transform: uppercase; }
.resto .foot .price { color: var(--brick); font-weight: 700; }
.resto .foot .time { display: inline-flex; align-items: center; gap: 4px; }
.show-more { margin: 36px auto 0; display: flex; justify-content: center; gap: 12px; }

/* Dish showcase */
section.dishes { background: var(--calico); padding: 72px 0 96px; border-bottom: 1px solid var(--ink); }
.dish-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.dish { background: var(--calico-2); border: 1px solid var(--ink); display: flex; gap: 0; min-height: 180px; cursor: pointer; transition: transform .2s, background .2s; overflow: hidden; }
.dish:hover { transform: translateY(-3px); background: var(--calico); }
.dish .ph { width: 42%; flex: 0 0 auto; background-color: var(--burgundy); background-image: repeating-linear-gradient(45deg, transparent 0 11px, rgba(244,234,218,.08) 11px 12px); position: relative; border-right: 1px solid var(--ink); }
.dish .ph .ti-photo { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); font-size: 30px; color: var(--calico); opacity: .35; }
.dish.alt .ph { background-color: var(--forest); }
.dish.alt2 .ph { background-color: var(--gold); }
.dish.alt3 .ph { background-color: var(--brick); }
.dish.alt4 .ph { background-color: var(--indigo); }
.dish.alt5 .ph { background-color: var(--orange); }
.dish .meta { padding: 18px 18px 16px; display: flex; flex-direction: column; gap: 8px; flex: 1; min-width: 0; }
.dish .cat-tag { font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--brick); }
.dish h4 { font-family: var(--display); font-weight: 800; font-size: 20px; line-height: 1.05; letter-spacing: -.012em; }
.dish .from { font-size: 12.5px; color: var(--ink); opacity: .75; font-style: italic; }
.dish .price-row { margin-top: auto; display: flex; justify-content: space-between; align-items: center; border-top: 1px dashed var(--line); padding-top: 10px; font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
.dish .price { font-family: var(--display); font-weight: 800; font-size: 18px; color: var(--burgundy); }

/* Restaurant How (dark bg, 4 steps) */
section.how { background: var(--burgundy); color: var(--calico); padding: 72px 0 96px; border-bottom: 1px solid var(--ink); }
section.how .sec-head .nm { color: var(--gold); border-top-color: var(--gold); }
section.how .sec-head h2 { color: var(--calico); }
section.how .sec-head h2 .hand { color: var(--orange); }
.how-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(244,234,218,.25); }
.how-step { padding: 32px 24px 28px 0; border-right: 1px solid rgba(244,234,218,.18); display: flex; flex-direction: column; gap: 14px; }
.how-step:last-child { border-right: 0; padding-right: 0; }
.how-step .num { font-family: var(--display); font-weight: 800; font-size: 88px; line-height: .9; color: var(--gold); letter-spacing: -.04em; }
.how-step .num.alt { color: var(--orange); }
.how-step h4 { font-family: var(--display); font-weight: 800; font-size: 22px; line-height: 1.05; letter-spacing: -.01em; }
.how-step p { font-size: 14px; line-height: 1.5; opacity: .9; max-width: 28ch; }
.how-step .ti-row { margin-top: auto; padding-top: 14px; border-top: 1px solid rgba(244,234,218,.18); font-family: var(--mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); display: flex; gap: 8px; align-items: center; }

/* Restaurant Coverage (uses .cov-grid / .cov-card) */
.cov-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.cov-card { background: var(--calico); border: 1px solid var(--ink); padding: 28px 28px 24px; display: flex; flex-direction: column; gap: 16px; }
.cov-card.dark { background: var(--ink); color: var(--calico); }
.cov-card.dark .cov-num { color: var(--gold); }
.cov-card .cov-num { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--brick); }
.cov-card h4 { font-family: var(--display); font-weight: 800; font-size: 32px; line-height: .98; letter-spacing: -.015em; }
.cov-card p { font-size: 14.5px; line-height: 1.55; max-width: 40ch; opacity: .92; }
.cov-zones { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }
.cov-zone { display: grid; grid-template-columns: 1fr auto; gap: 12px; border-bottom: 1px solid var(--line); padding-bottom: 10px; font-family: var(--mono); font-size: 11.5px; letter-spacing: .06em; text-transform: uppercase; }
.cov-card.dark .cov-zone { border-bottom-color: rgba(244,234,218,.2); }
.cov-zone b { font-family: var(--display); font-weight: 800; font-size: 17px; letter-spacing: -.01em; text-transform: none; }
.cov-zone .min { color: var(--orange); }
.pay-row { display: flex; flex-wrap: wrap; gap: 8px; }
.pay-pill { font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; border: 1px solid currentColor; padding: 6px 10px; display: inline-flex; gap: 6px; align-items: center; }

/* ====================================================================
 * ====== FIXES UI — Burtol/Jabbal brand-thumb + Cities + sec-head ===
 * ==================================================================== */

/* Fix brand-thumb : fond neutre crème pour Burtol et Jabbal */
.brand-thumb { background: var(--calico-2); border-bottom: 1px solid var(--ink); display: flex; align-items: center; justify-content: center; overflow: hidden; aspect-ratio: 3/2; }
.brand-thumb img { width: 100%; height: 100%; object-fit: contain; padding: 20px; }
.brand-thumb.dark { background: var(--burgundy); }

/* Fix cities list — texte coupé à gauche */
.cities-list { overflow: visible; }
.city-row { display: grid; grid-template-columns: 80px 1fr auto; gap: 16px; align-items: start; padding: 16px 0; border-bottom: 1px solid var(--line); }
.city-row .ix { font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--brick); opacity: .8; padding-top: 2px; white-space: nowrap; }
.city-row .nm { font-family: var(--display); font-weight: 800; font-size: 20px; letter-spacing: -.01em; line-height: 1.05; }
.city-row .nm small { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: .05em; font-weight: 400; opacity: .65; margin-top: 3px; text-transform: uppercase; }
.city-row .st { font-family: var(--mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; padding: 5px 10px; white-space: nowrap; }
.city-row .st.live { background: var(--burgundy); color: var(--calico); }
.city-row .st.soon { border: 1px solid var(--ink); color: var(--ink); }

/* Fix cities grid layout */
.cities-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
@media (max-width: 880px) { .cities-grid { grid-template-columns: 1fr; } }

/* Fix sec-head — cohérence entre landing et pages services */
.sec-head { display: grid; grid-template-columns: 220px 1fr; gap: 32px; padding: 0 0 36px; align-items: end; border-top: 2px solid var(--ink); padding-top: 28px; margin-bottom: 0; }
.sec-head .nm { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--brick); border-top: none; }
.sec-head h2 { font-family: var(--display); font-weight: 800; font-size: clamp(36px, 5vw, 62px); line-height: .92; letter-spacing: -.022em; color: var(--ink); }
.sec-head h2 .hand { font-family: var(--hand); font-weight: 700; color: var(--orange); font-size: 1.05em; }
.sec-head h2 .ind { color: var(--burgundy); }
.sec-head h2 .br { color: var(--brick); }
@media (max-width: 880px) { .sec-head { grid-template-columns: 1fr; gap: 12px; } }

/* Responsive restaurant/dish */
@media (max-width: 980px) {
  .dish-grid { grid-template-columns: 1fr; }
  .dish .ph { width: 35%; }
  .resto-grid { grid-template-columns: repeat(2, 1fr); }
  .how-steps { grid-template-columns: 1fr; }
  .how-step { border-right: 0; border-bottom: 1px solid rgba(244,234,218,.18); padding-right: 0; }
  .how-step:last-child { border-bottom: 0; }
  .cov-grid { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .resto-grid { grid-template-columns: 1fr; }
  .dish-grid { grid-template-columns: 1fr; }
}

/* ====================================================================
 * ====== RESTAURANT HERO — CSS complet (section.hero, hero-grid) =====
 * ==================================================================== */
section.hero { background: var(--calico); border-bottom: 1px solid var(--ink); padding: 56px 0 64px; position: relative; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 56px; align-items: center; position: relative; z-index: 2; }
.hero h1 { font-family: var(--display); font-weight: 800; font-size: clamp(48px, 6.4vw, 96px); line-height: .94; letter-spacing: -.024em; max-width: 14ch; color: var(--ink); }
.hero h1 .br { color: var(--orange); }
.hero h1 .hand { font-family: var(--hand); font-weight: 700; color: var(--brick); transform: rotate(-2deg); display: inline-block; }
.hero p.lede { margin-top: 22px; font-size: 18px; line-height: 1.55; max-width: 44ch; font-family: var(--display); font-weight: 500; }
.hero p.lede em { font-style: normal; color: var(--brick); font-weight: 700; }

/* Address card */
.addr-card { margin-top: 36px; border: 1.5px solid var(--ink); background: var(--calico); padding: 18px; box-shadow: 8px 8px 0 var(--ink); max-width: 520px; }
.addr-card .lab { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--burgundy); margin-bottom: 10px; display: flex; justify-content: space-between; align-items: center; }
.addr-card .lab span:last-child { opacity: .7; color: var(--ink); }
.addr-row { display: grid; grid-template-columns: auto 1fr auto; gap: 10px; align-items: center; border: 1px solid var(--ink); background: var(--calico-2); padding: 4px; }
.addr-row .pin { width: 42px; height: 42px; background: var(--burgundy-2); color: var(--orange); display: inline-flex; align-items: center; justify-content: center; font-size: 22px; }
.addr-row input { border: 0; background: transparent; outline: none; font-family: var(--display); font-weight: 500; font-size: 17px; color: var(--ink); padding: 0 4px; min-width: 0; width: 100%; }
.addr-row input::placeholder { color: var(--ink); opacity: .5; }
.addr-go { font-family: var(--mono); font-size: 11.5px; letter-spacing: .14em; text-transform: uppercase; background: var(--ink); color: var(--calico); padding: 12px 16px; border: 0; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: background .2s; }
.addr-go:hover { background: var(--orange); color: var(--burgundy-2); }
.city-pills { margin-top: 14px; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; }
.city-pills .lab2 { color: var(--ink); opacity: .7; margin-right: 4px; }
.city-pill { border: 1px solid var(--ink); padding: 6px 10px; background: var(--calico); cursor: pointer; transition: background .2s, color .2s; }
.city-pill:hover, .city-pill.on { background: var(--ink); color: var(--calico); }
.city-pill.dot::before { content: "•"; color: var(--orange); margin-right: 5px; font-size: 14px; }

/* Hero art (plate illustration for restaurant) */
.hero-art { position: relative; aspect-ratio: 1/1; width: 100%; max-width: 480px; justify-self: end; }
.hero-art .plate { position: absolute; inset: 0; border: 1.5px solid var(--ink); border-radius: 999px; background: var(--calico-2); background-image: repeating-conic-gradient(from 0deg, transparent 0 7deg, rgba(74,36,24,.06) 7deg 7.5deg), radial-gradient(circle at 50% 50%, var(--calico) 0 38%, transparent 38.2%); }
.hero-art .plate-inner { position: absolute; inset: 18%; border: 1px solid var(--ink); border-radius: 999px; background: var(--calico); }
.hero-art .plate-stamp { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); text-align: center; font-family: var(--mono); color: var(--ink); }
.hero-art .plate-stamp .ti { font-size: 42px; color: var(--orange); display: block; margin-bottom: 8px; }
.hero-art .plate-stamp b { display: block; font-family: var(--display); font-weight: 800; font-size: 22px; letter-spacing: -.01em; line-height: 1; color: var(--burgundy); }
.hero-art .plate-stamp small { display: block; margin-top: 6px; font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; }
.hero-art .deco-1, .hero-art .deco-2 { position: absolute; border: 1px solid var(--ink); background: var(--calico); padding: 10px 14px; font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; line-height: 1.4; }
.hero-art .deco-1 { top: 6%; right: -4%; transform: rotate(4deg); }
.hero-art .deco-1 b { font-family: var(--display); font-size: 22px; color: var(--orange); display: block; }
.hero-art .deco-2 { bottom: 4%; left: -6%; transform: rotate(-3deg); background: var(--orange); color: var(--burgundy-2); border-color: var(--burgundy-2); }
.hero-art .deco-2 b { font-family: var(--display); font-size: 22px; display: block; }

@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-art { display: none; }
}
