/* ============================================================
   LAMACUPA — Design system condiviso (Direzione Premium dorato)
   ============================================================ */
:root{
  --cream:#f8f3e7;
  --cream-2:#f1e9d6;
  --paper:#fcf9f0;
  --olive:#34401f;
  --olive-deep:#27300f;
  --olive-soft:#5c6b3c;
  --gold:#b88a3e;
  --gold-deep:#9a6f2c;
  --ink:#2b2a20;
  --ink-soft:#5f5c4d;
  --line:rgba(52,64,31,.16);
  --maxw:1280px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',system-ui,sans-serif;
  background:var(--cream);
  color:var(--ink);
  font-weight:400;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.eyebrow{font-size:13px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;color:var(--gold-deep)}
h1,h2,h3{font-weight:500;line-height:1.08;letter-spacing:-.01em;color:var(--olive)}

.btn{display:inline-flex;align-items:center;gap:10px;font-family:inherit;font-size:14px;
  letter-spacing:.16em;text-transform:uppercase;font-weight:500;cursor:pointer;border:none;
  padding:16px 30px;border-radius:2px;transition:.25s}
.btn-solid{background:var(--olive);color:var(--cream)}
.btn-solid:hover{background:var(--olive-deep)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-deep)}
.btn-ghost{background:transparent;border:1px solid var(--olive);color:var(--olive)}
.btn-ghost:hover{background:var(--olive);color:var(--cream)}

/* announcement */
.announce{background:var(--olive-deep);color:var(--cream);text-align:center;
  font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;padding:9px 20px}
.announce b{color:var(--gold)}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(248,243,231,.9);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand{display:flex;align-items:baseline;gap:10px}
.brand .mark{font-size:25px;font-weight:600;letter-spacing:.18em;color:var(--olive)}
.brand .tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-deep)}
.menu{display:flex;gap:24px;list-style:none}
.menu a{font-size:14px;letter-spacing:.04em;color:var(--ink);position:relative;padding:4px 0;white-space:nowrap}
.menu a::after{content:'';position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--gold);transition:.3s}
.menu a:hover,.menu a.active{color:var(--olive)}
.menu a:hover::after,.menu a.active::after{width:100%}
.nav-right{display:flex;align-items:center;gap:16px}
.lang{font-size:12px;letter-spacing:.12em;color:var(--ink-soft);cursor:pointer;background:none;border:none;font-family:inherit}
.lang b{color:var(--olive)}
.icnbtn{display:flex;align-items:center;gap:7px;font-size:13px;letter-spacing:.08em;color:var(--olive)}
.cart-count{background:var(--gold);color:#fff;font-size:11px;font-weight:600;width:18px;height:18px;
  border-radius:50%;display:grid;place-items:center}
.burger{display:none;background:none;border:none;cursor:pointer;color:var(--olive)}

/* generic section */
section.block{padding:108px 0}
.center{text-align:center;max-width:760px;margin:0 auto}
.center h2{font-size:clamp(32px,4.2vw,52px);font-weight:400;margin:16px 0 0}
.center p.lead{font-size:20px;color:var(--ink-soft);margin-top:24px;line-height:1.7}
.center .eyebrow{display:block}

/* page banner (inner pages) */
.pagehero{position:relative;min-height:46vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--olive-deep)}
.pagehero image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.pagehero::after{content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,26,8,.2),rgba(20,26,8,.66))}
.pagehero .inner{position:relative;z-index:2;width:100%;padding:0 0 56px}
.pagehero .eyebrow{color:var(--gold)}
.pagehero h1{color:#fbf7ec;font-size:clamp(38px,5.2vw,68px);font-weight:400;max-width:18ch;margin-top:14px;
  text-shadow:0 2px 30px rgba(0,0,0,.3)}
.pagehero h1 em{font-style:italic;color:var(--gold)}
.crumb{font-size:13px;letter-spacing:.06em;color:var(--ink-soft);padding:18px 0}
.crumb a:hover{color:var(--olive)}
.crumb span{color:var(--gold-deep)}

/* prose */
.prose{max-width:760px;margin:0 auto}
.prose p{font-size:17.5px;color:var(--ink-soft);margin-bottom:22px;line-height:1.8}
.prose p.intro{font-size:22px;color:var(--ink);line-height:1.6}
.prose h2{font-size:clamp(26px,3vw,38px);font-weight:400;margin:48px 0 18px}
.prose .pull{font-size:clamp(24px,3vw,34px);color:var(--olive);font-weight:400;line-height:1.4;
  border-left:3px solid var(--gold);padding:8px 0 8px 28px;margin:40px 0}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.split.rev .media{order:2}
.split .media{min-height:560px;position:relative}
.split .media image-slot{position:absolute;inset:0;width:100%;height:100%}
.split .body{padding:90px clamp(40px,6vw,96px);display:flex;flex-direction:column;justify-content:center}
.split .body h2{font-size:clamp(30px,3.6vw,46px);font-weight:400;margin:18px 0 0}
.split .body p{font-size:17px;color:var(--ink-soft);margin-top:22px}

/* trust strip */
.trust{background:var(--paper);border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.trust-item{padding:30px 24px;text-align:center;border-right:1px solid var(--line)}
.trust-item:last-child{border-right:none}
.trust-item svg{margin:0 auto 12px;stroke:var(--gold-deep)}
.trust-item h4{font-size:15px;font-weight:500;color:var(--olive);letter-spacing:.04em}
.trust-item p{font-size:13px;color:var(--ink-soft);margin-top:3px}

/* product feature / detail */
.prod-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:70px;align-items:center}
.prod-media{position:relative;aspect-ratio:4/5;background:var(--cream-2);border-radius:4px;overflow:hidden}
.prod-media image-slot{position:absolute;inset:0;width:100%;height:100%}
.prod-badge{position:absolute;top:22px;left:22px;z-index:3;background:var(--olive);color:var(--cream);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:8px 14px;border-radius:2px}
.prod-body h2{font-size:clamp(34px,4.4vw,56px);font-weight:500;margin:14px 0 0;letter-spacing:-.02em}
.prod-sub{font-size:18px;color:var(--olive-soft);margin-top:8px;font-style:italic}
.prod-desc{font-size:16px;color:var(--ink-soft);margin-top:22px;max-width:52ch}
.tasting{display:flex;flex-direction:column;gap:14px;margin:30px 0;max-width:440px}
.tnote{display:grid;grid-template-columns:90px 1fr 64px;align-items:center;gap:14px}
.tnote>span{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)}
.tnote .bar{height:5px;background:var(--cream-2);border-radius:99px;overflow:hidden}
.tnote .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-deep));border-radius:99px}
.tnote .val{font-size:12px;color:var(--ink-soft);text-align:right}
.formats{display:flex;gap:10px;margin:26px 0 22px;flex-wrap:wrap}
.fmt{border:1px solid var(--line);background:var(--cream);padding:14px 20px;border-radius:3px;
  text-align:center;cursor:pointer;transition:.2s;min-width:84px}
.fmt:hover{border-color:var(--gold)}
.fmt.active{border-color:var(--olive);background:var(--olive);color:var(--cream)}
.fmt b{display:block;font-size:17px;font-weight:500}
.fmt small{font-size:12px;opacity:.7}
.buyrow{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.price{font-size:34px;font-weight:500;color:var(--olive)}
.price small{font-size:15px;color:var(--ink-soft);font-weight:400}

/* spec table */
.specs{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line);margin-top:10px}
.specs div{padding:16px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;padding-right:24px}
.specs div:nth-child(even){padding-left:24px;padding-right:0}
.specs dt{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep)}
.specs dd{font-size:15px;color:var(--ink);text-align:right}

/* band */
.band{background:var(--olive-deep);color:var(--cream);position:relative;overflow:hidden}
.band .eyebrow{color:var(--gold)}
.band-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
.band h2{color:#fbf7ec;font-size:clamp(30px,3.8vw,48px);font-weight:400;margin:16px 0 24px}
.band p{color:rgba(248,243,231,.82);font-size:17px;max-width:50ch}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:42px}
.stat b{display:block;font-size:46px;font-weight:500;color:var(--gold);line-height:1}
.stat span{font-size:14px;letter-spacing:.04em;color:rgba(248,243,231,.7);margin-top:8px;display:block}
.band-media{position:relative;aspect-ratio:1;border-radius:4px;overflow:hidden}
.band-media image-slot{position:absolute;inset:0;width:100%;height:100%}

/* cards grid (shop / products) */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:5px;overflow:hidden;transition:.25s;cursor:pointer}
.card:hover{transform:translateY(-5px);box-shadow:0 18px 40px -22px rgba(52,64,31,.45)}
.card-media{aspect-ratio:3/4;position:relative;background:var(--cream-2)}
.card-media image-slot{position:absolute;inset:0;width:100%;height:100%}
.card-tag{position:absolute;top:12px;left:12px;z-index:3;background:var(--gold);color:#fff;
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:5px 10px;border-radius:2px}
.card-body{padding:22px}
.card-body h4{font-size:18px;font-weight:500;color:var(--olive)}
.card-body .ct{font-size:13px;color:var(--olive-soft);margin-top:3px}
.card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:18px}
.card-foot .p{font-size:18px;font-weight:500;color:var(--ink)}
.card-foot .add{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:500}

.shop-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;flex-wrap:wrap;gap:20px}
.shop-head h2{font-size:clamp(30px,3.8vw,48px);font-weight:400}

/* premi */
.premi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:56px}
.award{padding:38px 24px;border:1px solid var(--line);border-radius:4px;background:var(--cream);transition:.25s;text-align:center}
.award:hover{border-color:var(--gold);transform:translateY(-4px)}
.award .medal{width:54px;height:54px;margin:0 auto 18px;border-radius:50%;border:2px solid var(--gold);
  display:grid;place-items:center;color:var(--gold-deep)}
.award h4{font-size:17px;font-weight:500;color:var(--olive)}
.award p{font-size:13px;color:var(--ink-soft);margin-top:6px;letter-spacing:.03em}

/* premi list (detailed) */
.awardlist{display:flex;flex-direction:column;gap:0;margin-top:20px}
.awardrow{display:grid;grid-template-columns:120px 1fr auto;gap:32px;align-items:center;
  padding:30px 0;border-bottom:1px solid var(--line)}
.awardrow .yr{font-size:30px;font-weight:500;color:var(--gold)}
.awardrow h4{font-size:21px;font-weight:500;color:var(--olive)}
.awardrow p{font-size:15px;color:var(--ink-soft);margin-top:4px}
.awardrow .rank{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);
  border:1px solid var(--line);padding:8px 14px;border-radius:99px;white-space:nowrap}

/* notes / blog */
.notes{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:52px}
.note{cursor:pointer}
.note-media{aspect-ratio:3/2;position:relative;border-radius:5px;overflow:hidden;background:var(--cream-2)}
.note-media image-slot{position:absolute;inset:0;width:100%;height:100%}
.note .date{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);margin:18px 0 8px}
.note h4{font-size:21px;font-weight:500;color:var(--olive);line-height:1.25}
.note:hover h4{color:var(--gold-deep)}
.note p{font-size:15px;color:var(--ink-soft);margin-top:8px}

/* newsletter */
.news{background:var(--olive);color:var(--cream);text-align:center}
.news h2{color:#fbf7ec;font-size:clamp(28px,3.4vw,42px);font-weight:400}
.news p{color:rgba(248,243,231,.8);font-size:17px;margin:18px auto 30px;max-width:52ch}
.news .eyebrow{color:var(--gold)}
.news form{display:flex;gap:12px;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.news input{flex:1;min-width:240px;padding:16px 20px;border:1px solid rgba(248,243,231,.3);
  background:rgba(248,243,231,.07);color:var(--cream);font-family:inherit;font-size:15px;border-radius:2px}
.news input::placeholder{color:rgba(248,243,231,.55)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start}
.field{margin-bottom:20px}
.field label{display:block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:8px}
.field input,.field textarea{width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--paper);
  font-family:inherit;font-size:15px;color:var(--ink);border-radius:3px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.field textarea{min-height:140px;resize:vertical}
.info-block{margin-bottom:30px}
.info-block h4{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:8px}
.info-block p{font-size:17px;color:var(--ink)}
.info-block a:hover{color:var(--gold-deep)}
.mapbox{aspect-ratio:16/9;position:relative;border-radius:5px;overflow:hidden;background:var(--cream-2);margin-top:14px}
.mapbox image-slot{position:absolute;inset:0;width:100%;height:100%}

/* footer */
footer{background:var(--olive-deep);color:rgba(248,243,231,.75);padding:80px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px;
  border-bottom:1px solid rgba(248,243,231,.14)}
.foot-brand .mark{font-size:24px;font-weight:600;letter-spacing:.18em;color:var(--cream)}
.foot-brand p{font-size:14px;margin-top:18px;max-width:34ch;line-height:1.7}
.foot-col h5{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col a{font-size:14px}
.foot-col a:hover{color:var(--cream)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;
  font-size:12.5px;letter-spacing:.04em;flex-wrap:wrap;gap:14px}

/* hero (home) */
.hero{position:relative;height:88vh;min-height:600px;display:flex;align-items:flex-end;overflow:hidden;background:var(--olive-deep)}
.hero image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero::after{content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,26,8,.15),rgba(20,26,8,.05) 40%,rgba(20,26,8,.62))}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:64px}
.hero .eyebrow{color:var(--gold);margin-bottom:18px}
.hero h1{color:#fbf7ec;font-size:clamp(42px,6vw,82px);font-weight:400;max-width:14ch;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero p{color:rgba(251,247,236,.92);font-size:19px;max-width:46ch;margin:22px 0 30px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero .btn-ghost{border-color:rgba(251,247,236,.7);color:#fbf7ec}
.hero .btn-ghost:hover{background:#fbf7ec;color:var(--olive)}

/* orci */
.orci-grid{display:grid;grid-template-columns:1fr 1fr;align-items:center}
.orci-media{min-height:520px;position:relative}
.orci-media image-slot{position:absolute;inset:0;width:100%;height:100%}
.orci-body{padding:80px clamp(40px,6vw,90px)}
.orci-body h2{font-size:clamp(30px,3.6vw,46px);font-weight:400;margin:16px 0 0}
.orci-body p{font-size:17px;color:var(--ink-soft);margin-top:20px}

.statement .sig{margin-top:34px;font-size:15px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep)}

@media(max-width:980px){
  .menu,.lang{display:none}
  .burger{display:block}
  .split,.prod-grid,.band-grid,.orci-grid,.contact-grid{grid-template-columns:1fr}
  .split.rev .media{order:0}
  .trust-grid{grid-template-columns:1fr 1fr}
  .premi-row,.cards{grid-template-columns:1fr 1fr}
  .cards.c3{grid-template-columns:1fr 1fr}
  .notes{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .split .media,.orci-media{min-height:380px}
  .specs{grid-template-columns:1fr}
  .specs div:nth-child(even){padding-left:0}
  .awardrow{grid-template-columns:70px 1fr;gap:18px}
  .awardrow .rank{grid-column:2}
  section.block{padding:72px 0}
}
@media(max-width:560px){
  .wrap{padding:0 22px}
  .trust-grid,.premi-row,.cards,.cards.c3{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
}


/* =========================================================
   HERO SLIDESHOW (più slide, costruito da cms.js)
   ========================================================= */
.hero-has-slider > #a-hero,.hero-has-slider > .hero-inner{display:none}
.hero-slides{position:absolute;inset:0;z-index:2}
.hero-slide{position:absolute;inset:0;display:flex;align-items:flex-end;opacity:0;visibility:hidden;transition:opacity .8s ease}
.hero-slide.active{opacity:1;visibility:visible}
.hero-slide .hero-bg{position:absolute;inset:0;background:var(--olive-deep) center/cover no-repeat;z-index:0}
.hero-slide .hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,26,8,.15),rgba(20,26,8,.05) 40%,rgba(20,26,8,.62))}
.hero-slide .hero-inner{position:relative;z-index:2;display:block;width:100%}
.hero-dots{position:absolute;z-index:5;bottom:26px;left:50%;transform:translateX(-50%);display:flex;gap:10px}
.hero-dot{width:9px;height:9px;border-radius:50%;border:none;background:rgba(251,247,236,.45);cursor:pointer;padding:0;transition:.25s}
.hero-dot.active{background:var(--gold);width:26px;border-radius:99px}
.hero-nav{position:absolute;z-index:5;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;
  border:1px solid rgba(251,247,236,.4);background:rgba(20,26,8,.25);color:#fbf7ec;display:grid;place-items:center;
  cursor:pointer;transition:.2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.hero-nav:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.hero-nav.prev{left:26px}
.hero-nav.next{right:26px}
@media(max-width:560px){.hero-nav{display:none}}
