
/* NEWSLETTER SECTION */


section.newsletter { width: 100%; }

textarea { 
	resize: none; 
	outline: none;
	border: none;
	background-color: transparent;
	box-shadow: none;
	box-sizing: border-box;
	overflow: hidden;
	width: 100%;
	height: 100%;
}

.notch.news-notch {
	background: var(--color-dark-sand);
}

.newsletter .content, .notch.news-notch .notch-left, .notch.news-notch .notch-right {
	background: var(--color-sand);
}

.notch.news-notch .notch-center svg path {
	fill: var(--color-sand);
}

.newsletter .content {
    position: relative;
}

.newsletter .grid {
    position: sticky;
    top: 0;
    z-index: 1;
	display: grid;
    min-height: 100dvh;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(4, 1fr);
    gap: 1.5vw var(--grid-gap-x);
	padding: var(--spacing-section-top) var(--spacing-wrapper);
}

.new1 {
    grid-column: span 4 / span 4;
    display: flex;
	justify-content: space-between;
    align-items:center;
}

.new2 {
    grid-column: span 4 / span 4;
    grid-row-start: 2;
    display: flex;
	justify-content: space-between;
    align-items:center;
}

.new3 {
    grid-column: span 4 / span 4;
    grid-row-start: 3;
    display: flex;
    justify-content: center;
    align-items:center;
}

.new4 {
    grid-column: span 3 / span 3;
    grid-row-start: 4;
    display: flex;
    align-items:center;
}

.new5 {
    grid-column-start: 4;
    grid-row-start: 4;
	align-content: center;
    align-items:center;
}

.new5 p {
	margin: 0;
	text-align: right;
	font-size: clamp(12px, 0.9vw, 16px);
	font-weight: 500;
	line-height: clamp(14px, 1vw, 19px);
	letter-spacing: clamp(-0.16px, -0.016vw, 0px);
	text-transform: uppercase;
}

.newsletter .wrapper {
    height: 100dvh;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: var(--spacing-section-top) var(--spacing-wrapper);
}

.newsletter-form {
    position: relative;
    z-index: 2;
	width: 40%;
    min-width: 550px;
    height: auto;
    max-height:100%;
	justify-self: center;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.newsletter video {
	width: 100%;
	height: auto;
	aspect-ratio: 640 / 400;
	object-fit: cover;
	object-position: center;
}

.newsletter-header {
	border-radius: var(--border-radius-md) var(--border-radius-md) 0 0;
	aspect-ratio: 640 / 400;
	background-color: var(--color-orange);
	position: relative;
	overflow: hidden;
}

.newsletter-header .sml-text {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 2.8%;
}

.sml-text p {
	margin: 0;
	font-size: clamp(12px, 0.9vw, 16px);
	font-weight: 400;
	line-height: 1;
	text-transform: uppercase;
	color: var(--color-sand);
}

.sml-text svg {
	width: clamp(12px, 0.9vw, 16px);
	height: clamp(12px, 0.9vw, 16px);
}

.newsletter-body {
	border-radius: 0 0 var(--border-radius-md) var(--border-radius-md);
	background-color: var(--color-orange);
    overflow: clip;
}

.pd-block {
    padding: 4% 6.25% 0;
}

.newsletter-body h3, .newsletter-body p {
	margin: 0;
	color: var(--color-sand);
}

.newsletter-body h3 {
	font-size: clamp(24px, 1.8vw, 34.22px);
	font-style: normal;
	font-weight: 400;
	line-height: 1.052;
	letter-spacing: clamp(0, 0.02vw, 0.274px);
	margin-bottom: clamp(16px, 1.2vw, 20px);
    text-wrap: balance;
}

.newsletter-body .subtitle {
    font-size: clamp(16px, 1.3vw, 22px);
	font-weight: 400;
	line-height: 1.27;
    margin-bottom: clamp(24px, 1.5vw, 30px);
    text-wrap: balance;
}


/* CONTACT PAGE */

.contact-page .notch { display: none; }
.contact-page .newsletter .grid {
	width: 100%;
}

.contact-page .newsletter .wrapper {
	height:auto;
	min-height: 100dvh;
	margin-top: -100dvh;
}

/* Form: one field per row, textarea full width, submit below disclaimers centered.
   Uses .contact-page .newsletter prefix for higher specificity than form.css rules. */
.contact-page .newsletter .form-container form .parent {
    grid-template-rows: 1fr 1fr 1fr 1fr auto auto auto;
}

.contact-page .newsletter .form-container form .div1 {
    grid-column: 1 / 4;
    grid-row: 1;
}

.contact-page .newsletter .form-container form .div2 {
    grid-column: 1 / 4;
    grid-row: 2;
}

.contact-page .newsletter .form-container form .div3 {
    grid-column: 1 / 4;
    grid-row: 3;
}

.contact-page .newsletter .form-container form .div4 {
    grid-column: 1 / 4;
    grid-row: 4;
}

.contact-page .newsletter .form-container form .div5 {
    grid-column: 1 / 4;
    grid-row: 5;
    min-height: 120px;
}

.contact-page .newsletter .form-container form .disclaimer {
    grid-column: 1 / 4;
    grid-row: 6;
}

.contact-page .newsletter .form-container form .div6 {
    grid-column: 1 / 4;
    grid-row: 7;
    align-self: auto;
    justify-items: center;
}

@media (max-width: 1700px) {
	.newsletter-form { width: 50%; min-width:550px; }
}

@media (max-width: 1500px) {
	.newsletter-form { width: 60%; min-width:600px; }
}


@media (max-width: 1024px) {
	.newsletter-form { width: 60%; }
}

@media (max-width: 768px) {
    .newsletter-form {
        min-width: 300px;
        width: 88%;
        max-height: unset;
    }
    .newsletter .grid .h2 {
        font-size: var(--font-size-heading-h3);
        line-height: 1;
        letter-spacing: var(--letter-spacing-heading-h3);
    }
    .newsletter .grid {
        grid-template-rows: repeat(4, auto);
    }

    .newsletter .wrapper { height:auto; min-height:100dvh; }
	.contact-page .newsletter .wrapper { margin-top:0; min-height: none; padding-bottom: var(--spacing-gap-large-vertical); }
	.contact-page .newsletter .grid { display:none; }
}

@media (max-width: 500px) {
    .newsletter-form {
        width: 100%;
    }
}

