:root {
    --ink: #1a1d21;
    --body: #33373d;
    --muted: #6b7280;
    --line: #e7e8ea;
    --bg: #ffffff;
    --soft: #f6f7f8;
    --graphite: #1f2530;
    --accent: #e8622a;
    --accent-dark: #c44e1e;
    --maxw: 1080px;
    --readw: 720px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    color: var(--body);
    background: var(--bg);
    line-height: 1.65;
    font-size: 17px;
}

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

img { max-width: 100%; height: auto; display: block; }

/* ---------- Masthead ---------- */
.masthead { border-bottom: 1px solid var(--line); background: var(--bg); position: sticky; top: 0; z-index: 30; }
.masthead-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; height: 66px; }
.logo {
    font-weight: 800; font-size: 1.18rem; color: var(--ink); letter-spacing: -.02em;
    display: flex; align-items: center; gap: 9px;
}
.logo:hover { text-decoration: none; }
.logo-mark { color: var(--accent); font-size: 1.3rem; line-height: 1; }
.topnav { display: flex; align-items: center; gap: 26px; }
.topnav a { color: var(--body); font-size: .93rem; font-weight: 500; position: relative; padding: 4px 0; }
.topnav a:hover { color: var(--accent); text-decoration: none; }
.topnav a.is-active { color: var(--ink); }
.topnav a.is-active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -3px; height: 2px; background: var(--accent); }
.nav-toggle { position: absolute; width: 1px; height: 1px; opacity: 0; }
.nav-burger { display: none; }

.site-main { padding: 36px 20px 56px; }

/* ---------- Hero / page heads ---------- */
.hero { padding: 30px 0 26px; }
.hero-eyebrow { text-transform: uppercase; letter-spacing: .14em; font-size: .76rem; font-weight: 700; color: var(--accent); margin: 0 0 12px; }
.hero-title {
    font-size: clamp(1.8rem, 4.6vw, 2.7rem); line-height: 1.12; color: var(--ink);
    font-weight: 800; letter-spacing: -.025em; margin: 0; max-width: 820px;
}
.page-head { margin-bottom: 30px; }
.page-h1 { font-size: clamp(1.5rem, 3.5vw, 2.1rem); color: var(--ink); font-weight: 800; letter-spacing: -.02em; margin: 4px 0 8px; }
.page-lead { color: var(--muted); font-size: 1.05rem; max-width: var(--readw); margin: 0; }
.eyebrow {
    text-transform: uppercase; letter-spacing: .08em; font-size: .74rem; font-weight: 700;
    color: var(--accent); margin: 0;
}

/* ---------- Card grid ---------- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 26px; }
.post-card { border: 1px solid var(--line); border-radius: 12px; overflow: hidden; background: var(--bg); transition: border-color .14s ease, transform .14s ease; }
.post-card:hover { border-color: #d4d6da; transform: translateY(-2px); }
.post-card-link { color: inherit; display: block; }
.post-card-link:hover { text-decoration: none; }
.post-thumb {
    aspect-ratio: 16 / 9; background-size: cover; background-position: center;
    background-color: var(--soft);
}
.post-thumb--empty { display: flex; align-items: center; justify-content: center; background: var(--graphite); }
.thumb-mark { color: var(--accent); font-size: 2rem; opacity: .85; }
.post-body { padding: 16px 18px 20px; }
.post-cat { font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; font-weight: 700; color: var(--accent); }
.post-title { font-size: 1.16rem; line-height: 1.3; color: var(--ink); margin: 6px 0 8px; font-weight: 700; letter-spacing: -.01em; }
.post-excerpt { font-size: .94rem; color: var(--muted); margin: 0; }

/* ---------- Pagination ---------- */
.pagination { display: flex; align-items: center; justify-content: center; gap: 22px; margin: 44px 0 0; }
.page-link { font-weight: 600; }
.page-info { color: var(--muted); font-size: .9rem; }

/* ---------- Article ---------- */
.article { max-width: var(--readw); margin: 0 auto; }
.breadcrumb { font-size: .84rem; color: var(--muted); display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.breadcrumb a { color: var(--muted); }
.breadcrumb a:hover { color: var(--accent); }
.article-head { margin-bottom: 22px; }
.article-title { font-size: clamp(1.7rem, 4.5vw, 2.5rem); line-height: 1.15; color: var(--ink); font-weight: 800; letter-spacing: -.02em; margin: 6px 0 14px; }
.article-meta { color: var(--muted); font-size: .9rem; margin: 0; }
.article-cover { margin: 0 0 28px; border-radius: 14px; overflow: hidden; }
.article-cover img { width: 100%; }

.article-body { font-size: 1.08rem; line-height: 1.75; color: var(--body); }
.article-body h2 { font-size: 1.5rem; color: var(--ink); margin: 2em 0 .5em; font-weight: 700; letter-spacing: -.01em; }
.article-body h3 { font-size: 1.22rem; color: var(--ink); margin: 1.6em 0 .4em; font-weight: 700; }
.article-body p { margin: 0 0 1.2em; }
.article-body ul, .article-body ol { margin: 0 0 1.2em; padding-left: 1.4em; }
.article-body li { margin-bottom: .4em; }
.article-body a { font-weight: 500; text-decoration: underline; text-underline-offset: 2px; }
.article-body img { border-radius: 10px; margin: 1.5em 0; }
.article-body blockquote {
    margin: 1.5em 0; padding: 4px 0 4px 18px; border-left: 3px solid var(--accent);
    color: var(--ink); font-style: italic;
}
.article-body table { width: 100%; border-collapse: collapse; margin: 1.5em 0; font-size: .96rem; }
.article-body th, .article-body td { border: 1px solid var(--line); padding: 10px 12px; text-align: left; }
.article-body th { background: var(--soft); font-weight: 700; }

/* ---------- FAQ ---------- */
.faq { margin: 44px 0 0; border-top: 1px solid var(--line); padding-top: 28px; }
.faq h2 { font-size: 1.4rem; color: var(--ink); margin: 0 0 16px; font-weight: 700; }
.faq-item { border: 1px solid var(--line); border-radius: 10px; padding: 4px 16px; margin-bottom: 10px; }
.faq-item summary { cursor: pointer; font-weight: 600; color: var(--ink); padding: 12px 0; list-style: none; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; float: right; color: var(--accent); font-weight: 700; }
.faq-item[open] summary::after { content: "\2212"; }
.faq-item p { margin: 0 0 14px; color: var(--body); }

/* ---------- Related ---------- */
.related { max-width: var(--maxw); margin: 56px auto 0; border-top: 1px solid var(--line); padding-top: 34px; }
.related-title { font-size: 1.3rem; color: var(--ink); margin: 0 0 22px; font-weight: 700; }

/* ---------- Empty / buttons / footer ---------- */
.empty-state { text-align: center; color: var(--muted); padding: 60px 20px; }
.btn-public {
    display: inline-block; margin-top: 14px; background: var(--accent); color: #fff;
    padding: 11px 22px; border-radius: 8px; font-weight: 600;
}
.btn-public:hover { background: var(--accent-dark); text-decoration: none; }

.site-footer { border-top: 1px solid var(--line); margin-top: 50px; padding: 36px 0 26px; color: var(--muted); font-size: .92rem; background: var(--soft); }
.footer-grid { display: flex; justify-content: space-between; gap: 30px 40px; flex-wrap: wrap; }
.footer-col-brand { max-width: 340px; }
.footer-brand { font-weight: 800; color: var(--ink); font-size: 1.12rem; display: inline-flex; align-items: center; gap: 8px; }
.footer-tag { margin: 8px 0 0; color: var(--muted); font-size: .92rem; line-height: 1.5; }
.footer-nav { display: flex; flex-wrap: wrap; gap: 10px 24px; align-content: flex-start; }
.footer-nav a { color: var(--body); }
.footer-nav a:hover { color: var(--accent); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 26px; padding-top: 18px; border-top: 1px solid var(--line); }
.footer-bottom a { color: var(--muted); }
.footer-bottom a:hover { color: var(--accent); }

@media (max-width: 860px) {
    .nav-burger {
        display: flex; flex-direction: column; justify-content: center; gap: 5px;
        width: 44px; height: 44px; margin-right: -10px; cursor: pointer;
    }
    .nav-burger span { display: block; width: 24px; height: 2px; background: var(--ink); border-radius: 2px; transition: transform .2s ease, opacity .2s ease; }
    .topnav {
        position: absolute; top: 100%; left: 0; right: 0; background: var(--bg);
        border-bottom: 1px solid var(--line); box-shadow: 0 12px 24px rgba(0,0,0,.07);
        flex-direction: column; align-items: stretch; gap: 0; padding: 4px 20px 14px; display: none;
    }
    .nav-toggle:checked ~ .topnav { display: flex; }
    .topnav a { padding: 14px 2px; border-bottom: 1px solid var(--line); font-size: 1rem; }
    .topnav a:last-child { border-bottom: none; }
    .topnav a.is-active::after { display: none; }
    .topnav a.is-active { color: var(--accent); }
    .nav-toggle:checked ~ .nav-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .nav-toggle:checked ~ .nav-burger span:nth-child(2) { opacity: 0; }
    .nav-toggle:checked ~ .nav-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}

@media (max-width: 640px) {
    body { font-size: 16px; }
    .masthead-inner { height: 58px; }
    .site-main { padding: 26px 18px 44px; }
}

@media (prefers-reduced-motion: reduce) {
    * { transition: none !important; scroll-behavior: auto; }
}

/* ---------- Box prodotto Amazon ---------- */
.amz-box {
    display: flex; gap: 20px; align-items: center; border: 1px solid var(--line);
    border-radius: 16px; padding: 18px 22px; margin: 2.2em 0; background: #fff;
    box-shadow: 0 1px 2px rgba(16,24,40,.04), 0 10px 28px rgba(16,24,40,.07);
    transition: box-shadow .18s ease, transform .18s ease;
}
.amz-box:hover { box-shadow: 0 2px 6px rgba(16,24,40,.06), 0 16px 40px rgba(16,24,40,.12); transform: translateY(-2px); }
.amz-box a { text-decoration: none; }
.amz-box a:hover { text-decoration: none; }
.amz-box-media {
    position: relative; flex-shrink: 0; width: 140px; height: 140px; display: flex;
    align-items: center; justify-content: center; background: #fff; border: 1px solid var(--line);
    border-radius: 12px; overflow: hidden;
}
.amz-box-media img { max-width: 86%; max-height: 86%; object-fit: contain; }
.amz-box-mark { color: var(--accent); font-size: 2rem; }
.amz-box-badge {
    position: absolute; top: 9px; left: 9px; background: var(--accent); color: #fff;
    font-size: .74rem; font-weight: 800; padding: 3px 9px; border-radius: 7px; letter-spacing: .3px;
    box-shadow: 0 2px 6px rgba(232,98,42,.35);
}
.amz-box-body { display: flex; flex-direction: column; gap: 6px; min-width: 0; flex: 1; }
.amz-box-eyebrow {
    font-size: .68rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
    color: var(--accent);
}
.amz-box .amz-box-title {
    font-size: 1.12rem; font-weight: 700; color: var(--ink); line-height: 1.34;
    text-decoration: none; transition: color .15s ease;
}
.amz-box .amz-box-title:hover { color: var(--accent); text-decoration: none; }
.amz-box-rating { display: flex; align-items: center; gap: 8px; font-size: .85rem; color: var(--muted); margin-top: 1px; }
.amz-stars { position: relative; display: inline-block; line-height: 1; font-size: 1rem; color: #d7d9dd; white-space: nowrap; }
.amz-stars::before { content: "\2605\2605\2605\2605\2605"; }
.amz-stars-on { position: absolute; left: 0; top: 0; overflow: hidden; white-space: nowrap; color: #f5a623; }
.amz-stars-on::before { content: "\2605\2605\2605\2605\2605"; }
.amz-box-rating-val { font-weight: 700; color: var(--ink); }
.amz-box-reviews { color: var(--muted); }
.amz-box-pricing { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-top: 4px; }
.amz-box-was { font-size: .98rem; color: var(--muted); text-decoration: line-through; }
.amz-box-price { font-size: 1.45rem; font-weight: 800; color: var(--graphite); }
.amz-box-price--ask { font-size: 1.02rem; font-weight: 600; color: var(--muted); }
.amz-box-prime {
    font-size: .7rem; font-weight: 800; color: #0a6cff; border: 1px solid #cfe0ff;
    background: #eef5ff; padding: 2px 8px; border-radius: 6px; align-self: center; letter-spacing: .3px;
}
.amz-box .amz-box-cta {
    display: inline-flex; align-items: center; gap: 8px; align-self: flex-start; margin-top: 10px;
    background: var(--accent); color: #fff; font-weight: 700; padding: 11px 22px; border-radius: 10px;
    font-size: .96rem; text-decoration: none; box-shadow: 0 3px 10px rgba(232,98,42,.32);
    transition: background .15s ease, transform .12s ease, box-shadow .15s ease;
}
.amz-box .amz-box-cta:hover { background: var(--accent-dark); text-decoration: none; transform: translateY(-1px); box-shadow: 0 5px 16px rgba(232,98,42,.42); }
.amz-box .amz-box-cta svg { flex-shrink: 0; }
@media (max-width: 560px) {
    .amz-box { flex-direction: column; align-items: stretch; gap: 14px; padding: 16px; }
    .amz-box-media { width: 100%; height: 190px; }
    .amz-box .amz-box-cta { align-self: stretch; justify-content: center; }
}


.amz-table-wrap { margin: 1.8em 0; overflow-x: auto; }
.amz-table { width: 100%; border-collapse: collapse; }
.amz-table th, .amz-table td { border: 1px solid var(--line); padding: 12px; text-align: left; vertical-align: middle; }
.amz-table th { background: var(--graphite); color: #fff; font-weight: 600; font-size: .9rem; }
.amz-t-prod { display: flex; gap: 12px; align-items: center; }
.amz-t-prod img { width: 56px; height: 56px; object-fit: contain; flex-shrink: 0; }
.amz-t-price { font-weight: 700; color: var(--graphite); white-space: nowrap; }
.amz-t-cta a { display: inline-block; background: var(--accent); color: #fff; padding: 7px 14px; border-radius: 7px; font-weight: 600; font-size: .88rem; }
.amz-t-cta a:hover { background: var(--accent-dark); text-decoration: none; }

@media (max-width: 560px) {
    .amz-box { flex-direction: column; align-items: flex-start; }
    .amz-box-media { width: 100%; height: 160px; }
}

/* ---------- Sezione Guide all'acquisto (money page) ---------- */
.hero-sub { color: var(--muted); font-size: 1.05rem; margin: 10px 0 0; max-width: 640px; }
.topnav-guida { color: var(--accent) !important; font-weight: 700 !important; }
.post-cat--guida { color: var(--accent); }
.eyebrow--guida { color: var(--accent); }

/* Card di rimando a una guida, inserita negli articoli del blog via [guida slug="..."] */
.guida-card {
    display: flex; gap: 16px; align-items: stretch;
    border: 1px solid var(--line); border-left: 4px solid var(--accent);
    border-radius: 12px; overflow: hidden; background: #fffaf7;
    margin: 28px 0; transition: border-color .14s ease, transform .14s ease;
}
.guida-card:hover { transform: translateY(-2px); text-decoration: none; }
.guida-card-media {
    flex: 0 0 130px; background-size: cover; background-position: center; min-height: 120px;
}
.guida-card-body { display: flex; flex-direction: column; gap: 4px; padding: 16px 18px; }
.guida-card-eyebrow {
    font-size: .72rem; text-transform: uppercase; letter-spacing: .06em;
    font-weight: 700; color: var(--accent);
}
.guida-card-title { font-size: 1.12rem; font-weight: 700; color: var(--ink); line-height: 1.3; }
.guida-card-desc { font-size: .92rem; color: var(--muted); }
.guida-card-cta { font-size: .9rem; font-weight: 600; color: var(--accent); margin-top: 4px; }
@media (max-width: 560px) {
    .guida-card { flex-direction: column; }
    .guida-card-media { flex-basis: 150px; width: 100%; }
}

/* ---------- Schede prodotto nelle guide ---------- */
.role-badge { display: inline-block; vertical-align: middle; font-size: .62em; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: #fff; background: var(--accent); padding: 3px 9px; border-radius: 20px; }
.amz-disclaimer { font-size: .85rem; color: var(--muted); margin-top: -6px; }
.proscons { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 16px 0; }
.proscons .pc-pro, .proscons .pc-con { border: 1px solid var(--line); border-radius: 10px; padding: 12px 14px; }
.proscons .pc-h { display: block; font-weight: 700; margin-bottom: 6px; }
.proscons .pc-pro { border-left: 4px solid #2e9e5b; }
.proscons .pc-con { border-left: 4px solid #d9534f; }
.proscons ul { margin: 0; padding-left: 18px; }
.proscons li { margin: 3px 0; }
@media (max-width: 560px) { .proscons { grid-template-columns: 1fr; } }

/* ---------- Home: articolo in evidenza ---------- */
.featured {
    display: grid; grid-template-columns: 1.1fr .9fr; border: 1px solid var(--line);
    border-radius: 16px; overflow: hidden; background: var(--bg); color: inherit;
    margin: 6px 0 46px; transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.featured:hover { border-color: #d4d6da; box-shadow: 0 12px 32px rgba(0,0,0,.07); transform: translateY(-2px); text-decoration: none; }
.featured-media { min-height: 320px; background-size: cover; background-position: center; background-color: var(--soft); }
.featured-media--empty { display: flex; align-items: center; justify-content: center; background: var(--graphite); }
.featured-media--empty .thumb-mark { font-size: 3rem; }
.featured-body { padding: 36px; display: flex; flex-direction: column; justify-content: center; }
.featured-tag {
    align-self: flex-start; text-transform: uppercase; letter-spacing: .07em; font-size: .72rem;
    font-weight: 700; color: var(--accent-dark); background: #fdeee4; padding: 5px 11px; border-radius: 20px;
}
.featured-title { font-size: clamp(1.5rem, 3vw, 2.05rem); line-height: 1.18; color: var(--ink); font-weight: 800; letter-spacing: -.02em; margin: 16px 0 12px; }
.featured-excerpt { color: var(--muted); font-size: 1.02rem; margin: 0 0 20px; }
.featured-cta { font-weight: 700; color: var(--accent); font-size: .95rem; }
@media (max-width: 760px) {
    .featured { grid-template-columns: 1fr; margin-bottom: 36px; }
    .featured-media { min-height: 200px; }
    .featured-body { padding: 24px 22px; }
}

/* ---------- Home: sezioni per categoria ---------- */
.home-section { margin: 0 0 48px; }
.section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin: 0 0 22px; padding-bottom: 10px; border-bottom: 2px solid var(--ink); }
.section-title { font-size: 1.32rem; color: var(--ink); font-weight: 800; letter-spacing: -.01em; margin: 0; }
.section-all { font-size: .9rem; font-weight: 600; color: var(--accent); white-space: nowrap; }
.section-all:hover { text-decoration: none; color: var(--accent-dark); }
.home-section--guide .section-head { border-bottom-color: var(--accent); }
@media (max-width: 560px) { .section-title { font-size: 1.18rem; } }

/* ---------- Home: layout griglia compatta (4) ---------- */
.card-grid--4 { grid-template-columns: repeat(auto-fill, minmax(208px, 1fr)); gap: 20px; }
.card-grid--4 .post-body { padding: 13px 15px 16px; }
.card-grid--4 .post-title { font-size: 1.02rem; }
.card-grid--4 .post-excerpt { font-size: .88rem; }

/* ---------- Home: layout spotlight (1 grande + lista) ---------- */
.sec-spotlight { display: grid; grid-template-columns: 1.4fr 1fr; gap: 28px; align-items: start; }
.spot-lead { display: block; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; color: inherit; transition: border-color .15s ease, transform .15s ease; }
.spot-lead:hover { border-color: #d4d6da; transform: translateY(-2px); text-decoration: none; }
.spot-media { aspect-ratio: 16 / 9; background-size: cover; background-position: center; background-color: var(--soft); }
.spot-media--empty { display: flex; align-items: center; justify-content: center; background: var(--graphite); }
.spot-media--empty .thumb-mark { font-size: 2.4rem; }
.spot-body { padding: 20px 22px 24px; }
.spot-title { font-size: 1.35rem; line-height: 1.25; color: var(--ink); font-weight: 800; letter-spacing: -.01em; margin: 0 0 8px; }
.spot-excerpt { color: var(--muted); font-size: .96rem; margin: 0; }
.spot-list { display: flex; flex-direction: column; }
.spot-item { display: grid; grid-template-columns: 92px 1fr; gap: 15px; align-items: center; color: inherit; padding: 14px 0; border-bottom: 1px solid var(--line); }
.spot-item:first-child { padding-top: 0; }
.spot-item:last-child { border-bottom: none; padding-bottom: 0; }
.spot-item:hover { text-decoration: none; }
.spot-item:hover .spot-item-title { color: var(--accent); }
.spot-item-thumb { aspect-ratio: 1 / 1; border-radius: 10px; background-size: cover; background-position: center; background-color: var(--soft); }
.spot-item-thumb--empty { background: var(--graphite); }
.spot-item-title { font-size: 1rem; line-height: 1.3; color: var(--ink); font-weight: 700; margin: 0; transition: color .12s ease; }
@media (max-width: 760px) {
    .sec-spotlight { grid-template-columns: 1fr; gap: 20px; }
}

/* ---------- Home: blocco shop (guide da prodotti) ---------- */
.shop-showcase { background: var(--graphite); border-radius: 18px; padding: 34px 34px 38px; margin: 6px 0 48px; }
.shop-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 24px; }
.shop-eyebrow { display: block; text-transform: uppercase; letter-spacing: .14em; font-size: .74rem; font-weight: 700; color: var(--accent); margin: 0 0 6px; }
.shop-title { font-size: 1.5rem; font-weight: 800; color: #fff; margin: 0; letter-spacing: -.01em; }
.shop-all { color: #fff; font-weight: 600; font-size: .9rem; border-bottom: 1px solid rgba(255,255,255,.35); padding-bottom: 1px; }
.shop-all:hover { color: #fff; text-decoration: none; border-color: var(--accent); }
.shop-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(232px, 1fr)); gap: 18px; }
.shop-card { background: var(--bg); border-radius: 12px; overflow: hidden; color: inherit; display: flex; flex-direction: column; transition: transform .14s ease, box-shadow .14s ease; }
.shop-card:hover { transform: translateY(-3px); box-shadow: 0 14px 30px rgba(0,0,0,.22); text-decoration: none; }
.shop-card-thumb { aspect-ratio: 16 / 10; background-size: cover; background-position: center; background-color: var(--soft); position: relative; display: flex; align-items: center; justify-content: center; }
.shop-card-thumb--empty { background: #2b3340; }
.shop-card-thumb--empty .thumb-mark { font-size: 1.8rem; }
.shop-badge { position: absolute; top: 10px; left: 10px; background: var(--accent); color: #fff; font-size: .64rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; padding: 4px 9px; border-radius: 14px; }
.shop-card-body { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.shop-card-title { font-size: 1.04rem; font-weight: 700; color: var(--ink); line-height: 1.3; margin: 0; }
.shop-card-excerpt { font-size: .87rem; color: var(--muted); margin: 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.shop-card-cta { margin-top: auto; padding-top: 4px; font-size: .85rem; font-weight: 700; color: var(--accent); }
@media (max-width: 560px) { .shop-showcase { padding: 24px 20px 28px; } }

/* ---------- Immagini responsive dentro le thumb ---------- */
.post-thumb img, .post-thumb picture,
.featured-media img, .featured-media picture,
.spot-media img, .spot-media picture,
.spot-item-thumb img, .spot-item-thumb picture,
.shop-card-thumb img, .shop-card-thumb picture { width: 100%; height: 100%; object-fit: cover; display: block; }
.post-thumb { overflow: hidden; }
.shop-card-thumb img, .shop-card-thumb picture { position: absolute; inset: 0; }
.article-cover img, .article-cover picture { width: 100%; height: auto; display: block; }

/* ---------- Box "In breve" (answer-first) ---------- */
.answer-box {
    margin: 0 0 1.6rem; padding: 1rem 1.1rem 1rem 1.25rem;
    background: #fff7f2; border: 1px solid #f3d6c5; border-left: 4px solid var(--accent, #e8622a);
    border-radius: 10px;
}
.answer-box-label {
    display: inline-block; font-size: .72rem; font-weight: 700; letter-spacing: .08em;
    text-transform: uppercase; color: var(--accent, #e8622a); margin-bottom: .35rem;
}
.answer-box p { margin: 0; font-size: 1.05rem; line-height: 1.55; color: #2a2d31; }

/* ---------- Sommario (TOC) ---------- */
.toc {
    margin: 0 0 1.8rem; padding: 1rem 1.2rem; background: #f6f7f8;
    border: 1px solid #e6e8ea; border-radius: 10px;
}
.toc-title { margin: 0 0 .5rem; font-size: .78rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: #5a6066; }
.toc ol { margin: 0; padding: 0; list-style: none; counter-reset: toc; }
.toc li { margin: .2rem 0; }
.toc li a { color: #2a2d31; text-decoration: none; border-bottom: 1px solid transparent; }
.toc li a:hover { color: var(--accent, #e8622a); border-bottom-color: currentColor; }
.toc-l3 { padding-left: 1.1rem; font-size: .95rem; }

/* ---------- Byline ---------- */
.article-meta .byline { color: inherit; text-decoration: none; border-bottom: 1px solid rgba(0,0,0,.18); }
.article-meta .byline:hover { color: var(--accent, #e8622a); border-bottom-color: currentColor; }

/* ---------- Pagine informative ---------- */
.info-page { max-width: 760px; }
.info-page .article-body h2 { margin-top: 1.6rem; }
.page-note { margin-top: 1.5rem; font-size: .85rem; color: #8a9099; font-style: italic; }
.page-head { max-width: 760px; margin: 0 auto 1.4rem; }
.page-h1 { font-size: clamp(1.6rem, 4vw, 2.2rem); margin: .2rem 0 .4rem; }
.page-lead { color: #5a6066; margin: 0; }

/* ---------- Form di ricerca ---------- */
.search-form { display: flex; gap: .5rem; max-width: 760px; margin: 0 auto 2rem; }
.search-form input[type="search"] {
    flex: 1; padding: .7rem .9rem; border: 1px solid #d4d7da; border-radius: 8px; font-size: 1rem;
}
.search-form input[type="search"]:focus { outline: none; border-color: var(--accent, #e8622a); }
.search-form .btn-public { white-space: nowrap; }

/* ---------- Disclosure affiliazione (footer) ---------- */
.footer-disclosure { padding-top: 10px; }
.footer-disclosure p { font-size: .78rem; line-height: 1.5; color: var(--muted); margin: 0; max-width: 70ch; }
