header, footer, section, main, nav, aside, article { display: block }
.visually-hidden { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0) }
.site-nav ul { list-style:none; margin:0; padding:0; display:flex; gap:1rem; align-items:center }
.site-nav .menu-toggle { display:none }
.site-nav a { display:inline-flex; align-items:center; padding:.5rem .75rem; border-radius:999px; color: var(--color-text) }
.site-nav a:hover { background: rgba(44,110,73,.08); color: var(--color-primary) }
.site-nav .current-menu-item > a,
.site-nav .current-menu-ancestor > a,
.site-nav .current_page_item > a,
.site-nav .current_page_parent > a,
.site-nav a[aria-current="page"] { background: var(--color-primary); color:#fff }
.site-footer .site-nav { flex-direction: column; align-items:flex-start; gap:.25rem }
.site-footer .site-nav a { padding:.25rem .5rem }
.header-actions { display:flex; align-items:center; gap:.75rem }
.header-search input { width: 220px; max-width: 34vw; padding:.55rem .7rem; border:1px solid #e7e7e7; border-radius:999px; background:#fff }
.header-search input:focus { outline: 2px solid rgba(44,110,73,.25); border-color: rgba(44,110,73,.45) }
.header-cart { display:inline-flex; align-items:center; gap:.35rem; padding:.55rem .7rem; border:1px solid #e7e7e7; border-radius:999px; color: var(--color-text) }
.header-cart-count { min-width: 1.6rem; height:1.6rem; display:inline-flex; align-items:center; justify-content:center; background: var(--color-primary); color:#fff; border-radius:999px; font-size:.85rem; padding:0 .45rem }
.se-cookie { position:fixed; left:0; right:0; bottom:0; z-index:1000; padding: .9rem; background: rgba(255,255,255,.92); backdrop-filter: blur(10px) saturate(180%); border-top: 3px solid var(--color-primary) }
.se-cookie[hidden] { display:none }
.se-cookie-inner { max-width: var(--container); margin: 0 auto; display:grid; grid-template-columns: 1fr auto; gap: 1rem; align-items:center }
.se-cookie-actions { display:flex; gap:.5rem; flex-wrap:wrap; justify-content:flex-end }
.se-cookie-links { margin-top:.35rem }
.se-cookie-links a { color: var(--color-primary) }
@media (max-width: 820px) { .se-cookie-inner { grid-template-columns: 1fr; } .se-cookie-actions { justify-content:flex-start } }

.se-cookie-modal { position:fixed; inset:0; z-index:1100; background: rgba(0,0,0,.45); padding: 1rem; display:flex; align-items:flex-end; justify-content:center }
.se-cookie-modal[hidden] { display:none }
.se-cookie-modal-card { width: min(560px, 100%); background:#fff; border-radius:16px; border:1px solid #eaeaea; padding: 1rem; box-shadow: 0 16px 40px rgba(0,0,0,.18) }
.se-cookie-toggles { display:grid; gap:.6rem; margin: .75rem 0 1rem 0 }
.se-cookie-toggle { display:flex; align-items:center; justify-content:space-between; gap: 1rem; padding: .75rem; border:1px solid #eee; border-radius:14px; background:#fff }
.se-cookie-toggle input { width: 44px; height: 24px; accent-color: var(--color-primary) }
.se-cookie-modal-actions { display:flex; justify-content:flex-end; gap:.5rem; flex-wrap:wrap }
.se-cookie-fab { position:fixed; left: 1rem; bottom: 1rem; z-index:900; border:1px solid #eaeaea; background:#fff; color: var(--color-text); border-radius:999px; padding: .55rem .75rem; box-shadow: 0 8px 22px rgba(0,0,0,.08); cursor:pointer }
.se-cookie-fab[hidden] { display:none }
@media (max-width: 820px) {
  .site-nav ul { display:none; flex-direction:column; background:#fff; position:absolute; top:64px; right:1rem; left:1rem; padding:1rem; border:1px solid #eee; border-radius:12px }
  .site-nav.open ul { display:flex }
  .site-nav .menu-toggle { display:inline-flex }
  .header-search { display:none }
}
.post-item { display:grid; gap:1rem; grid-template-columns: 180px 1fr; align-items:start }
@media (max-width: 720px) { .post-item { grid-template-columns:1fr } }
.post-item h2 { margin:0 }
.se-blog-head { margin: 1rem 0 1.25rem 0 }
.se-post-grid { display:grid; gap:1.25rem; grid-template-columns: repeat(3, minmax(0, 1fr)) }
@media (max-width: 980px) { .se-post-grid { grid-template-columns: 1fr } }
.se-post-card, .se-post-featured { border:1px solid #eaeaea; border-radius:16px; overflow:hidden; background:#fff; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease }
.se-post-card:hover, .se-post-featured:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(0,0,0,.06); border-color: #e2e2e2 }
.se-post-featured { display:grid; grid-template-columns: 1.2fr 1fr; gap:0 }
@media (max-width: 980px) { .se-post-featured { grid-template-columns: 1fr } }
.se-post-media { display:block; background:#f5f3ef; aspect-ratio: 16/9; overflow:hidden }
.se-post-media img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .25s ease }
.se-post-card:hover .se-post-media img, .se-post-featured:hover .se-post-media img { transform: scale(1.03) }
.se-post-body { padding: 1rem }
.se-post-cats, .se-article-cats { margin-bottom: .35rem }
.se-post-cats ul, .se-post-cats li, .se-article-cats ul, .se-article-cats li { list-style:none; margin:0; padding:0 }
.se-post-cats a { display:inline-flex; align-items:center; padding:.2rem .55rem; border:1px solid #eee; border-radius:999px; font-size:.8rem; margin: 0 .35rem .35rem 0; background:#fff; color: var(--color-text); transition: border-color .15s ease }
.se-post-cats a:hover { border-color: rgba(44,110,73,.35) }
.se-article-cats a { display:inline-flex; align-items:center; padding:.2rem .55rem; border:1px solid #eee; border-radius:999px; font-size:.8rem; margin: 0 .35rem .35rem 0; background:#fff; color: var(--color-text); transition: border-color .15s ease }
.se-article-cats a:hover { border-color: rgba(44,110,73,.35) }
.se-post-title { margin: .25rem 0 .35rem 0 }
.se-post-title a { color: var(--color-text); text-decoration:none }
.se-post-title a:hover { color: var(--color-primary) }
.se-post-meta { color: var(--color-text-muted); font-size:.9rem; margin-bottom:.35rem }
.se-post-excerpt { color: var(--color-text); opacity:.9 }
.se-reviews-head { display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom: .75rem }
.se-review-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem }
.se-review-card { border:1px solid #eaeaea; border-radius:16px; background:#fff; padding: 1.1rem; box-shadow: 0 8px 22px rgba(0,0,0,.04) }
.se-review-stars { display:flex; gap:.15rem; color: #f0b429; font-size: 1rem; margin-bottom:.6rem }
.se-review-stars .off { opacity: .25 }
.se-review-text { margin: 0 0 .9rem 0; color: var(--color-text); opacity: .92; line-height: 1.75 }
.se-review-author { display:flex; align-items:center; gap:.75rem }
.se-review-avatar { width: 40px; height: 40px; border-radius:999px; background: rgba(44,110,73,.10); color: var(--color-primary-600); display:flex; align-items:center; justify-content:center; font-weight:700 }
.se-review-name { font-weight: 600 }
@media (max-width: 980px) { .se-review-grid { grid-template-columns: 1fr } }
.clamp-2 { display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient: vertical; overflow: hidden }
.clamp-3 { display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient: vertical; overflow: hidden }
.se-pagination { display:flex; justify-content:center; margin: 1.25rem 0 }
.se-pagination ul { display:flex; gap:.4rem; list-style:none; margin:0; padding:0 }
.se-pagination a, .se-pagination span { display:inline-flex; min-width: 2.25rem; height:2.25rem; align-items:center; justify-content:center; border:1px solid #e7e7e7; border-radius:10px; color: var(--color-text) }
.se-pagination .current { background: var(--color-primary); color:#fff; border-color: var(--color-primary) }
.se-edu { position:relative }
.se-edu-row { display:grid; grid-auto-flow: column; grid-auto-columns: minmax(260px, 320px); gap: 1rem; overflow:auto; scroll-snap-type: x mandatory; padding: .25rem; scrollbar-width:none }
.se-edu-row::-webkit-scrollbar { display:none }
.se-edu-card { scroll-snap-align: start; border:1px solid #eaeaea; border-radius:16px; overflow:hidden; background:#fff; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease }
.se-edu-card:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(0,0,0,.06); border-color: #e2e2e2 }
.se-edu-media { display:block; background:#f5f3ef; aspect-ratio: 16/9; overflow:hidden }
.se-edu-media img { width:100%; height:100%; object-fit:cover; transition: transform .25s ease; display:block }
.se-edu-card:hover .se-edu-media img { transform: scale(1.03) }
.se-edu-body { padding: .85rem }
.se-edu-nav { position:absolute; top:50%; transform: translateY(-50%); z-index:3; width:42px; height:42px; border-radius:999px; border:1px solid #e7e7e7; background:#fff; color: var(--color-text); box-shadow: 0 6px 16px rgba(0,0,0,.06); cursor:pointer }
.se-edu-prev { left:-.5rem }
.se-edu-next { right:-.5rem }
.se-edu-nav[disabled] { opacity:.4; cursor: default }
.se-article-hero { margin: 1.25rem 0 1.25rem 0 }
.se-article-meta { display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-bottom:.5rem }
.se-article-cats a { display:inline-flex; align-items:center; padding:.2rem .55rem; border:1px solid #eee; border-radius:999px; font-size:.8rem; margin: 0 .35rem .35rem 0; background:#fff; color: var(--color-text) }
.se-article-intro { font-size: 1.1rem; color: var(--color-text-muted); margin: .75rem 0 1rem 0 }
.se-article-image { margin: 1rem 0 0 0 }
.se-article-image img { border-radius: 12px }
.se-article-content { margin-top: 1.25rem }
.se-article-content p { font-size: 1.05rem; line-height: 1.8; margin: 0 0 1rem 0 }
.se-article-content h2 { margin-top: 2rem; font-size: 1.6rem }
.se-article-content h3 { margin-top: 1.5rem; font-size: 1.25rem }
.se-article-content ul, .se-article-content ol { padding-left: 1.2rem; margin: 0 0 1rem 0 }
.content img { border-radius: 12px }
/* Allineamenti Gutenberg (cover/image wide/full) */
.content .alignwide { width: min(1100px, 92vw); max-width: none; position: relative; left: 50%; transform: translateX(-50%); margin: 1.5rem 0 }
.content .alignfull { width: 100vw; max-width: none; position: relative; left: 50%; right: 50%; margin-left: -50vw; margin-right: -50vw; margin-top: 1.5rem; margin-bottom: 1.5rem }
@media (min-width: 981px) {
  .content .alignwide { margin: 2rem 0 }
  .content .alignfull { margin-top: 2rem; margin-bottom: 2rem }
}
.se-inline-cta { border:1px solid rgba(44,110,73,.2); background: rgba(44,110,73,.04); border-radius:12px; padding: 1rem; margin: 1.25rem 0 }
.se-inline-cta-head { display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom: .75rem }
.se-cross-box { border:1px dashed rgba(44,110,73,.55); border-radius:12px; padding: 1rem; background:#fff; margin: 1.25rem 0; display:flex; align-items:center; justify-content:space-between; gap:1rem }
.se-toc { border:1px solid #eee; border-radius:12px; background:#fff; padding:.25rem .9rem; margin: 1rem 0 1.25rem 0 }
.se-toc summary { cursor:pointer; font-weight:700; padding:.6rem 0; list-style:none }
.se-toc summary::-webkit-details-marker { display:none }
.se-toc nav { padding: .25rem 0 .75rem 0 }
.se-toc-list { list-style:none; padding:0; margin:0; display:grid; gap:.35rem }
.se-toc-item a { color: var(--color-text); text-decoration:none }
.se-toc-item a:hover { color: var(--color-primary) }
.se-toc-h3 { padding-left: 1rem; font-size:.95rem; color: var(--color-text-muted) }
.se-related-products { margin-top: 1.75rem }
.se-faq { margin: 2rem 0 }
.se-faq details { border:1px solid #eee; border-radius:12px; padding: .75rem 1rem; background:#fff; margin: .75rem 0 }
.se-faq summary { cursor:pointer; font-weight:600 }
.se-faq summary::marker { color: var(--color-primary) }
.se-author { display:grid; grid-template-columns: 72px 1fr; gap: 1rem; align-items:start; padding: 1rem; border:1px solid #eee; border-radius:12px; background:#fff; margin: 2rem 0 }
.se-author-avatar { border-radius:999px }
.se-author-bio p { margin: .5rem 0 0 0 }
.woocommerce ul.products li.product a img { border-radius:12px }
.woocommerce div.product div.images img { border-radius:12px }
.woocommerce .quantity .qty { width: 90px }
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button { background: var(--color-primary); color:#fff; border-radius:12px; padding:.75rem 1rem; border:0 }
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover { background: var(--color-primary-600); color:#fff }
.se-product-card { position:relative }
.se-product-media { display:block; position:relative; overflow:hidden; border-bottom:1px solid #eee }
.se-badge { position:absolute; top:.75rem; left:.75rem; background:#fff; border:1px solid #eee; border-radius:999px; padding:.25rem .6rem; font-size:.8rem; z-index:2 }
.woocommerce span.onsale { position:absolute; top:.75rem; right:.75rem; left:auto !important; background: var(--color-primary) !important; color:#fff !important; border-radius:999px !important; padding:.25rem .6rem !important; min-width: auto !important; min-height: auto !important; line-height: 1.2 !important; font-weight:600; font-size:.8rem; transform:none !important; box-shadow: 0 6px 16px rgba(0,0,0,.08); z-index:3 }
.woocommerce ul.products li.product .onsale { top:.75rem; right:.75rem }
.woocommerce div.product .onsale { top:.75rem; left:.75rem; right:auto }
.se-product-cta { margin-top:.75rem }
.woocommerce ul.products li.product .price { margin:.25rem 0 .5rem 0; font-weight:600 }
.benefit-list { display:grid; gap:1rem; grid-template-columns: repeat(3, minmax(0,1fr)) }
@media (max-width:980px){ .benefit-list { grid-template-columns: 1fr } }
.trust-row { display:flex; gap:1rem; flex-wrap:wrap }
.hero-badges { display:flex; gap:.5rem; flex-wrap:wrap; margin: .5rem 0 1rem 0 }
.hero-badges span { background:#fff; border:1px solid #eee; padding:.35rem .6rem; border-radius:999px; font-size:.85rem }
.se-why { display:grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items:center }
.se-why-left { display:flex; flex-direction:column; gap:.75rem }
.se-why-cta { display:flex; gap:.6rem; flex-wrap:wrap; margin-top:.25rem }
.se-why-badges { display:flex; gap:.5rem; margin-top:.75rem; flex-wrap:wrap }
.se-why-badges span { background:#fff; border:1px solid #eee; padding:.28rem .6rem; border-radius:999px; font-size:.8rem }
.se-why-list { list-style:none; padding:0; margin:.25rem 0 .5rem 0; display:grid; gap:.6rem }
.se-why-list li { display:flex; align-items:flex-start; gap:.6rem }
.se-why-list li .se-why-icon { color: var(--color-primary); line-height:1; margin-top:.1rem; width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center; border:1px solid #e7e7e7; border-radius:999px; background:#fff }
.se-why-media { position:relative; border-radius:16px; overflow:hidden; background:#000 }
.se-why-media img { width:100%; height:auto; display:block; transform: scale(1.02); }
.se-why-float-card { position:absolute; left:1rem; bottom:1rem; background:#fff; border:1px solid #e7e7e7; padding:.65rem .8rem; border-radius:12px; box-shadow: 0 8px 22px rgba(0,0,0,.06) }
.se-why-float-title { font-weight:600; margin-bottom:.15rem }
.se-why-badge { position:absolute; top:1rem; right:1rem; background: var(--color-primary); color:#fff; padding:.3rem .6rem; border-radius:999px; font-size:.8rem }
@media (max-width: 980px) { .se-why { grid-template-columns: 1fr } }
.se-section-primary { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-600) 100%) }
.se-final-cta { display:grid; grid-template-columns: 1.25fr .75fr; gap: 1.5rem; align-items: center; border:1px solid #eaeaea; border-radius:20px; background: #fff; overflow:hidden }
.se-final-cta-left { padding: 1.5rem }
.se-final-cta-actions { display:flex; gap:.6rem; flex-wrap:wrap; margin-top:.75rem }
.se-final-cta-trust { display:flex; flex-wrap:wrap; gap:1rem; margin-top: 1rem }
.se-final-cta-media { height: 100%; min-height: 220px }
.se-final-cta-media img { width:100%; height:100%; object-fit:cover; display:block; filter: saturate(105%) contrast(102%) }
.se-section-primary .se-final-cta { border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.08) }
.se-section-primary .se-final-cta-left { color:#fff }
.se-section-primary .se-final-cta h2 { color:#fff }
.se-section-primary .se-final-cta .microcopy { color: rgba(255,255,255,.86) }
.se-section-primary .se-final-cta .trust { color: rgba(255,255,255,.92) }
.se-section-primary .se-final-cta .btn { background:#fff; color: var(--color-primary-600) }
.se-section-primary .se-final-cta .btn:hover { background: rgba(255,255,255,.92); color: var(--color-primary-600) }
.se-section-primary .se-final-cta .btn.btn-outline { background: transparent; border-color:#fff; color:#fff }
.se-section-primary .se-final-cta .btn.btn-outline:hover { background: rgba(255,255,255,.14); border-color:#fff; color:#fff }

.se-section-primary .se-why h2 { color:#fff }
.se-section-primary .se-why .microcopy { color: rgba(255,255,255,.86) }
.se-section-primary .se-why-list li { color: rgba(255,255,255,.9) }
.se-section-primary .se-why-list li strong { color:#fff }
.se-section-primary .se-why-list li .se-why-icon { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.25); color:#fff }
.se-section-primary .se-why-badges span { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.25); color:#fff }
.se-section-primary .se-why-badge { background:#fff; color: var(--color-primary-600) }
.se-section-primary .se-why-float-card { border-color: rgba(255,255,255,.22) }
.se-section-primary .se-why-float-card .microcopy { color: var(--color-primary-600) }
.se-section-primary .se-why-cta .btn { background:#fff; color: var(--color-primary-600) }
.se-section-primary .se-why-cta .btn:hover { background: rgba(255,255,255,.92); color: var(--color-primary-600) }
.se-section-primary .se-why-cta .btn.btn-outline { background: transparent; border-color:#fff; color:#fff }
.se-section-primary .se-why-cta .btn.btn-outline:hover { background: rgba(255,255,255,.14); border-color:#fff; color:#fff }
@media (max-width: 980px) {
  .se-final-cta { grid-template-columns: 1fr }
  .se-final-cta-right { display:none }
}
.se-hero { position:relative; width:100%; padding: 4.25rem 0; overflow:hidden }
.se-hero-inner { position:relative; z-index:2; max-width: 680px }
.se-hero h1 { color:#0f0f0f; font-size: clamp(2.1rem, 3.4vw, 3.2rem) }
.se-hero-sub { color: rgba(15,15,15,.78); margin: .75rem 0 1rem 0; font-size: 1.1rem }
.se-hero-bg { position:absolute; inset:0; z-index:0; overflow:hidden }
.se-hero-bg-img { position:absolute; inset:-10% 0 -10% 0; width:100%; height:120%; object-fit:cover; transform: translate3d(0,0,0) scale(1.08); will-change: transform }
.se-hero-overlay { position:absolute; inset:0; z-index:1; background: linear-gradient(90deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.78) 46%, rgba(255,255,255,.20) 100%) }
.se-hero-trust { margin-top: 1rem }
.se-hero-btn { background: transparent }
/* Varianti hero per pagine blog/archivi */
.se-hero--small { padding: 2.75rem 0 }
.se-hero--center .se-hero-inner { margin: 0 auto; text-align: center; max-width: 780px }
.se-hero--center .se-hero-overlay { background: linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.78) 40%, rgba(255,255,255,.30) 100%) }
.se-hero + .container { margin-top: 1.5rem }
@media (min-width: 981px) { .se-hero + .container { margin-top: 2rem } }
.se-hero--page .se-hero-overlay { background: linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(255,255,255,.84) 50%, rgba(255,255,255,.32) 100%) }
.se-hero--page + .container { margin-top: 1.75rem }
.se-hero--slider { position: relative; padding: 0 }
.se-hero--slider .se-hero-slider { position: relative; z-index: 0 }
.se-hero--slider .se-hero-inner { position: absolute; inset: 0; display:flex; align-items:center; justify-content:center; flex-direction:column; z-index: 2; text-align:center; padding: 3.5rem 1rem }
.se-hero--slider .se-hero-overlay { position:absolute; inset:0; z-index:1; background: linear-gradient(180deg, rgba(255,255,255,.88) 0%, rgba(255,255,255,.42) 100%) }
@media (max-width: 980px) {
  .se-hero { padding: 3.25rem 0 }
  .se-hero--small { padding: 2rem 0 }
  .se-hero-inner { max-width: 100% }
  .se-hero-overlay { background: linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.78) 55%, rgba(255,255,255,.30) 100%) }
}
@media (prefers-reduced-motion: reduce) { .se-hero-bg-img { transform: none; will-change: auto } }
.cta-sticky { position:sticky; top:72px; background:#fff; border:1px solid #eee; border-radius:12px; padding:1rem; }
.product-benefits { margin:.75rem 0 1rem 0; padding:0; list-style:none; display:grid; gap:.4rem }
.product-benefits li { display:flex; gap:.5rem; align-items:flex-start; color: var(--color-text) }
.product-benefits li span { color: var(--color-primary); line-height:1.3 }
.microcopy { color: var(--color-text-muted); font-size: .95rem }
.se-trust-strip { margin: 1rem 0 }
.se-buy-now { margin: .75rem 0 0 0 }
.sticky-atc { position:fixed; left:0; right:0; bottom:0; z-index:60; background:#fff; border-top:1px solid #eee; padding:.75rem 1rem; display:none }
.sticky-atc-inner { max-width: var(--container); margin: 0 auto; display:flex; align-items:center; justify-content:space-between; gap:.75rem }
.sticky-atc-title { font-size: .95rem; font-weight: 600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width: 55vw }
@media (max-width: 980px) {
  .sticky-atc.show { display:block }
  body { padding-bottom: 84px }
}
