/**
 * UniCredit ePOS Online - Monthly Installment Calculator Styles
 * Theme-agnostic styles that work across all OpenCart 3 themes
 */

/* ============================================
   CSS Reset for Calculator Components
   Ensures consistent appearance across themes
   ============================================ */
.unicredit-payment-calculator {
	background: #f8f9fa !important;
	border: 2px solid #e0e0e0 !important;
	border-radius: 8px !important;
	padding: 20px !important;
	margin: 20px 0 !important;
	box-sizing: border-box !important;
	/* Force calculator to always be on a new line regardless of theme layout */
	display: block !important;
	width: 100% !important;
	clear: both !important;
	float: none !important;
	flex-basis: 100% !important;
	/* Force new line in flexbox containers */
	flex-shrink: 0 !important;
	min-width: 100% !important;
	/* Break before the element in flexbox */
	break-before: always !important;
	page-break-before: always !important;
}
/* Force parent containers to wrap when containing the calculator */
.e-atc-qty-button-holder:has(.unicredit-payment-calculator),
form.cart:has(.unicredit-payment-calculator),
.woocommerce-variation-add-to-cart:has(.unicredit-payment-calculator),
.single_add_to_cart_button:has(~ .unicredit-payment-calculator) {
	flex-wrap: wrap !important;
}
/* Use ::before pseudo-element to force line break in flexbox */
.unicredit-payment-calculator::before {
	content: "" !important;
	flex-basis: 100% !important;
	width: 100% !important;
	height: 0 !important;
	order: -1 !important;
}
.unicredit-calculator-header {
	display: flex !important;
	align-items: center !important;
	gap: 15px !important;
	margin-bottom: 0 !important;
}
.unicredit-calculator-logo {
	height: 100% !important;
	width: auto !important;
	max-height: 40px !important;
}
.unicredit-calculator-header-text {
	margin: 0 !important;
	font-size: 18px !important;
	font-weight: 600 !important;
	color: #333 !important;
	line-height: 1.4 !important;
}
.unicredit-calculator-content {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 15px !important;
	align-items: center !important;
}
.unicredit-calculator-content label {
	display: block !important;
	margin-bottom: 8px !important;
	font-weight: 500 !important;
	color: #555 !important;
	font-size: 14px !important;
}
.unicredit-months-select {
	flex: 1 1 auto !important;
	min-width: 200px !important;
	padding: 10px !important;
	padding-right: 35px !important; /* Extra space for dropdown arrow */
	font-size: 16px !important;
	border: 1px solid #ccc !important;
	border-radius: 4px !important;
	background: #fff !important;
	height: 44px !important;
	box-sizing: border-box !important;
	color: #333 !important;
	line-height: 1.4 !important;

	/* Remove native arrows */
	appearance: none !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;

	/* Add custom SVG arrow */
	background-image: url("data:image/svg+xml,%3Csvg fill='%23000000' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30.727 30.727'%3E%3Cpath d='M29.994,10.183L15.363,24.812L0.733,10.184c-0.977-0.978-0.977-2.561,0-3.536c0.977-0.977,2.559-0.976,3.536,0l11.095,11.093L26.461,6.647c0.977-0.976,2.559-0.976,3.535,0C30.971,7.624,30.971,9.206,29.994,10.183z'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-size: 12px auto !important;
	background-position: right 12px center !important;
}
.unicredit-monthly-payment {
	display: flex !important;
	flex: 1 1 auto !important;
	min-width: 200px !important;
	flex-direction: row !important;
	justify-content: space-between !important;
	align-items: center !important;
	gap: 10px !important;
	padding: 10px 15px !important;
	background: #fff !important;
	border-radius: 4px !important;
	border: 1px solid #e0e0e0 !important;
	height: 44px !important;
	box-sizing: border-box !important;
}
.unicredit-payment-label {
	font-weight: 500 !important;
	color: #555 !important;
	font-size: 14px !important;
}
.unicredit-payment-amount {
	font-size: 24px !important;
	font-weight: 700 !important;
	color: #e2001a !important;
	line-height: 1 !important;
}
.unicredit-calculator-simple {
	padding: 5px 10px !important;
}
.unicredit-calculator-simple .unicredit-calculator-content {
	text-align: center !important;
}
/* Simple calculator: place starting payment in header next to logo */
.unicredit-calculator-simple .unicredit-calculator-header {
	justify-content: center !important;
}
.unicredit-calculator-simple .unicredit-starting-payment {
	font-size: 14px !important;
	color: #555 !important;
	margin-left: auto !important;
	line-height: 1.4 !important;
}
.unicredit-calculator-simple .unicredit-payment-amount {
	display: inline !important;
	font-size: 20px !important;
}
.unicredit-calculator-clickable {
	cursor: pointer !important;
	transition: transform 0.2s, box-shadow 0.2s !important;
}
.unicredit-calculator-clickable:hover {
	transform: translateY(-2px) !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}
.unicredit-modal {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	width: 100% !important;
	height: 100% !important;
	z-index: 999999 !important;
	display: none;
}
.unicredit-modal-overlay {
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	width: 100% !important;
	height: 100% !important;
	background: rgba(0, 0, 0, 0.7) !important;
}
.unicredit-modal-content {
	position: relative !important;
	background: #fff !important;
	max-width: 80vw !important;
	margin: 50px auto !important;
	padding: 25px !important;
	border-radius: 8px !important;
	box-shadow: 0 5px 20px rgba(0, 0, 0, 0.3) !important;
	z-index: 1000000 !important;
	overflow: visible !important;
	box-sizing: border-box !important;
}
@media (min-width: 768px) {
	.unicredit-modal-content {
		max-width: 600px !important;
	}
}
.unicredit-modal-close {
	position: absolute !important;
	top: 15px !important;
	right: 15px !important;
	font-size: 28px !important;
	font-weight: bold !important;
	color: #aaa !important;
	cursor: pointer !important;
	line-height: 20px !important;
	transition: color 0.2s !important;
	background: none !important;
	border: none !important;
	padding: 0 !important;
}
.unicredit-modal-close:hover {
	color: #000 !important;
}
.unicredit-modal-calculator {
	background: #f8f9fa !important;
	border: 2px solid #e0e0e0 !important;
	border-radius: 8px !important;
	padding: 20px !important;
	margin: 5px !important;
	overflow: visible !important;
	box-sizing: border-box !important;
}

/* ============================================
   Responsive Styles - 1150px breakpoint
   ============================================ */
@media (max-width: 1150px) {
    .unicredit-calculator-content {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 15px !important;
        flex-wrap: wrap !important;
    }

    .unicredit-months-select {
        width: 100% !important;
        max-width: none !important;
        flex: none !important;
    }

    .unicredit-monthly-payment {
        width: 100% !important;
        flex: none !important;
        flex-direction: row !important;
        justify-content: space-between !important;
    }

    .unicredit-modal {
        width: 100% !important;
    }
}

/* ============================================
   Responsive Styles - 768px breakpoint
   ============================================ */
@media (max-width: 768px) {
    .unicredit-payment-calculator {
        margin: 10px 0 !important;
    }

    .unicredit-calculator-full {
        padding: 15px !important;
    }

    .unicredit-calculator-full .unicredit-calculator-header {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 10px !important;
    }

    .unicredit-payment-amount {
        font-size: 14px !important;
    }

    .unicredit-simple-content {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 8px !important;
    }

    .unicredit-simple-arrow {
        display: none !important;
    }

	.unicredit-months-select {
		font-size: 14px !important;
	}
}

/* ============================================
   OpenCart Product Page Specific Styles
   ============================================ */
#product .unicredit-payment-calculator,
.product-info .unicredit-payment-calculator,
#content .unicredit-payment-calculator {
    margin: 15px 0 !important;
    max-width: 100% !important;
}

/* ============================================
   OpenCart Cart Page Specific Styles
   ============================================ */
.unicredit-cart-calculator {
    margin: 20px 0 !important;
    clear: both !important;
}

.unicredit-cart-calculator .unicredit-payment-calculator {
    max-width: 100% !important;
}

/* Cart Full Calculator - Compact Layout */
.unicredit-cart-calculator .unicredit-calculator-full .unicredit-calculator-header {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 15px !important;
}

/* ============================================
   OpenCart Checkout Page Specific Styles
   ============================================ */
#collapse-payment-method .unicredit-payment-calculator,
.payment-method .unicredit-payment-calculator {
    margin: 10px 0 !important;
}

/* ============================================
   Monthly Payment Info in Title
   ============================================ */
.unicredit-monthly-payment-info {
    color: #555 !important;
    font-weight: normal !important;
    font-size: 14px !important;
    margin-left: 10px !important;
}

.unicredit-monthly-payment-info strong {
    color: #e2001a !important;
    font-weight: 700 !important;
}

/* Logo positioning in payment method title */
.unicredit-logo-before-payment-info {
    vertical-align: middle !important;
    margin: 0 5px !important;
    max-height: 24px !important;
    width: auto !important;
}

.unicredit-payment-logo {
    max-height: 48px !important;
    width: auto !important;
    height: auto !important;
    vertical-align: middle !important;
    display: inline-block !important;
}

/* ============================================
   Theme Override Resets
   Ensures calculator looks consistent
   ============================================ */

/* Reset any theme button styles on our elements */
.unicredit-payment-calculator button,
.unicredit-payment-calculator select {
    font-family: inherit !important;
}

/* Reset any theme link styles */
.unicredit-payment-calculator a {
    text-decoration: none !important;
}

/* Reset any theme list styles */
.unicredit-payment-calculator ul,
.unicredit-payment-calculator ol {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Ensure images don't get theme max-width overrides */
.unicredit-payment-calculator img {
    max-width: none !important;
    height: auto !important;
}

/* ============================================
   Print Styles
   ============================================ */
@media print {
    .unicredit-payment-calculator {
        border: 1px solid #000 !important;
        box-shadow: none !important;
        background: #fff !important;
    }

    .unicredit-modal-overlay {
        display: none !important;
    }

    .unicredit-calculator-simple {
        display: none !important;
    }
}
