/* ===== BNBK2R v3 ===== */
:root{
  --cream:#FAF7F2;--terra:#C4705A;--terra-d:#A85D4A;
  --charcoal:#2C2C2C;--wg:#6B6560;--lg:#E8E4DE;--gold:#D4AF37;
  --serif:'Cormorant Garamond',serif;--sans:'Plus Jakarta Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--cream);color:var(--charcoal);-webkit-font-smoothing:antialiased;}
img{display:block;max-width:100%;}
a{color:inherit;}
::-webkit-scrollbar{width:7px;}::-webkit-scrollbar-track{background:var(--cream);}::-webkit-scrollbar-thumb{background:var(--terra);border-radius:4px;}
::selection{background:var(--terra);color:#fff;}

/* ── Language switching ── */
/* Default: show IT, hide EN */
.en{display:none}
body.lang-en .en{display:inline}
body.lang-en .it{display:none}
/* for block elements */
p.it,div.it,li.it,span.it{display:inline}
p.en,div.en,li.en,span.en{display:none}
body.lang-en p.en,body.lang-en div.en,body.lang-en li.en,body.lang-en span.en{display:inline}
body.lang-en p.it,body.lang-en div.it,body.lang-en li.it,body.lang-en span.it{display:none}

.container{max-width:1400px;margin:0 auto;padding:0 3rem;}

/* ── Loader ── */
#loader{position:fixed;inset:0;background:var(--cream);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .6s,visibility .6s;}
#loader.gone{opacity:0;visibility:hidden;pointer-events:none;}
.loader-bar{width:0;height:2px;background:var(--terra);animation:lb 1.4s ease forwards;}
@keyframes lb{to{width:120px}}

/* ── Nav ── */
#nav{position:relative;width:100%;z-index:100;padding:0.75rem 3rem;background:var(--cream);border-bottom:1px solid var(--lg);transition:all .3s;}
.nav-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;}
.logo{font-family:var(--serif);font-size:1.8rem;font-weight:500;color:var(--charcoal);text-decoration:none;letter-spacing:.05em;}
.nav-links{display:flex;align-items:center;gap:1.8rem;}
.nav-links .li{font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--charcoal);text-decoration:none;transition:color .3s;}
.nav-links .li:hover{color:var(--terra);}
.lang-btns{display:flex;gap:.4rem;}
.lb{background:transparent;border:1px solid var(--terra);color:var(--terra);font-size:.65rem;font-weight:700;padding:.22rem .7rem;border-radius:99px;cursor:pointer;transition:all .3s;}
.lb.active,.lb:hover{background:var(--terra);color:#fff;}
.burger{display:none;background:none;border:none;font-size:1.3rem;color:var(--charcoal);cursor:pointer;}

/* ── Mobile menu ── */
#mob-menu{position:fixed;inset:0;background:var(--cream);z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.8rem;transform:translateX(100%);transition:transform .5s cubic-bezier(.4,0,.2,1);}
#mob-menu.open{transform:translateX(0);}
#mob-menu a{font-family:var(--serif);font-size:2.2rem;color:var(--charcoal);text-decoration:none;}
.mob-x{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--charcoal);}

/* ── Buttons ── */
.btn-p{background:var(--terra);color:#fff;border:none;cursor:pointer;font-family:var(--sans);font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:.85rem 2rem;border-radius:99px;transition:all .3s;display:inline-block;text-decoration:none;}
.btn-p:hover{background:var(--terra-d);transform:translateY(-2px);box-shadow:0 10px 28px rgba(196,112,90,.3);}
.btn-o{background:transparent;border:1.5px solid rgba(255,255,255,.85);color:#fff;cursor:pointer;font-family:var(--sans);font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:.85rem 2rem;border-radius:99px;transition:all .3s;display:inline-block;text-decoration:none;}
.btn-o:hover{background:#fff;color:var(--charcoal);}
.btn-border{background:transparent;border:1px solid var(--charcoal);color:var(--charcoal);cursor:pointer;font-family:var(--sans);font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:.7rem 1.5rem;border-radius:6px;transition:all .3s;width:100%;}
.btn-border:hover{background:var(--charcoal);color:#fff;}
.glass{background:rgba(255,255,255,.9);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);}

/* ── Hero ── */
#hero{position:relative;height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.45) 0%,rgba(0,0,0,.65) 100%);}
.hero-content{position:relative;z-index:2;text-align:center;color:#fff;padding:0 1.5rem;max-width:860px;}
.hero-eye{font-size:.68rem;letter-spacing:.32em;text-transform:uppercase;opacity:.9;margin-bottom:1.2rem;animation:fu .8s ease both;}
.hero-title{font-family:var(--serif);font-size:clamp(3.5rem,9vw,7rem);font-weight:300;line-height:.95;margin-bottom:1.3rem;animation:fu .8s .1s ease both;}
.hero-sub{font-size:.9rem;opacity:.88;max-width:500px;margin:0 auto 2.2rem;line-height:1.75;font-weight:300;animation:fu .8s .2s ease both;}
.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:fu .8s .3s ease both;}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:1rem;z-index:2;animation:bounce 2s infinite;}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes fu{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* ── Quick Book ── */
#qbook{position:relative;z-index:20;padding:0 3rem 5rem;margin-top:-5rem;}
.qb-wrap{max-width:920px;margin:0 auto;padding:2rem 2.5rem;border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.13);}
.qb-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:1.5rem;align-items:end;}
.qf label{display:block;font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--wg);margin-bottom:.4rem;}
.qf input,.qf select{width:100%;background:transparent;border:none;border-bottom:1.5px solid #ccc;padding:.45rem 0;font-size:.85rem;font-family:var(--sans);color:var(--charcoal);outline:none;transition:border-color .3s;cursor:pointer;appearance:none;}
.qf input:focus,.qf select:focus{border-color:var(--terra);}

/* ── Section helpers ── */
.eye{font-size:.62rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--terra);margin-bottom:.9rem;}
.st{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:300;line-height:1.1;}
.st em{font-style:italic;}
.div{width:3.5rem;height:2px;background:var(--terra);margin:1.4rem 0;}
.sh{margin-bottom:3.5rem;}

/* ── About ── */
#about{padding:6rem 0;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.about-img{border-radius:20px;overflow:hidden;}
.about-img img{width:100%;height:560px;object-fit:cover;transition:transform .8s cubic-bezier(.4,0,.2,1);}
.about-img:hover img{transform:scale(1.04);}
.about-text p{font-size:.87rem;color:var(--wg);line-height:1.85;}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem;text-align:center;}
.sn{font-family:var(--serif);font-size:2.2rem;color:var(--terra);}
.sl{font-size:.6rem;text-transform:uppercase;letter-spacing:.2em;color:var(--wg);margin-top:.2rem;}

/* ── Apartments ── */
#apartments{padding:6rem 0;}
.apts-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
.apt-card{border-radius:20px;overflow:hidden;background:var(--cream);cursor:pointer;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s;}
.apt-card:hover{transform:translateY(-10px);box-shadow:0 24px 60px rgba(0,0,0,.12);}
.apt-img{aspect-ratio:4/3;overflow:hidden;}
.apt-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.4,0,.2,1);}
.apt-card:hover .apt-img img{transform:scale(1.06);}
.apt-body{padding:2rem;}
.apt-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;}
.apt-name{font-family:var(--serif);font-size:1.5rem;margin-bottom:.3rem;}
.apt-meta{font-size:.7rem;color:var(--wg);}
.apb{text-align:right;}
.ap{font-family:var(--serif);font-size:1.6rem;color:var(--terra);}
.apn{font-size:.6rem;text-transform:uppercase;letter-spacing:.14em;color:var(--wg);}
.apt-desc{font-size:.82rem;color:var(--wg);line-height:1.7;margin-bottom:1.2rem;}
.tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.4rem;}
.tags span{font-size:.68rem;background:rgba(196,112,90,.1);padding:.28rem .75rem;border-radius:99px;}

/* ── Experience ── */
#experience{padding:6rem 0;position:relative;overflow:hidden;}
.exp-bg{position:absolute;inset:0;z-index:0;}
.exp-bg img{width:100%;height:100%;object-fit:cover;opacity:.15;}
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:3rem;}
.exp-card{background:#fff;border-radius:20px;padding:2.5rem 1.5rem;text-align:center;transition:transform .4s,box-shadow .4s;}
.exp-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px rgba(0,0,0,.1);}
.exp-ico{width:3.5rem;height:3.5rem;border-radius:50%;background:rgba(196,112,90,.1);color:var(--terra);display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin:0 auto 1rem;transition:all .3s;}
.exp-card:hover .exp-ico{background:var(--terra);color:#fff;}
.et{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.4rem;}
.es{font-size:.7rem;color:var(--wg);}

/* ── GALLERY — horizontal auto-scroll ── */
#gallery{padding:5rem 0;background:#2C2C2C;overflow:hidden;}
.gal-track-wrap{position:relative;overflow:hidden;cursor:grab;}
.gal-track-wrap:active{cursor:grabbing;}
.gal-track{display:flex;gap:1.5rem;width:max-content;animation:galScroll 40s linear infinite;padding:0 3rem;}
.gal-track:hover,.gal-track.paused{animation-play-state:paused;}
@keyframes galScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.gal-card{width:320px;flex-shrink:0;border-radius:16px;overflow:hidden;background:#1a1a1a;transition:transform .4s;}
.gal-card:hover{transform:translateY(-8px);}
.gal-img{height:220px;overflow:hidden;}
.gal-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.4,0,.2,1);}
.gal-card:hover .gal-img img{transform:scale(1.08);}
.gal-info{padding:1.2rem 1.4rem;}
.gal-name{font-family:var(--serif);font-size:1.2rem;color:#fff;margin-bottom:.4rem;}
.gal-desc{font-size:.75rem;color:rgba(255,255,255,.5);line-height:1.55;}

/* ── Contact ── */
#contact{padding:6rem 0;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;}
.ci-row{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.8rem;}
.ci-ico{width:2.8rem;height:2.8rem;border-radius:50%;background:rgba(196,112,90,.1);color:var(--terra);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;transition:all .3s;}
.ci-row:hover .ci-ico{background:var(--terra);color:#fff;}
.ci-lbl{font-size:.6rem;text-transform:uppercase;letter-spacing:.2em;color:var(--wg);margin-bottom:.2rem;}
.cf-box{background:#fff;padding:2.5rem;border-radius:20px;box-shadow:0 8px 40px rgba(0,0,0,.08);}
.fg{margin-bottom:1.2rem;}
.fg label{display:block;font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--wg);margin-bottom:.45rem;}
.fg input,.fg select,.fg textarea{width:100%;border:1.5px solid var(--lg);border-radius:8px;padding:.72rem 1rem;font-size:.85rem;font-family:var(--sans);color:var(--charcoal);outline:none;transition:border-color .3s,box-shadow .3s;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--terra);box-shadow:0 0 0 3px rgba(196,112,90,.1);}
.fg textarea{resize:none;}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}

/* ── Footer ── */
#footer{background:var(--charcoal);color:#fff;padding:5rem 0 2rem;}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:3rem;}
.ft-logo{font-family:var(--serif);font-size:2rem;margin-bottom:1rem;}
.ft-desc{font-size:.83rem;color:rgba(255,255,255,.5);line-height:1.8;max-width:340px;margin-bottom:1.5rem;}
/* EU funding badge */
.eu-badge{display:flex;align-items:center;gap:1rem;background:rgba(0,51,153,.25);border:1px solid rgba(0,100,220,.3);border-radius:10px;padding:.9rem 1.2rem;margin-top:1.2rem;}
.eu-stars{color:#FFD700;font-size:.9rem;letter-spacing:.2em;flex-shrink:0;}
.eu-title{font-size:.72rem;font-weight:700;color:rgba(255,255,255,.9);letter-spacing:.05em;}
.eu-sub{font-size:.62rem;color:rgba(255,255,255,.5);margin-top:.1rem;}
.fh{font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1.1rem;}
.flinks{list-style:none;}
.flinks li{margin-bottom:.55rem;}
.flinks a{font-size:.85rem;color:rgba(255,255,255,.7);text-decoration:none;transition:color .3s;}
.flinks a:hover{color:var(--terra);}
.ft-btm{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(255,255,255,.1);padding-top:1.8rem;}
.ft-btm p{font-size:.68rem;color:rgba(255,255,255,.3);letter-spacing:.1em;}
.fsoc{width:2.4rem;height:2.4rem;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;text-decoration:none;transition:background .3s;}
.fsoc:hover{background:var(--terra);}

/* ── Modals ── */
.overlay{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;visibility:hidden;transition:all .4s;}
.overlay.active{opacity:1;visibility:visible;}
.ob{position:absolute;inset:0;background:rgba(44,44,44,.85);backdrop-filter:blur(6px);cursor:pointer;}
.mbox{position:relative;background:var(--cream);border-radius:20px;width:100%;max-height:90vh;overflow-y:auto;transform:scale(.95) translateY(20px);transition:transform .4s;}
.overlay.active .mbox{transform:scale(1) translateY(0);}
.mx{position:absolute;top:1rem;right:1rem;z-index:10;width:2.3rem;height:2.3rem;border-radius:50%;background:rgba(255,255,255,.85);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--charcoal);transition:all .3s;}
.mx:hover{background:var(--terra);color:#fff;}

/* Booking modal */
.bk-grid{display:grid;grid-template-columns:1fr 1fr;}
.bk-img{position:relative;min-height:300px;}
.bk-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.bk-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(44,44,44,.6),transparent 60%);}
.bk-lbl{position:absolute;bottom:1.5rem;left:1.5rem;color:#fff;z-index:2;}
.bk-lbl small{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;opacity:.8;display:block;margin-bottom:.3rem;}
.bk-lbl h3{font-family:var(--serif);font-size:1.4rem;}
.bk-form{padding:2rem;}

/* Price box */
.price-box{background:#fff;border-radius:12px;padding:1.2rem;margin:1rem 0;}
.pr{display:flex;justify-content:space-between;font-size:.83rem;padding:.4rem 0;border-bottom:1px solid var(--lg);}
.pr:last-child{border:none;}
.pr-l{color:var(--wg);}
.pr-tot{font-family:var(--serif);font-size:1.2rem;padding-top:.8rem;}
.pr-tot span:last-child{color:var(--terra);font-weight:600;}
.wmsg{font-size:.72rem;color:#c0392b;background:#fdf0ef;border-radius:6px;padding:.5rem .9rem;margin:.4rem 0;display:none;}
.wmsg.on{display:block;}

/* Room detail modal */
.rd-img{position:relative;height:18rem;}
.rd-img img{width:100%;height:100%;object-fit:cover;}
.rd-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(44,44,44,.55),transparent 60%);}
.rd-ov{position:absolute;bottom:1.5rem;left:1.5rem;color:#fff;z-index:2;}
.rd-ov h2{font-family:var(--serif);font-size:2rem;}
.rd-ov p{font-size:.9rem;opacity:.9;margin-top:.3rem;}
.amen-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin:1.5rem 0;}
.amen{text-align:center;background:var(--cream);border-radius:10px;padding:.9rem .5rem;}
.amen i{color:var(--terra);margin-bottom:.4rem;display:block;}
.amen span{font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;}

/* ── Toast ── */
#toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:600;background:var(--charcoal);color:#fff;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.25);display:flex;align-items:center;gap:.75rem;font-size:.85rem;font-weight:500;transform:translateX(130%);transition:transform .4s cubic-bezier(.4,0,.2,1);}
#toast.show{transform:translateX(0);}
#t-ico{color:var(--terra);font-size:1.1rem;}
#toast.err #t-ico{color:#e74c3c;}

/* ── Reveal ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease;}
.reveal.active{opacity:1;transform:translateY(0);}

/* ── Responsive ── */
@media(max-width:1024px){
  .apts-grid,.exp-grid,.ft-grid{grid-template-columns:1fr 1fr;}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:3rem;}
  .bk-grid{grid-template-columns:1fr;}
  .bk-img{min-height:220px;}
  .container{padding:0 2rem;}
}
@media(max-width:768px){
  #nav{padding:1rem 1.5rem;}
  #nav.scrolled{padding:.75rem 1.5rem;}
  .nav-links{display:none;}
  .burger{display:block;}
  #about,#apartments,#experience,#contact{padding:4rem 0;}
  #qbook{padding:0 1.5rem 3.5rem;}
  .qb-grid{grid-template-columns:1fr 1fr;}
  .apts-grid,.exp-grid{grid-template-columns:1fr;}
  .amen-grid{grid-template-columns:repeat(2,1fr);}
  .ft-grid{grid-template-columns:1fr;}
  .fr2{grid-template-columns:1fr;}
  .container{padding:0 1.5rem;}
  .gal-card{width:260px;}
}
@media(max-width:480px){
  .qb-grid{grid-template-columns:1fr;}
  .hero-ctas{flex-direction:column;align-items:center;}
}
