/* ============================================================
   Terre di Luigi — Agriturismo & cantina · Trecastagni (Etna)
   Stile condiviso (multi-pagina). Dark luxury rurale: Cormorant
   display + Inter, oliva / vino, foto.
   ============================================================ */
:root{
  --black:#160f0f; --black-2:#1f1717; --black-3:#28201f; --vine:#9aa86a; --vine-d:#6c7a3e;
  --terra:#9c3b34; --terra-l:#c4564a; --cream:#f4efe6; --cream-2:#e8ddca; --ink:#241d1a; --muted:#6c6358;
  --line:rgba(243,238,226,.14); --r:16px; --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.75;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,.serif{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;line-height:1.1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--vine);color:var(--black)}
:focus-visible{outline:2px solid var(--vine);outline-offset:3px}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.eyebrow{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--vine-d)}
.serif-eye{font-family:'Cormorant Garamond';font-style:italic;color:var(--terra)}

/* header */
header{position:fixed;inset:0 0 auto;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:20px 32px;transition:.4s var(--ease)}
header.scrolled{background:rgba(19,20,15,.92);backdrop-filter:blur(10px);padding:13px 32px}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brand .bmark{font-family:'Cormorant Garamond';font-size:1.5rem;letter-spacing:.02em}
.brand .bmark span{color:var(--vine)}
nav{display:flex;align-items:center;gap:26px}
nav a{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:#ece7d8;transition:color .25s}
nav a:not(.cta):hover,nav a.active{color:var(--vine)}
.cta{border:1px solid var(--vine);color:var(--vine)!important;padding:10px 22px;border-radius:40px;transition:.3s var(--ease)}
.cta:hover{background:var(--vine);color:var(--black)!important}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0;padding:6px}.burger span{width:25px;height:1.6px;background:#fff}

/* hero */
.hero{min-height:88vh;min-height:88dvh;position:relative;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero.tall{min-height:100dvh}
.hero__bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;transform:scale(1.06);animation:zoom 16s var(--ease) forwards}
@keyframes zoom{to{transform:scale(1)}}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(19,20,15,.28),rgba(19,20,15,.82))}
.hero__in{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:0 28px 9vh;width:100%}
.hero .eyebrow{color:var(--vine);margin-bottom:22px;display:block}
.hero h1{font-size:clamp(2.8rem,8vw,6rem);max-width:16ch;font-weight:400}
.hero h1 em{font-style:italic;color:var(--terra-l)}
.hero p{margin-top:22px;max-width:48ch;font-size:1.18rem;color:#e6e0d0}
.hero .btns{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
/* compact hero for inner pages */
.phead{min-height:54vh;align-items:center;text-align:center}
.phead .hero__in{padding:8vh 28px}
.phead h1{margin:0 auto}.phead p{margin:22px auto 0}

.btn{display:inline-block;padding:15px 32px;border-radius:40px;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;transition:.3s var(--ease);cursor:pointer;border:1px solid transparent}
.btn-p{background:var(--vine);color:var(--black)}.btn-p:hover{background:#fff;transform:translateY(-2px)}
.btn-g{border-color:rgba(255,255,255,.5);color:#fff}.btn-g:hover{border-color:var(--terra);color:var(--terra)}
.btn-d{background:var(--vine);color:var(--black)}.btn-d:hover{background:var(--vine-d);color:#fff;transform:translateY(-2px)}

section{padding:13vh 0}
.sec-head{max-width:60ch}
.sec-head.ctr{margin-inline:auto;text-align:center}
.sec-head .eyebrow{display:block;margin-bottom:16px}
.sec-head h2{font-size:clamp(2rem,4.6vw,3.4rem);color:var(--black)}
.sec-head p{margin-top:16px;color:var(--muted);font-size:1.08rem}

/* intro split */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split .media{border-radius:var(--r);overflow:hidden;box-shadow:0 40px 80px -50px rgba(19,20,15,.7);aspect-ratio:4/5}
.split .media img{width:100%;height:100%;object-fit:cover}
.split h2{font-size:clamp(2rem,4.4vw,3.2rem);color:var(--black)}
.split p{margin-top:16px;color:var(--muted);font-size:1.06rem}
.split.rev .media{order:2}

/* feature scene panels (image bg + glass card) */
.scene{min-height:80vh;position:relative;display:flex;align-items:center;color:#fff;padding:8vh 0;overflow:hidden}
.scene__bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.scene__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(19,20,15,.78),rgba(19,20,15,.25))}
.scene.rev .scene__bg::after{background:linear-gradient(250deg,rgba(19,20,15,.78),rgba(19,20,15,.2))}
.scene .card{position:relative;z-index:2;background:rgba(19,20,15,.34);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:46px;max-width:480px}
.scene.rev .card{margin-left:auto}
.scene .eyebrow{color:var(--vine);display:block;margin-bottom:14px}
.scene h2{font-size:clamp(1.9rem,4vw,3rem);margin-bottom:14px}
.scene h2 em{font-style:italic;color:var(--terra-l)}
.scene p{color:#e6e0d0}
.scene .btn{margin-top:24px}

/* cards grid (rooms / generic) */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:50px}
.cards.two{grid-template-columns:repeat(2,1fr)}
.rcard{background:var(--black);color:#fff;border:1px solid rgba(255,255,255,.08);border-radius:var(--r);overflow:hidden;transition:.4s var(--ease)}
.rcard:hover{transform:translateY(-6px);border-color:var(--vine)}
.rcard .ph{aspect-ratio:4/3;background:linear-gradient(150deg,#2d3320,#5f7e3e);background-size:cover;background-position:center}
.rcard .ph.noimg{display:flex;align-items:center;justify-content:center}
.rcard .ph.noimg span{font-family:'Cormorant Garamond';font-style:italic;color:rgba(243,238,226,.5);font-size:1.4rem}
.rcard .b{padding:26px 26px 30px}
.rcard small{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--vine)}
.rcard h3{font-size:1.7rem;margin:8px 0 8px}
.rcard p{color:#bdb8a8;font-size:.96rem}

/* feature list (light cards) */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.feat{background:#fff;border:1px solid var(--cream-2);border-radius:var(--r);padding:30px 28px;transition:.35s var(--ease)}
.feat:hover{transform:translateY(-4px);box-shadow:0 26px 54px -40px rgba(19,20,15,.4)}
.feat h3{font-size:1.5rem;color:var(--black);margin-bottom:8px}
.feat p{color:var(--muted);font-size:.96rem}

/* list rows (treatments / places) */
.rows{margin-top:40px}
.row{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:baseline;padding:24px 0;border-top:1px solid var(--cream-2)}
.row:last-child{border-bottom:1px solid var(--cream-2)}
.row .no{font-family:'Cormorant Garamond';font-size:1.6rem;color:var(--terra)}
.row h3{font-size:clamp(1.4rem,2.6vw,1.9rem);color:var(--black)}
.row p{margin-top:6px;color:var(--muted);max-width:62ch}

/* dark section */
.dark{background:var(--black);color:#fff}
.dark .sec-head h2{color:#fff}
.dark .sec-head p{color:#bdb8a8}
.dark .row{border-color:rgba(255,255,255,.1)}.dark .row h3{color:#fff}.dark .row p{color:#bdb8a8}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.k{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--vine-d);margin:18px 0 4px}
.contact-grid a.big{font-family:'Cormorant Garamond';font-size:1.6rem;color:var(--black);transition:color .25s}.contact-grid a.big:hover{color:var(--terra)}
.mapbox{border-radius:var(--r);overflow:hidden;border:1px solid var(--cream-2);box-shadow:0 30px 60px -40px rgba(19,20,15,.5)}
.mapbox iframe{width:100%;height:100%;min-height:380px;border:0;display:block}
.small-note{font-size:.86rem;color:var(--muted);margin-top:8px}

/* footer */
footer{background:var(--black);color:#9a937f;padding:54px 0 34px;font-size:.9rem;border-top:1px solid var(--line)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:36px}
.foot-top h4{font-family:'Cormorant Garamond';font-size:1.6rem;color:#fff;margin-bottom:10px}.foot-top h4 span{color:var(--vine)}
.foot-top p{max-width:34ch}
.foot-col b{display:block;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--vine);margin-bottom:12px;font-weight:600}
.foot-col a,.foot-col span{display:block;color:#9a937f;padding:4px 0;transition:color .25s}.foot-col a:hover{color:var(--vine)}
.foot-bottom{border-top:1px solid var(--line);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.78rem;color:#6f6a59}

.reveal{opacity:0;transform:translateY(26px);transition:.9s var(--ease)}.reveal.in{opacity:1;transform:none}

.cookie{position:fixed;bottom:18px;left:18px;right:18px;max-width:430px;background:var(--black-2);color:#fff;padding:20px;border-radius:14px;border:1px solid rgba(138,172,99,.4);z-index:60;font-size:.85rem;display:none}
.cookie.show{display:block}
.cookie button{margin-top:12px;background:var(--vine);border:0;color:var(--black);font-weight:500;padding:10px 22px;border-radius:30px;cursor:pointer;font-family:inherit}

@media(max-width:900px){
  nav{position:fixed;top:0;right:0;bottom:0;height:100dvh;width:80%;max-width:330px;flex-direction:column;justify-content:center;align-items:flex-start;gap:24px;background:var(--black-2);padding:92px 36px 40px;transform:translateX(105%);transition:.4s var(--ease);box-shadow:-24px 0 70px -30px #000;z-index:45;overflow-y:auto}
  nav.open{transform:none}
  nav a{font-family:'Cormorant Garamond';font-size:1.6rem;letter-spacing:.01em;text-transform:none;color:#fff}
  nav a.cta{margin-top:8px;align-self:stretch;text-align:center;font-family:'Inter';font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;padding:13px 22px}
  .burger{display:flex;z-index:46}
  .scrim{position:fixed;inset:0;background:rgba(19,20,15,.6);opacity:0;visibility:hidden;transition:.4s var(--ease);z-index:44}
  .scrim.open{opacity:1;visibility:visible}body.nav-open{overflow:hidden}
  .split{grid-template-columns:1fr;gap:32px}.split.rev .media{order:0}
  .scene .card{max-width:none;padding:32px 26px}
  .cards,.cards.two,.feat-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .foot-top{grid-template-columns:1fr;gap:24px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}.hero__bg{transform:none}}
