 :root{
  --bg:#fbf5ee;
  --paper:#fffaf4;
  --panel:#fff7ef;
  --ink:#26352c;
  --muted:#5f695f;
  --line:rgba(38,53,44,.10);
  --terracotta:#c76442;
  --terracotta-dark:#a54e31;
  --olive:#6e7a58;
  --soft-olive:#eef2e7;
  --radius:24px;
  --shadow:0 22px 60px rgba(65,39,22,.10);
  --sans:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
 }
 *{box-sizing:border-box}
 html{scroll-behavior:smooth}
 body{margin:0;background:linear-gradient(180deg,#fff8f1,#f7f0e8 40%,#fbf5ee 100%);color:var(--ink);font-family:var(--sans);line-height:1.6;overflow-x:hidden}
 a{color:inherit;text-decoration:none}
 img{max-width:100%;display:block}
 .container{width:min(1120px,calc(100% - 40px));margin-inline:auto}
 .site-header{position:fixed;top:14px;left:50%;transform:translateX(-50%);width:min(1120px,calc(100% - 28px));z-index:20;display:flex;align-items:center;justify-content:center;padding:8px 14px;border:1px solid rgba(38,53,44,.08);border-radius:999px;background:rgba(255,250,244,.88);backdrop-filter:blur(16px);box-shadow:0 8px 30px rgba(65,39,22,.08)}
 .brand{display:flex;align-items:center;justify-content:center;width:100%}
 .brand img{width:248px;height:auto;margin-inline:auto}
 .hero{padding:132px 0 42px}
 .hero-single{display:grid;gap:18px}
 .eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--terracotta-dark);font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;font-weight:800}
 .eyebrow::before{content:"";width:34px;height:2px;background:var(--terracotta)}
 h1,h2,h3,p{margin-top:0}
 h1{font-size:clamp(2.35rem,5.2vw,4.2rem);line-height:1.06;letter-spacing:-.045em;margin:14px 0 0;font-weight:800;max-width:680px}
 h2{font-size:clamp(2rem,4vw,3.4rem);line-height:1.08;letter-spacing:-.04em;margin:14px 0 18px;font-weight:800;max-width:760px}
 h3{font-size:1.12rem;margin-bottom:10px}
 .hero-copy{max-width:760px}
 .hero-photo{margin:0;position:relative;border-radius:34px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(38,53,44,.06)}
 .hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,22,18,.20) 0%,rgba(16,22,18,.34) 55%,rgba(16,22,18,.44) 100%)}
 .hero-photo img{width:100%;height:500px;object-fit:cover}
 .hero-overlay{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:34px 28px;color:#fff}
 .hero-overlay h1{max-width:560px;color:rgba(244,240,234,.90);margin-top:18px;text-shadow:0 2px 10px rgba(16,22,18,.18)}
  .hero-overlay .eyebrow{position:absolute;top:28px;left:28px} 
 .eyebrow.light{color:rgba(236,232,226,.82)}
 .eyebrow.light::before{background:rgba(236,232,226,.82)}
 .actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
 .actions-inline{margin-top:24px}
 .btn{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:13px 20px;border-radius:999px;border:1px solid var(--line);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;font-weight:800;background:#fff;transition:.25s}
 .btn:hover{transform:translateY(-2px)}
 .btn.primary{background:var(--terracotta);color:#fff;border-color:transparent}
 .btn.secondary{background:#fff;color:var(--ink)}
 .btn.ghost{background:transparent}
 .btn.full{width:100%;margin-top:18px}
 .quick-facts{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px;color:var(--muted);font-size:.9rem}
 .quick-facts span{padding:11px 14px;border:1px solid rgba(38,53,44,.09);border-radius:999px;background:#fff}
 .quick-facts strong{color:var(--ink)}
 .section{padding:82px 0}
 .compact-section{padding-top:54px}
 .split{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:40px;align-items:start}
 .copy p,.section-head p{color:var(--muted);font-size:1.04rem}
 .info-panel,.contact-card,.map-card{border:1px solid rgba(38,53,44,.08);border-radius:28px;background:rgba(255,255,255,.68);box-shadow:var(--shadow)}
 .info-panel{padding:28px;display:grid;gap:20px}
 .info-panel div{padding-bottom:18px;border-bottom:1px solid rgba(38,53,44,.08)}
 .info-panel div:last-child{padding-bottom:0;border-bottom:0}
 .info-panel span,.contact-list span,.hours span{display:block;color:var(--terracotta-dark);font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;font-weight:800}
 .info-panel strong,.contact-list strong,.hours strong{display:block;margin-top:6px}
 .gallery-section{background:linear-gradient(180deg,rgba(110,122,88,.06),transparent)}
 .section-head{max-width:680px;margin-bottom:28px}
 .gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
 .gallery figure{margin:0;position:relative;overflow:hidden;border-radius:24px;border:1px solid rgba(38,53,44,.08);background:#fff;box-shadow:var(--shadow)}
 .gallery img{width:100%;height:100%;object-fit:cover;min-height:230px}
 .gallery figure.tall{grid-column:span 4;grid-row:span 2}
 .gallery figure:not(.tall):not(.wide){grid-column:span 4}
 .gallery figure.wide{grid-column:span 8}
 .gallery figcaption{position:absolute;left:14px;bottom:14px;padding:8px 10px;border-radius:999px;background:rgba(255,250,244,.92);color:var(--ink);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em}
 .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
 .contact-card,.map-card{padding:30px}
 .contact-card p{color:var(--muted)}
 .contact-list{display:grid;gap:12px;margin-top:22px}
 .contact-list a{padding:16px;border:1px solid rgba(38,53,44,.08);border-radius:18px;background:#fff}
 .map-visual{min-height:220px;border-radius:24px;background:linear-gradient(135deg,rgba(199,100,66,.16),rgba(110,122,88,.10)),linear-gradient(90deg,rgba(38,53,44,.07) 1px,transparent 1px),linear-gradient(rgba(38,53,44,.06) 1px,transparent 1px);background-size:auto,42px 42px,42px 42px;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;position:relative;overflow:hidden}
 .pin{width:24px;height:24px;border-radius:50% 50% 50% 0;background:var(--terracotta);transform:rotate(-45deg);box-shadow:0 0 0 14px rgba(199,100,66,.12);margin-right:18px}
 .map-visual strong{font-size:1.55rem}
 .map-visual p{color:var(--muted);margin:4px 0 0}
 .hours{display:grid;gap:10px;margin-top:22px}
 .hours div{display:flex;justify-content:space-between;gap:14px;padding-bottom:10px;border-bottom:1px solid rgba(38,53,44,.08)}
 .footer{padding:46px 0;border-top:1px solid rgba(38,53,44,.08);background:#fff9f3}
 .footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:34px;color:var(--muted)}
 .footer img{width:170px;margin-bottom:16px}
 .footer h3{color:var(--ink)}
 .footer p{margin:0 0 8px}
 .reveal{opacity:0;transform:translateY(18px);transition:opacity .65s ease,transform .65s ease}
 .reveal.visible{opacity:1;transform:none}
 @media (max-width:980px){
  .split,.contact-grid{grid-template-columns:1fr}
 }
 @media (max-width:880px){
  .gallery{grid-template-columns:1fr 1fr}
  .gallery figure,.gallery figure.tall,.gallery figure.wide{grid-column:auto;grid-row:auto}
 }
 @media (max-width:560px){
  .container{width:min(100% - 32px,1120px)}
  .site-header{top:10px;padding:5px 12px;justify-content:center;align-items:center}
  .brand{width:auto;margin:0;justify-content:center;transform:translateX(30px)}
  .brand img{width:232px;margin:0}
  .hero{padding:108px 0 26px}
  h1{font-size:2.42rem;line-height:1.08}
  h2{font-size:2.28rem}
  .hero-photo{width:calc(100% + 32px);margin-left:-16px;margin-right:-16px;border-radius:0;border-left:0;border-right:0}
  .hero-photo img{height:360px}
  .hero-overlay{padding:28px 24px}
  .hero-overlay .eyebrow{top:22px;left:24px}
  .hero-overlay h1{max-width:320px}
  .actions{display:grid}
  .btn{width:100%}
  .quick-facts{display:grid}
  .section{padding:68px 0}
  .gallery{grid-template-columns:1fr}
  .contact-card,.map-card,.info-panel{padding:22px}
  .hours div{display:grid}
  .footer-grid{grid-template-columns:1fr}
 }
 

/* v12 — Chi siamo mobile cleanup */
.about-section{padding-top:54px}
.about-card{display:grid;grid-template-columns:1fr;gap:24px;align-items:start;padding:30px;border:1px solid rgba(38,53,44,.08);border-radius:30px;background:rgba(255,255,255,.58);box-shadow:var(--shadow)}
.about-copy p{color:var(--muted);font-size:1.04rem;max-width:680px}
.about-info{display:grid;gap:12px}
.about-info div{padding:18px;border:1px solid rgba(38,53,44,.08);border-radius:20px;background:#fff}
.about-info span{display:block;color:var(--terracotta-dark);font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;font-weight:800;margin-bottom:4px}
.about-info strong{display:block;font-size:1rem;color:var(--ink)}
.about-info p{margin:4px 0 0;color:var(--muted);font-size:.92rem}
@media (max-width:760px){
  .about-card{grid-template-columns:1fr;padding:24px;gap:22px}
  .about-copy h2{font-size:2.18rem}
  .about-copy p{font-size:1rem}
  .about-info{grid-template-columns:1fr}
}
@media (max-width:560px){
  .about-section{padding-top:48px}
  .about-card{margin-inline:0;padding:22px;border-radius:26px}
  .about-copy h2{font-size:2.05rem;line-height:1.08}
  .actions-inline{grid-template-columns:1fr}
}


/* v17 — info cards moved under hero */
.info-strip-section{padding:0 0 14px}
.info-strip{grid-template-columns:repeat(4,minmax(0,1fr));align-items:stretch}
.info-strip div{height:100%}
@media (max-width:760px){
  .info-strip-section{padding:8px 0 6px}
  .info-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
}


/* v21 — footer legal cleanup */
.contact-section{padding-bottom:58px}
.footer{padding-top:38px}
.footer-bottom{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;margin-top:28px;padding-top:18px;border-top:1px solid rgba(38,53,44,.08);color:var(--muted);font-size:.86rem}
.footer-bottom a{color:var(--ink);font-weight:700}
@media (max-width:560px){
  .contact-section{padding-bottom:46px}
  .footer-bottom{display:grid;gap:8px}
}


/* v21 — privacy/cookie page */
.legal-page{padding-top:96px}
.legal-card{max-width:860px;padding:34px;border:1px solid rgba(38,53,44,.08);border-radius:30px;background:rgba(255,255,255,.72);box-shadow:var(--shadow)}
.legal-card h1{color:var(--ink);text-shadow:none;margin-bottom:20px}
.legal-card h2{font-size:1.45rem;margin-top:30px;margin-bottom:10px;letter-spacing:-.02em}
.legal-card p{color:var(--muted)}
.legal-card .btn{margin-top:24px}
@media (max-width:560px){
  .legal-page{padding-top:86px}
  .legal-card{padding:24px;border-radius:26px}
  .legal-card h1{font-size:2.28rem}
}
