:root{
  --bg:#f2f2ee;
  --sand:#b9a27c;
  --sand2:#a48e6a;
  --blue:#86a0b2;
  --ink:#222;
  --muted:#666;
  --card:#ffffff;
  --line:rgba(0,0,0,.12);
  --white:#fff;
}

*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--ink);
}

/* ---------- TOPBAR ---------- */
.topbar{
  height:64px;
  background: var(--sand);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 0 18px;
  position:sticky;
  top:0;
  z-index:20;
}
.topbar__left{
  display:flex;
  gap:18px;
  align-items:center;
}

.icon{
  color:#fff;
  opacity:.95;
  font-size:16px;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;
  height:22px;
}
.topbar__right{position:relative}
.lang{
  background:transparent;
  border:0;
  color:#fff;
  font-weight:700;
  letter-spacing:.08em;
  cursor:pointer;
  padding:10px 10px;
}
.chev{opacity:.9;margin-left:4px}
.lang__menu{
  position:absolute;
  right:0;
  top:44px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:10px;
  overflow:hidden;
  min-width:86px;
}
.lang__opt{
  width:100%;
  padding:12px 14px;
  background:#fff;
  border:0;
  text-align:left;
  cursor:pointer;
}
.lang__opt:hover{background:#f6f6f6}

/* ---------- HEADER ---------- */
.header{
  background: #eeeee9;
  position:sticky;
  top:64px;
  z-index:15;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 18px 18px;
}
.brand{
  display:flex;
  gap:14px;
  align-items:flex-start; /* <-- come in foto: logo “su”, testo parte dall’alto */
}

.brand__mark{
  width:64px;
  height:64px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background: rgba(0,0,0,.06);
  font-size:22px;
  margin-top:2px; /* leggero offset come screenshot */
}

/* testo più grande come originale */
.brand__name{
  font-family: "Georgia", serif;
  font-style: italic;
  font-size:52px;      /* <-- più grande */
  line-height:0.95;
  color:#b89f78;
  letter-spacing:0.02em;
}

.brand__sub{
  font-size:13px;
  letter-spacing:.28em;
  color:#b89f78;
  margin-top:8px;
}

.hamb{
  width:56px;
  height:56px;
  background: rgba(0,0,0,.06);
  border:0;
  border-radius:8px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:6px;
  cursor:pointer;
}

.hamb span{
  width:22px;
  height:2px;
  background: rgba(0,0,0,.38);
  border-radius:99px;
}

.menu{
  padding: 12px 18px 18px;
  display:grid;
  gap:10px;
}
.menu a{
  padding: 14px 12px;
  background: rgba(0,0,0,.04);
  border-radius: 10px;
  color: rgba(0,0,0,.75);
  font-weight:600;
}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  height: calc(100vh - 64px - 92px);
  min-height: 560px;
  overflow:hidden;
}
.hero__img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
}
.hero__overlay{
  position:absolute;inset:0;
  background: linear-gradient(rgba(0,0,0,.15), rgba(0,0,0,.35));
}
.hero__content{
  position:relative;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding: 24px;
  text-align:center;
  color:#fff;
}
.hero__title{
  font-family: "Georgia", serif;
  font-style: italic;
  font-weight:500;
  letter-spacing:.02em;
  font-size: 72px;
  line-height: .92;
  text-shadow: 0 8px 30px rgba(0,0,0,.35);
  margin-bottom: 26px;
}
.btn{
  display:inline-block;
  background:#fff;
  color:#333;
  padding: 16px 46px;
  letter-spacing:.18em;
  font-weight:700;
  border-radius:2px;
}

/* ---------- ARCH IMAGE ---------- */
.arch{padding: 30px 18px 10px}
.arch__frame{
  margin: 0 auto;
  max-width: 520px;
  background: #fff;
  padding: 22px;
}
.arch__frame img{
  width:100%;
  height: 520px;
  object-fit:cover;
  border-radius: 260px 260px 20px 20px; /* arco */
  display:block;
}

/* ---------- WELCOME ---------- */
.welcome{
  padding: 42px 22px 24px;
  text-align:center;
  max-width: 780px;
  margin: 0 auto;
}
.welcome__title{margin-bottom:18px}
.caps{
  display:block;
  font-family: "Georgia", serif;
  font-weight:800;
  letter-spacing:.08em;
  font-size: 44px;
}
.script{
  display:block;
  font-family: "Georgia", serif;
  font-style: italic;
  font-size: 54px;
  margin-top: -8px;
  color:#333;
}
.welcome__text{
  color: rgba(0,0,0,.6);
  font-size: 18px;
  line-height: 2;
  padding: 0 10px;
  margin: 18px auto 18px;
}
.link{
  display:inline-block;
  margin-top: 12px;
  letter-spacing:.18em;
  font-weight:700;
  color: rgba(0,0,0,.55);
}

/* ---------- PANELS (TEXTURE LOOK) ---------- */
.panel{
  padding: 34px 18px;
}
.panel--blue{
  background:
    linear-gradient(rgba(0,0,0,.02), rgba(0,0,0,.02)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.06), rgba(255,255,255,.06) 2px, transparent 2px, transparent 6px),
    var(--blue);
}
.panel--sand{
  background:
    linear-gradient(rgba(0,0,0,.03), rgba(0,0,0,.03)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.05), rgba(255,255,255,.05) 2px, transparent 2px, transparent 6px),
    linear-gradient(180deg, var(--sand), var(--sand2));
}
.panel__inner{
  max-width: 760px;
  margin: 0 auto;
  padding: 56px 26px;
  text-align:center;
  color:#fff;
}
.panel__title .caps{font-size: 54px}
.panel__title .script{font-size: 62px}
.white{color:#fff}
.panel__lead{
  margin-top: 12px;
  font-size: 20px;
  font-weight:700;
  letter-spacing:.06em;
}
.panel__text{
  margin-top: 22px;
  font-size: 18px;
  line-height: 2;
  opacity:.92;
}
.divider{
  margin: 28px auto;
  height:2px;
  width: 92%;
  background: rgba(255,255,255,.25);
}
.panel__ctaTitle{
  font-weight:800;
  letter-spacing:.14em;
  margin-top: 6px;
}
.panel__cta{
  display:inline-block;
  margin-top: 18px;
  letter-spacing:.18em;
  font-weight:800;
  color:#fff;
  opacity:.95;
}

/* ---------- PHOTOS STRIP ---------- */
.photos{background:#efefe9;padding: 36px 18px}
.photos__inner{
  max-width: 760px;
  margin:0 auto;
  display:grid;
  gap: 18px;
}
.photos__inner img{width:100%;display:block}

/* ---------- EXPERIENCE LIST ---------- */
.center{padding-top: 60px;padding-bottom: 60px}
.exp{margin-top: 26px}
.exp__item{padding: 26px 0}
.exp__icon{font-size: 48px;opacity:.95;margin-bottom: 10px}
.exp__name{font-weight:900;letter-spacing:.18em}
.exp__desc{margin-top: 12px;opacity:.9;line-height:2}
.line{
  height:2px;
  width: 92%;
  background: rgba(255,255,255,.25);
  margin: 0 auto;
}

/* ---------- CONTACT ---------- */
.contact{
  padding: 44px 18px 70px;
  text-align:center;
  color: rgba(0,0,0,.7);
}
.contact a{color: rgba(0,0,0,.7);font-weight:700}

/* ---------- MOBILE TYPE SCALE ---------- */
@media (max-width: 430px){
  .brand__name{font-size:38px}
  .hero__title{font-size:62px}
  .caps{font-size:40px}
  .script{font-size:50px}
  .panel__title .caps{font-size:46px}
  .panel__title .script{font-size:54px}
  .arch__frame img{height: 460px}
}

/* ===== MENU OVERLAY (come screenshot) ===== */
.overlay{
  position:fixed;
  inset:0;
  z-index:9999;
  background: #f2f2ee;
  overflow:auto;
}

.overlay__top{
  background: var(--sand);
  padding: 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.close{
  width:56px;height:56px;
  border:0;
  border-radius:6px;
  background: rgba(255,255,255,.14);
  color:#fff;
  font-size:34px;
  line-height:1;
  cursor:pointer;
}

.overlay__nav{
  padding: 26px 22px 40px;
  display:flex;
  flex-direction:column;
  gap: 22px;
}

.overlay__nav a{
  font-size: 26px;
  letter-spacing: .14em;
  color: rgba(0,0,0,.75);
  font-weight: 500;
}

.overlay__nav a:first-child{
  color: rgba(0,0,0,.35);
}

.overlay__cta{
  margin-top: 14px;
  font-size: 18px !important;
  letter-spacing: .18em;
  font-weight: 700;
  color: rgba(0,0,0,.65) !important;
}


/* ===== SHUTTLE HERO ===== */
.hero2{position:relative;min-height:560px}
.hero2__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero2__overlay{position:absolute;inset:0;background:rgba(0,0,0,.35)}
.hero2__content{
  position:relative;
  padding:70px 22px;
  color:#fff;
  text-align:center;
  max-width:780px;
  margin:0 auto;
}
.hero2__badge{
  width:78px;height:78px;border-radius:999px;
  background:rgba(185,162,124,.95);
  display:grid;place-items:center;
  margin:0 auto 18px;
  font-size:34px;
}
.hero2__title{
  font-family:"Georgia",serif;
  font-size:44px;
  letter-spacing:.02em;
  margin-bottom:10px;
}
.hero2__text{font-size:18px;line-height:2;opacity:.95}
.hero2__note{margin-top:18px;opacity:.9}

/* ===== BOX PICKUP ===== */
.boxWrap{padding:40px 18px;background:var(--bg)}
.box{
  max-width:760px;margin:0 auto;
  background:#fafaf7;
  padding:44px 26px;
  text-align:center;
  border:1px solid rgba(0,0,0,.06);
}
.box__lead{color:#b89f78;font-weight:700;letter-spacing:.06em;line-height:2}
.box__muted{margin-top:14px;color:#b89f78;opacity:.9}
.box__line{height:1px;background:rgba(0,0,0,.18);width:86%;margin:26px auto}
.box__title{letter-spacing:.2em;margin-bottom:14px}
.box__list{list-style:disc;max-width:520px;margin:0 auto 22px;text-align:left;line-height:2;color:#333}
.box__btn{
  display:inline-block;
  padding:16px 26px;
  border:2px solid #b89f78;
  color:#b89f78;
  letter-spacing:.18em;
  font-weight:800;
}

/* ===== BIG TITLES (RISTORANTE / MENU) ===== */
.bigTitle{
  padding:70px 22px;
  text-align:center;
  max-width:860px;
  margin:0 auto;
}
.bigTitle__h{
  font-family:"Georgia",serif;
  font-weight:800;
  letter-spacing:.08em;
  font-size:54px;
}
.bigTitle__s{
  font-family:"Georgia",serif;
  font-style:italic;
  font-size:54px;
  margin-top:-10px;
}
.bigTitle__p{
  margin:24px auto 0;
  max-width:720px;
  color:rgba(0,0,0,.6);
  font-size:18px;
  line-height:2;
}
.photoFrame{
  max-width:760px;
  margin:42px auto 0;
  background:#fff;
  padding:18px;
}
.photoFrame img{width:100%;display:block}

/* ===== MENU LIST ===== */
.menuBlock{max-width:760px;margin:46px auto 0;text-align:left}
.menuCat{color:#b89f78;font-weight:800;letter-spacing:.18em;margin-bottom:14px}
.menuHr{height:2px;background:rgba(0,0,0,.18);width:100%;margin-bottom:22px}

.menuRow{
  display:flex;
  align-items:baseline;
  gap:12px;
  padding:18px 0;
}
.menuRow__name{
  flex:1;
  letter-spacing:.06em;
  font-weight:700;
  color:#222;
}
.menuRow__dots{
  flex:1;
  border-bottom:3px dotted rgba(0,0,0,.25);
  transform:translateY(-6px);
}
.menuRow__price{min-width:54px;text-align:right;font-weight:900;letter-spacing:.08em}

.acc{border-top:1px solid rgba(0,0,0,.12)}
.acc:last-of-type{border-bottom:1px solid rgba(0,0,0,.12)}
.acc__btn{
  width:100%;
  padding:22px 0;
  background:transparent;
  border:0;
  text-align:left;
  font-weight:900;
  letter-spacing:.18em;
  cursor:pointer;
}
.acc__panel{padding:0 0 22px;color:rgba(0,0,0,.6);line-height:2}

.menuBtns{display:grid;gap:18px;margin:34px auto 0;max-width:520px}
.menuBtn{
  text-align:center;
  padding:18px 18px;
  border:2px solid #b89f78;
  color:#b89f78;
  letter-spacing:.18em;
  font-weight:800;
}

/* ===== BLUE ACC ===== */
.pad0{padding:0}
.blueAcc{padding:46px 22px}
.blueAcc__btn{
  width:100%;
  background:transparent;
  border:0;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  cursor:pointer;
}
.blueAcc__t{
  font-family:"Georgia",serif;
  font-size:52px;
  text-decoration:underline;
}
.blueAcc__i{font-size:26px;opacity:.9}
.blueAcc__p{margin:22px auto 22px;max-width:640px;line-height:2;opacity:.95}
.blueAcc__sep{height:2px;background:rgba(255,255,255,.25);width:92%;margin:22px auto}

/* ===== CONTACT FORM (sabbia) ===== */
.formWrap{padding-top:64px;padding-bottom:64px}
.formTitle{margin-bottom:34px}
.form{max-width:680px;margin:0 auto}
.f{display:block;text-align:left;margin:18px 0}
.f span{display:block;opacity:.85;letter-spacing:.14em;margin-bottom:10px}
.f input,.f textarea{
  width:100%;
  background:transparent;
  border:0;
  border-bottom:2px solid rgba(255,255,255,.6);
  color:#fff;
  padding:12px 2px;
  outline:none;
  font-size:16px;
}
.chk{
  display:flex;
  gap:12px;
  align-items:flex-start;
  margin:26px 0;
  text-align:left;
  opacity:.95;
  line-height:1.8;
}
.chk input{margin-top:4px;width:18px;height:18px}
.formBtn{
  width:100%;
  padding:18px;
  background:#fff;
  border:0;
  color:#b89f78;
  letter-spacing:.18em;
  font-weight:900;
  cursor:pointer;
}

/* ===== FOTO GALLERY ===== */
.galleryHero{background:var(--bg)}
.galleryHero__img img{width:100%;display:block}
.galleryHero__title{
  padding:70px 22px 30px;
  text-align:center;
  max-width:860px;
  margin:0 auto;
}
.galleryStack{
  max-width:760px;
  margin:0 auto;
  padding: 0 18px 60px;
  display:grid;
  gap:28px;
}
.gItem{
  background:#fff;
  padding:18px;
}
.gItem img{width:100%;display:block}

/* ===== PARTNERS ===== */
.partners{
  padding:70px 22px;
  text-align:center;
  background:var(--bg);
}
.partners__title{
  font-family:"Georgia",serif;
  font-style:italic;
  font-size:52px;
  margin-bottom:26px;
}
.partnerSlider{
  max-width:760px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.pArrow{
  width:56px;height:56px;
  border:0;
  background:transparent;
  font-size:42px;
  color:rgba(0,0,0,.35);
  cursor:pointer;
}
.pSlide{
  flex:1;
  display:flex;
  justify-content:center;
  align-items:center;
  padding: 16px 0;
}
.pSlide img{max-width:520px;width:100%;opacity:.9}

/* ===== FOOTER BRAND ===== */
.footerBrand{
  padding:80px 22px 60px;
  text-align:center;
  background:var(--bg);
}
.footerBrand__logo{margin-bottom:22px}
.footerBrand__mark{
  width:64px;height:64px;border-radius:999px;
  display:grid;place-items:center;
  margin:0 auto 14px;
  background:rgba(185,162,124,.18);
  color:#b89f78;
  font-size:22px;
}
.footerBrand__name{
  font-family:"Georgia",serif;
  font-style:italic;
  font-size:64px;
  line-height:1;
  color:#86a0b2;
}
.footerBrand__sub{
  margin-top:10px;
  font-size:12px;
  letter-spacing:.28em;
  color:#86a0b2;
}
.footerBrand__text{
  max-width:760px;
  margin:18px auto 26px;
  color:rgba(0,0,0,.7);
  font-size:18px;
  line-height:2;
}
.follow{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
  margin-top:22px;
}
.follow__label{letter-spacing:.2em;font-weight:900}
.follow__icons{display:flex;gap:12px}
.round{
  width:46px;height:46px;
  border-radius:999px;
  background:rgba(185,162,124,.95);
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:900;
}

/* ===== NEWSLETTER ===== */
.newsletter{
  padding:70px 22px;
  text-align:center;
  background:var(--bg);
}
.newsletter__title{
  letter-spacing:.2em;
  font-weight:900;
  margin-bottom:24px;
}
.newsForm{
  max-width:760px;
  margin:0 auto;
}
.newsInput{
  width:100%;
  background:transparent;
  border:0;
  border-bottom:2px solid rgba(0,0,0,.25);
  padding:16px 6px;
  font-size:18px;
  outline:none;
}
.newsBtn{
  margin-top:18px;
  width:100%;
  padding:18px;
  background:var(--sand);
  color:#fff;
  border:0;
  letter-spacing:.18em;
  font-weight:900;
  cursor:pointer;
}

/* ===== ADDRESS ===== */
.addr{
  padding:70px 22px 90px;
  text-align:center;
  background:var(--bg);
}
.addr__title{
  letter-spacing:.2em;
  font-weight:900;
  margin-bottom:26px;
}
.addr__text{
  color:rgba(0,0,0,.7);
  line-height:2.1;
  font-size:20px;
}
.addr__map{
  display:inline-block;
  margin-top:26px;
  letter-spacing:.18em;
  font-weight:900;
  color:rgba(0,0,0,.75);
}

