/* ===== Maison Beurre — premium café landing ===== */
:root {
  --bg:#fbf9f4; --bg-alt:#eef0e6; --dark:#23271f; --text:#4b4a42; --muted:#8c8a7e; --accent:#5f7350; --accent-soft:#8a9b73; --white:#fff;
  --shadow-sm:0 6px 20px rgba(35,39,31,.06);
  --shadow-md:0 18px 50px rgba(35,39,31,.10);
  --shadow-lg:0 30px 80px rgba(35,39,31,.18);
  --radius:18px; --radius-lg:28px; --max:1180px;
  --serif:'Fraunces',Georgia,serif; --sans:'Inter',system-ui,sans-serif;
}

* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:var(--sans);
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
h1,h2,h3,h4 { font-family:var(--serif); color:var(--dark); line-height:1.08; font-weight:600; }

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

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* ===== Buttons ===== */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--sans); font-weight:600; font-size:.95rem;
  padding:14px 26px; border-radius:999px; border:1.5px solid transparent;
  cursor:pointer; transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
}
.btn--primary { background:var(--accent); color:var(--white); box-shadow:var(--shadow-sm); }
.btn--primary:hover { background:var(--dark); transform:translateY(-3px); box-shadow:var(--shadow-md); }
.btn--ghost { background:transparent; color:var(--dark); border-color:rgba(35,39,31,.18); }
.btn--ghost:hover { border-color:var(--accent); color:var(--accent); transform:translateY(-3px); }
.btn--block { width:100%; }

/* ===== Eyebrow & section heads ===== */
.eyebrow {
  display:inline-block; font-size:.78rem; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--accent); margin-bottom:18px;
}
.eyebrow--light { color:var(--accent-soft); }
.accent { color:var(--accent); font-style:italic; }

.section { padding:110px 0; }
.section--alt { background:var(--bg-alt); }
.section__head { max-width:640px; margin:0 auto 60px; text-align:center; }
.section__title { font-size:clamp(2rem, 4vw, 3rem); margin-bottom:18px; }
.section__title--light { color:var(--white); }
.section__lead { font-size:1.1rem; color:var(--muted); }
.section__lead--light { color:rgba(255,255,255,.7); }

/* ===== Nav ===== */
.nav {
  position:sticky; top:0; z-index:50;
  padding:20px 0; transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
}
.nav.scrolled {
  background:rgba(251,249,244,.9); backdrop-filter:blur(12px);
  box-shadow:var(--shadow-sm); padding:12px 0;
}
.nav__inner { display:flex; align-items:center; justify-content:space-between; gap:24px; }
.nav__brand { font-family:var(--serif); font-weight:700; font-size:1.4rem; color:var(--dark); }
.nav__links { display:flex; gap:34px; }
.nav__links a { font-weight:500; color:var(--text); transition:color .2s ease; }
.nav__links a:hover { color:var(--accent); }
.nav__cta { padding:11px 22px; }

/* ===== Hero ===== */
.hero { padding:70px 0 100px; }
.hero__grid {
  display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;
}
.hero__title { font-size:clamp(2.6rem, 5.2vw, 4.4rem); margin-bottom:24px; }
.hero__lead { font-size:1.18rem; color:var(--text); max-width:480px; margin-bottom:34px; }
.hero__actions { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:46px; }
.hero__stats { display:flex; gap:40px; flex-wrap:wrap; }
.stat__num { display:block; font-family:var(--serif); font-size:1.6rem; font-weight:600; color:var(--dark); }
.stat__label { font-size:.85rem; color:var(--muted); }

.hero__media { position:relative; }
.hero__imgwrap { border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); }
.hero__imgwrap img { width:100%; height:560px; object-fit:cover; transition:transform .8s ease; }
.hero__media:hover .hero__imgwrap img { transform:scale(1.05); }
.hero__card {
  position:absolute; left:-26px; bottom:42px;
  background:var(--white); border-radius:var(--radius); padding:18px 22px;
  box-shadow:var(--shadow-md); display:flex; flex-direction:column; gap:2px;
}
.hero__stars { color:#e3a83a; letter-spacing:2px; font-size:.95rem; }
.hero__card strong { color:var(--dark); font-size:1rem; }
.hero__card-sub { font-size:.82rem; color:var(--muted); }

/* ===== Menu cards ===== */
.cards { display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.card {
  background:var(--white); border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-sm); transition:transform .3s ease, box-shadow .3s ease;
  display:flex; flex-direction:column;
}
.card:hover { transform:translateY(-8px); box-shadow:var(--shadow-md); }
.card__media { overflow:hidden; }
.card__media img { width:100%; height:200px; object-fit:cover; transition:transform .7s ease; }
.card:hover .card__media img { transform:scale(1.08); }
.card__body { padding:22px 22px 26px; display:flex; flex-direction:column; flex:1; }
.tag {
  align-self:flex-start; font-size:.72rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--accent); background:var(--bg-alt); padding:5px 12px; border-radius:999px; margin-bottom:14px;
}
.card__name { font-size:1.25rem; margin-bottom:8px; }
.card__desc { font-size:.92rem; color:var(--muted); margin-bottom:18px; flex:1; }
.card__price { font-family:var(--serif); font-weight:600; font-size:1.2rem; color:var(--dark); }

/* ===== Story ===== */
.story { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.story__media { position:relative; padding-bottom:40px; }
.story__img { border-radius:var(--radius-lg); box-shadow:var(--shadow-md); object-fit:cover; }
.story__img--big { width:100%; height:480px; }
.story__img--small {
  position:absolute; right:-24px; bottom:-12px; width:200px; height:240px;
  border:6px solid var(--bg-alt);
}
.story__list { list-style:none; margin:26px 0 32px; display:flex; flex-direction:column; gap:16px; }
.story__list li { position:relative; padding-left:30px; color:var(--muted); }
.story__list li::before {
  content:'✓'; position:absolute; left:0; top:0;
  color:var(--accent); font-weight:700;
}
.story__list strong { color:var(--dark); }

/* ===== Features ===== */
.features { display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.feature {
  background:var(--white); border-radius:var(--radius-lg); padding:34px 28px;
  box-shadow:var(--shadow-sm); transition:transform .3s ease, box-shadow .3s ease;
}
.feature:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.feature__icon {
  width:58px; height:58px; border-radius:16px; background:var(--bg-alt);
  display:flex; align-items:center; justify-content:center; font-size:1.6rem; margin-bottom:20px;
}
.feature__title { font-size:1.2rem; margin-bottom:10px; }
.feature p { font-size:.92rem; color:var(--muted); }

/* ===== Menu preview (dark) ===== */
.menu-preview { background:var(--dark); }
.pricelist {
  display:grid; grid-template-columns:1fr 1fr; gap:24px 70px;
  max-width:860px; margin:0 auto;
}
.pricelist__col { list-style:none; display:flex; flex-direction:column; gap:18px; }
.pricelist__col li {
  display:flex; align-items:baseline; gap:12px;
  color:rgba(255,255,255,.85); font-size:1.02rem;
}
.pricelist__col li span:first-child { color:var(--white); font-weight:500; }
.pricelist__col li span:last-child { font-family:var(--serif); color:var(--accent-soft); font-weight:600; }
.dots { flex:1; border-bottom:1px dotted rgba(255,255,255,.25); transform:translateY(-4px); }
.menu-preview__cta { text-align:center; margin-top:52px; }

/* ===== Reviews ===== */
.reviews { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.review {
  background:var(--white); border-radius:var(--radius-lg); padding:32px 28px;
  box-shadow:var(--shadow-sm); transition:transform .3s ease, box-shadow .3s ease;
}
.review:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.review__stars { color:#e3a83a; letter-spacing:2px; margin-bottom:16px; }
.review blockquote { font-size:1.05rem; color:var(--text); margin-bottom:24px; }
.review__author { display:flex; align-items:center; gap:14px; }
.review__author img { width:50px; height:50px; border-radius:50%; object-fit:cover; }
.review__author strong { display:block; color:var(--dark); }
.review__author span { font-size:.85rem; color:var(--muted); }

/* ===== Visit / form ===== */
.visit { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.visit__details { list-style:none; margin-top:30px; display:flex; flex-direction:column; gap:20px; }
.visit__details li { display:flex; flex-direction:column; }
.visit__details strong { font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin-bottom:4px; }
.visit__details span { color:var(--text); font-size:1.05rem; }

.visit__form {
  background:var(--white); border-radius:var(--radius-lg); padding:36px;
  box-shadow:var(--shadow-md); display:flex; flex-direction:column; gap:18px;
}
.field { display:flex; flex-direction:column; gap:7px; }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field label { font-size:.85rem; font-weight:600; color:var(--dark); }
.field input, .field select {
  font-family:var(--sans); font-size:.95rem; color:var(--text);
  padding:13px 15px; border:1.5px solid rgba(35,39,31,.14); border-radius:14px;
  background:var(--bg); transition:border-color .2s ease, box-shadow .2s ease;
}
.field input:focus, .field select:focus {
  outline:none; border-color:var(--accent); box-shadow:0 0 0 4px rgba(95,115,80,.12);
}
.form-note { font-size:.85rem; color:var(--muted); text-align:center; margin-top:4px; }
.form-note.success { color:var(--accent); font-weight:600; }

/* ===== Footer ===== */
.footer { background:var(--dark); color:rgba(255,255,255,.72); padding:72px 0 28px; }
.footer__grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.footer__brand .nav__brand { color:var(--white); }
.footer__brand p { margin:14px 0 20px; max-width:300px; }
.footer__social { display:flex; gap:18px; }
.footer__social a { font-size:.9rem; transition:color .2s ease; }
.footer__social a:hover { color:var(--accent-soft); }
.footer__col h4 { color:var(--white); font-size:1rem; margin-bottom:16px; }
.footer__col a { display:block; font-size:.92rem; margin-bottom:10px; transition:color .2s ease; }
.footer__col a:hover { color:var(--accent-soft); }
.footer__bar {
  display:flex; justify-content:space-between; align-items:center;
  margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.12);
  font-size:.85rem;
}

/* ===== Responsive ===== */
@media (max-width:980px) {
  .section { padding:80px 0; }
  .nav__links { display:none; }
  .hero__grid { grid-template-columns:1fr; gap:48px; }
  .hero__lead { max-width:none; }
  .hero__imgwrap img { height:440px; }
  .cards { grid-template-columns:repeat(2,1fr); }
  .features { grid-template-columns:repeat(2,1fr); }
  .reviews { grid-template-columns:1fr; }
  .story { grid-template-columns:1fr; gap:48px; }
  .story__media { max-width:520px; }
  .visit { grid-template-columns:1fr; gap:40px; }
  .footer__grid { grid-template-columns:1fr 1fr; gap:32px; }
}

@media (max-width:600px) {
  .container { padding:0 18px; }
  .section { padding:64px 0; }
  .hero { padding:40px 0 70px; }
  .hero__title { font-size:2.4rem; }
  .hero__stats { gap:24px; }
  .hero__card { left:0; bottom:16px; padding:14px 18px; }
  .hero__imgwrap img { height:360px; }
  .hero__actions { flex-direction:column; }
  .hero__actions .btn { width:100%; }
  .cards { grid-template-columns:1fr; }
  .features { grid-template-columns:1fr; }
  .pricelist { grid-template-columns:1fr; gap:16px; }
  .story__img--small { display:none; }
  .field-row { grid-template-columns:1fr; }
  .visit__form { padding:26px; }
  .footer__grid { grid-template-columns:1fr; }
  .footer__bar { flex-direction:column; gap:8px; text-align:center; }
}
