/* ============================================================
   FORTE STORAGE — "Inventario"
   Sistema chiaro/editoriale: carta neutra + inchiostro + 1 accento blu.
   Type: Space Grotesk (display) · Inter (testo) · Space Mono (dati).
   Anti-slop: niente eyebrow numerati, niente scroll-cue, zero em-dash,
   griglie che variano, accento unico bloccato, angoli quasi vivi.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:84px}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button,input,select,textarea{font:inherit;color:inherit}
.ph{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;flex:none}

:root{
  --paper:#F3F4F1;
  --paper-2:#EAEBE5;
  --ink:#15161B;
  --ink-soft:#33353D;
  --muted:#6B6E75;
  --line:#DDDED8;
  --line-2:#CBCCC4;
  --accent:#2233E0;
  --accent-press:#1A28B4;
  --on-ink:#F3F4F1;
  --on-ink-mut:#9A9CA4;
  --ink-line:rgba(243,244,241,.13);
  --maxw:1240px;
  --r:3px;
  --fd:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --fb:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --fm:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

/* ---------- TEMA SCURO ---------- */
[data-theme="dark"]{
  --paper:#111217;
  --paper-2:#1A1C23;
  --ink:#F2F3F1;
  --ink-soft:#C6C8CE;
  --muted:#90939B;
  --line:rgba(242,243,241,.13);
  --line-2:rgba(242,243,241,.22);
  --accent:#5C6BFF;
  --accent-press:#7A86FF;
  --on-ink:#F2F3F1;
  --on-ink-mut:#9DA0A8;
  --ink-line:rgba(242,243,241,.12);
}
/* superfici che in chiaro erano bianche -> pannello scuro */
[data-theme="dark"] .hero__card,
[data-theme="dark"] .cell,
[data-theme="dark"] .lead-wrap,
[data-theme="dark"] .caro__slide,
[data-theme="dark"] .unit{background:var(--paper-2)}
[data-theme="dark"] .header.scrolled{background:rgba(17,18,23,.85)}
/* bande/elementi che usano var(--ink) come fondo scuro: in dark vanno tenuti scuri */
[data-theme="dark"] .footer,
[data-theme="dark"] .lead-aside,
[data-theme="dark"] .cell--ink,
[data-theme="dark"] .btn--dark{background:#0B0C0F}
[data-theme="dark"] .form__msg.ok{color:var(--accent)}

/* ---------- theme toggle ---------- */
.theme-toggle{width:44px;height:44px;border:1px solid var(--line-2);border-radius:var(--r);background:transparent;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);transition:border-color .2s}
.theme-toggle:hover{border-color:var(--ink)}
.theme-toggle:active{transform:scale(.95)}
.theme-toggle .ph{font-size:20px;line-height:1}
.theme-toggle .i-sun{display:none}
[data-theme="dark"] .theme-toggle .i-sun{display:inline}
[data-theme="dark"] .theme-toggle .i-moon{display:none}

html,body{background:var(--paper)}
body{font-family:var(--fb);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}

/* ---------- layout ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,56px)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--tight{padding-block:clamp(48px,6vw,84px)}
.rule-top{border-top:1px solid var(--line)}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--fd);font-weight:700;line-height:1.0;letter-spacing:-.02em}
.display{font-size:clamp(2.9rem,8.5vw,6.6rem);font-weight:700;letter-spacing:-.035em;line-height:.94}
.h2{font-size:clamp(2rem,5vw,3.6rem);letter-spacing:-.03em;line-height:.98}
.h3{font-size:clamp(1.25rem,2.4vw,1.7rem);font-weight:600;letter-spacing:-.02em}
.lead{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--ink-soft);line-height:1.5;max-width:46ch}
.muted{color:var(--muted)}
.mono{font-family:var(--fm);font-weight:400;letter-spacing:-.02em}
.acc{color:var(--accent)}
.kicker{font-family:var(--fm);font-size:.8rem;color:var(--muted);letter-spacing:0}
.section-head .h2{margin-bottom:18px}
.section-head .lead{color:var(--muted);max-width:52ch}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--fb);font-weight:600;font-size:1rem;line-height:1;
  padding:16px 24px;border:1px solid transparent;border-radius:var(--r);cursor:pointer;
  transition:transform .18s ease,background .2s ease,border-color .2s ease,color .2s ease}
.btn svg{width:17px;height:17px}
.btn .ph{font-size:17px}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--accent);color:#fff}
.btn--primary:hover{background:var(--accent-press)}
.btn--dark{background:var(--ink);color:var(--on-ink)}
.btn--dark:hover{background:#000}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--ink)}
.btn--on-ink{background:var(--paper);color:var(--ink)}
.btn--on-ink:hover{background:#fff}
.btn--block{width:100%;justify-content:center}
.btn--lg{padding:18px 30px}
.contact-link{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:700}
.contact-link .contact-icon{font-size:18px;line-height:1}
.contact-link.is-whatsapp{gap:0;color:#128c4a}
.contact-link.is-whatsapp [data-contact-label],.contact-link.is-whatsapp [data-contact-float-label]{display:none}
.contact-link.is-whatsapp .contact-icon{font-size:22px}
.contact-icon--whatsapp{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;flex:none}
.contact-icon--whatsapp svg{display:block;width:1em;height:1em;fill:currentColor}
[data-theme="dark"] .contact-link.is-whatsapp{color:#4bd16f}

/* ---------- header ---------- */
.header{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.header.scrolled{border-color:var(--line);background:rgba(243,244,241,.86);backdrop-filter:blur(10px)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:72px}
.brandlock{display:flex;align-items:center;gap:11px}
.brandlock .mark{width:30px;height:30px;flex:none}
.brandlock .name{font-family:var(--fd);font-weight:700;letter-spacing:-.03em;font-size:1.2rem;line-height:1}
.brandlock .name b{font-weight:700}
.legal-nav{display:flex;align-items:center;justify-content:space-between;gap:20px}
.legal-nav__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.legal-nav__home{padding:13px 16px}
.nav__links{display:flex;align-items:center;gap:28px}
.nav__links a{font-size:.96rem;color:var(--ink-soft);font-weight:500;position:relative;padding-block:4px}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;background:var(--accent);transition:right .3s cubic-bezier(.16,1,.3,1)}
.nav__links a:hover{color:var(--ink)}
.nav__links a:hover::after{right:0}
.nav__cta{display:flex;align-items:center;gap:12px}
.nav-contact{height:44px;border:1px solid var(--line-2);border-radius:var(--r);padding:0 13px;background:transparent;color:var(--ink-soft);font-size:.9rem;font-weight:700;max-width:230px;transition:border-color .2s,color .2s,background .2s}
.nav-contact:hover{border-color:var(--ink);color:var(--ink)}
.nav-contact.is-whatsapp{width:44px;max-width:44px;padding:0;justify-content:center;color:#128c4a}
.nav-contact.is-whatsapp .contact-icon{font-size:24px}
.nav-contact span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav__toggle{display:none;width:44px;height:44px;border:1px solid var(--line-2);border-radius:var(--r);background:transparent;align-items:center;justify-content:center;cursor:pointer}
.nav__toggle:hover{border-color:var(--ink)}
.nav__toggle .bars{position:relative;width:20px;height:12px;display:block}
.nav__toggle .bars span{position:absolute;left:0;width:100%;height:2px;background:var(--ink);transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .25s}
.nav__toggle .bars span:nth-child(1){top:0}
.nav__toggle .bars span:nth-child(2){top:5px}
.nav__toggle .bars span:nth-child(3){top:10px}
.nav__toggle.is-active .bars span:nth-child(1){transform:translateY(5px) rotate(45deg)}
.nav__toggle.is-active .bars span:nth-child(2){opacity:0}
.nav__toggle.is-active .bars span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

/* ---------- mobile menu (overlay chiaro) ---------- */
body.menu-locked{overflow:hidden}
.mmenu{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;background:var(--paper);
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .4s ease,visibility .4s ease;
  padding:0 clamp(20px,6vw,40px) calc(env(safe-area-inset-bottom,0px) + 28px);overflow-y:auto;overscroll-behavior:contain}
.mmenu.is-open{opacity:1;visibility:visible;pointer-events:auto}
.mmenu__bar{display:flex;align-items:center;justify-content:space-between;height:72px;border-bottom:1px solid var(--line)}
.mmenu__close{width:44px;height:44px;border:1px solid var(--line-2);border-radius:var(--r);background:transparent;display:grid;place-items:center;cursor:pointer}
.mmenu__close:hover{border-color:var(--ink)}
.mmenu__close svg{width:22px;height:22px;stroke:var(--ink)}
.mmenu__nav{display:flex;flex-direction:column;flex:1;justify-content:center;padding-block:20px}
.mm-item{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:clamp(12px,2.2vh,18px) 0;border-bottom:1px solid var(--line);
  font-family:var(--fd);font-weight:700;letter-spacing:-.03em;font-size:clamp(2rem,9vw,2.8rem);line-height:1;color:var(--ink);transition:color .2s,padding-left .35s cubic-bezier(.16,1,.3,1)}
.mm-item .mm-arrow{width:24px;height:24px;stroke:var(--accent);opacity:0;transform:translateX(-8px);transition:opacity .25s,transform .35s cubic-bezier(.16,1,.3,1);flex:none;align-self:center}
.mm-item:active{color:var(--accent);padding-left:10px}
.mm-item:active .mm-arrow{opacity:1;transform:translateX(0)}
@media(hover:hover){.mm-item:hover{color:var(--accent);padding-left:10px}.mm-item:hover .mm-arrow{opacity:1;transform:translateX(0)}}
.mmenu__foot{padding-top:26px;border-top:1px solid var(--line)}
.mmenu__facts{display:flex;flex-wrap:wrap;gap:8px 20px;font-family:var(--fm);font-size:.82rem;color:var(--muted);margin-bottom:20px}
.mmenu__contact{margin-top:18px;padding-top:18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
.mmenu__contact>span{font-family:var(--fm);font-size:.78rem;color:var(--muted)}
.mmenu__contact-link{font-size:1rem;word-break:break-word}
.mmenu__contact-link.is-whatsapp{width:44px;height:44px;border:1px solid var(--line-2);border-radius:var(--r);justify-content:center}
.mmenu__contact-link.is-whatsapp .contact-icon{font-size:25px}
.mmenu__contact-number{display:block;font-family:var(--fd);font-size:1.15rem;font-weight:700;letter-spacing:-.01em;color:var(--ink)}

/* ---------- hero (asimmetrico, chiaro) ---------- */
.hero{padding-top:clamp(36px,6vw,72px);padding-bottom:clamp(40px,6vw,72px)}
.hero__grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(28px,4vw,56px);align-items:end}
.hero__title{margin-bottom:26px}
.hero__title .stroke{-webkit-text-stroke:1.5px var(--ink);color:transparent;text-stroke:1.5px var(--ink)}
.hero__sub{max-width:40ch;margin-bottom:30px;font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--ink-soft)}
.hero__actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.hero__note{font-family:var(--fm);font-size:.84rem;color:var(--muted)}
.hero__card{border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;background:#fff}
.hero__card figure{position:relative;aspect-ratio:4/5;overflow:hidden}
.hero__card img{width:100%;height:100%;object-fit:cover;filter:contrast(1.03)}
.hero__card .spec{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-top:1px solid var(--line);font-family:var(--fm);font-size:.82rem;color:var(--muted)}
.hero__card .spec b{font-family:var(--fd);font-size:1.05rem;color:var(--ink);font-weight:700;letter-spacing:-.02em}

/* ---------- facts band ---------- */
.facts{border-block:1px solid var(--line)}
.facts__row{display:grid;grid-template-columns:repeat(4,1fr)}
.fact{padding:30px 8px 30px 0}
.fact+.fact{padding-left:clamp(16px,2.5vw,34px);border-left:1px solid var(--line)}
.fact b{display:block;font-family:var(--fd);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.7rem);letter-spacing:-.03em;line-height:1}
.fact span{font-size:.92rem;color:var(--muted);margin-top:6px;display:block}

/* ---------- editorial 2-col ---------- */
.edit{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,80px);align-items:start}
.edit__big{font-family:var(--fd);font-weight:700;font-size:clamp(2.1rem,5vw,3.6rem);letter-spacing:-.03em;line-height:.98}
.edit__body p{font-size:clamp(1.05rem,1.4vw,1.22rem);color:var(--ink-soft);max-width:52ch}
.edit__body p+p{margin-top:18px}

/* ---------- bento (cosa conservare) ---------- */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:48px}
.cell{border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:26px;display:flex;flex-direction:column;justify-content:space-between;min-height:200px;transition:border-color .25s,transform .25s ease}
.cell:hover{border-color:var(--ink);transform:translateY(-3px)}
.cell h3{margin-bottom:8px}
.cell p{color:var(--muted);font-size:.95rem;max-width:30ch}
.cell .ico{font-size:30px;color:var(--accent);margin-bottom:auto;line-height:1}
.cell--wide{grid-column:span 4}
.cell--reg{grid-column:span 2}
.cell--img{grid-column:span 2;padding:0;overflow:hidden;min-height:220px;position:relative}
.cell--img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;filter:contrast(1.03)}
.cell--ink{background:var(--paper-2);color:var(--ink);border-color:var(--line)}
.cell--ink p{color:var(--muted)}
.cell--ink .ico{color:var(--accent)}
.cell--ink:hover{border-color:var(--ink);transform:translateY(-3px)}

/* ---------- dark band (sicurezza) ---------- */
.band-ink{background:var(--paper-2);color:var(--ink);border-block:1px solid var(--line)}
.band-ink .lead,.band-ink .muted{color:var(--muted)}
.secure{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center}
.secure__media{border-radius:var(--r);overflow:hidden;border:1px solid var(--line-2)}
.secure__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;filter:contrast(1.03)}

/* ---------- Unità: esterne e interne ---------- */
.units{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:44px}
.unit{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;transition:transform .3s cubic-bezier(.16,1,.3,1),border-color .3s}
.unit:hover{transform:translateY(-4px);border-color:var(--ink)}
.unit__img{aspect-ratio:4/3;overflow:hidden}
.unit__img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.03)}
.unit figcaption{padding:18px 22px}
.unit figcaption h3{margin-bottom:6px}
.unit figcaption p{color:var(--muted);font-size:.95rem}
.secure__list{margin-top:22px;border-top:1px solid var(--line)}
.secure__item{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.secure__item .n{font-size:22px;color:var(--accent);flex:none;padding-top:2px}
.secure__item h4{font-family:var(--fb);font-weight:700;font-size:1.05rem;margin-bottom:2px}
.secure__item p{color:var(--muted);font-size:.95rem}

/* ---------- come funziona ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:48px;border-top:1px solid var(--line)}
.step{padding:34px 26px 34px 0;border-bottom:1px solid var(--line)}
.step .big{font-family:var(--fd);font-weight:700;font-size:3rem;letter-spacing:-.04em;line-height:1;color:var(--line-2);margin-bottom:18px}
.step h3{margin-bottom:8px}
.step p{color:var(--muted);font-size:.96rem;max-width:34ch}
.step+.step{padding-left:clamp(20px,3vw,40px);border-left:1px solid var(--line)}
.step__icon{font-size:32px;color:var(--accent)}

/* ---------- prezzi (lista, non 3 card uguali) ---------- */
.plans{margin-top:48px;border-top:1px solid var(--ink)}
.plan{display:grid;grid-template-columns:1fr 1.7fr;gap:24px;align-items:center;padding:28px 0;border-bottom:1px solid var(--line)}
.plan__name{display:flex;flex-direction:column;gap:6px}
.plan__name h3{font-size:1.5rem}
.plan__name .size{font-family:var(--fm);font-size:.84rem;color:var(--muted)}
.plan__desc{color:var(--ink-soft);font-size:.98rem;max-width:42ch}
.plan__price{text-align:right;white-space:nowrap}
.plan__price .num{font-family:var(--fd);font-weight:700;font-size:2.2rem;letter-spacing:-.03em}
.plan__price .per{font-family:var(--fm);font-size:.8rem;color:var(--muted);display:block;margin-top:2px}
.plan--feat{background:var(--paper-2);margin-inline:clamp(-20px,-2vw,-24px);padding-inline:clamp(20px,2vw,24px)}
.plan--feat .tag{display:inline-block;font-family:var(--fm);font-size:.72rem;color:var(--accent);margin-bottom:2px}
.plans__note{margin-top:22px;font-family:var(--fm);font-size:.82rem;color:var(--muted);max-width:70ch;line-height:1.7}

/* ---------- carosello social ---------- */
.caro{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:8px 0 22px;margin-top:44px;scrollbar-width:none}
.caro::-webkit-scrollbar{display:none}
.caro__slide{flex:0 0 auto;width:clamp(216px,70vw,272px);scroll-snap-align:start;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-2);background:#fff;transition:transform .3s cubic-bezier(.16,1,.3,1)}
.caro__slide img{width:100%;height:auto;aspect-ratio:941/1672}
.caro__slide:active{transform:scale(.99)}
@media(hover:hover){.caro__slide:hover{transform:translateY(-5px)}}

/* ---------- offerta (banda accento) ---------- */
.offer{background:var(--accent);color:#fff;border-radius:var(--r)}
.offer__in{display:grid;grid-template-columns:1.5fr auto;gap:28px;align-items:center;padding:clamp(34px,5vw,56px)}
.offer h2{color:#fff}
.offer p{color:rgba(255,255,255,.82);margin-top:10px;max-width:46ch}

/* ---------- form ---------- */
.lead-wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff}
.lead-aside{padding:clamp(30px,4vw,48px);background:var(--paper-2);color:var(--ink)}
.lead-aside h3{font-size:1.5rem;margin-bottom:18px}
.lead-aside ul{display:flex;flex-direction:column;gap:14px;margin-bottom:26px}
.lead-aside li{display:flex;gap:12px;color:var(--ink);font-size:.96rem;align-items:flex-start}
.lead-aside li .ph{color:var(--accent);font-size:18px;flex:none;margin-top:2px}
.lead-aside .contact{font-family:var(--fm);font-size:.86rem;color:var(--muted);border-top:1px solid var(--line);padding-top:20px}
.lead-aside .contact__place{display:block;margin-bottom:10px}
.contact-link--inline{font-family:var(--fb);font-size:.96rem;word-break:break-word}
.form{padding:clamp(30px,4vw,48px)}
.field{margin-bottom:18px}
.field label{display:block;font-size:.84rem;font-weight:600;margin-bottom:7px}
.field label .req{color:var(--accent)}
.field input,.field select,.field textarea{width:100%;background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r);padding:13px 14px;font-size:.97rem;transition:border-color .2s,box-shadow .2s}
.field textarea{resize:vertical;min-height:96px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(34,51,224,.14)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236B6E75' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.84rem;color:var(--muted);margin:4px 0 20px}
.consent input{width:18px;height:18px;flex:none;margin-top:2px;accent-color:var(--accent)}
.consent a{color:var(--accent);text-decoration:underline}
.form .error{border-color:#d8462e!important}
.form__msg{display:none;margin-top:16px;padding:14px 16px;border-radius:var(--r);font-size:.93rem}
.form__msg.ok{display:block;background:rgba(34,51,224,.08);border:1px solid rgba(34,51,224,.3);color:var(--accent-press)}
.form__msg.bad{display:block;background:rgba(216,70,46,.08);border:1px solid rgba(216,70,46,.35);color:#a8331f}
.form__msg--success{display:flex!important;flex-direction:column;gap:4px;padding:18px 18px 18px 48px;position:relative;line-height:1.45}
.form__msg--success::before{content:"";position:absolute;left:18px;top:19px;width:18px;height:18px;border-radius:50%;background:var(--accent)}
.form__msg--success::after{content:"";position:absolute;left:24px;top:23px;width:6px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.form__msg--success strong{font-family:var(--fd);font-size:1.05rem;color:var(--ink)}
.form__msg--success span{color:var(--ink-soft)}
.form button[disabled]{opacity:.72;cursor:wait}

/* ---------- faq ---------- */
.faq{margin-top:40px;border-top:1px solid var(--ink)}
.qa{border-bottom:1px solid var(--line)}
.qa__q{width:100%;text-align:left;background:none;border:0;padding:24px 0;display:flex;justify-content:space-between;gap:20px;align-items:baseline;cursor:pointer;font-family:var(--fd);font-weight:600;font-size:clamp(1.1rem,2vw,1.45rem);letter-spacing:-.02em;color:var(--ink)}
.qa__q .pm{flex:none;width:22px;height:22px;position:relative;align-self:center}
.qa__q .pm::before,.qa__q .pm::after{content:"";position:absolute;background:var(--accent);transition:transform .3s cubic-bezier(.16,1,.3,1)}
.qa__q .pm::before{top:50%;left:0;right:0;height:2px;transform:translateY(-50%)}
.qa__q .pm::after{left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%)}
.qa[open] .qa__q .pm::after{transform:translateX(-50%) scaleY(0)}
.qa__a{padding:0 0 26px;color:var(--ink-soft);max-width:68ch;font-size:1.02rem}
.qa summary{list-style:none}
.qa summary::-webkit-details-marker{display:none}

/* ---------- footer ---------- */
.footer{background:var(--paper-2);color:var(--ink);border-top:1px solid var(--line);padding-block:clamp(56px,7vw,84px) 30px}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px}
.footer .brandlock .name{color:var(--ink)}
.footer p{color:var(--muted);font-size:.94rem;margin-top:16px;max-width:34ch}
.footer h5{font-family:var(--fm);font-size:.78rem;color:var(--muted);margin-bottom:16px;font-weight:400}
.footer ul{display:flex;flex-direction:column;gap:11px}
.footer ul a,.footer ul li{color:var(--ink);font-size:.95rem}
.footer ul a:hover{color:var(--accent)}
.footer .footer-contact{color:var(--accent)}
.footer__bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-family:var(--fm);font-size:.8rem;color:var(--muted)}
.footer__bottom a:hover{color:var(--accent)}

/* ---------- floating mobile contact ---------- */
.mobile-contact-float{position:fixed;right:16px;bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:70;display:none;align-items:center;gap:8px;padding:12px 14px;border:1px solid var(--line-2);border-radius:999px;background:var(--paper);color:var(--ink);box-shadow:0 12px 34px rgba(0,0,0,.22);font-size:.9rem;line-height:1;opacity:0;pointer-events:none;transform:translateY(12px);transition:opacity .25s ease,transform .25s ease,bottom .25s ease,color .2s,background .2s,width .2s,height .2s,padding .2s}
.mobile-contact-float .contact-icon{font-size:20px}
.mobile-contact-float.is-visible{opacity:1;pointer-events:auto;transform:none}
.mobile-contact-float.is-whatsapp{width:62px;height:62px;padding:0;justify-content:center;background:#128c4a;color:#fff;border-color:#128c4a}
.mobile-contact-float.is-whatsapp .contact-icon{font-size:36px;color:#fff}
body.cookie-open .mobile-contact-float{bottom:calc(var(--cookie-banner-offset,194px) + env(safe-area-inset-bottom,0px))}

/* ---------- cookie banner ---------- */
.cookie-banner{position:fixed;left:50%;bottom:18px;z-index:90;width:min(calc(100% - 32px),980px);transform:translateX(-50%);background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:0 18px 60px rgba(0,0,0,.28);padding:20px;color:var(--ink)}
.cookie-banner__main{display:grid;grid-template-columns:1fr auto;gap:22px;align-items:end}
.cookie-banner h2{font-size:1.2rem;margin-bottom:8px;letter-spacing:-.02em}
.cookie-banner p{max-width:68ch;color:var(--ink-soft);font-size:.94rem;line-height:1.55}
.cookie-banner__links{display:flex;flex-wrap:wrap;gap:14px;margin-top:12px;font-size:.86rem;color:var(--accent);font-weight:600}
.cookie-banner__actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.cookie-banner__actions .btn,.cookie-prefs__foot .btn{padding:13px 16px;font-size:.9rem}
.cookie-prefs{margin-top:18px;border-top:1px solid var(--line);padding-top:16px}
.cookie-pref{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}
.cookie-pref strong{display:block;font-family:var(--fd);font-size:.98rem;letter-spacing:-.01em}
.cookie-pref span{display:block;color:var(--muted);font-size:.88rem;line-height:1.45;margin-top:3px}
.cookie-state{font-size:.78rem!important;color:var(--accent)!important;font-weight:700;text-align:right;text-transform:uppercase;letter-spacing:.04em}
.cookie-pref input{width:22px;height:22px;accent-color:var(--accent)}
.cookie-prefs__foot{display:flex;justify-content:flex-end;padding-top:16px}

/* ---------- reveal / motion ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.hero-rise{opacity:0;transform:translateY(24px)}
.hero-rise.in{opacity:1;transform:none;transition:opacity .7s ease,transform .8s cubic-bezier(.16,1,.3,1);transition-delay:calc(var(--i,0)*90ms + 60ms)}
.mo .reveal,.mo .hero-rise{transition:none}
.mmenu .reveal-item{opacity:0;transform:translateY(18px)}
.mmenu.is-open .reveal-item{opacity:1;transform:none;transition:opacity .45s ease,transform .55s cubic-bezier(.16,1,.3,1);transition-delay:calc(var(--i,0)*50ms + 80ms)}
.mmenu.mm--motion .reveal-item{transition:none}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal,.hero-rise,.mmenu .reveal-item{opacity:1;transform:none;transition:none}
}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .hero__grid{grid-template-columns:1fr;gap:36px}
  .hero__card{max-width:420px}
  .secure{grid-template-columns:1fr}
  .lead-wrap{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .nav__links{display:none}
  .nav__cta .btn{display:none}
  .nav-contact{display:none}
  .nav-contact.is-whatsapp{display:inline-flex}
  .nav__toggle{display:flex}
  .edit{grid-template-columns:1fr;gap:20px}
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento>*{grid-column:auto!important}
  .cell--img{min-height:200px}
  .units{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .step,.step+.step{padding:26px 0;border-left:0;border-bottom:1px solid var(--line)}
  .offer__in{grid-template-columns:1fr;gap:22px}
  .plan{grid-template-columns:1fr;gap:10px;align-items:start}
  .plan__price{text-align:left}
  .plan__desc{max-width:none}
  .cookie-banner{bottom:0;width:100%;border-radius:0;border-inline:0;padding:18px}
  .cookie-banner__main{grid-template-columns:1fr;gap:16px}
  .cookie-banner__actions{display:grid;grid-template-columns:1fr;justify-content:stretch}
  .cookie-banner__actions .btn,.cookie-prefs__foot .btn{width:100%;justify-content:center}
  .cookie-pref{grid-template-columns:1fr;gap:10px}
  .cookie-state{text-align:left}
  .mobile-contact-float{display:inline-flex}
}
@media (max-width:560px){
  .display{font-size:clamp(2.3rem,9vw,3rem);line-height:.98}
  .h2{font-size:clamp(1.8rem,6.6vw,2.4rem)}
  .edit__big{font-size:clamp(1.85rem,6.8vw,2.4rem)}
  .mm-item{font-size:clamp(1.85rem,8vw,2.4rem)}
  .facts__row{grid-template-columns:1fr 1fr}
  .fact{padding:22px 8px}
  .fact:nth-child(2){border-left:0}
  .fact:nth-child(3),.fact:nth-child(4){border-top:1px solid var(--line)}
  .fact:nth-child(odd){border-left:0}
  .bento{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn{width:100%;justify-content:center}
}
