:root,
body {
	--tw-ink: #17212b;
	--tw-muted: #5e6a73;
	--tw-line: #d9e1e6;
	--tw-surface: #ffffff;
	--tw-soft: #f4f7f8;
	--tw-deep: #102335;
	--tw-accent: #16786f;
	--tw-accent-2: #b66a2c;
	--tw-warm: #f7efe5;
}

html.tw-bar-modal-open,
body.tw-bar-modal-open {
	overflow: hidden;
}

.tw-window-calculator,
.tw-window-calculator *,
.tw-cart-window-drawings,
.tw-cart-window-drawings *,
.tw-cart-window-report,
.tw-cart-window-report * {
	box-sizing: border-box;
}

.tw-window-calculator {
	--panel-colour: #f7f7f2;
}

.tw-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 12px 18px;
	border: 1px solid transparent;
	border-radius: 8px;
	font-weight: 800;
	line-height: 1.1;
	text-decoration: none;
	cursor: pointer;
	letter-spacing: 0 !important;
	text-transform: none !important;
}

.tw-btn-primary {
	background: var(--tw-accent);
	color: #fff;
}

.tw-btn-secondary {
	background: #fff;
	color: var(--tw-deep);
	border-color: var(--tw-line);
}

.tw-btn-link {
	min-height: 0;
	padding: 8px 4px;
	background: transparent;
	color: var(--tw-muted);
	border-color: transparent;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.tw-tool-panel {
	min-width: 0;
	padding: 24px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
	box-shadow: 0 16px 40px rgba(16, 35, 53, 0.06);
}

.tw-section-heading h2,
.tw-eyebrow,
.tw-result-label {
	letter-spacing: 0 !important;
	text-transform: none;
}

.tw-eyebrow {
	margin: 0 0 12px;
	color: var(--tw-accent-2);
	font-size: 13px;
	font-weight: 900;
	text-transform: uppercase;
}

.tw-section-heading h2 {
	margin: 0;
	color: var(--tw-deep);
	font-size: clamp(30px, 4vw, 48px);
	line-height: 1.06;
}

.tw-section-heading p,
.tw-disclaimer {
	color: var(--tw-muted);
	line-height: 1.55;
}

.tw-field,
.tw-field-grid {
	display: grid;
	gap: 8px;
}

.tw-field-grid {
	grid-template-columns: 1fr 1fr;
	margin-top: 16px;
}

.tw-shape-dimension-grid[hidden] {
	display: none !important;
}

.tw-shape-dimension-grid {
	grid-template-columns: minmax(0, 1fr);
	margin-top: 12px;
}

.tw-field > span,
.tw-field label {
	color: var(--tw-deep);
	font-weight: 850;
}

.tw-field input,
.tw-field select,
.tw-field textarea {
	width: 100%;
	min-height: 48px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	padding: 12px 14px;
	background: #fff;
	color: var(--tw-ink);
}

.tw-field textarea {
	min-height: 112px;
	resize: vertical;
}

.tw-result-label {
	margin: 0;
	color: var(--tw-muted);
	font-size: 13px;
	font-weight: 900;
	text-transform: uppercase;
}
.tw-window-calculator-section {
	background: var(--tw-soft);
	max-width: none;
	padding-left: max(24px, calc((100% - 1180px) / 2 + 24px));
	padding-right: max(24px, calc((100% - 1180px) / 2 + 24px));
}

.tw-window-calculator-section > .tw-window-calculator {
	max-width: 1180px;
	margin-left: auto;
	margin-right: auto;
	min-width: 0;
}

.tw-window-builder {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(430px, 0.78fr);
	gap: 18px;
	align-items: start;
	min-width: 0;
}

.tw-window-builder > * {
	min-width: 0;
}

.tw-quote-notice {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 14px;
	align-items: center;
	max-width: 1180px;
	margin: 0 auto 18px;
	padding: 14px 16px;
	border: 1px solid rgba(31, 132, 118, 0.24);
	border-radius: 8px;
	background: #effaf7;
	color: var(--tw-deep);
}

.tw-quote-notice a {
	color: var(--tw-accent);
	font-weight: 850;
}

.tw-window-options .tw-section-heading {
	margin-bottom: 24px;
}

.tw-choice-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
	margin: 0;
	padding: 0;
	border: 0;
	min-width: 0;
}

.tw-layout-grid,
.tw-shape-grid,
.tw-assembly-grid,
.tw-colour-grid,
.tw-finish-scope {
	display: grid;
	gap: 12px;
	margin: 22px 0 0;
	padding: 0;
	border: 0;
	min-width: 0;
}

.tw-layout-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tw-shape-grid {
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.tw-assembly-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tw-colour-grid {
	grid-template-columns: repeat(6, minmax(0, 1fr));
}

.tw-finish-scope {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tw-early-spec-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 22px;
}

.tw-choice-grid legend,
.tw-layout-grid legend,
.tw-shape-grid legend,
.tw-assembly-grid legend,
.tw-colour-grid legend,
.tw-finish-scope legend {
	grid-column: 1 / -1;
	margin-bottom: 2px;
	color: var(--tw-deep);
	font-weight: 850;
}

.tw-layout-grid > p {
	grid-column: 1 / -1;
	margin: -2px 0 4px;
	color: var(--tw-muted);
	font-size: 14px;
	line-height: 1.45;
}

.tw-window-design-card {
	display: grid;
	gap: 10px;
	min-width: 0;
	min-height: 180px;
	padding: 16px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
	color: var(--tw-ink);
	cursor: pointer;
	transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.tw-layout-card,
.tw-shape-card,
.tw-assembly-card,
.tw-colour-swatch-card,
.tw-finish-scope label {
	display: grid;
	gap: 8px;
	min-width: 0;
	padding: 12px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
	color: var(--tw-ink);
	cursor: pointer;
	transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.tw-colour-swatch-card {
	padding: 10px;
}

.tw-window-design-card:hover,
.tw-window-design-card:focus-within,
.tw-window-design-card.is-selected,
.tw-layout-card:hover,
.tw-layout-card:focus-within,
.tw-layout-card.is-selected,
.tw-shape-card:hover,
.tw-shape-card:focus-within,
.tw-shape-card.is-selected,
.tw-assembly-card:hover,
.tw-assembly-card:focus-within,
.tw-assembly-card.is-selected,
.tw-colour-swatch-card:hover,
.tw-colour-swatch-card:focus-within,
.tw-colour-swatch-card.is-selected,
.tw-finish-scope label:hover,
.tw-finish-scope label:focus-within,
.tw-finish-scope label.is-selected {
	border-color: var(--tw-accent);
	box-shadow: 0 16px 38px rgba(16, 35, 53, 0.1);
	transform: translateY(-1px);
}

.tw-window-design-card input,
.tw-layout-card input,
.tw-shape-card input,
.tw-assembly-card input,
.tw-colour-swatch-card input,
.tw-finish-scope input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.tw-window-design-card strong,
.tw-layout-card strong,
.tw-shape-card strong,
.tw-assembly-card strong,
.tw-colour-swatch-card strong,
.tw-option-toggle strong,
.tw-finish-scope strong {
	color: var(--tw-deep);
	font-size: 17px;
	line-height: 1.2;
	min-width: 0;
	overflow-wrap: anywhere;
	word-break: normal;
}

.tw-shape-card strong,
.tw-assembly-card strong {
	font-size: clamp(14px, 1.35vw, 17px);
}

.tw-colour-swatch-card strong {
	font-size: 14px;
	line-height: 1.12;
	overflow-wrap: anywhere;
}

.tw-window-design-card em,
.tw-assembly-card em,
.tw-option-toggle em,
.tw-finish-scope em {
	color: var(--tw-muted);
	font-size: 13px;
	font-style: normal;
	line-height: 1.35;
	min-width: 0;
	overflow-wrap: anywhere;
}

.tw-shape-card,
.tw-assembly-card {
	align-content: start;
}

.tw-shape-icon,
.tw-assembly-mini {
	display: block;
	width: 100%;
	height: 50px;
	border: 4px solid var(--tw-deep);
	background: linear-gradient(135deg, #fff, #d9e8ed);
	box-shadow: inset 0 0 0 4px rgba(255, 255, 255, 0.7);
}

.tw-shape-rectangle {
	border-radius: 6px;
}

.tw-shape-arch {
	border-radius: 48% 48% 6px 6px / 42% 42% 6px 6px;
}

.tw-shape-triangle_left {
	border: 0;
	background:
		linear-gradient(20deg, transparent calc(50% - 2px), var(--tw-deep) calc(50% - 2px) calc(50% + 2px), transparent calc(50% + 2px)),
		linear-gradient(270deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(90deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(0deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(135deg, #fff, #d9e8ed);
	clip-path: polygon(0 0, 100% 36%, 100% 100%, 0 100%);
}

.tw-shape-triangle_right {
	border: 0;
	background:
		linear-gradient(160deg, transparent calc(50% - 2px), var(--tw-deep) calc(50% - 2px) calc(50% + 2px), transparent calc(50% + 2px)),
		linear-gradient(270deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(90deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(0deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(135deg, #fff, #d9e8ed);
	clip-path: polygon(100% 0, 100% 100%, 0 100%, 0 36%);
}

.tw-shape-triangle_gable {
	border: 0;
	background:
		linear-gradient(22deg, transparent calc(50% - 2px), var(--tw-deep) calc(50% - 2px) calc(50% + 2px), transparent calc(50% + 2px)),
		linear-gradient(158deg, transparent calc(50% - 2px), var(--tw-deep) calc(50% - 2px) calc(50% + 2px), transparent calc(50% + 2px)),
		linear-gradient(270deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(90deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(0deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(135deg, #fff, #d9e8ed);
	clip-path: polygon(50% 0, 100% 40%, 100% 100%, 0 100%, 0 40%);
}

.tw-shape-rake_left {
	border: 0;
	background:
		linear-gradient(14deg, transparent calc(50% - 2px), var(--tw-deep) calc(50% - 2px) calc(50% + 2px), transparent calc(50% + 2px)),
		linear-gradient(270deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(90deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(0deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(135deg, #fff, #d9e8ed);
	clip-path: polygon(0 0, 100% 46%, 100% 100%, 0 100%);
}

.tw-shape-rake_right {
	border: 0;
	background:
		linear-gradient(166deg, transparent calc(50% - 2px), var(--tw-deep) calc(50% - 2px) calc(50% + 2px), transparent calc(50% + 2px)),
		linear-gradient(270deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(90deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(0deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(135deg, #fff, #d9e8ed);
	clip-path: polygon(100% 0, 100% 100%, 0 100%, 0 46%);
}

.tw-shape-rake_gable {
	border: 0;
	background:
		linear-gradient(18deg, transparent calc(50% - 2px), var(--tw-deep) calc(50% - 2px) calc(50% + 2px), transparent calc(50% + 2px)),
		linear-gradient(162deg, transparent calc(50% - 2px), var(--tw-deep) calc(50% - 2px) calc(50% + 2px), transparent calc(50% + 2px)),
		linear-gradient(270deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(90deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(0deg, var(--tw-deep) 0 4px, transparent 4px),
		linear-gradient(135deg, #fff, #d9e8ed);
	clip-path: polygon(50% 0, 100% 46%, 100% 100%, 0 100%, 0 46%);
}

.tw-shape-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 76px;
	padding: 6px;
	border: 1px solid rgba(16, 35, 53, 0.12) !important;
	border-radius: 8px !important;
	background: linear-gradient(135deg, #fafdfe, #eef5f7) !important;
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.74),
		0 8px 16px rgba(16, 35, 53, 0.06);
	clip-path: none !important;
	overflow: hidden;
}

.tw-shape-icon img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.tw-assembly-mini {
	position: relative;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4px;
	padding: 5px;
	border-radius: 6px;
}

.tw-assembly-mini::before,
.tw-assembly-mini::after {
	content: "";
	display: block;
	border: 3px solid rgba(16, 35, 53, 0.6);
	background: rgba(255, 255, 255, 0.6);
}

.tw-assembly-single {
	grid-template-columns: 1fr;
}

.tw-assembly-single::after {
	display: none;
}

.tw-assembly-shaped_top::before {
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
	grid-column: 1 / -1;
}

.tw-assembly-shaped_top {
	grid-template-rows: 0.75fr 1fr;
}

.tw-assembly-shaped_fixed {
	grid-template-columns: 1fr;
}

.tw-assembly-shaped_fixed::before {
	border-radius: 48% 48% 4px 4px / 38% 38% 4px 4px;
}

.tw-assembly-shaped_fixed::after {
	display: none;
}

.tw-assembly-door_sidelight_top {
	grid-template-rows: 0.55fr 1fr;
}

.tw-layout-mini {
	--layout-cols: 2;
	--layout-rows: 1;
	display: grid;
	grid-template-columns: repeat(var(--layout-cols), minmax(0, 1fr));
	grid-template-rows: repeat(var(--layout-rows), minmax(0, 1fr));
	gap: 3px;
	height: 46px;
	padding: 6px;
	border: 4px solid var(--tw-deep);
	border-radius: 6px;
	background: #f7f7f2;
	box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.68);
}

.tw-layout-mini i {
	display: block;
	border: 3px solid rgba(16, 35, 53, 0.76);
	box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.78);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(196, 218, 226, 0.78)),
		linear-gradient(90deg, transparent 46%, rgba(16, 35, 53, 0.16) 47% 53%, transparent 54%);
}

.tw-pane-designer {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	margin-top: 22px;
	padding: 16px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: linear-gradient(135deg, #f8fbfc, #eef4f6);
}

.tw-window-calculator.is-bar-draw-mode .tw-pane-designer {
	position: fixed;
	z-index: 100000;
	left: 50%;
	top: 50%;
	grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
	align-items: start;
	width: min(1180px, calc(100vw - 40px));
	max-height: calc(100vh - 40px);
	margin: 0;
	padding: 20px;
	overflow: auto;
	border-color: rgba(16, 35, 53, 0.16);
	background: linear-gradient(135deg, #fbfdfd, #eef5f6);
	box-shadow:
		0 28px 90px rgba(16, 35, 53, 0.32),
		0 0 0 9999px rgba(16, 35, 53, 0.48);
	transform: translate(-50%, -50%);
}

.tw-window-calculator.is-bar-draw-mode .tw-pane-designer > div {
	min-width: 0;
}

.tw-window-calculator.is-bar-draw-mode .tw-pane-toolbar {
	position: sticky;
	z-index: 5;
	top: -20px;
	margin: -20px -20px 16px;
	padding: 16px 20px 12px;
	border-bottom: 1px solid rgba(16, 35, 53, 0.08);
	background: rgba(251, 253, 253, 0.94);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
}

.tw-window-calculator.is-bar-draw-mode .tw-pane-controls {
	max-height: calc(100vh - 96px);
	overflow: auto;
}

.tw-window-calculator.is-bar-draw-mode .tw-measure-shell {
	grid-template-columns: minmax(96px, 0.16fr) minmax(420px, 1fr) minmax(96px, 0.16fr);
	grid-template-rows: auto minmax(360px, auto) auto;
}

.tw-window-calculator.is-bar-draw-mode .tw-pane-editor-frame {
	--frame-visual-max-height: min(66vh, 680px);
	--frame-editor-width-cap: min(74vw, 780px);
	width: min(100%, 780px, var(--frame-editor-width-cap));
	max-height: var(--frame-visual-max-height);
	padding: clamp(16px, 2vw, 24px);
}

.tw-window-calculator.is-bar-draw-mode .tw-bar-mode-toggle.is-active {
	border-color: rgba(15, 127, 118, 0.62);
	background: var(--tw-accent);
	color: #fff;
	box-shadow: 0 8px 18px rgba(15, 127, 118, 0.22);
}

.tw-pane-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin: 0 0 10px;
}

.tw-pane-title,
.tw-pane-selected {
	margin: 0 0 10px;
	color: var(--tw-deep);
	font-weight: 850;
}

.tw-pane-toolbar .tw-pane-title {
	margin: 0;
}

.tw-bar-mode-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	padding: 8px 12px;
	border: 1px solid rgba(16, 35, 53, 0.18);
	border-radius: 8px;
	background: #fff;
	color: var(--tw-deep);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	cursor: pointer;
	box-shadow: 0 1px 2px rgba(16, 35, 53, 0.06);
	appearance: none;
}

.tw-bar-mode-toggle:hover,
.tw-bar-mode-toggle:focus-visible {
	border-color: rgba(15, 127, 118, 0.38);
	outline: 2px solid rgba(15, 127, 118, 0.18);
	outline-offset: 2px;
}

.tw-bar-mode-toggle.is-active {
	border-color: rgba(15, 127, 118, 0.52);
	background: #edf8f5;
	color: var(--tw-accent);
	box-shadow: inset 0 0 0 1px rgba(15, 127, 118, 0.1);
}

.tw-local-grid-controls {
	display: grid;
	gap: 10px;
	margin: 0 0 12px;
	padding: 10px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #f8fbfc;
}

.tw-local-grid-controls[hidden] {
	display: none !important;
}

.tw-local-measure-group {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
	gap: 7px;
	align-items: end;
}

.tw-local-measure-group > strong {
	grid-column: 1 / -1;
	color: var(--tw-deep);
	font-size: 12px;
	font-weight: 900;
}

.tw-local-measure-group label {
	display: grid;
	grid-template-columns: minmax(58px, 1fr) minmax(86px, 104px) 22px auto;
	gap: 5px;
	align-items: center;
	color: var(--tw-muted);
	font-size: 11px;
	font-weight: 800;
}

.tw-local-measure-group input {
	width: 100%;
	min-height: 34px;
	padding: 6px;
	border: 1px solid var(--tw-line);
	border-radius: 6px;
	background: #fff;
	color: var(--tw-deep);
	font-weight: 850;
}

.tw-local-segment-spacer {
	width: 22px;
	height: 22px;
}

.tw-local-measure-group input,
.tw-measure-line input,
.tw-measure-segment input {
	-moz-appearance: textfield;
}

.tw-local-measure-group input::-webkit-outer-spin-button,
.tw-local-measure-group input::-webkit-inner-spin-button,
.tw-measure-line input::-webkit-outer-spin-button,
.tw-measure-line input::-webkit-inner-spin-button,
.tw-measure-segment input::-webkit-outer-spin-button,
.tw-measure-segment input::-webkit-inner-spin-button {
	margin: 0;
	-webkit-appearance: none;
}

.tw-measure-lock {
	position: relative;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	width: 22px;
	height: 22px;
	padding: 0;
	border: 1px solid rgba(16, 35, 53, 0.22);
	border-radius: 6px;
	background: #fff;
	color: var(--tw-deep);
	cursor: pointer;
}

.tw-window-calculator button.tw-measure-lock {
	width: 22px !important;
	min-width: 22px !important;
	max-width: 22px !important;
	height: 22px !important;
	min-height: 22px !important;
	padding: 0 !important;
	border: 1px solid rgba(16, 35, 53, 0.22) !important;
	border-radius: 6px !important;
	background: #fff !important;
	color: var(--tw-deep) !important;
	font-size: 0 !important;
	line-height: 0 !important;
	text-indent: 0 !important;
	box-shadow: none !important;
	appearance: none;
}

.tw-measure-lock::before {
	content: "";
	position: absolute;
	left: 6px;
	top: 9px;
	width: 10px;
	height: 8px;
	border-radius: 2px;
	background: currentColor;
}

.tw-measure-lock::after {
	content: "";
	position: absolute;
	left: 6px;
	top: 3px;
	width: 10px;
	height: 10px;
	border: 2px solid currentColor;
	border-bottom: 0;
	border-radius: 9px 9px 0 0;
	transform-origin: left bottom;
	transform: translateX(4px) rotate(-28deg);
}

.tw-measure-lock.is-locked {
	border-color: rgba(15, 127, 118, 0.34);
	background: #effaf7;
	color: var(--tw-accent);
}

.tw-window-calculator button.tw-measure-lock.is-locked {
	border-color: rgba(15, 127, 118, 0.34) !important;
	background: #effaf7 !important;
	color: var(--tw-accent) !important;
}

.tw-measure-lock.is-locked::after {
	transform: none;
}

.tw-measure-segment input[readonly],
.tw-local-measure-group input[readonly] {
	background: #f8fbfc;
	color: #506473;
}

.tw-measure-shell {
	--measure-col-template: 1fr;
	--measure-row-template: 1fr;
	display: grid;
	grid-template-columns: minmax(108px, 0.18fr) minmax(360px, 1fr) minmax(108px, 0.18fr);
	grid-template-rows: auto minmax(180px, auto) auto;
	gap: 12px 16px;
	align-items: stretch;
	min-width: 0;
}

.tw-measure-line,
.tw-measure-segment {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	min-width: 0;
	color: var(--tw-muted);
	font-size: 11px;
	font-weight: 900;
	text-transform: uppercase;
}

.tw-measure-line::before,
.tw-measure-segment::before {
	content: "";
	position: absolute;
	border-color: rgba(16, 35, 53, 0.32);
	pointer-events: none;
}

.tw-measure-line span,
.tw-measure-line em,
.tw-measure-segment span,
.tw-measure-segment em {
	position: relative;
	z-index: 1;
	padding: 2px 3px;
	border-radius: 4px;
	background: #f8fbfc;
	font-style: normal;
	line-height: 1;
	white-space: nowrap;
}

.tw-measure-line input,
.tw-measure-segment input {
	position: relative;
	z-index: 1;
	width: 104px;
	min-height: 34px;
	border: 1px solid rgba(16, 35, 53, 0.22);
	border-radius: 6px;
	padding: 7px 8px;
	background: #fff;
	color: var(--tw-deep);
	font-size: 14px;
	font-weight: 850;
	text-align: center;
}

.tw-measure-segment input {
	width: 86px;
	padding-left: 6px;
	padding-right: 6px;
}

.tw-measure-overall-width {
	grid-column: 2;
	grid-row: 1;
	min-height: 38px;
}

.tw-measure-overall-width::before {
	left: 0;
	right: 0;
	top: 50%;
	border-top: 2px solid rgba(16, 35, 53, 0.3);
}

.tw-measure-overall-height {
	grid-column: 3;
	grid-row: 2;
	flex-direction: column;
}

.tw-measure-overall-height::before {
	top: 0;
	bottom: 0;
	left: 50%;
	border-left: 2px solid rgba(16, 35, 53, 0.3);
}

.tw-measure-cols {
	grid-column: 2;
	grid-row: 3;
	display: grid;
	grid-template-columns: var(--measure-col-template);
	gap: 6px;
	min-width: 0;
}

.tw-measure-rows {
	grid-column: 1;
	grid-row: 2;
	display: grid;
	grid-template-rows: var(--measure-row-template);
	gap: 6px;
	min-width: 0;
}

.tw-measure-segment-col::before {
	left: 0;
	right: 0;
	top: 50%;
	border-top: 1px dashed rgba(16, 35, 53, 0.34);
}

.tw-measure-segment-row {
	flex-direction: column;
}

.tw-measure-segment-row::before {
	top: 0;
	bottom: 0;
	left: 50%;
	border-left: 1px dashed rgba(16, 35, 53, 0.34);
}

.tw-measure-error {
	min-height: 20px;
	margin: 10px 0 0;
	color: #b42318;
	font-size: 13px;
	font-weight: 850;
	line-height: 1.35;
}

.tw-measure-line input.is-invalid,
.tw-measure-segment input.is-invalid,
.tw-local-measure-group input.is-invalid {
	border-color: #b42318;
	box-shadow: 0 0 0 3px rgba(180, 35, 24, 0.12);
}

.tw-pane-editor-frame {
	--layout-cols: 2;
	--layout-rows: 2;
	--grid-cols-template: repeat(var(--layout-cols), minmax(0, 1fr));
	--grid-rows-template: repeat(var(--layout-rows), minmax(0, 1fr));
	--frame-ratio: 1;
	--frame-visual-max-height: 340px;
	--frame-editor-width-cap: 340px;
	--frame-colour: var(--tw-deep);
	--inside-colour: #f7f7f2;
	position: relative;
	grid-column: 2;
	grid-row: 2;
	display: grid;
	grid-template-columns: var(--grid-cols-template);
	grid-template-rows: var(--grid-rows-template);
	align-items: stretch;
	justify-items: stretch;
	gap: 8px;
	justify-self: center;
	align-self: center;
	width: min(100%, 560px, var(--frame-editor-width-cap));
	aspect-ratio: var(--frame-aspect, 1 / 1);
	height: auto;
	max-height: var(--frame-visual-max-height);
	min-height: 0;
	padding: 18px;
	border: 9px solid var(--frame-colour);
	border-radius: 8px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.36), rgba(16, 35, 53, 0.08)),
		var(--inside-colour);
	box-shadow:
		0 20px 38px rgba(16, 35, 53, 0.12),
		inset 0 0 0 4px rgba(255, 255, 255, 0.45),
		inset 0 0 0 8px rgba(16, 35, 53, 0.08);
}

.tw-window-calculator.has-local-grid .tw-pane-editor-frame {
	width: min(100%, 560px, var(--frame-editor-width-cap));
}

.tw-window-calculator.has-local-grid .tw-window-preview-frame {
	width: min(100%, 320px, var(--frame-preview-width-cap));
}

.tw-pane-editor-frame.has-cill,
.tw-window-preview-frame.has-cill {
	margin-bottom: 18px;
}

.tw-pane-editor-frame.tw-frame-shape-arch,
.tw-window-preview-frame.tw-frame-shape-arch {
	border-color: transparent;
	background: transparent;
	box-shadow: none;
}

.tw-pane-editor-frame.tw-frame-shape-triangle_left,
.tw-window-preview-frame.tw-frame-shape-triangle_left,
.tw-pane-editor-frame.tw-frame-shape-rake_left,
.tw-window-preview-frame.tw-frame-shape-rake_left {
	border-top-color: transparent;
	border-color: transparent;
	background: transparent;
	box-shadow: none;
	clip-path: polygon(0 0, 100% var(--shape-top-ratio, 28%), calc(100% + 42px) calc(100% + 42px), -42px calc(100% + 42px), 0 100%);
}

.tw-pane-editor-frame.tw-frame-shape-triangle_right,
.tw-window-preview-frame.tw-frame-shape-triangle_right,
.tw-pane-editor-frame.tw-frame-shape-rake_right,
.tw-window-preview-frame.tw-frame-shape-rake_right {
	border-top-color: transparent;
	border-color: transparent;
	background: transparent;
	box-shadow: none;
	clip-path: polygon(100% 0, calc(100% + 42px) calc(100% + 42px), -42px calc(100% + 42px), 0 var(--shape-top-ratio, 28%));
}

.tw-pane-editor-frame.tw-frame-shape-triangle_gable,
.tw-window-preview-frame.tw-frame-shape-triangle_gable,
.tw-pane-editor-frame.tw-frame-shape-rake_gable,
.tw-window-preview-frame.tw-frame-shape-rake_gable {
	border-top-color: transparent;
	border-color: transparent;
	background: transparent;
	box-shadow: none;
	clip-path: polygon(50% 0, 100% var(--shape-top-ratio, 28%), calc(100% + 42px) calc(100% + 42px), -42px calc(100% + 42px), 0 var(--shape-top-ratio, 28%));
}

.tw-frame-shape-only.tw-frame-shape-triangle_left {
	clip-path: polygon(0 0, 100% 100%, 0 100%);
}

.tw-frame-shape-only.tw-frame-shape-triangle_right {
	clip-path: polygon(100% 0, 100% 100%, 0 100%);
}

.tw-frame-shape-only.tw-frame-shape-triangle_gable {
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.tw-shape-frame-fill {
	position: absolute;
	z-index: 0;
	inset: 0;
	border-radius: 8px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.36), rgba(16, 35, 53, 0.08)),
		var(--inside-colour);
	filter: drop-shadow(0 16px 26px rgba(16, 35, 53, 0.12));
	pointer-events: none;
}

.tw-shape-frame-fill-svg {
	position: absolute;
	z-index: 0;
	inset: 0;
	width: 100%;
	height: 100%;
	overflow: visible;
	filter: drop-shadow(0 16px 26px rgba(16, 35, 53, 0.12));
	pointer-events: none;
}

.tw-shape-frame-fill-path {
	fill: var(--inside-colour);
	stroke: rgba(255, 255, 255, 0.42);
	stroke-width: 1;
	vector-effect: non-scaling-stroke;
}

.tw-frame-shape-triangle_left .tw-shape-frame-fill {
	clip-path: polygon(0 0, 100% var(--shape-top-ratio, 28%), 100% 100%, 0 100%);
}

.tw-frame-shape-triangle_right .tw-shape-frame-fill {
	clip-path: polygon(100% 0, 100% 100%, 0 100%, 0 var(--shape-top-ratio, 28%));
}

.tw-frame-shape-triangle_gable .tw-shape-frame-fill {
	clip-path: polygon(50% 0, 100% var(--shape-top-ratio, 28%), 100% 100%, 0 100%, 0 var(--shape-top-ratio, 28%));
}

.tw-shape-frame-outline {
	position: absolute;
	z-index: 7;
	left: -10px;
	right: -10px;
	top: -10px;
	width: calc(100% + 20px);
	height: calc(100% + 20px);
	overflow: visible;
	pointer-events: none;
}

.tw-shape-frame-line,
.tw-shape-frame-detail {
	fill: none;
	stroke-linecap: round;
	stroke-linejoin: round;
	vector-effect: non-scaling-stroke;
}

.tw-shape-frame-line {
	stroke: var(--frame-colour);
	stroke-width: 10px;
	filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.42));
}

.tw-shape-frame-detail {
	stroke: rgba(16, 35, 53, 0.34);
	stroke-width: 2px;
}

.tw-pane-editor-frame.has-cill::before,
.tw-window-preview-frame.has-cill::before {
	content: "";
	position: absolute;
	z-index: 4;
	left: -10px;
	right: -8px;
	bottom: calc(-1 * var(--cill-drop, 16px) + var(--cill-depth, 13px) - 1px);
	height: 4px;
	border-radius: 2px;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.55), transparent 22% 82%, rgba(16, 35, 53, 0.12)),
		color-mix(in srgb, var(--frame-colour, #102335) 82%, #fff);
	box-shadow: 0 2px 4px rgba(16, 35, 53, 0.12);
}

.tw-pane-editor-frame.has-cill::after,
.tw-window-preview-frame.has-cill::after {
	content: "";
	position: absolute;
	z-index: 3;
	left: -12px;
	right: calc(-1 * var(--cill-projection, 18px));
	bottom: calc(-1 * var(--cill-drop, 16px));
	height: var(--cill-depth, 13px);
	border: 1px solid rgba(16, 35, 53, 0.22);
	border-top-color: rgba(255, 255, 255, 0.42);
	border-radius: 2px 2px 6px 6px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.54), rgba(255, 255, 255, 0.12) 38%, rgba(16, 35, 53, 0.2)),
		linear-gradient(90deg, rgba(255, 255, 255, 0.18), transparent 30% 82%, rgba(16, 35, 53, 0.18)),
		var(--frame-colour);
	box-shadow: 0 10px 18px rgba(16, 35, 53, 0.18);
	transform: skewX(-12deg);
	transform-origin: top left;
}

.tw-pane-editor-frame[data-cill="stub_95"],
.tw-window-preview-frame[data-cill="stub_95"] {
	--cill-depth: 11px;
	--cill-drop: 14px;
	--cill-projection: 14px;
}

.tw-pane-editor-frame[data-cill="normal_150"],
.tw-window-preview-frame[data-cill="normal_150"] {
	--cill-depth: 14px;
	--cill-drop: 17px;
	--cill-projection: 22px;
}

.tw-pane-editor-frame[data-cill="large_180"],
.tw-window-preview-frame[data-cill="large_180"] {
	--cill-depth: 17px;
	--cill-drop: 20px;
	--cill-projection: 28px;
}

	.tw-pane {
		position: relative;
		z-index: 1;
		display: block;
		place-self: stretch;
		width: 100%;
		height: 100%;
		max-width: 100%;
		max-height: 100%;
		min-width: 0;
		min-height: 0;
		margin: 0;
		border: 5px solid color-mix(in srgb, var(--frame-colour, #102335) 78%, #102335);
		border-radius: 4px;
	box-shadow:
		inset 0 0 0 3px rgba(255, 255, 255, 0.82),
		inset 0 0 0 8px color-mix(in srgb, var(--frame-colour, #102335) 16%, transparent),
		inset 0 12px 20px rgba(255, 255, 255, 0.36),
		inset 0 -10px 18px rgba(16, 35, 53, 0.1);
	background:
		linear-gradient(115deg, rgba(255, 255, 255, 0.92) 0 18%, rgba(255, 255, 255, 0.18) 19% 36%, transparent 37%),
		linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(191, 217, 226, 0.82)),
		repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.2) 0 1px, transparent 1px 8px);
	--tw-local-grid-inset: clamp(6px, 6%, 8px);
	contain: paint;
	overflow: hidden;
}

	.tw-pane[role="button"],
	button.tw-pane {
		padding: 0;
		margin: 0;
		cursor: pointer;
		appearance: none;
	}

	.tw-pane.tw-french-master-left,
	.tw-pane.tw-french-master-right {
		left: auto;
		right: auto;
	}

button.tw-pane:disabled {
	opacity: 1;
}

.tw-pane[role="button"].is-active,
button.tw-pane.is-active {
	outline: 3px solid var(--tw-accent);
	outline-offset: -6px;
}

.tw-pane-shape-top {
	cursor: default;
	border-color: color-mix(in srgb, var(--frame-colour, #102335) 84%, #102335);
	background:
		linear-gradient(122deg, rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.18) 38%, transparent 39%),
		linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(191, 217, 226, 0.86));
}

.tw-pane-shape-top i {
	display: none;
}

.tw-pane-has-local-grid > .tw-pane-tilt-line,
.tw-pane-has-local-grid > i {
	display: none;
}

.tw-pane-local-grid {
	position: absolute;
	z-index: 2;
	inset: var(--tw-local-grid-inset);
	display: grid;
	grid-template-columns: repeat(var(--local-cols, 1), minmax(0, 1fr));
	grid-template-rows: repeat(var(--local-rows, 1), minmax(0, 1fr));
	gap: 0;
	min-height: 0;
}

.tw-local-pane {
	min-height: 0;
	border: 1px solid color-mix(in srgb, var(--frame-colour, #102335) 72%, #102335) !important;
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.78),
		inset 0 8px 14px rgba(255, 255, 255, 0.28),
		inset 0 -7px 12px rgba(16, 35, 53, 0.08);
}

.tw-local-pane.is-active {
	outline: 3px solid var(--tw-accent);
	outline-offset: -1px;
}

.tw-pane-segment-grid {
	position: absolute;
	z-index: 4;
	inset: var(--tw-local-grid-inset);
	pointer-events: none;
}

.tw-segment-pane {
	position: absolute;
	pointer-events: auto;
}

.tw-window-calculator.is-bar-draw-mode .tw-local-pane {
	border-color: color-mix(in srgb, var(--tw-accent-2) 66%, var(--frame-colour, #102335)) !important;
}

.tw-pane-bar-editor {
	position: absolute;
	z-index: 8;
	inset: var(--tw-local-grid-inset);
	--tw-bar-guide-rgb: 182, 106, 44;
	--tw-bar-added-rgb: 22, 120, 111;
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.14s ease, visibility 0.14s ease;
}

.tw-window-calculator.is-bar-draw-mode .tw-pane-bar-editor {
	visibility: visible;
	opacity: 1;
}

.tw-pane-bar-guide,
.tw-pane-existing-bar {
	position: absolute;
	display: block;
	margin: 0;
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: transparent;
	color: inherit;
	cursor: copy;
	appearance: none;
	pointer-events: auto;
	touch-action: manipulation;
}

.tw-pane-bar-guide {
	background: rgba(var(--tw-bar-guide-rgb), 0.025);
	opacity: 0.54;
	transition: opacity 0.16s ease, background-color 0.16s ease, box-shadow 0.16s ease;
}

.tw-pane:hover > .tw-pane-bar-editor .tw-pane-bar-guide,
.tw-pane:focus-within > .tw-pane-bar-editor .tw-pane-bar-guide,
.tw-pane.is-active > .tw-pane-bar-editor .tw-pane-bar-guide {
	opacity: 0.82;
}

.tw-pane-bar-guide:hover,
.tw-pane-bar-guide:focus-visible {
	background: rgba(var(--tw-bar-guide-rgb), 0.08);
	box-shadow: inset 0 0 0 1px rgba(var(--tw-bar-guide-rgb), 0.14);
	opacity: 1 !important;
	outline: 2px solid rgba(var(--tw-bar-guide-rgb), 0.34);
	outline-offset: 2px;
}

.tw-pane-bar-guide::before,
.tw-pane-bar-guide::after,
.tw-pane-existing-bar::before {
	content: "";
	position: absolute;
	border-radius: 999px;
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65);
}

.tw-pane-bar-guide::before,
.tw-pane-bar-guide::after {
	background: rgba(var(--tw-bar-guide-rgb), 0.72);
}

.tw-pane-existing-bar::before {
	background: rgba(var(--tw-bar-added-rgb), 0.9);
}

.tw-pane-bar-guide::after {
	content: "+";
	display: flex;
	align-items: center;
	justify-content: center;
	width: 9px;
	height: 9px;
	left: 50%;
	top: 50%;
	border: 1px solid rgba(var(--tw-bar-guide-rgb), 0.56);
	background: rgba(255, 255, 255, 0.88);
	color: var(--tw-accent-2);
	font-size: 8px;
	font-weight: 900;
	line-height: 1;
	transform: translate(-50%, -50%);
	box-shadow:
		0 1px 2px rgba(16, 35, 53, 0.16),
		0 0 0 3px rgba(255, 255, 255, 0.42);
}

.tw-pane-bar-guide-col {
	top: 0;
	bottom: 0;
	left: 50%;
	width: min(18px, 22%);
	transform: translateX(-50%);
}

.tw-pane-bar-guide-col::before {
	top: 0;
	bottom: 0;
	left: 50%;
	width: 1px;
	transform: translateX(-50%);
}

.tw-pane-bar-guide-row {
	left: 0;
	right: 0;
	top: 50%;
	height: min(18px, 22%);
	transform: translateY(-50%);
}

.tw-pane-bar-guide-row::before {
	left: 0;
	right: 0;
	top: 50%;
	height: 1px;
	transform: translateY(-50%);
}

.tw-pane-existing-bar {
	z-index: 2;
	cursor: pointer;
}

.tw-pane-existing-bar-col {
	top: -3px;
	bottom: -3px;
	width: 10px;
	transform: translateX(-50%);
}

.tw-pane-existing-bar-col::before {
	top: 0;
	bottom: 0;
	left: 50%;
	width: 2px;
	background: rgba(var(--tw-bar-added-rgb), 0.9);
	box-shadow:
		0 0 0 2px rgba(255, 255, 255, 0.46),
		0 1px 2px rgba(16, 35, 53, 0.12);
	transform: translateX(-50%);
	transition: background 0.16s ease, box-shadow 0.16s ease;
}

.tw-pane-existing-bar-row {
	left: -3px;
	right: -3px;
	height: 10px;
	transform: translateY(-50%);
}

.tw-pane-existing-bar-row::before {
	left: 0;
	right: 0;
	top: 50%;
	height: 2px;
	background: rgba(var(--tw-bar-added-rgb), 0.9);
	box-shadow:
		0 0 0 2px rgba(255, 255, 255, 0.46),
		0 1px 2px rgba(16, 35, 53, 0.12);
	transform: translateY(-50%);
	transition: background 0.16s ease, box-shadow 0.16s ease;
}

.tw-pane-existing-bar:hover::before,
.tw-pane-existing-bar:focus-visible::before {
	background: rgba(138, 59, 71, 0.9);
	box-shadow:
		0 0 0 3px rgba(138, 59, 71, 0.16),
		0 1px 2px rgba(16, 35, 53, 0.14);
}

.tw-pane-existing-bar:focus-visible {
	outline: 2px solid rgba(138, 59, 71, 0.62);
	outline-offset: 2px;
}

.tw-window-calculator .tw-pane-bar-editor .tw-pane-bar-guide,
.tw-window-calculator .tw-pane-bar-editor .tw-pane-existing-bar {
	margin: 0 !important;
	padding: 0 !important;
	min-width: 0 !important;
	min-height: 0 !important;
	max-width: none;
	max-height: none;
	line-height: 1 !important;
	font-size: 0;
}

.tw-window-calculator .tw-pane-bar-editor .tw-pane-bar-guide-col {
	width: min(18px, 22%) !important;
	height: auto !important;
}

.tw-window-calculator .tw-pane-bar-editor .tw-pane-bar-guide-row {
	width: auto !important;
	height: min(18px, 22%) !important;
}

.tw-window-calculator .tw-pane-bar-editor .tw-pane-existing-bar-col {
	width: 10px !important;
	height: auto !important;
}

.tw-window-calculator .tw-pane-bar-editor .tw-pane-existing-bar-row {
	width: auto !important;
	height: 10px !important;
}

.tw-window-calculator .tw-pane-bar-editor .tw-pane-existing-bar-row.tw-pane-existing-bar-partial {
	width: var(--tw-partial-length, auto) !important;
}

.tw-window-calculator .tw-pane-bar-editor .tw-pane-existing-bar-col.tw-pane-existing-bar-partial {
	height: var(--tw-partial-length, auto) !important;
}

.tw-pane::before,
.tw-pane::after {
	content: "";
	position: absolute;
	z-index: 1;
	display: none;
	width: max(0px, min(42%, calc(100% - 24px)));
	height: 2px;
	background: rgba(16, 35, 53, 0.52);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.55);
}

.tw-pane i {
	position: absolute;
}

.tw-pane-handle {
	position: absolute;
	z-index: 9;
	display: block;
	width: clamp(14px, 18%, 28px);
	height: clamp(28px, 46%, 56px);
	max-width: calc(100% - 12px);
	max-height: calc(100% - 12px);
	background: transparent url("../images/window-handle-white-realistic-v2.png") center / contain no-repeat;
	filter: drop-shadow(0 2px 2px rgba(16, 35, 53, 0.38));
	pointer-events: none;
}

.tw-pane-tilt-line {
	display: none;
	position: absolute;
	z-index: 1;
	inset: var(--tw-local-grid-inset, 7px);
	width: auto;
	height: auto;
	background: transparent;
	pointer-events: none;
}

.tw-pane-tilt-line svg {
	display: block;
	width: 100%;
	height: 100%;
	overflow: visible;
}

.tw-pane-tilt-line line {
	stroke: rgba(16, 35, 53, 0.58);
	stroke-width: 1.8;
	stroke-linecap: round;
	vector-effect: non-scaling-stroke;
	filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.55));
}

.tw-pane-top::before {
	left: 50%;
	top: 26%;
	display: block;
	transform: rotate(126deg);
	transform-origin: left center;
}

.tw-pane-top::after {
	right: 50%;
	top: 26%;
	display: block;
	transform: rotate(-126deg);
	transform-origin: right center;
}

.tw-pane-side_left::before,
.tw-pane-side_left::after {
	left: 28%;
	top: 50%;
	display: block;
	transform-origin: left center;
}

.tw-pane-side_left::before {
	transform: rotate(28deg);
}

.tw-pane-side_left::after {
	transform: rotate(-28deg);
}

.tw-pane-side_right::before,
.tw-pane-side_right::after {
	right: 28%;
	top: 50%;
	display: block;
	transform-origin: right center;
}

.tw-pane-side_right::before {
	transform: rotate(28deg);
}

.tw-pane-side_right::after {
	transform: rotate(-28deg);
}

.tw-pane-tilt_turn_left .tw-pane-tilt-line,
.tw-pane-tilt_turn_right .tw-pane-tilt-line {
	display: block;
}

.tw-pane-tilt_turn_left .tw-pane-tilt-line {
	transform: scaleX(-1);
}

.tw-pane i {
	z-index: 3;
	display: block;
	width: clamp(12px, 17%, 26px);
	height: clamp(24px, 44%, 52px);
	max-width: calc(100% - 14px);
	max-height: calc(100% - 14px);
	border-radius: 0;
	background: transparent url("../images/window-handle-white-realistic-v2.png") center / contain no-repeat;
	filter: drop-shadow(0 2px 2px rgba(16, 35, 53, 0.38));
}

.tw-pane-handle::before,
.tw-pane-handle::after {
	content: "";
	position: absolute;
	display: none;
	background: linear-gradient(135deg, #ffffff, #d8e0e3 72%, #f9fbfc);
	border: 1px solid rgba(68, 82, 91, 0.82);
	box-shadow:
		0 1px 2px rgba(16, 35, 53, 0.34),
		inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.tw-pane-handle::before {
	left: 50%;
	top: 50%;
	width: clamp(6px, 34%, 9px);
	height: min(100%, 34px);
	border-radius: 999px;
	transform: translate(-50%, -50%);
}

.tw-pane-handle::after {
	left: 46%;
	top: 50%;
	width: clamp(13px, 88%, 22px);
	height: clamp(5px, 17%, 8px);
	border-radius: 999px;
	transform: translateY(-50%) rotate(18deg);
	transform-origin: left center;
}

.tw-local-pane.tw-pane-side_left i,
.tw-local-pane.tw-pane-side_right i,
.tw-local-pane.tw-pane-top i,
.tw-local-pane.tw-pane-tilt_turn_left i,
.tw-local-pane.tw-pane-tilt_turn_right i {
	z-index: 7;
	background: none;
	filter: none;
}

.tw-local-pane.tw-pane-side_left i::before,
.tw-local-pane.tw-pane-side_right i::before,
.tw-local-pane.tw-pane-top i::before,
.tw-local-pane.tw-pane-tilt_turn_left i::before,
.tw-local-pane.tw-pane-tilt_turn_right i::before,
.tw-local-pane.tw-pane-side_left i::after,
.tw-local-pane.tw-pane-side_right i::after,
.tw-local-pane.tw-pane-top i::after,
.tw-local-pane.tw-pane-tilt_turn_left i::after,
.tw-local-pane.tw-pane-tilt_turn_right i::after {
	content: "";
	position: absolute;
	display: block;
	background: linear-gradient(135deg, #ffffff, #d7dee0 72%, #f8fafb);
	border: 1px solid rgba(70, 84, 92, 0.76);
	box-shadow:
		0 1px 2px rgba(16, 35, 53, 0.3),
		inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.tw-local-pane.tw-pane-side_left i::before,
.tw-local-pane.tw-pane-side_right i::before,
.tw-local-pane.tw-pane-top i::before,
.tw-local-pane.tw-pane-tilt_turn_left i::before,
.tw-local-pane.tw-pane-tilt_turn_right i::before {
	left: 50%;
	top: 50%;
	width: clamp(5px, 34%, 8px);
	height: min(100%, 32px);
	border-radius: 999px;
	transform: translate(-50%, -50%);
}

.tw-local-pane.tw-pane-side_left i::after,
.tw-local-pane.tw-pane-side_right i::after,
.tw-local-pane.tw-pane-top i::after,
.tw-local-pane.tw-pane-tilt_turn_left i::after,
.tw-local-pane.tw-pane-tilt_turn_right i::after {
	left: 46%;
	top: 50%;
	width: clamp(11px, 86%, 20px);
	height: clamp(4px, 17%, 7px);
	border-radius: 999px;
	transform: translateY(-50%) rotate(18deg);
	transform-origin: left center;
}

.tw-pane-fixed i {
	display: none;
}

.tw-pane-fixed > .tw-pane-handle,
.tw-pane-shape-top > .tw-pane-handle,
.tw-pane-has-local-grid > .tw-pane-handle,
.tw-pane-dummy_sash > .tw-pane-handle {
	display: none;
}

.tw-pane-transom-bars {
	position: absolute;
	z-index: 2;
	inset: var(--tw-local-grid-inset);
	pointer-events: none;
}

.tw-pane-partial-bars {
	position: absolute;
	z-index: 5;
	inset: var(--tw-local-grid-inset);
	pointer-events: none;
}

.tw-pane-transom-bars b,
.tw-pane-partial-bars b {
	position: absolute;
	border-radius: 3px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.12)),
		color-mix(in srgb, var(--frame-colour, #102335) 82%, #102335);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.56),
			0 2px 4px rgba(16, 35, 53, 0.14);
}

.tw-window-calculator.is-bar-draw-mode .tw-pane-transom-bars b,
.tw-window-calculator.is-bar-draw-mode .tw-pane-partial-bars b {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.14)),
		rgba(22, 120, 111, 0.92);
}

.tw-pane-transom-bars b {
	left: 0;
	right: 0;
}

.tw-pane-transom-bars b,
.tw-pane-partial-bar-row {
	height: 5px;
	transform: translateY(-50%);
}

.tw-pane-partial-bar-col {
	width: 5px;
	transform: translateX(-50%);
}

.tw-pane-dummy_sash {
	box-shadow:
		inset 0 0 0 3px rgba(255, 255, 255, 0.82),
		inset 0 0 0 9px color-mix(in srgb, var(--frame-colour, #102335) 24%, transparent),
		inset 0 0 0 15px rgba(255, 255, 255, 0.34),
		inset 0 12px 20px rgba(255, 255, 255, 0.34),
		inset 0 -10px 18px rgba(16, 35, 53, 0.1);
}

.tw-pane-dummy_sash::before {
	display: block;
	inset: max(10px, 16%);
	width: auto;
	height: auto;
	border: 2px solid rgba(16, 35, 53, 0.22);
	background: transparent;
}

.tw-pane-upvc_door_left::before,
.tw-pane-upvc_door_right::before,
.tw-pane-french_doors::before {
	left: 50%;
	top: 7%;
	display: block;
	width: 2px;
	height: 86%;
	background: rgba(16, 35, 53, 0.28);
	transform: none;
}

.tw-pane-french_doors::before {
	left: calc(50% - 2px);
	width: 4px;
	background: color-mix(in srgb, var(--frame-colour, #102335) 64%, #102335);
	box-shadow:
		-11px 0 0 rgba(16, 35, 53, 0.18),
		11px 0 0 rgba(16, 35, 53, 0.18);
}

.tw-pane-french_doors::after {
	left: 10%;
	right: 10%;
	top: 65%;
	display: block;
	width: auto;
	height: 2px;
	background: rgba(16, 35, 53, 0.32);
	transform: none;
}

.tw-pane-french_doors::after {
	left: 12%;
	right: 12%;
	top: 64%;
	height: 3px;
}

.tw-pane-upvc_door_left::before,
.tw-pane-upvc_door_right::before {
	display: none;
}

.tw-door-swing,
.tw-door-hinges {
	position: absolute;
	z-index: 2;
	pointer-events: none;
}

.tw-door-swing {
	inset: max(12px, 15%) max(12px, 15%);
}

.tw-door-swing b {
	position: absolute;
	top: 50%;
	display: block;
	width: 48%;
	height: 2px;
	border-radius: 999px;
	background: rgba(16, 35, 53, 0.52);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.55);
}

.tw-door-swing-left b {
	left: 0;
	transform-origin: left center;
}

.tw-door-swing-left b:first-child {
	transform: rotate(28deg);
}

.tw-door-swing-left b:nth-child(2) {
	transform: rotate(-28deg);
}

.tw-door-swing-right b {
	right: 0;
	transform-origin: right center;
}

.tw-door-swing-right b:first-child {
	transform: rotate(28deg);
}

.tw-door-swing-right b:nth-child(2) {
	transform: rotate(-28deg);
}

.tw-door-swing-french {
	inset: max(12px, 16%) max(10px, 12%);
}

.tw-door-swing-french b {
	width: 36%;
}

.tw-door-swing-french b:nth-child(1),
.tw-door-swing-french b:nth-child(2) {
	left: 0;
	transform-origin: left center;
}

.tw-door-swing-french b:nth-child(1) {
	transform: rotate(24deg);
}

.tw-door-swing-french b:nth-child(2) {
	transform: rotate(-24deg);
}

.tw-door-swing-french b:nth-child(3),
.tw-door-swing-french b:nth-child(4) {
	right: 0;
	transform-origin: right center;
}

.tw-door-swing-french b:nth-child(3) {
	transform: rotate(24deg);
}

.tw-door-swing-french b:nth-child(4) {
	transform: rotate(-24deg);
}

.tw-door-swing-outward.tw-door-view-interior,
.tw-door-swing-inward.tw-door-view-exterior {
	opacity: 0.35;
}

.tw-door-swing-inward b {
	background: rgba(15, 127, 118, 0.62);
}

.tw-french-master-badge {
	position: absolute;
	z-index: 4;
	top: 9%;
	display: grid;
	place-items: center;
	width: clamp(16px, 16%, 22px);
	height: clamp(16px, 16%, 22px);
	border-radius: 999px;
	background: var(--tw-accent);
	color: #fff;
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	pointer-events: none;
}

	.tw-french-master-badge.tw-french-master-left {
		left: 24%;
	}

	.tw-french-master-badge.tw-french-master-right {
		right: 24%;
	}

.tw-pane-vent {
	position: absolute;
	z-index: 4;
	left: max(10px, 22%);
	right: max(10px, 22%);
	height: clamp(4px, 4%, 6px);
	border-radius: 999px;
	background:
		repeating-linear-gradient(90deg, rgba(16, 35, 53, 0.65) 0 4px, transparent 4px 8px),
		rgba(255, 255, 255, 0.86);
	box-shadow: 0 1px 2px rgba(16, 35, 53, 0.22);
	pointer-events: none;
}

.tw-pane-vent-head,
.tw-pane-vent-top,
.tw-pane-vent-both {
	top: max(6px, 8%);
}

.tw-pane-vent-sash,
.tw-pane-vent-bottom {
	top: max(16px, 20%);
}

.tw-pane-vent-both::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: calc(100% + 8px);
	height: 6px;
	border-radius: inherit;
	background:
		repeating-linear-gradient(90deg, rgba(16, 35, 53, 0.65) 0 4px, transparent 4px 8px),
		rgba(255, 255, 255, 0.86);
	box-shadow: 0 1px 2px rgba(16, 35, 53, 0.22);
}

.tw-window-calculator.has-panel-infill .tw-pas24-toggle {
	display: none;
}

.tw-door-hinges {
	top: max(10px, 16%);
	bottom: max(10px, 16%);
	display: grid;
	align-content: space-between;
	width: 7px;
}

.tw-door-hinges b {
	display: block;
	width: 7px;
	height: 18px;
	border-radius: 2px;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.75), rgba(255, 255, 255, 0.12)),
		color-mix(in srgb, var(--frame-colour, #102335) 76%, #102335);
	box-shadow: 0 1px 2px rgba(16, 35, 53, 0.26);
}

.tw-door-hinges-left {
	left: 5px;
}

.tw-door-hinges-right {
	right: 5px;
}

.tw-door-hinges-both {
	left: 5px;
	right: 5px;
	width: auto;
	grid-template-columns: 7px 7px;
	grid-template-rows: repeat(3, 18px);
}

.tw-door-hinges-both b:nth-child(1) {
	grid-column: 1;
	grid-row: 1;
}

.tw-door-hinges-both b:nth-child(2) {
	grid-column: 1;
	grid-row: 2;
}

.tw-door-hinges-both b:nth-child(3) {
	grid-column: 1;
	grid-row: 3;
}

.tw-door-hinges-both b:nth-child(4) {
	grid-column: 2;
	grid-row: 1;
}

.tw-door-hinges-both b:nth-child(5) {
	grid-column: 2;
	grid-row: 2;
}

.tw-door-hinges-both b:nth-child(6) {
	grid-column: 2;
	grid-row: 3;
}

.tw-pane-top i {
	left: 50%;
	bottom: max(5px, 6%);
	width: clamp(11px, 15%, 22px);
	height: clamp(22px, 40%, 44px);
	transform: translateX(-50%) rotate(90deg);
}

.tw-pane-top > .tw-pane-handle {
	left: 50%;
	bottom: max(5px, 6%);
	width: clamp(12px, 16%, 24px);
	height: clamp(24px, 42%, 48px);
	transform: translateX(-50%) rotate(90deg);
}

.tw-pane-side_left i,
.tw-pane-tilt_turn_right i,
.tw-pane-upvc_door_left i {
	right: max(7px, 12%);
	top: 50%;
	transform: translateY(-50%);
}

.tw-pane-side_left > .tw-pane-handle,
.tw-pane-tilt_turn_right > .tw-pane-handle,
.tw-pane-upvc_door_left > .tw-pane-handle {
	right: max(7px, 12%);
	top: 50%;
	transform: translateY(-50%);
}

.tw-pane-side_right i,
.tw-pane-tilt_turn_left i,
.tw-pane-upvc_door_right i {
	left: max(7px, 12%);
	top: 50%;
	transform: translateY(-50%) scaleX(-1);
}

.tw-pane-side_right > .tw-pane-handle,
.tw-pane-tilt_turn_left > .tw-pane-handle,
.tw-pane-upvc_door_right > .tw-pane-handle {
	left: max(7px, 12%);
	top: 50%;
	transform: translateY(-50%) scaleX(-1);
}

.tw-pane-french_doors i {
	left: calc(50% - 18px);
	top: 50%;
	transform: translateY(-50%);
}

.tw-pane-french_doors > .tw-pane-handle {
	left: calc(50% - 18px);
	top: 50%;
	transform: translateY(-50%);
}

.tw-pane-french_doors i::after {
	content: "";
	position: absolute;
	left: 30px;
	top: 0;
	width: 26px;
	height: 52px;
	background: transparent url("../images/window-handle-white-realistic-v2.png") center / contain no-repeat;
	filter: drop-shadow(0 2px 2px rgba(16, 35, 53, 0.38));
	transform: scaleX(-1);
}

.tw-pane-french_doors > .tw-pane-handle {
	filter: drop-shadow(30px 0 0 rgba(255, 255, 255, 0.78));
}

.tw-pane-dummy_sash i {
	display: none;
}

.tw-pane-type-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
	gap: 8px;
}

.tw-selected-pane-options {
	display: grid;
	gap: 12px;
	margin: 14px 0;
	padding: 12px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #f8fbfc;
}

.tw-panel-design-grid,
.tw-door-option-grid {
	display: grid;
	gap: 8px;
	margin: 0;
	padding: 0;
	border: 0;
}

.tw-panel-design-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tw-panel-design-grid[hidden],
.tw-door-option-grid[hidden],
.tw-door-option-grid:not(.is-french-selected) .tw-french-master-option {
	display: none !important;
}

.tw-panel-design-card,
.tw-door-option-grid label {
	display: grid;
	gap: 6px;
	min-width: 0;
	padding: 8px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
	cursor: pointer;
}

.tw-door-option-grid label {
	grid-template-columns: auto minmax(0, 1fr);
	align-items: center;
}

.tw-door-hardware-card {
	display: grid;
	grid-template-columns: 92px minmax(0, 1fr);
	gap: 10px;
	align-items: center;
	grid-column: 1 / -1;
	padding: 10px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
}

.tw-door-hardware-card img {
	display: block;
	width: 92px;
	max-width: 100%;
	border-radius: 8px;
	background: #eef3f5;
}

.tw-door-hardware-card .tw-field {
	margin: 0;
}

.tw-french-master-option {
	grid-column: 1 / -1;
	grid-template-columns: 1fr !important;
	cursor: default !important;
}

.tw-panel-design-card input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.tw-panel-design-card:has(input:checked) {
	border-color: var(--tw-accent);
	box-shadow: 0 8px 20px rgba(16, 35, 53, 0.08);
}

.tw-panel-design-card strong {
	color: var(--tw-deep);
	font-size: 12px;
	line-height: 1.15;
	overflow-wrap: anywhere;
}

.tw-panel-design-photo,
.tw-pane-panel-visual {
	position: relative;
	display: block;
	border-radius: 6px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.55), rgba(16, 35, 53, 0.08)),
		#f4f2ea;
	box-shadow:
		inset 0 0 0 2px rgba(255, 255, 255, 0.72),
		inset 0 0 0 6px rgba(16, 35, 53, 0.09);
	overflow: hidden;
}

.tw-panel-design-photo {
	aspect-ratio: 3 / 8;
	min-height: 86px;
}

.tw-pane-panel-visual {
	position: absolute;
	z-index: 1;
	inset: max(8px, 12%);
	pointer-events: none;
}

.tw-panel-design-photo.has-image,
.tw-pane-panel-visual.has-image {
	background-color: var(--tw-panel-render-colour, #f7f7f2);
	background-image: var(--panel-image), linear-gradient(var(--tw-panel-render-colour, #f7f7f2), var(--tw-panel-render-colour, #f7f7f2));
	background-position: center;
	background-repeat: no-repeat;
	background-blend-mode: multiply, normal;
}

.tw-panel-design-photo.has-image {
	background-size: contain, cover;
}

.tw-pane-panel-visual.has-image {
	background-size: 100% 100%, cover;
}

.tw-panel-design-photo.has-image::after,
.tw-pane-panel-visual.has-image::after {
	position: absolute;
	display: none;
	inset: 0;
	z-index: 1;
	content: "";
	pointer-events: none;
	background-image: var(--panel-glass-image, none);
	background-position: center;
	background-repeat: no-repeat;
}

.tw-panel-design-photo.has-image::after {
	background-size: contain;
}

.tw-pane-panel-visual.has-image::after {
	background-size: 100% 100%;
}

.tw-panel-design-tdp_01.has-image::after,
.tw-panel-design-tdp_02.has-image::after,
.tw-panel-design-tdp_03.has-image::after,
.tw-panel-design-tdp_04.has-image::after,
.tw-panel-design-tdp_05.has-image::after,
.tw-panel-design-tdp_06.has-image::after {
	display: block;
}

.tw-panel-design-photo.has-image {
	--tw-panel-render-colour: var(--panel-colour, #f7f7f2);
}

.tw-pane-panel-visual.has-image {
	--tw-panel-render-colour: var(--inside-colour, var(--panel-colour, #f7f7f2));
}

.tw-pane-panel-visual.has-image {
	inset: 0;
	border-radius: 2px;
	box-shadow: none;
}

.tw-panel-design-tdp_01 {
	--panel-glass-image: url("../images/panels/panel-tdp-01-glass.svg");
}

.tw-panel-design-tdp_02 {
	--panel-glass-image: url("../images/panels/panel-tdp-02-glass.svg");
}

.tw-panel-design-tdp_03 {
	--panel-glass-image: url("../images/panels/panel-tdp-03-glass.svg");
}

.tw-panel-design-tdp_04 {
	--panel-glass-image: url("../images/panels/panel-tdp-04-glass.svg?ver=1.2.33");
}

.tw-panel-design-tdp_05 {
	--panel-glass-image: url("../images/panels/panel-tdp-05-glass.svg");
}

.tw-panel-design-tdp_06 {
	--panel-glass-image: url("../images/panels/panel-tdp-06-glass.svg");
}

.tw-pane-panel {
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.54), rgba(16, 35, 53, 0.08)),
		color-mix(in srgb, var(--frame-colour, #f7f7f2) 28%, #f6f1e6);
}

.tw-pane-type[hidden] {
	display: none !important;
}

.tw-pane-type {
	display: grid;
	grid-template-columns: 46px minmax(0, 1fr);
	gap: 8px;
	align-items: center;
	min-height: 58px;
	padding: 8px !important;
	border: 1px solid var(--tw-line) !important;
	border-radius: 8px !important;
	background: #fff !important;
	color: var(--tw-deep) !important;
	text-align: left;
	cursor: pointer;
	appearance: none;
	text-transform: none !important;
	letter-spacing: 0 !important;
}

.tw-pane-type:hover,
.tw-pane-type:focus-visible,
.tw-pane-type.is-selected {
	border-color: var(--tw-accent) !important;
	background: #fff !important;
	color: var(--tw-deep) !important;
	box-shadow: 0 10px 24px rgba(16, 35, 53, 0.08);
}

.tw-pane-type strong {
	color: var(--tw-deep) !important;
	font-size: 13px;
	letter-spacing: 0 !important;
	line-height: 1.15;
	text-transform: none !important;
	overflow-wrap: anywhere;
}

.tw-pane-type-icon {
	position: relative;
	display: block;
	width: 46px;
	height: 34px;
	border: 3px solid var(--tw-deep);
	border-radius: 5px;
	box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.82);
	background:
		linear-gradient(135deg, #fff, #d9e8ed),
		linear-gradient(90deg, transparent 47%, rgba(16, 35, 53, 0.14) 48% 52%, transparent 53%);
}

.tw-pane-type-icon::before,
.tw-pane-type-icon::after {
	content: "";
	position: absolute;
	background: transparent;
}

.tw-pane-type-icon.tw-pane-fixed::before {
	content: "";
	inset: 8px;
	border: 2px solid rgba(16, 35, 53, 0.34);
	border-radius: 2px;
}

.tw-pane-type-icon.tw-pane-top::before {
	content: "";
	left: 9px;
	right: 9px;
	top: 9px;
	height: 2px;
	background: rgba(16, 35, 53, 0.42);
}

.tw-pane-type-icon.tw-pane-side_left::before {
	content: "";
	right: 13px;
	top: 7px;
	bottom: 7px;
	width: 2px;
	background: rgba(16, 35, 53, 0.42);
}

.tw-pane-type-icon.tw-pane-side_right::before {
	content: "";
	left: 13px;
	top: 7px;
	bottom: 7px;
	width: 2px;
	background: rgba(16, 35, 53, 0.42);
}

.tw-pane-type-icon.tw-pane-tilt_turn_left::before,
.tw-pane-type-icon.tw-pane-tilt_turn_right::before {
	content: "";
	top: 7px;
	bottom: 7px;
	width: 2px;
	background: rgba(16, 35, 53, 0.42);
}

.tw-pane-type-icon.tw-pane-tilt_turn_left::before {
	left: 13px;
	box-shadow: 9px -5px 0 -1px rgba(16, 35, 53, 0.42);
}

.tw-pane-type-icon.tw-pane-tilt_turn_right::before {
	right: 13px;
	box-shadow: -9px -5px 0 -1px rgba(16, 35, 53, 0.42);
}

.tw-pane-type-icon::after {
	width: 14px;
	height: 27px;
	border-radius: 0;
	background: transparent url("../images/window-handle-white-realistic-v2.png") center / contain no-repeat;
	filter: drop-shadow(0 1px 1px rgba(16, 35, 53, 0.32));
}

.tw-pane-type-icon.tw-pane-fixed::after,
.tw-pane-type-icon.tw-pane-dummy_sash::after {
	display: none;
}

.tw-pane-type-icon.tw-pane-dummy_sash::before {
	content: "";
	inset: 7px;
	border: 2px solid rgba(16, 35, 53, 0.34);
	border-radius: 2px;
}

.tw-pane-type-icon.tw-pane-upvc_door_left::before,
.tw-pane-type-icon.tw-pane-upvc_door_right::before {
	content: "";
	left: 50%;
	top: 5px;
	bottom: 5px;
	width: 2px;
	background: rgba(16, 35, 53, 0.42);
}

.tw-pane-type-icon.tw-pane-french_doors::before {
	content: "";
	left: 50%;
	top: 5px;
	bottom: 5px;
	width: 2px;
	background: rgba(16, 35, 53, 0.42);
	box-shadow: 0 15px 0 0 rgba(16, 35, 53, 0.28);
}

.tw-pane-type-icon.tw-pane-top::after {
	left: 50%;
	bottom: 2px;
	width: 13px;
	height: 26px;
	transform: translateX(-50%) rotate(90deg);
}

.tw-pane-type-icon.tw-pane-side_left::after,
.tw-pane-type-icon.tw-pane-tilt_turn_right::after,
.tw-pane-type-icon.tw-pane-upvc_door_left::after {
	right: 8px;
	top: 50%;
	transform: translateY(-50%);
}

.tw-pane-type-icon.tw-pane-side_right::after,
.tw-pane-type-icon.tw-pane-tilt_turn_left::after,
.tw-pane-type-icon.tw-pane-upvc_door_right::after {
	left: 8px;
	top: 50%;
	transform: translateY(-50%) scaleX(-1);
}

.tw-pane-type-icon.tw-pane-french_doors::after {
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

.tw-colour-swatch {
	display: block;
	width: 100%;
	height: 42px;
	border-radius: 6px;
	border: 1px solid rgba(16, 35, 53, 0.16);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.16), transparent 45%),
		var(--swatch);
	box-shadow: inset 0 0 0 4px rgba(255, 255, 255, 0.18);
}

.tw-finish-scope label {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.tw-finish-scope input {
	position: static;
	flex: 0 0 auto;
	width: 20px;
	height: 20px;
	margin-top: 2px;
	opacity: 1;
	pointer-events: auto;
	accent-color: var(--tw-accent);
}

.tw-finish-scope span {
	display: grid;
	gap: 4px;
}

.tw-finish-scope.is-hidden {
	display: none;
}

.tw-window-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 280px;
	height: 70px;
	overflow: hidden;
}

.tw-window-icon img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.tw-field > span,
.tw-field label,
.tw-choice-grid legend,
.tw-issue-list legend {
	color: var(--tw-deep);
	font-weight: 850;
}

.tw-option-toggle {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	margin-top: 18px;
	padding: 16px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
	min-width: 0;
}

.tw-option-toggle input {
	width: 20px;
	height: 20px;
	margin-top: 2px;
	accent-color: var(--tw-accent);
}

.tw-option-toggle span {
	display: grid;
	gap: 4px;
}

.tw-window-summary {
	position: sticky;
	top: 96px;
	display: grid;
	gap: 16px;
}

.tw-window-preview {
	display: grid;
	place-items: stretch;
	min-height: 0;
	border-radius: 8px;
	background: linear-gradient(135deg, #f7efe5, #e8f1f3);
}

.tw-window-preview-dual {
	grid-template-columns: 1fr;
	gap: 18px;
	align-items: stretch;
	width: 100%;
	padding: 18px;
}

.tw-window-preview-dual > div {
	display: grid;
	gap: 8px;
	align-content: center;
	justify-items: center;
	min-height: 190px;
	padding: 12px;
	border: 1px solid rgba(16, 35, 53, 0.08);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.42);
}

.tw-window-preview-dual > div > span {
	color: var(--tw-muted);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.tw-window-preview-frame {
	--layout-cols: 2;
	--layout-rows: 2;
	--grid-cols-template: repeat(var(--layout-cols), minmax(0, 1fr));
	--grid-rows-template: repeat(var(--layout-rows), minmax(42px, 1fr));
	--frame-ratio: 1;
	--frame-preview-max-height: 150px;
	--frame-preview-width-cap: 150px;
	--frame-colour: var(--tw-deep);
	--inside-colour: #f7f7f2;
	position: relative;
	display: grid;
	grid-template-columns: var(--grid-cols-template);
	grid-template-rows: var(--grid-rows-template);
	align-items: stretch;
	justify-items: stretch;
	gap: 8px;
	justify-self: center;
	align-self: center;
	width: min(100%, 320px, var(--frame-preview-width-cap));
	aspect-ratio: var(--frame-aspect, 1 / 1);
	height: auto;
	max-height: var(--frame-preview-max-height);
	min-height: 0;
	padding: 18px;
	border: 10px solid var(--frame-colour);
	border-radius: 6px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.36), rgba(16, 35, 53, 0.08)),
		var(--inside-colour);
	box-shadow:
		0 18px 34px rgba(16, 35, 53, 0.12),
		inset 0 0 0 3px rgba(255, 255, 255, 0.45),
		inset 0 0 0 6px rgba(16, 35, 53, 0.08);
}

.tw-window-preview-frame .tw-pane {
	border-width: 4px;
	box-shadow:
		inset 0 0 0 2px rgba(255, 255, 255, 0.82),
		inset 0 0 0 6px color-mix(in srgb, var(--frame-colour, #102335) 14%, transparent),
		inset 0 10px 18px rgba(255, 255, 255, 0.34),
		inset 0 -8px 16px rgba(16, 35, 53, 0.08);
}

.tw-window-preview-frame .tw-local-pane {
	border-width: 1px !important;
}

.tw-window-preview-label {
	margin: -6px 0 0;
	color: var(--tw-muted);
	font-size: 14px;
	font-weight: 750;
}

.tw-window-price {
	margin: -6px 0 0;
	color: var(--tw-deep);
	font-size: 46px;
	font-weight: 900;
	line-height: 1;
}

.tw-price-lines {
	display: grid;
	gap: 0;
	margin: 0;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	overflow: hidden;
}

.tw-price-lines div {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 12px 14px;
	background: #fff;
	border-bottom: 1px solid var(--tw-line);
}

.tw-price-lines div:last-child {
	border-bottom: 0;
}

.tw-price-lines dt {
	color: var(--tw-muted);
	font-weight: 750;
}

.tw-price-lines dd {
	margin: 0;
	color: var(--tw-deep);
	font-weight: 850;
	text-align: right;
}

.tw-cart-window-thumb {
	display: inline-block;
	padding: 8px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #f8fbfc;
}

.tw-cart-window-thumb-thumb .tw-window-drawing-svg {
	display: block;
	width: 118px;
	max-width: 100%;
	height: auto;
}

.tw-cart-window-thumb-large {
	display: block;
	padding: 12px;
	background: #fff;
}

.tw-cart-window-thumb-large .tw-window-drawing-svg {
	display: block;
	width: min(100%, 360px);
	max-width: 360px;
	height: auto;
	margin: 0 auto;
}

.tw-window-drawing-svg .tw-svg-opener {
	stroke: #102335;
	stroke-width: 2.8;
	stroke-opacity: 0.58;
}

.tw-window-drawing-svg .tw-svg-local-transom {
	stroke: #102335;
	stroke-width: 5;
	stroke-opacity: 0.42;
}

.tw-window-drawing-svg .tw-svg-tilt-symbol {
	fill: #102335;
	fill-opacity: 0.65;
	font-family: Arial, sans-serif;
	font-size: 28px;
	font-weight: 800;
	letter-spacing: 3px;
}

.tw-window-drawing-svg .tw-svg-handle-shadow {
	fill: #102335;
	opacity: 0.16;
}

.tw-window-drawing-svg .tw-svg-handle-base {
	fill: #f8fafb;
	stroke: #7f8a90;
	stroke-width: 1;
	stroke-opacity: 0.72;
}

.tw-window-drawing-svg .tw-svg-handle-screw {
	fill: #cbd2d5;
	stroke: #879197;
	stroke-width: 0.7;
}

.tw-window-drawing-svg .tw-svg-handle-lever {
	fill: #f5f7f7;
	stroke: #768188;
	stroke-width: 1.2;
	stroke-linejoin: round;
}

.tw-window-drawing-svg .tw-svg-handle-highlight {
	fill: none;
	stroke: #fff;
	stroke-width: 1.4;
	stroke-linecap: round;
	opacity: 0.62;
}

.tw-window-drawing-svg .tw-svg-hinge {
	fill: #102335;
	fill-opacity: 0.7;
	stroke: #fff;
	stroke-width: 0.8;
	stroke-opacity: 0.68;
}

.tw-window-drawing-svg .tw-svg-panel-face {
	fill: rgba(255, 255, 255, 0.22);
	stroke: rgba(16, 35, 53, 0.18);
	stroke-width: 2;
}

.tw-window-drawing-svg .tw-svg-panel-detail {
	fill: rgba(255, 255, 255, 0.24);
	stroke: rgba(16, 35, 53, 0.28);
	stroke-width: 1.5;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.tw-window-drawing-svg path.tw-svg-panel-detail {
	fill: none;
}

.tw-window-drawing-svg .tw-svg-panel-glass {
	fill: #d8edf3;
	stroke: rgba(16, 35, 53, 0.24);
	stroke-width: 1.6;
}

.tw-window-drawing-svg .tw-svg-vent {
	fill: #ffffff;
	stroke: rgba(16, 35, 53, 0.5);
	stroke-width: 1;
}

.tw-window-drawing-svg .tw-svg-master-leaf {
	fill: #ffffff;
	stroke: #0f7f76;
	stroke-width: 3;
	paint-order: stroke fill;
	font-family: Arial, sans-serif;
	font-size: 18px;
	font-weight: 900;
}

.tw-window-drawing-svg .tw-svg-door-swing-outward.tw-svg-door-view-interior,
.tw-window-drawing-svg .tw-svg-door-swing-inward.tw-svg-door-view-exterior {
	stroke-opacity: 0.28;
}

.tw-window-drawing-svg .tw-svg-cill {
	stroke: #102335;
	stroke-width: 1;
	stroke-opacity: 0.22;
}

.tw-summary-actions {
	display: grid;
	gap: 10px;
}

.tw-design-list {
	display: grid;
	gap: 10px;
	max-height: 360px;
	overflow: auto;
	padding-right: 2px;
}

.tw-design-list-empty {
	margin: 0;
	padding: 14px;
	border: 1px dashed var(--tw-line);
	border-radius: 8px;
	background: #f8fbfc;
	color: var(--tw-muted);
	font-weight: 750;
}

.tw-design-list-item {
	display: grid;
	grid-template-columns: 86px minmax(0, 1fr) auto;
	gap: 12px;
	align-items: center;
	padding: 12px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
}

.tw-design-thumb {
	display: grid;
	place-items: center;
	width: 86px;
	min-height: 74px;
	padding: 6px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #f8fbfc;
}

.tw-design-thumb .tw-window-preview-frame {
	--frame-preview-width-cap: 72px;
	width: 72px;
	max-width: 100%;
	min-height: 0;
	gap: 2px;
	padding: 6px;
	border-width: 3px;
	box-shadow:
		0 8px 14px rgba(16, 35, 53, 0.08),
		inset 0 0 0 2px rgba(255, 255, 255, 0.5);
}

.tw-design-thumb .tw-pane {
	border-width: 2px;
}

.tw-design-thumb-empty {
	display: block;
	width: 58px;
	aspect-ratio: 1;
	border: 2px dashed var(--tw-line);
	border-radius: 8px;
	background: #fff;
}

.tw-design-list-item h3,
.tw-request-panel h3 {
	margin: 0;
	color: var(--tw-deep);
	font-size: 16px;
	line-height: 1.25;
}

.tw-design-list-item p {
	margin: 4px 0 0;
	color: var(--tw-muted);
	font-size: 13px;
	font-weight: 750;
	line-height: 1.35;
}

.tw-design-actions {
	display: grid;
	gap: 6px;
}

.tw-design-edit,
.tw-design-remove {
	min-height: 32px;
	padding: 6px 9px;
	border: 1px solid var(--tw-line);
	border-radius: 6px;
	background: #fff;
	color: var(--tw-muted);
	font-size: 12px;
	font-weight: 850;
	cursor: pointer;
}

.tw-design-edit {
	border-color: rgba(15, 127, 118, 0.28);
	color: var(--tw-accent);
}

.tw-request-panel {
	display: grid;
	gap: 12px;
	padding: 16px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #f8fbfc;
}

.tw-request-field-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-top: 0;
}

.tw-request-status {
	min-height: 20px;
	margin: 0;
	color: var(--tw-muted);
	font-size: 13px;
	font-weight: 850;
	line-height: 1.35;
}

.tw-request-status[data-status="success"] {
	color: var(--tw-accent);
}

.tw-request-status[data-status="error"] {
	color: #b42318;
}

.tw-summary-actions .tw-window-pdf,
.tw-summary-actions .tw-list-pdf {
	background: #fff !important;
	color: var(--tw-deep) !important;
	border-color: var(--tw-line) !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
}

.tw-summary-actions .tw-window-pdf:hover,
.tw-summary-actions .tw-list-pdf:hover {
	border-color: var(--tw-accent) !important;
	color: var(--tw-accent) !important;
}

.tw-cart-pdf-tool {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	max-width: 100%;
	min-width: 0;
	margin: 0;
	padding: 18px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
}

.tw-cart-pdf-tool > div {
	max-width: 100%;
	min-width: 0;
}

.tw-cart-window-drawings {
	display: grid;
	gap: 16px;
	box-sizing: border-box;
	max-width: 100%;
	min-width: 0;
	margin: 0 0 24px;
	padding: 18px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: var(--tw-soft);
}

.tw-cart-pdf-tool .tw-eyebrow {
	margin: 0 0 4px;
}

.tw-cart-pdf-tool h2 {
	margin: 0;
	color: var(--tw-deep);
	font-size: 24px;
	line-height: 1.15;
	overflow-wrap: anywhere;
}

.tw-cart-window-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
	gap: 14px;
}

.tw-cart-window-card {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	gap: 14px;
	align-items: center;
	max-width: 100%;
	min-width: 0;
	padding: 14px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
}

.tw-cart-window-card > div {
	max-width: 100%;
	min-width: 0;
}

.tw-cart-window-card h3 {
	margin: 0 0 4px;
	color: var(--tw-deep);
	font-size: 17px;
	line-height: 1.2;
	overflow-wrap: anywhere;
}

.tw-cart-window-card p {
	margin: 0 0 10px;
	color: var(--tw-muted);
	font-size: 13px;
	font-weight: 750;
	line-height: 1.35;
	overflow-wrap: anywhere;
}

.tw-cart-item-name {
	display: grid;
	gap: 4px;
	max-width: 100%;
	min-width: 0;
}

.tw-cart-item-name strong {
	color: var(--tw-deep);
	font-size: 17px;
	line-height: 1.2;
	overflow-wrap: anywhere;
}

.tw-cart-item-name em,
.tw-cart-item-qty {
	color: var(--tw-muted);
	font-size: 13px;
	font-style: normal;
	font-weight: 800;
	line-height: 1.35;
	overflow-wrap: anywhere;
}

body.woocommerce-cart .woocommerce {
	max-width: 1180px;
	margin: 0 auto;
	padding: 42px 24px 70px;
}

body.woocommerce-cart .woocommerce-cart-form,
body.woocommerce-cart .cart-collaterals .cart_totals {
	overflow: hidden;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
	box-shadow: 0 16px 36px rgba(16, 35, 53, 0.08);
}

body.woocommerce-cart table.shop_table {
	margin: 0;
	border: 0 !important;
	border-collapse: separate;
	border-spacing: 0;
}

body.woocommerce-cart table.shop_table.cart,
body.woocommerce-cart table.shop_table.cart tbody,
body.woocommerce-cart table.shop_table.cart tr,
body.woocommerce-cart table.shop_table.cart th,
body.woocommerce-cart table.shop_table.cart td {
	max-width: 100%;
	white-space: normal !important;
}

body.woocommerce-cart table.shop_table th {
	padding: 16px !important;
	background: var(--tw-soft);
	color: var(--tw-deep);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

body.woocommerce-cart table.shop_table td {
	padding: 18px 16px !important;
	border-top: 1px solid var(--tw-line) !important;
	vertical-align: middle;
	overflow-wrap: anywhere;
}

body.woocommerce-cart table.shop_table .product-thumbnail,
body.woocommerce-cart table.shop_table th.product-thumbnail {
	display: none;
}

body.woocommerce-cart table.shop_table .product-remove {
	width: 48px;
	text-align: center;
}

body.woocommerce-cart table.shop_table .product-name {
	max-width: 100%;
	min-width: 0;
	text-align: left !important;
}

body.woocommerce-cart table.shop_table .product-name > a {
	display: none;
}

body.woocommerce-cart table.shop_table td.product-name {
	min-width: 270px;
}

body.woocommerce-cart table.shop_table .product-thumbnail {
	width: 150px;
}

body.woocommerce-cart table.shop_table .product-thumbnail img {
	display: none;
}

body.woocommerce-cart table.shop_table .product-name a {
	color: var(--tw-deep);
	font-weight: 900;
	text-decoration: none;
}

body.woocommerce-cart table.shop_table dl.variation {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px 14px;
	margin: 10px 0 0;
	font-size: 13px;
}

body.woocommerce-cart table.shop_table .product-name dl.variation {
	display: none;
}

body.woocommerce-cart table.shop_table dl.variation dt,
body.woocommerce-cart table.shop_table dl.variation dd {
	margin: 0;
	padding: 0;
}

body.woocommerce-cart table.shop_table dl.variation dt {
	color: var(--tw-muted);
	font-weight: 850;
}

body.woocommerce-cart table.shop_table dl.variation dd {
	color: var(--tw-ink);
}

body.woocommerce-cart table.shop_table .actions {
	background: #fff;
}

body.woocommerce-cart .cart-collaterals {
	margin-top: 24px;
}

body.woocommerce-cart .cart_totals h2 {
	margin: 0;
	padding: 18px;
	background: var(--tw-soft);
	color: var(--tw-deep);
	font-size: 22px;
}

body.woocommerce-cart .wc-proceed-to-checkout {
	padding: 18px !important;
}

body.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
body.woocommerce-cart .woocommerce button.button {
	border-radius: 8px !important;
	background: var(--tw-accent) !important;
	color: #fff !important;
	font-weight: 900 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
}

.tw-cart-window-report[hidden] {
	display: none !important;
}

.tw-window-reference-control {
	display: grid;
	gap: 8px;
	max-width: 230px;
}

.tw-window-reference-control .tw-btn,
.tw-cart-pdf-tool .tw-btn,
.tw-cart-window-card .tw-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	width: auto;
	max-width: 100%;
	min-width: 0;
	min-height: 40px;
	padding: 10px 14px !important;
	font-size: 13px !important;
	line-height: 1.2 !important;
	text-align: center;
	letter-spacing: 0 !important;
	text-transform: none !important;
	white-space: normal !important;
	overflow-wrap: anywhere;
}

@media (max-width: 900px) {
	.tw-cart-pdf-tool {
		align-items: stretch;
		flex-direction: column;
	}

	.tw-cart-pdf-tool .tw-btn {
		width: 100%;
	}

	.tw-cart-window-card {
		grid-template-columns: 1fr;
		justify-items: start;
	}

	.tw-cart-window-card .tw-btn {
		width: 100%;
	}

	body.woocommerce-cart table.shop_table td.product-name {
		min-width: 0;
	}
}

.tw-window-reference-sheet {
	display: grid;
	gap: 18px;
	padding: 22px;
	border: 1px solid var(--tw-line);
	border-radius: 8px;
	background: #fff;
}

.tw-reference-header p {
	margin: 0 0 4px;
	color: var(--tw-muted);
	font-size: 12px;
	font-weight: 850;
	text-transform: uppercase;
}

.tw-reference-header h2 {
	margin: 0;
	color: var(--tw-deep);
	font-size: 28px;
	line-height: 1.15;
}

.tw-reference-views {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
	align-items: start;
}

.tw-reference-views > div {
	display: grid;
	gap: 8px;
}

.tw-reference-views h3 {
	margin: 0;
	color: var(--tw-deep);
	font-size: 16px;
}

.tw-reference-specs {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.tw-reference-specs th,
.tw-reference-specs td {
	padding: 9px 10px;
	border: 1px solid var(--tw-line);
	text-align: left;
	vertical-align: top;
}

.tw-reference-specs th {
	width: 34%;
	background: var(--tw-soft);
	color: var(--tw-deep);
	font-weight: 850;
}

.tw-reference-note {
	margin: 0;
	color: var(--tw-muted);
	font-size: 12px;
	line-height: 1.45;
}



@media (max-width: 900px) {
	.tw-cart-pdf-tool {
		align-items: stretch;
		flex-direction: column;
	}

	.tw-cart-pdf-tool .tw-btn {
		width: 100%;
	}

	.tw-cart-window-card {
		grid-template-columns: 1fr;
		justify-items: start;
	}

	.tw-cart-window-card .tw-btn {
		width: 100%;
	}

	body.woocommerce-cart table.shop_table td.product-name {
		min-width: 0;
	}
}

@media (max-width: 680px) {
	html,
	body.trafford-site,
	body.trafford-site .wrapper,
	body.trafford-site .inner-wrapper,
	body.trafford-site #main,
	body.trafford-site #primary,
	body.trafford-site .wdt-elementor-container-fluid,
	body.trafford-site .container {
		width: 100% !important;
		min-width: 0 !important;
		max-width: 100% !important;
		overflow-x: hidden !important;
	}

	.tw-header-inner,
	.tw-footer-inner,
	.tw-footer-bottom,
	.tw-page > section {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box;
		padding-left: 18px;
		padding-right: 18px;
	}

	.tw-subhero p,
	.tw-section p {
		width: 100% !important;
		max-width: 100% !important;
	}

	.tw-subhero h1,
	.tw-section-heading,
	.tw-section-heading h2,
	.tw-section-heading p {
		width: calc(100vw - 36px) !important;
		max-width: calc(100vw - 36px) !important;
	}

	.tw-page > section.tw-home-slider {
		max-width: 100% !important;
		padding-left: 0;
		padding-right: 0;
	}

	.tw-page > section.tw-proof-strip {
		padding-left: 0 !important;
		padding-right: 0 !important;
		overflow: hidden;
	}

	.tw-subhero p {
		width: 320px !important;
		max-width: calc(100vw - 36px) !important;
	}

	.tw-brand-text strong {
		font-size: 16px;
	}

	.tw-nav-list {
		display: grid;
		grid-template-columns: 1fr;
		align-items: stretch;
		width: 100%;
	}

	.tw-nav-list > li {
		min-width: 0;
	}

	.tw-nav-list > .menu-item-has-children {
		grid-column: 1 / -1;
	}

	.tw-nav-list a {
		width: 100%;
		white-space: normal !important;
		overflow-wrap: anywhere;
		font-size: 14px;
		padding-left: 9px;
		padding-right: 9px;
	}

	.tw-nav-list .sub-menu {
		display: none;
	}

	.tw-hero {
		padding-top: 44px;
		min-height: 0;
	}

	.tw-home-slider {
		min-height: 900px;
	}

	.tw-slider-track,
	.tw-slider-slide {
		min-height: 900px;
	}

	.tw-slider-slide {
		width: 100vw !important;
		max-width: 100vw !important;
		gap: 24px;
		padding: 30px 18px 116px;
	}

	.tw-slider-copy,
	.tw-slider-copy .tw-eyebrow,
	.tw-slider-copy .tw-lede,
	.tw-slider-copy h1,
	.tw-slider-copy h2 {
		width: 320px !important;
		max-width: calc(100vw - 36px) !important;
	}

	.tw-slider-media {
		width: calc(100vw - 36px) !important;
		max-width: calc(100vw - 36px) !important;
	}

	.tw-slider-copy .tw-eyebrow {
		font-size: 12px;
		line-height: 1.4;
	}

	.tw-slider-copy h1,
	.tw-slider-copy h2 {
		font-size: 31px;
		line-height: 1.08;
		overflow-wrap: normal;
		word-break: normal;
	}

	.tw-hero h1,
	.tw-subhero h1 {
		width: 320px !important;
		max-width: calc(100vw - 36px) !important;
		font-size: 26px;
		line-height: 1.08;
		overflow-wrap: break-word;
		word-break: normal;
	}

	.tw-lede,
	.tw-subhero p {
		font-size: 18px;
	}

	.tw-hero-media {
		min-height: 300px;
	}

	.tw-slider-media {
		height: 300px;
		min-height: 300px;
	}

	.tw-slider-controls {
		left: 18px !important;
		right: auto !important;
		bottom: 24px;
		display: grid;
		grid-template-columns: 40px minmax(0, 1fr) 40px;
		align-items: center;
		justify-items: center;
		width: 90vw !important;
		max-width: 354px !important;
		min-width: 0 !important;
		box-sizing: border-box;
		gap: 6px;
		padding: 6px;
		overflow: visible;
	}

	.tw-slider-prev {
		grid-column: 1;
		justify-self: start;
	}

	.tw-slider-next {
		grid-column: 3;
		justify-self: end;
		display: inline-grid !important;
	}

	.tw-slider-arrow {
		width: 40px !important;
		min-width: 40px !important;
		height: 40px !important;
		min-height: 40px !important;
	}

	.tw-slider-dots {
		grid-column: 2;
		justify-self: center;
		justify-content: center;
		min-width: 0;
		gap: 6px;
	}

	.tw-slider-dot {
		width: 20px !important;
		min-width: 20px !important;
	}

	.tw-slider-dot.is-active,
	.tw-slider-dot:hover,
	.tw-slider-dot:focus-visible {
		width: 32px !important;
	}

	.tw-slide-count {
		display: none;
	}

	.tw-slider-small-img {
		width: 42% !important;
		border-width: 5px;
	}

	.tw-product-hero {
		padding-top: 50px;
		padding-bottom: 50px;
	}

	.tw-product-hero h1 {
		font-size: 36px;
	}

	.tw-product-hero-image {
		min-height: 300px;
	}

	.tw-product-card span,
	.tw-product-card h2,
	.tw-product-card p,
	.tw-product-card strong {
		display: block;
		width: auto !important;
		max-width: min(300px, calc(100vw - 72px)) !important;
		margin-left: 18px;
		margin-right: 18px;
	}

	.tw-product-card p {
		max-width: min(280px, calc(100vw - 72px)) !important;
	}

	.tw-product-grid,
	.tw-product-card {
		width: 100%;
		max-width: calc(100vw - 36px);
	}

	.tw-card-grid,
	.tw-card-grid-compact,
	.tw-product-grid,
	.tw-feature-grid,
	.tw-service-links,
	.tw-logo-grid,
	.tw-proof-strip,
	.tw-process ol,
	.tw-footer-inner,
	.tw-field-grid,
	.tw-choice-grid,
	.tw-layout-grid,
	.tw-colour-grid,
	.tw-finish-scope,
	.tw-product-seo-copy,
	.tw-cta-band {
		grid-template-columns: 1fr;
	}

	.tw-window-calculator-section {
		padding-left: 18px;
		padding-right: 18px;
	}

	.tw-window-calculator,
	.tw-window-builder,
	.tw-tool-panel {
		width: 100%;
		max-width: 100%;
	}

	.tw-tool-panel {
		padding: 18px;
	}

	.tw-window-options .tw-section-heading,
	.tw-window-options .tw-section-heading h2,
	.tw-window-options .tw-section-heading p {
		width: calc(100vw - 72px) !important;
		max-width: calc(100vw - 72px) !important;
	}

	.tw-window-options .tw-choice-grid,
	.tw-window-options .tw-layout-grid,
	.tw-window-options .tw-shape-grid,
	.tw-window-options .tw-assembly-grid,
	.tw-window-options .tw-pane-designer,
	.tw-window-options .tw-colour-grid,
	.tw-window-options .tw-finish-scope,
	.tw-window-options .tw-field-grid,
	.tw-window-options .tw-option-toggle,
	.tw-window-summary .tw-price-lines,
	.tw-window-summary .tw-disclaimer,
	.tw-window-summary .tw-btn {
		width: min(300px, calc(100vw - 90px));
		max-width: min(300px, calc(100vw - 90px));
	}

	.tw-window-options .tw-section-heading h2 {
		width: 270px !important;
		max-width: calc(100vw - 96px) !important;
		font-size: 27px;
		line-height: 1.12;
		overflow-wrap: break-word;
	}

	.tw-window-options .tw-section-heading p {
		width: 270px !important;
		max-width: calc(100vw - 96px) !important;
		font-size: 16px;
		line-height: 1.45;
	}

	.tw-window-design-card {
		width: 100%;
		max-width: 100%;
		min-height: 0;
		overflow: hidden;
	}

	.tw-window-icon {
		max-width: 220px;
		height: 58px;
	}

	.tw-layout-mini {
		max-width: 220px;
	}

		.tw-pane-designer {
			grid-template-columns: 1fr;
		}

			.tw-measure-shell {
				grid-template-columns: 82px minmax(0, 1fr) 82px;
				gap: 8px;
			}

			.tw-measure-line input,
			.tw-measure-segment input {
				width: 82px;
				min-height: 31px;
				padding: 6px 5px;
				font-size: 12px;
		}

		.tw-measure-line span,
		.tw-measure-line em,
		.tw-measure-segment span,
		.tw-measure-segment em {
			padding: 1px 2px;
			font-size: 9px;
		}

		.tw-pane-editor-frame {
			grid-template-rows: var(--grid-rows-template);
			min-height: 150px;
			padding: 10px;
		}

	.tw-pane-type-grid {
		grid-template-columns: 1fr;
	}

	.tw-window-preview-dual {
		grid-template-columns: 1fr;
	}

	.tw-cart-pdf-tool {
		align-items: stretch;
		flex-direction: column;
	}

	.tw-cart-window-card {
		grid-template-columns: 1fr;
		justify-items: start;
	}

	.tw-reference-views {
		grid-template-columns: 1fr;
	}

	.tw-colour-swatch {
		max-width: 220px;
	}

	.tw-window-preview {
		min-height: 180px;
	}

	.tw-window-preview-frame {
		height: auto;
		min-height: 0;
	}

	.tw-window-price {
		font-size: 38px;
	}

	.tw-price-lines div {
		align-items: flex-start;
	}

	.tw-proof-strip div,
	.tw-proof-strip span {
		min-width: 0;
		max-width: 100%;
		overflow-wrap: anywhere;
		white-space: normal !important;
	}

	.tw-proof-strip div {
		width: 100%;
		box-sizing: border-box;
		padding-left: 22px;
		padding-right: 22px;
	}

	.tw-proof-strip span {
		display: block;
	}

	.tw-footer-brand {
		grid-column: auto;
	}

	.tw-section,
	.tw-subhero {
		padding-top: 56px;
		padding-bottom: 56px;
	}

	.tw-health-section {
		padding-left: 18px;
		padding-right: 18px;
	}

	.tw-score-wrap {
		grid-template-columns: 1fr;
	}

	.tw-estimate-box {
		display: grid;
	}

	.tw-product-seo-copy {
		margin-bottom: 56px;
	}

	.tw-door-designer-frame {
		height: 680px;
		min-height: 680px;
	}
}

@media (max-width: 1180px) {
	.tw-window-builder {
		grid-template-columns: 1fr;
	}

	.tw-window-summary {
		position: static;
		top: auto;
	}

	.tw-window-preview {
		min-height: 0;
	}

	.tw-window-preview-dual {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1000px) {
	.tw-window-calculator.is-bar-draw-mode .tw-pane-designer {
		grid-template-columns: 1fr;
		width: calc(100vw - 28px);
		max-height: calc(100vh - 28px);
		padding: 16px;
	}

	.tw-window-calculator.is-bar-draw-mode .tw-pane-toolbar {
		top: -16px;
		margin: -16px -16px 14px;
		padding: 14px 16px 12px;
	}

	.tw-window-calculator.is-bar-draw-mode .tw-pane-controls {
		max-height: none;
		overflow: visible;
	}

	.tw-window-calculator.is-bar-draw-mode .tw-pane-editor-frame {
		--frame-editor-width-cap: min(88vw, 720px);
	}
}

@media (max-width: 900px) {
	.tw-choice-grid,
	.tw-layout-grid,
	.tw-shape-grid,
	.tw-assembly-grid,
	.tw-colour-grid,
	.tw-early-spec-grid {
		grid-template-columns: repeat(auto-fit, minmax(min(100%, 150px), 1fr));
	}

	.tw-summary-actions .tw-btn {
		width: 100%;
		white-space: normal !important;
		overflow-wrap: anywhere;
	}

	.tw-measure-shell {
		grid-template-columns: minmax(76px, 0.2fr) minmax(0, 1fr) minmax(76px, 0.2fr);
		gap: 8px;
	}

	.tw-measure-line input,
	.tw-measure-segment input {
		width: clamp(70px, 18vw, 96px);
	}
}

@media (max-width: 720px) {
	.tw-window-options .tw-section-heading,
	.tw-window-options .tw-section-heading h2,
	.tw-window-options .tw-section-heading p,
	.tw-window-options .tw-choice-grid,
	.tw-window-options .tw-layout-grid,
	.tw-window-options .tw-shape-grid,
	.tw-window-options .tw-assembly-grid,
	.tw-window-options .tw-pane-designer,
	.tw-window-options .tw-colour-grid,
	.tw-window-options .tw-finish-scope,
	.tw-window-options .tw-field-grid,
	.tw-window-options .tw-option-toggle,
	.tw-window-summary .tw-price-lines,
	.tw-window-summary .tw-disclaimer,
	.tw-window-summary .tw-btn {
		width: 100% !important;
		max-width: 100% !important;
	}

	.tw-window-options .tw-section-heading h2,
	.tw-window-options .tw-section-heading p {
		width: 100% !important;
		max-width: 100% !important;
	}

	.tw-window-calculator.is-bar-draw-mode .tw-window-options .tw-pane-designer {
		width: calc(100vw - 20px) !important;
		max-width: calc(100vw - 20px) !important;
	}

	.tw-measure-shell {
		grid-template-columns: minmax(0, 1fr);
		grid-template-rows: auto;
	}

	.tw-window-calculator.is-bar-draw-mode .tw-measure-shell {
		grid-template-columns: minmax(0, 1fr);
		grid-template-rows: auto;
	}

	.tw-window-calculator.is-bar-draw-mode .tw-pane-editor-frame {
		--frame-visual-max-height: min(58vh, 520px);
		min-height: 220px;
	}

	.tw-measure-overall-width,
	.tw-measure-overall-height,
	.tw-measure-cols,
	.tw-measure-rows,
	.tw-pane-editor-frame {
		grid-column: 1;
	}

	.tw-measure-overall-width {
		grid-row: 1;
	}

	.tw-pane-editor-frame {
		grid-row: 2;
	}

	.tw-measure-overall-height {
		grid-row: 3;
		flex-direction: row;
		min-height: 38px;
	}

	.tw-measure-cols {
		grid-row: 4;
	}

	.tw-measure-rows {
		grid-row: 5;
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(126px, 1fr));
		grid-template-rows: none;
	}

	.tw-measure-segment-row {
		flex-direction: row;
	}

	.tw-measure-overall-height::before,
	.tw-measure-segment-row::before {
		left: 0;
		right: 0;
		top: 50%;
		bottom: auto;
		border-left: 0;
		border-top: 1px dashed rgba(16, 35, 53, 0.34);
	}

	.tw-measure-overall-height::before {
		border-top-width: 2px;
	}

	.tw-request-field-grid,
	.tw-reference-views {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 520px) {
	.tw-window-preview-dual,
	.tw-design-list-item {
		grid-template-columns: 1fr;
	}

	.tw-design-thumb {
		width: 100%;
	}

	.tw-design-actions {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.tw-door-hardware-card {
		grid-template-columns: 1fr;
	}

	.tw-pane-type {
		grid-template-columns: 40px minmax(0, 1fr);
	}

	.tw-pane-type-icon {
		width: 40px;
	}
}
