/* Modu Quote – Frontend stylesheet */

:root {
	--modu-navy: #0f427b;
	--modu-navy-700: #0c365f;
	--modu-navy-50: #eaf1f9;
	--modu-navy-100: #d6e3f1;
	--modu-pink: #ff5b9e;
	--modu-yellow: #ffc83d;
	--modu-cyan: #7ec9d3;
	--modu-ink: #16243a;
	--modu-ink-soft: #4a5b75;
	--modu-ink-mute: #8494a8;
	--modu-bg: #fafaf7;
	--modu-surface: #ffffff;
	--modu-line: #e7e8ea;
	--modu-line-soft: #f0f1f3;
	--modu-ok: #1f8a5b;
	--modu-warn: #c97c1f;
	--modu-bad: #c33d4f;
	--modu-r-sm: 8px;
	--modu-r-md: 12px;
	--modu-r-lg: 18px;
	--modu-r-xl: 26px;
	--modu-shadow-sm: 0 1px 2px rgba(15,36,70,.06), 0 1px 3px rgba(15,36,70,.04);
	--modu-shadow-md: 0 6px 16px -8px rgba(15,36,70,.12), 0 2px 6px -2px rgba(15,36,70,.06);
	--modu-shadow-lg: 0 24px 48px -24px rgba(15,36,70,.22), 0 8px 18px -10px rgba(15,36,70,.1);
}

.modu-screen, .modu-screen * { box-sizing: border-box; }
.modu-screen { font-family: 'Rubik', -apple-system, system-ui, sans-serif; color: var(--modu-ink); direction: rtl; }

.modu-logo { display: inline-flex; align-items: center; gap: 10px; font-weight: 800; letter-spacing: -0.02em; color: var(--modu-navy); font-size: 26px; }
.modu-logo .glyph { display: inline-flex; gap: 3px; align-items: flex-end; height: 28px; }
.modu-logo .glyph i { display: block; width: 8px; background: currentColor; border-radius: 999px; }
.modu-logo .glyph i:nth-child(1) { height: 28px; background: var(--modu-pink); }
.modu-logo .glyph i:nth-child(2) { height: 22px; background: var(--modu-yellow); }
.modu-logo .glyph i:nth-child(3) { height: 26px; background: var(--modu-cyan); }

.modu-pill { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 500; background: var(--modu-navy-50); color: var(--modu-navy); white-space: nowrap; }
.modu-pill .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.modu-pill.pink { background: #ffe6f0; color: #c63d7c; }
.modu-pill.yellow { background: #fff5d4; color: #93660d; }
.modu-pill.cyan { background: #e0f3f6; color: #2d7480; }
.modu-pill.green { background: #e3f3eb; color: var(--modu-ok); }
.modu-pill.red { background: #fbe5e8; color: var(--modu-bad); }
.modu-pill.gray { background: #eef0f3; color: var(--modu-ink-soft); }

.modu-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 20px; border-radius: 999px; border: 1px solid transparent; background: var(--modu-navy); color: white; font-size: 15px; font-weight: 500; cursor: pointer; transition: transform .12s ease, box-shadow .12s ease, background .12s ease; white-space: nowrap; text-decoration: none; }
.modu-btn:hover { transform: translateY(-1px); box-shadow: var(--modu-shadow-md); color: white; }
.modu-btn:active { transform: translateY(0); }
.modu-btn.ghost { background: transparent; color: var(--modu-navy); border-color: var(--modu-navy-100); }
.modu-btn.ghost:hover { background: var(--modu-navy-50); }
.modu-btn.soft { background: var(--modu-navy-50); color: var(--modu-navy); }
.modu-btn.soft:hover { background: var(--modu-navy-100); }
.modu-btn.danger { background: #fbe5e8; color: var(--modu-bad); }
.modu-btn.icon { padding: 10px; width: 38px; height: 38px; border-radius: 12px; }
.modu-btn.lg { padding: 16px 28px; font-size: 16px; width: 100%; }
.modu-btn.sm { padding: 8px 14px; font-size: 13px; }
.modu-btn.is-disabled { opacity: .55; pointer-events: none; }

.modu-product-quote { margin-top: 24px; }
.modu-qty-label { font-size: 13px; color: var(--modu-ink-soft); margin-bottom: 10px; }
.modu-qty-stepper { display: inline-flex; align-items: center; border: 1px solid var(--modu-line); border-radius: 999px; padding: 4px; background: white; }
.modu-qty-stepper.sm { padding: 3px; }
.modu-qty-btn { background: transparent; border: 0; cursor: pointer; padding: 0; width: 34px; height: 34px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; color: var(--modu-navy); }
.modu-qty-btn:hover { background: var(--modu-navy-50); }
.modu-qty-stepper.sm .modu-qty-btn { width: 28px; height: 28px; }
.modu-qty-input { width: 60px; text-align: center; border: 0; outline: none; font-size: 16px; font-weight: 500; background: transparent; color: var(--modu-ink); -moz-appearance: textfield; }
.modu-qty-input::-webkit-outer-spin-button,
.modu-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.modu-quote-button { display: inline-flex; align-items: center; gap: 10px; padding: 18px 32px; border: none; border-radius: 999px; font-size: 17px; font-weight: 500; cursor: pointer; box-shadow: 0 12px 24px -10px rgba(15,66,123,.35); transition: all .15s ease; margin-top: 24px; }
.modu-quote-button:hover { transform: translateY(-1px); }
.modu-quote-button .modu-qb-icon { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 50%; background: rgba(255,255,255,.18); }
.modu-quote-button--gradient { background: linear-gradient(135deg, var(--modu-navy) 0%, #1c5fa8 100%); color: white; }
.modu-quote-button--navy { background: var(--modu-navy); color: white; }
.modu-quote-button--outline { background: white; color: var(--modu-navy); border: 2px solid var(--modu-navy); }
.modu-quote-button--outline .modu-qb-icon { background: var(--modu-navy-50); color: var(--modu-navy); }
.modu-quote-button--pink { background: var(--modu-pink); color: white; }
.modu-quote-button--loop { padding: 10px 16px; font-size: 13px; margin-top: 12px; gap: 6px; box-shadow: var(--modu-shadow-sm); background: var(--modu-navy); color: white; }
.modu-quote-button--loop .modu-qb-icon { width: 20px; height: 20px; }
.modu-quote-tip { font-size: 12px; color: var(--modu-ink-mute); margin-top: 12px; display: inline-flex; align-items: center; gap: 6px; }
.modu-quote-tip .dots { display: inline-flex; gap: 4px; }
.modu-quote-tip .dots i { display: block; width: 8px; height: 8px; border-radius: 50%; }
.modu-quote-tip .dots i:nth-child(1) { background: var(--modu-pink); }
.modu-quote-tip .dots i:nth-child(2) { background: var(--modu-yellow); }
.modu-quote-tip .dots i:nth-child(3) { background: var(--modu-cyan); }

.modu-hero { background: linear-gradient(135deg, var(--modu-navy) 0%, #1c5fa8 100%); color: white; padding: 40px; position: relative; overflow: hidden; }
.modu-hero--compact { padding: 32px 40px; }
.modu-hero__inner { position: relative; z-index: 1; max-width: 1200px; margin: 0 auto; }
.modu-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 13px; opacity: .8; }
.modu-hero__title { font-size: 36px; font-weight: 600; margin: 12px 0 6px; letter-spacing: -0.02em; }
.modu-hero--compact .modu-hero__title { font-size: 28px; }
.modu-hero__sub { margin: 0; opacity: .85; font-size: 15px; }
.modu-hero__dots { position: absolute; inset: 0; pointer-events: none; }
.modu-hero__dots .d { position: absolute; border-radius: 50%; opacity: .15; }
.modu-hero__dots .d-pink   { top: 30px; right: 60px; width: 80px; height: 80px; background: var(--modu-pink); }
.modu-hero__dots .d-yellow { bottom: -20px; right: 200px; width: 120px; height: 120px; background: var(--modu-yellow); opacity: .1; }
.modu-hero__dots .d-cyan   { top: 60px; right: 180px; width: 50px; height: 50px; background: var(--modu-cyan); opacity: .12; }

.modu-steps { display: flex; align-items: center; gap: 16px; justify-content: center; padding: 24px 40px 0; flex-wrap: wrap; }
.modu-step { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.modu-step .n { width: 28px; height: 28px; border-radius: 50%; background: #e7e8ea; color: var(--modu-ink-mute); display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; }
.modu-step .t { color: var(--modu-ink-mute); }
.modu-step.is-active .n { background: var(--modu-navy); color: white; }
.modu-step.is-active .t { color: var(--modu-ink); font-weight: 500; }
.modu-step.is-done .n { background: var(--modu-ok); color: white; }
.modu-step-bar { width: 40px; height: 2px; background: #e7e8ea; }
.modu-step-bar.is-done { background: var(--modu-ok); }

.modu-card { background: var(--modu-surface); border: 1px solid var(--modu-line); border-radius: var(--modu-r-lg); box-shadow: var(--modu-shadow-sm); }
.modu-section-title { font-size: 22px; font-weight: 600; letter-spacing: -0.01em; margin: 0; }
.modu-section-sub { font-size: 14px; color: var(--modu-ink-soft); margin: 4px 0 0 0; }

.modu-cart-body { padding: 24px 40px; display: grid; grid-template-columns: 1fr 320px; gap: 24px; max-width: 1240px; margin: 0 auto; align-items: flex-start; }
@media (max-width: 900px) { .modu-cart-body { grid-template-columns: 1fr; } }

.modu-cart-items__head { padding: 20px 24px; border-bottom: 1px solid var(--modu-line-soft); display: flex; justify-content: space-between; align-items: center; }
.modu-cart-row { display: grid; grid-template-columns: 64px 1fr 200px 40px; gap: 16px; padding: 20px; align-items: center; border-bottom: 1px solid var(--modu-line-soft); }
.modu-cart-row:last-child { border-bottom: none; }
.modu-cart-row__img { width: 64px; height: 64px; border-radius: 12px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.modu-cart-row__img img { width: 100%; height: 100%; object-fit: cover; }
.modu-bottle-shape { width: 30px; height: 42px; background: rgba(255,255,255,.55); border-radius: 14px 14px 6px 6px; }
.modu-cart-row__name { font-weight: 500; font-size: 15px; }
.modu-cart-row__meta { display: flex; gap: 6px; margin-top: 6px; align-items: center; font-size: 12px; color: var(--modu-ink-mute); flex-wrap: wrap; }
.modu-cart-row__qty { display: flex; align-items: center; gap: 12px; }
.modu-tiny-label { font-size: 11px; color: var(--modu-ink-mute); }

.modu-empty { padding: 40px 24px; text-align: center; color: var(--modu-ink-mute); }
.modu-empty-screen { padding: 80px 24px; text-align: center; }

.modu-summary { padding: 24px; }
.modu-summary__title { margin: 0 0 16px; font-size: 16px; font-weight: 600; }
.modu-summary__rows .row { display: flex; justify-content: space-between; align-items: center; font-size: 14px; padding: 4px 0; }
.modu-summary__rows .row b { font-weight: 500; }
.modu-summary__rows .row span:first-child { color: var(--modu-ink-soft); }
.modu-summary__tip { margin-top: 20px; padding: 14px; border-radius: 12px; background: var(--modu-navy-50); display: flex; gap: 10px; align-items: flex-start; color: var(--modu-navy); font-size: 12px; line-height: 1.5; }
.modu-summary__items { display: flex; flex-direction: column; gap: 10px; }
.modu-summary__item { display: flex; gap: 10px; align-items: center; }
.modu-summary__sw { width: 36px; height: 36px; border-radius: 8px; flex-shrink: 0; }
.modu-summary__info .n { font-size: 12px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 160px; }
.modu-summary__info .m { font-size: 11px; color: var(--modu-ink-mute); }
.modu-summary__total { display: flex; justify-content: space-between; margin-top: 16px; padding-top: 16px; border-top: 1px dashed var(--modu-line); font-size: 13px; }
.modu-summary__total span { color: var(--modu-ink-soft); }
.modu-summary__total b { font-weight: 600; }

.modu-cart-continue { margin-top: 16px; }
.modu-cart-continue-shop { width: 100%; margin-top: 8px; }

.modu-help-card { margin-top: 16px; padding: 16px 20px; background: white; border-radius: 18px; border: 1px dashed var(--modu-line); }
.modu-help-card__sub { font-size: 12px; color: var(--modu-ink-mute); margin-bottom: 6px; }
.modu-help-card__row { display: flex; align-items: center; gap: 10px; }
.modu-help-card__avatar { width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, var(--modu-pink), var(--modu-yellow)); }
.modu-help-card__name { font-size: 13px; font-weight: 500; }
.modu-help-card__phone { font-size: 12px; color: var(--modu-navy); }

.modu-form-body { align-items: flex-start; }
.modu-form-card { padding: 28px; }
.modu-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 20px; }
@media (max-width: 600px) { .modu-grid-2 { grid-template-columns: 1fr; } }

.modu-field { display: flex; flex-direction: column; gap: 6px; }
.modu-field label { font-size: 13px; color: var(--modu-ink-soft); font-weight: 500; }
.modu-field label .req { color: var(--modu-pink); margin-inline-start: 2px; }
.modu-input, .modu-textarea, .modu-select { width: 100%; padding: 12px 14px; border: 1px solid var(--modu-line); background: var(--modu-surface); border-radius: var(--modu-r-md); font-size: 15px; color: var(--modu-ink); transition: border .15s ease, box-shadow .15s ease; outline: none; font-family: inherit; }
.modu-input:focus, .modu-textarea:focus, .modu-select:focus { border-color: var(--modu-navy); box-shadow: 0 0 0 3px var(--modu-navy-50); }
.modu-textarea { min-height: 92px; resize: vertical; }

.modu-form-extra { margin-top: 24px; padding-top: 24px; border-top: 1px solid var(--modu-line-soft); display: flex; flex-direction: column; gap: 16px; }
.modu-form-extra h3 { font-size: 16px; font-weight: 600; margin: 0; }
.modu-check { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.modu-check input { width: 18px; height: 18px; accent-color: var(--modu-navy); }

.modu-segmented__label { font-size: 13px; color: var(--modu-ink-soft); margin-bottom: 8px; }
.modu-segmented__options { display: flex; gap: 8px; flex-wrap: wrap; }
.modu-segmented__options label { cursor: pointer; }
.modu-segmented__options label input { display: none; }
.modu-segmented__options label span { display: inline-block; padding: 10px 24px; border-radius: 999px; border: 2px solid var(--modu-line); background: white; color: var(--modu-ink-soft); font-weight: 500; font-size: 14px; transition: .12s; }
.modu-segmented__options label input:checked + span { border-color: var(--modu-navy); background: var(--modu-navy-50); color: var(--modu-navy); }

.modu-privacy { margin-top: 24px; padding: 16px; background: var(--modu-navy-50); border-radius: 12px; font-size: 12px; color: var(--modu-ink-soft); line-height: 1.6; }
.modu-form-msg { margin-top: 16px; padding: 14px 18px; border-radius: 12px; font-size: 14px; display: none; }
.modu-form-msg.is-error { display: block; background: #fbe5e8; color: var(--modu-bad); }
.modu-form-msg.is-success { display: block; background: #e3f3eb; color: var(--modu-ok); }

/* ---------- Floating cart FAB + Drawer ---------- */
.modu-floating-fab {
	position: fixed; bottom: 24px; left: 24px; z-index: 9998;
	display: inline-flex; align-items: center; gap: 10px;
	padding: 14px 20px 14px 18px; border: none; cursor: pointer;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--modu-navy) 0%, #1c5fa8 100%);
	color: white;
	font-family: 'Rubik', sans-serif; font-size: 14px; font-weight: 500;
	box-shadow: 0 18px 36px -10px rgba(15,66,123,.45), 0 6px 14px -6px rgba(15,66,123,.35);
	transition: transform .18s ease, box-shadow .18s ease, opacity .25s ease;
}
.modu-floating-fab:hover { transform: translateY(-3px); box-shadow: 0 26px 44px -12px rgba(15,66,123,.5); }
.modu-floating-fab:active { transform: translateY(-1px); }
.modu-floating-fab.is-empty { opacity: 0; pointer-events: none; transform: translateY(20px); }
.modu-fab-icon { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 50%; background: rgba(255,255,255,.18); }
.modu-fab-label { letter-spacing: -0.01em; }
.modu-fab-count { display: inline-block; min-width: 22px; height: 22px; padding: 0 6px; line-height: 22px; text-align: center; border-radius: 999px; background: var(--modu-pink); color: white; font-weight: 700; font-size: 12px; margin-inline-start: 2px; box-shadow: 0 2px 6px rgba(255,91,158,.4); }
.modu-fab-pulse { position: absolute; inset: 0; border-radius: 999px; pointer-events: none; box-shadow: 0 0 0 0 rgba(255,91,158,.5); animation: moduPulse 2s ease-out infinite; }
.modu-floating-fab.is-empty .modu-fab-pulse { display: none; }
@keyframes moduPulse {
	0%   { box-shadow: 0 0 0 0 rgba(255,91,158,.5); }
	70%  { box-shadow: 0 0 0 18px rgba(255,91,158,0); }
	100% { box-shadow: 0 0 0 0 rgba(255,91,158,0); }
}

.modu-drawer-overlay {
	position: fixed; inset: 0; z-index: 9998;
	background: rgba(15,36,70,.4); backdrop-filter: blur(3px);
	opacity: 0; pointer-events: none;
	transition: opacity .25s ease;
}
.modu-drawer-overlay.is-open { opacity: 1; pointer-events: auto; }

.modu-drawer {
	position: fixed; top: 0; bottom: 0; left: 0;
	width: 420px; max-width: 92vw;
	z-index: 9999; background: white;
	display: flex; flex-direction: column;
	box-shadow: 24px 0 60px -20px rgba(15,36,70,.35);
	transform: translateX(-105%);
	transition: transform .35s cubic-bezier(.22,.61,.36,1);
	font-family: 'Rubik', sans-serif;
	direction: rtl; color: var(--modu-ink);
}
.modu-drawer.is-open { transform: translateX(0); }

.modu-drawer__head { position: relative; padding: 22px 22px 18px; color: white; overflow: hidden; background: linear-gradient(135deg, var(--modu-navy) 0%, #1c5fa8 100%); }
.modu-drawer__head-bg { position: absolute; inset: 0; pointer-events: none; }
.modu-drawer__head-bg .bub { position: absolute; border-radius: 50%; opacity: .18; }
.modu-drawer__head-bg .b1 { top: -32px; right: -20px; width: 110px; height: 110px; background: var(--modu-pink); }
.modu-drawer__head-bg .b2 { bottom: -40px; left: -16px; width: 130px; height: 130px; background: var(--modu-yellow); opacity: .14; }
.modu-drawer__head-bg .b3 { top: 40px; left: 90px; width: 56px; height: 56px; background: var(--modu-cyan); }
.modu-drawer__head-inner { position: relative; display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.modu-drawer__head-title { display: flex; align-items: center; gap: 12px; }
.modu-drawer__head-title .t { font-size: 17px; font-weight: 600; letter-spacing: -0.01em; }
.modu-drawer__head-title .s { font-size: 12px; opacity: .8; margin-top: 2px; }
.modu-drawer__head-title svg { background: rgba(255,255,255,.18); border-radius: 12px; padding: 6px; box-sizing: content-box; }
.modu-drawer__close { background: rgba(255,255,255,.16); border: 0; color: white; width: 34px; height: 34px; border-radius: 12px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: background .15s; }
.modu-drawer__close:hover { background: rgba(255,255,255,.28); }

.modu-drawer__body { flex: 1; overflow-y: auto; padding: 12px 14px; background: var(--modu-bg); }
.modu-drawer__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.modu-drawer__item { display: grid; grid-template-columns: 56px 1fr auto; gap: 12px; align-items: center; padding: 12px; background: white; border-radius: 14px; border: 1px solid var(--modu-line); transition: border-color .15s, box-shadow .15s; }
.modu-drawer__item:hover { border-color: var(--modu-navy-100); box-shadow: var(--modu-shadow-sm); }
.modu-drawer__item-img { width: 56px; height: 56px; border-radius: 12px; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.modu-drawer__item-img img { width: 100%; height: 100%; object-fit: cover; }
.modu-drawer__item-info { min-width: 0; }
.modu-drawer__item-name { font-size: 13px; font-weight: 500; line-height: 1.35; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.modu-drawer__item-meta { font-size: 11px; color: var(--modu-ink-mute); margin-top: 4px; display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.modu-drawer__item-actions { display: flex; flex-direction: column; gap: 6px; align-items: flex-end; }
.modu-drawer__item-remove { background: transparent; border: 0; color: var(--modu-ink-mute); cursor: pointer; padding: 4px; border-radius: 8px; }
.modu-drawer__item-remove:hover { color: var(--modu-bad); background: #fbe5e8; }

.modu-drawer__empty { display: none; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 60px 20px; color: var(--modu-ink-mute); gap: 8px; }
.modu-drawer__empty-icon { width: 70px; height: 70px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: var(--modu-navy-50); color: var(--modu-navy); margin-bottom: 8px; }
.modu-drawer__empty-title { font-size: 16px; font-weight: 600; color: var(--modu-ink); }
.modu-drawer__empty-sub { font-size: 13px; line-height: 1.5; max-width: 240px; }
.modu-drawer.is-cart-empty .modu-drawer__list { display: none; }
.modu-drawer.is-cart-empty .modu-drawer__empty { display: flex; }
.modu-drawer.is-cart-empty .modu-drawer__cta { opacity: .55; pointer-events: none; }

.modu-drawer__foot { padding: 16px 20px 20px; border-top: 1px solid var(--modu-line); background: white; display: flex; flex-direction: column; gap: 8px; }
.modu-drawer__foot-row { display: flex; justify-content: space-between; align-items: center; font-size: 14px; padding: 4px 2px 8px; }
.modu-drawer__foot-row .lbl { color: var(--modu-ink-soft); }
.modu-drawer__foot-row b { font-size: 18px; color: var(--modu-navy); font-weight: 700; }
.modu-drawer__cta { width: 100%; }
.modu-drawer__cta-alt { width: 100%; text-align: center; }

@media (max-width: 480px) {
	.modu-floating-fab { padding: 12px 16px; bottom: 16px; left: 16px; }
	.modu-fab-label { display: none; }
	.modu-drawer { width: 100%; max-width: 100%; }
}

.modu-quote-active .single_add_to_cart_button,
.modu-quote-active .product .button.add_to_cart_button:not(.modu-quote-button),
.modu-quote-active .elementor-button-wrapper .single_add_to_cart_button { display: none !important; }

.modu-toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); background: var(--modu-navy); color: white; padding: 14px 22px; border-radius: 999px; font-size: 14px; display: flex; align-items: center; gap: 10px; box-shadow: var(--modu-shadow-lg); z-index: 100000; animation: moduSlideUp .3s ease; }
.modu-toast .icon { width: 22px; height: 22px; border-radius: 50%; background: var(--modu-yellow); color: var(--modu-navy); display: flex; align-items: center; justify-content: center; }
.modu-toast a { color: var(--modu-cyan); text-decoration: underline; cursor: pointer; }
@keyframes moduSlideUp { from { opacity: 0; transform: translate(-50%, 20px); } to { opacity: 1; transform: translate(-50%, 0); } }

.modu-thanks-screen { padding: 80px 20px; display: flex; justify-content: center; }
.modu-thanks-card { max-width: 520px; text-align: center; background: white; padding: 48px 40px; border-radius: 24px; border: 1px solid var(--modu-line); box-shadow: var(--modu-shadow-md); }
.modu-thanks-icon { width: 72px; height: 72px; margin: 0 auto 20px; border-radius: 50%; background: var(--modu-ok); color: white; display: flex; align-items: center; justify-content: center; }
.modu-thanks-card h1 { margin: 0 0 8px; font-size: 26px; }
.modu-thanks-number { color: var(--modu-ink-soft); margin: 12px 0 16px; font-size: 14px; }
.modu-thanks-number b { color: var(--modu-navy); font-family: ui-monospace, monospace; }
.modu-thanks-card p { color: var(--modu-ink-soft); line-height: 1.7; margin: 0 0 28px; }

.modu-customer-view { background: #eef0f3; padding: 24px 0 64px; }
.modu-customer-actions { max-width: 794px; margin: 0 auto 16px; padding: 0 16px; display: flex; gap: 8px; justify-content: flex-end; }
.modu-customer-view .modu-pdf { margin: 0 auto; }

@media print {
	.modu-floating-fab, .modu-drawer, .modu-drawer-overlay, .modu-customer-actions, header, footer, nav { display: none !important; }
	body { background: white !important; }
	.modu-customer-view { background: white; padding: 0; }
	.modu-pdf { box-shadow: none !important; }
}

.modu-quote-active .price:empty { display: none; }

/* ---------- Customer-view top bar + hero + CTA ---------- */
.modu-on-view-page .modu-floating-fab,
.modu-on-view-page .modu-drawer,
.modu-on-view-page .modu-drawer-overlay { display: none !important; }

.modu-customer-view-wrap { background: #f4f6fa; min-height: 100vh; padding-bottom: 60px; font-family: 'Rubik', sans-serif; }

.modu-cv-bar { background: white; border-bottom: 1px solid var(--modu-line); position: sticky; top: 0; z-index: 50; box-shadow: 0 1px 0 rgba(15,36,70,.04); }
.modu-cv-bar__inner { max-width: 900px; margin: 0 auto; padding: 12px 20px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.modu-cv-bar__left { display: flex; align-items: center; gap: 12px; }
.modu-cv-mini-logo { display: inline-flex; gap: 3px; align-items: flex-end; height: 22px; }
.modu-cv-mini-logo .g { display: inline-block; width: 6px; border-radius: 999px; }
.modu-cv-mini-logo .g.g1 { height: 22px; background: var(--modu-pink); }
.modu-cv-mini-logo .g.g2 { height: 16px; background: var(--modu-yellow); }
.modu-cv-mini-logo .g.g3 { height: 19px; background: var(--modu-cyan); }
.modu-cv-bar__sub { font-size: 11px; color: var(--modu-ink-mute); }
.modu-cv-bar__title { font-size: 16px; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.modu-cv-bar__right { display: flex; gap: 8px; flex-wrap: wrap; }
.modu-cv-bar .modu-btn.sm { padding: 8px 16px; }
.modu-cv-accept { background: var(--modu-ok) !important; }
.modu-cv-accept:hover { background: #1a7c50 !important; }

/* Hero greeting */
.modu-cv-hero { padding: 28px 20px 16px; }
.modu-cv-hero__inner { max-width: 900px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.modu-cv-hero__greet { font-size: 15px; color: var(--modu-ink); line-height: 1.6; max-width: 540px; }
.modu-cv-hero__greet .hi { font-weight: 600; font-size: 18px; display: block; margin-bottom: 4px; color: var(--modu-navy); letter-spacing: -0.01em; }
.modu-cv-hero__greet .msg { color: var(--modu-ink-soft); font-size: 14px; }
.modu-cv-hero__meta { display: flex; gap: 8px; flex-wrap: wrap; }
.modu-cv-hero__chip { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 999px; background: white; border: 1px solid var(--modu-line); font-size: 13px; color: var(--modu-ink-soft); }
.modu-cv-hero__chip svg { color: var(--modu-navy); }
.modu-cv-hero__chip.price { background: linear-gradient(135deg, var(--modu-navy) 0%, #1c5fa8 100%); color: white; border: 0; padding: 8px 18px; }
.modu-cv-hero__chip.price .lab { font-size: 11px; opacity: .8; margin-inline-end: 6px; }
.modu-cv-hero__chip.price .val { font-weight: 700; font-size: 16px; }

/* Existing PDF wrapper */
.modu-customer-view { background: #eef0f3; padding: 24px 0; }
.modu-customer-view-wrap .modu-customer-view { background: transparent; padding: 0 16px; }
.modu-customer-view-wrap .modu-pdf { max-width: 794px; margin: 0 auto; }

/* Bottom CTA card */
.modu-cv-cta { padding: 28px 20px 0; }
.modu-cv-cta__inner { max-width: 794px; margin: 0 auto; background: white; border: 1px solid var(--modu-line); border-radius: 20px; padding: 24px 28px; box-shadow: var(--modu-shadow-md); display: flex; gap: 24px; align-items: center; justify-content: space-between; flex-wrap: wrap; position: relative; overflow: hidden; }
.modu-cv-cta__inner::before { content: ''; position: absolute; top: -40px; right: -40px; width: 140px; height: 140px; border-radius: 50%; background: linear-gradient(135deg, rgba(255,91,158,.08), rgba(255,200,61,.08)); pointer-events: none; }
.modu-cv-cta__text .t { font-size: 18px; font-weight: 600; color: var(--modu-ink); margin-bottom: 4px; }
.modu-cv-cta__text .s { font-size: 13px; color: var(--modu-ink-soft); max-width: 360px; line-height: 1.5; }
.modu-cv-cta__buttons { display: flex; flex-direction: column; gap: 8px; align-items: stretch; min-width: 200px; }
.modu-cv-accept-big { background: linear-gradient(135deg, var(--modu-ok), #2bb077) !important; box-shadow: 0 12px 24px -10px rgba(31,138,91,.45); }
.modu-cv-accept-big:hover { transform: translateY(-2px); }

/* Status banners (already accepted/rejected) */
.modu-cv-status { padding: 28px 20px 0; }
.modu-cv-status { max-width: 794px; margin: 28px auto 0; padding: 22px 26px; border-radius: 20px; display: flex; gap: 16px; align-items: center; }
.modu-cv-status .ico { width: 48px; height: 48px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.modu-cv-status .t { font-size: 17px; font-weight: 600; }
.modu-cv-status .s { font-size: 13px; opacity: .8; margin-top: 2px; }
.modu-cv-status--ok { background: #e3f3eb; color: #1a7c50; }
.modu-cv-status--ok .ico { background: var(--modu-ok); color: white; }
.modu-cv-status--bad { background: #fbe5e8; color: #9a2434; }
.modu-cv-status--bad .ico { background: var(--modu-bad); color: white; }

/* Help footer */
.modu-cv-help { text-align: center; color: var(--modu-ink-mute); font-size: 13px; padding: 28px 20px 12px; }
.modu-cv-help a { color: var(--modu-navy); text-decoration: none; font-weight: 500; }
.modu-cv-help a:hover { text-decoration: underline; }

@media (max-width: 600px) {
	.modu-cv-bar__title { font-size: 14px; }
	.modu-cv-bar .modu-btn.sm { padding: 6px 12px; font-size: 12px; }
	.modu-cv-hero__greet .hi { font-size: 16px; }
	.modu-cv-cta__inner { flex-direction: column; align-items: stretch; text-align: center; }
	.modu-cv-cta__buttons { min-width: 0; }
}

/* Print: hide bar, hero, CTA, status, help. Show only the PDF block. */
@media print {
	.modu-cv-bar, .modu-cv-hero, .modu-cv-cta, .modu-cv-status, .modu-cv-help { display: none !important; }
	.modu-customer-view-wrap { background: white; padding: 0; }
	.modu-customer-view-wrap .modu-customer-view { padding: 0; }
}
