:root {
	--black: #000000;
	--ink: #1d1d1f;
	--ink-2: #424245;
	--ink-3: #6e6e73;
	--line: #d2d2d7;
	--light: #f5f5f7;
	--white: #ffffff;
	--blue: #0071e3;
	--blue-hover: #0077ed;
	--green: #34c759;
}

body.wlan-landing {
	margin: 0;
	font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Inter', sans-serif;
	background: var(--white);
	color: var(--ink);
	-webkit-font-smoothing: antialiased;
	line-height: 1.5;
	letter-spacing: -0.01em;
}

.wlan-landing * { box-sizing: border-box; }

.wlan-nav {
	position: fixed; top: 0; left: 0; right: 0;
	z-index: 100; height: 48px;
	background: rgba(0,0,0,0.8);
	backdrop-filter: saturate(180%) blur(20px);
	-webkit-backdrop-filter: saturate(180%) blur(20px);
}
.wlan-nav-inner {
	max-width: 1024px; margin: 0 auto;
	padding: 0 22px; height: 100%;
	display: flex; align-items: center; justify-content: space-between;
}
.wlan-logo {
	font-size: 21px; font-weight: 600; letter-spacing: -0.5px;
	color: var(--white); text-decoration: none;
}
.wlan-logo .dot { color: var(--blue); font-weight: 700; }
.wlan-nav-links {
	display: flex; gap: 0; list-style: none; align-items: center;
	margin: 0; padding: 0;
}
.wlan-nav-links li { padding: 0; }
.wlan-nav-links a {
	color: rgba(255,255,255,0.85);
	text-decoration: none;
	font-size: 12px;
	font-weight: 400;
	padding: 0 12px;
	letter-spacing: -0.01em;
	transition: color 0.3s;
}
.wlan-nav-links a:hover { color: var(--white); }
.wlan-nav-portal { font-weight: 500 !important; }

.wlan-hero {
	background: var(--black);
	color: var(--white);
	padding: 100px 20px 60px;
	text-align: center;
	overflow: hidden;
	position: relative;
}
.wlan-hero-glow {
	position: absolute;
	top: -200px; left: 50%;
	transform: translateX(-50%);
	width: 1200px; height: 800px;
	background: radial-gradient(ellipse at center, rgba(0, 113, 227, 0.25) 0%, transparent 60%);
	pointer-events: none;
}
.wlan-hero-content { position: relative; z-index: 1; max-width: 980px; margin: 0 auto; }
.wlan-hero h1 {
	font-size: clamp(48px, 9vw, 96px);
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -0.04em;
	margin: 0 0 12px;
	color: var(--white);
}
.wlan-hero h2 {
	font-size: clamp(22px, 3vw, 32px);
	font-weight: 400;
	color: rgba(255,255,255,0.85);
	margin: 0 0 24px;
	letter-spacing: -0.01em;
}
.wlan-hero-tagline {
	font-size: clamp(16px, 2vw, 21px);
	color: rgba(255,255,255,0.7);
	max-width: 600px;
	margin: 0 auto 32px;
	font-weight: 400;
}
.wlan-hero-links {
	display: flex; justify-content: center; gap: 32px; flex-wrap: wrap;
	font-size: 19px;
	margin-bottom: 60px;
}
.wlan-hero-links a {
	color: var(--blue);
	text-decoration: none;
	font-weight: 400;
}
.wlan-hero-links a:hover { text-decoration: underline; }
.wlan-hero-links a::after {
	content: ' ›';
	display: inline-block;
	transition: transform 0.2s;
}
.wlan-hero-links a:hover::after { transform: translateX(3px); }

.wlan-hero-visual { max-width: 900px; margin: 0 auto; position: relative; }
.wlan-signal-display {
	background: linear-gradient(180deg, #1c1c1e 0%, #000 100%);
	border: 1px solid #2c2c2e;
	border-radius: 24px;
	padding: 60px 40px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
}
.wlan-signal-stat { text-align: center; }
.wlan-signal-stat .num {
	font-size: clamp(48px, 7vw, 80px);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1;
	background: linear-gradient(180deg, #fff 0%, #999 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.wlan-signal-stat .unit {
	font-size: 24px;
	font-weight: 600;
	color: var(--ink-3);
	margin-left: 4px;
	-webkit-text-fill-color: var(--ink-3);
}
.wlan-signal-stat .label {
	font-size: 14px;
	color: var(--ink-3);
	margin-top: 8px;
	font-weight: 400;
}

.wlan-section {
	padding: 100px 22px;
	text-align: center;
}
.wlan-section-light { background: var(--light); }
.wlan-section-dark { background: var(--black); color: var(--white); }
.wlan-section-white { background: var(--white); }

.wlan-eyebrow {
	font-size: 21px;
	font-weight: 600;
	color: var(--blue);
	margin-bottom: 8px;
	letter-spacing: -0.01em;
}
.wlan-section-dark .wlan-eyebrow { color: #2997ff; }

.wlan-section-title {
	font-size: clamp(40px, 6vw, 72px);
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -0.04em;
	margin: 0 auto 16px;
	max-width: 900px;
	color: inherit;
}
.wlan-section-title .grad {
	background: linear-gradient(90deg, var(--blue) 0%, #4abdfe 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.wlan-section-sub {
	font-size: clamp(19px, 2.5vw, 28px);
	font-weight: 400;
	color: var(--ink-2);
	max-width: 720px;
	margin: 0 auto 60px;
	line-height: 1.3;
	letter-spacing: -0.01em;
}
.wlan-section-dark .wlan-section-sub { color: rgba(255,255,255,0.7); }

.wlan-btn {
	display: inline-flex; align-items: center;
	padding: 12px 24px;
	border-radius: 980px;
	font-size: 17px;
	font-weight: 400;
	letter-spacing: -0.01em;
	text-decoration: none;
	transition: all 0.2s ease;
	cursor: pointer; border: none;
	font-family: inherit;
	min-height: 44px;
}
.wlan-btn-primary { background: var(--blue); color: var(--white); }
.wlan-btn-primary:hover { background: var(--blue-hover); color: var(--white); }
.wlan-btn-secondary {
	background: var(--white);
	color: var(--ink);
	border: 1px solid var(--line);
}
.wlan-section-dark .wlan-btn-secondary {
	background: transparent;
	color: var(--white);
	border-color: rgba(255,255,255,0.3);
}
.wlan-btn-secondary:hover { background: var(--light); }
.wlan-section-dark .wlan-btn-secondary:hover { background: rgba(255,255,255,0.1); border-color: var(--white); }
.wlan-btn-link {
	background: transparent;
	color: var(--blue);
	padding: 0;
	font-size: 17px;
	text-decoration: none;
}
.wlan-btn-link:hover { text-decoration: underline; }
.wlan-btn-link::after {
	content: ' ›';
	display: inline-block;
	transition: transform 0.2s;
}
.wlan-btn-link:hover::after { transform: translateX(3px); }

.wlan-btn-row {
	display: flex; justify-content: center;
	gap: 16px; flex-wrap: wrap;
	margin-top: 8px;
}

.wlan-packages-grid {
	max-width: 1200px; margin: 60px auto 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	text-align: left;
}
.wlan-package {
	background: var(--white);
	border-radius: 22px;
	padding: 40px 32px;
	display: flex;
	flex-direction: column;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	position: relative;
	border: 1px solid transparent;
}
.wlan-package:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 60px rgba(0,0,0,0.08);
}
.wlan-package.featured {
	background: linear-gradient(180deg, #1d1d1f 0%, #000 100%);
	color: var(--white);
}
.wlan-package-tag {
	font-size: 13px;
	font-weight: 600;
	color: var(--blue);
	margin-bottom: 4px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
.wlan-package.featured .wlan-package-tag {
	background: linear-gradient(90deg, #2997ff, #4abdfe);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.wlan-package-name {
	font-size: 32px;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin-bottom: 4px;
	line-height: 1.1;
}
.wlan-package-tagline {
	font-size: 17px;
	color: var(--ink-3);
	font-weight: 400;
	margin-bottom: 32px;
}
.wlan-package.featured .wlan-package-tagline { color: rgba(255,255,255,0.6); }
.wlan-package-speed {
	display: flex;
	align-items: baseline;
	gap: 8px;
	padding: 24px 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	margin-bottom: 24px;
}
.wlan-package.featured .wlan-package-speed { border-color: rgba(255,255,255,0.15); }
.wlan-package-speed .big {
	font-size: 56px;
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1;
}
.wlan-package-speed .lbl {
	font-size: 17px;
	color: var(--ink-3);
}
.wlan-package.featured .wlan-package-speed .lbl { color: rgba(255,255,255,0.6); }
.wlan-package-features {
	list-style: none;
	flex: 1;
	margin: 0 0 32px;
	padding: 0;
}
.wlan-package-features li {
	padding: 8px 0;
	font-size: 15px;
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: var(--ink-2);
}
.wlan-package.featured .wlan-package-features li { color: rgba(255,255,255,0.85); }
.wlan-package-features li::before {
	content: '✓';
	color: var(--blue);
	font-weight: 700;
	flex-shrink: 0;
	width: 14px;
}
.wlan-package.featured .wlan-package-features li::before { color: #2997ff; }

.wlan-package-price-row { margin-bottom: 24px; }
.wlan-package-price {
	display: flex; align-items: baseline; gap: 4px;
	margin-bottom: 4px;
}
.wlan-package-price .from {
	font-size: 15px;
	color: var(--ink-3);
	margin-right: 4px;
}
.wlan-package.featured .wlan-package-price .from { color: rgba(255,255,255,0.6); }
.wlan-package-price .amt {
	font-size: 40px;
	font-weight: 700;
	letter-spacing: -0.02em;
}
.wlan-package-price .per {
	font-size: 17px;
	color: var(--ink-3);
}
.wlan-package.featured .wlan-package-price .per { color: rgba(255,255,255,0.6); }
.wlan-package-equip {
	font-size: 13px;
	color: var(--ink-3);
}
.wlan-package.featured .wlan-package-equip { color: rgba(255,255,255,0.5); }
.wlan-package .wlan-btn {
	width: 100%;
	justify-content: center;
}

.wlan-map-wrap {
	max-width: 1200px;
	margin: 60px auto 0;
	border-radius: 22px;
	overflow: hidden;
	box-shadow: 0 30px 80px rgba(0,0,0,0.12);
	position: relative;
}
.wlan-map-wrap iframe {
	width: 100%;
	height: 600px;
	border: 0;
	display: block;
}
.wlan-map-badge {
	position: absolute;
	top: 20px; left: 20px;
	background: rgba(0,0,0,0.85);
	backdrop-filter: blur(20px);
	color: var(--white);
	padding: 10px 18px;
	border-radius: 980px;
	font-size: 13px;
	font-weight: 500;
	display: flex; align-items: center; gap: 8px;
}
.wlan-map-badge::before {
	content: '';
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--green);
	animation: wlan-pulse 2s ease-in-out infinite;
}
@keyframes wlan-pulse {
	0%, 100% { opacity: 1; transform: scale(1); box-shadow: 0 0 0 0 rgba(52, 199, 89, 0.7); }
	50% { opacity: 0.7; transform: scale(1.2); box-shadow: 0 0 0 8px rgba(52, 199, 89, 0); }
}

.wlan-feature-row {
	max-width: 1200px; margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	text-align: left;
	align-items: center;
}
.wlan-feature-row.reverse { direction: rtl; }
.wlan-feature-row.reverse > * { direction: ltr; }
.wlan-feature-text h3 {
	font-size: clamp(32px, 5vw, 56px);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.05;
	margin: 0 0 20px;
}
.wlan-feature-text p {
	font-size: 21px;
	color: var(--ink-2);
	line-height: 1.4;
	font-weight: 400;
	margin: 0 0 24px;
}
.wlan-section-dark .wlan-feature-text p { color: rgba(255,255,255,0.75); }
.wlan-feature-visual {
	aspect-ratio: 1;
	border-radius: 22px;
	background: linear-gradient(135deg, #f5f5f7 0%, #e8e8ed 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
}
.wlan-feature-visual.dark {
	background: linear-gradient(135deg, #1c1c1e 0%, #000 100%);
}
.wlan-feature-visual svg { width: 60%; height: 60%; }

.wlan-steps-grid {
	max-width: 1200px; margin: 60px auto 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	text-align: left;
}
.wlan-step {
	background: var(--white);
	border-radius: 22px;
	padding: 40px 32px;
	position: relative;
}
.wlan-step-num {
	font-size: 13px;
	font-weight: 600;
	color: var(--blue);
	letter-spacing: 1px;
	text-transform: uppercase;
	margin-bottom: 16px;
}
.wlan-step h3 {
	font-size: 28px;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin: 0 0 8px;
}
.wlan-step p {
	font-size: 17px;
	color: var(--ink-2);
	line-height: 1.4;
	margin: 0;
}
.wlan-step-icon {
	width: 56px; height: 56px;
	border-radius: 14px;
	background: linear-gradient(135deg, var(--blue), #4abdfe);
	display: flex; align-items: center; justify-content: center;
	margin-bottom: 24px;
	color: var(--white);
}

.wlan-footer {
	background: var(--light);
	padding: 20px 22px 40px;
	font-size: 12px;
	color: var(--ink-3);
}
.wlan-footer-inner { max-width: 1024px; margin: 0 auto; }
.wlan-footer-top {
	padding: 32px 0;
	border-bottom: 1px solid var(--line);
	font-size: 12px;
	line-height: 1.6;
}
.wlan-footer-cols {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 40px;
	padding: 32px 0;
}
.wlan-footer-col h4 {
	font-size: 12px;
	font-weight: 600;
	color: var(--ink);
	margin: 0 0 12px;
}
.wlan-footer-col ul { list-style: none; margin: 0; padding: 0; }
.wlan-footer-col li { padding: 4px 0; }
.wlan-footer-col a {
	color: var(--ink-3);
	text-decoration: none;
	font-size: 12px;
}
.wlan-footer-col a:hover { text-decoration: underline; }
.wlan-footer-bottom {
	padding-top: 24px;
	border-top: 1px solid var(--line);
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
}

@media (max-width: 900px) {
	.wlan-nav-inner { padding: 0 16px; }
	.wlan-nav-links a { padding: 0 8px; font-size: 11px; }

	.wlan-hero { padding: 80px 16px 40px; }
	.wlan-signal-display { grid-template-columns: 1fr; gap: 32px; padding: 40px 24px; }

	.wlan-section { padding: 70px 16px; }

	.wlan-packages-grid { grid-template-columns: 1fr; gap: 16px; }

	.wlan-feature-row { grid-template-columns: 1fr; gap: 32px; }
	.wlan-feature-row.reverse { direction: ltr; }
	.wlan-feature-text { order: 2; }
	.wlan-feature-visual { order: 1; max-width: 400px; margin: 0 auto; width: 100%; }

	.wlan-steps-grid { grid-template-columns: 1fr; }

	.wlan-map-wrap iframe { height: 400px; }

	.wlan-footer-cols { grid-template-columns: 1fr 1fr; gap: 32px; }
	.wlan-footer-bottom { flex-direction: column; }
}

@media (max-width: 600px) {
	.wlan-nav-links li:not(:last-child) { display: none; }
}

/* === Hero video/poster/overlay (added 2026-05-12) === */
.wlan-hero {
	position: relative;
	min-height: 92vh;
	overflow: hidden;
}
.wlan-hero.has-video,
.wlan-hero.has-poster {
	background: #000;
}
.wlan-hero-video,
.wlan-hero-poster {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	background-size: cover;
	background-position: center;
	z-index: 0;
}
.wlan-hero-video {
	opacity: 0.85;
}
.wlan-hero-poster {
	opacity: 0.7;
}
.wlan-hero-overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.55) 60%, rgba(0,0,0,0.85) 100%),
		radial-gradient(ellipse at 30% 30%, rgba(0,113,227,0.18) 0%, transparent 60%);
	z-index: 1;
	pointer-events: none;
}
.wlan-hero-content {
	position: relative;
	z-index: 2;
}

/* New hero CTA buttons */
.wlan-hero-buttons {
	display: flex;
	justify-content: center;
	gap: 14px;
	flex-wrap: wrap;
	margin-bottom: 60px;
}
.wlan-btn-primary,
.wlan-btn-secondary {
	display: inline-flex;
	align-items: center;
	padding: 14px 28px;
	border-radius: 980px;
	font-size: 17px;
	font-weight: 500;
	letter-spacing: -0.01em;
	text-decoration: none;
	transition: all 0.2s ease;
	min-height: 48px;
}
.wlan-btn-primary {
	background: var(--blue);
	color: var(--white);
}
.wlan-btn-primary:hover {
	background: var(--blue-hover);
	color: var(--white);
}
.wlan-btn-secondary {
	background: rgba(255,255,255,0.08);
	color: var(--white);
	border: 1px solid rgba(255,255,255,0.3);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}
.wlan-btn-secondary:hover {
	background: rgba(255,255,255,0.15);
	border-color: var(--white);
	color: var(--white);
}

@media (max-width: 600px) {
	.wlan-hero-buttons { flex-direction: column; align-items: stretch; padding: 0 20px; }
	.wlan-btn-primary, .wlan-btn-secondary { justify-content: center; }
}
