/* ============================================================
 * Hub Disdette — landing-style (D.6)
 * Vanilla CSS, no framework, no webfont (icone SVG inline).
 * Identità Mittivo: blu #042C53, giallo #F5C518, azzurro #B5D4F4.
 * ============================================================ */

.disdette-hub {
    --mip-blue:   #042C53;
    --mip-yellow: #F5C518;
    --mip-azure:  #B5D4F4;

    --hub-bg:        #f6f5f1;
    --hub-surface:   #ffffff;
    --hub-surface-2: #faf9f6;
    --hub-border:    #e7e5df;
    --hub-text:      #1f2421;
    --hub-secondary: #5f5e5a;
    --hub-tertiary:  #9c9a93;
    --hub-accent:    #185fa5;

    color: var(--hub-text);
    line-height: 1.55;
    background: var(--hub-bg);
    -webkit-font-smoothing: antialiased;
}

.disdette-hub-container {
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 20px;
}

.disdette-hub .mip-ico {
    display: block;
    width: 20px;
    height: 20px;
}

.disdette-hub-section-title {
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--hub-text);
    margin: 0 0 20px;
    letter-spacing: -0.01em;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

/* ──────────────────────────────────────────────
 * Hero
 * ────────────────────────────────────────────── */

.disdette-hub-hero {
    padding: 40px 0 28px;
}

.disdette-hub-hero-surface {
    background: var(--hub-surface);
    border: 1px solid var(--hub-border);
    border-radius: 18px;
    padding: 40px 32px 32px;
    text-align: center;
    box-shadow: 0 1px 2px rgba(4, 44, 83, 0.04);
}

.disdette-hub-trust-pill {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: #faeeda;
    color: #854f0b;
    font-size: 0.82rem;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: 999px;
    margin-bottom: 18px;
}

.disdette-hub-trust-pill .mip-ico { width: 16px; height: 16px; }

.disdette-hub-title {
    font-size: 1.65rem;
    font-weight: 500;
    color: var(--mip-blue);
    margin: 0 0 10px;
    letter-spacing: -0.01em;
    line-height: 1.2;
}

.disdette-hub-subtitle {
    font-size: 1rem;
    color: var(--hub-secondary);
    margin: 0 auto 26px;
    max-width: 620px;
}

.disdette-hub-search-wrap {
    position: relative;
    max-width: 560px;
    margin: 0 auto;
}

.disdette-hub-search-ico {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--hub-tertiary);
    pointer-events: none;
}

/* D.6.2 — Selettore ancorato a .disdette-hub (specificita 0,2,0) + !important
 * mirati su 4 proprieta' per battere WoodMart e la user-agent stylesheet,
 * che su input[type="search"] forzano box-sizing:content-box e
 * -webkit-appearance:textfield + padding-inline. Senza questi override il
 * testo finiva sotto l'icona lente.
 * Non e' un !important globale: solo box-sizing/appearance/padding. */
.disdette-hub .disdette-hub-search-input {
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    padding: 0 18px 0 46px !important;
    width: 100%;
    height: 48px;
    font-size: 1rem;
    border: 1px solid var(--hub-border);
    border-radius: 999px;
    background: var(--hub-surface);
    color: var(--hub-text);
    box-shadow: 0 1px 3px rgba(4, 44, 83, 0.05);
    transition: border-color 120ms ease, box-shadow 120ms ease;
}

.disdette-hub-search-input:focus {
    outline: none;
    border-color: var(--mip-blue);
    box-shadow: 0 0 0 3px rgba(4, 44, 83, 0.12);
}

.disdette-hub-trust-signals {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px 26px;
    list-style: none;
    margin: 22px 0 0;
    padding: 0;
}

.disdette-hub-trust-signals li {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--hub-secondary);
}

.disdette-hub-trust-signals .mip-ico {
    width: 18px;
    height: 18px;
    color: var(--hub-accent);
}

/* ──────────────────────────────────────────────
 * Section spacing
 * ────────────────────────────────────────────── */

.disdette-hub-top,
.disdette-hub-categorie,
.disdette-hub-how,
.disdette-hub-faq,
.disdette-hub-results {
    padding: 36px 0;
}

/* ──────────────────────────────────────────────
 * Brand grid (top + results)
 * ────────────────────────────────────────────── */

.disdette-hub-brand-grid,
.disdette-hub-results-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 12px;
}

.disdette-hub-brand-card {
    position: relative;
    background: var(--hub-surface);
    border: 1px solid var(--hub-border);
    border-radius: 12px;
    padding: 12px;
    transition: border-color 120ms ease, transform 80ms ease, box-shadow 120ms ease;
}

.disdette-hub-brand-card:hover {
    border-color: var(--mip-azure);
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(4, 44, 83, 0.07);
}

.disdette-hub-brand-link {
    display: flex;
    align-items: center;
    gap: 11px;
    text-decoration: none;
    color: inherit;
}

.disdette-hub-brand-icon {
    flex: 0 0 auto;
    width: 42px;
    height: 42px;
    border-radius: 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.disdette-hub-brand-icon .mip-ico { width: 23px; height: 23px; }

.disdette-hub-brand-text {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

/* Nomi per esteso: niente troncamento, vanno a capo se necessario. */
.disdette-hub-brand-name {
    font-size: 0.94rem;
    font-weight: 500;
    color: var(--hub-text);
    line-height: 1.3;
    word-break: break-word;
}

.disdette-hub-brand-cat {
    font-size: 0.81rem;
    color: var(--hub-secondary);
    margin-top: 2px;
    word-break: break-word;
}

.disdette-hub-badge-private {
    position: absolute;
    top: 8px;
    right: 10px;
    font-size: 10px;
    color: var(--hub-tertiary);
    font-weight: 500;
    letter-spacing: 0.02em;
    text-transform: lowercase;
}

/* ──────────────────────────────────────────────
 * Come funziona (3 step)
 * ────────────────────────────────────────────── */

.disdette-hub-steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.disdette-hub-step {
    background: var(--hub-surface);
    border: 1px solid var(--hub-border);
    border-radius: 14px;
    padding: 22px;
}

.disdette-hub-step-ico {
    width: 40px;
    height: 40px;
    border-radius: 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
}

.disdette-hub-step-ico .mip-ico { width: 22px; height: 22px; }
.disdette-hub-step-ico.is-blue  { background: #e6f1fb; color: #185fa5; }
.disdette-hub-step-ico.is-teal  { background: #ccfbf1; color: #0f766e; }
.disdette-hub-step-ico.is-amber { background: #faeeda; color: #854f0b; }

.disdette-hub-step-title {
    font-size: 1.02rem;
    font-weight: 600;
    color: var(--hub-text);
    margin: 0 0 6px;
}

.disdette-hub-step p {
    font-size: 0.92rem;
    color: var(--hub-secondary);
    margin: 0;
}

/* ──────────────────────────────────────────────
 * Per categoria
 * ────────────────────────────────────────────── */

.disdette-hub-cat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 12px;
}

.disdette-hub-cat-card {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--hub-surface);
    border: 1px solid var(--hub-border);
    border-radius: 12px;
    padding: 14px 16px;
    text-decoration: none;
    color: inherit;
    transition: border-color 120ms ease, transform 80ms ease, box-shadow 120ms ease;
}

a.disdette-hub-cat-card:hover {
    border-color: var(--mip-azure);
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(4, 44, 83, 0.07);
}

.disdette-hub-cat-card.is-empty {
    opacity: 0.7;
    cursor: default;
}

.disdette-hub-cat-icon {
    flex: 0 0 auto;
    width: 38px;
    height: 38px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.disdette-hub-cat-icon .mip-ico { width: 21px; height: 21px; }

.disdette-hub-cat-text {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.disdette-hub-cat-name {
    font-size: 0.96rem;
    font-weight: 500;
    color: var(--hub-text);
    line-height: 1.25;
}

.disdette-hub-cat-count {
    font-size: 0.8rem;
    font-weight: 600;
    margin-top: 2px;
}

.disdette-hub-cat-soon {
    font-size: 0.78rem;
    color: var(--hub-tertiary);
    margin-top: 2px;
}

/* ──────────────────────────────────────────────
 * Search results meta + reset + empty
 * ────────────────────────────────────────────── */

.disdette-hub-results-count {
    font-size: 0.85rem;
    color: var(--hub-secondary);
    font-weight: 400;
    margin-left: 10px;
}

.disdette-hub-reset {
    margin-left: 14px;
    padding: 4px 14px;
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--mip-blue);
    background: #eef3f8;
    border: 1px solid var(--mip-azure);
    border-radius: 999px;
    cursor: pointer;
    transition: background 120ms ease, border-color 120ms ease;
}

.disdette-hub-reset:hover {
    background: #e0ebf6;
    border-color: var(--mip-blue);
}

.disdette-hub-empty-state {
    margin: 16px 0 0;
    padding: 24px;
    background: var(--hub-surface-2);
    border: 1px dashed var(--hub-border);
    border-radius: 12px;
    text-align: center;
    color: var(--hub-secondary);
    font-size: 0.95rem;
}

.disdette-hub-empty-state a {
    color: var(--hub-accent);
    text-decoration: none;
    font-weight: 500;
}

.disdette-hub-empty-state a:hover { text-decoration: underline; }

/* ──────────────────────────────────────────────
 * FAQ accordion
 * ────────────────────────────────────────────── */

.disdette-hub-faq-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.disdette-hub-faq-item {
    background: var(--hub-surface);
    border: 1px solid var(--hub-border);
    border-radius: 12px;
    padding: 16px 20px;
}

.disdette-hub-faq-item summary {
    cursor: pointer;
    font-weight: 600;
    color: var(--hub-text);
    list-style: none;
    padding-right: 30px;
    position: relative;
}

.disdette-hub-faq-item summary::-webkit-details-marker { display: none; }

/* Marker +/- costruito con due barre: la verticale collassa quando aperto */
.disdette-hub-faq-item summary::before,
.disdette-hub-faq-item summary::after {
    content: "";
    position: absolute;
    background: var(--hub-accent);
    border-radius: 2px;
}

.disdette-hub-faq-item summary::before {
    right: 2px;
    top: 50%;
    width: 14px;
    height: 2px;
    margin-top: -1px;
}

.disdette-hub-faq-item summary::after {
    right: 8px;
    top: 50%;
    width: 2px;
    height: 14px;
    margin-top: -7px;
    transition: transform 150ms ease;
}

.disdette-hub-faq-item[open] summary::after { transform: scaleY(0); }

.disdette-hub-faq-item p {
    margin: 12px 0 0;
    color: var(--hub-secondary);
    font-size: 0.93rem;
}

/* ──────────────────────────────────────────────
 * CTA finale — brand Mittivo
 * ────────────────────────────────────────────── */

.disdette-hub-cta {
    margin-top: 12px;
    padding: 52px 0;
    background: var(--mip-blue);
    text-align: center;
}

.disdette-hub-cta-title {
    font-size: 1.55rem;
    font-weight: 600;
    margin: 0 0 10px;
    color: #ffffff;
}

.disdette-hub-cta-text {
    font-size: 1rem;
    margin: 0 0 22px;
    color: var(--mip-azure);
}

.disdette-hub-cta-btn {
    display: inline-block;
    background: var(--mip-yellow);
    color: var(--mip-blue);
    font-weight: 700;
    padding: 13px 26px;
    border-radius: 999px;
    text-decoration: none;
    transition: transform 80ms ease, box-shadow 120ms ease, filter 120ms ease;
}

.disdette-hub-cta-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.22);
    filter: brightness(1.04);
    color: var(--mip-blue);
}

/* ──────────────────────────────────────────────
 * Keyboard nav: highlight focused card
 * ────────────────────────────────────────────── */

.disdette-hub-brand-card.is-keyboard-focused {
    border-color: var(--mip-blue);
    box-shadow: 0 0 0 3px rgba(4, 44, 83, 0.16);
}

/* ──────────────────────────────────────────────
 * Mobile
 * ────────────────────────────────────────────── */

@media (max-width: 600px) {
    .disdette-hub-hero            { padding: 24px 0 18px; }
    .disdette-hub-hero-surface    { padding: 28px 18px 24px; border-radius: 14px; }
    .disdette-hub-title           { font-size: 1.4rem; }
    .disdette-hub-subtitle        { font-size: 0.95rem; }
    .disdette-hub-section-title   { font-size: 1.2rem; }
    .disdette-hub-trust-signals   { gap: 8px 18px; }
    .disdette-hub-brand-grid,
    .disdette-hub-results-grid,
    .disdette-hub-cat-grid        { grid-template-columns: 1fr; }
    .disdette-hub-cta             { padding: 40px 0; }
    .disdette-hub-cta-title       { font-size: 1.3rem; }
}
