/*
Theme Name:        C10i — Par-delà la frontière
Theme URI:         https://c10i.info
Author:            Teradelis
Author URI:        https://teradelis.com
Description:       Guide lifestyle transfrontalier. Restaurants, shopping, art de vivre, tourisme — les bonnes adresses d'ici et là.
Version:           2.0.0
Requires at least: 6.4
Tested up to:      6.7
Requires PHP:      8.1
License:           Proprietary
Text Domain:       c10i
*/

/* ══════════════════════════════════════════════════════
   VARIABLES GLOBALES & PALETTE C10i
   (issue du guide papier — rouge framboise #E3003A)
══════════════════════════════════════════════════════ */
:root {
  --rouge:         #E3003A;
  --rouge-sombre:  #B5002E;
  --rouge-pale:    #FFF0F4;
  --noir:          #1A1A1A;
  --gris-prof:     #2D2D2D;
  --gris:          #6E6E6E;
  --gris-clair:    #E8E4DF;
  --creme:         #F7F4EF;
  --blanc:         #FFFFFF;
  --or:            #C8A84B;
  --vert-ok:       #2D7A3A;
  --cyan:          #00B4C8;

  /* Zone active – override par body.zone-* */
  --zone-accent:        var(--rouge);
  --zone-accent-sombre: var(--rouge-sombre);
  --zone-accent-pale:   var(--rouge-pale);

  --font-display: 'Arial Black','Helvetica Neue',Arial,sans-serif;
  --font-body:    'Segoe UI',system-ui,-apple-system,sans-serif;

  --text-xs:   11px; --text-sm: 13px; --text-base: 15px;
  --text-lg:   18px; --text-xl: 22px; --text-2xl:  28px;
  --text-3xl:  38px; --text-4xl: 52px;

  --max-w:     1140px;
  --header-h:  56px;
  --radius-sm: 4px;
  --radius:    8px;
  --radius-lg: 14px;
  --shadow:    0 4px 16px rgba(0,0,0,.10);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.14);
}

/* ── Déclinaisons multi-zones ──────────────────────── */
body.zone-nfc-jura      { --zone-accent:#E3003A; --zone-accent-sombre:#B5002E; --zone-accent-pale:#FFF0F4; }
body.zone-alsace-bade   { --zone-accent:#2D6A2D; --zone-accent-sombre:#1E4D1E; --zone-accent-pale:#EEF6EE; }
body.zone-savoie-val    { --zone-accent:#0066CC; --zone-accent-sombre:#004F9F; --zone-accent-pale:#EEF4FF; }
body.zone-cotedazur-lig { --zone-accent:#E8650A; --zone-accent-sombre:#BA5008; --zone-accent-pale:#FFF4EE; }
body.zone-pays-basque   { --zone-accent:#CC0000; --zone-accent-sombre:#A00000; --zone-accent-pale:#FFF0F0; }
body.zone-normandie-kent{ --zone-accent:#003E7E; --zone-accent-sombre:#002D5C; --zone-accent-pale:#EEF2FF; }
body.zone-moselle-benelux{ --zone-accent:#5B2D8E; --zone-accent-sombre:#3D1D63; --zone-accent-pale:#F3EEF9; }

/* ══════════════════════════════════════════════════════
   RESET
══════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.65;background:var(--creme);color:var(--noir);overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit}

/* ══════════════════════════════════════════════════════
   HEADER
══════════════════════════════════════════════════════ */
#c10i-header{
  background:var(--noir);
  height:var(--header-h);
  padding:0 24px;
  display:flex;align-items:center;gap:20px;
  position:sticky;top:0;z-index:500;
  background-image:repeating-linear-gradient(-60deg,transparent,transparent 18px,rgba(227,0,58,.05) 18px,rgba(227,0,58,.05) 19px);
}

/* Logo */
.c10i-logo{display:flex;align-items:baseline;gap:1px;text-decoration:none;flex-shrink:0;line-height:1}
.c10i-logo-c{font-family:var(--font-display);font-size:30px;font-weight:900;color:var(--blanc);letter-spacing:-2px}
.c10i-logo-10{
  font-family:var(--font-display);font-size:30px;font-weight:900;letter-spacing:-2px;
  background:repeating-linear-gradient(-45deg,var(--zone-accent) 0,var(--zone-accent) 2px,transparent 2px,transparent 5px);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.c10i-logo-i{font-family:Georgia,'Times New Roman',serif;font-style:italic;font-size:26px;font-weight:700;color:var(--zone-accent);margin-left:1px}

/* Badge FR|CH */
.c10i-frontiere-badge{display:flex;align-items:center;gap:0;font-size:var(--text-xs);font-weight:800;letter-spacing:.06em;text-transform:uppercase;border:1px solid rgba(255,255,255,.12);border-radius:4px;overflow:hidden;flex-shrink:0}
.c10i-frontiere-badge .pays{padding:3px 8px;color:rgba(255,255,255,.5)}
.c10i-frontiere-badge .sep{width:1px;height:16px;background:rgba(255,255,255,.15);transform:skewX(-12deg)}

/* Nav */
.c10i-nav{display:flex;gap:3px;margin-left:16px}
.c10i-nav a{font-size:var(--text-xs);font-weight:700;color:rgba(247,244,239,.6);padding:5px 10px;border-radius:var(--radius-sm);letter-spacing:.04em;text-transform:uppercase;transition:all .12s;white-space:nowrap;text-decoration:none}
.c10i-nav a:hover{color:var(--blanc);background:rgba(255,255,255,.08)}
.c10i-nav a.active{color:var(--blanc);background:rgba(255,255,255,.11)}
.c10i-nav a.active-accent{background:var(--zone-accent);color:var(--blanc)}

/* Zone select */
.c10i-zone-select{margin-left:auto;display:flex;align-items:center;gap:8px}
.c10i-zone-select select{background:rgba(255,255,255,.08) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='rgba(255,255,255,.4)'/%3E%3C/svg%3E") no-repeat right 7px center;border:1px solid rgba(255,255,255,.15);color:rgba(247,244,239,.75);font-size:var(--text-xs);font-weight:600;padding:5px 22px 5px 9px;border-radius:var(--radius-sm);appearance:none;cursor:pointer;transition:all .15s}
.c10i-zone-select select:focus{outline:none;border-color:var(--zone-accent)}

/* Back link */
.c10i-back{font-size:var(--text-xs);color:rgba(247,244,239,.5);display:flex;align-items:center;gap:4px;margin-left:auto;padding:4px 8px;border-radius:var(--radius-sm);transition:all .12s;white-space:nowrap;text-decoration:none}
.c10i-back:hover{color:var(--blanc);background:rgba(255,255,255,.07)}

/* Hamburger */
.c10i-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;margin-left:auto}
.c10i-hamburger span{display:block;width:22px;height:2px;background:rgba(247,244,239,.8);border-radius:1px;transition:all .2s;transform-origin:center}
.c10i-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.c10i-hamburger.open span:nth-child(2){opacity:0}
.c10i-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Menu mobile */
.c10i-mobile-menu{display:none;position:fixed;top:var(--header-h);left:0;right:0;background:var(--gris-prof);border-top:2px solid var(--zone-accent);z-index:499;padding:8px 0 16px}
.c10i-mobile-menu.open{display:block}
.c10i-mobile-menu a{display:block;padding:12px 24px;font-size:var(--text-sm);font-weight:700;color:rgba(247,244,239,.7);text-transform:uppercase;letter-spacing:.04em;transition:all .1s;border-left:3px solid transparent;text-decoration:none}
.c10i-mobile-menu a:hover,.c10i-mobile-menu a.active{color:var(--blanc);border-left-color:var(--zone-accent);background:rgba(255,255,255,.05)}

/* ══════════════════════════════════════════════════════
   BANDEAU FRONTIÈRE (signature C10i)
══════════════════════════════════════════════════════ */
.c10i-frontiere-strip{
  height:5px;
  background:linear-gradient(to right,var(--zone-accent) 0%,var(--zone-accent) 49.5%,var(--blanc) 49.5%,var(--blanc) 50.5%,var(--cyan) 50.5%,var(--cyan) 100%);
  position:relative;overflow:hidden;
}


/* ══════════════════════════════════════════════════════
   HERO MINI
══════════════════════════════════════════════════════ */
.c10i-hero-mini{background:var(--noir);padding:40px 24px 32px;position:relative;overflow:hidden}
.c10i-hero-mini::before{content:'';position:absolute;top:-20%;right:-5%;width:320px;height:200%;background:repeating-linear-gradient(-55deg,transparent,transparent 14px,rgba(227,0,58,.07) 14px,rgba(227,0,58,.07) 15px);pointer-events:none}
.c10i-hero-mini::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--zone-accent)}
.c10i-hero-mini .inner{max-width:var(--max-w);margin:0 auto;position:relative}
.c10i-hero-eyebrow{font-size:var(--text-xs);font-weight:800;text-transform:uppercase;letter-spacing:.18em;color:var(--zone-accent);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.c10i-hero-eyebrow::before{content:'';display:block;width:24px;height:2px;background:var(--zone-accent)}
.c10i-hero-titre{font-family:var(--font-display);font-size:clamp(28px,4vw,52px);font-weight:900;color:var(--blanc);letter-spacing:-.03em;line-height:1.05;margin-bottom:10px;text-transform:uppercase}
.c10i-hero-desc{font-size:var(--text-sm);color:rgba(247,244,239,.6);max-width:520px;line-height:1.65}

/* ══════════════════════════════════════════════════════
   LAYOUT
══════════════════════════════════════════════════════ */
.c10i-container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.c10i-section{padding:48px 24px}
.c10i-section-inner{max-width:var(--max-w);margin:0 auto}

.c10i-section-header{display:flex;align-items:baseline;gap:16px;margin-bottom:24px;padding-bottom:12px;border-bottom:2px solid var(--gris-clair);position:relative}
.c10i-section-header::after{content:'';position:absolute;bottom:-2px;left:0;width:48px;height:2px;background:var(--zone-accent)}
.c10i-section-titre{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:900;letter-spacing:-.02em;text-transform:uppercase;color:var(--noir);line-height:1.1}
.c10i-section-lien{font-size:var(--text-xs);font-weight:700;color:var(--zone-accent);text-decoration:none;text-transform:uppercase;letter-spacing:.06em;margin-left:auto;transition:opacity .12s}
.c10i-section-lien:hover{opacity:.7}
.c10i-label{font-size:var(--text-xs);font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--gris);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--gris-clair)}

/* ══════════════════════════════════════════════════════
   CARTES ADRESSE
══════════════════════════════════════════════════════ */
.c10i-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.c10i-grid-sm{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}

.c10i-card{background:var(--blanc);border:1px solid var(--gris-clair);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:var(--noir);display:flex;flex-direction:column;transition:border-color .15s,transform .15s,box-shadow .15s;position:relative}
.c10i-card:hover{border-color:var(--zone-accent);transform:translateY(-3px);box-shadow:var(--shadow)}
.c10i-card.is-sponsor{border-color:var(--or);border-width:2px}
.c10i-card.is-sponsor::before{content:'⭐ Partenaire';position:absolute;top:8px;left:8px;background:var(--or);color:var(--blanc);font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:3px;z-index:2}

.c10i-card-img{aspect-ratio:4/3;overflow:hidden;background:var(--gris-clair);display:flex;align-items:center;justify-content:center;font-size:36px;position:relative}
.c10i-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.c10i-card:hover .c10i-card-img img{transform:scale(1.04)}
.c10i-card-pays{position:absolute;bottom:8px;right:8px;background:rgba(26,26,26,.75);color:var(--blanc);font-size:16px;border-radius:4px;padding:2px 5px;backdrop-filter:blur(4px)}

.c10i-card-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:4px}
.c10i-card-cat{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--zone-accent)}
.c10i-card-nom{font-family:var(--font-display);font-size:var(--text-base);font-weight:900;line-height:1.2;letter-spacing:-.01em}
.c10i-card-desc{font-size:var(--text-xs);color:var(--gris);line-height:1.5;margin-top:4px;flex:1}
.c10i-card-footer{display:flex;align-items:center;gap:8px;padding:10px 16px;border-top:1px solid var(--gris-clair);background:var(--creme)}
.c10i-card-ville{font-size:var(--text-xs);color:var(--gris);display:flex;align-items:center;gap:4px}
.c10i-card-note{font-size:var(--text-xs);font-weight:800;color:var(--zone-accent);margin-left:auto}
.c10i-card-prix{font-size:var(--text-xs);color:var(--gris)}

/* ══════════════════════════════════════════════════════
   CATÉGORIES
══════════════════════════════════════════════════════ */
.c10i-cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.c10i-cat-pill{background:var(--blanc);border:1.5px solid var(--gris-clair);border-radius:var(--radius);padding:16px 12px;text-decoration:none;color:var(--noir);display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;transition:all .15s}
.c10i-cat-pill:hover{border-color:var(--zone-accent);background:var(--zone-accent-pale);transform:translateY(-2px)}
.c10i-cat-picto{font-size:26px;line-height:1}
.c10i-cat-nom{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;line-height:1.3}
.c10i-cat-count{font-size:10px;color:var(--gris)}

/* ══════════════════════════════════════════════════════
   BOUTONS
══════════════════════════════════════════════════════ */
.c10i-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:700;text-transform:uppercase;letter-spacing:.04em;text-decoration:none;border:2px solid transparent;cursor:pointer;transition:all .15s;font-family:var(--font-body);white-space:nowrap}
.c10i-btn-primary{background:var(--zone-accent);color:var(--blanc);border-color:var(--zone-accent)}
.c10i-btn-primary:hover{background:var(--zone-accent-sombre);border-color:var(--zone-accent-sombre);transform:translateY(-1px)}
.c10i-btn-outline{background:transparent;color:var(--zone-accent);border-color:var(--zone-accent)}
.c10i-btn-outline:hover{background:var(--zone-accent);color:var(--blanc)}
.c10i-btn-ghost{background:rgba(255,255,255,.12);color:var(--blanc);border-color:rgba(255,255,255,.25);backdrop-filter:blur(6px)}
.c10i-btn-ghost:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.4)}
.c10i-btn-noir{background:var(--noir);color:var(--blanc);border-color:var(--noir)}
.c10i-btn-noir:hover{background:var(--gris-prof)}
.c10i-btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}
.c10i-btn-full{width:100%}
.c10i-btn-lg{padding:14px 28px;font-size:var(--text-base)}
.c10i-btn-sm{padding:7px 13px;font-size:var(--text-xs)}

/* ══════════════════════════════════════════════════════
   FORMULAIRES
══════════════════════════════════════════════════════ */
.c10i-field{margin-bottom:16px}
.c10i-label{display:block;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gris);margin-bottom:5px}
.c10i-label .req{color:var(--zone-accent)}
.c10i-label .opt{font-weight:400;text-transform:none;letter-spacing:0;font-size:10px}
.c10i-input,.c10i-select,.c10i-textarea{width:100%;padding:10px 13px;border:1.5px solid var(--gris-clair);border-radius:var(--radius-sm);font-size:var(--text-sm);background:var(--blanc);color:var(--noir);font-family:var(--font-body);transition:border-color .15s,box-shadow .15s;appearance:none}
.c10i-input:focus,.c10i-select:focus,.c10i-textarea:focus{outline:none;border-color:var(--zone-accent);box-shadow:0 0 0 3px var(--zone-accent-pale)}
.c10i-input.erreur,.c10i-select.erreur,.c10i-textarea.erreur{border-color:var(--zone-accent);background:var(--zone-accent-pale)}
.c10i-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236E6E6E'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:28px}
.c10i-textarea{resize:vertical;min-height:100px;line-height:1.6}
.c10i-field-error{font-size:11px;color:var(--zone-accent);font-weight:600;margin-top:4px}
.c10i-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.c10i-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* ══════════════════════════════════════════════════════
   FILTRES
══════════════════════════════════════════════════════ */
.c10i-filtres{background:var(--blanc);border-bottom:1px solid var(--gris-clair);padding:12px 24px;display:flex;gap:8px;align-items:center;flex-wrap:wrap;position:sticky;top:var(--header-h);z-index:100;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.c10i-filtre-pill{padding:5px 12px;border:1.5px solid var(--gris-clair);border-radius:20px;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--creme);color:var(--gris);cursor:pointer;appearance:none;transition:all .12s}
.c10i-filtre-pill:focus{outline:none}
.c10i-filtre-pill:hover,.c10i-filtre-pill.actif{border-color:var(--zone-accent);color:var(--zone-accent);background:var(--zone-accent-pale)}
.c10i-filtres-count{font-size:var(--text-xs);color:var(--gris);margin-left:auto;white-space:nowrap}

/* ══════════════════════════════════════════════════════
   SIDEBAR INFO
══════════════════════════════════════════════════════ */
.c10i-info-card{background:var(--blanc);border:1px solid var(--gris-clair);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.c10i-info-header{background:var(--noir);color:var(--blanc);padding:12px 16px;font-size:var(--text-xs);font-weight:800;text-transform:uppercase;letter-spacing:.1em;background-image:repeating-linear-gradient(-55deg,transparent,transparent 10px,rgba(255,255,255,.03) 10px,rgba(255,255,255,.03) 11px)}
.c10i-info-row{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-bottom:1px solid var(--gris-clair);font-size:var(--text-sm)}
.c10i-info-row:last-child{border-bottom:none}
.c10i-info-icon{font-size:16px;flex-shrink:0;line-height:1.4}
.c10i-info-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--gris);margin-bottom:2px}
.c10i-info-val{color:var(--noir);line-height:1.5}
.c10i-info-val a{color:var(--zone-accent)}
.c10i-info-val a:hover{text-decoration:underline}

/* ══════════════════════════════════════════════════════
   ZONES MULTI-FRONTALIÈRES
══════════════════════════════════════════════════════ */
.c10i-zones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.c10i-zone-card{border-radius:var(--radius);overflow:hidden;text-decoration:none;color:var(--blanc);position:relative;aspect-ratio:3/2;display:flex;flex-direction:column;justify-content:flex-end;padding:20px;transition:transform .2s,box-shadow .2s}
.c10i-zone-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.c10i-zone-card-bg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;transition:transform .3s}
.c10i-zone-card:hover .c10i-zone-card-bg{transform:scale(1.04)}
.c10i-zone-card-overlay{position:absolute;inset:0;background:linear-gradient(transparent 20%,rgba(26,26,26,.85) 100%)}
.c10i-zone-card-content{position:relative}
.c10i-zone-card-flags{font-size:20px;margin-bottom:4px}
.c10i-zone-card-nom{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;text-transform:uppercase;letter-spacing:-.02em;line-height:1.1;margin-bottom:2px}
.c10i-zone-card-pays{font-size:var(--text-xs);opacity:.7;text-transform:uppercase;letter-spacing:.1em}
.c10i-zone-card-count{position:absolute;top:12px;right:12px;background:rgba(26,26,26,.7);backdrop-filter:blur(4px);color:var(--blanc);font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px}
.c10i-zone-card[data-zone="nfc-jura"]::after      {content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:#E3003A}
.c10i-zone-card[data-zone="alsace-bade"]::after   {content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:#2D6A2D}
.c10i-zone-card[data-zone="savoie-val"]::after    {content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:#0066CC}
.c10i-zone-card[data-zone="cotedazur-lig"]::after {content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:#E8650A}
.c10i-zone-card[data-zone="pays-basque"]::after   {content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:#CC0000}
.c10i-zone-card[data-zone="normandie-kent"]::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:#003E7E}

/* ══════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════ */
#c10i-footer{background:var(--noir);color:var(--blanc)}
.c10i-footer-cta{background:var(--zone-accent);padding:40px 24px;text-align:center;position:relative;overflow:hidden}
.c10i-footer-cta::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-55deg,transparent,transparent 18px,rgba(0,0,0,.05) 18px,rgba(0,0,0,.05) 19px);pointer-events:none}
.c10i-footer-cta h2{font-family:var(--font-display);font-size:clamp(22px,3vw,38px);font-weight:900;text-transform:uppercase;color:var(--blanc);margin-bottom:8px;letter-spacing:-.02em;position:relative}
.c10i-footer-cta p{font-size:var(--text-sm);color:rgba(255,255,255,.85);max-width:460px;margin:0 auto 24px;line-height:1.65;position:relative}
.c10i-footer-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}

.c10i-footer-body{padding:48px 24px 32px;max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px}
.c10i-footer-logo{font-family:var(--font-display);font-size:34px;font-weight:900;letter-spacing:-2px;margin-bottom:12px;line-height:1}
.c10i-footer-logo .c{color:var(--blanc)}
.c10i-footer-logo .dix{color:var(--zone-accent)}
.c10i-footer-logo .i{font-style:italic;font-family:Georgia,serif;color:var(--zone-accent)}
.c10i-footer-baseline{font-style:italic;font-size:var(--text-sm);color:rgba(247,244,239,.45);margin-bottom:16px;font-family:Georgia,serif}
.c10i-footer-about{font-size:var(--text-xs);color:rgba(247,244,239,.4);line-height:1.7;max-width:300px}
.c10i-footer-about a{color:var(--zone-accent)}
.c10i-footer-col-titre{font-size:var(--text-xs);font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:rgba(247,244,239,.3);margin-bottom:16px}
.c10i-footer-col nav{display:flex;flex-direction:column;gap:8px}
.c10i-footer-col nav a{font-size:var(--text-sm);color:rgba(247,244,239,.5);text-decoration:none;transition:color .12s;line-height:1.4}
.c10i-footer-col nav a:hover{color:var(--blanc)}
.c10i-footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:20px 24px;max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.c10i-footer-bottom p{font-size:11px;color:rgba(247,244,239,.3)}
.c10i-footer-bottom a{color:rgba(247,244,239,.4);transition:color .12s}
.c10i-footer-bottom a:hover{color:var(--zone-accent)}

/* ══════════════════════════════════════════════════════
   BADGES & UTILITAIRES
══════════════════════════════════════════════════════ */
.c10i-badge{display:inline-block;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;padding:2px 8px;border-radius:3px}
.c10i-badge-accent{background:var(--zone-accent);color:var(--blanc)}
.c10i-badge-or{background:var(--or);color:var(--blanc)}
.c10i-badge-noir{background:var(--noir);color:var(--blanc)}
.c10i-badge-vert{background:var(--vert-ok);color:var(--blanc)}
.c10i-badge-outline{border:1.5px solid var(--gris-clair);color:var(--gris);background:none}
.c10i-note{display:flex;align-items:center;gap:4px;font-size:var(--text-xs);font-weight:700;color:var(--zone-accent)}
.c10i-etoiles{color:#F5A623}

/* ══════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════ */
@media(max-width:900px){.c10i-footer-body{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:768px){
  :root{--header-h:50px}
  #c10i-header{padding:0 16px;gap:12px}
  .c10i-nav,.c10i-frontiere-badge,.c10i-zone-select{display:none}
  .c10i-hamburger{display:flex}
  .c10i-hero-mini{padding:32px 16px 24px}
  .c10i-section{padding:32px 16px}
  .c10i-grid{grid-template-columns:1fr}
  .c10i-grid-2,.c10i-grid-3{grid-template-columns:1fr}
  .c10i-filtres{padding:12px 16px;gap:4px}
  .c10i-footer-body{grid-template-columns:1fr;gap:32px;padding:32px 16px}
  .c10i-footer-bottom{flex-direction:column;text-align:center}
}
@media(max-width:480px){.c10i-cats-grid{grid-template-columns:repeat(3,1fr)}.c10i-zones-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
