/* =========================================================
   Maydeli — Ristorante a San Cesareo
   Redesign gourmet · palette calda terrosa (crema, terracotta, salvia)
   ========================================================= */

:root{
  --cream:      #F7F1E7;
  --cream-2:    #FCF8F1;
  --paper:      #FFFFFF;
  --ink:        #2A2521;
  --ink-soft:   #5C544B;
  --terra:      #BC4B2A;
  --terra-dark: #9C3C20;
  --sage:       #6E7A5E;
  --sage-dark:  #485139;
  --espresso:   #211D19;
  --gold:       #C29A4E;
  --line:       rgba(42,37,33,.12);
  --shadow:     0 18px 50px -24px rgba(33,29,25,.45);
  --radius:     14px;
  --maxw:       1180px;
  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-body:    "Jost", system-ui, -apple-system, "Segoe UI", sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.12;color:var(--ink)}
h1{font-size:clamp(2.6rem,6vw,5rem)}
h2{font-size:clamp(2rem,4.2vw,3.4rem)}
h3{font-size:clamp(1.4rem,2.4vw,1.9rem)}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:clamp(64px,9vw,120px) 0}

/* Eyebrow / small label */
.eyebrow{
  font-family:var(--font-body);
  font-weight:500;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-size:.72rem;
  color:var(--terra);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--terra);display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--terra);display:inline-block}

.lead{font-size:1.12rem;color:var(--ink-soft);max-width:60ch}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-body);font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;font-size:.78rem;
  padding:15px 30px;border-radius:50px;border:1.5px solid transparent;
  cursor:pointer;transition:.28s ease;white-space:nowrap;
}
.btn-primary{background:var(--terra);color:#fff}
.btn-primary:hover{background:var(--terra-dark);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn-dark{background:var(--espresso);color:var(--cream)}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-outline{border-color:var(--ink);color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream)}

/* ---------- Header ---------- */
.header{
  position:fixed;top:0;left:0;width:100%;z-index:100;
  padding:22px 0;transition:.35s ease;
}
.header.scrolled{
  background:rgba(33,29,25,.97);
  padding:13px 0;
  box-shadow:0 10px 30px -18px rgba(0,0,0,.6);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav__logo img{height:46px;width:auto;transition:.35s ease}
.header.scrolled .nav__logo img{height:38px}
.nav__menu{display:flex;align-items:center;gap:34px;list-style:none}
.nav__menu a{
  color:#fff;font-weight:400;font-size:.92rem;letter-spacing:.06em;
  position:relative;padding:4px 0;
}
.nav__menu a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;
  background:var(--terra);transition:.3s ease;
}
.nav__menu a:hover::after,.nav__menu a.active::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:14px}
.nav__shop{color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;opacity:.9}
.nav__shop:hover{color:var(--terra)}
.nav__toggle{display:none;background:none;border:0;color:#fff;font-size:1.7rem;cursor:pointer;line-height:1}

/* mobile drawer */
@media (max-width:900px){
  .nav__toggle{display:block}
  .nav__menu{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);height:100vh;
    flex-direction:column;align-items:flex-start;justify-content:center;gap:26px;
    background:var(--espresso);padding:40px;transform:translateX(100%);
    transition:.4s ease;display:flex;
  }
  .nav__menu.open{transform:translateX(0)}
  .nav__menu a{font-size:1.2rem;color:#fff}
  .nav__shop{display:none}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;
  color:#fff;text-align:center;
  background:linear-gradient(180deg,rgba(20,17,14,.55),rgba(20,17,14,.78)),
             var(--hero-img,#211d19) center/cover no-repeat;
}
.hero__inner{max-width:880px;margin:0 auto;padding:120px 24px 80px}
.hero h1{color:#fff;margin:18px 0 24px;text-shadow:0 4px 30px rgba(0,0,0,.4)}
.hero .lead{color:rgba(255,255,255,.92);margin:0 auto 38px;font-size:1.18rem}
.hero__cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero__scroll{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.7);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.hero__scroll span{width:1px;height:42px;background:rgba(255,255,255,.5);animation:scroll 1.8s ease-in-out infinite}
@keyframes scroll{0%,100%{opacity:.25;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- About / intro ---------- */
.intro__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(36px,6vw,84px);align-items:center}
.intro__media{position:relative}
.intro__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;aspect-ratio:1/1;object-fit:cover}
.intro__media::after{
  content:"";position:absolute;inset:18px -18px -18px 18px;border:1.5px solid var(--gold);
  border-radius:var(--radius);z-index:-1;
}
.intro h2{margin:16px 0 22px}
.intro p+p{margin-top:16px}

/* ---------- Services ---------- */
.services{background:var(--cream-2)}
.services__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:48px}
.services__grid--3{grid-template-columns:repeat(3,1fr)}
.card{
  background:var(--paper);border-radius:var(--radius);padding:44px 38px;
  border:1px solid var(--line);text-align:center;transition:.3s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card__icon{
  width:74px;height:74px;border-radius:50%;display:grid;place-items:center;margin:0 auto 22px;
  background:rgba(188,75,42,.1);color:var(--terra);font-size:1.9rem;
}
.card h3{margin-bottom:10px}
.card p{color:var(--ink-soft)}

/* ---------- Menu ---------- */
.menu{background:var(--espresso);color:var(--cream)}
.menu h2,.menu h3,.menu h4{color:var(--cream)}
.menu .eyebrow{color:var(--gold)}
.menu .eyebrow::before,.menu .eyebrow::after{background:var(--gold)}
.menu__head{text-align:center;max-width:680px;margin:0 auto 50px}
.menu__head p{color:rgba(247,241,231,.7);margin-top:14px}

.tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:54px}
.tab{
  font-family:var(--font-body);font-weight:400;letter-spacing:.08em;
  font-size:.86rem;color:rgba(247,241,231,.7);
  background:transparent;border:1px solid rgba(247,241,231,.22);
  padding:11px 22px;border-radius:50px;cursor:pointer;transition:.25s ease;text-transform:uppercase;
}
.tab:hover{color:var(--cream);border-color:var(--gold)}
.tab.active{background:var(--terra);border-color:var(--terra);color:#fff}

.panel{display:none;animation:fade .5s ease}
.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.menu__group-title{
  font-family:var(--font-body);text-transform:uppercase;letter-spacing:.26em;
  font-size:.78rem;color:var(--gold);text-align:center;margin:46px 0 26px;
  display:flex;align-items:center;justify-content:center;gap:18px;font-weight:500;
}
.menu__group-title::before,.menu__group-title::after{content:"";height:1px;width:60px;background:rgba(194,154,78,.4)}

.menu__list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 56px;max-width:1000px;margin:0 auto}
.menu__item{padding:16px 0;border-bottom:1px dashed rgba(247,241,231,.16)}
.menu__item-head{display:flex;align-items:baseline;gap:12px}
.menu__item-name{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--cream)}
.menu__dots{flex:1;border-bottom:1px dotted rgba(247,241,231,.3);transform:translateY(-4px)}
.menu__price{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--gold);white-space:nowrap}
.menu__desc{color:rgba(247,241,231,.66);font-size:.94rem;margin-top:6px;max-width:52ch}
.menu__allergens{display:block;margin-top:6px;font-size:.76rem;letter-spacing:.04em;color:rgba(247,241,231,.42);font-style:italic}
.menu__note{text-align:center;color:rgba(247,241,231,.6);font-size:.9rem;margin-top:40px;font-style:italic}

@media (max-width:760px){
  .menu__list{grid-template-columns:1fr;gap:0}
}

/* ---------- CTA band ---------- */
.cta{
  position:relative;color:#fff;text-align:center;
  background:linear-gradient(rgba(20,17,14,.7),rgba(20,17,14,.78)),var(--cta-img,var(--sage-dark)) center/cover fixed no-repeat;
}
.cta h2{color:#fff;margin:16px 0 26px}
.cta .container{padding-top:clamp(70px,10vw,130px);padding-bottom:clamp(70px,10vw,130px)}

/* ---------- Footer ---------- */
.footer{background:var(--espresso);color:rgba(247,241,231,.75);padding:72px 0 28px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(247,241,231,.12)}
.footer__logo{height:50px;margin-bottom:20px}
.footer h4{color:var(--cream);font-family:var(--font-body);font-weight:500;letter-spacing:.18em;text-transform:uppercase;font-size:.82rem;margin-bottom:20px}
.footer a:hover{color:var(--terra)}
.footer__contact li{list-style:none;margin-bottom:12px;display:flex;gap:12px;align-items:flex-start}
.footer__contact i{color:var(--terra);margin-top:4px}
.footer__social{display:flex;gap:12px;margin-top:8px}
.footer__social a{
  width:42px;height:42px;border-radius:50%;border:1px solid rgba(247,241,231,.2);
  display:grid;place-items:center;transition:.25s ease;
}
.footer__social a:hover{background:var(--terra);border-color:var(--terra);color:#fff}
.footer__bottom{padding-top:24px;text-align:center;font-size:.84rem;color:rgba(247,241,231,.5)}

/* ---------- Page header (contatti) ---------- */
.page-hero{
  position:relative;color:#fff;text-align:center;
  background:linear-gradient(rgba(20,17,14,.6),rgba(20,17,14,.78)),var(--page-img,var(--sage-dark)) center/cover no-repeat;
  padding:180px 0 90px;
}
.page-hero h1{color:#fff;margin-bottom:10px}
.breadcrumb{font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.75)}
.breadcrumb a:hover{color:var(--terra)}

/* ---------- Contatti ---------- */
.contact__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:64px}
.contact__card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:40px 30px;text-align:center;transition:.3s ease;
}
.contact__card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.contact__card .card__icon{margin-bottom:18px}
.contact__card h3{margin-bottom:8px}
.contact__card p,.contact__card a{color:var(--ink-soft)}
.contact__card a:hover{color:var(--terra)}

.contact__main{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.form{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius);padding:40px}
.form h3{margin-bottom:6px}
.form p.sub{color:var(--ink-soft);margin-bottom:26px}
.form label{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;margin-bottom:8px;color:var(--ink)}
.form .field{margin-bottom:20px}
.form input,.form textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:10px;
  font-family:var(--font-body);font-size:1rem;background:#fff;color:var(--ink);transition:.2s;
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(188,75,42,.12)}
.form textarea{min-height:130px;resize:vertical}
.map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:100%;border:1px solid var(--line)}
.map iframe{width:100%;height:100%;min-height:460px;border:0;display:block}

/* ============================================================
   RESPONSIVE — smartphone · tablet · desktop
   ============================================================ */

/* Desktop ampio: limita la larghezza delle descrizioni lunghe del menù */
@media (min-width:1025px){
  .menu__list{column-gap:64px}
}

/* Tablet landscape / small laptop */
@media (max-width:1024px){
  .services__grid--3{grid-template-columns:repeat(3,1fr)} /* resta 3 su tablet largo */
  .intro__grid{gap:48px}
  .footer__grid{grid-template-columns:1.2fr 1fr 1fr;gap:36px}
}

/* Tablet portrait */
@media (max-width:900px){
  .intro__grid,.contact__main{grid-template-columns:1fr}
  .intro__media{max-width:520px;margin:0 auto}
  .intro__media::after{display:none}
  .services__grid--3{grid-template-columns:repeat(3,1fr)}
  .cta{background-attachment:scroll}
  .page-hero{padding:150px 0 70px}
}

/* Tablet stretto / phablet */
@media (max-width:760px){
  .menu__list{grid-template-columns:1fr;gap:0}
  .services__grid,.services__grid--3{grid-template-columns:1fr;gap:20px}
  .contact__grid{grid-template-columns:1fr;gap:18px}
  .footer__grid{grid-template-columns:1fr;gap:36px;text-align:center}
  .footer__contact li{justify-content:center}
  .footer__social{justify-content:center}
  .map iframe{min-height:340px}
  .ristorante-full{grid-template-columns:1fr !important}
}

/* Smartphone */
@media (max-width:600px){
  .container{padding:0 18px}
  .header{padding:16px 0}
  .header.scrolled{padding:11px 0}
  .nav__logo img{height:40px}
  .header.scrolled .nav__logo img{height:34px}
  /* il bottone "Prenota" nel menu diventa solo icona per non affollare */
  .nav__actions .btn-primary{padding:12px 16px;font-size:0}
  .nav__actions .btn-primary i{font-size:1rem}
  .hero__inner{padding:110px 20px 90px}
  .hero .lead{font-size:1.05rem}
  .hero__cta{gap:12px}
  .hero__cta .btn{width:100%;max-width:300px;justify-content:center}
  .section{padding:56px 0}
  .tabs{gap:8px;margin-bottom:38px}
  .tab{padding:9px 16px;font-size:.78rem}
  .menu__group-title::before,.menu__group-title::after{width:34px}
  .menu__item-name,.menu__price{font-size:1.22rem}
  .card{padding:34px 26px}
  .form{padding:28px 22px}
  .contact__card{padding:32px 22px}
  .footer{padding:56px 0 24px}
}

/* Smartphone piccolo */
@media (max-width:380px){
  .menu__item-head{flex-wrap:wrap}
  .menu__dots{display:none}
  .menu__price{margin-left:auto}
  .tab{padding:8px 13px;letter-spacing:.04em}
}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
