/**
 * Skin PA Comuni — ispirata a commercialisti.it (CNDCEC)
 * Target: layout pa-comuni (staging.myefree.it e siti PA)
 */

@import url("https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,600;1,400&display=swap");

:root {
    --cndcec-rosso: #ce0021;
    --cndcec-dark: #0c162c;
    --cndcec-blue: #112c5b;
    --cndcec-blue-2: #122b5b;
    --cndcec-primary: #0066cc;
    --cndcec-primary-hover: #004d99;
    --cndcec-muted-bg: #f5f5f5;
    --cndcec-surface: #f2f7fc;
    --cndcec-border: #d9dadb;
    --cndcec-text: #1a1a1a;
    --cndcec-text-muted: #5c6f82;

    --bs-primary: var(--cndcec-primary);
    --pa-primary: var(--cndcec-blue);
    --pa-primary-light: var(--cndcec-surface);
    --pa-gray-50: var(--cndcec-muted-bg);
    --pa-focus: var(--cndcec-rosso);
}

body {
    color: var(--cndcec-text);
}

/* ── Header slim ── */
.it-header-slim-wrapper.pa-header-slim,
.pa-header-slim {
    background: var(--cndcec-dark) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.pa-slim-nav .nav-link,
.pa-slim-nav .btn-link {
    color: #fff !important;
}

.pa-slim-nav .btn-outline-white {
    border-radius: 0;
    border-color: rgba(255, 255, 255, 0.7);
    color: #fff;
}

.pa-slim-nav .btn-outline-white:hover {
    background: #fff;
    color: var(--cndcec-dark);
}

/* ── Header centrale ── */
.it-header-center-wrapper.theme-primary,
.theme-primary.it-header-center-wrapper {
    background: var(--cndcec-blue) !important;
}

.it-header-center-wrapper .it-brand-title {
    font-size: 1.35rem;
    font-weight: 600;
    line-height: 1.15;
}

.it-header-center-wrapper .it-brand-tagline {
    opacity: 0.88;
}

.it-header-center-wrapper .icon,
.it-header-center-wrapper .it-brand-wrapper a {
    color: #fff;
}

.pa-search-form .form-control {
    border: 1px solid var(--cndcec-text);
    border-radius: 0;
    min-height: 46px;
}

.pa-search-form .btn-primary {
    background: var(--cndcec-dark) !important;
    border-color: var(--cndcec-dark) !important;
    border-radius: 0;
    font-size: 1.05rem;
    font-weight: 400;
}

.pa-search-form .btn-primary:hover {
    background: #000 !important;
    border-color: #000 !important;
}

/* ── Nav sticky (override tema base bianco) ── */
.it-header-navbar-wrapper.pa-nav-sticky,
.pa-nav-sticky {
    background: var(--cndcec-dark) !important;
    box-shadow: 0 4px 14px rgba(12, 22, 44, 0.28);
}

.it-header-navbar-wrapper .navbar-nav .nav-link {
    color: #fff !important;
    font-size: 1rem;
    font-weight: 400;
    padding: 1rem 1.1rem;
    border-bottom: 3px solid transparent;
    border-radius: 0;
}

.it-header-navbar-wrapper .navbar-nav .nav-link:hover,
.it-header-navbar-wrapper .navbar-nav .nav-link:focus {
    color: #fff !important;
    background: rgba(255, 255, 255, 0.06);
}

.it-header-navbar-wrapper .navbar-nav .nav-link.active {
    color: #fff !important;
    border-bottom-color: var(--cndcec-rosso);
    background: transparent;
}

.it-header-navbar-wrapper .dropdown-menu {
    border: 0;
    border-radius: 0;
    box-shadow: 0 8px 24px rgba(12, 22, 44, 0.22);
    padding: 0.35rem 0;
}

.it-header-navbar-wrapper .dropdown-item {
    padding: 0.65rem 1.25rem;
    color: var(--cndcec-blue-2);
}

.it-header-navbar-wrapper .dropdown-item:hover,
.it-header-navbar-wrapper .dropdown-item:focus,
.it-header-navbar-wrapper .dropdown-item.active {
    background: var(--cndcec-surface);
    color: var(--cndcec-primary);
}

.it-header-navbar-wrapper .custom-navbar-toggler,
.it-header-navbar-wrapper .close-menu,
.it-header-navbar-wrapper .custom-navbar-toggler .icon,
.it-header-navbar-wrapper .close-menu .icon {
    color: #fff;
    fill: #fff;
}

/* ── Hero home ── */
#pa-sezione-hero.pa-hero {
    background: linear-gradient(135deg, var(--cndcec-blue) 0%, var(--cndcec-dark) 100%) !important;
    color: #fff;
}

#pa-sezione-hero .display-5,
#pa-sezione-hero .lead {
    color: #fff !important;
}

#pa-sezione-hero .lead {
    opacity: 0.92;
    font-size: 1.2rem;
    max-width: 720px;
    margin-inline: auto;
}

#pa-sezione-hero .input-group-lg .form-control {
    border-radius: 0;
    border-color: var(--cndcec-text);
}

#pa-sezione-hero .btn-primary {
    background: var(--cndcec-rosso) !important;
    border-color: var(--cndcec-rosso) !important;
    border-radius: 0;
}

#pa-sezione-hero .btn-primary:hover {
    background: #a8001a !important;
    border-color: #a8001a !important;
}

#pa-sezione-hero .btn-outline-primary {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.85);
    border-radius: 0;
}

#pa-sezione-hero .btn-outline-primary:hover {
    background: #fff;
    color: var(--cndcec-dark);
    border-color: #fff;
}

/* ── Titoli sezione ── */
#pa-servizi-title,
#pa-news-title {
    font-size: 2rem;
    font-weight: 600;
    color: var(--cndcec-blue-2);
    margin-bottom: 1.5rem !important;
    padding-bottom: 0.75rem;
    border-bottom: 4px solid var(--cndcec-border);
    position: relative;
}

#pa-servizi-title::after,
#pa-news-title::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -4px;
    width: min(200px, 40%);
    height: 4px;
    background: var(--cndcec-rosso);
}

#pa-accesso-title,
#pa-trasparenza-title {
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--cndcec-blue-2);
}

#pa-sezione-chi-siamo .card-title {
    color: var(--cndcec-blue-2);
    font-weight: 600;
}

/* ── Servizi ── */
.pa-card-servizio {
    border-radius: 0 !important;
    border-color: var(--cndcec-border) !important;
    box-shadow: none !important;
    transition: box-shadow 0.2s ease;
}

.pa-card-servizio:hover {
    transform: none;
    box-shadow: 0 8px 24px rgba(17, 44, 91, 0.12) !important;
}

.pa-card-servizio .card-title,
.pa-card-servizio h3 {
    color: var(--cndcec-blue-2) !important;
    font-weight: 600;
}

.pa-card-servizio .read-more .text {
    color: var(--cndcec-primary);
    font-weight: 600;
}

.pa-card-servizio:hover .read-more .text {
    color: var(--cndcec-rosso);
    text-decoration: underline;
}

.pa-card-servizio .icon.text-primary {
    color: var(--cndcec-primary) !important;
}

/* ── Accesso rapido ── */
#pa-sezione-accesso-rapido {
    background: var(--cndcec-muted-bg) !important;
}

.pa-tile-accesso {
    border-radius: 0 !important;
    border-color: var(--cndcec-border) !important;
    background: #fff;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.pa-tile-accesso:hover {
    border-color: var(--cndcec-primary) !important;
    box-shadow: 0 4px 16px rgba(0, 102, 204, 0.12) !important;
}

.pa-tile-accesso .icon.text-primary {
    color: var(--cndcec-primary) !important;
}

/* ── Novità ── */
#pa-sezione-novita {
    background: #fff !important;
}

.pa-filter-chip.btn-outline-primary {
    border-radius: 0;
    border-color: var(--cndcec-primary);
    color: var(--cndcec-primary);
}

.pa-filter-chip.btn-primary {
    background: var(--cndcec-primary) !important;
    border-color: var(--cndcec-primary) !important;
    border-radius: 0;
}

.pa-card-news,
.pa-card-news.card-teaser {
    border-radius: 0 !important;
    border-color: var(--cndcec-border) !important;
    box-shadow: none !important;
}

.pa-card-news .card-title a {
    color: var(--cndcec-blue-2) !important;
}

.pa-card-news .card-title a:hover {
    color: var(--cndcec-primary) !important;
}

/* ── Trasparenza ── */
#pa-sezione-trasparenza {
    background: var(--cndcec-muted-bg) !important;
}

.pa-card-trasparenza {
    border-radius: 0 !important;
    border-color: var(--cndcec-border) !important;
    box-shadow: none !important;
}

.pa-card-trasparenza:hover {
    transform: none;
    box-shadow: 0 8px 24px rgba(17, 44, 91, 0.12) !important;
}

.pa-card-trasparenza .card-title {
    color: var(--cndcec-blue-2) !important;
    font-weight: 600;
}

.pa-card-trasparenza .read-more .text {
    color: var(--cndcec-primary);
    font-weight: 600;
}

/* ── Avvisi ── */
.pa-avviso-urgente {
    border-left-color: var(--cndcec-rosso) !important;
    border-radius: 0;
}

/* ── Chi siamo ── */
#pa-sezione-chi-siamo .card-teaser {
    border-radius: 0 !important;
    border-color: var(--cndcec-border) !important;
    box-shadow: none !important;
}

#pa-sezione-chi-siamo .read-more .text {
    color: var(--cndcec-primary);
    font-weight: 600;
}

/* ── Footer ── */
.it-footer.pa-footer .it-footer-main {
    background: var(--cndcec-blue) !important;
}

.it-footer.pa-footer .footer-heading-title {
    font-family: "Lora", Georgia, serif;
    font-weight: 600;
    font-size: 1rem;
    color: #fff;
}

.it-footer.pa-footer .footer-list a,
.it-footer.pa-footer address,
.it-footer.pa-footer address a {
    color: rgba(255, 255, 255, 0.88);
    text-decoration: none;
}

.it-footer.pa-footer .footer-list a:hover,
.it-footer.pa-footer address a:hover {
    color: #fff;
    text-decoration: underline;
}

.it-footer.pa-footer .it-footer-small-prints {
    background: var(--cndcec-dark) !important;
    color: #fff;
}

.it-footer.pa-footer .it-footer-small-prints a {
    color: #fff;
}

/* ── Pulsanti globali ── */
.btn-primary {
    background: var(--cndcec-primary) !important;
    border-color: var(--cndcec-primary) !important;
    border-radius: 0;
}

.btn-primary:hover {
    background: var(--cndcec-primary-hover) !important;
    border-color: var(--cndcec-primary-hover) !important;
}

.btn-outline-primary {
    border-radius: 0;
    border-color: var(--cndcec-primary);
    color: var(--cndcec-primary);
}

.text-primary {
    color: var(--cndcec-primary) !important;
}

/* ── Contenuti CMS ── */
.cms-body h2,
.cms-body h3 {
    color: var(--cndcec-blue-2);
}

.cms-body a {
    color: var(--cndcec-primary);
}

.cms-body a:hover {
    color: var(--cndcec-rosso);
}

/* ── Focus ── */
:focus-visible {
    outline: 3px solid var(--cndcec-rosso) !important;
    outline-offset: 2px !important;
}

/* ── Mobile menu ── */
@media (max-width: 991.98px) {
    .it-header-navbar-wrapper .navbar-collapsable {
        background: var(--cndcec-dark);
    }

    .it-header-navbar-wrapper .navbar-nav .nav-link {
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }

    .it-header-navbar-wrapper .dropdown-menu {
        background: #fff;
        margin-left: 0.75rem;
    }

    #pa-sezione-hero .display-5 {
        font-size: 1.75rem;
    }

    #pa-servizi-title,
    #pa-news-title {
        font-size: 1.5rem;
    }
}
