/*
 * Snow Day Calculator – Page Template Styles
 * Integrates with Hello Elementor Child theme.
 *
 * Brand palette:
 *   #0E1F2F  navy    – headings, dark text
 *   #2591B7  blue    – CTA, accents
 *   #A9DDF3  sky     – light accents
 *   #D4EEF9  mist    – card backgrounds
 *   #F4F5F6  ash     – section backgrounds
 */

/* =========================================================
   Custom properties
   ========================================================= */
.snow-page {
	--snow-navy   : #0E1F2F;
	--snow-blue   : #2591B7;
	--snow-sky    : #A9DDF3;
	--snow-mist   : #D4EEF9;
	--snow-ash    : #F4F5F6;
	--snow-white  : #ffffff;
	--snow-radius : 14px;
	--snow-shadow : 0 4px 24px rgba(14, 31, 47, 0.09);
	--snow-trans  : 0.22s ease;

	--prob-clear      : #27ae60;
	--prob-unlikely   : #e6a817;
	--prob-possible   : #e67e22;
	--prob-likely     : #2591B7;
	--prob-very-likely: #0E1F2F;
}

/* =========================================================
   HERO – centered, contains the calculator
   ========================================================= */
.snow-hero {
	position: relative;
	min-height: 560px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--snow-navy);
	background-size: cover;
	background-position: center;
	overflow: hidden;
	text-align: center;
}

.snow-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		160deg,
		rgba(14, 31, 47, 0.94) 0%,
		rgba(37, 145, 183, 0.50) 100%
	);
}

.snow-hero__inner {
	position: relative;
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
	padding: 140px 32px 80px 32px;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.snow-hero__overline {
	display: inline-block;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--snow-sky);
	margin: 0 0 14px;
}

.snow-hero__title {
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	color: var(--snow-white);
	line-height: 1.12;
	margin: 0 0 16px;
}

.snow-hero__subtitle {
	font-size: 1.0625rem;
	color: rgba(169, 221, 243, 0.85);
	margin: 0 0 36px;
	line-height: 1.6;
	max-width: 480px;
}

/* =========================================================
   HERO CALCULATOR WIDGET
   ========================================================= */
.snow-hero-calc {
	width: 100%;
	max-width: 560px;
}

/* ---- Input: pill form ---- */
.snow-hero-form {
	display: flex;
	align-items: center;
	gap: 8px;
	background: rgba(255, 255, 255, 0.10);
	border: 1.5px solid rgba(255, 255, 255, 0.22);
	border-radius: 60px;
	padding: 6px 6px 6px 20px;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	transition: border-color var(--snow-trans);
}

.snow-hero-form:focus-within {
	border-color: rgba(255, 255, 255, 0.50);
}

.snow-hero-form__pin {
	flex-shrink: 0;
	color: rgba(255, 255, 255, 0.45);
}

.snow-hero-input {
	flex: 1;
	min-width: 0;
	background: transparent;
	border: none;
	outline: none;
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--snow-white);
	letter-spacing: 0.08em;
	height: 44px;
}

.snow-hero-input::placeholder {
	color: rgba(255, 255, 255, 0.38);
	font-weight: 400;
	letter-spacing: 0;
}

.snow-hero-btn {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	height: 46px;
	padding: 0 22px;
	background: var(--snow-blue);
	color: var(--snow-white);
	border: none;
	border-radius: 40px;
	font-size: 0.9375rem;
	font-weight: 600;
	cursor: pointer;
	white-space: nowrap;
	transition: background var(--snow-trans);
}

.snow-hero-btn:hover { background: #1a7a9f; }
.snow-hero-btn__arrow { flex-shrink: 0; }

/* ---- Error ---- */
.snow-page [hidden] { display: none !important; }

.snow-hero-error {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 12px;
	padding: 10px 16px;
	background: rgba(192, 57, 43, 0.18);
	border-left: 3px solid #e74c3c;
	border-radius: 6px;
	color: #ff9b8a;
	font-size: 0.9rem;
	text-align: left;
}

/* ---- Loading ---- */
.snow-hero-loading {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	padding: 28px 0;
}

.snow-loading__spinner {
	color: rgba(255, 255, 255, 0.8);
	animation: snow-spin 0.9s linear infinite;
}

@keyframes snow-spin {
	from { transform: rotate(0deg); }
	to   { transform: rotate(360deg); }
}

.snow-loading__text {
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.65);
	margin: 0;
}

/* ---- Result (inside hero) ---- */
.snow-hero-result {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
}

.snow-hero-result .snow-result__inner {
	width: 100%;
	background: var(--snow-white);
	border-radius: 16px;
	padding: 32px 28px;
	box-shadow: 0 8px 40px rgba(14, 31, 47, 0.25);
}

.snow-hero-back-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 22px;
	background: rgba(255, 255, 255, 0.10);
	border: 1.5px solid rgba(255, 255, 255, 0.22);
	border-radius: 30px;
	color: rgba(255, 255, 255, 0.80);
	font-size: 0.875rem;
	font-weight: 500;
	cursor: pointer;
	transition: background var(--snow-trans), color var(--snow-trans);
}

.snow-hero-back-btn:hover {
	background: rgba(255, 255, 255, 0.18);
	color: var(--snow-white);
}

/* ---- Disclaimer ---- */
.snow-hero-disclaimer {
	margin-top: 16px;
	font-size: 0.8rem;
	color: rgba(255, 255, 255, 0.509);
	line-height: 1.5;
	text-align: center;
}

/* =========================================================
   RESULT BODY (injected by JS into #snow-result-inner)
   ========================================================= */
.snow-result-body {
	text-align: center;
}

/* ---- All Clear ---- */
.snow-result-body--clear .snow-result-body__icon-circle {
	width: 68px;
	height: 68px;
	border-radius: 50%;
	background: var(--prob-clear);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 18px;
	color: #fff;
}

.snow-result-body__headline {
	font-size: 1.625rem;
	font-weight: 800;
	color: var(--snow-navy);
	margin: 0 0 10px;
	line-height: 1.2;
}

.snow-result-body--clear .snow-result-body__headline {
	color: var(--prob-clear);
}

.snow-result-body__location {
	font-size: 1rem;
	color: #5a6a7a;
	margin: 0;
	line-height: 1.6;
}

.snow-result-body__location strong {
	color: var(--snow-navy);
}

/* ---- Snow Day States ---- */
.snow-result-body__probability {
	font-size: 3.75rem;
	font-weight: 900;
	line-height: 1;
	color: var(--snow-navy);
	margin: 0 0 10px;
}

.snow-result-body__badge {
	display: inline-block;
	padding: 5px 18px;
	border-radius: 30px;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--snow-white);
	margin-bottom: 14px;
}

.snow-result-body__badge--unlikely    { background: var(--prob-unlikely); }
.snow-result-body__badge--possible    { background: var(--prob-possible); }
.snow-result-body__badge--likely      { background: var(--prob-likely); }
.snow-result-body__badge--very-likely { background: var(--prob-very-likely); }

.snow-result-body--unlikely   .snow-result-body__probability { color: var(--prob-unlikely); }
.snow-result-body--possible   .snow-result-body__probability { color: var(--prob-possible); }
.snow-result-body--likely     .snow-result-body__probability { color: var(--prob-likely); }
.snow-result-body--very-likely .snow-result-body__probability { color: var(--prob-very-likely); }

/* Detail chips */
.snow-result-body__details {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin-top: 18px;
}

.snow-detail-chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 14px;
	background: var(--snow-ash);
	border-radius: 30px;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--snow-navy);
}

.snow-detail-chip svg { flex-shrink: 0; color: var(--snow-blue); }

/* =========================================================
   CONTENT AREA – single column, no sidebar
   ========================================================= */
.snow-content-area {
	max-width: 860px;
	margin: 0 auto;
	padding: 56px 32px 80px;
}

/* =========================================================
   SECTION BASE
   ========================================================= */
.snow-section {
	padding-top: 56px;
	border-top: 1px solid #e8edf2;
	margin-bottom: 0;
}

.snow-section:first-child {
	padding-top: 0;
	border-top: none;
}

.snow-section__title {
	font-size: 1.625rem;
	font-weight: 700;
	color: var(--snow-navy);
	margin: 0 0 16px;
	scroll-margin-top: 100px;
}

/* Prose */
.snow-content-area p,
.snow-content-area li {
	font-size: 1rem;
	color: #3d4d5c;
	line-height: 1.8;
}

.snow-content-area h3 {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--snow-navy);
	margin: 32px 0 10px;
}

.snow-content-area ul,
.snow-content-area ol {
	padding-left: 22px;
	margin: 10px 0 18px;
}

.snow-content-area li { margin-bottom: 6px; }

/* =========================================================
   PROBABILITY LEVEL CARDS
   ========================================================= */
.snow-scale-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	margin-top: 20px;
}

.snow-scale-card {
	border-radius: 12px;
	background: var(--snow-ash);
	overflow: hidden;
	border: 1px solid rgba(0, 0, 0, 0.07);
	transition: box-shadow var(--snow-trans), transform var(--snow-trans);
}

.snow-scale-card:hover {
	box-shadow: var(--snow-shadow);
	transform: translateY(-3px);
}

.snow-scale-card__swatch { height: 6px; }
.snow-scale-card--clear    .snow-scale-card__swatch { background: var(--prob-clear); }
.snow-scale-card--low      .snow-scale-card__swatch { background: var(--prob-unlikely); }
.snow-scale-card--moderate .snow-scale-card__swatch { background: var(--prob-possible); }
.snow-scale-card--high     .snow-scale-card__swatch { background: var(--prob-likely); }

.snow-scale-card__body { padding: 16px; }

.snow-scale-card__range {
	display: block;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: 6px;
}

.snow-scale-card--clear    .snow-scale-card__range { color: var(--prob-clear); }
.snow-scale-card--low      .snow-scale-card__range { color: var(--prob-unlikely); }
.snow-scale-card--moderate .snow-scale-card__range { color: var(--prob-possible); }
.snow-scale-card--high     .snow-scale-card__range { color: var(--prob-likely); }

.snow-scale-card__title {
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--snow-navy);
	margin: 0 0 6px;
}

.snow-scale-card__desc {
	font-size: 0.8125rem;
	color: #5a6a7a;
	line-height: 1.5;
	margin: 0;
}

/* =========================================================
   FAQ ACCORDION
   ========================================================= */
.snow-accordion {
	margin-top: 20px;
	border-top: 1px solid #dde4ec;
}

.snow-accordion__item {
	border-bottom: 1px solid #dde4ec;
	transition: background var(--snow-trans), border-radius var(--snow-trans);
}

.snow-accordion__item.is-open {
	background: var(--snow-ash);
	border-radius: 10px;
	border-bottom-color: transparent;
	margin-bottom: 6px;
}

.snow-accordion__trigger {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 20px 0;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	gap: 16px;
}

.snow-accordion__trigger span:first-child {
	font-size: 1rem;
	font-weight: 600;
	color: var(--snow-navy);
	line-height: 1.4;
	white-space: normal;
	word-break: break-word;
}

.snow-accordion__trigger:hover span:first-child { color: var(--snow-blue); }

.snow-accordion__item .snow-accordion__trigger,
.snow-accordion__item .snow-accordion__trigger:hover,
.snow-accordion__item .snow-accordion__trigger:focus {
	background: none;
	background-color: transparent;
}

.snow-accordion .is-open .snow-accordion__trigger { padding: 20px 25px; }
.snow-accordion .is-open .snow-accordion__panel   { padding: 0 25px; }

/* Plus/Minus icon */
.snow-accordion__icon {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	border: 2px solid #c0ccd8;
	position: relative;
	transition: border-color var(--snow-trans), background var(--snow-trans);
}

.snow-accordion__icon::before,
.snow-accordion__icon::after {
	content: '';
	position: absolute;
	background: #6b7c8d;
	border-radius: 2px;
	transition: transform var(--snow-trans), background var(--snow-trans);
}

.snow-accordion__icon::before {
	width: 10px; height: 2px;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%);
}

.snow-accordion__icon::after {
	width: 2px; height: 10px;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%);
}

.snow-accordion__trigger.is-open .snow-accordion__icon {
	border-color: var(--snow-blue);
	background: var(--snow-mist);
}

.snow-accordion__trigger.is-open .snow-accordion__icon::before,
.snow-accordion__trigger.is-open .snow-accordion__icon::after { background: var(--snow-blue); }

.snow-accordion__trigger.is-open .snow-accordion__icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.snow-accordion__panel { overflow: hidden; }

.snow-accordion__content { padding: 0 0 20px; }

.snow-accordion__content p {
	margin: 0 0 10px;
	font-size: 0.9375rem;
	color: #4a5a6a;
	line-height: 1.7;
}

.snow-accordion__content p:last-child { margin-bottom: 0; }

.snow-accordion__content ul {
	padding-left: 20px;
	margin: 8px 0 10px;
}

.snow-accordion__content li {
	font-size: 0.9375rem;
	color: #4a5a6a;
	line-height: 1.7;
	margin-bottom: 6px;
}

/* =========================================================
   EDITABLE CMS CONTENT
   ========================================================= */
.snow-content h2 { font-size: 1.625rem; font-weight: 700; color: var(--snow-navy); margin-bottom: 14px; }
.snow-content h3 { font-size: 1.125rem;  font-weight: 700; color: var(--snow-navy); margin-top: 32px; margin-bottom: 10px; }
.snow-content p  { font-size: 1rem; color: #3d4d5c; line-height: 1.8; }
.snow-content ul,
.snow-content ol { font-size: 1rem; color: #3d4d5c; line-height: 1.8; padding-left: 22px; }
.snow-content li { margin-bottom: 6px; }

/* =========================================================
   SCROLL MARGIN
   ========================================================= */
.snow-section[id] { scroll-margin-top: 100px; }

/* =========================================================
   RESPONSIVE – tablet (≤ 1024px)
   ========================================================= */
@media ( max-width: 1024px ) {
	.snow-content-area { padding: 40px 24px 64px; }
	.snow-scale-grid { grid-template-columns: repeat(2, 1fr); }
}

/* =========================================================
   RESPONSIVE – mobile (≤ 600px)
   ========================================================= */
@media ( max-width: 600px ) {
	.snow-hero { min-height: 480px; }
	.snow-hero__inner { padding: 120px 20px 60px 20px; }
	.snow-hero__title { font-size: 2rem; }

	.snow-hero-form {
		flex-direction: column;
		border-radius: 16px;
		padding: 14px 16px;
		gap: 10px;
	}

	.snow-hero-form__pin { display: none; }
	.snow-hero-input { width: 100%; height: 44px; text-align: center; }
	.snow-hero-btn { width: 100%; justify-content: center; height: 48px; border-radius: 10px; }

	.snow-hero-result .snow-result__inner { padding: 24px 16px; }
	.snow-result-body__probability { font-size: 3rem; }

	.snow-scale-grid { grid-template-columns: 1fr; }
	.snow-content-area { padding: 32px 16px 48px; }
}
