/**
 * IT Shop Checkout - Complete Styling
 */

:root {
    --itsc-primary: #FE913C;
    --itsc-secondary: #FF6A00;
    --itsc-text: #1a1a1a;
    --itsc-radius: 12px;
    --itsc-font: 'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;
    --itsc-gray: #666;
    --itsc-light: #f8f8f8;
    --itsc-border: #e5e5e5;
    --itsc-white: #fff;
}

/* ==========================================================================
   HIDE ALL STANDARD WOOCOMMERCE ELEMENTS
   ========================================================================== */

/* Cart - hide shipping */
.wp-block-woocommerce-cart-order-summary-shipping-block,
.wc-block-components-totals-shipping,
.wc-block-components-totals-item--shipping,
.wc-block-components-shipping-calculator,
.wc-block-components-shipping-address,
.cart_totals .woocommerce-shipping-totals,
.cart_totals .shipping,
#shipping_method { 
    display: none !important; 
}

/* Hide standard shipping in checkout order review */
.woocommerce-checkout-review-order-table .shipping,
.woocommerce-checkout-review-order-table .woocommerce-shipping-totals,
.woocommerce-checkout-review-order-table tr.shipping th,
.woocommerce-checkout-review-order-table tr.shipping td,
.order-total .woocommerce-Price-amount + .woocommerce-Price-currencySymbol + .shipping,
.wc-block-components-order-summary .wc-block-components-totals-shipping {
    display: none !important;
}

/* Checkout - hide standard elements on step 2 */
.woocommerce-checkout .woocommerce-form-coupon-toggle,
.woocommerce-checkout .woocommerce-info:not(.itsc-notice),
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout #ship-to-different-address { 
    display: none !important; 
}

/* Hide billing, payment and order review on step 2 (when map is shown) */
body:not(.itsc-step-3) .woocommerce-checkout #customer_details,
body:not(.itsc-step-3) .woocommerce-checkout .woocommerce-checkout-review-order-table,
body:not(.itsc-step-3) .woocommerce-checkout .woocommerce-checkout-payment,
body:not(.itsc-step-3) .woocommerce-checkout #order_review,
body:not(.itsc-step-3) .woocommerce-checkout .woocommerce-checkout-review-order,
body:not(.itsc-step-3) .woocommerce-checkout h3#order_review_heading {
    display: none !important;
}

/* Show on step 3 */
body.itsc-step-3 #customer_details,
body.itsc-step-3 .woocommerce-checkout-review-order-table,
body.itsc-step-3 .woocommerce-checkout-payment,
body.itsc-step-3 #order_review {
    display: block !important;
}

/* ==========================================================================
   SHIPPING SELECTION (Cart Page)
   ========================================================================== */

.itsc-shipping-selection-wrapper {
    background: var(--itsc-white);
    padding: 20px;
    border-radius: var(--itsc-radius);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    margin: 20px 0;
}

.itsc-shipping-title {
    font: 600 16px var(--itsc-font);
    margin: 0 0 16px;
    color: var(--itsc-text);
}

.itsc-shipping-options {
    display: flex;
    gap: 12px;
}

.itsc-shipping-option {
    flex: 1;
    cursor: pointer;
    margin: 0;
}

.itsc-shipping-option input { display: none; }

.itsc-option-content {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    border: 2px solid var(--itsc-border);
    border-radius: var(--itsc-radius);
    transition: all 0.2s;
    background: var(--itsc-white);
}

.itsc-shipping-option:hover .itsc-option-content {
    border-color: var(--itsc-primary);
}

.itsc-shipping-option.selected .itsc-option-content,
.itsc-shipping-option input:checked + .itsc-option-content {
    border-color: var(--itsc-primary);
    background: rgba(254,145,60,0.04);
}

.itsc-option-icon {
    width: 48px;
    height: 48px;
    min-width: 48px;
    min-height: 48px;
    border-radius: 50%;
    background: var(--itsc-light);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--itsc-gray);
    flex-shrink: 0;
}

.itsc-shipping-option.selected .itsc-option-icon,
.itsc-shipping-option input:checked + .itsc-option-content .itsc-option-icon {
    background: linear-gradient(135deg, var(--itsc-secondary), var(--itsc-primary));
    color: var(--itsc-white);
}

.itsc-option-icon svg { 
    width: 22px; 
    height: 22px;
    flex-shrink: 0;
}

.itsc-option-text { flex: 1; }

.itsc-option-title {
    font: 600 15px var(--itsc-font);
    color: var(--itsc-text);
    display: block;
}

.itsc-option-price {
    font: 400 13px var(--itsc-font);
    color: var(--itsc-gray);
    display: block;
    margin-top: 2px;
}

.itsc-shipping-option.selected .itsc-option-price {
    color: var(--itsc-primary);
    font-weight: 600;
}

/* ==========================================================================
   CHECKOUT STEPS INDICATOR
   ========================================================================== */

.itsc-checkout-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin: 0 0 24px;
    padding: 16px 20px;
    background: var(--itsc-white);
    border-radius: var(--itsc-radius);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.itsc-step {
    display: flex;
    align-items: center;
    gap: 8px;
    opacity: 0.4;
    transition: opacity 0.2s;
}

.itsc-step.active, .itsc-step.completed { opacity: 1; }

.itsc-step-number {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--itsc-light);
    color: var(--itsc-gray);
    display: flex;
    align-items: center;
    justify-content: center;
    font: 700 13px var(--itsc-font);
    transition: all 0.2s;
}

.itsc-step.active .itsc-step-number {
    background: linear-gradient(135deg, var(--itsc-secondary), var(--itsc-primary));
    color: var(--itsc-white);
}

.itsc-step.completed .itsc-step-number {
    background: var(--itsc-primary);
    color: var(--itsc-white);
}

.itsc-step-title {
    font: 500 13px var(--itsc-font);
    color: var(--itsc-text);
}

.itsc-step-line {
    width: 40px;
    height: 2px;
    background: var(--itsc-border);
    margin: 0 8px;
}

.itsc-step-line.completed {
    background: var(--itsc-primary);
}

/* ==========================================================================
   MAP CONTAINER (Step 2)
   ========================================================================== */

.itsc-map-step {
    margin-bottom: 24px;
}

.itsc-map-container {
    display: grid;
    grid-template-columns: 340px 1fr;
    background: var(--itsc-white);
    border-radius: var(--itsc-radius);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    overflow: hidden;
    min-height: 450px;
}

.itsc-map-sidebar {
    padding: 24px;
    background: var(--itsc-white);
    border-right: 1px solid var(--itsc-border);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    max-height: 450px;
}

.itsc-map-sidebar h3 {
    font: 600 17px var(--itsc-font);
    margin: 0 0 20px;
    color: var(--itsc-text);
    padding-bottom: 12px;
    border-bottom: 1px solid var(--itsc-border);
}

.itsc-map-wrapper {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
}

#itsc-map {
    width: 100%;
    height: 100%;
    min-height: 450px;
    flex: 1;
}

/* Fix Leaflet z-index */
.leaflet-pane, .leaflet-top, .leaflet-bottom { z-index: 1 !important; }
.leaflet-control { z-index: 2 !important; }
.leaflet-popup-pane { z-index: 5 !important; }

/* Leaflet zoom controls - remove underlines */
.leaflet-control-zoom a,
.leaflet-control-zoom-in,
.leaflet-control-zoom-out {
    text-decoration: none !important;
    border-bottom: none !important;
}

.leaflet-control-zoom a:hover,
.leaflet-control-zoom a:focus {
    text-decoration: none !important;
}

/* Hide Leaflet attribution */
.leaflet-control-attribution {
    display: none !important;
}

.itsc-map-instruction {
    position: absolute;
    bottom: 16px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--itsc-white);
    padding: 10px 20px;
    border-radius: 24px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.15);
    font: 500 13px var(--itsc-font);
    display: flex;
    align-items: center;
    gap: 8px;
    z-index: 10;
}

.itsc-map-instruction svg {
    color: var(--itsc-primary);
    width: 18px;
    height: 18px;
}

/* ==========================================================================
   PICKUP LIST
   ========================================================================== */

.itsc-pickup-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
    overflow-y: auto;
}

.itsc-pickup-item {
    display: grid;
    grid-template-columns: 44px 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 14px;
    border: 2px solid var(--itsc-border);
    border-radius: var(--itsc-radius);
    cursor: pointer;
    transition: all 0.2s;
}

.itsc-pickup-item:hover {
    border-color: var(--itsc-primary);
}

.itsc-pickup-item.selected {
    border-color: var(--itsc-primary);
    background: rgba(254,145,60,0.04);
}

.itsc-pickup-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--itsc-secondary), var(--itsc-primary));
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--itsc-white);
}

.itsc-pickup-icon svg { width: 20px; height: 20px; }

.itsc-pickup-info {
    min-width: 0;
    overflow: hidden;
}

.itsc-pickup-info strong {
    font: 600 14px var(--itsc-font);
    color: var(--itsc-text);
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.itsc-pickup-address {
    font: 400 12px var(--itsc-font);
    color: var(--itsc-gray);
    display: block;
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.itsc-pickup-hours {
    font: 600 11px var(--itsc-font);
    color: var(--itsc-primary);
    display: block;
    margin-top: 4px;
}

.itsc-select-pickup {
    background: linear-gradient(135deg, var(--itsc-secondary), var(--itsc-primary)) !important;
    color: var(--itsc-white) !important;
    border: none !important;
    padding: 10px 16px !important;
    border-radius: var(--itsc-radius) !important;
    font: 600 12px var(--itsc-font) !important;
    cursor: pointer;
    white-space: nowrap;
}

.itsc-select-pickup:hover {
    opacity: 0.9;
}

/* ==========================================================================
   ADDRESS FORM (Delivery)
   ========================================================================== */

.itsc-address-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
    flex: 1;
}

.itsc-form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.itsc-form-group label {
    font: 600 13px var(--itsc-font);
    color: var(--itsc-text);
}

.itsc-form-group input,
.itsc-form-group select,
.itsc-form-group textarea {
    padding: 12px 14px;
    border: 2px solid var(--itsc-border);
    border-radius: var(--itsc-radius);
    font: 400 14px var(--itsc-font);
    width: 100%;
    box-sizing: border-box;
    transition: border-color 0.2s;
}

.itsc-form-group input:focus,
.itsc-form-group select:focus,
.itsc-form-group textarea:focus {
    outline: none;
    border-color: var(--itsc-primary);
}

.itsc-help-text {
    font: 400 11px var(--itsc-font);
    color: var(--itsc-gray);
}

.itsc-address-input-wrapper {
    position: relative;
}

.itsc-address-suggestions {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--itsc-white);
    border: 2px solid var(--itsc-primary);
    border-top: none;
    border-radius: 0 0 var(--itsc-radius) var(--itsc-radius);
    max-height: 180px;
    overflow-y: auto;
    z-index: 100;
    display: none;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.itsc-address-suggestions.show { display: block; }

.itsc-suggestion-item {
    padding: 12px 14px;
    font: 400 13px var(--itsc-font);
    cursor: pointer;
    border-bottom: 1px solid var(--itsc-border);
}

.itsc-suggestion-item:last-child { border-bottom: none; }

.itsc-suggestion-item:hover {
    background: rgba(254,145,60,0.05);
}

.itsc-selected-address {
    padding: 14px;
    background: rgba(254,145,60,0.05);
    border: 2px solid var(--itsc-primary);
    border-radius: var(--itsc-radius);
    font: 400 13px var(--itsc-font);
    margin-bottom: 16px;
}

.itsc-selected-address strong {
    display: block;
    font: 600 11px var(--itsc-font);
    color: var(--itsc-gray);
    text-transform: uppercase;
    margin-bottom: 6px;
}

/* ==========================================================================
   NAVIGATION BUTTONS
   ========================================================================== */

.itsc-map-actions {
    margin-top: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

.itsc-back-btn {
    background: var(--itsc-white) !important;
    color: var(--itsc-text) !important;
    border: 2px solid var(--itsc-border) !important;
    padding: 12px 24px !important;
    border-radius: var(--itsc-radius) !important;
    font: 600 14px var(--itsc-font) !important;
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: all 0.2s;
}

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

/* Confirm address button in actions row */
.itsc-map-actions .itsc-confirm-address {
    background: linear-gradient(135deg, var(--itsc-secondary), var(--itsc-primary)) !important;
    color: var(--itsc-white) !important;
    border: none !important;
    padding: 14px 28px !important;
    border-radius: var(--itsc-radius) !important;
    font: 600 14px var(--itsc-font) !important;
    cursor: pointer;
    transition: all 0.2s;
}

.itsc-map-actions .itsc-confirm-address:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.itsc-map-actions .itsc-confirm-address:not(:disabled):hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

/* ==========================================================================
   STEP 3 - CHECKOUT SUMMARY
   ========================================================================== */

.itsc-checkout-summary {
    background: var(--itsc-white);
    padding: 20px;
    border-radius: var(--itsc-radius);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    margin-bottom: 24px;
}

.itsc-checkout-summary h3 {
    font: 600 16px var(--itsc-font);
    margin: 0 0 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--itsc-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.itsc-summary-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 10px 0;
    font: 400 14px var(--itsc-font);
    border-bottom: 1px solid var(--itsc-light);
}

.itsc-summary-row:last-child { border-bottom: none; }

.itsc-summary-row strong {
    color: var(--itsc-text);
    font-weight: 600;
    flex-shrink: 0;
}

.itsc-summary-row span {
    color: var(--itsc-gray);
    text-align: right;
    margin-left: 16px;
}

.itsc-edit-step-btn {
    background: var(--itsc-light) !important;
    color: var(--itsc-gray) !important;
    border: none !important;
    padding: 8px 14px !important;
    border-radius: var(--itsc-radius) !important;
    font: 500 12px var(--itsc-font) !important;
    cursor: pointer;
    text-decoration: none !important;
    transition: all 0.2s;
}

.itsc-edit-step-btn:hover {
    color: var(--itsc-primary) !important;
    background: rgba(254,145,60,0.1) !important;
}

/* ==========================================================================
   WOOCOMMERCE CHECKOUT FORM STYLING (Step 3)
   ========================================================================== */

body.itsc-step-3 .woocommerce-checkout {
    font-family: var(--itsc-font);
}

body.itsc-step-3 #customer_details {
    background: var(--itsc-white);
    padding: 24px;
    border-radius: var(--itsc-radius);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    margin-bottom: 24px;
}

body.itsc-step-3 .woocommerce-billing-fields h3,
body.itsc-step-3 #customer_details h3 {
    font: 600 16px var(--itsc-font);
    margin: 0 0 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--itsc-border);
}

body.itsc-step-3 .woocommerce-billing-fields__field-wrapper .form-row {
    margin-bottom: 16px;
}

body.itsc-step-3 .woocommerce-billing-fields__field-wrapper label,
body.itsc-step-3 .woocommerce-checkout label {
    font: 600 13px var(--itsc-font);
    color: var(--itsc-text);
    margin-bottom: 6px;
    display: block;
}

/* ALL form inputs */
body.itsc-step-3 .woocommerce-checkout input[type="text"],
body.itsc-step-3 .woocommerce-checkout input[type="email"],
body.itsc-step-3 .woocommerce-checkout input[type="tel"],
body.itsc-step-3 .woocommerce-checkout input[type="number"],
body.itsc-step-3 .woocommerce-checkout input[type="password"],
body.itsc-step-3 .woocommerce-checkout select,
body.itsc-step-3 .woocommerce-checkout textarea,
body.itsc-step-3 .woocommerce-checkout .input-text,
body.itsc-step-3 .woocommerce-checkout .select2-selection,
body.itsc-step-3 #customer_details input:not([type="checkbox"]):not([type="radio"]),
body.itsc-step-3 #customer_details select,
body.itsc-step-3 #customer_details textarea,
.woocommerce-checkout input.input-text,
.woocommerce-checkout select,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
    padding: 12px 14px !important;
    border: 2px solid var(--itsc-border) !important;
    border-radius: var(--itsc-radius) !important;
    font: 400 14px var(--itsc-font) !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: var(--itsc-white) !important;
}

/* Exclude checkboxes and radios from appearance override */
body.itsc-step-3 .woocommerce-checkout input[type="text"],
body.itsc-step-3 .woocommerce-checkout input[type="email"],
body.itsc-step-3 .woocommerce-checkout input[type="tel"],
body.itsc-step-3 .woocommerce-checkout input[type="number"],
body.itsc-step-3 .woocommerce-checkout input[type="password"],
body.itsc-step-3 .woocommerce-checkout select {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

body.itsc-step-3 .woocommerce-checkout input:focus,
body.itsc-step-3 .woocommerce-checkout select:focus,
body.itsc-step-3 .woocommerce-checkout textarea:focus,
body.itsc-step-3 #customer_details input:focus,
body.itsc-step-3 #customer_details select:focus,
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus {
    border-color: var(--itsc-primary) !important;
    outline: none !important;
    box-shadow: none !important;
}

/* Select2 dropdown styling */
body.itsc-step-3 .select2-container--default .select2-selection--single {
    border: 2px solid var(--itsc-border) !important;
    border-radius: var(--itsc-radius) !important;
    height: auto !important;
    padding: 10px 14px !important;
}

body.itsc-step-3 .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding: 0 !important;
    line-height: 1.4 !important;
    font: 400 14px var(--itsc-font) !important;
}

body.itsc-step-3 .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100% !important;
    top: 0 !important;
    right: 10px !important;
}

body.itsc-step-3 .select2-dropdown {
    border: 2px solid var(--itsc-primary) !important;
    border-radius: var(--itsc-radius) !important;
}

/* Order Review Table */
body.itsc-step-3 .woocommerce-checkout-review-order-table {
    background: var(--itsc-white);
    border-radius: var(--itsc-radius);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    margin-bottom: 24px;
    border-collapse: collapse;
    width: 100%;
}

body.itsc-step-3 .woocommerce-checkout-review-order-table th,
body.itsc-step-3 .woocommerce-checkout-review-order-table td {
    padding: 14px 16px;
    font: 400 14px var(--itsc-font);
    border-bottom: 1px solid var(--itsc-border);
    text-align: left;
}

body.itsc-step-3 .woocommerce-checkout-review-order-table .product-total,
body.itsc-step-3 .woocommerce-checkout-review-order-table td:last-child,
body.itsc-step-3 .woocommerce-checkout-review-order-table th:last-child {
    text-align: right;
    white-space: nowrap;
}

body.itsc-step-3 .woocommerce-checkout-review-order-table thead th {
    font-weight: 600;
    background: var(--itsc-light);
}

body.itsc-step-3 .order-total th,
body.itsc-step-3 .order-total td {
    font-weight: 700;
    font-size: 16px;
    color: var(--itsc-text);
}

/* Payment Methods - Fixed Layout */
body.itsc-step-3 .woocommerce-checkout-payment {
    background: var(--itsc-white);
    padding: 24px;
    border-radius: var(--itsc-radius);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    margin-bottom: 24px;
}

body.itsc-step-3 .wc_payment_methods {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 20px !important;
}

body.itsc-step-3 .wc_payment_method {
    padding: 20px;
    border: 2px solid var(--itsc-primary);
    border-radius: var(--itsc-radius);
    margin-bottom: 12px;
    background: rgba(254,145,60,0.03);
}

body.itsc-step-3 .wc_payment_method:last-child { margin-bottom: 0; }

body.itsc-step-3 .wc_payment_method > label {
    font: 600 15px var(--itsc-font) !important;
    color: var(--itsc-primary) !important;
    cursor: default !important;
    display: block !important;
    margin: 0 0 12px !important;
}

body.itsc-step-3 .wc_payment_method input[type="radio"] {
    display: none !important;
}

body.itsc-step-3 .payment_box {
    padding: 14px 16px !important;
    margin: 0 !important;
    font: 400 13px var(--itsc-font) !important;
    color: var(--itsc-gray) !important;
    background: rgba(254,145,60,0.06) !important;
    border-radius: 8px !important;
}

body.itsc-step-3 .payment_box::before {
    display: none !important;
}

body.itsc-step-3 .payment_box p {
    margin: 0 !important;
    padding: 0 !important;
}

/* Terms & Conditions and Privacy */
body.itsc-step-3 .woocommerce-terms-and-conditions-wrapper {
    margin: 20px 0;
}

body.itsc-step-3 .woocommerce-privacy-policy-text {
    font: 400 12px var(--itsc-font);
    color: var(--itsc-gray);
    margin-bottom: 16px;
}

body.itsc-step-3 .woocommerce-form__label-for-checkbox {
    display: flex !important;
    align-items: flex-start;
    gap: 10px;
    font: 400 14px var(--itsc-font);
    color: var(--itsc-text);
    cursor: pointer;
}

body.itsc-step-3 .woocommerce-form__label-for-checkbox input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    margin: 2px 0 0 0 !important;
    flex-shrink: 0;
}

body.itsc-step-3 .woocommerce-form__label-for-checkbox span {
    flex: 1;
}

/* Place Order Button */
body.itsc-step-3 #place_order {
    background: linear-gradient(135deg, var(--itsc-secondary), var(--itsc-primary)) !important;
    border: none !important;
    border-radius: var(--itsc-radius) !important;
    padding: 16px 32px !important;
    font: 600 15px var(--itsc-font) !important;
    width: 100%;
    cursor: pointer;
    transition: all 0.2s;
    color: var(--itsc-white) !important;
}

body.itsc-step-3 #place_order:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

/* Different address checkbox */
.itsc-different-address-wrapper {
    margin: 0 0 20px;
    padding: 12px 16px;
    background: var(--itsc-light);
    border-radius: var(--itsc-radius);
    display: block;
    width: fit-content;
}

.itsc-checkbox-label {
    display: flex !important;
    align-items: center;
    gap: 10px;
    font: 500 14px var(--itsc-font) !important;
    color: var(--itsc-text) !important;
    cursor: pointer;
    margin: 0 !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
}

/* Force standard checkbox appearance - override theme toggle */
#itsc_different_address,
.itsc-checkbox-label input[type="checkbox"],
.itsc-different-address-wrapper input[type="checkbox"] {
    -webkit-appearance: auto !important;
    -moz-appearance: auto !important;
    appearance: auto !important;
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    max-width: 18px !important;
    min-height: 18px !important;
    max-height: 18px !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
    cursor: pointer !important;
    position: static !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    visibility: visible !important;
    display: inline-block !important;
    vertical-align: middle !important;
    background: none !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    transform: none !important;
}

/* Hide any pseudo elements the theme might add */
#itsc_different_address::before,
#itsc_different_address::after,
.itsc-checkbox-label input[type="checkbox"]::before,
.itsc-checkbox-label input[type="checkbox"]::after {
    display: none !important;
    content: none !important;
}

/* Ensure label wrapper doesn't hide checkbox */
.itsc-checkbox-label::before,
.itsc-checkbox-label::after {
    display: none !important;
    content: none !important;
}

.itsc-checkbox-label span {
    flex-shrink: 0;
    line-height: 1.3;
}

/* Hide any extra WC input styling inside our wrapper */
.itsc-different-address-wrapper input:not([type="checkbox"]) {
    display: none !important;
}

/* Fix any WC field that might appear before our checkbox */
.woocommerce-billing-fields > .itsc-different-address-wrapper:first-child {
    margin-top: 0;
}

/* If WC adds input before checkbox, hide it */
body.itsc-step-3 .woocommerce-billing-fields > p:first-of-type input[type="text"]:not(#billing_first_name) {
    display: none !important;
}

/* ==========================================================================
   NOTICE
   ========================================================================== */

.itsc-notice {
    padding: 16px 20px;
    border-radius: var(--itsc-radius);
    margin-bottom: 20px;
    font: 400 14px var(--itsc-font);
}

.itsc-notice-warning {
    background: #fff3cd;
    border: 1px solid #ffc107;
    color: #856404;
}

.itsc-notice p {
    margin: 0 0 12px;
}

.itsc-notice p:last-child { margin-bottom: 0; }

/* ==========================================================================
   LEAFLET MARKER
   ========================================================================== */

.itsc-marker-icon {
    background: none !important;
    border: none !important;
}

.itsc-marker-icon svg {
    filter: drop-shadow(0 3px 6px rgba(0,0,0,0.3));
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 900px) {
    .itsc-map-container {
        grid-template-columns: 1fr;
        min-height: auto;
    }
    
    .itsc-map-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--itsc-border);
        order: 2;
        max-height: none;
        padding: 20px;
    }
    
    .itsc-map-wrapper {
        order: 1;
        min-height: 300px;
    }
    
    #itsc-map {
        min-height: 300px;
        height: 300px;
    }
    
    .itsc-map-actions {
        flex-direction: column-reverse;
        gap: 12px;
    }
    
    .itsc-map-actions .itsc-back-btn,
    .itsc-map-actions .itsc-confirm-address {
        width: 100%;
        text-align: center;
        justify-content: center;
    }
    
    .itsc-shipping-options {
        flex-direction: column;
    }
    
    .itsc-pickup-item {
        grid-template-columns: 40px 1fr;
    }
    
    .itsc-select-pickup {
        grid-column: 1 / -1;
        width: 100%;
        margin-top: 8px;
        text-align: center;
    }
}

@media (max-width: 600px) {
    .itsc-step-title { display: none; }
    .itsc-step-line { width: 24px; margin: 0 4px; }
    .itsc-step-number { width: 28px; height: 28px; font-size: 12px; }
    
    .itsc-checkout-steps { padding: 12px; }
    .itsc-shipping-selection-wrapper { padding: 16px; }
    .itsc-map-sidebar { padding: 16px; }
    .itsc-checkout-summary { padding: 16px; }
    
    body.itsc-step-3 #customer_details { padding: 16px; }
    body.itsc-step-3 .woocommerce-checkout-payment { padding: 16px; }
}

/* ==========================================================================
   WOOCOMMERCE BLOCKS BUTTON
   ========================================================================== */

.wc-block-cart__submit-button,
.wp-block-woocommerce-proceed-to-checkout-block a {
    background: linear-gradient(135deg, var(--itsc-secondary), var(--itsc-primary)) !important;
    border-radius: var(--itsc-radius) !important;
    font-family: var(--itsc-font) !important;
    font-weight: 600 !important;
    border: none !important;
    padding: 14px 28px !important;
    transition: all 0.2s;
}

.wc-block-cart__submit-button.itsc-loading,
.wp-block-woocommerce-proceed-to-checkout-block a.itsc-loading {
    opacity: 0.6 !important;
    cursor: wait !important;
}

.wc-block-cart__submit-button:hover,
.wp-block-woocommerce-proceed-to-checkout-block a:hover {
    opacity: 0.9 !important;
}

/* ==========================================================================
   LEAD TIME / DELIVERY ESTIMATION
   ========================================================================== */

/* Classic cart/checkout table row */
.itsc-lead-time-row th {
    font-weight: 500;
    color: var(--itsc-text);
}

.itsc-lead-time-row td {
    text-align: right;
}

.itsc-lead-time-row .itsc-lead-time-value {
    color: var(--itsc-primary);
}

/* Blocks cart/checkout */
.itsc-lead-time-block {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 0;
    border-bottom: 1px solid var(--itsc-border);
    margin-bottom: 8px;
}

.itsc-lead-time-block .itsc-lead-time-label {
    font-weight: 500;
    color: var(--itsc-text);
    font-size: 14px;
}

.itsc-lead-time-block .itsc-lead-time-value {
    color: var(--itsc-primary);
    font-size: 14px;
    text-align: right;
    max-width: 60%;
    word-wrap: break-word;
}

/* Date range styling - "od Subote, 07.02, do 10.02" */
.itsc-lead-date-range {
    display: inline;
}

.itsc-lead-date-from {
    font-weight: 700;
    font-size: 1.07em; /* Slightly larger - about 1-2px */
    color: var(--itsc-primary);
}

.itsc-lead-date-to {
    font-weight: 400;
    font-size: 1em;
    color: var(--itsc-primary);
    opacity: 0.85;
}

/* Single date styling */
.itsc-lead-date-single {
    font-weight: 500;
}

.itsc-lead-date-single strong {
    font-weight: 700;
}

/* Days format styling */
.itsc-lead-days {
    font-weight: 500;
}

.itsc-lead-days strong {
    font-weight: 700;
}

/* Unknown text */
.itsc-lead-time-unknown {
    font-weight: 500;
    font-style: italic;
    opacity: 0.9;
}

/* Note asterisk */
.itsc-lead-note {
    font-size: 0.9em;
    opacity: 0.7;
}

/* Long text handling */
.itsc-lead-time-value {
    word-break: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
}

@media (max-width: 600px) {
    .itsc-lead-time-block {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }
    
    .itsc-lead-time-block .itsc-lead-time-value {
        max-width: 100%;
        text-align: left;
    }
    
    .itsc-lead-date-range {
        display: block;
    }
    
    .itsc-lead-date-from {
        display: block;
        margin-bottom: 2px;
    }
}
