/* ============================================================
   VendemmiaFico — orto.css
   Concept: a Tuscan harvest almanac / seed-catalogue zine.
   Constitution:
   - Two foundations: paper cream #f7efe0 + ink #33251a.
   - One accent: fig-purple #6d3b5e (folios, active, headline words).
     Olive #7c8a4f + terracotta #c56a3a only as gentle seasonal marks.
   - Type: Roboto Slab (almanac slab display) + Figtree (body).
   - Surface: warm paper grain, thin ink hairlines + soft warm shadows,
     hand-drawn fig/leaf marks.
   - Signature: roman-numeral folio "§ Orto I" + leaf mark per section,
     sprouting dotted-seed rule dividers.
   ============================================================ */

@font-face{font-family:'Roboto Slab';font-style:normal;font-weight:100 900;font-display:swap;src:url('../fonts/robotoslab.woff2') format('woff2')}
@font-face{font-family:'Figtree';font-style:normal;font-weight:100 900;font-display:swap;src:url('../fonts/figtree.woff2') format('woff2')}

:root{
  --cream:#f7efe0;
  --cream-2:#f1e5cf;
  --paper:#fcf8ee;
  --ink:#33251a;
  --ink-soft:#4c3a2b;
  --muted:#7a6a55;
  --fig:#6d3b5e;
  --fig-deep:#54294a;
  --olive:#7c8a4f;
  --terra:#c56a3a;
  --line:rgba(51,37,26,.16);
  --line-soft:rgba(51,37,26,.09);
  --shadow-s:0 6px 18px -12px rgba(51,37,26,.45);
  --shadow-m:0 18px 44px -24px rgba(51,37,26,.55);
  --shadow-fig:0 16px 40px -22px rgba(84,41,74,.6);
  --r:14px;
  --r-s:8px;
  --wrap:90rem;        /* 1920px cap on ultra-wide, fills at 1440 */
  --wrap-mid:92rem;     /* comfortable editorial band */
  --wrap-narrow:58rem;  /* single reading column / ledger */
  --slab:'Roboto Slab',Georgia,'Times New Roman',serif;
  --body:'Figtree',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.62;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* paper grain material */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:1;
  opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{max-width:100%;height:auto;display:block}
a{color:var(--fig);text-decoration:none}
h1,h2,h3,h4{font-family:var(--slab);font-weight:800;line-height:1.08;color:var(--ink);margin:0 0 .5em;letter-spacing:-.01em}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--fig);outline-offset:3px;border-radius:3px}

.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1rem,4vw,4rem)}
.wrap.mid{max-width:var(--wrap-mid)}
.wrap.narrow{max-width:var(--wrap-narrow)}
.em-fig{color:var(--fig);font-style:italic}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--fig);--fg:#fff5ef;
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--body);font-weight:700;font-size:1rem;
  padding:.85rem 1.5rem;border-radius:999px;border:1px solid transparent;
  background:var(--bg);color:var(--fg);cursor:pointer;
  box-shadow:var(--shadow-fig);
  transition:transform .25s ease,background .25s ease,box-shadow .25s ease;
}
.btn:hover{transform:translateY(-2px);background:var(--fig-deep);box-shadow:0 22px 44px -20px rgba(84,41,74,.7)}
.btn .arrow{transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(4px)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line);box-shadow:none}
.btn.ghost:hover{background:var(--cream-2);border-color:var(--ink);transform:translateY(-2px)}
.btn.olive{--bg:var(--olive);--fg:#fbfaef;box-shadow:0 16px 36px -22px rgba(124,138,79,.75)}
.btn.olive:hover{background:#6a7742}

/* ---------- folio / section head ---------- */
.folio{
  display:flex;align-items:center;gap:.7rem;
  font-family:var(--body);font-weight:700;letter-spacing:.24em;text-transform:uppercase;
  font-size:.72rem;color:var(--fig);margin-bottom:1rem;
}
.folio .leaf{width:22px;height:22px;flex:none}
.folio .num{color:var(--terra);font-style:italic;font-weight:800;letter-spacing:.08em}
.sec-head{max-width:60ch}
.sec-head h2{font-size:clamp(1.9rem,4.6vw,3.1rem)}
.sec-head .lede{color:var(--ink-soft);font-size:1.08rem;max-width:56ch}

/* dotted sprouting rule */
.seed-rule{
  border:0;height:2px;margin:0;
  background-image:radial-gradient(circle,var(--muted) 1.4px,transparent 1.6px);
  background-size:14px 2px;background-repeat:repeat-x;opacity:.5;
}

section{position:relative;z-index:2}

/* ---------- header ---------- */
.site-head{
  position:sticky;top:0;z-index:60;
  background:rgba(247,239,224,.9);backdrop-filter:blur(9px);
  border-bottom:1px solid var(--line);
}
.head-in{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:70px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--slab);font-weight:800;font-size:1.28rem;color:var(--ink);letter-spacing:-.01em}
.brand svg{width:34px;height:34px;flex:none}
.brand b{color:var(--fig)}
.nav{display:flex;align-items:center;gap:.35rem}
.nav a{
  color:var(--ink-soft);font-weight:600;font-size:.97rem;
  padding:.5rem .8rem;border-radius:8px;position:relative;transition:color .2s ease,background .2s ease;
}
.nav a::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.34rem;height:2px;background:var(--fig);transform:scaleX(0);transform-origin:left;transition:transform .28s ease}
.nav a:hover{color:var(--ink)}
.nav a:hover::after,.nav a[aria-current="page"]::after{transform:scaleX(1)}
.nav a[aria-current="page"]{color:var(--fig)}
.nav .btn{margin-left:.5rem;padding:.6rem 1.1rem}

.burger{display:none;width:46px;height:46px;border:1px solid var(--line);background:var(--paper);border-radius:10px;cursor:pointer;padding:0;align-items:center;justify-content:center}
.burger span{display:block;width:22px;height:2px;background:var(--ink);position:relative;transition:background .2s ease}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--ink);transition:transform .3s ease,top .3s ease}
.burger span::before{top:-7px}
.burger span::after{top:7px}
.burger[aria-expanded="true"] span{background:transparent}
.burger[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.burger[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

/* mobile dropdown accordion */
.mnav{overflow:hidden;max-height:0;transition:max-height .4s cubic-bezier(.4,0,.2,1);background:var(--paper);border-bottom:1px solid transparent}
.mnav.open{border-bottom-color:var(--line)}
.mnav .wrap{display:flex;flex-direction:column;padding-top:.4rem;padding-bottom:1.1rem}
.mnav a{padding:.85rem .4rem;border-bottom:1px dashed var(--line-soft);color:var(--ink);font-weight:600;font-size:1.05rem}
.mnav a:last-of-type{border-bottom:0}
.mnav .btn{margin-top:.9rem;justify-content:center}

/* ---------- masthead (aged-paper almanac nameplate) ---------- */
.masthead{
  position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  background:
    radial-gradient(120% 92% at 80% 6%,rgba(124,138,79,.16),transparent 48%),
    radial-gradient(96% 84% at 2% 104%,rgba(197,106,58,.13),transparent 46%),
    linear-gradient(178deg,var(--paper),var(--cream-2));
}
.masthead::after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 140px -46px rgba(51,37,26,.42)}
.masthead>.wrap{position:relative;z-index:2;padding-top:clamp(1.3rem,3vw,2.4rem);padding-bottom:clamp(2rem,4vw,3.4rem)}
.dateline{
  display:flex;align-items:center;gap:clamp(.5rem,1.8vw,1.3rem);flex-wrap:wrap;
  font-family:var(--body);font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  font-size:clamp(.58rem,1.05vw,.74rem);color:var(--ink-soft);
  padding:.7rem 0;border-top:2px solid var(--ink);border-bottom:1px solid var(--line);
  margin:0 0 clamp(1.6rem,4vw,3rem)}
.dateline .dot-lead{flex:1 1 30px;min-width:16px;height:0;border-bottom:2px dotted var(--line);opacity:.7}
.mast-grid{display:grid;grid-template-columns:1.14fr .86fr;gap:clamp(1.6rem,4.5vw,4.5rem);align-items:center}
.mast-grid .hero-copy{display:flex;flex-direction:column;justify-content:center;gap:1.15rem;padding:0;position:relative;z-index:3}
.hero-copy .kicker{display:inline-flex;align-items:center;gap:.5rem;align-self:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.4rem .95rem;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--fig)}
.hero-copy h1{font-size:clamp(2.5rem,6vw,4.9rem);letter-spacing:-.02em}
.hero-copy .sub{font-size:clamp(1.05rem,1.5vw,1.26rem);color:var(--ink-soft);max-width:46ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;margin-top:.4rem}
.hero-stats{display:flex;flex-wrap:wrap;gap:clamp(1.2rem,3vw,2.6rem);margin-top:1.4rem;padding-top:1.3rem;border-top:1px solid var(--line)}
.hero-stats div{min-width:0}
.hero-stats b{display:block;font-family:var(--slab);font-size:clamp(1.7rem,2.4vw,2.1rem);color:var(--fig);line-height:1}
.hero-stats span{font-size:.82rem;color:var(--muted);letter-spacing:.03em}
/* framed harvest plate */
.mast-plate{position:relative;margin:0;padding:clamp(.6rem,1.3vw,1.05rem);background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow-m)}
.mast-plate::before{content:"";position:absolute;inset:6px;border:1px solid var(--line-soft);pointer-events:none;z-index:2}
.mast-plate>img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;display:block}
.mast-plate figcaption{font-family:var(--slab);font-style:italic;font-size:.86rem;color:var(--muted);padding:.6rem .2rem 0;text-align:center}
.mast-plate .wax{
  position:absolute;top:-16px;right:-8px;z-index:4;width:92px;height:92px;border-radius:50%;
  background:radial-gradient(circle at 34% 30%,#7c4a70,var(--fig-deep));color:#fff5ef;transform:rotate(-9deg);
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--slab);font-weight:700;font-size:.72rem;line-height:1.16;letter-spacing:.02em;
  box-shadow:var(--shadow-fig);border:2px solid rgba(255,245,239,.35)}
/* almanac contents index band */
.indice{position:relative;z-index:2;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);background:var(--paper)}
.indice>.wrap{display:flex;align-items:baseline;gap:clamp(1rem,3vw,2.4rem);flex-wrap:wrap;padding-top:.95rem;padding-bottom:.95rem}
.indice .idx-lead{font-family:var(--slab);font-style:italic;font-weight:600;font-size:1.02rem;color:var(--fig);flex:none}
.indice ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.2rem 1.9rem;flex:1}
.indice li{min-width:0}
.indice a{display:inline-flex;align-items:baseline;gap:.5rem;color:var(--ink-soft);font-weight:600;font-size:.92rem;padding:.2rem 0;transition:color .2s ease}
.indice a i{font-family:var(--slab);font-style:italic;font-weight:800;color:var(--terra);font-size:.86rem;letter-spacing:.04em;min-width:1.4em;text-align:right}
.indice a:hover{color:var(--fig)}
.indice a:hover i{color:var(--fig)}

/* ---------- alternating featured rows ---------- */
.raccolto{padding:clamp(3.4rem,7vw,6rem) 0 1rem}
.raccolto>.wrap>.sec-head{margin-bottom:2.4rem}
.riga{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.4rem,4vw,3.4rem);align-items:center;padding:clamp(1.6rem,4vw,3rem) 0;border-top:1px solid var(--line-soft)}
.riga:first-of-type{border-top:0}
.riga-visual{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-m);border:1px solid var(--line)}
.riga-visual img{width:100%;height:100%;min-height:260px;object-fit:cover;aspect-ratio:16/11}
.riga-visual .plate{position:absolute;top:14px;left:14px;background:var(--fig);color:#fff5ef;font-family:var(--slab);font-weight:700;font-size:.8rem;padding:.35rem .7rem;border-radius:7px;letter-spacing:.04em}
.riga:nth-child(even) .riga-visual{order:2}
.riga-copy .rank{font-family:var(--slab);font-size:.9rem;color:var(--terra);font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem}
.riga-copy h3{font-size:clamp(1.5rem,3vw,2.15rem);margin-bottom:.55rem}
.riga-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin:.2rem 0 1rem}
.chip{display:inline-flex;align-items:center;gap:.35rem;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.32rem .8rem;font-size:.82rem;font-weight:600;color:var(--ink-soft)}
.chip.stars{color:var(--terra)}
.riga-copy p{color:var(--ink-soft)}
.riga-copy .btn{margin-top:.4rem}

/* section-head variants (kill the repeated centered band) */
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head.center .folio{justify-content:center}
.sec-head.center .lede{margin-inline:auto}

/* ---------- raccolto del mese — grid breaker ---------- */
.mese{
  position:relative;display:grid;grid-template-columns:1.12fr .88fr;
  gap:clamp(1.6rem,4vw,3.6rem);align-items:center;
  margin:0 0 clamp(2.6rem,5vw,4rem);padding:clamp(1.4rem,3vw,2.6rem);
  background:radial-gradient(130% 120% at 100% 0,rgba(109,59,94,.09),transparent 56%),var(--paper);
  border:1px solid var(--line);box-shadow:var(--shadow-m);
}
.mese::before{content:"";position:absolute;inset:9px;border:1px dashed var(--line);pointer-events:none;z-index:1}
.mese>*{position:relative;z-index:2}
.mese-copy{min-width:0}
.mese-copy .rank{font-family:var(--slab);font-size:.92rem;color:var(--terra);font-weight:700;letter-spacing:.11em;text-transform:uppercase;margin-bottom:.45rem}
.mese-copy h3{font-size:clamp(2rem,4.4vw,3.4rem);margin-bottom:.5rem;line-height:1.02}
.mese-copy .riga-meta{margin:.2rem 0 1.1rem}
.mese-lead{color:var(--ink-soft);font-size:1.07rem}
.mese-lead::first-letter{float:left;font-family:var(--slab);font-weight:800;color:var(--fig);font-size:3.7rem;line-height:.72;padding:.32rem .5rem 0 0}
.mese-plate{position:relative;margin:0;border:1px solid var(--line);box-shadow:var(--shadow-m);overflow:hidden;background:var(--ink)}
.mese-plate img{width:100%;height:100%;min-height:320px;object-fit:cover;aspect-ratio:5/4;display:block}
.mese-seal{position:absolute;top:0;left:0;z-index:3;background:var(--fig);color:#fff5ef;font-family:var(--slab);font-weight:700;font-size:.8rem;letter-spacing:.06em;padding:.5rem 1rem;box-shadow:var(--shadow-fig)}
/* pinned hand-written margin note */
.margin-note{position:absolute;right:clamp(.8rem,2vw,1.7rem);bottom:clamp(.8rem,2vw,1.7rem);z-index:6;max-width:210px;transform:rotate(-2.6deg);font-family:var(--slab);font-style:italic;color:#7a3d2a;font-size:.92rem;line-height:1.42;background:#fbf3e3;border:1px solid var(--line);box-shadow:var(--shadow-m);padding:.75rem .95rem}
.margin-note b{display:block;font-style:normal;font-weight:700;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:.28rem}
.margin-note::after{content:"";position:absolute;left:16px;top:-10px;width:38px;height:17px;background:rgba(197,106,58,.32);border:1px solid rgba(197,106,58,.4);transform:rotate(-5deg)}
@media (max-width:760px){
  .mese{grid-template-columns:1fr;gap:1.4rem}
  .margin-note{position:static;transform:none;max-width:none;margin-top:1.1rem}
  .margin-note::after{display:none}
}

/* ---------- catalogo di sementi (alternating list) ---------- */
.sementi{padding:clamp(3.4rem,7vw,6rem) 0;background:var(--cream-2);border-block:1px solid var(--line);position:relative}
.sementi::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 12% 16%,rgba(124,138,79,.1),transparent 30%),radial-gradient(circle at 88% 84%,rgba(197,106,58,.08),transparent 32%);pointer-events:none}
.sementi>.wrap{position:relative;z-index:2}
.catalogo{list-style:none;margin:2.6rem 0 0;padding:0}
.semenza{
  position:relative;display:grid;grid-template-columns:auto minmax(0,1fr);
  gap:clamp(1.3rem,4vw,3.2rem);align-items:center;
  padding:clamp(1.8rem,4vw,2.8rem) 0;
}
.semenza::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background-image:radial-gradient(circle,var(--muted) 1.4px,transparent 1.6px);
  background-size:14px 2px;background-repeat:repeat-x;opacity:.5}
.semenza:first-child::before{display:none}
.semenza:nth-child(even){grid-template-columns:minmax(0,1fr) auto}
.semenza:nth-child(even) .stamp{order:2}

/* seed-packet postage stamp */
.stamp{
  --d:17px;--r:5px;
  align-self:start;justify-self:center;width:clamp(142px,20vw,186px);
  padding:14px 14px 11px;background:var(--paper);
  display:flex;flex-direction:column;gap:.55rem;align-items:center;
  transform:rotate(-2.1deg);transition:transform .3s ease;
  filter:drop-shadow(0 12px 18px rgba(51,37,26,.22));
  -webkit-mask:radial-gradient(var(--r) at var(--r) var(--r),#0000 99%,#000) calc(var(--r)*-1) calc(var(--r)*-1)/var(--d) var(--d) round;
          mask:radial-gradient(var(--r) at var(--r) var(--r),#0000 99%,#000) calc(var(--r)*-1) calc(var(--r)*-1)/var(--d) var(--d) round;
}
.semenza:nth-child(even) .stamp{transform:rotate(2.1deg)}
.semenza:hover .stamp{transform:rotate(0)}
.stamp img{width:100%;max-width:120px;height:auto;border-radius:12px;border:1px solid var(--line);box-shadow:var(--shadow-s)}
.stamp .denom{display:flex;flex-direction:column;align-items:center;line-height:1.06;text-align:center}
.stamp .no{font-family:var(--slab);font-weight:800;font-size:1.04rem;color:var(--fig)}
.stamp .cat{font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}

/* catalogue entry body */
.semenza-body{min-width:0;max-width:60ch}
.semenza .varieta{font-family:var(--body);font-size:.72rem;font-weight:700;letter-spacing:.17em;text-transform:uppercase;color:var(--olive);margin:0 0 .35rem}
.semenza-body h3{font-size:clamp(1.5rem,3vw,2.15rem);margin:0 0 .5rem}
.semenza-rate{display:flex;align-items:baseline;flex-wrap:wrap;gap:.35rem;font-size:.9rem;color:var(--muted);margin-bottom:.95rem}
.semenza-rate .stars{color:var(--terra);letter-spacing:1px;font-size:.98rem}
.semenza-rate b{color:var(--ink);font-family:var(--slab);font-size:1.06rem}
.nota{
  position:relative;font-family:var(--slab);font-style:italic;font-weight:400;
  font-size:1.03rem;line-height:1.72;color:var(--ink-soft);margin:0 0 1.15rem;
  padding:.85rem 1.15rem .85rem 2.35rem;background-color:var(--paper);
  background-image:repeating-linear-gradient(to bottom,transparent 0 27px,var(--line-soft) 27px 28px);
  border:1px solid var(--line);border-radius:var(--r-s);box-shadow:var(--shadow-s);
}
.nota::before{content:"\201C";position:absolute;left:.55rem;top:.42rem;font-family:var(--slab);font-style:normal;font-size:2rem;line-height:1;color:var(--fig);opacity:.6}
.semenza .play{
  display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.92rem;
  color:var(--fig);background:var(--paper);border:1px solid var(--line);border-radius:10px;
  padding:.6rem 1rem;transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease;
}
.semenza .play:hover{background:var(--fig);color:#fff5ef;border-color:var(--fig);transform:translateY(-2px)}
.semenza .play svg{width:15px;height:15px}
.semenza .play .arrow{transition:transform .25s ease}
.semenza .play:hover .arrow{transform:translateX(3px)}
@media (max-width:600px){
  .semenza,.semenza:nth-child(even){grid-template-columns:1fr;gap:1.3rem;justify-items:start}
  .semenza .stamp,.semenza:nth-child(even) .stamp{order:0;justify-self:start}
  .semenza-body{max-width:none}
}

/* ---------- consigli — ruled almanac ledger (narrow editorial column) ---------- */
.consigli{padding:clamp(3.4rem,7vw,6rem) 0}
.ledger{margin-top:2.2rem;border-top:2px solid var(--ink)}
.ledger-row{display:grid;grid-template-columns:auto 1fr;gap:clamp(1rem,3vw,2.4rem);align-items:baseline;padding:clamp(1.15rem,3vw,1.7rem) 0;border-bottom:1px dashed var(--line)}
.ledger-row .n{font-family:var(--slab);font-weight:800;font-size:clamp(2.3rem,5vw,3.2rem);color:var(--olive);line-height:.85;min-width:1.7em}
.ledger-row:nth-child(2) .n{color:var(--terra)}
.ledger-row:nth-child(3) .n{color:var(--fig)}
.ledger-row:nth-child(4) .n{color:var(--muted)}
.ledger-row h3{font-size:1.24rem;margin-bottom:.28rem}
.ledger-row p{font-size:.98rem;color:var(--ink-soft);margin:0}

/* ---------- calendario stagionale ---------- */
.stagioni{padding:clamp(3.4rem,7vw,6rem) 0;border-top:1px solid var(--line);position:relative}
.stagioni::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 85% 12%,rgba(124,138,79,.09),transparent 34%),radial-gradient(circle at 8% 88%,rgba(197,106,58,.08),transparent 32%);pointer-events:none}
.stagioni-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(1rem,1.6vw,1.5rem);margin-top:2.4rem}
.stagione{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-s);display:flex;flex-direction:column;transition:transform .28s ease,box-shadow .28s ease}
.stagione:hover{transform:translateY(-5px);box-shadow:var(--shadow-m)}
.stagione .cap{padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem;color:#fdf6ec}
.stagione .cap h3{color:inherit;margin:0;font-size:1.32rem;font-family:var(--slab)}
.stagione .cap .mese{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.85}
.stagione .cap .season-ic{width:30px;height:30px;flex:none}
.stagione.s-pri .cap{background:var(--olive)}
.stagione.s-est .cap{background:var(--terra)}
.stagione.s-aut .cap{background:var(--fig)}
.stagione.s-inv .cap{background:#6b5a45}
.stagione .body{padding:1.2rem 1.3rem 1.35rem;display:flex;flex-direction:column;gap:.95rem;flex:1}
.stagione .pick{display:flex;align-items:center;gap:.75rem;background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r-s);padding:.7rem .8rem}
.stagione .pick img{width:48px;height:48px;border-radius:12px;border:1px solid var(--line);flex:none;box-shadow:var(--shadow-s)}
.stagione .pick .tag{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.1rem}
.stagione .pick b{font-family:var(--slab);font-size:1.05rem;line-height:1.15;color:var(--ink)}
.stagione .note{font-size:.92rem;color:var(--ink-soft);margin:0;flex:1}
.stagione .go{margin-top:.1rem;display:inline-flex;align-items:center;gap:.45rem;font-weight:700;font-size:.88rem;color:var(--fig);align-self:flex-start}
.stagione .go svg{width:15px;height:15px}
.stagione .go:hover{color:var(--fig-deep);text-decoration:underline}

/* ---------- reviews ---------- */
.recensioni{padding:clamp(3.4rem,7vw,6rem) 0;background:var(--cream-2);border-block:1px solid var(--line)}
.rec-grid{columns:4 300px;column-gap:1.4rem;margin-top:2.4rem}
.rec{break-inside:avoid;margin-bottom:1.3rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.35rem 1.4rem;box-shadow:var(--shadow-s)}
.rec .stars{color:var(--terra);letter-spacing:1px;font-size:.95rem}
.rec p{font-size:.96rem;color:var(--ink-soft);margin:.6rem 0 1rem}
.rec .who{display:flex;align-items:center;gap:.7rem}
.rec .av{width:40px;height:40px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-family:var(--slab);font-weight:700;color:#fff5ef;font-size:1rem}
.rec .who b{display:block;font-size:.92rem;color:var(--ink);font-family:var(--slab)}
.rec .who span{font-size:.78rem;color:var(--muted)}

/* ---------- faq ---------- */
.faq{padding:clamp(3.4rem,7vw,6rem) 0}
.faq-wrap{display:grid;grid-template-columns:1fr 1.35fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:start;margin-top:1rem}
.faq-aside{position:sticky;top:96px}
.faq-aside .card-note{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;box-shadow:var(--shadow-s)}
.faq-aside img{border-radius:var(--r);border:1px solid var(--line);margin-bottom:1.2rem;box-shadow:var(--shadow-s);aspect-ratio:4/5;object-fit:cover;width:100%}
.faq-list{display:flex;flex-direction:column;gap:.8rem}
details.qa{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:border-color .2s ease}
details.qa[open]{border-color:var(--fig)}
details.qa summary{list-style:none;cursor:pointer;padding:1.1rem 1.3rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-family:var(--slab);font-weight:700;font-size:1.05rem;color:var(--ink)}
details.qa summary::-webkit-details-marker{display:none}
details.qa summary .ic{flex:none;width:26px;height:26px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--fig);transition:transform .3s ease,background .2s ease}
details.qa[open] summary .ic{transform:rotate(45deg);background:var(--fig);color:#fff5ef;border-color:var(--fig)}
details.qa .a{padding:0 1.3rem 1.2rem;color:var(--ink-soft);font-size:.97rem}

/* ---------- newsletter band + contatti ---------- */
.raccolta-band{position:relative;color:#fdf6ec;padding:clamp(3.4rem,7vw,6rem) 0;overflow:hidden;background:var(--fig-deep)}
.raccolta-band::before{content:"";position:absolute;inset:0;background:url("../images/orto-riga.webp") center/cover;opacity:.22}
.raccolta-band::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(84,41,74,.94),rgba(51,37,26,.86))}
.band-grid{position:relative;z-index:3;display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3.6rem);align-items:center}
.band-copy .folio{color:#e7c8dc}
.band-copy .folio .num{color:#e6a97f}
.band-copy h2{color:#fdf6ec;font-size:clamp(1.9rem,4.4vw,3rem)}
.band-copy p{color:rgba(253,246,236,.86)}
.band-contacts{display:flex;flex-direction:column;gap:.7rem;margin-top:1.4rem}
.band-contacts a,.band-contacts span{color:#fdf6ec;display:flex;align-items:center;gap:.6rem;font-size:.98rem}
.band-contacts svg{width:18px;height:18px;flex:none;color:#e6a97f}
.sub-card{position:relative;z-index:3;background:rgba(252,248,238,.97);color:var(--ink);border-radius:18px;padding:clamp(1.5rem,3vw,2.3rem);box-shadow:0 30px 70px -30px rgba(0,0,0,.6)}
.sub-card h3{font-size:1.4rem;margin-bottom:.3rem}
.sub-card>p{color:var(--muted);font-size:.95rem;margin-bottom:1.2rem}
.field{margin-bottom:.9rem}
.field label{display:block;font-size:.8rem;font-weight:700;letter-spacing:.04em;color:var(--ink-soft);margin-bottom:.35rem}
.field input[type=text],.field input[type=tel],.field input[type=email]{
  width:100%;padding:.8rem .9rem;border:1px solid var(--line);border-radius:10px;
  background:var(--cream);font-family:var(--body);font-size:1rem;color:var(--ink);transition:border-color .2s ease,box-shadow .2s ease;
}
.field input:focus{outline:none;border-color:var(--fig);box-shadow:0 0 0 3px rgba(109,59,94,.18)}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--ink-soft);margin:.4rem 0 1rem}
.consent input{margin-top:.25rem;width:18px;height:18px;flex:none;accent-color:var(--fig)}
.consent a{text-decoration:underline}
.sub-card .btn{width:100%;justify-content:center}
#successMsg{display:none;margin-top:1rem;padding:.85rem 1rem;background:rgba(124,138,79,.16);border:1px solid var(--olive);border-radius:10px;color:#4f5a2c;font-weight:600;font-size:.92rem}
#successMsg.show{display:block}

/* ---------- about (chi siamo) ---------- */
.about{padding:clamp(3.4rem,7vw,6rem) 0}
.about-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center}
.about-visual{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.about-visual img{border-radius:var(--r);border:1px solid var(--line);box-shadow:var(--shadow-s);width:100%;height:100%;object-fit:cover}
.about-visual img:first-child{grid-row:span 2;aspect-ratio:3/5}
.about-visual img:last-child{aspect-ratio:4/3;align-self:end}
.about-copy .vals{display:flex;flex-direction:column;gap:.9rem;margin-top:1.2rem}
.about-copy .vals li{display:flex;gap:.8rem;align-items:flex-start;list-style:none}
.about-copy .vals .m{flex:none;width:34px;height:34px;border-radius:9px;background:rgba(109,59,94,.12);display:flex;align-items:center;justify-content:center;color:var(--fig)}
.about-copy .vals b{font-family:var(--slab);display:block;font-size:1rem}
.about-copy .vals p{margin:.1rem 0 0;font-size:.92rem;color:var(--muted)}
.about-copy ul{padding:0;margin:0}

/* ---------- footer ---------- */
.site-foot{background:var(--ink);color:#e9ddcb;padding:clamp(3rem,6vw,4.6rem) 0 1.6rem;position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2rem}
.foot-brand .brand{color:#fbf3e4}
.foot-brand .brand b{color:#d79bbe}
.foot-brand p{color:#bcae99;font-size:.92rem;max-width:34ch;margin-top:1rem}
.foot-col h4{font-family:var(--slab);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:#d79bbe;margin-bottom:1rem}
.foot-col a{display:block;color:#cbbda8;font-size:.94rem;padding:.28rem 0;transition:color .2s ease}
.foot-col a:hover{color:#fff}
.foot-nap{font-style:normal;color:#cbbda8;font-size:.94rem;line-height:1.9}
.foot-nap a{color:#cbbda8}
.foot-nap a:hover{color:#fff}
.foot-bottom{margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid rgba(233,221,203,.15);display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;font-size:.84rem;color:#a89a85}
.foot-bottom .colophon{font-style:italic}

/* ---------- cookie banner ---------- */
.cookie{
  position:fixed;left:50%;transform:translateX(-50%) translateY(140%);
  bottom:18px;z-index:80;width:min(720px,calc(100% - 28px));
  background:var(--paper);border:1px solid var(--line);border-radius:16px;
  box-shadow:0 24px 60px -20px rgba(51,37,26,.6);
  padding:1.2rem 1.4rem;display:flex;gap:1.2rem;align-items:center;flex-wrap:wrap;
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.cookie.show{transform:translateX(-50%) translateY(0)}
.cookie p{margin:0;font-size:.9rem;color:var(--ink-soft);flex:1;min-width:220px}
.cookie p b{color:var(--ink)}
.cookie .acts{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie .btn{padding:.6rem 1.1rem;font-size:.9rem}

/* ---------- generic page hero (subpages) ---------- */
.page-hero{position:relative;background:var(--cream-2);border-bottom:1px solid var(--line);overflow:hidden;padding:clamp(2.6rem,6vw,4.6rem) 0 clamp(2.2rem,5vw,3.6rem)}
.page-hero::before{content:"";position:absolute;top:-30%;right:-6%;width:min(46vw,460px);height:min(46vw,460px);border-radius:50%;background:radial-gradient(circle,rgba(197,106,58,.2),transparent 66%);pointer-events:none}
.page-hero .crumb{font-size:.82rem;color:var(--muted);margin-bottom:.7rem}
.page-hero .crumb a{color:var(--fig)}
.page-hero h1{font-size:clamp(2.1rem,5vw,3.4rem);max-width:20ch;position:relative}
.page-hero .lede{color:var(--ink-soft);max-width:60ch;font-size:1.08rem;position:relative}

/* ---------- prose (legal / about pages) ---------- */
.prose{padding:clamp(2.8rem,6vw,4.6rem) 0}
.prose-grid{display:grid;grid-template-columns:230px 1fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:start}
.prose-toc{position:sticky;top:96px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.3rem;font-size:.9rem}
.prose-toc h4{font-family:var(--slab);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fig);margin-bottom:.7rem}
.prose-toc a{display:block;color:var(--ink-soft);padding:.3rem 0;border-bottom:1px dashed var(--line-soft)}
.prose-toc a:last-child{border-bottom:0}
.prose-body{max-width:74ch}
.prose-body h2{font-size:clamp(1.4rem,3vw,2rem);margin-top:2.4rem;padding-top:1.4rem;border-top:1px solid var(--line-soft)}
.prose-body h2:first-child{margin-top:0;padding-top:0;border-top:0}
.prose-body h3{font-size:1.15rem;margin-top:1.5rem}
.prose-body p,.prose-body li{color:var(--ink-soft)}
.prose-body ul{padding-left:1.2rem}
.prose-body li{margin-bottom:.4rem}
.prose-body .nap-box{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--fig);border-radius:var(--r-s);padding:1.1rem 1.3rem;margin:1.4rem 0;font-size:.96rem}
.prose-body .nap-box b{font-family:var(--slab)}
.prose-body .updated{color:var(--muted);font-size:.88rem;font-style:italic}

/* ---------- contact page ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3.4rem);align-items:start;padding:clamp(2.8rem,6vw,4.6rem) 0}
.contact-info .info-item{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 0;border-bottom:1px solid var(--line-soft)}
.contact-info .info-item:last-child{border-bottom:0}
.contact-info .m{flex:none;width:44px;height:44px;border-radius:12px;background:rgba(109,59,94,.12);display:flex;align-items:center;justify-content:center;color:var(--fig)}
.contact-info .m svg{width:20px;height:20px}
.contact-info b{font-family:var(--slab);display:block;font-size:1.02rem}
.contact-info p,.contact-info a{margin:.15rem 0 0;color:var(--ink-soft);font-size:.96rem}
.contact-info a:hover{color:var(--fig)}
.contact-map{margin-top:1.4rem;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-s)}
.contact-map img{width:100%;height:auto;display:block}

/* ---------- 404 ---------- */
.notfound{min-height:66vh;display:flex;align-items:center;padding:clamp(3rem,7vw,6rem) 0;position:relative;overflow:hidden}
.notfound .big{font-family:var(--slab);font-size:clamp(5rem,20vw,12rem);color:var(--fig);line-height:.9;letter-spacing:-.03em}
.notfound .em-fig{color:var(--terra)}

/* ---------- la dispensa (comparison ledger) ---------- */
.dispensa{padding:clamp(3.4rem,7vw,6rem) 0;position:relative}
.dispensa .cornice{margin-top:2.4rem;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r)}
.dispensa-tavola{width:100%;min-width:600px;border-collapse:separate;border-spacing:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-s)}
.dispensa-tavola thead th{font-family:var(--body);text-align:left;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:.95rem 1.1rem;background:var(--cream-2);border-bottom:1px solid var(--line);white-space:nowrap}
.dispensa-tavola tbody th{text-align:left;font-weight:400;padding:.85rem 1.1rem;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.dispensa-tavola tbody td{padding:.85rem 1.1rem;border-bottom:1px solid var(--line-soft);vertical-align:middle;color:var(--ink-soft);font-size:.94rem}
.dispensa-tavola tbody tr:last-child th,.dispensa-tavola tbody tr:last-child td{border-bottom:0}
.dispensa-tavola tbody tr{transition:background .2s ease}
.dispensa-tavola tbody tr:hover{background:rgba(124,138,79,.07)}
.barattolo{display:flex;align-items:center;gap:.75rem}
.barattolo img{width:42px;height:42px;border-radius:11px;border:1px solid var(--line);flex:none;box-shadow:var(--shadow-s)}
.barattolo .txt{display:block;min-width:0}
.barattolo b{font-family:var(--slab);font-size:1.02rem;color:var(--ink);line-height:1.12;display:block}
.barattolo .txt span{font-size:.74rem;color:var(--muted)}
.relax{color:var(--olive);letter-spacing:2px;font-size:.92rem;white-space:nowrap}
.relax .v{color:var(--muted);opacity:.32}
.tag-off{display:inline-block;font-weight:700;font-size:.78rem;padding:.24rem .7rem;border-radius:999px;letter-spacing:.02em}
.tag-off.si{background:rgba(124,138,79,.16);color:#4f5a2c;border:1px solid var(--olive)}
.tag-off.no{background:var(--cream-2);color:var(--muted);border:1px solid var(--line)}
.ritmo{font-family:var(--slab);font-style:italic;color:var(--fig);font-size:.98rem}
.dispensa .postilla{margin:1.3rem 0 0;font-size:.86rem;color:var(--muted);font-style:italic;display:flex;align-items:flex-start;gap:.55rem;max-width:62ch}
.dispensa .postilla svg{width:17px;height:17px;flex:none;margin-top:.15rem;opacity:.8}
@media (max-width:640px){
  .dispensa .cornice{overflow:visible;border-radius:0}
  .dispensa-tavola{min-width:0;border:0;background:transparent;box-shadow:none;overflow:visible}
  .dispensa-tavola thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0;white-space:nowrap}
  .dispensa-tavola tbody,.dispensa-tavola tbody tr,.dispensa-tavola tbody th,.dispensa-tavola tbody td{display:block;width:100%}
  .dispensa-tavola tbody tr{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-s);margin-bottom:1.1rem;overflow:hidden}
  .dispensa-tavola tbody tr:hover{background:var(--paper)}
  .dispensa-tavola tbody th{background:var(--cream-2);border-bottom:1px solid var(--line);padding:.9rem 1.05rem}
  .dispensa-tavola tbody td{display:flex;align-items:center;justify-content:space-between;gap:1rem;border-bottom:1px solid var(--line-soft);padding:.7rem 1.05rem;text-align:right}
  .dispensa-tavola tbody tr td:last-child{border-bottom:0}
  .dispensa-tavola tbody td::before{content:attr(data-label);font-family:var(--body);font-weight:700;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:left}
}

/* ---------- momenti della giornata (daypart picks) ---------- */
.momenti{padding:clamp(3.4rem,7vw,6rem) 0;background:var(--cream-2);border-block:1px solid var(--line);position:relative}
.momenti::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 90% 14%,rgba(197,106,58,.1),transparent 32%),radial-gradient(circle at 6% 90%,rgba(84,41,74,.08),transparent 34%);pointer-events:none}
.momenti>.wrap{position:relative;z-index:2}
.momenti-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1rem,1.8vw,1.6rem);margin-top:2.4rem}
.momento{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-s);display:flex;flex-direction:column;transition:transform .28s ease,box-shadow .28s ease}
.momento:hover{transform:translateY(-5px);box-shadow:var(--shadow-m)}
.momento .cielo{position:relative;padding:1.25rem 1.3rem;color:#fdf6ec;display:flex;align-items:center;justify-content:space-between;gap:.7rem}
.momento .cielo .tit{min-width:0}
.momento .cielo h3{color:inherit;margin:0;font-size:1.32rem;line-height:1.1}
.momento .cielo .ora{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;opacity:.92;display:block;margin-top:.22rem}
.momento .cielo .sky-ic{width:34px;height:34px;flex:none;opacity:.95}
.momento.m-mat .cielo{background:linear-gradient(120deg,#c56a3a,#e0a95a)}
.momento.m-pom .cielo{background:linear-gradient(120deg,#7c8a4f,#a9ac5c)}
.momento.m-ser .cielo{background:linear-gradient(125deg,#54294a,#7c4a70)}
.momento .body{padding:1.2rem 1.3rem 1.35rem;display:flex;flex-direction:column;gap:.9rem;flex:1}
.momento .scelta{display:flex;align-items:center;gap:.75rem;background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r-s);padding:.65rem .75rem}
.momento .scelta img{width:44px;height:44px;border-radius:12px;border:1px solid var(--line);flex:none;box-shadow:var(--shadow-s)}
.momento .scelta .tag{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.12rem}
.momento .scelta b{font-family:var(--slab);font-size:1.04rem;line-height:1.12;color:var(--ink)}
.momento .umore{font-size:.92rem;color:var(--ink-soft);margin:0;flex:1}
.momento .go{margin-top:.1rem;display:inline-flex;align-items:center;gap:.45rem;font-weight:700;font-size:.88rem;color:var(--fig);align-self:flex-start}
.momento .go svg{width:15px;height:15px}
.momento .go:hover{color:var(--fig-deep);text-decoration:underline}

/* ============ responsive ============ */
@media (max-width:1140px){
  .stagioni-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:960px){
  .foot-grid{grid-template-columns:1fr 1fr}
  .faq-wrap{grid-template-columns:1fr}
  .faq-aside{position:static}
  .faq-aside img{max-height:300px}
  .prose-grid{grid-template-columns:1fr}
  .prose-toc{position:static}
  .rec-grid{columns:2 260px}
  .mast-grid{grid-template-columns:1fr;gap:2rem}
  .mast-plate{max-width:560px;margin-inline:auto;width:100%}
  .momenti-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .stagioni-grid{grid-template-columns:1fr}
}
@media (max-width:820px){
  .nav{display:none}
  .burger{display:inline-flex}
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{min-height:300px;order:-1}
  .band-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  body{font-size:16px}
  .riga{grid-template-columns:1fr;gap:1.4rem}
  .riga:nth-child(even) .riga-visual{order:0}
  .about-grid{grid-template-columns:1fr}
  .about-visual{max-width:440px}
  .rec-grid{columns:1}
  .foot-grid{grid-template-columns:1fr}
  .cookie{flex-direction:column;align-items:stretch;text-align:left}
  .cookie .acts .btn{flex:1}
}
@media (max-width:400px){
  .wrap{padding-inline:16px}
  .hero-stats{gap:1.1rem}
  .card-top img{width:54px;height:54px}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}
