/* ── Palette Nama ────────────────────────────────────────────────── */
:root {
    --nama-navy:   #1A2B4A;
    --nama-gold:   #C9A84C;
    --nama-sand:   #F5F0E8;
    --nama-light:  #F8F6F2;
    --nama-border: #E2D9C8;
    --nama-txt:    #2D3748;
    --nama-muted:  #8A9AB0;
    --nama-radius: 8px;
    --nama-shadow: 0 2px 12px rgba(0,0,0,.08);
}

/* ── Wrapper ─────────────────────────────────────────────────────── */
.nama-immobili-wrapper { max-width: 1200px; margin: 0 auto; padding: 48px 20px 64px; }

/* ── Archivio hero ───────────────────────────────────────────────── */
.nama-archive-hero {
    position: relative;
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    min-height: clamp(300px, 46vh, 520px);
    overflow: hidden;
    background-color: var(--nama-navy);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.nama-archive-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        180deg,
        rgba(26, 43, 74, 0.78) 0%,
        rgba(26, 43, 74, 0.42) 45%,
        rgba(26, 43, 74, 0.88) 100%
    );
    display: flex;
    align-items: flex-end;
}

.nama-archive-hero__inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px 56px;
}

.nama-archive-hero__eyebrow {
    margin: 0 0 12px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--nama-gold);
}

.nama-archive-hero__title {
    margin: 0 0 14px;
    max-width: 720px;
    font-size: clamp(28px, 4.5vw, 46px);
    font-weight: 700;
    line-height: 1.15;
    color: #fff;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.45);
}

.nama-archive-hero__subtitle {
    margin: 0;
    max-width: 640px;
    font-size: clamp(15px, 2vw, 18px);
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.92);
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.35);
}

.nama-archive-page .nama-immobili-wrapper {
    position: relative;
    z-index: 1;
}

/* Fascia archivio: contrasto per header tema trasparente */
.nama-archive-bar {
    --nama-header-offset: 76px;
    position: relative;
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    background-color: var(--nama-navy);
}

.nama-archive-bar--compact {
    padding: var(--nama-header-offset) 0 10px;
}

.nama-archive-bar--spacer {
    min-height: var(--nama-header-offset);
    padding: 0;
}

.nama-archive-bar__inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.nama-archive-bar__title {
    margin: 0;
    font-size: clamp(18px, 2.2vw, 24px);
    font-weight: 700;
    line-height: 1.15;
    color: #fff;
}

.nama-archive-hero-compact .nama-immobili-wrapper {
    padding-top: 28px;
}

.nama-archive-hero-off .nama-immobili-wrapper {
    padding-top: 28px;
}

.nama-archive-page-head {
    margin-bottom: 20px;
}

.nama-archive-page-head__title {
    margin: 0;
    font-size: clamp(20px, 2.5vw, 28px);
    font-weight: 700;
    line-height: 1.2;
    color: var(--nama-navy);
}

.nama-immobili-wrapper--titled {
    padding-top: 20px;
}

/* ── Filtri ──────────────────────────────────────────────────────── */
.nama-filters {
    background: var(--nama-light);
    border: 1px solid var(--nama-border);
    border-radius: var(--nama-radius);
    padding: 24px;
    margin-bottom: 32px;
}
.nama-filter-row {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 16px;
}
.nama-filter-group { flex: 1 1 180px; }
.nama-filter-group label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: var(--nama-navy);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.nama-select, .nama-input {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--nama-border);
    border-radius: 6px;
    font-size: 14px;
    color: var(--nama-txt);
    background: #fff;
    appearance: none;
}
.nama-select:focus, .nama-input:focus {
    outline: none;
    border-color: var(--nama-navy);
}
.nama-range-inputs {
    display: flex;
    align-items: center;
    gap: 8px;
}
.nama-range-inputs span { color: var(--nama-muted); }
.nama-range-inputs .nama-input { flex: 1; }

.nama-filter-checkboxes { align-items: stretch; flex-wrap: wrap; gap: 12px; }
.nama-filter-check-title {
    width: 100%;
    flex: 0 0 100%;
    font-size: 12px;
    font-weight: 600;
    color: var(--nama-navy);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 4px;
}
.nama-filter-row.nama-filter-checkboxes {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 14px;
    align-items: center;
}
.nama-filter-row.nama-filter-checkboxes .nama-filter-check-title {
    grid-column: 1 / -1;
    margin-bottom: 2px;
}
.nama-checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--nama-txt);
    cursor: pointer;
    margin: 0;
    min-width: 0;
    width: 100%;
}
.nama-checkbox input {
    flex-shrink: 0;
    accent-color: var(--nama-navy);
    margin: 0;
}

.nama-filter-actions { display: flex; gap: 12px; margin-top: 8px; flex-wrap: wrap; }
.nama-btn {
    padding: 10px 24px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: opacity .15s;
}
.nama-btn:hover { opacity: .88; }
.nama-btn-primary  { background: var(--nama-navy); color: #fff; }
.nama-btn-secondary{ background: transparent; color: var(--nama-navy); border: 1px solid var(--nama-navy); }

/* ── Risultati header ────────────────────────────────────────────── */
.nama-results-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    gap: 16px;
    flex-wrap: wrap;
}
.nama-count { font-size: 14px; color: var(--nama-muted); }
.nama-sort select {
    padding: 8px 12px;
    border: 1px solid var(--nama-border);
    border-radius: 6px;
    font-size: 14px;
    color: var(--nama-txt);
    background: #fff;
}

/* ── Griglia card ────────────────────────────────────────────────── */
.nama-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    transition: opacity .2s;
}
.nama-grid.nama-loading { opacity: .5; pointer-events: none; }
.nama-no-results { grid-column: 1/-1; text-align: center; padding: 48px; color: var(--nama-muted); }

/* ── Card ────────────────────────────────────────────────────────── */
.nama-card {
    background: #fff;
    border-radius: var(--nama-radius);
    border: 1px solid var(--nama-border);
    overflow: hidden;
    box-shadow: var(--nama-shadow);
    transition: transform .2s, box-shadow .2s;
}
.nama-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
}
.nama-card--evidenza { border-color: var(--nama-gold); }
.nama-card__link { display: block; text-decoration: none; color: inherit; }

.nama-card__thumb { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--nama-sand); }
.nama-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.nama-card__no-thumb { width: 100%; height: 100%; background: var(--nama-sand); }

.nama-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.nama-badge--evidenza  { background: var(--nama-gold);  color: var(--nama-navy); z-index: 6; }

/* Nastro diagonale stato (venduto / trattativa) */
.nama-ribbon {
    position: absolute;
    top: 0;
    right: 0;
    width: 150px;
    height: 150px;
    overflow: hidden;
    pointer-events: none;
    z-index: 8;
}
.nama-ribbon span {
    position: absolute;
    top: 34px;
    right: -38px;
    width: 190px;
    padding: 9px 0;
    text-align: center;
    transform: rotate(45deg);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: #fff;
    box-shadow: 0 3px 8px rgba(0, 0, 0, .28);
    line-height: 1.2;
}
.nama-ribbon--venduto span {
    background: linear-gradient(135deg, #d4213d 0%, #9a1028 55%, #7a0018 100%);
}
.nama-ribbon--trattativa span {
    background: linear-gradient(135deg, #2a7ec8 0%, #1a5a96 55%, #0d3d6b 100%);
}
.nama-single__hero .nama-ribbon {
    width: 180px;
    height: 180px;
    z-index: 4;
}
.nama-single__hero .nama-ribbon span {
    top: 42px;
    right: -44px;
    width: 230px;
    font-size: 14px;
    padding: 11px 0;
}

.nama-card__body { padding: 16px; }
.nama-card__rif {
    margin: 0 0 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--nama-muted);
}
.nama-card__location { display: flex; gap: 8px; align-items: center; margin-bottom: 6px; flex-wrap: wrap; }
.nama-card__tipo   { font-size: 11px; color: var(--nama-gold); font-weight: 700; text-transform: uppercase; }
.nama-card__comune { font-size: 12px; color: var(--nama-muted); }
.nama-card__title  { font-size: 15px; font-weight: 600; color: var(--nama-navy); margin: 0 0 10px; line-height: 1.4; }

.nama-card__specs  { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 8px; }

/* ── Icone specifiche ───────────────────────────────────────────── */
.nama-specs { display: flex; flex-wrap: wrap; gap: 12px; }
.nama-specs--card { margin-bottom: 8px; }

.nama-spec,
.nama-single__spec-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--nama-muted);
    line-height: 1.2;
}

.nama-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    color: var(--nama-gold);
}
.nama-icon svg { width: 18px; height: 18px; display: block; }

.nama-spec__text { font-weight: 500; color: var(--nama-txt); }

.nama-ape-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 22px;
    padding: 0 6px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .02em;
    line-height: 1;
}
.nama-ape--high { background: #1a7f4b; color: #fff; }
.nama-ape--mid  { background: #c9a84c; color: #1a2b4a; }
.nama-ape--low  { background: #c0392b; color: #fff; }
.nama-ape--na   { background: #8a9ab0; color: #fff; }

.nama-spec--ape { gap: 5px; }

.nama-single__quick-icon {
    display: flex;
    justify-content: center;
    margin-bottom: 8px;
    color: var(--nama-gold);
}
.nama-single__quick-icon .nama-icon,
.nama-single__quick-icon .nama-icon svg { width: 22px; height: 22px; }
.nama-single__quick-value--ape { display: flex; justify-content: center; }
.nama-single__quick-value--ape .nama-ape-badge { min-width: 40px; height: 30px; font-size: 15px; }

.nama-card__features { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.nama-feat {
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 20px;
    background: var(--nama-light);
    border: 1px solid var(--nama-border);
    color: var(--nama-navy);
}

.nama-card__price { font-size: 18px; font-weight: 700; color: var(--nama-navy); margin-top: 10px; }

.nama-property-summary {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 1px;
    margin-bottom: 36px;
    background: var(--nama-border);
    border: 1px solid var(--nama-border);
    border-radius: var(--nama-radius);
    overflow: hidden;
}
.nama-property-summary__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    min-width: 0;
    padding: 18px 14px;
    text-align: center;
    background: #fff;
}
.nama-property-summary__icon {
    display: flex;
    justify-content: center;
    color: var(--nama-gold);
}
.nama-property-summary__icon .nama-icon,
.nama-property-summary__icon .nama-icon svg {
    width: 22px;
    height: 22px;
}
.nama-property-summary__label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--nama-muted);
}
.nama-property-summary__value {
    font-size: 16px;
    font-weight: 700;
    color: var(--nama-navy);
    line-height: 1.35;
}
.nama-property-summary__value .nama-ape-badge {
    font-size: 14px;
}
.nama-ape-epi {
    margin-left: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--nama-navy);
}

.nama-single__detail-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    color: var(--nama-navy);
}
.nama-single__detail-label .nama-icon,
.nama-single__detail-label .nama-icon svg {
    width: 18px;
    height: 18px;
    color: var(--nama-gold);
    flex-shrink: 0;
}
.nama-single__table--details th {
    width: 46%;
    vertical-align: middle;
}

.nama-survey-embed {
    min-height: 420px;
}
.nama-survey-embed iframe {
    display: block;
    min-height: 420px;
}

/* ── Paginazione ─────────────────────────────────────────────────── */
.nama-pagination { text-align: center; margin-top: 40px; }
.nama-load-more {
    padding: 12px 40px;
    background: var(--nama-navy);
    color: #fff;
    border: none;
    border-radius: 6px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity .15s;
}
.nama-load-more:hover { opacity: .88; }

/* ── Lightbox ────────────────────────────────────────────────────── */
.nama-lightbox {
    position: fixed; inset: 0; background: rgba(0,0,0,.92); z-index: 99999;
    display: flex; align-items: center; justify-content: center;
}
.nama-lightbox__inner { position: relative; max-width: 90vw; max-height: 90vh; }
.nama-lightbox__img   { max-width: 90vw; max-height: 85vh; object-fit: contain; display: block; }
.nama-lightbox__close,
.nama-lightbox__prev,
.nama-lightbox__next  {
    position: absolute; background: rgba(255,255,255,.15); border: none;
    color: #fff; font-size: 28px; cursor: pointer; border-radius: 50%;
    width: 44px; height: 44px; display: flex; align-items: center; justify-content: center;
}
.nama-lightbox__close { top: -48px; right: 0; }
.nama-lightbox__prev  { left: -56px; top: 50%; transform: translateY(-50%); }
.nama-lightbox__next  { right: -56px; top: 50%; transform: translateY(-50%); }
.nama-lightbox__counter {
    position: absolute; bottom: -36px; left: 50%;
    transform: translateX(-50%); color: rgba(255,255,255,.7); font-size: 14px;
}

/* ── Single immobile ─────────────────────────────────────────────── */
.nama-single {
    --nama-hero-height: clamp(360px, 55vh, 560px);
}

.nama-single__hero {
    position: relative;
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    min-height: var(--nama-hero-height);
    overflow: hidden;
    background-color: var(--nama-navy);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.nama-single__hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        180deg,
        rgba(26, 43, 74, 0.35) 0%,
        rgba(26, 43, 74, 0.55) 45%,
        rgba(26, 43, 74, 0.92) 100%
    );
    display: flex;
    align-items: flex-end;
}

.nama-single__hero-inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.nama-single__hero-content {
    padding: 48px 0 56px;
    color: #fff;
    max-width: 820px;
}

.nama-single__tipo,
.nama-single__rif {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-right: 12px;
    margin-bottom: 10px;
}

.nama-single__tipo { color: var(--nama-gold); }
.nama-single__rif  { color: rgba(255, 255, 255, .75); }

.nama-single__title {
    font-size: clamp(26px, 4vw, 42px);
    font-weight: 700;
    margin: 0 0 12px;
    color: #fff;
    line-height: 1.2;
    text-shadow: 0 2px 16px rgba(0, 0, 0, .45);
}

.nama-single__location {
    font-size: 16px;
    margin: 0 0 18px;
    color: rgba(255, 255, 255, .92);
    text-shadow: 0 1px 8px rgba(0, 0, 0, .35);
}

.nama-single__price {
    display: inline-block;
    font-size: clamp(24px, 3vw, 34px);
    font-weight: 700;
    color: var(--nama-gold);
    text-shadow: 0 2px 12px rgba(0, 0, 0, .4);
    padding: 8px 0;
}

.nama-single__body--contained {
    max-width: 1200px;
    margin: 0 auto;
    padding: 40px 20px 64px;
}

.nama-single__quick-specs {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 1px;
    background: var(--nama-border);
    border: 1px solid var(--nama-border);
    border-radius: var(--nama-radius);
    overflow: hidden;
    margin-bottom: 40px;
}

.nama-single__quick-spec {
    background: #fff;
    padding: 18px 16px;
    text-align: center;
}

.nama-single__quick-label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--nama-muted);
    margin-bottom: 6px;
}

.nama-single__quick-value {
    display: block;
    font-size: 18px;
    color: var(--nama-navy);
    line-height: 1.2;
}

.nama-single__specs-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    padding: 24px;
    background: var(--nama-light);
    border: 1px solid var(--nama-border);
    border-radius: var(--nama-radius);
    margin-bottom: 40px;
    justify-content: center;
}
.nama-single__spec {
    text-align: center;
    min-width: 80px;
}
.nama-single__spec strong {
    display: block;
    font-size: 24px;
    color: var(--nama-navy);
    line-height: 1.2;
}
.nama-single__spec span {
    font-size: 12px;
    color: var(--nama-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}

.nama-single__main {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    margin-bottom: 40px;
}
.nama-single__description h2,
.nama-single__details h2,
.nama-single__gallery h2,
.nama-single__map h2,
.nama-single__video h2,
.nama-single__contact h2 {
    font-size: 20px;
    color: var(--nama-navy);
    margin: 0 0 16px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--nama-gold);
}
.nama-single__description { font-size: 15px; line-height: 1.7; color: var(--nama-txt); }

.nama-single__table { width: 100%; border-collapse: collapse; font-size: 14px; }
.nama-single__table th,
.nama-single__table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--nama-border);
    text-align: left;
}
.nama-single__table th {
    color: var(--nama-muted);
    font-weight: 600;
    width: 40%;
}

.nama-single__features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 12px;
    margin-bottom: 40px;
}
.nama-single__feature {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: var(--nama-light);
    border: 1px solid var(--nama-border);
    border-radius: 6px;
    font-size: 14px;
    color: var(--nama-navy);
}
.nama-feature-check {
    color: var(--nama-gold);
    font-weight: 700;
}

.nama-gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px;
    margin-bottom: 40px;
}
.nama-gallery-item {
    border: none;
    padding: 0;
    cursor: pointer;
    border-radius: 6px;
    overflow: hidden;
    aspect-ratio: 4/3;
    background: var(--nama-sand);
}
.nama-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .2s;
}
.nama-gallery-item:hover img { transform: scale(1.05); }

.nama-map-wrap {
    position: relative;
    z-index: 1;
}

.nama-map {
    height: 420px;
    width: 100%;
    border-radius: var(--nama-radius);
    overflow: hidden;
    border: 1px solid var(--nama-border);
    margin-bottom: 0;
    background: var(--nama-sand);
}

.nama-map .leaflet-container {
    height: 100%;
    width: 100%;
    z-index: 1;
    font-family: inherit;
}

.nama-single__map,
.nama-single__gallery,
.nama-single__video {
    margin-bottom: 48px;
}

.nama-video-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
}

.nama-video-item {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: var(--nama-radius);
    overflow: hidden;
    background: var(--nama-navy);
    border: 1px solid var(--nama-border);
}

.nama-video-item iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.nama-contact-form input,
.nama-contact-form textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--nama-border);
    border-radius: 6px;
    font-size: 14px;
    margin-bottom: 12px;
    font-family: inherit;
}
.nama-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

/* ── Responsive ──────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .nama-grid { grid-template-columns: repeat(2, 1fr); }
    .nama-single__main { grid-template-columns: 1fr; }
}
@media (min-width: 768px) {
    .nama-filter-row.nama-filter-checkboxes {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}
@media (max-width: 640px) {
    .nama-grid        { grid-template-columns: 1fr; }
    .nama-filter-row  { flex-direction: column; }
    .nama-filter-group{ flex: none; width: 100%; }
    .nama-lightbox__prev { left: -10px; }
    .nama-lightbox__next { right: -10px; }
    .nama-archive-hero__inner { padding-bottom: 40px; }
    .nama-immobili-wrapper { padding-top: 32px; }
    .nama-single__hero-content { padding: 32px 0 40px; }
    .nama-single__quick-specs { grid-template-columns: repeat(2, 1fr); }
    .nama-map { height: 300px; }
    .nama-form-row { grid-template-columns: 1fr; }
}
