/* ───────────────────────────────────────────────────────────────────────────
   site.css — shared design system for Vetrina content pages (landing + blog).
   Mirrors the tokens and components used on the homepage so new pages feel
   native. Fonts are loaded per-page via <link> (Playfair Display + Inter).
   ─────────────────────────────────────────────────────────────────────────── */

:root{
  --cream:#ece3cc;
  --cream-deep:#e2d8bd;
  --espresso:#2a2520;
  --yellow:#7d0b0b;
  --yellow-deep:#7d0b0b;
  --muted:#6a5f49;
  --ink:#52483a;
}

*{margin:0;padding:0;box-sizing:border-box;}

.sr-only{
  position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
a:focus-visible,button:focus-visible,input:focus-visible,
select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--yellow);outline-offset:3px;border-radius:2px;
}

html{scroll-behavior:smooth;}
body{
  background:var(--cream);color:var(--espresso);
  font-family:"Inter",-apple-system,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}

.wrap{max-width:1040px;margin:0 auto;}

/* ── store-window mark (reused by header + footer logos) ── */
.mk{display:inline-block;width:.7em;height:.7em;border:1.5px solid currentColor;border-radius:.08em;
  background:linear-gradient(90deg,transparent 49%,currentColor 49%,currentColor 51%,transparent 51%) 0 50%/100% 40% no-repeat,
            linear-gradient(0deg,transparent 49%,currentColor 49%,currentColor 51%,transparent 51%) 50% 0/40% 100% no-repeat;}

/* ── header (always visible on content pages) ── */
.site-header{
  position:sticky;top:0;z-index:30;background:rgba(236,227,204,.92);
  backdrop-filter:saturate(1.1) blur(6px);
  border-bottom:1px solid rgba(125,11,11,.12);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:13px clamp(18px,5vw,46px);
}
.site-header .brand{
  font-family:"Playfair Display",serif;font-weight:600;font-size:clamp(16px,1.6vw,20px);
  letter-spacing:.04em;color:var(--yellow);text-decoration:none;
  display:inline-flex;align-items:center;gap:.4em;
}
.site-nav{display:flex;align-items:center;gap:clamp(14px,2vw,26px);}
.site-nav a{font:500 11px/1 "Inter",sans-serif;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s;}
.site-nav a:hover{color:var(--yellow);}
.site-nav a.nav-cta{color:var(--cream);background:var(--yellow);padding:9px 15px;border-radius:2px;}
.site-nav a.nav-cta:hover{background:#a01010;}
@media (max-width:640px){ .site-nav a:not(.nav-cta){display:none;} }

/* ── landing hero ── */
.lp-hero{
  background:radial-gradient(120% 90% at 50% 0%,#f0e8d2 0%,var(--cream) 60%,var(--cream-deep) 100%);
  padding:clamp(56px,9vw,120px) clamp(20px,6vw,90px) clamp(48px,7vw,90px);
  text-align:center;
}
.lp-eyebrow{font:500 12px/1 "Inter",sans-serif;letter-spacing:.3em;text-transform:uppercase;color:var(--yellow);
  display:inline-flex;align-items:center;gap:12px;margin-bottom:18px;}
.lp-eyebrow::before,.lp-eyebrow::after{content:"";width:26px;height:1px;background:var(--yellow);opacity:.55;}
.lp-hero h1{
  font-family:"Playfair Display",serif;font-weight:600;letter-spacing:-.015em;
  font-size:clamp(30px,5.4vw,60px);line-height:1.04;color:var(--espresso);
  max-width:16ch;margin:0 auto;
}
.lp-hero h1.wide{max-width:24ch;}
.lp-hero h1 em{font-style:italic;color:var(--yellow);}
.lp-lead{margin:22px auto 0;max-width:60ch;
  font:400 clamp(15px,1.4vw,18px)/1.7 "Inter",sans-serif;color:var(--muted);}
.lp-cta-row{margin-top:30px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ── buttons ── */
.btn-primary{display:inline-flex;align-items:center;gap:9px;
  font:600 13px/1 "Inter",sans-serif;letter-spacing:.06em;text-transform:uppercase;
  color:var(--cream);background:var(--yellow);text-decoration:none;border:none;cursor:pointer;
  padding:15px 26px;border-radius:3px;box-shadow:0 6px 18px rgba(125,11,11,.18);
  transition:background .2s,transform .15s,box-shadow .2s;}
.btn-primary:hover{background:#a01010;transform:translateY(-2px);box-shadow:0 10px 24px rgba(125,11,11,.28);}
.btn-ghost{display:inline-flex;align-items:center;gap:9px;
  font:500 13px/1 "Inter",sans-serif;letter-spacing:.04em;color:var(--yellow);text-decoration:none;
  padding:15px 22px;border:1px solid rgba(125,11,11,.4);border-radius:3px;transition:border-color .2s,color .2s;}
.btn-ghost:hover{border-color:#a01010;color:#a01010;}
.wa-btn{display:inline-flex;align-items:center;gap:9px;
  font:500 13px/1 "Inter",sans-serif;letter-spacing:.03em;
  color:#fff;background:#1f7a4d;padding:15px 24px;border-radius:3px;text-decoration:none;transition:background .2s;}
.wa-btn:hover{background:#176039;}

/* ── generic section ── */
.sec{position:relative;padding:clamp(60px,9vw,120px) clamp(20px,6vw,90px);background:var(--cream);}
.sec.alt{background:linear-gradient(180deg,#efe7d2,#e6dbbe);
  border-top:1px solid rgba(125,11,11,.12);border-bottom:1px solid rgba(125,11,11,.12);}
.sec-head{max-width:680px;margin:0 auto clamp(40px,5vw,64px);text-align:center;}
.sec-tag{font:500 11px/1 "Inter",sans-serif;letter-spacing:.3em;text-transform:uppercase;color:var(--yellow);
  display:inline-flex;align-items:center;gap:12px;margin-bottom:14px;}
.sec-tag::before,.sec-tag::after{content:"";width:26px;height:1px;background:var(--yellow);opacity:.55;}
.sec-head h2{font-family:"Playfair Display",serif;font-weight:600;font-size:clamp(26px,4.2vw,46px);line-height:1.06;color:var(--espresso);letter-spacing:-.01em;}
.sec-head h2 em{font-style:italic;color:var(--yellow);}
.sec-head p{margin-top:14px;font:400 clamp(14px,1.2vw,16px)/1.6 "Inter",sans-serif;color:var(--muted);}

/* ── prose (landing body + blog post) ── */
.prose{max-width:680px;margin:0 auto;}
.prose h2{font-family:"Playfair Display",serif;font-weight:600;font-size:clamp(22px,3.2vw,32px);line-height:1.12;color:var(--espresso);letter-spacing:-.01em;margin:clamp(32px,4vw,48px) 0 14px;}
.prose h2 em,.prose h3 em{font-style:italic;color:var(--yellow);}
.prose h3{font-family:"Playfair Display",serif;font-weight:600;font-size:clamp(18px,2.4vw,23px);color:var(--espresso);margin:28px 0 10px;}
.prose p{font:400 clamp(15px,1.25vw,17px)/1.78 "Inter",sans-serif;color:var(--ink);margin:0 0 18px;}
.prose ul,.prose ol{margin:0 0 20px;padding-left:1.2em;}
.prose li{font:400 clamp(15px,1.25vw,17px)/1.7 "Inter",sans-serif;color:var(--ink);margin-bottom:9px;}
.prose strong{color:var(--espresso);font-weight:600;}
.prose a{color:var(--yellow);text-decoration:none;border-bottom:1px solid rgba(125,11,11,.35);}
.prose a:hover{color:#a01010;border-color:#a01010;}
.prose blockquote{margin:0 0 20px;padding:14px 20px;background:#efe7d2;border-left:2px solid var(--yellow);
  border-radius:0 3px 3px 0;font:400 clamp(15px,1.25vw,17px)/1.6 "Inter",sans-serif;color:var(--muted);}
.prose blockquote p{margin:0;}

/* ── "what's included" cards ── */
.incl-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(16px,2vw,26px);max-width:1000px;margin:0 auto;}
.incl-card{background:#f1ead9;border:1px solid rgba(125,11,11,.14);border-radius:5px;padding:24px 22px;}
.incl-card h3{font-family:"Playfair Display",serif;font-weight:600;font-size:18px;color:var(--espresso);margin-bottom:8px;display:flex;align-items:center;gap:9px;}
.incl-card h3 .dot{width:8px;height:8px;border-radius:50%;background:var(--yellow);flex-shrink:0;}
.incl-card p{font:400 13.5px/1.6 "Inter",sans-serif;color:var(--muted);}
.feat-row{display:flex;align-items:flex-start;gap:10px;font:400 15px/1.55 "Inter",sans-serif;color:var(--ink);margin-bottom:12px;}
.feat-row .ok{color:#3a7d3a;font-weight:700;flex-shrink:0;}

/* ── categories / "per chi" nav block ── */
.cats{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;}
.cat-link{display:block;background:#f1ead9;border:1px solid rgba(125,11,11,.14);border-radius:5px;
  padding:18px 20px;text-decoration:none;transition:border-color .2s,transform .15s,background .2s;}
.cat-link:hover{border-color:var(--yellow);transform:translateY(-2px);background:#f5efe0;}
.cat-link .ct{font-family:"Playfair Display",serif;font-weight:600;font-size:17px;color:var(--espresso);display:block;margin-bottom:4px;}
.cat-link .cd{display:block;font:400 13px/1.5 "Inter",sans-serif;color:var(--muted);}
.cat-link .cg{font:500 11px/1 "Inter",sans-serif;letter-spacing:.06em;text-transform:uppercase;color:var(--yellow);margin-top:10px;display:inline-block;}

/* ── FAQ accordion ── */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;}
.faq-item{border-top:1px solid rgba(125,11,11,.18);overflow:hidden;}
.faq-item:last-child{border-bottom:1px solid rgba(125,11,11,.18);}
.faq-q{width:100%;background:none;border:none;cursor:pointer;text-align:left;
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  padding:22px 0;font-family:"Playfair Display",serif;font-weight:500;font-size:clamp(16px,1.6vw,19px);color:var(--espresso);transition:color .2s;}
.faq-q:hover{color:var(--yellow);}
.faq-q .plus{width:22px;height:22px;border:1.5px solid var(--yellow);border-radius:50%;position:relative;flex-shrink:0;transition:transform .35s cubic-bezier(.2,.8,.25,1);}
.faq-q .plus::before,.faq-q .plus::after{content:"";position:absolute;left:50%;top:50%;background:var(--yellow);transition:transform .35s cubic-bezier(.2,.8,.25,1);}
.faq-q .plus::before{width:10px;height:1.5px;transform:translate(-50%,-50%);}
.faq-q .plus::after{width:1.5px;height:10px;transform:translate(-50%,-50%);}
.faq-item.open .faq-q .plus{transform:rotate(135deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.2,.8,.25,1),padding .35s ease;}
.faq-item.open .faq-a{max-height:400px;padding-bottom:22px;}
.faq-a p{font:400 14.5px/1.72 "Inter",sans-serif;color:var(--ink);max-width:64ch;}

/* ── contact / demo CTA (mirrors homepage #chiedici) ── */
.ask-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px);max-width:1040px;margin:0 auto;align-items:start;}
.ask-info > p{font:400 clamp(14px,1.2vw,16px)/1.7 "Inter",sans-serif;color:var(--muted);margin-bottom:24px;}
.ask-item{display:flex;align-items:center;gap:11px;font:400 14px/1.4 "Inter",sans-serif;color:#5e543f;margin-bottom:12px;}
.ask-item svg{flex-shrink:0;color:var(--yellow);}
.ask-item a{color:var(--yellow);text-decoration:none;}
.ask-item a:hover{color:#a01010;}
.ask-note{margin-top:24px;padding:18px 20px;background:#efe7d2;border-left:2px solid var(--yellow);
  font:400 13px/1.65 "Inter",sans-serif;color:var(--muted);border-radius:0 3px 3px 0;}
.ask-note strong{display:block;color:var(--espresso);font-weight:600;margin-bottom:5px;font-family:"Playfair Display",serif;font-size:15px;}
form.ask{display:flex;flex-direction:column;gap:13px;}
form.ask input,form.ask select,form.ask textarea{
  font:400 14px/1.4 "Inter",sans-serif;color:var(--espresso);
  background:#fff;border:1px solid rgba(125,11,11,.18);border-radius:3px;padding:14px 16px;outline:none;transition:border-color .2s;resize:vertical;}
form.ask input::placeholder,form.ask textarea::placeholder{color:#a89e86;}
form.ask input:focus,form.ask select:focus,form.ask textarea:focus{border-color:var(--yellow);}
form.ask button{font:600 13px/1 "Inter",sans-serif;letter-spacing:.06em;text-transform:uppercase;
  color:var(--cream);background:var(--yellow);border:none;padding:16px;border-radius:3px;cursor:pointer;transition:background .2s;}
form.ask button:hover{background:#a01010;}
form.ask button:disabled{background:#1f7a4d;cursor:default;letter-spacing:.02em;text-transform:none;}
@media (max-width:760px){ .ask-grid{grid-template-columns:1fr;gap:34px;} }

/* ── footer ── */
footer.site-footer{
  background:var(--cream-deep);border-top:1px solid rgba(125,11,11,.12);
  padding:clamp(28px,4vw,46px) clamp(20px,6vw,90px);
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;}
.foot-logo{font-family:"Playfair Display",serif;font-weight:600;font-size:19px;color:var(--yellow);letter-spacing:.05em;display:inline-flex;align-items:center;gap:.45em;}
footer.site-footer p{font:400 13px/1.5 "Inter",sans-serif;color:var(--muted);}
footer.site-footer a{color:inherit;border-bottom:1px solid rgba(125,11,11,.3);text-decoration:none;}
.foot-nav{display:flex;gap:16px;flex-wrap:wrap;}
.foot-nav a{font:500 11px/1 "Inter",sans-serif;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border:none;}
.foot-nav a:hover{color:var(--yellow);}

/* ── WhatsApp floating button ── */
.wa-fab{position:fixed;bottom:26px;right:26px;z-index:40;width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;background:#25D366;
  box-shadow:0 10px 26px rgba(37,211,102,.45),0 3px 8px rgba(0,0,0,.18);text-decoration:none;
  transition:transform .25s,box-shadow .25s;}
.wa-fab:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 14px 32px rgba(37,211,102,.5),0 4px 10px rgba(0,0,0,.2);}
.wa-fab .tip{position:absolute;right:calc(100% + 14px);top:50%;transform:translateY(-50%);
  white-space:nowrap;background:var(--espresso);color:var(--cream);font:500 12px/1 "Inter",sans-serif;
  padding:8px 12px;border-radius:4px;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;}
.wa-fab .tip::after{content:"";position:absolute;left:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-left-color:var(--espresso);}
.wa-fab:hover .tip{opacity:1;transform:translateY(-50%) translateX(-4px);}
@media(max-width:560px){.wa-fab{width:52px;height:52px;bottom:18px;right:18px;}}

/* ── cookie banner ── */
.cookie-banner{position:fixed;left:26px;bottom:26px;max-width:360px;z-index:39;
  background:#241310;border:1px solid rgba(217,180,106,.3);border-radius:8px;
  transform:translateY(140%);opacity:0;pointer-events:none;transition:transform .5s cubic-bezier(.2,.8,.25,1),opacity .5s ease;}
.cookie-banner.show{transform:none;opacity:1;pointer-events:auto;}
.cookie-banner-inner{padding:18px 22px;display:flex;flex-direction:column;gap:13px;}
.cookie-banner p{font:400 13px/1.55 "Inter",sans-serif;color:#cbb9a0;margin:0;}
.cookie-banner p strong{color:var(--cream);font-weight:500;}
.cookie-banner p a{color:#d9b46a;text-decoration:none;border-bottom:1px solid rgba(217,180,106,.42);}
.cookie-ok{align-self:flex-start;font:500 11px/1 "Inter",sans-serif;letter-spacing:.1em;text-transform:uppercase;
  color:#1e0c0c;background:#d9b46a;border:none;border-radius:3px;padding:11px 18px;cursor:pointer;transition:background .2s;}
.cookie-ok:hover{background:#e8c886;}
@media(max-width:560px){.cookie-banner{left:14px;right:14px;bottom:14px;max-width:none;}}

/* ── blog index ── */
.post-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:6px;}
.post-row{display:block;text-decoration:none;border-top:1px solid rgba(125,11,11,.18);padding:24px 0;transition:padding-left .2s;}
.post-row:last-child{border-bottom:1px solid rgba(125,11,11,.18);}
.post-row:hover{padding-left:8px;}
.post-row .pdate{font:500 11px/1 "Inter",sans-serif;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);}
.post-row .ptitle{display:block;margin:8px 0 6px;font-family:"Playfair Display",serif;font-weight:600;font-size:clamp(19px,2.4vw,25px);color:var(--espresso);line-height:1.2;}
.post-row .pexc{font:400 14.5px/1.6 "Inter",sans-serif;color:var(--muted);max-width:62ch;}
.post-row.draft{opacity:.55;pointer-events:none;}
.post-row.draft .pdate::after{content:" · in arrivo";color:var(--muted);}

/* ── blog post meta ── */
.post-meta{text-align:center;margin-bottom:8px;font:500 11px/1 "Inter",sans-serif;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);}
.post-back{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font:500 11px/1 "Inter",sans-serif;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-decoration:none;}
.post-back:hover{color:var(--yellow);}
