

/* Start:/local/templates/main/components/bitrix/sale.basket.basket/custom_cart/style.css?177842103618745*/
:root {
	--font-main: 'Montserrat', sans-serif;
	--color-text: #222222;
	--color-text-light: #777777;
	--color-text-muted: #999999;
	--color-bg-body: #ffffff;
	--color-bg-summary: #f4f5f7;
	--color-bg-image: #f8f9fb;
	--color-bg-control: #f0f0f0;
	--color-border: #eaeaea;
	--color-accent: #ff9d00;
	--color-accent-hover: #e68d00;
	--color-discount: #d32f2f;
	--border-radius-sm: 4px;
	--border-radius-md: 8px;
	--border-radius-lg: 12px;
}

.basket-item-amount-filed {
	padding: 0 !important;
}

body {
	font-family: var(--font-main);
	color: var(--color-text);
	background-color: var(--color-bg-body);
	margin: 0;
	padding: 0;
	-webkit-font-smoothing: antialiased;
}

.container {
	max-width: 1755px;
	margin: 0 auto;
	padding: 20px 0 0 0;
}

/* Header */
.cart-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 30px;
}

.cart-header h1 {
	font-size: 40px;
	font-weight: 800;
	letter-spacing: -3px;
	margin: 0;
	color: var(--color-text);
}

.header-actions {
	display: flex;
	gap: 24px;
	color: #d0d0d0;
}

.header-actions button {
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	color: inherit;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color 0.2s;
}

.header-actions button:hover {
	color: var(--color-text-light);
}

.cart-item.is-deleted > *:not(.item-undo) {
    display: none !important;
}

.item-undo {
    display: none;
    padding: 16px;
    background: #f8f8f8;
    border-radius: 8px;
    gap: 12px;
    flex-direction: column;
    align-items: flex-start;
}

.cart-item.is-deleted .item-undo {
    display: flex;
}

.undo-text {
    font-size: 15px;
    color: #333;
}

.undo-actions {
    display: flex;
    gap: 12px;
}

.undo-btn {
    padding: 10px 20px;
    border-radius: 8px;
    border: none;
    cursor: pointer;
    font-weight: 600;
    font-size: 14px;
    background: #eee;
    color: #333;
    transition: background 0.2s;
}

.undo-btn:hover {
    background: #e0e0e0;
}

.header-actions button svg {
	width: 28px;
	height: 28px;
}

/* Layout */
.cart-layout {
	display: grid;
	grid-template-columns: 1fr 310px;
	gap: 50px;
	align-items: start;
}

/* Items List */
.cart-items {
	display: flex;
	flex-direction: column;
}

.cart-item {
	display: flex;
	align-items: flex-start;
	min-height: 210px;
	margin-bottom: 18px;
}

.item-content {
	flex-grow: 1;
	display: flex;
	align-items: flex-start;
	min-height: 210px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--color-border);
}

.cart-item:last-child .item-content {
	border-bottom: none;
}

.item-image {
	width: 230px;
	height: 210px;
	background-color: var(--color-bg-image);
	border-radius: var(--border-radius-md);
	display: flex;
	justify-content: center;
	align-items: center;
	flex-shrink: 0;
	padding: 10px;
	box-sizing: border-box;
	margin-right: 20px;
}

.item-image img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.item-details {
	flex-grow: 1;
	padding: 0;
}

.item-details h2 {
	font-size: 22px;
	font-weight: 700;
	letter-spacing: -0.44px;
	line-height: 1.4;
	margin: 0 0 12px 0;
}

.item-specs {
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: 14px;
	color: var(--color-text-light);
	line-height: 1.6;
}

.item-specs span {
	color: var(--color-text-light);
}

.item-actions {
	display: flex;
	align-items: flex-start;
	flex-shrink: 0;
	margin: auto 0;
}

.item-controls {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 120px;
	padding-top: 13px;
	flex-shrink: 0;
}

.quantity-control {
	display: flex;
	align-items: center;
	background-color: var(--color-bg-control);
	border-radius: var(--border-radius-sm);
	overflow: hidden;
	height: 40px;
}

.quantity-control button {
	width: 36px;
	height: 100%;
	border: none;
	background: transparent;
	font-size: 20px;
	font-weight: 500;
	color: var(--color-text-muted);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding-bottom: 2px;
}

.quantity-control button:hover {
	background-color: #e4e4e4;
	color: var(--color-text);
}

.quantity-control input {
	width: 48px;
	height: 100%;
	border: none;
	background: transparent;
	text-align: center;
	font-size: 16px;
	font-weight: 600;
	color: var(--color-text);
	padding: 0;
	font-family: inherit;
}

.quantity-control input:focus {
	outline: none;
}

.unit-price {
	font-size: 12px;
	color: var(--color-text-muted);
	text-align: center;
	margin-top: 15px;
	line-height: 1.4;
}

.layout ul li {
	paddind-left: 0 !important;
}

.item-price {
	text-align: left;
	padding-top: 10px;
	flex-shrink: 0;
	padding-right: 55px;
	padding-left: 55px;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
}

.current-price {
	letter-spacing: -0.5px;
	font-size: 22px;
	font-weight: 800;
	margin-top: 10px;
	white-space: nowrap;
}

.item-price:has(.old-price-wrap) .current-price {
	color: var(--color-discount);
}

.old-price-wrap {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 8px;
	margin-top: 6px;
}

.old-price {
	font-size: 14px;
	letter-spacing: -0.5px;
	color: var(--color-text-muted);
	text-decoration: line-through;
	font-weight: 600;
}

.discount-badge {
	background-color: var(--color-discount);
	color: #fff;
	font-size: 11px;
	font-weight: 800;
	padding: 3px 5px;
	border-radius: 3px;
}

.remove-btn {
	background: transparent;
	border: none;
	color: #ccc;
	cursor: pointer;
	padding: 0;
	display: flex;
	align-items: flex-start;
	transition: color 0.2s;
	margin-top: 4px;
}

.remove-btn svg {
	width: 48px;
	height: 48px;
}

.remove-btn:hover {
	color: var(--color-discount);
}

/* Undo Delete Styles */
.item-undo {
	display: none;
}

.cart-item.is-deleted {
	display: block !important;
	min-height: auto !important;
	margin-bottom: 18px !important;
	border: none !important;
	padding: 0 !important;
}

.cart-item.is-deleted>*:not(.item-undo) {
	display: none !important;
}

.cart-item.is-deleted .item-undo {
	display: flex;
	background-color: #f4f5f7;
	padding: 20px 24px;
	flex-direction: column;
	gap: 16px;
}

.undo-text {
	font-size: 16px;
	color: #777;
	font-weight: 500;
	line-height: 1.4;
}

.undo-text strong {
	color: var(--color-text);
	font-weight: 700;
}

.undo-actions {
	display: flex;
	gap: 12px;
}

.undo-btn {
	background-color: #e8e9eb;
	border: none;
	padding: 10px 24px;
	border-radius: var(--border-radius-sm);
	font-weight: 700;
	font-size: 14px;
	color: #666;
	cursor: pointer;
	font-family: inherit;
	transition: background-color 0.2s;
}

.undo-btn:hover {
	background-color: #ddd;
}

@media (max-width: 600px) {
	.cart-item.is-deleted .item-undo {
		padding: 16px;
		gap: 12px;
	}

	.undo-text {
		font-size: 14px;
	}

	.undo-btn {
		padding: 8px 16px;
		font-size: 13px;
		flex: 1;
		text-align: center;
	}
}

.more-details {
	display: none;
}

/* Summary Panel */
.cart-summary {
	background-color: var(--color-bg-summary);
	border-radius: var(--border-radius-lg);
	padding: 28px;
	position: sticky;
	top: 40px;
}

.cart-summary h2 {
	font-size: 22px;
	letter-spacing: -0.3px;
	font-weight: 800;
	margin: 0 0 17px 0;
}

.cart-header,
.cart-header .header-actions,
.cart-header .header-actions button,
.cart-header svg {
    position: relative;
    z-index: 1 !important; /* Ставим минимальный слой */
}

.summary-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 6px;
	font-size: 16px;
	color: var(--color-text);
	font-weight: 500;
}

.summary-row .value {
	font-weight: 700;
}

.summary-row.discount-row .label,
.summary-row.discount-row .value {
	color: var(--color-discount);
	font-weight: 700;
}

.summary-total {
	display: grid;
	margin-top: 12px;
	margin-bottom: 16px;
}

.summary-total .total-label {
	font-size: 14px;
	font-weight: 800;
	margin-bottom: 4px;
}

.summary-total .total-value {
	font-size: 28px;
	font-weight: 800;
	letter-spacing: -1px;
}

.checkout-form {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.header-actions button svg {
    width: 30px;
    height: 30px;
}

.checkout-form input[type="text"],
.checkout-form input[type="tel"] {
	width: 100%;
	box-sizing: border-box;
	padding: 12px 20px;
	border: 1px solid #fff;
	border-radius: var(--border-radius-sm);
	background-color: #fff;
	font-family: inherit;
	font-size: 15px;
	color: var(--color-text);
	outline: none;
	transition: border-color 0.2s;
}

.checkout-form input::placeholder {
	color: #b0b0b0;
	font-weight: 500;
}

.checkout-form input:focus {
	border-color: var(--color-accent);
}

.submit-btn {
	background-color: var(--color-accent);
	color: #fff;
	border: none;
	padding: 12px;
	border-radius: var(--border-radius-sm);
	font-size: 18px;
	font-weight: 700;
	cursor: pointer;
	transition: background-color 0.2s;
}

.submit-btn:hover {
	background-color: var(--color-accent-hover);
}

.basket-item-amount-filed {
	min-width: 20px;
}

.agreement {
	display: flex;
	align-items: flex-start;
	margin-top: 4px;
	cursor: pointer;
}

.agreement input {
	margin-top: 2px;
	cursor: pointer;
	accent-color: var(--color-accent);
	flex-shrink: 0;
	width: 16px;
	height: 16px;
}

.agreement .text {
	font-size: 12px;
	line-height: 1.4;
	color: var(--color-text-light);
	font-weight: 500;
}

.agreement .text a {
	color: inherit;
	text-decoration: underline;
}

.agreement .text a:hover {
	color: var(--color-text);
}

/* SVG styles */
svg {
	display: block;
}

/* Responsive tweaks */
/* Clamping for 1200px - 1920px */
@media (min-width: 1200px) and (max-width: 1919px) {
	.container {
		max-width: clamp(964px, 88.28vw + 60px, 1755px);
		padding: clamp(20px, -1.12vw + 41.4px, 30px) 0;
	}

	.cart-header {
		margin-bottom: clamp(20px, 1.12vw + 8.6px, 30px);
	}

	.cart-header h1 {
		font-size: clamp(32px, 0.89vw + 22.9px, 40px);
		letter-spacing: clamp(-3px, -0.15vw, -1.6px);
	}

	.cart-layout {
		grid-template-columns: 1fr clamp(270px, 4.46vw + 224.3px, 310px);
		gap: clamp(18px, 3.57vw - 18.6px, 50px);
	}

	.cart-item {
		min-height: clamp(160px, 5.58vw + 102.8px, 210px);
		margin-bottom: clamp(5px, 1.45vw - 9.8px, 18px);
	}

	.item-content {
		min-height: clamp(150px, 3.91vw + 110px, 185px);
		padding-bottom: clamp(10px, 1.12vw + 8.6px, 20px);
	}

	.item-image {
		width: clamp(170px, 6.7vw + 101.4px, 230px);
		height: clamp(170px, 4.46vw + 124.3px, 210px);
		margin-right: clamp(16px, 0.45vw + 11.4px, 20px);
		padding: clamp(8px, 0.22vw + 5.7px, 10px);
	}

	.item-details h2 {
		font-size: clamp(16px, 0.67vw + 9.1px, 22px);
		letter-spacing: clamp(-1px, 0.06vw - 1.15px, -0.44px);
		margin-bottom: clamp(8px, 0.45vw + 3.4px, 12px);
	}

	.item-specs {
		font-size: clamp(13px, 0.11vw + 11.9px, 14px);
	}

	.item-controls {
		width: clamp(64px, 6.25vw, 120px);
		padding-top: clamp(6.9px, 0.67vw, 13px);
	}

	.quantity-control {
		height: clamp(36px, 0.45vw + 31.4px, 40px);
	}

	.quantity-control button {
		width: clamp(32px, 0.45vw + 27.4px, 36px);
		font-size: clamp(16px, 0.45vw + 11.4px, 20px);
	}

	.quantity-control input {
		width: clamp(36px, 1.34vw + 22.3px, 48px);
		font-size: clamp(14px, 0.22vw + 11.7px, 16px);
	}

	.unit-price {
		font-size: clamp(11px, 0.11vw + 9.9px, 12px);
		margin-top: clamp(6px, 1.01vw - 4.3px, 15px);
	}

	.item-price {
		padding-top: clamp(5.3px, 0.52vw, 10px);
		padding-right: clamp(29.3px, 2.86vw, 55px);
		padding-left: clamp(29.3px, 2.86vw, 55px);
	}

	.current-price {
		font-size: clamp(22px, 0vw + 22px, 22px);
		margin-top: clamp(5.3px, 0.52vw, 10px);
	}

	.old-price-wrap {
		gap: clamp(6px, 0.22vw + 3.7px, 8px);
		margin-top: clamp(6px, 0vw + 6px, 6px);
	}

	.old-price {
		font-size: clamp(14px, 0vw + 14px, 14px);
	}

	.discount-badge {
		font-size: clamp(11px, 0vw + 11px, 11px);
		padding: clamp(2.6px, 0.26vw, 5px);
	}

	.remove-btn svg {
		width: clamp(36px, 1.34vw + 22.3px, 48px);
		height: clamp(36px, 1.34vw + 22.3px, 48px);
	}

	.cart-summary {
		padding: clamp(24px, 0.45vw + 19.4px, 28px);
		top: clamp(21.3px, 2.08vw, 40px);
	}

	.cart-summary h2 {
		font-size: clamp(20px, 0.22vw + 17.7px, 22px);
		margin-bottom: clamp(12px, 0.56vw + 6.3px, 17px);
	}

	.summary-row {
		font-size: clamp(15px, 0.11vw + 13.9px, 16px);
		margin-bottom: clamp(6px, 0vw + 6px, 6px);
	}

	.summary-total {
		margin-top: clamp(6.4px, 0.62vw, 12px);
		margin-bottom: clamp(16px, 0vw + 16px, 16px);
	}

	.summary-total .total-label {
		font-size: clamp(9px, 2.2vw, 18px);
		margin-bottom: clamp(2.1px, 0.2vw, 4px);
	}

	.summary-total .total-value {
		font-size: clamp(28px, -0.22vw + 32.3px, 30px);
	}

	.checkout-form {
		gap: clamp(8px, 0vw + 8px, 8px);
	}

	.checkout-form input[type="text"],
	.checkout-form input[type="tel"] {
		padding: clamp(12px, 0.22vw + 9.7px, 14px) clamp(16px, 0.45vw + 11.4px, 20px);
		font-size: clamp(15px, 0vw + 15px, 15px);
	}

	.submit-btn {
		padding: clamp(12px, 0.45vw + 7.4px, 16px);
		font-size: clamp(18px, 0vw + 18px, 18px);
	}

	.agreement .text {
		font-size: clamp(12px, 0vw + 12px, 12px);
	}

	.agreement input {
		width: clamp(16px, 0vw + 16px, 16px);
		height: clamp(16px, 0vw + 16px, 16px);
	}
}



@media (max-width: 1200px) {
	.container {
		padding: clamp(17.6px, 2.93vw, 30px);
	}

	.cart-header {
		margin-bottom: 12px;
	}

	.cart-layout {
		grid-template-columns: 1fr clamp(158px, 26.37vw, 270px);
		gap: clamp(10.5px, 1.76vw, 18px);
	}

	.cart-header h1 {
		font-size: 2.2rem !important;
	}

	.cart-summary {
		padding: clamp(10px, 2vw, 24px) clamp(10px, 2.5vw, 28px);
	}

	.cart-summary h2 {
		margin-bottom: clamp(7px, 1.27vw, 12px) !important;
        font-size: clamp(12px, 2.4vw, 24px) !important;
        letter-spacing: -1.8px;
	}

	.current-price {
		font-size: clamp(12.9px, 2.15vw, 22px);
		letter-spacing: clamp(-0.29px, -0.05vw, -0.5px);
		margin-top: 10px;
	}

	.old-price-wrap {
		justify-content: flex-end;
		margin-top: clamp(2px, 0.5vw, 6px);
		gap: clamp(4px, 0.8vw, 8px);
	}

	.old-price {
		font-size: clamp(9px, 1.3vw, 14px);
	}

	.discount-badge {
		font-size: clamp(7px, 1vw, 11px);
		padding: clamp(1px, 0.2vw, 3px) clamp(3px, 0.5vw, 5px);
	}

	.remove-btn {
		margin-top: clamp(2.9px, 0.49vw, 5px);
	}

	.remove-btn svg {
		width: clamp(21.1px, 3.5vw, 36px);
		height: clamp(21.1px, 3.5vw, 36px);
	}

	.item-content {
		padding-bottom: clamp(5.8px, 0.98vw, 10px);
	}

	.cart-item {
		margin-bottom: clamp(2.9px, 0.49vw, 5px);
	}

	.checkout-form {
		gap: clamp(5.8px, 0.98vw, 10px);
	}

	.checkout-form input[type="text"],
	.checkout-form input[type="tel"] {
		padding: clamp(6px, 1vw, 12px) clamp(10px, 1.5vw, 20px);
		font-size: clamp(10px, 1.4vw, 15px);
	}

	.agreement .text {
		font-size: clamp(4.7px, 0.78vw, 8px);
		line-height: 1.9;
	}
}





@media (max-width: 600px) {
    .container {
        padding: 20px 16px;
    }
    .cart-layout {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    .cart-summary {
        position: static;
        padding: 18px 28px;
        margin-top: 10px;
		margin-bottom: 10px
    }
    .cart-header {
        margin-bottom: 0;
    }
    .cart-header h1 {
        font-size: 28px;
        letter-spacing: -1.5px;
    }
    .header-actions {
        gap: 16px;
    }
    .cart-item {
        display: grid;
        grid-template-columns: 140px 1fr;
        grid-template-rows: auto auto;
        grid-template-areas:
            "image details"
            "actions actions";
        padding: 15px 0;
        gap: 0px 16px;
        border-bottom: 1px solid var(--color-border);
    }
    .cart-item:has(.item-specs) {
        grid-template-areas:
            "image details"
            "actions actions"
            "specs specs"
            "more more";
    }
    .cart-item:last-child {
        border-bottom: none;
    }
    .item-image {
        grid-area: image;
        width: 140px;
        height: 130px;
        padding: 8px;
        margin: 0;
    }
    .item-image img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }
    .item-info-wrapper {
        display: contents;
    }
    .item-content {
        display: contents;
    }
    .item-details {
        display: contents;
    }
    .item-details h2 {
        grid-area: details;
        font-size: 14px !important;
        line-height: 1.3;
        margin-bottom: 0;
        font-weight: 700;
        align-self: start;
    }
    .item-specs {
        display: none;
        grid-area: specs;
        margin-top: 4px;
        font-size: 12px;
    }
    .cart-item.show-specs .item-specs {
        display: block;
    }
    .cart-item.show-specs .item-details h2 {
        -webkit-line-clamp: unset;
        display: block;
    }
    .item-actions {
        grid-area: actions;
        width: 100%;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 8px;
        margin-top: 0;
    }
    .item-price {
        padding: 0;
        width: auto;
        order: 1;
        min-width: 0;
    }
    .current-price {
        font-size: 18px;
        margin-bottom: 20px;
        white-space: nowrap;
    }
    .old-price-wrap {
        margin-top: 2px;
        gap: 6px;
    }
    .old-price {
        font-size: 12px;
    }
    .discount-badge {
        font-size: 10px;
        padding: 2px 4px;
    }
	.unit-price br {
		display: none;
	}
    .item-controls {
        order: 2;
        margin-top: 0;
        padding: 0;
        flex-direction: column;
        align-items: center;
        gap: 4px;
    }
    .quantity-control {
        height: 36px;
    }
    .quantity-control button {
        width: 32px;
    }
    .quantity-control input {
        width: 36px;
        font-size: 14px;
    }
    .unit-price {
        font-size: 11px;
        margin-top: 2px;
        color: var(--color-text-muted);
        text-align: center;
    }
    .remove-btn {
		margin-bottom: 20px;
        order: 3;
        flex-shrink: 0;
    }
	.summary-row {
		font-size: 15px;
		margin-top: 10px;
	}
    .cart-summary h2 {
        font-size: 22px !important;
	}
	.summary-total .total-label {
		font-size: 15px;
		margin-top: 10px;
	}
	.summary-total .total-value {
		font-size: 28px;
	}
	.submit-btn {
		padding: 16px;
	}
	.agreement .text {
		font-size: 11px;
	}
    .remove-btn svg {
        width: 28px;
        height: 28px;
    }
    .more-details {
        display: none;
    }
    .cart-item:has(.item-specs) .more-details {
        grid-area: more;
        display: flex;
        width: 100%;
        justify-content: center;
        align-items: center;
        gap: 6px;
        font-weight: 700;
        font-size: 13px;
        color: var(--color-text);
        margin-top: 12px;
        cursor: pointer;
    }
    .more-details svg {
        transition: transform 0.3s;
    }
    .cart-item.show-specs .more-details svg {
        transform: rotate(180deg);
    }
}
/* End */
/* /local/templates/main/components/bitrix/sale.basket.basket/custom_cart/style.css?177842103618745 */
