
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{overflow-x:hidden}
:root{
  /* ─── Warm paper palette ─── */
  --paper:#F2E8D3;
  --paper-2:#EADEC0;
  --paper-3:#E2D3AE;
  --paper-dark:#D9C89D;
  /* dark panels */
  --espresso:#221812;
  --espresso-2:#2D2018;
  --olive-deep:#2F3A22;
  /* ink */
  --ink:#2B1E13;
  --ink-2:#5A4733;
  --ink-3:#8A7759;
  --ink-faint:#B2A385;
  /* accents */
  --olive:#4F5E30;
  --olive-dark:#3A4622;
  --terra:#B05434;
  --terra-dark:#8A3D24;
  --wine:#6B1E27;
  --brass:#9C7C3E;
  --brass-light:#C4A366;
  /* cream on dark */
  --cream:#F2E8D3;
  --cream-dim:#CFC0A0;
  --line:rgba(43,30,19,.14);
  --line-strong:rgba(43,30,19,.28);
  --line-on-dark:rgba(242,232,211,.14);
  /* typography */
  --display:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --serif:"Lora",Georgia,serif;
  --script:"Caveat",cursive;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --nav-h:72px;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ─── Subtle paper texture (SVG noise) on the cream body ─── */
body{
  font-family:var(--serif);
  font-size:17px;
  line-height:1.7;
  font-weight:400;
  color:var(--ink);
  background-color:var(--paper);
  background-image:
    radial-gradient(ellipse 90% 60% at 10% 0%, rgba(176,84,52,.05) 0%, transparent 60%),
    radial-gradient(ellipse 80% 60% at 90% 100%, rgba(79,94,48,.05) 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.2 0 0 0 0 0.15 0 0 0 0 0.1 0 0 0 0.035 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--paper-2)}
::-webkit-scrollbar-thumb{background:var(--olive);border-radius:99px}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}
img{max-width:100%;display:block}
h1,h2,h3,h4,h5{font-family:var(--display);font-weight:400;line-height:1.08;letter-spacing:-.005em;color:var(--ink)}
em,i{font-style:italic}
.page{display:none;animation:fade .5s var(--ease)}
.page.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ════════════════════════════════════════
   NAV
══════════════════════════════════════════ */
#site-nav{
  position:fixed;top:0;left:0;right:0;z-index:500;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  gap:clamp(1.5rem,3vw,3rem);
  padding:0 clamp(1.5rem,5vw,4rem);
  background:rgba(242,232,211,.92);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  transition:background .3s,border-color .3s;
}
.nav-logo{display:flex;align-items:center;gap:.75rem;cursor:pointer;flex-shrink:0}
.nav-logo svg{width:42px;height:42px;flex-shrink:0}
.nav-brand{font-family:var(--display);font-size:1.4rem;font-weight:500;color:var(--ink);letter-spacing:.01em;line-height:1;white-space:nowrap;font-style:italic}
.nav-links{display:flex;align-items:center;gap:clamp(1.6rem,2.6vw,2.4rem)}
.nav-link{font-family:var(--serif);font-size:.82rem;font-weight:500;letter-spacing:.08em;color:var(--ink-2);cursor:pointer;transition:color .2s;text-transform:uppercase;white-space:nowrap;position:relative}
.nav-link::after{content:'';position:absolute;bottom:-6px;left:50%;transform:translateX(-50%) scaleX(0);width:100%;height:1px;background:var(--olive);transition:transform .25s var(--ease);transform-origin:center}
.nav-link:hover{color:var(--olive-dark)}
.nav-link:hover::after{transform:translateX(-50%) scaleX(.7)}
.nav-btn{background:var(--olive-dark);color:var(--cream);padding:.7rem 1.4rem;border-radius:2px;font-family:var(--serif);font-size:.74rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;transition:all .2s;white-space:nowrap}
.nav-btn:hover{background:var(--espresso);transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--ink);transition:all .3s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-nav{display:none;position:fixed;top:var(--nav-h);left:0;right:0;z-index:499;background:var(--paper);border-bottom:1px solid var(--line);padding:1.5rem clamp(1.5rem,5vw,4rem) 2rem;flex-direction:column}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--ink);cursor:pointer;padding:.9rem 0;border-bottom:1px solid var(--line);transition:color .2s}
.mobile-nav a:last-child{border-bottom:none}
.mobile-nav a:hover{color:var(--olive)}
.mobile-nav a.mobile-cta{margin-top:1.5rem;background:var(--olive-dark);color:var(--cream);padding:1rem;text-align:center;border-radius:2px;font-family:var(--serif);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;font-style:normal;border-bottom:none}
.mobile-nav a.mobile-cta:hover{color:var(--cream);background:var(--olive)}

/* ════════════════════════════════════════
   REUSABLE TYPOGRAPHY PRIMITIVES
══════════════════════════════════════════ */
.ital-script{font-family:var(--script);font-style:normal;font-weight:400}
.kicker{font-family:var(--serif);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--terra-dark);font-weight:500;display:inline-block}
.kicker-olive{color:var(--olive)}
.chapter-mark{font-family:var(--display);font-style:italic;font-size:.95rem;color:var(--ink-3);letter-spacing:.08em;display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem}
.chapter-mark::before{content:'';width:28px;height:1px;background:var(--ink-faint)}
.chapter-num{font-family:var(--display);font-weight:300;font-style:italic;color:var(--terra);font-size:1.1rem}
.h-display{font-family:var(--display);font-weight:300;font-style:italic;line-height:1}
.h-serif{font-family:var(--serif);font-weight:500}
.drop-cap::first-letter{
  font-family:var(--display);
  font-style:italic;
  font-weight:400;
  font-size:4.6em;
  float:left;
  line-height:.85;
  padding:.1em .12em 0 0;
  color:var(--terra);
}
.ornament{text-align:center;display:flex;align-items:center;justify-content:center;gap:1rem;color:var(--ink-faint);font-family:var(--display);font-style:italic}
.ornament::before,.ornament::after{content:'';flex:1;max-width:80px;height:1px;background:var(--line-strong)}
.ornament-dark::before,.ornament-dark::after{background:var(--line-on-dark)}
.ornament-dark{color:var(--cream-dim)}

/* ════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--serif);font-size:.78rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;padding:1rem 2.2rem;transition:all .25s var(--ease);cursor:pointer;border-radius:2px;line-height:1;text-decoration:none}
.btn-primary{background:var(--olive-dark);color:var(--cream);border:1px solid var(--olive-dark)}
.btn-primary:hover{background:var(--espresso);border-color:var(--espresso);transform:translateY(-1px);box-shadow:0 10px 28px rgba(47,58,34,.3)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}
.btn-outline:hover{border-color:var(--olive-dark);color:var(--olive-dark);transform:translateY(-1px)}
.btn-on-dark{background:var(--paper);color:var(--ink);border:1px solid var(--paper)}
.btn-on-dark:hover{background:var(--paper-2);border-color:var(--paper-2)}
.btn-outline-light{background:transparent;color:var(--cream);border:1px solid rgba(242,232,211,.35)}
.btn-outline-light:hover{border-color:var(--cream);background:rgba(242,232,211,.06)}
.btn-arrow{transition:transform .25s}
.btn:hover .btn-arrow{transform:translateX(4px)}
.btn-text{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--terra-dark);font-weight:500;cursor:pointer;transition:gap .25s}
.btn-text:hover{gap:1rem;color:var(--wine)}
.btn-text-olive{color:var(--olive-dark)}
.btn-text-light{color:var(--brass-light)}

/* ════════════════════════════════════════
   BREADCRUMB
══════════════════════════════════════════ */
.crumb{padding:calc(var(--nav-h) + .8rem) clamp(1.5rem,5vw,4rem) .8rem;font-family:var(--serif);font-size:.72rem;letter-spacing:.14em;color:var(--ink-3);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;text-transform:uppercase}
.crumb span{cursor:pointer;transition:color .2s}
.crumb span:hover{color:var(--terra-dark)}
.crumb .sep{color:var(--ink-faint)}

/* ════════════════════════════════════════
   HOME — HERO
══════════════════════════════════════════ */
.hero-italian{
  min-height:100vh;
  min-height:100svh;
  padding:var(--nav-h) 0 0;
  display:grid;
  grid-template-columns:1fr 1.1fr;
  align-items:stretch;
  position:relative;
  background:var(--paper);
}
.hero-text{
  padding:clamp(3rem,7vw,6rem) clamp(1.8rem,5vw,4.5rem);
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
  z-index:2;
}
.hero-greeting{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1.8rem;width:fit-content}
.hero-buongiorno{
  font-family:var(--script);
  font-size:clamp(1.8rem,3vw,2.4rem);
  color:var(--terra);
  transform:rotate(-2deg);
  transform-origin:left center;
  display:inline-block;
  line-height:1.2;
  align-self:flex-start;
}
@media(min-width:720px){
  .hero-greeting{flex-direction:row;align-items:baseline;gap:1.2rem;flex-wrap:wrap}
  .hero-buongiorno{line-height:1}
}
.hero-ital-line{
  font-family:var(--display);
  font-style:italic;
  font-size:clamp(.95rem,1.5vw,1.1rem);
  color:var(--ink-3);
  letter-spacing:.02em;
  line-height:1.3;
  align-self:flex-start;
}
.hero-headline{
  font-family:var(--display);
  font-size:clamp(3rem,6.5vw,6rem);
  font-weight:300;
  line-height:1;
  letter-spacing:-.015em;
  color:var(--ink);
  margin-bottom:1.8rem;
}
.hero-headline em{font-style:italic;color:var(--terra-dark);font-weight:400}
.hero-headline-2{display:block;font-weight:400;font-style:italic}
.hero-body{font-family:var(--serif);font-size:clamp(1rem,1.4vw,1.1rem);color:var(--ink-2);line-height:1.75;max-width:490px;margin-bottom:2.2rem;font-weight:400}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.hero-sig{display:flex;align-items:baseline;gap:1rem;padding-top:1.8rem;border-top:1px solid var(--line);max-width:490px}
.hero-sig-label{font-family:var(--serif);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-weight:500;flex-shrink:0}
.hero-sig-signature{font-family:var(--script);font-size:1.35rem;color:var(--ink);line-height:1}

.hero-visual{
  position:relative;
  overflow:hidden;
  background:var(--paper-2);
  min-height:45vh;
}
.hero-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-visual::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(to bottom left,rgba(34,24,18,.15) 0%,transparent 50%);
  z-index:1;
}

/* Wax seal floating on hero */
.wax-seal{
  position:absolute;
  bottom:clamp(1.5rem,4vw,3.5rem);
  right:clamp(1.5rem,4vw,3.5rem);
  width:clamp(110px,14vw,170px);
  height:clamp(110px,14vw,170px);
  z-index:3;
  animation:sealFloat 6s ease-in-out infinite;
  filter:drop-shadow(0 14px 28px rgba(34,24,18,.35));
}
@keyframes sealFloat{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-6px) rotate(-4deg)}}

/* ════════════════════════════════════════
   MARQUEE
══════════════════════════════════════════ */
.marq-wrap{background:var(--olive-deep);padding:1rem 0;overflow:hidden;border-top:1px solid var(--line-on-dark);border-bottom:1px solid var(--line-on-dark)}
.marq-track{display:flex;width:max-content;animation:marq 40s linear infinite}
.marq-item{white-space:nowrap;padding:0 2.5rem;font-family:var(--display);font-style:italic;font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--cream-dim);display:flex;align-items:center;gap:2.5rem}
.marq-item::after{content:'❋';color:var(--brass-light);font-size:.9em;opacity:.7;font-style:normal}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ════════════════════════════════════════
   SECTION: IL NOSTRO CREDO (story intro)
══════════════════════════════════════════ */
.credo{padding:clamp(5rem,9vw,8rem) clamp(1.8rem,5vw,4rem)}
.credo-inner{max-width:820px;margin:0 auto;text-align:center}
.credo h2{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(2.6rem,5.5vw,4.5rem);
  letter-spacing:-.01em;line-height:1.05;color:var(--ink);
  margin:1.2rem 0 2rem;
}
.credo-body{
  font-family:var(--serif);font-size:clamp(1.05rem,1.5vw,1.2rem);line-height:1.85;
  color:var(--ink-2);text-align:left;
}
.credo-body p{margin-bottom:1.3rem}
.credo-body p:last-child{margin-bottom:0}
.credo-sig{margin-top:3rem;font-family:var(--script);font-size:1.6rem;color:var(--terra-dark)}

/* ════════════════════════════════════════
   PRODUCT CHAPTERS (editorial spread)
══════════════════════════════════════════ */
.chapter{padding:clamp(4rem,7vw,7rem) clamp(1.8rem,5vw,4rem)}
.chapter-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:center;max-width:1300px;margin:0 auto}
.chapter-grid.reverse{direction:rtl}
.chapter-grid.reverse > *{direction:ltr}
.chapter-img-wrap{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--paper-2);border-radius:2px;box-shadow:0 30px 60px rgba(34,24,18,.12),0 0 0 1px var(--line)}
.chapter-img-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.chapter-grid:hover .chapter-img-wrap img{transform:scale(1.03)}
.chapter-img-wrap::after{
  content:'';position:absolute;inset:1.2rem;border:1px solid rgba(242,232,211,.35);pointer-events:none;border-radius:1px;
}
.chapter-label{position:absolute;bottom:1.8rem;left:1.8rem;background:var(--paper);padding:.55rem 1.1rem;font-family:var(--display);font-style:italic;font-size:.95rem;color:var(--ink);z-index:2;border-radius:2px;box-shadow:0 4px 14px rgba(34,24,18,.2)}
.chapter-text{padding:1rem 0}
.chapter-text .chapter-mark{margin-bottom:1.2rem}
.chapter-text h2{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(2.6rem,5vw,4.3rem);line-height:1;letter-spacing:-.01em;
  color:var(--ink);margin-bottom:.4rem;
}
.chapter-sub{font-family:var(--serif);font-size:1rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:500;margin-bottom:1.8rem}
.chapter-body{font-family:var(--serif);font-size:1.02rem;line-height:1.8;color:var(--ink-2);margin-bottom:1.3rem}
.chapter-body.drop-cap::first-letter{color:var(--terra)}
.chapter-meta{display:flex;gap:2.5rem;margin:2rem 0;flex-wrap:wrap}
.chapter-meta div{flex:1;min-width:100px}
.chapter-meta .meta-num{font-family:var(--display);font-style:italic;font-size:2.1rem;color:var(--olive-dark);line-height:1;font-weight:400}
.chapter-meta .meta-label{font-family:var(--serif);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-top:.3rem;font-weight:500}

/* ════════════════════════════════════════
   TRADIZIONE (dark panel with seals)
══════════════════════════════════════════ */
.tradizione{
  background:var(--espresso);
  color:var(--cream);
  padding:clamp(5rem,9vw,8rem) clamp(1.8rem,5vw,4rem);
  position:relative;
  overflow:hidden;
}
.tradizione::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.95 0 0 0 0 0.9 0 0 0 0 0.8 0 0 0 0.045 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.5;pointer-events:none;
}
.trad-inner{max-width:1100px;margin:0 auto;position:relative}
.trad-head{text-align:center;margin-bottom:4rem}
.trad-head h2{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(2.6rem,5.5vw,4.5rem);color:var(--cream);
  margin:1rem 0 1.5rem;line-height:1.05;
}
.trad-head p{max-width:560px;margin:0 auto;color:var(--cream-dim);font-size:1.05rem;line-height:1.8}
.trad-seals{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(2rem,4vw,3.5rem);margin-top:3.5rem}
.seal{text-align:center;padding:1rem}
.seal svg{width:100px;height:100px;margin:0 auto 1.4rem;display:block}
.seal-n{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(2.8rem,5vw,3.8rem);color:var(--brass-light);line-height:1;margin-bottom:.4rem}
.seal-l{font-family:var(--serif);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:.8rem;font-weight:500}
.seal-txt{font-family:var(--display);font-style:italic;font-size:1rem;color:var(--cream);line-height:1.5;max-width:230px;margin:0 auto}

/* ════════════════════════════════════════
   LA BOTTEGA (shop teaser)
══════════════════════════════════════════ */
.bottega{padding:clamp(5rem,9vw,8rem) clamp(1.8rem,5vw,4rem);background:var(--paper-2)}
.bottega-inner{max-width:1200px;margin:0 auto}
.bottega-head{text-align:center;margin-bottom:3.5rem;max-width:680px;margin-left:auto;margin-right:auto}
.bottega-head h2{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(2.4rem,5vw,4rem);color:var(--ink);
  margin:1rem 0 1.2rem;line-height:1.05;
}
.bottega-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:1.5rem}
.bottega-grid > div:first-child{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.bottega-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:3px;
  overflow:hidden;
  cursor:pointer;
  transition:all .4s var(--ease);
  display:flex;
  flex-direction:column;
}
.bottega-card:hover{transform:translateY(-5px);box-shadow:0 22px 44px rgba(34,24,18,.15);border-color:var(--line-strong)}
.bottega-card-img{aspect-ratio:4/3;overflow:hidden;background:var(--paper-2);position:relative}
.bottega-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.bottega-card:hover .bottega-card-img img{transform:scale(1.06)}
.bottega-card-body{padding:1.7rem 1.7rem 1.8rem;flex:1;display:flex;flex-direction:column}
.bottega-card-ital{font-family:var(--display);font-style:italic;font-size:.9rem;color:var(--terra-dark);margin-bottom:.35rem;letter-spacing:.01em}
.bottega-card-ital::before{content:'— '}
.bottega-card h3{font-family:var(--display);font-style:italic;font-weight:400;font-size:clamp(1.5rem,2.2vw,1.85rem);color:var(--ink);margin-bottom:.6rem;line-height:1.1}
.bottega-card p{font-family:var(--serif);font-size:.93rem;line-height:1.7;color:var(--ink-2);margin-bottom:1.3rem;flex:1}
.bottega-card .btn-text{font-size:.72rem}
.bottega-card.featured{grid-row:span 2;display:grid;grid-template-rows:auto 1fr}
.bottega-card.featured .bottega-card-img{aspect-ratio:unset;height:100%;min-height:280px}
.bottega-card.featured.bottega-card-text{
  grid-row:span 2;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg, #E8E1D2 0%, #DDD3B8 100%);
  border:1px solid rgba(79,94,48,.15);
  min-height:380px;
  padding:2rem;
}
.bottega-card.featured.bottega-card-text .bottega-card-body{
  padding:1.5rem;
  flex:0;
  display:block;
  text-align:center;
  max-width:380px;
}
.bottega-card.featured.bottega-card-text .bottega-card-ital{
  font-family:var(--script);
  color:var(--terra);
  font-size:1.4rem;
  margin-bottom:1rem;
  line-height:1.3;
}
.bottega-card.featured.bottega-card-text h3{
  font-family:var(--display);
  font-style:italic;
  font-weight:400;
  font-size:clamp(1.6rem,2.5vw,2rem);
  color:var(--ink);
  margin:0 0 1rem;
  letter-spacing:-.01em;
}
.bottega-card.featured.bottega-card-text p{
  font-family:var(--serif);
  color:var(--ink-2);
  font-size:1rem;
  line-height:1.7;
  margin:0;
}

/* ════════════════════════════════════════
   TESTIMONIAL BAND
══════════════════════════════════════════ */
.testimonial{padding:clamp(5rem,9vw,7rem) clamp(1.8rem,5vw,4rem);background:var(--paper)}
.testimonial-inner{max-width:900px;margin:0 auto;text-align:center}
.quote-mark{font-family:var(--display);font-size:6rem;color:var(--terra);line-height:.5;font-style:italic;display:block;margin-bottom:-.5rem}
.testimonial blockquote{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(1.6rem,3.2vw,2.6rem);line-height:1.35;color:var(--ink);
  letter-spacing:-.005em;max-width:760px;margin:0 auto;
}
.testimonial-cite{margin-top:2.2rem;font-family:var(--serif);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.testimonial-cite span{color:var(--terra-dark)}

/* ════════════════════════════════════════
   CTA BAND (deep espresso)
══════════════════════════════════════════ */
.cta-band{
  padding:clamp(5rem,10vw,9rem) clamp(1.8rem,5vw,4rem);
  background:var(--espresso);
  color:var(--cream);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.95 0 0 0 0 0.9 0 0 0 0 0.8 0 0 0 0.045 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.55;pointer-events:none;
}
.cta-band-inner{max-width:780px;margin:0 auto;position:relative}
.cta-band .script-head{font-family:var(--script);color:var(--brass-light);font-size:clamp(1.6rem,2.6vw,2.2rem);display:block;margin-bottom:.5rem;transform:rotate(-2deg)}
.cta-band h2{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(2.6rem,6vw,5.5rem);line-height:1;letter-spacing:-.015em;
  color:var(--cream);margin-bottom:1.5rem;
}
.cta-band p{color:var(--cream-dim);font-size:clamp(1rem,1.5vw,1.15rem);line-height:1.8;max-width:560px;margin:0 auto 2.5rem}
.cta-band .btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
.foot{background:var(--paper-2);padding:clamp(3rem,6vw,5rem) clamp(1.8rem,5vw,4rem) 2rem;border-top:1px solid var(--line)}
.foot-ornament{text-align:center;margin-bottom:3rem}
.foot-ornament svg{width:100px;height:28px;display:inline-block;opacity:.5}
.foot-top{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.foot-brand .foot-ital{font-family:var(--script);color:var(--terra);font-size:1.3rem;display:block;margin-bottom:.3rem}
.foot-brand .foot-name{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--ink);display:block;margin-bottom:.8rem}
.foot-brand p{font-family:var(--serif);font-size:.88rem;color:var(--ink-2);line-height:1.7;max-width:260px;margin-bottom:1rem}
.foot-brand .foot-mail{color:var(--terra-dark);font-family:var(--serif);font-style:italic;font-size:.95rem;transition:color .2s}
.foot-brand .foot-mail:hover{color:var(--wine)}
.foot-col h5{font-family:var(--serif);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);margin-bottom:1rem;font-weight:500}
.foot-col a{display:block;font-family:var(--serif);color:var(--ink-2);font-size:.92rem;margin-bottom:.55rem;cursor:pointer;transition:color .2s}
.foot-col a:hover{color:var(--terra-dark)}
.foot-bot{border-top:1px solid var(--line);padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-family:var(--serif);font-size:.78rem;color:var(--ink-3)}
.foot-bot .foot-sig{font-family:var(--script);color:var(--terra);font-size:1.05rem}

/* ════════════════════════════════════════
   PRODUCT DETAIL PAGE (PDP) — Parm + Olivolja
══════════════════════════════════════════ */
.pdp-hero{
  position:relative;
  min-height:92vh;
  padding-top:var(--nav-h);
  display:grid;
  grid-template-columns:1.05fr .95fr;
  align-items:stretch;
  background:var(--paper);
}
.pdp-hero-img-side{position:relative;overflow:hidden;background:var(--paper-2)}
.pdp-hero-img-side > img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pdp-hero-img-side::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 60%,rgba(242,232,211,.18) 100%);pointer-events:none}
/* Product spotlight section — clean catalog-style presentation */
.prodotto-sec{
  padding:clamp(4rem,7vw,7rem) clamp(1.8rem,5vw,4rem);
  background:var(--paper-2);
  position:relative;
  overflow:hidden;
}
.prodotto-sec::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(to right,transparent,var(--line-strong),transparent);
}
.prodotto-sec::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(to right,transparent,var(--line-strong),transparent);
}
.prodotto-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,5vw,5rem);
  align-items:center;position:relative;
}
.prodotto-card{
  position:relative;
  aspect-ratio:4/5;
  background:
    linear-gradient(135deg,var(--paper) 0%,var(--paper-3) 100%);
  border:1px solid var(--line-strong);
  border-radius:3px;
  padding:2rem;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:
    0 30px 60px rgba(34,24,18,.15),
    0 0 0 8px var(--paper-2),
    0 0 0 9px var(--line);
  transform:rotate(-1deg);
  transition:transform .5s var(--ease);
}
.prodotto-card:hover{transform:rotate(0deg) scale(1.02)}
.prodotto-card img{
  max-width:80%;max-height:90%;
  object-fit:contain;
  filter:drop-shadow(0 20px 30px rgba(34,24,18,.2));
}
.prodotto-card .prod-corner{
  position:absolute;font-family:var(--display);font-style:italic;
  color:var(--terra);font-size:1rem;
}
.prodotto-card .corner-tl{top:.9rem;left:1.1rem}
.prodotto-card .corner-br{bottom:.9rem;right:1.1rem;transform:rotate(180deg)}
.prodotto-card .prod-label{
  position:absolute;bottom:-1.5rem;left:50%;transform:translateX(-50%);
  background:var(--espresso);color:var(--cream);
  font-family:var(--display);font-style:italic;font-size:.95rem;
  padding:.5rem 1.5rem;border-radius:2px;
  box-shadow:0 10px 20px rgba(34,24,18,.25);
  white-space:nowrap;
  letter-spacing:.02em;
}
.prodotto-text h2{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(2rem,4.5vw,3.5rem);line-height:1.05;margin-bottom:1.2rem;
}
.prodotto-text p{
  font-family:var(--serif);font-size:1.02rem;line-height:1.8;
  color:var(--ink-2);margin-bottom:1.3rem;
}
.prodotto-specs{
  list-style:none;padding:0;margin:1.5rem 0 2rem;
  display:grid;grid-template-columns:1fr 1fr;gap:.8rem 1.5rem;
}
.prodotto-specs li{
  font-family:var(--serif);font-size:.92rem;color:var(--ink-2);
  padding:.5rem 0;border-bottom:1px dotted var(--line-strong);
  display:flex;justify-content:space-between;gap:.5rem;
}
.prodotto-specs li strong{
  font-family:var(--display);font-style:italic;color:var(--ink);
  font-weight:400;
}
@media(max-width:720px){
  .prodotto-inner{grid-template-columns:1fr}
  .prodotto-specs{grid-template-columns:1fr}
  .prodotto-card{transform:rotate(0deg);margin-bottom:1.5rem}
}
.pdp-hero-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(3rem,6vw,5rem) clamp(2rem,5vw,4.5rem);position:relative}
.pdp-hero-text .chapter-mark{margin-bottom:1.5rem}
.pdp-hero-text h1{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(3rem,6.5vw,5.8rem);line-height:.98;letter-spacing:-.015em;
  color:var(--ink);margin-bottom:1.5rem;
}
.pdp-hero-text h1 .ital-small{font-family:var(--display);font-style:italic;font-weight:300;font-size:.5em;display:block;color:var(--terra-dark);letter-spacing:.04em;margin-bottom:.4rem}
.pdp-hero-text .lead{font-family:var(--serif);font-size:clamp(1rem,1.4vw,1.1rem);line-height:1.75;color:var(--ink-2);margin-bottom:2rem;max-width:500px}
.pdp-attrs{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.2rem;max-width:500px}
.pdp-attr{background:var(--paper-2);border:1px solid var(--line);font-family:var(--serif);font-size:.76rem;letter-spacing:.08em;padding:.5rem 1rem;color:var(--ink-2);border-radius:2px}
.pdp-note{font-family:var(--display);font-style:italic;font-size:.92rem;color:var(--ink-3);margin-top:1.2rem;max-width:500px;line-height:1.55}

/* PDP story sections */
.story-sec{padding:clamp(4rem,7vw,7rem) clamp(1.8rem,5vw,4rem)}
.story-two{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,6rem);align-items:center;max-width:1200px;margin:0 auto}
.story-two.flip{direction:rtl}.story-two.flip > *{direction:ltr}
.story-img-box{aspect-ratio:4/5;overflow:hidden;position:relative;border-radius:2px;background:var(--paper-2);box-shadow:0 24px 50px rgba(34,24,18,.12)}
.story-img-box img{width:100%;height:100%;object-fit:cover}
.story-img-box.tall{aspect-ratio:3/4}
.story-txt h2{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(2.2rem,4.5vw,3.8rem);line-height:1.05;margin-bottom:1.2rem;color:var(--ink)}
.story-txt p{font-family:var(--serif);font-size:1.02rem;line-height:1.8;color:var(--ink-2);margin-bottom:1.2rem}
.pullq{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(1.35rem,2.3vw,1.75rem);line-height:1.4;
  padding:1.2rem 0 1.2rem 1.8rem;
  border-left:2px solid var(--terra);
  color:var(--ink);
  margin:1.8rem 0;
}
.facts-list{margin:1.5rem 0 2rem;padding:0;list-style:none}
.facts-list li{display:flex;gap:.9rem;padding:.9rem 0;border-bottom:1px dotted var(--line-strong);font-family:var(--serif);font-size:.95rem;color:var(--ink-2);line-height:1.6}
.facts-list li:last-child{border-bottom:none}
.facts-list li::before{content:'❋';color:var(--terra);font-size:.8em;line-height:1.8;flex-shrink:0}
.facts-list li strong{color:var(--ink);font-weight:500;font-family:var(--display);font-style:italic;font-size:1.02em;margin-right:.4rem}

/* AGING card row (parm) */
.aging-sec{padding:clamp(5rem,8vw,7rem) clamp(1.8rem,5vw,4rem);background:var(--paper-2)}
.aging-head{text-align:center;max-width:700px;margin:0 auto 3.5rem}
.aging-head h2{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(2.2rem,4.5vw,3.8rem);margin:1rem 0 1.2rem;line-height:1.05}
.aging-head p{font-family:var(--serif);font-size:1.02rem;line-height:1.75;color:var(--ink-2)}
.aging-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1050px;margin:0 auto}
.aging-card-it{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:3px;
  padding:2.5rem 1.8rem;
  text-align:center;
  position:relative;
}
.aging-card-it.feat{border-color:var(--terra);box-shadow:0 16px 40px rgba(176,84,52,.12)}
.aging-card-it.feat::before{
  content:'Vår standard';
  position:absolute;top:-.6rem;left:50%;transform:translateX(-50%);
  background:var(--terra);color:var(--cream);
  font-family:var(--serif);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.35rem 1rem;border-radius:1px;font-weight:500;
}
.aging-ital{font-family:var(--display);font-style:italic;font-size:.95rem;color:var(--ink-3);margin-bottom:.6rem}
.aging-num-big{font-family:var(--display);font-style:italic;font-weight:300;font-size:4.5rem;color:var(--olive-dark);line-height:1;margin-bottom:.3rem}
.aging-card-it.feat .aging-num-big{color:var(--terra-dark)}
.aging-mesi{font-family:var(--serif);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);margin-bottom:1.2rem;font-weight:500}
.aging-card-it p{font-family:var(--serif);font-size:.9rem;line-height:1.65;color:var(--ink-2)}

/* USE grid (olive oil) */
.use-sec{padding:clamp(5rem,8vw,7rem) clamp(1.8rem,5vw,4rem);background:var(--paper-2)}
.use-head{text-align:center;max-width:640px;margin:0 auto 3.5rem}
.use-head h2{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(2.2rem,4.5vw,3.5rem);margin:1rem 0 1.2rem;line-height:1.05}
.use-head p{font-family:var(--serif);font-size:1rem;line-height:1.75;color:var(--ink-2)}
.use-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1050px;margin:0 auto}
.use-card-it{
  background:var(--paper);border:1px solid var(--line);border-radius:3px;
  padding:2.2rem 1.8rem;position:relative;
}
.use-num{font-family:var(--display);font-style:italic;font-size:2.6rem;color:var(--terra);line-height:1;margin-bottom:1rem;font-weight:300}
.use-card-it h3{font-family:var(--display);font-style:italic;font-size:1.4rem;margin-bottom:.7rem;font-weight:400;color:var(--ink)}
.use-card-it .it-tag{font-family:var(--serif);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--olive-dark);margin-bottom:.6rem;font-weight:500;display:block}
.use-card-it p{font-family:var(--serif);font-size:.92rem;line-height:1.7;color:var(--ink-2)}

/* Gift section on PDP */
.pdp-gift{padding:clamp(4rem,7vw,6rem) clamp(1.8rem,5vw,4rem);background:var(--paper)}
.pdp-gift-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(3rem,5vw,5rem);align-items:center}
.pdp-gift-box{background:var(--paper-2);border:1px solid var(--line);border-radius:3px;padding:clamp(1.8rem,3vw,2.5rem)}
.pdp-gift-box h3{font-family:var(--display);font-style:italic;font-size:1.6rem;margin-bottom:1.2rem;color:var(--ink);font-weight:400}
.pdp-step{display:flex;gap:1rem;margin-bottom:1rem;align-items:flex-start}
.pdp-step-n{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--terra);line-height:1;flex-shrink:0;min-width:30px;font-weight:300}
.pdp-step p{font-family:var(--serif);font-size:.95rem;color:var(--ink-2);line-height:1.6;margin:0}
.tax-box-it{background:var(--olive-deep);color:var(--cream);padding:1.4rem;border-radius:3px;margin-bottom:1.5rem}
.tax-box-it .tax-label-it{font-family:var(--serif);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-light);margin-bottom:.5rem;font-weight:500}
.tax-box-it p{font-family:var(--serif);font-size:.88rem;color:var(--cream-dim);line-height:1.65;margin:0}

/* ════════════════════════════════════════
   FORMS
══════════════════════════════════════════ */
.form-hero{padding:calc(var(--nav-h) + clamp(3rem,5vw,4.5rem)) clamp(1.8rem,5vw,4rem) 2rem;background:var(--paper);border-bottom:1px solid var(--line)}
.form-hero-inner{max-width:900px;margin:0 auto;text-align:center}
.form-hero h1{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(2.6rem,5.5vw,4.8rem);line-height:1;margin:1rem 0 1rem;letter-spacing:-.01em}
.form-hero p{font-family:var(--serif);font-size:1.1rem;color:var(--ink-2);line-height:1.7;max-width:540px;margin:0 auto}
.form-wrap-main{padding:clamp(2.5rem,5vw,4rem) clamp(1.8rem,5vw,4rem) clamp(4rem,7vw,6rem);background:var(--paper)}
.form-cols{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(2.5rem,5vw,4.5rem);max-width:1100px;margin:0 auto;align-items:start}
.form-side h3{font-family:var(--display);font-style:italic;font-size:1.7rem;margin-bottom:1.5rem;font-weight:400;color:var(--ink)}
.side-item{padding:.9rem 0;border-bottom:1px dotted var(--line-strong)}
.side-item:last-child{border-bottom:none}
.side-label{font-family:var(--serif);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--terra-dark);margin-bottom:.3rem;font-weight:500}
.side-val{font-family:var(--serif);font-size:.95rem;color:var(--ink)}
.side-val a{color:var(--olive-dark);font-style:italic;border-bottom:1px solid var(--olive);transition:color .2s}
.side-val a:hover{color:var(--wine);border-color:var(--wine)}
.form-card{background:var(--paper-2);border:1px solid var(--line);border-radius:3px;padding:clamp(1.8rem,3vw,2.8rem)}
.form-card h2{font-family:var(--display);font-style:italic;font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:.4rem;font-weight:400;color:var(--ink)}
.form-card-sub{font-family:var(--serif);font-size:.95rem;color:var(--ink-3);margin-bottom:2rem;font-style:italic}
.fg{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.2rem}
.fg label{font-family:var(--serif);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.fg input,.fg textarea,.fg select{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:2px;
  padding:.85rem 1.1rem;
  font-family:var(--serif);
  font-size:1rem;
  color:var(--ink);
  width:100%;
  transition:border-color .2s,background .2s;
  font-weight:400;
  appearance:none;-webkit-appearance:none;
}
.fg input::placeholder,.fg textarea::placeholder{color:var(--ink-faint);font-style:italic}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--olive);background:var(--paper);outline:none}
.fg select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='8' fill='none'%3E%3Cpath d='M1 1l6 6 6-6' stroke='%238A7759' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1.1rem center;padding-right:2.6rem;cursor:pointer}
.fg textarea{resize:vertical;min-height:120px;font-family:var(--serif)}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-submit{
  width:100%;background:var(--olive-dark);color:var(--cream);border:none;
  padding:1.1rem;border-radius:2px;font-family:var(--serif);
  font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  transition:all .25s var(--ease);margin-top:.8rem;cursor:pointer;
}
.form-submit:hover{background:var(--espresso);transform:translateY(-1px)}
.form-legal{font-family:var(--serif);font-size:.78rem;color:var(--ink-3);text-align:center;margin-top:1rem;line-height:1.6;font-style:italic}
.form-legal span{color:var(--terra-dark);cursor:pointer;border-bottom:1px solid var(--terra)}
.form-success{background:rgba(79,94,48,.12);border:1px solid var(--olive);border-radius:3px;padding:1.3rem 1.6rem;color:var(--olive-dark);font-family:var(--display);font-style:italic;font-size:1.05rem;line-height:1.5;display:none;margin-bottom:1.5rem}
.form-success.show{display:block}
.form-success::before{content:'✓ ';font-size:1.2rem}
.form-error{background:rgba(176,84,52,.1);border:1px solid var(--terra);border-radius:3px;padding:1.3rem 1.6rem;color:#8B3E20;font-family:var(--display);font-style:italic;font-size:1.05rem;line-height:1.5;display:none;margin-bottom:1.5rem}
.form-error.show{display:block}
.form-error::before{content:'⚠ ';font-size:1.1rem;font-style:normal}
.form-error a{color:#8B3E20;text-decoration:underline}

/* ════════════════════════════════════════
   ABOUT PAGE
══════════════════════════════════════════ */
.about-hero{padding:calc(var(--nav-h) + clamp(3rem,6vw,5rem)) clamp(1.8rem,5vw,4rem) clamp(2rem,4vw,3rem);background:var(--paper)}
.about-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(3rem,6vw,6rem);max-width:1200px;margin:0 auto;align-items:start}
.about-text h1{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(3rem,6vw,5.5rem);line-height:.98;margin:1.2rem 0 2rem;letter-spacing:-.015em}
.about-block{margin-bottom:2rem}
.about-block h3{font-family:var(--serif);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--terra-dark);margin-bottom:.7rem;font-weight:500}
.about-block h3 em{font-family:var(--display);font-style:italic;text-transform:none;letter-spacing:.02em;font-size:1.4rem;color:var(--ink);display:block;margin-top:.2rem;font-weight:400}
.about-block p{font-family:var(--serif);font-size:1.05rem;line-height:1.8;color:var(--ink-2)}
.about-facts{background:var(--paper-2);border:1px solid var(--line);border-radius:3px;padding:clamp(1.8rem,3vw,2.5rem);position:sticky;top:calc(var(--nav-h) + 2rem)}
.about-facts .ital-head{font-family:var(--script);color:var(--terra);font-size:1.2rem;margin-bottom:.2rem;display:block}
.about-facts h3{font-family:var(--display);font-style:italic;font-weight:400;font-size:1.6rem;margin-bottom:1.5rem;color:var(--ink)}
.about-fact-row{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px dotted var(--line-strong);align-items:flex-start}
.about-fact-row:last-child{border-bottom:none}
.about-fact-row::before{content:'❋';color:var(--terra);margin-top:.1rem;flex-shrink:0}
.about-fact-row p{font-family:var(--serif);font-size:.95rem;line-height:1.65;color:var(--ink-2);margin:0}

.about-quote-sec{padding:clamp(4rem,7vw,6rem) clamp(1.8rem,5vw,4rem);background:var(--paper-2)}
.about-quote-inner{max-width:900px;margin:0 auto;text-align:center}
.about-bigq{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(1.7rem,3.5vw,3rem);line-height:1.3;color:var(--ink);margin-bottom:2rem}
.about-bigq::before{content:'«';color:var(--terra);margin-right:.3rem}
.about-bigq::after{content:'»';color:var(--terra);margin-left:.3rem}

/* ════════════════════════════════════════
   LEGAL PAGES
══════════════════════════════════════════ */
.legal-wrap-it{padding:calc(var(--nav-h) + clamp(2.5rem,4vw,3.5rem)) clamp(1.8rem,5vw,4rem) clamp(3rem,6vw,5rem);max-width:780px;margin:0 auto}
.legal-wrap-it h1{font-family:var(--display);font-style:italic;font-weight:300;font-size:clamp(2.4rem,5vw,3.8rem);margin-bottom:2rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line);line-height:1}
.legal-wrap-it h2{font-family:var(--display);font-style:italic;font-size:1.4rem;margin-top:2.3rem;margin-bottom:.7rem;color:var(--ink);font-weight:400}
.legal-wrap-it p,.legal-wrap-it li{font-family:var(--serif);font-size:1rem;color:var(--ink-2);line-height:1.8;margin-bottom:.7rem}
.legal-wrap-it ul{padding-left:1.3rem;margin-bottom:1rem}
.legal-wrap-it a{color:var(--olive-dark);font-style:italic;border-bottom:1px solid var(--olive)}

/* ════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-italian,.pdp-hero{grid-template-columns:1fr}
  .hero-visual,.pdp-hero-img-side{min-height:55vw;order:2}
  .hero-text{order:1}
  .chapter-grid,.chapter-grid.reverse,.story-two,.story-two.flip,.form-cols,.about-grid,.bottega-grid,.pdp-gift-inner{grid-template-columns:1fr!important;direction:ltr!important}
  .bottega-grid > div:first-child{grid-template-columns:1fr 1fr}
  .bottega-card.featured{grid-row:auto}
  .foot-top{grid-template-columns:1fr 1fr}
  .about-facts{position:static}
  .wax-seal{top:auto;bottom:1.2rem;right:1.2rem;width:90px;height:90px}
}
/* Mobile menu triggers earlier — nav was cramped between 720-1024 */
@media(max-width:960px){
  .nav-links{display:none}
  .hamburger{display:flex}
}
@media(max-width:720px){
  :root{--nav-h:64px}
  .trad-seals,.aging-row,.use-row{grid-template-columns:1fr!important}
  .bottega-grid > div:first-child{grid-template-columns:1fr!important}
  .form-row-2{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:2rem}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{justify-content:center}
  .cta-band .btns{flex-direction:column;align-items:center}
  .hero-headline{font-size:3.2rem}
  
  .chapter-text h2,.story-txt h2{font-size:2.4rem}
}

/* ════════════════════════════════════════
   FAQ SECTION
══════════════════════════════════════════ */
.faq-sec{
  padding:clamp(4rem,7vw,6rem) clamp(1.8rem,5vw,4rem);
  background:var(--paper-2);
  border-top:1px solid var(--line);
}
.faq-inner{max-width:900px;margin:0 auto}
.faq-head{text-align:center;margin-bottom:3rem}
.faq-head h2{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(2rem,4.5vw,3.5rem);line-height:1.05;
  color:var(--ink);margin:1rem 0 1rem;letter-spacing:-.01em;
}
.faq-head p{font-family:var(--serif);color:var(--ink-2);font-size:1.02rem;line-height:1.75;max-width:560px;margin:0 auto}
.faq-list{display:flex;flex-direction:column;gap:1rem}
.faq-item{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:3px;
  overflow:hidden;
  transition:border-color .2s;
}
.faq-item[open]{border-color:var(--line-strong)}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:1.3rem 1.5rem;
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(1.1rem,1.8vw,1.35rem);
  color:var(--ink);line-height:1.35;
  display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;
  transition:color .2s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';font-family:var(--display);font-style:italic;font-size:1.8rem;
  color:var(--terra);line-height:.8;flex-shrink:0;
  transition:transform .3s var(--ease);
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--terra-dark)}
.faq-body{
  padding:0 1.5rem 1.4rem;
  font-family:var(--serif);font-size:.98rem;line-height:1.75;
  color:var(--ink-2);
}
.faq-item .faq-body p{margin-bottom:.8rem}
.faq-item .faq-body p:last-child{margin-bottom:0}

@media(max-width:720px){
  .faq-item summary{font-size:1.05rem;padding:1.1rem 1.2rem}
  .faq-body{padding:0 1.2rem 1.2rem}
}

/* ── Cookie Banner ─────────────────────────────────────────── */
.cookie-banner{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;
  max-width:420px;width:calc(100% - 3rem);
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:4px;
  box-shadow:0 12px 40px rgba(34,24,18,.18),0 2px 8px rgba(34,24,18,.08);
  padding:1.6rem 1.7rem 1.5rem;
  opacity:0;transform:translateY(20px);pointer-events:none;
  transition:opacity .35s ease,transform .35s ease;
  font-family:var(--serif);
}
.cookie-banner.show{opacity:1;transform:translateY(0);pointer-events:auto}
.cookie-banner .cookie-ornament{
  display:flex;align-items:center;gap:.5rem;
  font-family:var(--script);font-size:1.05rem;color:var(--terra);
  margin-bottom:.5rem;
}
.cookie-banner .cookie-ornament::before{content:'';width:20px;height:1px;background:var(--terra);opacity:.5}
.cookie-banner h3{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:1.4rem;color:var(--ink);
  margin:0 0 .7rem;letter-spacing:-.01em;
}
.cookie-banner p{
  font-size:.92rem;line-height:1.6;color:var(--ink-2);
  margin:0 0 1.2rem;
}
.cookie-banner p a{
  color:var(--olive-dark);
  text-decoration:underline;
  text-decoration-color:rgba(79,94,48,.35);
  text-underline-offset:3px;
  transition:text-decoration-color .2s;
}
.cookie-banner p a:hover{text-decoration-color:var(--olive-dark)}
.cookie-banner .cookie-actions{
  display:flex;gap:.7rem;flex-wrap:wrap;
}
.cookie-banner .cookie-btn{
  flex:1;min-width:140px;
  padding:.8rem 1.1rem;
  font-family:var(--serif);font-size:.78rem;
  letter-spacing:.1em;text-transform:uppercase;font-weight:500;
  border-radius:2px;cursor:pointer;
  border:1px solid var(--olive-dark);
  background:var(--olive-dark);color:var(--cream);
  transition:background .2s,color .2s,transform .15s;
}
.cookie-banner .cookie-btn:hover{background:var(--olive);border-color:var(--olive)}
.cookie-banner .cookie-btn:active{transform:scale(.98)}
.cookie-banner .cookie-btn.cookie-btn-outline{
  background:transparent;color:var(--olive-dark);
}
.cookie-banner .cookie-btn.cookie-btn-outline:hover{
  background:rgba(79,94,48,.08);color:var(--olive-dark);
  border-color:var(--olive-dark);
}
@media(max-width:720px){
  .cookie-banner{
    left:1rem;right:1rem;bottom:1rem;
    max-width:none;width:auto;
    padding:1.4rem 1.4rem 1.3rem;
  }
  .cookie-banner h3{font-size:1.25rem}
  .cookie-banner .cookie-actions{flex-direction:column;gap:.55rem}
  .cookie-banner .cookie-btn{min-width:0;width:100%}
}
