/**
 * css/custom/checkout_odoo.css
 * Stili personalizzati per la pagina di checkout / conferma ordine
 * Adattato agli standard di stile Odoo
 * 
 * @package ItticiSurgelati
 * @version 2.0.0 - Odoo Style
 */

/* ============================================
   VARIABILI ODOO
   ============================================ */
:root {

    --odoo-cart-hover       : #f0f0f0;
    --odoo-text-soft        : #78878f;

}


/* ============================================
   SEZIONE PRINCIPALE CHECKOUT
   ============================================ */
.flat-spacing {
    padding         : 0px 0;
    margin-top      : 0px;
}

.tf-checkout-cart-main {
    background      : #fff;
    border-radius   : 0px;
    padding         : 32px;
}

.tf-checkout-cart-main .title {
    font-size       : 34px;
    font-weight     : 500;
    color           : var(--odoo-text-primary);
    margin-bottom   : 24px;
    padding-bottom  : 5px;
    border-bottom   : 2px solid var(--odoo-brand-accent);
    display         : inline-block;
    letter-spacing  : -0.3px;
}

/* ============================================
   GRIGLIA FORM
   ============================================ */
.tf-grid-layout {
    display         : grid;
    gap             : 20px;
    margin-bottom   : 20px;
}

.sm-col-2 {
    grid-template-columns: repeat(2, 1fr);
}

/* ============================================
   GRUPPO CAMPO
   ============================================ */
.form-group {
    margin-bottom: 20px;
}

.form-group .form-control {
    width           : 100%;
    padding         : 0px 0 0px 0;
    font-size       : 24px;
    font-weight     : 400;
    color           : var(--odoo-text-primary);
    background      : transparent;
    border          : none;
    border-bottom   : 1px solid var(--odoo-input-border);
    border-radius   : 0;
    transition      : border-color 0.2s ease;
    font-family     : inherit;
    cursor          : pointer;

    background      : var(--odoo-gray-200);


}

.form-group .form-control:hover {
    border-bottom-color: var(--odoo-gray-500);
}

.form-group .form-control:focus {
    outline         : none;
    border-bottom   : 2px solid var(--odoo-input-focus);
    box-shadow      : none;
}

.form-group .form-control-static {
    padding         : 6px 0;
    font-size       : 24px;
    font-weight     : 400;
    color           : var(--odoo-text-primary);
    border-bottom   : 1px solid var(--odoo-border-color);
    cursor          : default;
}

/* ============================================
   TEXTAREA NOTE
   ============================================ */
.form-group-note {
    margin-top: 16px;
}

.form-group-note label {
    display         : block;
    font-size       : 20px;
    font-weight     : 600;
    color           : var(--odoo-text-secondary);
    margin-bottom   : 8px;
    text-transform  : uppercase;
    letter-spacing  : 0.5px;
}

.form-group-note textarea.form-control {
    width           : 100%;
    padding         : 4px 0;
    font-size       : 20px;
    font-weight     : 400;
    color           : var(--odoo-text-primary);
    background      : transparent;
    border          : none;
    border-bottom   : 1px solid var(--odoo-input-border);
    border-radius   : 0;
    resize          : vertical;
    min-height      : 80px;
    transition      : border-color 0.2s ease;
    cursor          : pointer;

    background      : var(--odoo-gray-200);    
}

.form-group-note textarea.form-control:focus {
    border          : 2px solid var(--odoo-input-focus);
    box-shadow      : none;
}

/* ============================================
   CAMPO CON DOPPIO VALORE (CAP - COMUNE)
   ============================================ */
.double-value {
    display         : flex;
    align-items     : baseline;
    gap             : 8px;
    padding         : 8px 0;
    font-size       : 24px;
    font-weight     : 400;
    color           : var(--odoo-text-primary);
    border-bottom   : 1px solid var(--odoo-border-color);
    /** background      : var(--odoo-gray-100); */ 
}

.double-value .separator {
    color   : var(--odoo-gray-400);
    margin  : 0 4px;
}

/* ============================================
   METODO DI PAGAMENTO
   ============================================ */
.payment-box {
    margin-top  : 32px;
    padding-top : 24px;
    border-top  : 1px solid var(--odoo-border-color);
}

.payment-title {
    font-size       : 16px;
    font-weight     : 600;
    color           : var(--odoo-text-primary);
    margin-bottom   : 16px;
    text-transform  : uppercase;
    letter-spacing  : 0.5px;
}

.payment_methods {
    display         : flex;
    flex-direction  : column;
    gap             : 12px;
    margin-bottom   : 24px;
}

.payment_method {
    display         : flex;
    align-items     : center;
    gap             : 12px;
    cursor          : pointer;
    padding         : 12px 16px;
    border          : 1px solid var(--odoo-border-color);
    border-radius   : 6px;
    transition      : all 0.2s ease;
    background      : #fff;
}

.payment_method:hover {
    border-color    : var(--odoo-input-focus);
    background      : rgba(113, 75, 103, 0.02);
}

.payment_method.active {
    border-color    : var(--odoo-input-focus);
    background      : rgba(113, 75, 103, 0.05);
}

.payment_method input[type="radio"] {
    width           : 16px;
    height          : 16px;
    accent-color    : var(--odoo-input-focus);
    cursor          : pointer;
    margin          : 0;
}

.payment_method label {
    flex            : 1;
    font-size       : 14px;
    font-weight     : 500;
    color           : var(--odoo-text-primary);
    cursor          : pointer;
    margin          : 0;
}

/* ============================================
   CONSEGNA
   ============================================ */
.delivery-info {
    padding: 8px 0;
}

.delivery-date {
    font-size       : 28px;
    font-weight     : 600;
    color           : var(--odoo-brand-accent);
    display         : inline-block;
    letter-spacing  : -0.3px;
    background      : transparent;
    border-left     : 3px solid var(--odoo-brand-accent);
    padding-left    : 16px;
}

@media (max-width: 991px) {
    .delivery-date {
        font-size: 24px;
        padding-left: 12px;
    }
}

@media (max-width: 767px) {
    .delivery-info {
        padding: 6px 0;
    }
    .delivery-date {
        font-size: 20px;
        padding-left: 10px;
        border-left-width: 2px;
    }
}

/* ============================================
   COLONNA DESTRA - RIEPILOGO ORDINE
   ============================================ */
.box-your-order .header {
 
    margin-top      : 20px !important;               

    padding-top     : 6px !important;

    font-size       : 40px !important;
    font-weight     : 600 !important;
    line-height     : 1.2 !important;

    color           : var(--odoo-text-soft) !important;;

    white-space     : nowrap !important;
    overflow        : hidden !important;
    text-overflow   : ellipsis !important;

}

/* ... CONTAINER PRINCIPALE ITEMS */
.box-your-order .checkout-cart-items {
    margin-top      : 0px;
    max-height      : 405px !important;
    overflow-y      : auto !important;
    padding         : 8px 0 !important;
}

/* ... SINGOLO ITEM - ALTEZZA FISSA */
.box-your-order .checkout-cart-items .tf-mini-cart-item {
    display         : flex !important;
    min-height      : 95px !important;
    max-height      : 95px !important;
    margin-bottom   : 2px !important;
    border-bottom   : 1px solid var(--odoo-border-color) !important;
    padding         : 0 !important;
    align-items     : center !important;
    overflow        : hidden !important;
}

.box-your-order .checkout-cart-items .tf-mini-cart-item:hover {
    background-color     : var(--odoo-cart-hover);
}

/* ... IMMAGINE */
.box-your-order .checkout-cart-items .tf-mini-cart-image {
    flex-shrink     : 0 !important;
    width           : 70px !important;
    height          : 75px !important;;
    border-radius   : 12px;
    overflow        : hidden;
    background      : #f8f8f8;
    display         : flex;
    align-items     : center;
    justify-content : center;
}

.box-your-order .checkout-cart-items .tf-mini-cart-image img {
    width           : 100% !important;
    height          : 100% !important;
    object-fit      : contain !important;
}

/* ... INFO PRODOTTO */
.box-your-order .checkout-cart-items .tf-mini-cart-info {
    flex            : 1 !important;
    padding         : 0px 8px 0 8px !important;   
    overflow        : hidden !important;
    display         : flex !important;
    flex-direction  : column !important;
    justify-content : flex-start !important;      
    height          : 100% !important;
}

/* ... TITOLO */
.box-your-order .checkout-cart-items .title {
    padding-top     : 6px !important;
    font-size       : 14px !important;
    font-weight     : 500 !important;
    margin          : 0 !important;               
    line-height     : 1.2 !important;
    white-space     : nowrap !important;
    overflow        : hidden !important;
    text-overflow   : ellipsis !important;
}

/* ... PREZZO UNITARIO */
.box-your-order .checkout-cart-items .cart-item-unit-price .unit-price-value {
    margin          : -5px 0 0 0!important;
    padding         : 0 !important;
    font-size       : 15px !important;
    line-height     : 1.0 !important;
    white-space     : nowrap !important;
    color           : var(--odoo-brand-accent) !important;
}
/* PREZZO UNITARIO - UM */
.box-your-order .checkout-cart-items .cart-item-unit-price .unit-price-umbase {
    margin          : -5px 0 0 0 !important;
    padding         : 0 !important;
    font-size       : 11px !important;
    line-height     : 1.2 !important;
    white-space     : nowrap !important;
    /** color           : var(--odoo-brand-accent) !important; */ 
}

/* ... DETTAGLI VARIABILI */
.box-your-order .checkout-cart-items .cart-item-details {
    margin          : -10px 0 !important;  /* Margine negativo verticale */
    padding         : 0 !important;
    line-height     : 1 !important;           
    white-space     : nowrap !important;    
}

.box-your-order .checkout-cart-items .detail-row {
    display         : inline-flex !important;
    margin-top      : -5px !important;  
    margin-bottom   : -2px !important;  
    padding         : 0 !important;
    line-height     : 1 !important;           
    font-size       : 10px !important;
    white-space     : nowrap !important;
}

.box-your-order .checkout-cart-items .detail-label {
    min-width       : auto !important;
    font-size       : 12px !important;
    line-height     : 1 !important;           
    margin          : 0 !important;
    padding         : 0 !important;
}

.box-your-order .checkout-cart-items .detail-value {
    font-size       : 12px !important;
    line-height     : 1 !important;           
    margin          : 0 !important;
    padding         : 0 !important;
}




/* ============================================
    TOTALI SINGOLO ITEM DEL CARRELLO  
   ============================================ */

.box-your-order .checkout-cart-items .cart-item-total {
    display         : flex !important;
    align-items     : center !important;
    gap             : 0px !important;
    margin          : 0 !important;
    padding         : 6px 0 0 0 !important;
}
/** ... TOTALE ITEM QUANTITA' */ 
.box-your-order .checkout-cart-items .total-quantity {
    padding         : 2px 0px !important;
    /** background      : #f5f5f5 !important; */ 
    /** border-radius   : 12px !important; */ 
    white-space     : nowrap !important;

}
/** ... TOTALE ITEM QUANTITA' - LABEL */ 
.box-your-order .checkout-cart-items .quantity-label {
    font-size       : 14px !important;
    color           : var(--odoo-text-primary);

}
/** ... TOTALE ITEM QUANTITA' - NUMBER */ 
.box-your-order .checkout-cart-items .quantity-number {
    font-size       : 15px !important;
    color           : var(--odoo-brand-accent) !important;
}
/** ... TOTALE ITEM QUANTITA' - UNITA' DI MISIRA */ 
.box-your-order .checkout-cart-items .quantity-umbase {
    font-size       : 12px !important;
    color           : var(--odoo-text-primary);
}

/** ... TOTALE ITEM IMPORTO - LABEL */ 
.box-your-order .checkout-cart-items .total-label {
    font-size       : 15px !important;
    margin-left     : auto !important;
    color           : var(--odoo-text-primary);
}
/** ... TOTALE ITEM IMPORTO - VALORE */ 
.box-your-order .checkout-cart-items .total-value {
    font-size       : 24px !important;
    font-weight     : 600 !important;
    white-space     : nowrap !important;
    color           : var(--odoo-brand-accent) !important;
}


/* ============================================
    TOTALI GENERALI ORDINE  
   ============================================ */
.box-your-order .checkout-cart-bottom {
    margin-top      : 16px !important;
    padding-top     : 12px !important;
    border-top      : 1px solid var(--odoo-border-color) !important;
}

.box-your-order .tf-mini-cart-threshold {
    margin-bottom   : 12px !important;
}


/** ... TOTALE NUMERO PRODOTTI - LABEL */ 
.box-your-order .total-ord-items-label {
    font-size       : 14px !important;
    font-weight     : 500 !important;
    color           : var(--odoo-text-secondary) !important;
    margin          : 0 !important;
}
/** ... TOTALE NUMERO PRODOTTI - VALORE */ 
.box-your-order .total-ord-items-value {
    font-size       : 15px !important;
    font-weight     : 500 !important;
    color           : var(--odoo-brand-accent) !important;
    margin          : 0 !important;
}

/** ... TOTALE IMPORTO ORDINE - LABEL */ 
.box-your-order .total-ord-label {
    font-size       : 14px !important;
    font-weight     : 500 !important;
    color           : var(--odoo-text-secondary) !important;
    margin          : 0 !important;
}

/** ... TOTALE IMPORTO ORDINE - VALORE */ 
.box-your-order .total-ord-price {
    font-size       : 32px !important;
    font-weight     : 600 !important;
    color           : var(--odoo-brand-accent) !important;
    margin          : 0 !important;
}


/* ============================================
   BOTTONE CONFERMA ORDINE 
   ============================================ */
.box-your-order .btn-checkout-order {
    display         : block !important;
    width           : 100% !important;
    padding         : 12px 20px !important;
    background      : var(--odoo-brand-accent) !important;
    color           : #fff !important;
    text-align      : center !important;
    text-decoration : none !important;
    font-size       : 18px !important;
    font-weight     : 600 !important;
    border-radius   : 28px !important;
    transition      : all 0.2s ease !important;
}

.box-your-order .btn-checkout-order:hover {

    background      : var(--odoo-brand-accent) !important;

}

.box-your-order .btn-checkout-order.disabled {
    background      : #ccc !important;
    cursor          : not-allowed !important;
    opacity         : 0.6 !important;
}


/* ============================================
   CLASSI DI UTILITÀ ODOO
   ============================================ */
.o_readonly {
    background-color: var(--odoo-gray-100);
    cursor: default;
}

.o_invalid .form-control {
    border-bottom-color: #dc3545;
}

.o_invalid_feedback {
    color: #dc3545;
    font-size: 12px;
    margin-top: 4px;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 991px) {
    .flat-spacing {
        padding: 30px 0;
    }
    
    .tf-checkout-cart-main {
        padding: 24px;
        margin-bottom: 30px;
    }
    
    .tf-checkout-cart-main .title {
        font-size: 22px;
    }
    
    .sm-col-2 {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    
    .form-group .form-control,
    .form-group .form-control-static,
    .double-value {
        font-size: 14px;
    }
    
    .fl-sidebar-cart {
        position: static;
    }
    
    .box-your-order .checkout-cart-items .tf-mini-cart-item {
        height: 65px !important;
        min-height: 65px !important;
        max-height: 65px !important;
    }
    
    .box-your-order .total-price {
        font-size: 20px !important;
    }
}

@media (max-width: 767px) {
    .flat-spacing {
        padding: 20px 0;
    }
    
    .tf-checkout-cart-main {
        padding: 20px;
    }
    
    .tf-checkout-cart-main .title {
        font-size: 20px;
    }
    
    .form-group .form-control,
    .form-group .form-control-static,
    .double-value {
        font-size: 14px;
        padding: 6px 0;
    }
    
    .box-your-order .checkout-cart-items .tf-mini-cart-item {
        height: 60px !important;
        min-height: 60px !important;
        max-height: 60px !important;
    }
    
    .box-your-order .checkout-cart-items .tf-mini-cart-image {
        width: 45px !important;
        height: 45px !important;
    }
    
    .box-your-order .checkout-cart-items .title {
        font-size: 12px !important;
    }
    
    .box-your-order .total-price {
        font-size: 18px !important;
    }
    
    .box-your-order .btn-checkout-order {
        font-size: 14px !important;
        padding: 10px 16px !important;
    }
}