/**
 * Stili per il checkout classico WooCommerce (shortcode [woocommerce_checkout])
 * Usato nella pagina Carta del Docente. Segue il design system Google Minimal del plugin.
 */

/* ───────────────────────────────────────────
   Wrapper generale
─────────────────────────────────────────── */
.woocommerce-checkout-wrapper,
.woocommerce-page .woocommerce {
    max-width: 860px;
    margin: 2rem auto;
    padding: 0 1rem;
    font-family: Manrope, -apple-system, sans-serif;
    color: #202124;
}

/* ───────────────────────────────────────────
   Titoli sezioni
─────────────────────────────────────────── */
.woocommerce-checkout h3,
.woocommerce-checkout #order_review_heading {
    font-size: 1.1rem;
    font-weight: 600;
    color: #202124;
    border-bottom: 2px solid #0099FF;
    padding-bottom: .5rem;
    margin: 2rem 0 1.25rem;
}

/* ───────────────────────────────────────────
   Campi form — label
─────────────────────────────────────────── */
.woocommerce-checkout .form-row label {
    display: block;
    font-size: .8rem;
    font-weight: 600;
    color: #5f6368;
    margin-bottom: .35rem;
    letter-spacing: .02em;
    text-transform: uppercase;
}

.woocommerce-checkout .form-row label .required {
    color: #ea4335;
    text-decoration: none;
}

/* ───────────────────────────────────────────
   Wrapper input (WooCommerce avvolge ogni
   campo in un <span class="woocommerce-input-wrapper">)
─────────────────────────────────────────── */
.woocommerce-checkout .form-row .woocommerce-input-wrapper {
    display: block;
    width: 100%;
}

/* ───────────────────────────────────────────
   Campi form — input / select nativo / textarea
─────────────────────────────────────────── */
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
    display: block;
    width: 100%;
    padding: .7rem 1rem;
    border: 1.5px solid #dadce0;
    border-radius: 8px;
    font-size: .95rem;
    font-family: inherit;
    color: #202124;
    background: #fff;
    transition: border-color .2s ease, box-shadow .2s ease;
    box-sizing: border-box;
    -webkit-appearance: none;
    appearance: none;
    line-height: 1.5;
}

.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
    outline: none;
    border-color: #0099FF;
    box-shadow: 0 0 0 3px rgba(0, 153, 255, .15);
}

/* Select nativo: freccia personalizzata */
.woocommerce-checkout .form-row select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%235f6368' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 1.4em;
    padding-right: 2.5rem;
    cursor: pointer;
}

/* ───────────────────────────────────────────
   Select2 — usato da WooCommerce per paese/regione
   e da ThemeHigh per i campi select avanzati
─────────────────────────────────────────── */
.woocommerce-checkout .select2-container {
    width: 100% !important;
    display: block;
}

.woocommerce-checkout .select2-container--default .select2-selection--single {
    display: block;
    height: auto;
    min-height: 44px;
    padding: .7rem 2.5rem .7rem 1rem;
    border: 1.5px solid #dadce0;
    border-radius: 8px;
    font-size: .95rem;
    font-family: inherit;
    background-color: #fff;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%235f6368' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 1.4em;
    transition: border-color .2s ease, box-shadow .2s ease;
    box-sizing: border-box;
    cursor: pointer;
}

.woocommerce-checkout .select2-container--default.select2-container--open .select2-selection--single,
.woocommerce-checkout .select2-container--default.select2-container--focus .select2-selection--single {
    border-color: #0099FF;
    box-shadow: 0 0 0 3px rgba(0, 153, 255, .15);
    outline: none;
}

/* Testo selezionato — posizionamento verticale corretto */
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
    display: block;
    color: #202124;
    line-height: 1.5;
    padding: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Placeholder */
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #9aa0a6;
}

/* Nascondi la freccia nativa di select2 (usiamo quella CSS) */
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
    display: none;
}

/* Dropdown select2 */
.select2-dropdown {
    border: 1.5px solid #dadce0;
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(60, 64, 67, .2);
    overflow: hidden;
    font-family: Manrope, -apple-system, sans-serif;
}

.select2-search--dropdown {
    padding: .5rem;
}

.select2-search--dropdown .select2-search__field {
    width: 100%;
    padding: .5rem .75rem;
    border: 1.5px solid #dadce0;
    border-radius: 6px;
    font-size: .9rem;
    font-family: inherit;
    box-sizing: border-box;
    outline: none;
}

.select2-search--dropdown .select2-search__field:focus {
    border-color: #0099FF;
}

.select2-results__option {
    padding: .6rem 1rem;
    font-size: .9rem;
    color: #202124;
    cursor: pointer;
}

.select2-results__option--highlighted.select2-results__option--selectable {
    background-color: #0099FF;
    color: #fff;
}

.select2-results__option[aria-selected="true"] {
    background-color: #e8f0fe;
    color: #202124;
}

/* ───────────────────────────────────────────
   Layout campi affiancati (form-row-first / last)
─────────────────────────────────────────── */
.woocommerce-checkout .col2-set {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
}

.woocommerce-billing-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 1rem;
}

.woocommerce-billing-fields__field-wrapper .form-row-wide {
    grid-column: 1 / -1;
}

.woocommerce-billing-fields__field-wrapper .form-row-first,
.woocommerce-billing-fields__field-wrapper .form-row-last {
    grid-column: span 1;
}

/* Spaziatura verticale campi */
.woocommerce-checkout .form-row {
    margin-bottom: 1rem;
}

/* ───────────────────────────────────────────
   Tabella riepilogo ordine
─────────────────────────────────────────── */
.woocommerce-checkout-review-order-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1.5rem;
    font-size: .93rem;
}

.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
    padding: .75rem 1rem;
    border-bottom: 1px solid #dadce0;
    text-align: left;
}

.woocommerce-checkout-review-order-table thead {
    background: #f8f9fa;
}

.woocommerce-checkout-review-order-table thead th {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #5f6368;
}

.woocommerce-checkout-review-order-table .order-total td,
.woocommerce-checkout-review-order-table .order-total th {
    font-weight: 700;
    font-size: 1rem;
    color: #202124;
    border-bottom: none;
}

/* ───────────────────────────────────────────
   Sezione pagamento
─────────────────────────────────────────── */
#payment {
    background: #f8f9fa;
    border: 1.5px solid #dadce0;
    border-radius: 12px;
    padding: 1.5rem;
}

#payment .payment_methods {
    list-style: none;
    margin: 0 0 1.25rem;
    padding: 0;
}

#payment .payment_methods li {
    padding: .75rem 0;
    border-bottom: 1px solid #dadce0;
}

#payment .payment_methods li:last-child {
    border-bottom: none;
}

#payment .payment_methods label {
    font-weight: 600;
    font-size: .95rem;
    color: #202124;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: .5rem;
}

#payment .payment_methods input[type="radio"] {
    accent-color: #0099FF;
    width: 1.1em;
    height: 1.1em;
    flex-shrink: 0;
}

/* Box descrizione metodo di pagamento */
.payment_box {
    margin-top: .75rem;
    padding: 1rem;
    background: #fff;
    border: 1px solid #dadce0;
    border-radius: 8px;
    font-size: .9rem;
    color: #5f6368;
}

.payment_box p {
    margin: 0 0 .75rem;
}

.payment_box label {
    display: block;
    font-size: .8rem;
    font-weight: 600;
    color: #5f6368;
    margin-bottom: .35rem;
    letter-spacing: .02em;
    text-transform: uppercase;
}

.payment_box input.wc-codice-docente,
.payment_box input[type="text"] {
    width: 100%;
    padding: .7rem 1rem;
    border: 1.5px solid #dadce0;
    border-radius: 8px;
    font-size: .95rem;
    font-family: inherit;
    color: #202124;
    background: #fff;
    transition: border-color .2s ease, box-shadow .2s ease;
    box-sizing: border-box;
}

.payment_box input.wc-codice-docente:focus,
.payment_box input[type="text"]:focus {
    outline: none;
    border-color: #0099FF;
    box-shadow: 0 0 0 3px rgba(0, 153, 255, .15);
}

/* ───────────────────────────────────────────
   Pulsante "Effettua ordine"
─────────────────────────────────────────── */
#place_order {
    display: block;
    width: 100%;
    padding: .9rem 1.5rem;
    background: #0099FF;
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
    font-family: inherit;
    border: none;
    border-radius: 26px;
    cursor: pointer;
    transition: background .2s ease, transform .1s ease, box-shadow .2s ease;
    letter-spacing: .02em;
    margin-top: 1rem;
    box-shadow: 0 1px 2px rgba(60, 64, 67, .3), 0 1px 3px rgba(60, 64, 67, .15);
}

#place_order:hover {
    background: #007acc;
    box-shadow: 0 2px 6px rgba(60, 64, 67, .3);
    transform: translateY(-1px);
}

#place_order:active {
    transform: translateY(0);
}

/* ───────────────────────────────────────────
   Notifiche e messaggi di errore
─────────────────────────────────────────── */
.woocommerce-error,
.woocommerce-message,
.woocommerce-info {
    border-radius: 8px;
    padding: 1rem 1.25rem;
    margin-bottom: 1.25rem;
    font-size: .9rem;
    list-style: none;
}

.woocommerce-error {
    background: #fce8e6;
    border-left: 4px solid #ea4335;
    color: #c5221f;
}

.woocommerce-message {
    background: #e6f4ea;
    border-left: 4px solid #34a853;
    color: #1e6e42;
}

.woocommerce-info {
    background: #e8f0fe;
    border-left: 4px solid #0099FF;
    color: #174ea6;
}

/* ───────────────────────────────────────────
   Campi con errore di validazione
─────────────────────────────────────────── */
.woocommerce-checkout .form-row.woocommerce-invalid input,
.woocommerce-checkout .form-row.woocommerce-invalid select {
    border-color: #ea4335;
    box-shadow: 0 0 0 3px rgba(234, 67, 53, .12);
}

.woocommerce-checkout .form-row.woocommerce-invalid label {
    color: #ea4335;
}

/* ───────────────────────────────────────────
   Responsive
─────────────────────────────────────────── */
@media (max-width: 600px) {
    .woocommerce-billing-fields__field-wrapper {
        grid-template-columns: 1fr;
    }

    .woocommerce-billing-fields__field-wrapper .form-row-first,
    .woocommerce-billing-fields__field-wrapper .form-row-last {
        grid-column: 1 / -1;
    }
}
