/* ==========================================================================
   ITNETCOM - Pagina prodotto UX fix
   Obiettivo: allineare la pagina prodotto alla scala visiva del negozio.
   Non modifica home, negozio, carrello o checkout.
   ========================================================================== */

.product-page {
    font-size: 14px;
    line-height: 1.5;
}

/* Layout desktop più equilibrato */
.product-main-section {
    padding-top: 20px;
    padding-bottom: 26px;
}

.product-breadcrumb {
    margin-bottom: 18px;
    font-size: 11px;
}

.product-detail-card {
    grid-template-columns: minmax(330px, 0.9fr) minmax(0, 1.1fr) 285px;
    gap: 24px;
}

.product-summary {
    padding-top: 34px;
}

.product-media {
    min-height: 430px;
}

.product-media img {
    max-width: 92%;
    max-height: 470px;
}

.product-status-row {
    margin-bottom: 10px;
}

.product-status-pill {
    min-height: 22px;
    padding: 0 10px;
    font-size: 10px;
}

/* Titolo prodotto più vicino al negozio */
.product-summary h1,
.product-empty-state h1 {
    max-width: 680px;
    font-size: clamp(24px, 2.15vw, 31px);
    line-height: 1.08;
    letter-spacing: -0.035em;
    font-weight: 700;
}

.product-code-inline {
    margin-top: 9px;
    font-size: 12px;
}

.product-category-line {
    margin-top: 10px;
}

.product-summary-divider {
    margin: 16px 0;
}

.product-short-description {
    font-size: 13.5px;
    line-height: 1.5;
}

.product-summary-info {
    margin-top: 15px;
    padding-top: 13px;
}

.product-summary-info-heading h2 {
    font-size: 13.5px;
}

.product-summary-info-list {
    gap: 7px;
}

.product-summary-info-list > div {
    padding: 8px 9px;
}

.product-summary-info-list dt {
    font-size: 8.8px;
}

.product-summary-info-list dd {
    font-size: 11.5px;
}

/* Pulsanti informazioni */
.product-summary-actions {
    margin-top: 15px;
    padding-top: 15px;
    gap: 8px;
}

.product-outline-action {
    min-height: 36px;
    font-size: 10px;
}

/* Box acquisto più compatto */
.product-buy-box {
    top: 96px;
    padding: 18px;
}

.product-buy-status {
    font-size: 12px;
}

.product-buy-price {
    margin-top: 18px;
    padding-top: 15px;
}

.product-buy-price strong {
    font-size: 23px;
}

.product-buy-availability {
    margin-top: 10px;
    font-size: 11.5px;
}

.product-actions-row {
    margin-top: 15px;
    gap: 8px;
}

.product-qty {
    width: 82px;
    min-width: 82px;
    height: 38px;
    grid-template-columns: 26px 1fr 26px;
}

.product-qty button {
    font-size: 16px;
}

.product-qty span {
    font-size: 13px;
}

.product-primary-action,
.product-secondary-action,
.product-help-card a,
.product-empty-state .product-primary-action {
    min-height: 38px;
    font-size: 10px;
}

.product-secondary-action {
    margin-top: 8px;
}

.product-back-link {
    margin-top: 10px;
    font-size: 9.5px;
}

.product-buy-benefits {
    margin: 18px -18px -18px;
    padding: 15px 18px;
}

.product-buy-benefits li {
    font-size: 11.5px;
}

/* Descrizione prodotto */
.product-description-section {
    padding-bottom: 34px;
}

.product-description-card {
    padding: 22px 0 24px;
}

.product-kicker {
    font-size: 10px;
}

.product-description-card h2,
.product-section-heading h2 {
    font-size: 20px;
    line-height: 1.15;
}

.product-description-content {
    margin-top: 12px;
    font-size: 13.5px;
    line-height: 1.52;
}

.product-description-content li {
    margin-bottom: 5px;
}

/* Correlati più ordinati */
.product-related-section {
    padding-bottom: 38px;
}

.product-related-track {
    --product-related-gap: 18px;
}

.product-related-card {
    min-height: 390px;
}

.product-related-media {
    height: 190px;
    margin-bottom: 12px;
}

.product-related-name {
    min-height: 52px;
    font-size: 13.5px;
    line-height: 1.26;
}

.product-related-brand,
.product-related-code {
    font-size: 10px;
}

.product-related-price {
    font-size: 18px;
}

.product-related-stock {
    margin-top: 8px;
    font-size: 10.5px;
}

/* Tablet */
@media (max-width: 1180px) {
    .product-detail-card {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .product-summary {
        padding-top: 0;
    }

    .product-media {
        min-height: 340px;
    }

    .product-media img {
        max-height: 360px;
    }

    .product-buy-box {
        position: static;
    }
}

/* Mobile UX */
@media (max-width: 760px) {
    .product-main-section {
        padding-top: 12px;
        padding-bottom: 18px;
    }

    .product-breadcrumb {
        margin-bottom: 10px;
        font-size: 10px;
        gap: 6px;
    }

    .product-detail-card {
        gap: 14px;
    }

    .product-badge-row {
        margin-bottom: 6px;
    }

    .product-tag,
    .product-related-tag {
        min-height: 19px;
        padding: 0 6px;
        font-size: 8.5px;
    }

    .product-media {
        min-height: 245px;
    }

    .product-media img {
        max-width: 94%;
        max-height: 255px;
    }

    .product-status-row {
        min-height: 22px;
        margin-bottom: 9px;
    }

    .product-status-pill {
        min-height: 20px;
        font-size: 9px;
    }

    .product-summary h1,
    .product-empty-state h1 {
        font-size: 22px;
        line-height: 1.12;
        letter-spacing: -0.035em;
    }

    .product-code-inline {
        margin-top: 8px;
        font-size: 11px;
    }

    .product-category-line {
        margin-top: 9px;
        gap: 6px;
    }

    .product-category-line a,
    .product-category-line span {
        min-height: 21px;
        padding: 0 7px;
        font-size: 8.5px;
    }

    .product-summary-divider {
        margin: 13px 0;
    }

    .product-short-description {
        font-size: 13px;
        line-height: 1.48;
    }

    .product-summary-info {
        margin-top: 13px;
        padding-top: 12px;
    }

    .product-summary-info-heading {
        gap: 8px;
        margin-bottom: 9px;
    }

    .product-summary-info-icon {
        width: 25px;
        height: 25px;
        flex-basis: 25px;
        font-size: 12px;
    }

    .product-summary-info-heading h2 {
        font-size: 13px;
    }

    .product-summary-info-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
    }

    .product-summary-info-list > div {
        padding: 8px;
    }

    .product-summary-info-list dt {
        font-size: 8px;
    }

    .product-summary-info-list dd {
        font-size: 10.8px;
    }

    .product-summary-actions {
        grid-template-columns: 1fr;
        gap: 7px;
        margin-top: 13px;
        padding-top: 13px;
    }

    .product-outline-action {
        min-height: 34px;
        font-size: 9px;
    }

    .product-buy-box {
        padding: 15px;
        background: #ffffff;
    }

    .product-buy-price {
        margin-top: 15px;
        padding-top: 13px;
    }

    .product-buy-price strong {
        font-size: 21px;
    }

    .product-actions-row {
        margin-top: 14px;
        gap: 8px;
    }

    .product-qty {
        width: 72px;
        min-width: 72px;
        height: 36px;
        grid-template-columns: 23px 1fr 23px;
    }

    .product-primary-action {
        min-height: 36px;
        font-size: 9px;
        padding: 0 10px;
    }

    .product-secondary-action {
        min-height: 35px;
        font-size: 9px;
    }

    .product-buy-benefits {
        margin: 16px -15px -15px;
        padding: 14px 15px;
    }

    .product-buy-benefits li {
        font-size: 11px;
    }

    .product-description-section {
        padding-bottom: 28px;
    }

    .product-description-card {
        padding: 20px 0 22px;
    }

    .product-description-card h2,
    .product-section-heading h2 {
        font-size: 19px;
    }

    .product-description-content {
        font-size: 13px;
        line-height: 1.5;
    }

    .product-description-content ul,
    .product-description-content ol {
        padding-left: 17px;
    }

    .product-related-track {
        --product-related-gap: 14px;
        grid-auto-columns: calc((100% - var(--product-related-gap)) / 2);
    }

    .product-related-card {
        min-height: 330px;
    }

    .product-related-media {
        height: 132px;
        margin-bottom: 9px;
    }

    .product-related-name {
        min-height: 44px;
        font-size: 12px;
        line-height: 1.25;
    }

    .product-related-meta {
        margin-top: 7px;
    }

    .product-related-bottom {
        padding-top: 8px;
    }

    .product-related-price {
        font-size: 16px;
    }

    .product-related-stock {
        margin-top: 6px;
        gap: 5px;
        font-size: 9.5px;
    }
}

@media (max-width: 390px) {
    .product-summary h1,
    .product-empty-state h1 {
        font-size: 21px;
    }

    .product-media {
        min-height: 225px;
    }

    .product-media img {
        max-height: 235px;
    }

    .product-related-track {
        --product-related-gap: 12px;
    }

    .product-related-media {
        height: 122px;
    }

    .product-related-name {
        font-size: 11.5px;
    }
}

/* Fix descrizioni prodotto importate: elimina <br> anomali dentro liste */
.product-description-content ul > br,
.product-description-content ol > br,
.product-description-content li + br {
    display: none !important;
}

.product-description-content ul,
.product-description-content ol {
    margin-top: 10px;
    margin-bottom: 16px;
}

.product-description-content li {
    margin-bottom: 7px;
}

.product-description-content li:last-child {
    margin-bottom: 0;
}


/* ==========================================================================
   ITNETCOM - Product buy box UX refinement
   Migliora prezzo, disponibilità, quantità, CTA e resa mobile.
   Fine product buy box UX refinement
   ========================================================================== */

.product-buy-box {
    border: 1px solid #e5e5e5;
    background: #ffffff;
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.055);
}

.product-buy-status {
    display: flex;
    align-items: center;
    gap: 7px;
    padding-bottom: 14px;
    border-bottom: 1px solid #eeeeee;
    color: #148a32;
    font-size: 12px;
    font-weight: 800;
    line-height: 1.25;
}

.product-buy-status::before {
    content: "";
    width: 7px;
    height: 7px;
    flex: 0 0 7px;
    border-radius: 999px;
    background: currentColor;
}

.product-buy-price {
    margin-top: 16px;
    padding-top: 0;
    border-top: 0;
}

.product-buy-price span {
    display: block;
    margin-bottom: 5px;
    color: #777777;
    font-size: 9.5px;
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.product-buy-price strong {
    display: block;
    color: #111111;
    font-size: 25px;
    line-height: 1.05;
    font-weight: 900;
    letter-spacing: -0.035em;
}

.product-buy-availability {
    margin-top: 9px;
    color: #555555;
    font-size: 12px;
    line-height: 1.35;
}

.product-actions-row {
    display: grid;
    grid-template-columns: 82px minmax(0, 1fr);
    gap: 8px;
    align-items: stretch;
    margin-top: 16px;
}

.product-qty {
    width: 82px;
    min-width: 82px;
    height: 40px;
    border: 1px solid #dddddd;
    background: #ffffff;
}

.product-qty button {
    width: 100%;
    height: 100%;
    border: 0;
    background: #ffffff;
    color: #111111;
    font-size: 15px;
    font-weight: 900;
    line-height: 1;
}

.product-qty button:hover {
    background: #f5f5f5;
}

.product-qty span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    border-left: 1px solid #eeeeee;
    border-right: 1px solid #eeeeee;
    color: #111111;
    font-size: 13px;
    font-weight: 900;
    line-height: 1;
}

.product-primary-action {
    min-height: 40px;
    border: 1px solid #ff0000;
    background: #ff0000;
    color: #ffffff;
    font-size: 10px;
    font-weight: 900;
    line-height: 1.1;
    letter-spacing: 0.035em;
    text-transform: uppercase;
}

.product-primary-action:hover {
    background: #d90000;
    border-color: #d90000;
}

.product-secondary-action {
    min-height: 38px;
    border: 1px solid #dddddd;
    background: #ffffff;
    color: #111111;
    font-size: 9.5px;
    font-weight: 900;
    line-height: 1.1;
    letter-spacing: 0.035em;
    text-transform: uppercase;
}

.product-secondary-action:hover {
    border-color: #111111;
}

.product-back-link {
    display: inline-flex;
    justify-content: center;
    width: 100%;
    margin-top: 10px;
    color: #555555;
    font-size: 9.5px;
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: 0.045em;
    text-transform: uppercase;
}

.product-back-link:hover {
    color: #ff0000;
}

.product-buy-benefits {
    margin-top: 17px;
    border-top: 1px solid #eeeeee;
    background: #fafafa;
}

.product-buy-benefits ul,
.product-buy-benefits ol {
    margin: 0;
    padding: 0;
    list-style: none;
}

.product-buy-benefits li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    color: #444444;
    font-size: 11.5px;
    line-height: 1.42;
}

.product-buy-benefits li + li {
    margin-top: 9px;
}

.product-buy-benefits .material-symbols-outlined {
    margin-top: 1px;
    color: #ff0000;
    font-size: 16px;
    line-height: 1;
}

/* Stato non disponibile o pulsante disabilitato */
.product-primary-action:disabled,
.product-primary-action[disabled] {
    border-color: #cccccc;
    background: #cccccc;
    color: #666666;
    cursor: not-allowed;
}

/* Mobile */
@media (max-width: 760px) {
    .product-buy-box {
        margin-top: 4px;
        padding: 15px;
        border-color: #e2e2e2;
        box-shadow: 0 10px 28px rgba(0, 0, 0, 0.045);
    }

    .product-buy-status {
        padding-bottom: 12px;
        font-size: 11.5px;
    }

    .product-buy-price {
        margin-top: 14px;
    }

    .product-buy-price span {
        font-size: 9px;
    }

    .product-buy-price strong {
        font-size: 22px;
    }

    .product-buy-availability {
        margin-top: 8px;
        font-size: 11.5px;
    }

    .product-actions-row {
        grid-template-columns: 76px minmax(0, 1fr);
        gap: 8px;
        margin-top: 14px;
    }

    .product-qty {
        width: 76px;
        min-width: 76px;
        height: 38px;
        grid-template-columns: 24px 1fr 24px;
    }

    .product-qty button {
        font-size: 14px;
    }

    .product-qty span {
        font-size: 12px;
    }

    .product-primary-action {
        min-height: 38px;
        padding: 0 10px;
        font-size: 9px;
        letter-spacing: 0.025em;
    }

    .product-secondary-action {
        min-height: 36px;
        margin-top: 8px;
        font-size: 9px;
    }

    .product-back-link {
        margin-top: 9px;
        font-size: 9px;
    }

    .product-buy-benefits {
        margin: 15px -15px -15px;
        padding: 14px 15px;
    }

    .product-buy-benefits li {
        gap: 7px;
        font-size: 11px;
        line-height: 1.38;
    }

    .product-buy-benefits .material-symbols-outlined {
        font-size: 15px;
    }
}

@media (max-width: 390px) {
    .product-buy-box {
        padding: 14px;
    }

    .product-actions-row {
        grid-template-columns: 72px minmax(0, 1fr);
    }

    .product-qty {
        width: 72px;
        min-width: 72px;
    }

    .product-primary-action {
        font-size: 8.7px;
    }

    .product-buy-benefits {
        margin: 14px -14px -14px;
        padding: 13px 14px;
    }
}


/* ==========================================================================
   ITNETCOM - Product buy box premium refinement
   Versione più professionale del box acquisto prodotto.
   Non tocca home, negozio, carrello o checkout.
   ========================================================================== */

@media (min-width: 1181px) {
    .product-detail-card {
        grid-template-columns: minmax(330px, 0.86fr) minmax(0, 1fr) 320px;
        gap: 28px;
        align-items: start;
    }
}

.product-buy-box {
    overflow: hidden;
    padding: 0 !important;
    border: 1px solid #e7e7e7 !important;
    background: #ffffff !important;
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.055) !important;
}

.product-buy-status {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 46px !important;
    padding: 0 18px !important;
    border-bottom: 1px solid #ededed !important;
    background: #fbfbfb !important;
    color: #168236 !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    line-height: 1.2 !important;
    letter-spacing: 0.01em !important;
}

/* Evita doppio pallino verde */
.product-buy-status::before {
    display: none !important;
}

.product-buy-status .material-symbols-outlined {
    width: 9px !important;
    height: 9px !important;
    min-width: 9px !important;
    border-radius: 999px !important;
    background: currentColor !important;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 1 !important;
}

.product-buy-price {
    margin: 0 !important;
    padding: 20px 18px 0 !important;
    border-top: 0 !important;
}

.product-buy-price span {
    display: block !important;
    margin-bottom: 7px !important;
    color: #777777 !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    line-height: 1.2 !important;
    letter-spacing: 0.13em !important;
    text-transform: uppercase !important;
}

.product-buy-price strong {
    display: block !important;
    color: #111111 !important;
    font-size: 28px !important;
    line-height: 1 !important;
    font-weight: 950 !important;
    letter-spacing: -0.045em !important;
}

.product-buy-availability {
    margin: 9px 18px 0 !important;
    color: #565656 !important;
    font-size: 12px !important;
    line-height: 1.45 !important;
}

.product-actions-row {
    display: grid !important;
    grid-template-columns: 86px minmax(0, 1fr) !important;
    gap: 9px !important;
    align-items: stretch !important;
    margin: 18px 18px 0 !important;
}

.product-qty {
    width: 86px !important;
    min-width: 86px !important;
    height: 42px !important;
    display: grid !important;
    grid-template-columns: 27px 1fr 27px !important;
    border: 1px solid #dedede !important;
    background: #ffffff !important;
}

.product-qty button {
    width: 100% !important;
    height: 100% !important;
    border: 0 !important;
    background: #ffffff !important;
    color: #111111 !important;
    font-size: 15px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
}

.product-qty button:hover {
    background: #f5f5f5 !important;
}

.product-qty span {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-left: 1px solid #eeeeee !important;
    border-right: 1px solid #eeeeee !important;
    color: #111111 !important;
    font-size: 13px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
}

.product-primary-action {
    min-height: 42px !important;
    border: 1px solid #ff0000 !important;
    background: #ff0000 !important;
    color: #ffffff !important;
    font-size: 10px !important;
    font-weight: 950 !important;
    line-height: 1.1 !important;
    letter-spacing: 0.035em !important;
    text-transform: uppercase !important;
    box-shadow: 0 8px 18px rgba(255, 0, 0, 0.18) !important;
}

.product-primary-action:hover {
    border-color: #d90000 !important;
    background: #d90000 !important;
    box-shadow: 0 10px 20px rgba(217, 0, 0, 0.22) !important;
}

.product-secondary-action {
    width: calc(100% - 36px) !important;
    min-height: 39px !important;
    margin: 9px 18px 0 !important;
    border: 1px solid #dedede !important;
    background: #ffffff !important;
    color: #111111 !important;
    font-size: 9.5px !important;
    font-weight: 900 !important;
    line-height: 1.1 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
}

.product-secondary-action:hover {
    border-color: #111111 !important;
    background: #fafafa !important;
}

.product-back-link {
    display: flex !important;
    justify-content: center !important;
    width: calc(100% - 36px) !important;
    margin: 10px 18px 0 !important;
    color: #555555 !important;
    font-size: 9.5px !important;
    font-weight: 850 !important;
    line-height: 1.2 !important;
    letter-spacing: 0.045em !important;
    text-transform: uppercase !important;
}

.product-back-link:hover {
    color: #ff0000 !important;
}

.product-buy-benefits {
    margin: 18px 0 0 !important;
    padding: 16px 18px 18px !important;
    border-top: 1px solid #eeeeee !important;
    background: linear-gradient(180deg, #fafafa 0%, #ffffff 100%) !important;
}

.product-buy-benefits ul,
.product-buy-benefits ol {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.product-buy-benefits li {
    display: grid !important;
    grid-template-columns: 18px minmax(0, 1fr) !important;
    align-items: start !important;
    gap: 8px !important;
    color: #454545 !important;
    font-size: 11.5px !important;
    line-height: 1.42 !important;
}

.product-buy-benefits li + li {
    margin-top: 10px !important;
}

.product-buy-benefits .material-symbols-outlined {
    margin-top: 0 !important;
    color: #ff0000 !important;
    font-size: 16px !important;
    line-height: 1.15 !important;
}

.product-primary-action:disabled,
.product-primary-action[disabled] {
    border-color: #cfcfcf !important;
    background: #cfcfcf !important;
    color: #666666 !important;
    box-shadow: none !important;
    cursor: not-allowed !important;
}

/* Mobile: box pieno, compatto, più e-commerce */
@media (max-width: 760px) {
    .product-buy-box {
        margin-top: 2px !important;
        border-color: #e4e4e4 !important;
        box-shadow: 0 12px 30px rgba(0, 0, 0, 0.05) !important;
    }

    .product-buy-status {
        min-height: 43px !important;
        padding: 0 15px !important;
        font-size: 11.5px !important;
    }

    .product-buy-price {
        padding: 17px 15px 0 !important;
    }

    .product-buy-price span {
        margin-bottom: 6px !important;
        font-size: 9px !important;
    }

    .product-buy-price strong {
        font-size: 24px !important;
    }

    .product-buy-availability {
        margin: 8px 15px 0 !important;
        font-size: 11.5px !important;
    }

    .product-actions-row {
        grid-template-columns: 78px minmax(0, 1fr) !important;
        gap: 8px !important;
        margin: 15px 15px 0 !important;
    }

    .product-qty {
        width: 78px !important;
        min-width: 78px !important;
        height: 40px !important;
        grid-template-columns: 25px 1fr 25px !important;
    }

    .product-primary-action {
        min-height: 40px !important;
        padding: 0 10px !important;
        font-size: 9px !important;
        letter-spacing: 0.025em !important;
    }

    .product-secondary-action {
        width: calc(100% - 30px) !important;
        min-height: 38px !important;
        margin: 8px 15px 0 !important;
        font-size: 9px !important;
    }

    .product-back-link {
        width: calc(100% - 30px) !important;
        margin: 9px 15px 0 !important;
        font-size: 9px !important;
    }

    .product-buy-benefits {
        margin-top: 15px !important;
        padding: 15px !important;
    }

    .product-buy-benefits li {
        grid-template-columns: 17px minmax(0, 1fr) !important;
        gap: 7px !important;
        font-size: 11px !important;
        line-height: 1.38 !important;
    }

    .product-buy-benefits .material-symbols-outlined {
        font-size: 15px !important;
    }
}

@media (max-width: 390px) {
    .product-actions-row {
        grid-template-columns: 74px minmax(0, 1fr) !important;
    }

    .product-qty {
        width: 74px !important;
        min-width: 74px !important;
        grid-template-columns: 24px 1fr 24px !important;
    }

    .product-primary-action {
        font-size: 8.6px !important;
    }
}


/* ==========================================================================
   ITNETCOM - Product page modern commerce refinement
   Box acquisto e dettagli prodotto più moderni, morbidi e mobile-first.
   Non tocca home, negozio, carrello o checkout.
   Fine product page modern commerce refinement
   ========================================================================== */

.product-page {
    --itn-radius-lg: 18px;
    --itn-radius-md: 12px;
    --itn-soft-bg: #f5f6f8;
    --itn-soft-line: #e7e9ee;
    --itn-red: #ff0000;
    --itn-red-dark: #d90000;
}

/* Layout leggermente più arioso e moderno */
@media (min-width: 1181px) {
    .product-detail-card {
        grid-template-columns: minmax(340px, 0.9fr) minmax(0, 1fr) 330px !important;
        gap: 30px !important;
        align-items: start !important;
    }

    .product-media {
        border-radius: var(--itn-radius-lg);
    }
}

/* Immagine prodotto più pulita, senza effetto catalogo vecchio */
.product-media {
    background: #ffffff !important;
}

.product-media img {
    object-fit: contain !important;
}

/* Pill e tag meno rigidi */
.product-status-pill,
.product-category-line a,
.product-category-line span,
.product-tag,
.product-related-tag {
    border-radius: 999px !important;
}

/* Riferimenti prodotto più morbidi */
.product-summary-info-list > div {
    border-radius: 10px !important;
    background: #ffffff !important;
    border-color: #ececec !important;
}

/* Bottoni sotto descrizione: meno squadrati, più moderni */
.product-outline-action {
    min-height: 38px !important;
    border-radius: 10px !important;
    border-color: var(--itn-red) !important;
    color: var(--itn-red) !important;
    background: #ffffff !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    letter-spacing: 0.04em !important;
}

.product-outline-action:hover {
    background: #fff4f4 !important;
}

/* Buy box stile pannello moderno */
.product-buy-box {
    overflow: hidden !important;
    padding: 0 !important;
    border: 1px solid var(--itn-soft-line) !important;
    border-radius: var(--itn-radius-lg) !important;
    background: var(--itn-soft-bg) !important;
    box-shadow: 0 18px 42px rgba(17, 17, 17, 0.07) !important;
}

/* Header disponibilità */
.product-buy-status {
    min-height: 54px !important;
    padding: 0 20px !important;
    display: flex !important;
    align-items: center !important;
    gap: 9px !important;
    border-bottom: 1px solid #e0e3e8 !important;
    background: #eef1f5 !important;
    color: #168236 !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    line-height: 1.2 !important;
}

.product-buy-status::before {
    display: none !important;
}

.product-buy-status .material-symbols-outlined {
    width: 9px !important;
    height: 9px !important;
    min-width: 9px !important;
    border-radius: 999px !important;
    background: currentColor !important;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 1 !important;
}

/* Corpo prezzo */
.product-buy-price {
    margin: 0 !important;
    padding: 22px 20px 0 !important;
    border: 0 !important;
    background: transparent !important;
}

.product-buy-price span {
    display: block !important;
    margin-bottom: 6px !important;
    color: #6f7680 !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    line-height: 1.2 !important;
    letter-spacing: 0.13em !important;
    text-transform: uppercase !important;
}

.product-buy-price strong {
    display: block !important;
    color: #080808 !important;
    font-size: 30px !important;
    line-height: 1 !important;
    font-weight: 950 !important;
    letter-spacing: -0.045em !important;
}

/* Disponibilità sotto prezzo */
.product-buy-availability {
    margin: 9px 20px 0 !important;
    color: #4f5660 !important;
    font-size: 12px !important;
    line-height: 1.45 !important;
}

/* Quantità + CTA */
.product-actions-row {
    display: grid !important;
    grid-template-columns: 88px minmax(0, 1fr) !important;
    gap: 9px !important;
    align-items: stretch !important;
    margin: 18px 20px 0 !important;
}

.product-qty {
    width: 88px !important;
    min-width: 88px !important;
    height: 44px !important;
    display: grid !important;
    grid-template-columns: 28px 1fr 28px !important;
    overflow: hidden !important;
    border: 1px solid #d7dce3 !important;
    border-radius: 10px !important;
    background: #ffffff !important;
}

.product-qty button {
    border: 0 !important;
    background: #ffffff !important;
    color: #111111 !important;
    font-size: 15px !important;
    font-weight: 950 !important;
}

.product-qty button:hover {
    background: #f1f2f4 !important;
}

.product-qty span {
    border-left: 1px solid #edf0f3 !important;
    border-right: 1px solid #edf0f3 !important;
    color: #111111 !important;
    font-size: 13px !important;
    font-weight: 950 !important;
}

/* CTA principale */
.product-primary-action {
    gap: 8px !important;
    min-height: 44px !important;
    border: 0 !important;
    border-radius: 10px !important;
    background: linear-gradient(180deg, #ff1a1a 0%, #e00000 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 10px 22px rgba(255, 0, 0, 0.20) !important;
    font-size: 10.5px !important;
    font-weight: 950 !important;
    line-height: 1.1 !important;
    letter-spacing: 0.035em !important;
    text-transform: uppercase !important;
}

.product-primary-action:hover {
    background: linear-gradient(180deg, #e00000 0%, #c90000 100%) !important;
    box-shadow: 0 12px 24px rgba(217, 0, 0, 0.24) !important;
}

.product-primary-action svg {
    width: 18px;
    height: 18px;
    display: block;
    flex-shrink: 0;
}

/* Pulsanti secondari */
.product-secondary-action {
    width: calc(100% - 40px) !important;
    min-height: 40px !important;
    margin: 10px 20px 0 !important;
    border: 1px solid #d7dce3 !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    color: #111111 !important;
    font-size: 9.5px !important;
    font-weight: 900 !important;
    line-height: 1.1 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
}

.product-secondary-action:hover {
    border-color: #111111 !important;
    background: #f7f8fa !important;
}

.product-back-link {
    width: calc(100% - 40px) !important;
    margin: 11px 20px 0 !important;
    display: flex !important;
    justify-content: center !important;
    color: #5c626b !important;
    font-size: 9.5px !important;
    font-weight: 850 !important;
    letter-spacing: 0.045em !important;
    text-transform: uppercase !important;
}

/* Sezione vantaggi integrata nel box */
.product-buy-benefits {
    margin: 20px 0 0 !important;
    padding: 18px 20px 20px !important;
    border-top: 1px solid #dfe3e8 !important;
    background: #eef1f5 !important;
}

.product-buy-benefits ul,
.product-buy-benefits ol {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.product-buy-benefits li {
    display: grid !important;
    grid-template-columns: 20px minmax(0, 1fr) !important;
    align-items: start !important;
    gap: 9px !important;
    color: #2f343a !important;
    font-size: 12px !important;
    line-height: 1.42 !important;
}

.product-buy-benefits li + li {
    margin-top: 11px !important;
}

.product-buy-benefits .material-symbols-outlined {
    margin-top: 0 !important;
    color: var(--itn-red) !important;
    font-size: 17px !important;
    line-height: 1.15 !important;
}

/* Disabilitato */
.product-primary-action:disabled,
.product-primary-action[disabled] {
    background: #cfd3d9 !important;
    color: #68707a !important;
    box-shadow: none !important;
    cursor: not-allowed !important;
}

/* Correlati: card leggermente più morbide */
.product-related-card {
    border-radius: 14px !important;
}

/* Mobile */
@media (max-width: 760px) {
    .product-buy-box {
        margin-top: 4px !important;
        border-radius: 16px !important;
        box-shadow: 0 12px 28px rgba(17, 17, 17, 0.07) !important;
    }

    .product-buy-status {
        min-height: 48px !important;
        padding: 0 16px !important;
        font-size: 12px !important;
    }

    .product-buy-price {
        padding: 18px 16px 0 !important;
    }

    .product-buy-price span {
        font-size: 9px !important;
    }

    .product-buy-price strong {
        font-size: 25px !important;
    }

    .product-buy-availability {
        margin: 8px 16px 0 !important;
        font-size: 11.5px !important;
    }

    .product-actions-row {
        grid-template-columns: 80px minmax(0, 1fr) !important;
        gap: 8px !important;
        margin: 16px 16px 0 !important;
    }

    .product-qty {
        width: 80px !important;
        min-width: 80px !important;
        height: 42px !important;
        grid-template-columns: 25px 1fr 25px !important;
        border-radius: 9px !important;
    }

    .product-primary-action {
        min-height: 42px !important;
        border-radius: 9px !important;
        padding: 0 10px !important;
        font-size: 9px !important;
        letter-spacing: 0.025em !important;
    }

    .product-secondary-action {
        width: calc(100% - 32px) !important;
        min-height: 39px !important;
        margin: 9px 16px 0 !important;
        border-radius: 9px !important;
        font-size: 9px !important;
    }

    .product-back-link {
        width: calc(100% - 32px) !important;
        margin: 10px 16px 0 !important;
        font-size: 9px !important;
    }

    .product-buy-benefits {
        margin-top: 17px !important;
        padding: 16px !important;
    }

    .product-buy-benefits li {
        grid-template-columns: 18px minmax(0, 1fr) !important;
        gap: 8px !important;
        font-size: 11px !important;
        line-height: 1.38 !important;
    }

    .product-buy-benefits .material-symbols-outlined {
        font-size: 15px !important;
    }
}

@media (max-width: 390px) {
    .product-actions-row {
        grid-template-columns: 76px minmax(0, 1fr) !important;
    }

    .product-qty {
        width: 76px !important;
        min-width: 76px !important;
        grid-template-columns: 24px 1fr 24px !important;
    }

    .product-primary-action {
        font-size: 8.6px !important;
    }
}


/* ==========================================================================
   ITNETCOM - Product title size final tuning
   Riduce il titolo prodotto per renderlo più vicino alla scala del negozio.
   ========================================================================== */

.product-summary h1,
.product-empty-state h1 {
    max-width: 640px !important;
    font-size: clamp(21px, 1.75vw, 26px) !important;
    line-height: 1.12 !important;
    letter-spacing: -0.025em !important;
    font-weight: 800 !important;
}

@media (max-width: 760px) {
    .product-summary h1,
    .product-empty-state h1 {
        font-size: 20px !important;
        line-height: 1.16 !important;
        letter-spacing: -0.02em !important;
    }
}

@media (max-width: 390px) {
    .product-summary h1,
    .product-empty-state h1 {
        font-size: 19px !important;
        line-height: 1.16 !important;
    }
}

/* === ITNETCOM SCALE ALIGNMENT 2026-04-30 START === */
/* Riallineamento pagina prodotto alla scala visiva di Home e Negozio */
@media (min-width: 1421px) {
    .product-main-section {
        padding-top: 38px;
        padding-bottom: 44px;
    }

    .product-breadcrumb {
        margin-bottom: 26px;
        font-size: 12px;
    }

    .product-detail-card {
        grid-template-columns: minmax(500px, 0.95fr) minmax(500px, 1.05fr) 360px;
        gap: 38px;
        align-items: start;
    }

    .product-summary {
        padding-top: 44px;
    }

    .product-media {
        min-height: 560px;
        border: 1px solid #eeeeee;
        background: #ffffff;
    }

    .product-media img {
        max-width: 96%;
        max-height: 620px;
    }

    .product-summary h1,
    .product-empty-state h1 {
        max-width: 860px;
        font-size: clamp(34px, 2.55vw, 48px);
        line-height: 1.02;
        font-weight: 800;
        letter-spacing: -0.045em;
    }

    .product-code-inline {
        margin-top: 12px;
        font-size: 13px;
    }

    .product-short-description {
        max-width: 860px;
        font-size: 14px;
        line-height: 1.5;
    }

    .product-summary-info-heading h2 {
        font-size: 16px;
    }

    .product-summary-info-list > div {
        padding: 11px 12px;
    }

    .product-summary-info-list dd {
        font-size: 13px;
    }

    .product-buy-box {
        top: 118px;
        width: 100%;
        padding: 26px;
        border: 1px solid #e5e5e5;
        border-radius: 0;
        background: #ffffff;
        box-shadow: 0 18px 44px rgba(0, 0, 0, 0.07);
    }

    .product-buy-price strong {
        font-size: 32px;
    }

    .product-actions-row {
        gap: 10px;
    }

    .product-qty {
        width: 104px;
        min-width: 104px;
        height: 48px;
        grid-template-columns: 34px 1fr 34px;
    }

    .product-primary-action,
    .product-secondary-action,
    .product-help-card a,
    .product-empty-state .product-primary-action {
        min-height: 48px;
        font-size: 12px;
    }

    .product-description-section {
        padding-bottom: 52px;
    }

    .product-description-card {
        padding: 38px 0 44px;
        border-top: 1px solid #eeeeee;
    }

    .product-description-card h2,
    .product-section-heading h2 {
        font-size: 22px;
        line-height: 1.15;
    }

    .product-description-content {
        max-width: 1120px;
        font-size: 14px;
        line-height: 1.55;
    }

    .product-related-card {
        min-height: 430px;
    }

    .product-related-media {
        height: 220px;
    }
}

@media (min-width: 1181px) and (max-width: 1420px) {
    .product-detail-card {
        grid-template-columns: minmax(380px, 0.95fr) minmax(0, 1fr) 320px;
        gap: 28px;
    }

    .product-media {
        min-height: 470px;
    }

    .product-media img {
        max-height: 520px;
    }

    .product-summary h1,
    .product-empty-state h1 {
        font-size: clamp(30px, 2.4vw, 40px);
        line-height: 1.05;
    }

    .product-buy-box {
        padding: 22px;
    }
}

@media (max-width: 760px) {
    .product-media {
        min-height: 285px;
    }

    .product-media img {
        max-height: 300px;
    }

    .product-summary h1,
    .product-empty-state h1 {
        font-size: 24px;
        line-height: 1.1;
    }

    .product-primary-action,
    .product-secondary-action {
        min-height: 42px;
        font-size: 10.5px;
    }
}
/* === ITNETCOM SCALE ALIGNMENT 2026-04-30 END === */

/* === Pulsante carrello: stile identico al negozio === */
.product-primary-action[data-cart-add] {
    height: 40px !important;
    min-height: 40px !important;
    border: 1px solid var(--brand-red) !important;
    background: var(--brand-red) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.04em !important;
    padding: 0 12px !important;
    gap: 8px !important;
    transition: background 0.2s ease, border-color 0.2s ease, opacity 0.2s ease !important;
}

.product-primary-action[data-cart-add]:hover:not(:disabled) {
    background: #cc0000 !important;
    border-color: #cc0000 !important;
    box-shadow: none !important;
}

.product-primary-action[data-cart-add]:disabled,
.product-primary-action[data-cart-add][disabled] {
    background: var(--brand-red) !important;
    border-color: var(--brand-red) !important;
    box-shadow: none !important;
    opacity: 0.45 !important;
    color: #ffffff !important;
    cursor: not-allowed !important;
}
