*{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#1A1A2E;--ink-muted:#5A5A72;--ink-subtle:#8A8A9E;
  --canvas:#F8F7F4;--surface-1:#FFFFFF;--surface-2:#F0EEE8;
  --hairline:#E2E0DA;--hairline-soft:#F0EEE8;
  --primary:#6B3A2A;--primary-light:#8B5A3A;--primary-dark:#4A2518;--primary-soft:#F0E8E3;
  --accent:#C9952E;--accent-soft:#F5E6C8;--accent-dark:#A67A20;
  --success:#2D8F6C;--danger:#C44545;
  --font-heading:'Newsreader',Georgia,serif;--font-body:'Inter',sans-serif;--font-ui:'DM Sans',sans-serif;
  --max-w:1200px;
}
body{font-family:var(--font-body);color:var(--ink);background:var(--canvas);-webkit-font-smoothing:antialiased;line-height:1.6}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-light)}
img{display:block;max-width:100%;height:auto}

/* HEADER */
.site-header{background:var(--surface-1);border-bottom:1px solid var(--hairline);position:sticky;top:0;z-index:100}
.header-inner{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;height:64px;gap:2rem}
.logo{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;color:var(--primary);letter-spacing:-0.02em;display:flex;align-items:center;gap:8px}
.logo .shield{display:inline-flex;width:28px;height:28px;background:var(--primary);color:#fff;border-radius:6px;align-items:center;justify-content:center;font-size:13px}
.logo span{color:var(--accent)}
.nav{display:flex;gap:2px;flex:1}
.nav a{padding:.35rem .85rem;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--ink-muted);border-radius:6px;transition:all .15s}
.nav a:hover,.nav a.active{color:var(--primary);background:var(--primary-soft)}
.nav a.active{color:var(--primary);background:var(--primary-soft)}
.header-r{display:flex;align-items:center;gap:1rem}
.header-r .search{padding:.35rem .75rem;border:1px solid var(--hairline);border-radius:6px;font-size:13px;width:200px;background:var(--canvas);font-family:var(--font-body)}
.header-r .search:focus{outline:none;border-color:var(--primary)}

/* HERO GRID */
.hero-grid{max-width:var(--max-w);margin:0 auto;padding:1.5rem 1.5rem 0;display:grid;grid-template-columns:1.6fr 1fr;gap:1rem}
.hero-main{position:relative;border-radius:14px;overflow:hidden;background:var(--primary-dark);min-height:360px;display:flex;flex-direction:column;justify-content:flex-end;cursor:default}
.hero-main-img{width:100%;height:100%;position:absolute;inset:0;background:linear-gradient(135deg,var(--primary-dark) 0%,#5A3020 100%);display:flex;align-items:center;justify-content:center;font-size:4rem}
.hero-main-overlay{position:relative;z-index:2;padding:2rem 1.5rem;background:linear-gradient(transparent,rgba(0,0,0,0.7))}
.hero-main-badge{display:inline-block;padding:3px 10px;border-radius:4px;background:var(--accent);color:#fff;font-family:var(--font-ui);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.6rem}
.hero-main-title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:#fff;letter-spacing:-0.02em;line-height:1.2;margin-bottom:.3rem}
.hero-main-desc{font-size:13px;color:rgba(255,255,255,0.7);line-height:1.5;margin-bottom:.5rem}
.hero-main-meta{font-size:11px;color:rgba(255,255,255,0.5);display:flex;gap:.75rem}
.hero-side{display:flex;flex-direction:column;gap:1rem}
.hero-side-card{position:relative;border-radius:14px;overflow:hidden;flex:1;min-height:172px;display:flex;flex-direction:column;justify-content:flex-end;cursor:default}
.hero-side-card:nth-child(1){background:linear-gradient(135deg,#6B3A2A,#4A2518)}
.hero-side-card:nth-child(2){background:linear-gradient(135deg,#8B5A3A,#6B3A2A)}
.hero-side-overlay{position:relative;z-index:2;padding:1.25rem 1.25rem}
.hero-side-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-family:var(--font-ui);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}
.hero-side-badge.gold{background:var(--accent);color:#fff}
.hero-side-badge.green{background:var(--success);color:#fff}
.hero-side-title{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:#fff;letter-spacing:-0.01em;line-height:1.25;margin-bottom:.2rem}
.hero-side-meta{font-size:11px;color:rgba(255,255,255,0.5)}
@media(max-width:768px){.hero-grid{grid-template-columns:1fr}.hero-side{flex-direction:row;overflow-x:auto}.hero-side-card{min-height:140px;min-width:240px}}

/* SECTION */
.section{max-width:var(--max-w);margin:0 auto;padding:2rem 1.5rem}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.section-header h2{font-family:var(--font-heading);font-size:1.35rem;font-weight:700;color:var(--primary);letter-spacing:-0.02em}
.section-header a{font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--ink-subtle);text-transform:uppercase;letter-spacing:.06em}
.section-header a:hover{color:var(--primary)}

/* FEATURED GRID */
.featured-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:1rem}
.featured-card{background:var(--surface-1);border-radius:12px;overflow:hidden;transition:all .25s;cursor:default;border:1px solid var(--hairline-soft)}
.featured-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.06);transform:translateY(-2px)}
.featured-card-img{width:100%;height:110px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;background:var(--accent-soft)}
.featured-card-body{padding:.85rem 1rem 1rem}
.featured-card-badge{display:inline-block;padding:2px 7px;border-radius:4px;font-family:var(--font-ui);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem;background:var(--accent-soft);color:var(--accent-dark)}
.featured-card-title{font-family:var(--font-heading);font-size:.9rem;font-weight:600;color:var(--ink);line-height:1.25;margin-bottom:.25rem}
.featured-card-meta{font-size:11px;color:var(--ink-subtle)}
.featured-card-rating{font-size:12px;color:var(--accent-dark);margin-top:.2rem}

/* CITIES GRID */
.cities-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.75rem}
.city-card{background:var(--surface-1);border-radius:10px;padding:.85rem 1rem;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--hairline-soft);transition:all .2s;cursor:default}
.city-card:hover{box-shadow:0 2px 8px rgba(0,0,0,0.04);border-color:var(--primary-soft)}
.city-card-name{font-family:var(--font-heading);font-size:.9rem;font-weight:600;color:var(--ink)}
.city-card-count{font-size:12px;font-weight:700;color:var(--accent-dark);background:var(--accent-soft);padding:2px 8px;border-radius:12px}

/* RECENT LIST */
.main-dual{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem 2rem;display:grid;grid-template-columns:1fr 320px;gap:2rem}
.recent-list{display:flex;flex-direction:column;gap:1rem}
.recent-item{display:flex;gap:1rem;align-items:flex-start;background:var(--surface-1);border-radius:12px;overflow:hidden;border:1px solid var(--hairline-soft);padding:.75rem;transition:all .2s;cursor:default}
.recent-item:hover{box-shadow:0 4px 12px rgba(0,0,0,0.04)}
.recent-item-img{width:80px;height:70px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.8rem;background:var(--surface-2)}
.recent-item-body{flex:1;min-width:0}
.recent-item-city{font-family:var(--font-ui);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted)}
.recent-item-title{font-family:var(--font-heading);font-size:.9rem;font-weight:600;color:var(--ink);line-height:1.25;margin:.15rem 0 .2rem}
.recent-item-meta{font-size:11px;color:var(--ink-subtle);display:flex;gap:.5rem;align-items:center}
.recent-item-rating{color:var(--accent-dark);font-weight:600}

/* SIDEBAR */
.sidebar{display:flex;flex-direction:column;gap:1rem}
.widget{background:var(--surface-1);border-radius:12px;border:1px solid var(--hairline-soft);padding:1.25rem}
.widget-title{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--primary);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--hairline-soft);letter-spacing:-0.01em}
.pop-item{display:flex;gap:.65rem;padding:.55rem 0;border-bottom:1px solid var(--hairline-soft)}
.pop-item:last-child{border-bottom:none}
.pop-num{font-family:var(--font-ui);font-size:13px;font-weight:700;color:var(--ink-subtle);width:20px;flex-shrink:0}
.pop-text{font-size:13px;line-height:1.3;color:var(--ink)}

/* CTA */
.cta-section{background:var(--primary-dark);padding:3rem 1.5rem;text-align:center;color:#fff}
.cta-inner{max-width:500px;margin:0 auto}
.cta-inner h2{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;margin-bottom:.35rem}
.cta-inner p{color:rgba(255,255,255,0.7);font-size:14px;margin-bottom:1.25rem}
.cta-btn{display:inline-block;padding:.65rem 1.5rem;border-radius:8px;background:var(--accent);color:var(--ink);font-family:var(--font-ui);font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all .15s}
.cta-btn:hover{background:var(--accent-dark);color:var(--ink)}

/* FOOTER */
.footer{background:var(--primary-dark);border-top:1px solid rgba(255,255,255,0.06);padding:2.5rem 1.5rem 1.5rem}
.footer-inner{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;color:#fff}
.footer h3{font-family:var(--font-heading);font-size:1rem;font-weight:700;margin-bottom:.75rem}
.footer p{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.6}
.footer ul{list-style:none}
.footer li{margin-bottom:.35rem}
.footer a{font-size:13px;color:rgba(255,255,255,0.5);transition:color .15s}
.footer a:hover{color:var(--accent)}
.footer-btm{grid-column:1/-1;border-top:1px solid rgba(255,255,255,0.06);padding-top:1rem;margin-top:1.5rem;font-size:12px;color:rgba(255,255,255,0.3);text-align:center}

/* VILLE PAGE */
.ville-hero{background:var(--primary-dark);padding:2.5rem 1.5rem;text-align:center;color:#fff}
.ville-hero h1{font-family:var(--font-heading);font-size:2rem;font-weight:700;margin-bottom:.3rem}
.ville-hero p{color:rgba(255,255,255,0.7);font-size:14px}
.bakery-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;max-width:var(--max-w);margin:0 auto;padding:2rem 1.5rem}
.bakery-card{background:var(--surface-1);border-radius:12px;overflow:hidden;border:1px solid var(--hairline-soft);transition:all .2s;cursor:default}
.bakery-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.06);transform:translateY(-2px)}
.bakery-card-img{width:100%;height:100px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;background:var(--accent-soft)}
.bakery-card-body{padding:.85rem 1rem 1rem}
.bakery-card-name{font-family:var(--font-heading);font-size:.95rem;font-weight:600;color:var(--ink);margin-bottom:.2rem}
.bakery-card-addr{font-size:12px;color:var(--ink-muted);margin-bottom:.3rem}
.bakery-card-rating{font-size:12px;color:var(--accent-dark)}
.bakery-card-spec{display:flex;gap:.3rem;flex-wrap:wrap;margin-top:.4rem}
.bakery-card-spec span{padding:2px 6px;background:var(--primary-soft);border-radius:4px;font-size:10px;color:var(--primary)}

/* FICHE PAGE */
.fiche-hero{background:var(--primary-dark);padding:2rem 1.5rem;color:#fff}
.fiche-hero-inner{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:center}
.fiche-avatar{width:100px;height:100px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;font-size:3rem}
.fiche-info h1{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;margin-bottom:.3rem}
.fiche-info p{color:rgba(255,255,255,0.7);font-size:14px}
.fiche-info .rating{color:var(--accent);font-size:1.1rem;margin-top:.3rem}
.fiche-body{max-width:var(--max-w);margin:0 auto;padding:2rem 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.fiche-detail{background:var(--surface-1);border-radius:12px;padding:1.5rem;border:1px solid var(--hairline-soft)}
.fiche-detail h3{font-family:var(--font-heading);font-size:1.1rem;color:var(--primary);margin-bottom:.75rem}
.fiche-detail p{font-size:14px;color:var(--ink-muted);line-height:1.6}
.fiche-side{display:flex;flex-direction:column;gap:1rem}
.fiche-side-card{background:var(--surface-1);border-radius:12px;padding:1.25rem;border:1px solid var(--hairline-soft)}
.fiche-side-card h3{font-family:var(--font-heading);font-size:1rem;color:var(--primary);margin-bottom:.5rem}
.fiche-side-card .info-row{display:flex;justify-content:space-between;padding:.35rem 0;border-bottom:1px solid var(--hairline-soft);font-size:13px}
.fiche-side-card .info-row:last-child{border-bottom:none}
.fiche-side-card .info-label{color:var(--ink-muted)}
.fiche-side-card .info-value{font-weight:600;color:var(--ink)}

@media(max-width:768px){
  .featured-grid,.cities-grid,.bakery-grid{grid-template-columns:1fr 1fr}
  .main-dual{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .header-inner{flex-wrap:wrap;height:auto;padding:.75rem 1rem}
  .nav{order:3;width:100%;overflow-x:auto}
  .fiche-body{grid-template-columns:1fr}
  .fiche-hero-inner{grid-template-columns:1fr;text-align:center}
  .fiche-avatar{margin:0 auto}
}
