:root{
  --linen:#f7f1e7;
  --linen-2:#efe6d6;
  --terra:#c96f4a;
  --terra-deep:#a8512f;
  --azure:#1f5d7a;
  --olive:#7d7a4e;
  --ink:#2e2620;
  --line:rgba(46,38,32,.14);

  --maxw:1340px;
  --gut:clamp(20px,5vw,80px);

  --f-display:"Fraunces",Georgia,serif;
  --f-body:"Hanken Grotesk",-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--linen);
  background-image:url("assets/paper.png");
  background-size:560px;
  background-repeat:repeat;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  line-height:1.6;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* shared display type ---------------------------------- */
.display{
  font-family:var(--f-display);
  font-optical-sizing:auto;
  font-weight:380;
  font-size:clamp(2.6rem,6.4vw,5.2rem);
  line-height:.96;
  letter-spacing:-.015em;
  color:var(--azure);
}
.display em{font-style:italic;font-weight:340;color:var(--terra)}
.display--light{color:var(--linen)}
.display--light em{color:var(--linen)}
.display--xl{font-size:clamp(3.4rem,11vw,8rem)}

.eyebrow{
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink);
  opacity:.62;
}
.eyebrow--azure{color:var(--azure);opacity:.9}
.eyebrow--linen{color:var(--linen);opacity:.85}

.lede{font-size:clamp(1.12rem,1.6vw,1.4rem);line-height:1.5}

/* tide motif ------------------------------------------- */
.tide{display:block;width:100%;height:18px;color:var(--azure)}
.tide use{
  fill:none;stroke:currentColor;stroke-width:2.4;
  stroke-linecap:round;
  vector-effect:non-scaling-stroke;
}
.rule{
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--gut);
  opacity:.5;
}
.rule .tide{height:24px;color:var(--terra)}

/* buttons ---------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--f-body);font-weight:600;
  font-size:.92rem;letter-spacing:.02em;
  padding:.85em 1.5em;border-radius:999px;
  min-height:46px;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),background .35s,color .35s,box-shadow .35s;
  cursor:pointer;border:1px solid transparent;
}
.btn--terra{background:var(--terra);color:var(--linen);box-shadow:0 8px 22px -12px var(--terra-deep)}
.btn--terra:hover{background:var(--terra-deep);transform:translateY(-2px)}
.btn--ghost{border-color:var(--line);color:var(--ink);background:transparent}
.btn--ghost:hover{border-color:var(--azure);color:var(--azure);transform:translateY(-2px)}

/* nav -------------------------------------------------- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;
  padding:.95rem var(--gut);
  background:color-mix(in srgb,var(--linen) 86%,transparent);
  backdrop-filter:blur(10px) saturate(1.1);
  border-bottom:1px solid var(--line);
}
.nav__brand{
  font-family:var(--f-display);font-weight:480;
  font-size:1.45rem;letter-spacing:.04em;color:var(--azure);
}
.nav__links{display:flex;gap:clamp(.7rem,3vw,2.4rem);font-weight:500;font-size:.92rem;flex-wrap:nowrap}
.nav__cta{display:none}
.nav__links a{position:relative;padding:.2em 0}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-3px;height:6px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='6' viewBox='0 0 40 6'%3E%3Cpath d='M0 3 C5 0,10 0,15 3 S25 6,30 3 S40 0,40 3' fill='none' stroke='%231f5d7a' stroke-width='1.4'/%3E%3C/svg%3E") repeat-x left center;
  opacity:0;transform:translateY(3px);
  transition:opacity .3s,transform .3s;
}
.nav__links a:hover::after{opacity:1;transform:translateY(0)}
.nav__cta{padding:.6em 1.25em;min-height:0}
@media (min-width:600px){.nav__cta{display:inline-flex}}

/* hero ------------------------------------------------- */
.hero{
  position:relative;
  max-width:var(--maxw);margin-inline:auto;
  padding:clamp(2rem,5vw,4.5rem) var(--gut) clamp(3rem,6vw,5rem);
  display:grid;
  grid-template-columns:1fr;
}
.hero__media{
  position:relative;
  border-radius:14px;overflow:hidden;
  box-shadow:0 40px 80px -50px rgba(46,38,32,.55);
  aspect-ratio:16/10;
}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__plate{
  position:relative;z-index:2;
  margin-top:-1.5rem;
  background:transparent;
  max-width:740px;
}
.hero__word{
  font-family:var(--f-display);
  font-optical-sizing:auto;
  font-weight:340;
  font-size:clamp(4.6rem,21vw,17rem);
  line-height:.82;
  letter-spacing:-.02em;
  color:var(--azure);
  margin:.1em 0 0;
  text-shadow:0 2px 0 var(--linen);
}
.tide--hero{height:22px;max-width:min(420px,70%);color:var(--terra);margin:.2rem 0 1.2rem}
.hero__sub{
  font-family:var(--f-display);font-style:italic;font-weight:340;
  font-size:clamp(1.4rem,3.2vw,2.2rem);
  color:var(--terra);margin-bottom:.7rem;
}
.hero__promise{
  font-size:clamp(1.05rem,1.5vw,1.3rem);
  max-width:46ch;color:var(--ink);opacity:.86;
}
.hero__act{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem}
.eyebrow.eyebrow--azure{margin-bottom:.6rem;display:block}
.hero__tag{
  position:absolute;top:clamp(2.6rem,6vw,5rem);right:var(--gut);
  font-family:var(--f-display);font-style:italic;font-weight:340;
  font-size:clamp(1.3rem,3vw,2rem);
  color:var(--linen);
  background:var(--terra);
  padding:.18em .8em;border-radius:999px;
  transform:rotate(-7deg);
  box-shadow:0 12px 26px -16px var(--terra-deep);
  z-index:3;
}

/* story ------------------------------------------------ */
.story{
  max-width:var(--maxw);margin-inline:auto;
  padding:clamp(3.5rem,8vw,7rem) var(--gut);
  display:grid;grid-template-columns:1fr;gap:clamp(1.5rem,4vw,3rem);
}
.story__head h2{margin-top:.6rem}
.story__body{display:flex;flex-direction:column;gap:1.2rem;max-width:62ch}
.story__body p{font-size:1.08rem}
.story em{font-style:italic;color:var(--terra)}

/* carte ------------------------------------------------ */
.carte{
  max-width:var(--maxw);margin-inline:auto;
  padding:clamp(2rem,5vw,4rem) var(--gut) clamp(3rem,6vw,5rem);
}
.carte__intro{max-width:60ch;margin-bottom:clamp(2rem,5vw,3.5rem)}
.carte__intro h2{margin:.5rem 0 .8rem}
.carte__note{opacity:.78;max-width:48ch}
.carte__cols{
  display:grid;grid-template-columns:1fr;gap:clamp(2rem,5vw,4rem);
}
.menu__title{
  font-family:var(--f-display);font-style:italic;font-weight:360;
  font-size:1.8rem;color:var(--terra);
  padding-bottom:.7rem;margin-bottom:.5rem;
  border-bottom:2px solid var(--terra);
}
.menu__list{list-style:none}
.row{
  display:grid;
  grid-template-columns:1fr auto auto;
  align-items:baseline;gap:.6rem;
  padding:.95rem .6rem;
  border-bottom:1px solid var(--line);
  border-radius:8px;
  transition:background .3s,padding-left .3s;
}
.row:hover{background:color-mix(in srgb,var(--terra) 11%,transparent);padding-left:1rem}
.row__name{font-weight:600;font-size:1.04rem;display:flex;flex-direction:column;gap:.15rem}
.row__fr{font-family:var(--f-display);font-style:italic;font-weight:340;font-size:.92rem;color:var(--azure);opacity:.85}
.row__dots{align-self:end;border-bottom:1px dotted var(--line);min-width:14px;height:1px;margin-bottom:.35rem}
.row__price{font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink);white-space:nowrap}

.carte__fig{
  margin-top:clamp(2.5rem,6vw,4.5rem);
  border-radius:14px;overflow:hidden;
  box-shadow:0 36px 70px -48px rgba(46,38,32,.5);
}
.carte__fig img{width:100%;aspect-ratio:16/9;object-fit:cover}
.carte__fig figcaption{
  font-family:var(--f-display);font-style:italic;
  background:var(--linen-2);color:var(--azure);
  padding:.9rem 1.2rem;font-size:1rem;
}

/* la mer ----------------------------------------------- */
.mer{
  max-width:var(--maxw);margin-inline:auto;
  padding:clamp(2rem,5vw,3.5rem) var(--gut);
  display:grid;grid-template-columns:1fr;gap:0;
}
.mer__media{border-radius:14px;overflow:hidden;box-shadow:0 36px 70px -48px rgba(46,38,32,.5)}
.mer__media img{width:100%;height:100%;object-fit:cover}
.mer__block{
  background:var(--terra);color:var(--linen);
  padding:clamp(2rem,5vw,3.4rem);
  border-radius:14px;
  margin-top:-2rem;
  position:relative;z-index:2;
  align-self:start;
}
.mer__block .eyebrow{margin-bottom:.7rem;display:block}
.mer__block h2{margin-bottom:1rem}
.mer__block p{opacity:.94;max-width:42ch}
.mer__small{margin-top:1rem;font-family:var(--f-display);font-style:italic;font-size:1.2rem;opacity:1}

/* craft ------------------------------------------------ */
.craft{
  max-width:var(--maxw);margin-inline:auto;
  padding:clamp(3.5rem,8vw,6.5rem) var(--gut);
}
.craft__eyebrow{display:block;margin-bottom:clamp(1.6rem,4vw,2.6rem)}
.craft__grid{display:grid;grid-template-columns:1fr;gap:clamp(1.6rem,4vw,2.6rem)}
.craft__card{
  padding:clamp(1.6rem,3vw,2.2rem);
  background:color-mix(in srgb,var(--linen-2) 70%,transparent);
  border:1px solid var(--line);
  border-radius:12px;
}
.craft__num{
  font-family:var(--f-display);font-style:italic;
  font-size:1.5rem;color:var(--terra);display:block;margin-bottom:.6rem;
}
.craft__title{
  font-family:var(--f-display);font-weight:420;font-size:1.5rem;
  color:var(--azure);margin-bottom:.6rem;
}
.craft__card p{opacity:.82;font-size:1rem}

/* visite ----------------------------------------------- */
.visite{
  max-width:var(--maxw);margin-inline:auto;
  padding:clamp(2rem,5vw,4rem) var(--gut) clamp(3rem,6vw,5rem);
}
.visite__head{margin-bottom:clamp(2rem,5vw,3.2rem)}
.tide--foot{max-width:min(520px,80%);color:var(--terra);height:26px;margin-top:1rem}
.visite__cols{
  display:grid;grid-template-columns:1fr;gap:clamp(1.4rem,3vw,2rem);
  margin-bottom:clamp(2.4rem,6vw,3.6rem);
}
.vcard{padding:1.4rem 0;border-top:2px solid var(--terra)}
.vcard .eyebrow{display:block;margin-bottom:.7rem}
.vcard__big{font-family:var(--f-display);font-weight:400;font-size:clamp(1.4rem,2.4vw,1.9rem);color:var(--azure);line-height:1.15}
.vcard__sub{opacity:.72;margin-top:.3rem}

.news{
  background:var(--azure);color:var(--linen);
  padding:clamp(1.8rem,4vw,2.6rem);border-radius:14px;
}
.news__label{font-family:var(--f-display);font-style:italic;font-size:clamp(1.1rem,2vw,1.5rem);display:block;margin-bottom:1.1rem}
.news__row{display:flex;flex-wrap:wrap;gap:.7rem}
.news__input{
  flex:1 1 240px;min-width:0;
  background:color-mix(in srgb,var(--linen) 14%,transparent);
  border:1px solid color-mix(in srgb,var(--linen) 38%,transparent);
  color:var(--linen);
  padding:.85em 1.1em;border-radius:999px;font-family:var(--f-body);font-size:1rem;
  min-height:46px;
}
.news__input::placeholder{color:color-mix(in srgb,var(--linen) 65%,transparent)}
.news__input:focus{outline:none;border-color:var(--linen)}

/* footer ----------------------------------------------- */
.foot{
  border-top:1px solid var(--line);
  max-width:var(--maxw);margin-inline:auto;
  padding:clamp(2.2rem,5vw,3.2rem) var(--gut) clamp(3rem,6vw,4rem);
  display:flex;flex-direction:column;gap:.5rem;
}
.foot__mark{font-family:var(--f-display);font-weight:460;font-size:2rem;letter-spacing:.05em;color:var(--azure)}
.foot__line{font-family:var(--f-display);font-style:italic;color:var(--terra);font-size:1.15rem}
.foot__copy{opacity:.6;font-size:.88rem;margin-top:.4rem}

/* reveal animation ------------------------------------- */
.reveal,.reveal-up{opacity:0}
.reveal{transform:translateY(14px)}
.reveal-up{transform:translateY(26px)}
.is-in.reveal,.is-in.reveal-up{
  opacity:1;transform:none;
  transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1);
}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.18s}
.reveal[data-d="3"]{transition-delay:.30s}
.reveal[data-d="4"]{transition-delay:.42s}
.reveal[data-d="5"]{transition-delay:.54s}
.reveal[data-d="6"]{transition-delay:.66s}
.reveal-up[data-d="1"]{transition-delay:.12s}
.reveal-up[data-d="2"]{transition-delay:.24s}

/* tide draw-in */
.tide--hero use{stroke-dasharray:1400;stroke-dashoffset:1400}
.is-in .tide--hero use,.tide--hero.is-drawn use{
  stroke-dashoffset:0;
  transition:stroke-dashoffset 1.6s ease .5s;
}

/* ---- desktop / 13" ---- */
@media (min-width:860px){
  .hero{grid-template-rows:auto}
  .hero__media{aspect-ratio:16/9;width:78%;margin-left:auto}
  .hero__plate{margin-top:-9rem;margin-left:0}
  .hero__word{margin-top:0}

  .story{grid-template-columns:.85fr 1.15fr;align-items:start}
  .story__head{position:sticky;top:7rem}

  .carte__cols{grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem)}

  .mer{grid-template-columns:1.25fr .9fr;align-items:center;gap:0}
  .mer__media{grid-column:1;grid-row:1}
  .mer__block{grid-column:2;grid-row:1;margin-top:0;margin-left:-5rem}

  .craft__grid{grid-template-columns:repeat(3,1fr)}

  .visite__cols{grid-template-columns:repeat(3,1fr);gap:clamp(2rem,4vw,3.5rem)}
}

/* ---- large / 4K guard ---- */
@media (min-width:2000px){
  :root{--gut:clamp(80px,8vw,220px)}
  body{background-size:680px}
  .hero__word{font-size:15rem}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal,.reveal-up{opacity:1;transform:none;transition:none}
  .tide--hero use{stroke-dashoffset:0}
  .btn,.row,.nav__links a::after{transition:none}
}
