/* ============================================================
   Boulangerie Quartier — warm artisan theme
   ============================================================ */
:root{
  --brown-900:#4a2509;
  --brown-800:#78350F;
  --brown-700:#92400E;
  --brown-600:#B45309;
  --honey:#C8862C;
  --honey-soft:#E7A94B;
  --cream:#FEF7EA;
  --cream-200:#FBEFD8;
  --cream-300:#F6E4C4;
  --border:#EAD7B4;
  --ink:#3a2410;
  --muted:#7a6650;
  --white:#ffffff;
  --shadow-sm:0 2px 10px rgba(74,37,9,.06);
  --shadow-md:0 14px 40px rgba(74,37,9,.12);
  --radius:18px;
  --radius-lg:26px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --header-h:72px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 12px);-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:"Cabin",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img,picture,iframe{display:block;max-width:100%}
a{color:var(--brown-700);text-decoration:none}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;line-height:1.1;color:var(--brown-900);margin:0 0 .4em;font-weight:600}
p{margin:0 0 1em}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(18px,5vw,40px)}

.skip-link{position:absolute;left:-999px;top:0;background:var(--brown-700);color:#fff;padding:10px 16px;border-radius:0 0 10px 0;z-index:200}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--honey);outline-offset:2px;border-radius:6px}

/* ---------- Buttons ---------- */
.btn{
  --b:var(--brown-700);
  display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  font-family:"Cabin",sans-serif;font-weight:700;font-size:1rem;
  padding:.85em 1.5em;border-radius:999px;cursor:pointer;border:2px solid transparent;
  transition:transform .2s var(--ease),background .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease);
  line-height:1;text-align:center;
}
.btn svg{flex:none}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--brown-700);color:#fff;box-shadow:0 8px 22px rgba(146,64,14,.28)}
.btn-primary:hover{background:var(--brown-800)}
.btn-ghost{background:transparent;color:var(--brown-800);border-color:var(--border)}
.btn-ghost:hover{background:var(--cream-200);border-color:var(--honey)}
.btn-wa{background:#1f9d57;color:#fff}
.btn-wa:hover{background:#178347}
.btn-block{width:100%}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(254,247,234,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;transition:box-shadow .3s,border-color .3s,background .3s;
}
.site-header.scrolled{box-shadow:var(--shadow-sm);border-color:var(--border);background:rgba(254,247,234,.94)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:var(--header-h)}
.brand{display:flex;align-items:center;gap:.6em;font-family:"Fraunces",serif;font-weight:600;font-size:1.3rem;color:var(--brown-900)}
.brand em{font-style:italic;color:var(--brown-600)}
.brand-logo{border-radius:10px}
.nav-links{display:none;align-items:center;gap:clamp(14px,2vw,28px)}
.nav-links a{font-weight:600;color:var(--brown-800);position:relative;padding:.3em 0}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--honey);transition:width .25s var(--ease)}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:var(--brown-700);color:#fff !important;padding:.55em 1.1em !important;border-radius:999px}
.nav-cta:hover{background:var(--brown-800)}

.nav-toggle{display:flex;flex-direction:column;gap:5px;width:46px;height:46px;align-items:center;justify-content:center;background:none;border:0;cursor:pointer;border-radius:12px}
.nav-toggle span{width:24px;height:2.5px;background:var(--brown-800);border-radius:2px;transition:transform .25s var(--ease),opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.mobile-menu{display:flex;flex-direction:column;padding:8px clamp(18px,5vw,40px) 22px;gap:2px;background:var(--cream);border-bottom:1px solid var(--border)}
.mobile-menu[hidden]{display:none}
.mobile-menu a{padding:.85em .2em;font-weight:600;color:var(--brown-800);border-bottom:1px solid var(--cream-300)}
.mobile-menu .mobile-cta{margin-top:12px;background:var(--brown-700);color:#fff;text-align:center;border-radius:999px;border:0;padding:.9em}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:min(92vh,820px);display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg,.hero-bg img{position:absolute;inset:0;width:100%;height:100%}
.hero-bg img{object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(58,29,7,.82) 0%,rgba(74,37,9,.55) 45%,rgba(74,37,9,.25) 100%)}
.hero-inner{position:relative;z-index:2;padding-block:80px;max-width:680px}
.hero-kicker{text-transform:uppercase;letter-spacing:.22em;font-weight:700;font-size:.8rem;color:var(--honey-soft);margin-bottom:.8em}
.hero-title{font-size:clamp(2.7rem,7vw,4.7rem);color:#fff;font-weight:700;margin-bottom:.3em;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero-lead{font-size:clamp(1.05rem,2.4vw,1.3rem);color:#fdeccf;max-width:34ch;margin-bottom:1.8em}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.hero-actions .btn-ghost{color:#fff;border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.06)}
.hero-actions .btn-ghost:hover{background:rgba(255,255,255,.16);border-color:#fff}
.hero-scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;color:#fff;opacity:.85;animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- Sections ---------- */
.section{padding-block:clamp(60px,9vw,110px)}
.section-head{max-width:640px;margin:0 auto clamp(36px,6vw,60px);text-align:center}
.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-weight:700;font-size:.8rem;color:var(--brown-600);margin-bottom:.7em}
h2{font-size:clamp(1.9rem,4.4vw,2.9rem)}
.section-sub{color:var(--muted);font-size:1.08rem}
.note{color:var(--honey);font-style:italic;font-size:.85em;font-weight:600}

/* commitments */
.commitments{background:linear-gradient(180deg,var(--cream) 0%,var(--cream-200) 100%)}
.cards-3{display:grid;gap:24px;grid-template-columns:1fr}
.value-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:38px 30px;text-align:center;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.value-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.value-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:var(--cream-200);color:var(--brown-700);margin-bottom:18px}
.value-card h3{font-size:1.4rem}
.value-card p{color:var(--muted);margin:0}

/* products */
.product-grid{display:grid;gap:24px;grid-template-columns:1fr}
.product-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);display:flex;flex-direction:column}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.product-card.feature picture{display:block;overflow:hidden;aspect-ratio:3/2}
.product-card.feature img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.product-card.feature:hover img{transform:scale(1.05)}
.product-body{padding:24px 26px}
.product-body h3{font-size:1.4rem;margin-bottom:.35em}
.product-body p{color:var(--muted);margin:0}
.text-card{background:linear-gradient(160deg,var(--cream-200),var(--white));justify-content:center}
.text-card .product-body{padding:34px 30px}
.mini-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;background:var(--brown-700);color:#fff;margin-bottom:14px}

/* menu / carte */
.menu{background:linear-gradient(180deg,var(--cream-200),var(--cream))}
.menu-grid{display:grid;gap:24px;grid-template-columns:1fr}
.menu-cat{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:30px 30px 26px;box-shadow:var(--shadow-sm)}
.menu-cat h3{font-size:1.4rem;color:var(--brown-700);margin-bottom:.7em;padding-bottom:.45em;border-bottom:2px solid var(--cream-300)}
.menu-cat ul{list-style:none;margin:0;padding:0}
.menu-cat li{display:flex;align-items:baseline;gap:.4em;padding:.42em 0;font-size:1.02rem}
.menu-cat li+li{border-top:1px dotted var(--cream-300)}
.m-name{color:var(--ink)}
.m-dots{flex:1 1 auto;border-bottom:2px dotted var(--border);transform:translateY(-3px);min-width:14px}
.m-price{color:var(--brown-700);font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}
.menu-foot{text-align:center;margin:clamp(28px,5vw,44px) 0 0;font-size:1.08rem;color:var(--muted)}
.menu-foot a{font-weight:700}

/* reviews */
.reviews{background:linear-gradient(180deg,var(--cream),var(--cream-200))}
.reviews-grid{display:grid;gap:24px;grid-template-columns:1fr}
.review-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 30px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px;margin:0}
.stars{display:flex;gap:3px;color:var(--honey-soft)}
.stars svg{fill:currentColor}
.review-card blockquote{margin:0;font-family:"Fraunces",serif;font-size:1.18rem;line-height:1.5;color:var(--brown-900);font-style:italic}
.review-card figcaption{display:flex;flex-direction:column;margin-top:auto}
.r-name{font-weight:700;color:var(--ink)}
.r-meta{font-size:.9rem;color:var(--muted)}

/* story */
.story{background:var(--brown-900);color:#f6e9d6}
.story h2{color:#fff}
.story .eyebrow{color:var(--honey-soft)}
.story-grid{display:grid;gap:clamp(30px,5vw,64px);grid-template-columns:1fr;align-items:center}
.story-media picture{display:block;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.story-media img{width:100%;height:100%;object-fit:cover}
.story-text p{color:#e9d6bd}
.story-text strong{color:#fff}
.story-points{list-style:none;padding:0;margin:1.4em 0 0;display:grid;gap:12px}
.story-points li{display:flex;align-items:center;gap:.7em;font-weight:600;color:#fbe8d0}
.story-points span{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--honey);color:var(--brown-900);font-size:.8rem;flex:none}

/* gallery */
.gallery-grid{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}
.gallery-grid figure{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:4/3}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery-grid figure:hover img{transform:scale(1.06)}
.gallery-grid figure:first-child{grid-column:1 / -1;aspect-ratio:16/7}

/* info / hours / map */
.info{background:linear-gradient(180deg,var(--cream-200),var(--cream))}
.info-grid{display:grid;gap:clamp(30px,5vw,56px);grid-template-columns:1fr}
.hours-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px 28px;box-shadow:var(--shadow-sm);margin-bottom:24px}
.hours-card h3{font-size:1.25rem;margin-bottom:.6em}
.hours-table{width:100%;border-collapse:collapse;font-size:1.02rem}
.hours-table th{text-align:left;font-weight:600;color:var(--ink);padding:.5em 0}
.hours-table td{text-align:right;color:var(--brown-700);font-weight:600;font-variant-numeric:tabular-nums;padding:.5em 0}
.hours-table tr+tr{border-top:1px solid var(--cream-300)}
.hours-table .closed{color:var(--muted)}
.contact-list{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:14px}
.contact-list li{display:flex;align-items:flex-start;gap:.8em;color:var(--ink)}
.contact-list a{font-weight:700}
.ci{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:11px;background:var(--cream-200);color:var(--brown-700);flex:none}
.info-actions{display:flex;flex-wrap:wrap;gap:12px}
.map-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border);min-height:340px;height:100%}
.map-frame iframe{width:100%;height:100%;min-height:340px;border:0}

/* contact form */
.contact{background:var(--cream)}
.contact-form{max-width:680px;margin-inline:auto;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:clamp(24px,4vw,42px);box-shadow:var(--shadow-sm)}
.field-row{display:grid;gap:18px;grid-template-columns:1fr}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;margin-bottom:.45em;color:var(--brown-800)}
.req{color:var(--brown-600)}
.field input,.field textarea{
  width:100%;font:inherit;color:var(--ink);background:var(--cream);
  border:1.5px solid var(--border);border-radius:12px;padding:.8em .95em;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--honey);box-shadow:0 0 0 3px rgba(200,134,44,.18);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.field-error{display:block;min-height:1.1em;color:#c0392b;font-weight:600;font-size:.85rem;margin-top:.35em}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:#c0392b}
.form-hint{margin:14px 0 0;text-align:center;font-weight:600;min-height:1.2em}
.form-hint.ok{color:#1f9d57}
.form-hint.err{color:#c0392b}

/* footer */
.site-footer{background:var(--brown-900);color:#e9d6bd;padding-block:46px 26px}
.footer-inner{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:center;padding-bottom:26px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand{display:flex;align-items:center;gap:.8em}
.footer-name{font-family:"Fraunces",serif;font-size:1.25rem;color:#fff;margin:0}
.footer-tag{margin:0;color:#caa97f;font-size:.92rem}
.footer-nav{display:flex;flex-wrap:wrap;gap:18px}
.footer-nav a{color:#e9d6bd;font-weight:600}
.footer-nav a:hover{color:#fff}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px;padding-top:20px;font-size:.85rem;color:#b89a72}
.footer-bottom a{color:var(--honey-soft)}
.footer-bottom p{margin:0}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (min-width:600px){
  .field-row{grid-template-columns:1fr 1fr}
  .cards-3{grid-template-columns:repeat(3,1fr)}
  .menu-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:760px){
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(4,1fr)}
  .gallery-grid figure:first-child{grid-column:span 2;aspect-ratio:1/1}
}
@media (min-width:960px){
  .nav-links{display:flex}
  .nav-toggle{display:none}
  .mobile-menu{display:none !important}
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .menu-grid{grid-template-columns:repeat(3,1fr)}
  .reviews-grid{grid-template-columns:repeat(3,1fr)}
  .story-grid{grid-template-columns:1.05fr 1fr}
  .info-grid{grid-template-columns:1fr 1.1fr}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .reveal{opacity:1;transform:none}
  .hero-scroll{animation:none}
}
