/*
 * Scandinavian Ski Shop — theme.css
 * Hand-authored CSS ready to use as-is. If you prefer to work in SCSS,
 * edit assets/scss/main.scss and recompile with:
 *   sass assets/scss/main.scss assets/css/theme.css --style=compressed
 */

:root {
	--brand-primary:   #0c3a5f;
	--brand-secondary: #d6481b;
	--brand-accent:    #f4a62a;
	--brand-snow:      #f5f7fa;
	--brand-mist:      #e8eef3;
	--brand-ink:       #0b1f33;
	--brand-slate:     #4a5a6b;
	--brand-pine:      #1e3a2f;
	--font-display:    'Fraunces', Georgia, serif;
	--font-body:       'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--radius-sm:       0.5rem;
	--radius-md:       0.75rem;
	--radius-lg:       1.25rem;
	--radius-xl:       2rem;
	--shadow-sm:       0 1px 2px rgba(11, 31, 51, 0.05), 0 1px 3px rgba(11, 31, 51, 0.06);
	--shadow-md:       0 10px 30px rgba(11, 31, 51, 0.08);
	--shadow-lg:       0 20px 50px rgba(11, 31, 51, 0.12);
}

/* Base */
html, body { overflow-x: hidden; max-width: 100%; }
body {
	font-family: var(--font-body);
	color: var(--brand-ink);
	background-color: #fff;
	-webkit-font-smoothing: antialiased;
	text-wrap: balance;
}
a { color: var(--brand-primary); text-underline-offset: 0.15em; }
a:hover { color: var(--brand-secondary); }
img { max-width: 100%; height: auto; }
.skip-link {
	position: absolute; top: 0; left: 0; padding: 0.75rem 1rem;
	background: var(--brand-ink); color: #fff; z-index: 999;
}

/* Typography */
h1, h2, h3, h4,
.display-1, .display-2, .display-3, .display-4, .display-5, .display-6 {
	font-family: var(--font-display);
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--brand-ink);
}
h1, .display-2, .display-3, .display-4 { line-height: 1.05; }
h2 { line-height: 1.15; }

.eyebrow {
	font-family: var(--font-body);
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: 0.75rem;
	font-weight: bold;
	color: var(--brand-secondary);
	margin-bottom: 0.75rem;
}

.prose { font-size: 1.0625rem; line-height: 1.7; }
.prose p, .prose ul, .prose ol { margin-bottom: 1.25rem; }
.prose h2 { margin-top: 2.25rem; }
.prose h3 { margin-top: 1.75rem; }

/* Buttons */
.btn {
	border-radius: 999px;
	font-weight: 600;
	letter-spacing: 0.01em;
	padding: 0.65rem 1.4rem;
}
.btn-lg { padding: 0.85rem 1.75rem; }
.btn-primary {
	--bs-btn-bg: var(--brand-primary);
	--bs-btn-border-color: var(--brand-primary);
	--bs-btn-hover-bg: #09304e;
	--bs-btn-hover-border-color: #09304e;
	--bs-btn-active-bg: #09304e;
	--bs-btn-active-border-color: #09304e;
}
.btn-outline-primary {
	--bs-btn-color: var(--brand-primary);
	--bs-btn-border-color: var(--brand-primary);
	--bs-btn-hover-bg: var(--brand-primary);
	--bs-btn-hover-border-color: var(--brand-primary);
}
.btn-outline-light {
	--bs-btn-color: #fff;
	--bs-btn-border-color: rgba(255,255,255,0.7);
	--bs-btn-hover-bg: #fff;
	--bs-btn-hover-color: var(--brand-primary);
}
.btn-white {
	--bs-btn-bg: #fff;
	--bs-btn-border-color: #fff;
	--bs-btn-color: var(--brand-primary);
	--bs-btn-hover-bg: var(--brand-snow);
	--bs-btn-hover-border-color: var(--brand-snow);
	--bs-btn-hover-color: var(--brand-primary);
	--bs-btn-active-bg: var(--brand-mist);
	--bs-btn-active-border-color: var(--brand-mist);
	--bs-btn-active-color: var(--brand-primary);
}

/* Layout */
.section { padding-block: clamp(3rem, 6vw, 6rem); }
.section--alt { background-color: var(--brand-snow); }
.section-header__title { font-size: clamp(1.75rem, 3vw, 2.75rem); }

/* Header */
.utility-bar {
	background-color: var(--brand-ink);
	color: #fff;
	font-size: 0.825rem;
	padding-block: 0.55rem;
}
.utility-bar a { color: #fff; text-decoration: none; }
.utility-bar a:hover { color: var(--brand-accent); }
.utility-bar .nap__sep { opacity: 0.5; }

.site-brand-bar {
	background: linear-gradient(180deg, #fff 0%, var(--brand-snow) 100%);
}
.site-brand {
	display: inline-block;
	text-decoration: none;
	color: var(--brand-ink);
	font-family: var(--font-display);
	text-align: left;
}
@media (min-width: 992px) {
	.site-brand {
		text-align: center;
	}
}
.site-brand__top {
	display: block;
	font-size: clamp(2.25rem, 4vw, 3.25rem);
	font-weight: 600;
	line-height: 1;
	letter-spacing: -0.01em;
}
.site-brand__sub {
	display: block;
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--brand-slate);
	margin-top: 0.5rem;
}
.site-brand__tagline { letter-spacing: 0.25em; }

.site-nav {
	border-top: 1px solid var(--brand-mist);
	border-bottom: 1px solid var(--brand-mist);
	background: #fff;
	padding-block: 0;
}
.site-nav .navbar-nav { gap: 0.25rem; align-items: center; }
.site-nav .nav-link {
	color: var(--brand-ink);
	font-weight: 600;
	letter-spacing: 0.08em;
	font-size: 0.8125rem;
	text-transform: uppercase;
	padding: 1.1rem 1rem;
	border-bottom: 2px solid transparent;
	transition: border-color 0.15s ease, color 0.15s ease;
}
.site-nav .nav-link:hover,
.site-nav .nav-link.active {
	color: var(--brand-primary);
	border-bottom-color: var(--brand-secondary);
}
@media (max-width: 991.98px) {
	.site-nav .nav-link { padding: 0.75rem 0; border-bottom: none; }
	.site-nav .navbar-nav { gap: 0; padding-block: 0.5rem; }
}
.navbar-toggler { border: 1px solid var(--brand-mist); padding: 0.4rem 0.6rem; }
.navbar-toggler:focus { box-shadow: 0 0 0 0.15rem rgba(12,58,95,0.25); }

/* Mobile menu toggle (in brand bar) */
.site-menu-toggle {
	position: absolute;
	left: 15px;
	top: 50%;
	transform: translateY(-50%);
	background: transparent;
	border: 1px solid var(--brand-mist);
	border-radius: var(--radius-sm);
	padding: 0.4rem 0.6rem;
	cursor: pointer;
	line-height: 1;
}
.site-menu-toggle:focus { box-shadow: 0 0 0 0.15rem rgba(12,58,95,0.25); outline: none; }
.site-menu-toggle .navbar-toggler-icon {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%230c3a5f' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.5' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
	display: block;
	width: 1.5em;
	height: 1.5em;
}

/* Hide desktop nav bar on mobile — modal replaces it */
@media (max-width: 991.98px) {
	.site-nav { display: none; }
	.site-brand-bar { text-align: left; }
	.site-brand-bar .container {
		display: flex;
		align-items: center;
		gap: 1.5em;
	}
	.site-menu-toggle {
		position: static;
		transform: none;
		flex-shrink: 0;
	}
}

/* Mobile nav modal */
.mobile-nav {
	position: fixed;
	inset: 0;
	z-index: 1050;
	background: var(--brand-ink);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease;
}
.mobile-nav.is-open {
	opacity: 1;
	pointer-events: auto;
}
@media (min-width: 992px) {
	.mobile-nav { display: none !important; }
}
.mobile-nav__close {
	position: absolute;
	top: 1.25rem;
	right: 1.25rem;
	background: transparent;
	border: none;
	color: #fff;
	font-size: 1.75rem;
	line-height: 1;
	cursor: pointer;
	padding: 0.5rem;
	opacity: 0.6;
	transition: opacity 0.15s ease;
}
.mobile-nav__close:hover { opacity: 1; }
.mobile-nav__list {
	list-style: none;
	padding: 0;
	margin: 0;
	text-align: center;
}
.mobile-nav__list li + li { margin-top: 0.25rem; }
.mobile-nav__list a {
	display: block;
	font-family: var(--font-display);
	font-size: clamp(2rem, 7vw, 2.75rem);
	font-weight: 600;
	color: rgba(255,255,255,0.75);
	text-decoration: none;
	letter-spacing: -0.01em;
	padding: 0.25rem 0;
	transition: color 0.15s ease;
}
.mobile-nav__list a:hover,
.mobile-nav__list .current-menu-item > a { color: #fff; }

/* Hero */
.hero {
	position: relative;
	padding-block: clamp(4rem, 10vw, 8rem);
	background-size: cover;
	background-position: center;
	color: #fff;
	overflow: hidden;
}

.hero--gradient {
	background: linear-gradient(135deg, #0c3a5f 0%, #0b1f33 50%, #1e3a2f 100%);
}
.hero--gradient::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 15% 20%, rgba(255,255,255,0.08) 0, transparent 40%),
		radial-gradient(circle at 85% 80%, rgba(244,166,42,0.12) 0, transparent 40%);
	pointer-events: none;
}
.hero > .container { position: relative; }
.hero__eyebrow {
	color: rgba(255,255,255,0.8); 
	font-weight: bold !important;
}
.hero__title {
	font-size: clamp(2.5rem, 6vw, 4.75rem);
	font-weight: 600;
	margin-bottom: 1rem;
	max-width: 20ch;
	color: #fff;
}
.hero__subtitle {
	color: #fff;
	font-weight: bold;
	max-width: 60ch;
	font-size: clamp(1.05rem, 1.3vw, 1.25rem);
}

@media (max-width: 575.98px) {
	.hero__ctas,
	.cta-card__actions {
		flex-direction: column;
		align-items: stretch;
	}
	.hero__ctas .btn,
	.cta-card__actions .btn { width: 100%; }
}

/* Page header */
.page-header {
	background-color: var(--brand-snow);
    background-size: cover;
    background-position: center;
    border-bottom: 1px solid var(--brand-mist);
    min-height: 300px;
    display: flex;
    align-items: center;
}
@media(min-width:768px){
	.page-header {
	    min-height: 485px;
	}
}
.page-header--image {
	color: #fff;
	background-color: var(--brand-ink);
	position: relative;
}
.page-header--image::after {
	content: "";
	position: absolute; inset: 0;
	background: linear-gradient(135deg, rgba(12,31,51,0.72), rgba(12,31,51,0.45));
	pointer-events: none;
}
.page-header--image > .container { position: relative; z-index: 1; }
.page-header--image .page-header__subtitle,
.page-header--image .eyebrow { color: rgba(255,255,255); }
.page-header__title {
 font-size: clamp(2rem, 4vw, 3.25rem); 
 margin-bottom: 0.75rem; 
 color: #fff;
}
.page-header__subtitle { 
	max-width: 60ch; margin-inline: auto;
	font-weight: bold;
}

/* Service cards */
.service-card {
	background: #fff;
	border: 1px solid var(--brand-mist);
	border-radius: var(--radius-lg);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
	position: relative;
}
.service-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
	border-color: transparent;
}
.service-card__icon {
	width: 3rem; height: 3rem;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 999px;
	background: var(--brand-mist);
	color: var(--brand-primary);
	font-size: 1.5rem;
}
.service-card__link {
	display: inline-flex; align-items: center; gap: 0.25rem;
	color: var(--brand-primary);
	font-weight: 600;
	text-decoration: none;
}
.service-card__link:hover { color: var(--brand-secondary); }
.service-card__link .bi { transition: transform 0.15s ease; }
.service-card:hover .service-card__link .bi { transform: translateX(3px); }

/* About teaser */
.section--about { background: #fff; }
.about-media, .about-figure {
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--brand-mist);
	aspect-ratio: 5 / 4;
	position: relative;
}
.about-media img, .about-figure img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.about-media__placeholder,
.about-figure__placeholder {
	width: 100%; height: 100%;
	background: var(--brand-mist);
	color: var(--brand-slate);
	font-size: 3rem;
}

/* Brands */
.section--brands { background: var(--brand-snow); }
.brand-list__heading {
	display: flex; align-items: center; gap: 0.75rem;
	letter-spacing: 0.2em;
	color: var(--brand-slate);
}
.brand-list__dot {
	width: 0.5rem; height: 0.5rem; border-radius: 999px;
	background-color: var(--brand-secondary);
	display: inline-block;
}
.brand-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.75rem 1.5rem;
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: 500;
	color: var(--brand-ink);
}
@media (min-width: 576px) { .brand-list { grid-template-columns: repeat(3, 1fr); } }
.brand-list li {
	padding-block: 0.5rem;
	border-bottom: 1px dashed rgba(12,31,51,0.12);
}

/* Hours */
.section--hours { background: #fff; }
.hours-tabs .nav-pills { gap: 0.5rem; flex-wrap: wrap; }
.hours-tabs .nav-link {
	padding: 0.85rem 1.5rem;
	border-radius: 999px;
	background: var(--brand-mist);
	color: var(--brand-ink);
	font-weight: 600;
	border: 1px solid transparent;
	transition: background 0.15s ease, color 0.15s ease;
}
.hours-tabs .nav-link:hover { background: #fff; border-color: var(--brand-mist); }
.hours-tabs .nav-link.active { background: var(--brand-primary); color: #fff; }
.hours-tabs__sub { letter-spacing: 0.15em; opacity: 0.8; }
.hours-grid__item {
	border: 1px solid var(--brand-mist);
	border-radius: var(--radius-md);
	background: #fff;
	text-align: center;
}
.hours-grid__day { letter-spacing: 0.18em; color: var(--brand-slate); }
.hours-grid__time {
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: 600;
}
.hours-grid__time--closed {
	color: var(--brand-secondary);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

/* Rate / tune / info cards */
.rate-card,
.tune-card,
.info-card,
.contact-details,
.alert-card {
	background: #fff;
	border: 1px solid var(--brand-mist);
	border-radius: var(--radius-lg);
}
.rate-card__title { font-family: var(--font-display); }
.rate-list__item { border-bottom: 1px dashed rgba(12,31,51,0.1); }
.rate-list__item:last-child { border-bottom: none; }
.rate-list__label { color: var(--brand-ink); }
.rate-list__price {
	font-family: var(--font-display);
	font-weight: 600;
	color: var(--brand-primary);
	font-size: 1.125rem;
}
.tune-card { background: var(--brand-snow); text-align: center; }
.tune-card__price { color: var(--brand-primary); font-family: var(--font-display); font-weight: 700; }
.tune-card__title { letter-spacing: 0.12em; color: var(--brand-slate); }
.tune-card__details { color: var(--brand-ink); }
.alert-card { background: var(--brand-snow); }
.alert-card--accent {
	background: linear-gradient(135deg, #fff7e6, #fef1d6);
	border-color: rgba(244,166,42,0.35);
}
.alert-card--accent .eyebrow { color: #8a5a10; }
.info-card {
    background: linear-gradient(135deg, var(--brand-primary), #082a47);
    color: #fff;
    border: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1em;
}
.info-card .eyebrow { color: rgba(255,255,255,0.8); }
.info-card h2 { color: #fff; }
.contact-details { background: var(--brand-snow); }
.contact-list dt { letter-spacing: 0.18em; color: var(--brand-slate); font-size: 0.7rem; }
.contact-list dd { font-family: var(--font-display); font-size: 1.125rem; }
.contact-map iframe { border: 0; width: 100%; height: 100%; border-radius: var(--radius-lg); }

/* Staff */
.staff-card {
	background: #fff;
	border: 1px solid var(--brand-mist);
	border-radius: var(--radius-lg);
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.staff-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.staff-card__avatar {
	width: 4rem; height: 4rem; margin-inline: auto;
	border-radius: 999px;
	background: var(--brand-mist);
	color: var(--brand-primary);
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 1.75rem;
}

/* CTA */
.section--cta { background: var(--brand-snow); }
.cta-card {
	background: linear-gradient(135deg, #0c3a5f, #0b1f33);
	color: #fff;
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-lg);
	position: relative;
	overflow: hidden;
}
.cta-card::after {
	content: "";
	position: absolute; inset: 0;
	background:
		radial-gradient(circle at 20% 0%, rgba(244,166,42,0.2) 0, transparent 45%),
		radial-gradient(circle at 100% 100%, rgba(214,72,27,0.18) 0, transparent 40%);
	pointer-events: none;
}
.cta-card > * { position: relative; z-index: 1; }
.cta-card__eyebrow, .cta-card__title { color: #fff; }
.cta-card__subtitle { color: rgba(255,255,255,0.85); max-width: 55ch; margin-inline: auto; }
.cta-card .btn-outline-primary {
	--bs-btn-color: #fff;
	--bs-btn-border-color: rgba(255,255,255,0.7);
	--bs-btn-hover-bg: #fff;
	--bs-btn-hover-color: var(--brand-primary);
	--bs-btn-hover-border-color: #fff;
}

/* Footer */
.site-footer { background: var(--brand-ink); color: #fff; }
.site-footer a { color: #fff; text-decoration: none; }
.site-footer a:hover { color: var(--brand-accent); text-decoration: underline; }
.site-footer__brand { font-family: var(--font-display); letter-spacing: -0.01em; }
.site-footer .text-muted { color: rgba(255,255,255,0.6) !important; }
.site-footer__heading { color: rgba(255,255,255,0.6) !important; letter-spacing: 0.2em; }
.site-footer__nav ul { letter-spacing: 0.2em; color: rgba(255,255,255,0.7); }
.site-footer__copy { color: rgba(255,255,255,0.55) !important; }

/* Social */
.social-links__link {
	display: inline-flex; align-items: center; justify-content: center;
	width: 2.25rem; height: 2.25rem;
	border-radius: 999px;
	background: rgba(255,255,255,0.1);
	color: inherit;
	text-decoration: none;
	transition: transform 0.15s ease, background 0.15s ease, color 0.15s ease;
}
.site-footer .social-links__link { background: rgba(255,255,255,0.08); }
.utility-bar .social-links__link { background: rgba(255,255,255,0.12); }
.social-links__link:hover {
	transform: translateY(-1px);
	background: var(--brand-accent);
	color: var(--brand-ink);
}

.site-footer .social-links__link:hover i::before, .utility-bar .social-links__link:hover i::before  {
	color: #0b1f33;
}

.social-links--sm .social-links__link { width: 1.75rem; height: 1.75rem; font-size: 0.9rem; }
.social-links--lg .social-links__link { width: 2.5rem; height: 2.5rem; font-size: 1.15rem; }

/* Search + misc */
.search-form .form-control { border-radius: 999px; padding: 0.75rem 1.25rem; }
.pagination .page-link { color: var(--brand-primary); }
.pagination .active .page-link { background: var(--brand-primary); border-color: var(--brand-primary); }

/* Print */
@media print {
	.utility-bar, .site-nav, .site-footer, .cta-card, .hero { display: none !important; }
	body { color: #000; }
}
