/* =========================================================================
   NaviSystems 246 — exact design system
   Dark slate base, cyan accents, Inter. Mirrors the original React build.
   ========================================================================= */

:root {
	--slate-950: #020617;
	--slate-900: #0f172a;
	--slate-800: #1e293b;
	--slate-700: #334155;
	--slate-600: #475569;
	--slate-500: #64748b;
	--slate-400: #94a3b8;
	--slate-300: #cbd5e1;
	--slate-200: #e2e8f0;
	--white: #ffffff;
	--cyan-400: #22d3ee;
	--cyan-500: #06b6d4;
	--cyan-600: #0891b2;
	--yellow-400: #facc15;
	--green-400: #4ade80;
	--container: 1280px;
}

html { scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--slate-950);
	color: var(--slate-300);
	font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	-webkit-font-smoothing: antialiased;
	line-height: 1.6;
}

/* Account for the fixed header */
.navi-page { padding-top: 4rem; }

.navi-container {
	max-width: var(--container);
	margin: 0 auto;
	padding-left: 1rem;
	padding-right: 1rem;
}
@media (min-width: 640px) { .navi-container { padding-left: 1.5rem; padding-right: 1.5rem; } }
@media (min-width: 1024px) { .navi-container { padding-left: 2rem; padding-right: 2rem; } }

.navi-section { padding-top: 5rem; padding-bottom: 5rem; }
.bg-slate-950 { background: var(--slate-950); }
.bg-slate-900 { background: var(--slate-900); }

h1, h2, h3, h4 { color: var(--white); line-height: 1.15; margin: 0; }

/* ---- Buttons ------------------------------------------------------------ */
.navi-btn {
	box-sizing: border-box;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-weight: 600;
	border-radius: 8px;
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: background-color .2s ease, color .2s ease, border-color .2s ease;
	line-height: 1;
}
.navi-btn--lg { font-size: 1.125rem; padding: 1.1rem 2rem; }
.navi-btn--sm { font-size: 0.875rem; padding: 0.5rem 1rem; }
.navi-btn--md { font-size: 1rem; padding: 0.75rem 1.5rem; }
.navi-btn--block { width: 100%; padding: 1rem; }
.navi-btn--primary { background: var(--cyan-500); color: #fff; }
.navi-btn--primary:hover { background: var(--cyan-600); color: #fff; }
.navi-btn--outline { background: transparent; border-color: var(--slate-600); color: var(--slate-200); }
.navi-btn--outline:hover { background: var(--slate-800); color: #fff; }
.navi-btn--ghost { background: transparent; color: var(--slate-300); }
.navi-btn--ghost:hover { color: #fff; }
.navi-btn .navi-arrow { width: 1.1em; height: 1.1em; }

/* ---- Header ------------------------------------------------------------- */
.navi-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 50;
	height: 4rem;
	background: rgba(15, 23, 42, 0.95);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	border-bottom: 1px solid var(--slate-800);
}
.navi-header.menu-open { z-index: 60; }
.navi-header__inner {
	max-width: var(--container);
	margin: 0 auto;
	height: 4rem;
	padding: 0 1rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
@media (min-width: 640px) { .navi-header__inner { padding: 0 1.5rem; } }
@media (min-width: 1024px) { .navi-header__inner { padding: 0 2rem; } }
.navi-brand { display: inline-flex; align-items: center; gap: 0.5rem; text-decoration: none; }
.navi-brand__mark {
	width: 2.25rem; height: 2.25rem;
	background: linear-gradient(135deg, var(--cyan-400) 0%, var(--cyan-600) 100%);
	border-radius: 10px;
	display: inline-flex; align-items: center; justify-content: center;
	color: #fff;
	flex-shrink: 0;
	box-shadow: 0 4px 12px -2px rgba(6,182,212,0.45);
}
.navi-brand__mark svg { width: 1.15rem; height: 1.15rem; }
.navi-brand__name { color: #fff; font-weight: 700; font-size: 1.25rem; }
.navi-nav { display: none; align-items: center; gap: 1.5rem; }
.navi-nav a { color: var(--slate-300); font-size: 0.875rem; font-weight: 500; text-decoration: none; transition: color .2s; }
.navi-nav a:hover { color: var(--cyan-400); }
.navi-header__actions { display: none; align-items: center; gap: 0.75rem; }
/* Animated hamburger button */
.navi-burger { display: inline-flex; align-items: center; justify-content: center; width: 2.75rem; height: 2.75rem; background: transparent; border: none; color: #fff; cursor: pointer; padding: 0; z-index: 60; position: relative; }
.navi-burger__box { position: relative; width: 24px; height: 16px; }
.navi-burger__line { position: absolute; left: 0; width: 100%; height: 2px; border-radius: 2px; background: currentColor; transition: transform .3s ease, opacity .2s ease, top .3s ease, background-color .3s ease; }
.navi-burger__line:nth-child(1) { top: 0; }
.navi-burger__line:nth-child(2) { top: 7px; }
.navi-burger__line:nth-child(3) { top: 14px; }
.navi-burger.is-active { color: var(--cyan-400); }
.navi-burger.is-active .navi-burger__line:nth-child(1) { top: 7px; transform: rotate(45deg); }
.navi-burger.is-active .navi-burger__line:nth-child(2) { opacity: 0; }
.navi-burger.is-active .navi-burger__line:nth-child(3) { top: 7px; transform: rotate(-45deg); }

/* Full-screen mobile overlay menu */
.navi-mobile { position: fixed; inset: 0; z-index: 55; display: block; }
.navi-mobile[hidden] { display: none; }
.navi-mobile__backdrop { position: absolute; inset: 0; background: rgba(2,6,23,0.6); backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px); opacity: 0; transition: opacity .3s ease; }
.navi-mobile.is-open .navi-mobile__backdrop { opacity: 1; }
.navi-mobile__panel {
	position: absolute; top: 0; right: 0; bottom: 0;
	width: min(86vw, 360px);
	background: linear-gradient(180deg, var(--slate-900) 0%, var(--slate-950) 100%);
	border-left: 1px solid var(--slate-800);
	box-shadow: -20px 0 60px -20px rgba(0,0,0,0.6);
	padding: 5.5rem 1.75rem 2rem;
	display: flex; flex-direction: column;
	transform: translateX(100%);
	transition: transform .34s cubic-bezier(.22,.61,.36,1);
	overflow-y: auto;
}
.navi-mobile.is-open .navi-mobile__panel { transform: translateX(0); }
.navi-mobile__nav { display: flex; flex-direction: column; gap: 0.35rem; }
.navi-mobile__nav a:not(.navi-btn) { color: var(--slate-200); text-decoration: none; font-weight: 600; font-size: 1.35rem; padding: 0.6rem 0; border-bottom: 1px solid var(--slate-800); transition: color .2s, padding-left .2s; }
.navi-mobile__nav a:not(.navi-btn) span { display: inline-block; }
.navi-mobile__nav a:not(.navi-btn):hover { color: var(--cyan-400); padding-left: 0.35rem; }
.navi-mobile__nav .navi-btn { margin-top: 1.25rem; }
/* Staggered entrance for links */
.navi-mobile__nav > * { opacity: 0; transform: translateX(12px); }
.navi-mobile.is-open .navi-mobile__nav > * { animation: navi-stagger .4s ease forwards; }
.navi-mobile.is-open .navi-mobile__nav > *:nth-child(1) { animation-delay: .12s; }
.navi-mobile.is-open .navi-mobile__nav > *:nth-child(2) { animation-delay: .17s; }
.navi-mobile.is-open .navi-mobile__nav > *:nth-child(3) { animation-delay: .22s; }
.navi-mobile.is-open .navi-mobile__nav > *:nth-child(4) { animation-delay: .27s; }
.navi-mobile.is-open .navi-mobile__nav > *:nth-child(5) { animation-delay: .32s; }
.navi-mobile.is-open .navi-mobile__nav > *:nth-child(6) { animation-delay: .37s; }
@keyframes navi-stagger { to { opacity: 1; transform: translateX(0); } }
.navi-mobile__foot { margin-top: auto; padding-top: 2rem; display: flex; flex-direction: column; gap: 0.5rem; }
.navi-mobile__contact { color: var(--slate-400); font-size: 0.9rem; text-decoration: none; }
.navi-mobile__contact:hover { color: var(--cyan-400); }
body.navi-no-scroll { overflow: hidden; }

@media (min-width: 768px) {
	.navi-nav { display: flex; }
	.navi-header__actions { display: flex; }
	.navi-burger { display: none; }
	.navi-mobile { display: none !important; }
}

/* Back-to-top button */
.navi-to-top {
	position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 45;
	width: 3rem; height: 3rem; border-radius: 999px; border: none; cursor: pointer;
	background: var(--cyan-500); color: #fff;
	display: inline-flex; align-items: center; justify-content: center;
	box-shadow: 0 10px 25px -8px rgba(6,182,212,0.6);
	opacity: 0; visibility: hidden; transform: translateY(12px) scale(.9);
	transition: opacity .25s ease, transform .25s ease, visibility .25s, background-color .2s;
}
.navi-to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0) scale(1); }
.navi-to-top:hover { background: var(--cyan-600); transform: translateY(-2px) scale(1.05); }
.navi-to-top:focus-visible { outline: 2px solid var(--cyan-400); outline-offset: 3px; }
.navi-to-top svg { width: 22px; height: 22px; }

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	.navi-mobile__panel, .navi-mobile__backdrop, .navi-to-top, .navi-burger__line { transition: none; }
	.navi-mobile.is-open .navi-mobile__nav > * { animation: none; opacity: 1; transform: none; }
	.navi-badge__dot { animation: none; }
}

/* ---- Hero --------------------------------------------------------------- */
.navi-hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	overflow: hidden;
}
.navi-hero__bg { position: absolute; inset: 0; z-index: 0; }
.navi-hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.8; }
.navi-hero__overlay {
	position: absolute; inset: 0;
	background:
		linear-gradient(90deg, var(--slate-950) 0%, rgba(2,6,23,0.88) 30%, rgba(2,6,23,0.35) 68%, rgba(2,6,23,0.15) 100%),
		linear-gradient(0deg, rgba(2,6,23,0.45) 0%, rgba(2,6,23,0) 35%);
}
/* Mobile: stacked hero — solid dark text block on top, clear image card below. */
.navi-hero__photo { display: none; }
@media (max-width: 1023px) {
	.navi-hero { min-height: 0; }
	.navi-hero__bg { display: none; }
	.navi-hero__inner { padding-top: 3rem; padding-bottom: 3rem; }
	.navi-hero__photo { display: block; margin-top: 2.5rem; }
	.navi-hero__photo img {
		width: 100%; height: auto; display: block;
		border-radius: 16px;
		border: 1px solid var(--slate-800);
		box-shadow: 0 20px 40px -16px rgba(0,0,0,0.6);
	}
}
.navi-hero__inner {
	position: relative; z-index: 10;
	max-width: var(--container);
	margin: 0 auto;
	padding: 5rem 1rem;
	width: 100%;
}
@media (min-width: 640px) { .navi-hero__inner { padding: 5rem 1.5rem; } }
@media (min-width: 1024px) { .navi-hero__inner { padding: 5rem 2rem; } }
.navi-hero__content { max-width: 42rem; }
.navi-badge {
	display: inline-flex; align-items: center; gap: 0.5rem;
	background: rgba(6,182,212,0.10);
	border: 1px solid rgba(6,182,212,0.30);
	border-radius: 999px;
	padding: 0.375rem 1rem;
	margin-bottom: 1.5rem;
	color: var(--cyan-400);
	font-size: 0.875rem;
	font-weight: 500;
}
.navi-badge__dot { width: 0.5rem; height: 0.5rem; background: var(--cyan-400); border-radius: 999px; animation: navi-pulse 2s cubic-bezier(.4,0,.6,1) infinite; }
@keyframes navi-pulse { 0%,100% { opacity: 1; } 50% { opacity: .4; } }
.navi-hero h1 {
	font-size: clamp(2.25rem, 1.5rem + 3.2vw, 3.75rem);
	font-weight: 700;
	color: #fff;
	line-height: 1.1;
	margin-bottom: 1.5rem;
}
.navi-hero h1 .accent { color: var(--cyan-400); }
.navi-hero__lead { font-size: 1.125rem; color: var(--slate-300); margin-bottom: 2rem; line-height: 1.7; }
.navi-hero__cta { display: flex; flex-direction: column; gap: 1rem; }
@media (min-width: 640px) { .navi-hero__cta { flex-direction: row; } }
.navi-hero__trust { display: flex; flex-wrap: wrap; align-items: center; gap: 1.5rem; margin-top: 2.5rem; }
.navi-trust-item { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--slate-400); font-size: 0.875rem; }
.navi-trust-item .navi-ic { color: var(--cyan-400); width: 18px; height: 18px; flex-shrink: 0; }

/* ---- Section heading ---------------------------------------------------- */
.navi-section__head { text-align: center; margin-bottom: 4rem; }
.navi-section__head h2 { font-size: clamp(1.875rem, 1.4rem + 1.5vw, 2.25rem); font-weight: 700; color: #fff; margin-bottom: 1rem; }
.navi-section__head p { color: var(--slate-400); font-size: 1.125rem; max-width: 42rem; margin: 0 auto; }

/* ---- Services ----------------------------------------------------------- */
.navi-grid { display: grid; gap: 1.5rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .navi-grid--services { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .navi-grid--services { grid-template-columns: repeat(3, 1fr); } }
.navi-card {
	background: rgba(30,41,59,0.50);
	border: 1px solid var(--slate-700);
	border-radius: 12px;
	padding: 1.5rem;
	transition: border-color .3s ease, box-shadow .3s ease, transform .3s ease;
}
.navi-card:hover { border-color: rgba(6,182,212,0.50); box-shadow: 0 10px 30px -10px rgba(6,182,212,0.10); }
.navi-card__icon {
	width: 3rem; height: 3rem;
	background: rgba(6,182,212,0.10);
	border-radius: 8px;
	display: flex; align-items: center; justify-content: center;
	margin-bottom: 1rem;
	color: var(--cyan-400);
	transition: background-color .3s ease;
}
.navi-card:hover .navi-card__icon { background: rgba(6,182,212,0.20); }
.navi-card__icon svg { width: 24px; height: 24px; }
.navi-card h3 { font-size: 1.25rem; font-weight: 600; color: #fff; margin-bottom: 0.5rem; }
.navi-card__desc { color: var(--slate-400); font-size: 0.875rem; line-height: 1.6; margin-bottom: 1rem; }
.navi-card__meta { display: flex; align-items: center; justify-content: space-between; }
.navi-card__price { font-size: 1.5rem; font-weight: 700; color: var(--cyan-400); }
.navi-card__dur { color: var(--slate-500); font-size: 0.875rem; }
.navi-center { text-align: center; }
.mt-10 { margin-top: 2.5rem; }

/* ---- Services value section (homepage) ---------------------------------- */
.navi-value { text-align: center; }
.navi-convert-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.6rem; margin: 0 auto 2.5rem; max-width: 46rem; }
.navi-chip { padding: 0.5rem 1.1rem; border-radius: 999px; border: 1px solid var(--slate-700); background: rgba(30,41,59,0.5); color: var(--slate-300); font-size: 0.9rem; font-weight: 500; }
.navi-value-card { max-width: 640px; margin: 0 auto; background: rgba(30,41,59,0.5); border: 1px solid var(--slate-700); border-radius: 16px; padding: 2.5rem 2rem; }
.navi-value-price { color: #fff; font-size: 1.5rem; font-weight: 600; margin: 0 0 1.5rem; }
.navi-value-price .amt { color: var(--cyan-400); font-weight: 700; font-size: 2.25rem; }
.navi-value-trust { list-style: none; margin: 0 0 2rem; padding: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: 0.75rem 1.5rem; }
.navi-value-trust li { display: flex; align-items: center; gap: 0.5rem; color: var(--slate-300); font-size: 0.95rem; }
.navi-value-trust li::before {
	content: ""; width: 18px; height: 18px; flex-shrink: 0; background-color: var(--cyan-400);
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10Z'/%3E%3Cpath d='m9 12 2 2 4-4'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10Z'/%3E%3Cpath d='m9 12 2 2 4-4'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* ---- Service finder (homepage) ------------------------------------------ */
.navi-finder__card { background: rgba(30,41,59,0.5); border: 1px solid var(--slate-700); border-radius: 16px; padding: 2rem; }
@media (min-width: 768px) { .navi-finder__card { padding: 2.5rem; } }
.navi-finder__title { color: #fff; font-size: 1.375rem; font-weight: 600; margin: 0 0 0.4rem; }
.navi-finder__sub { color: var(--slate-400); margin: 0 0 1.5rem; }
.navi-finder__brands { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.navi-finder__brand { padding: 0.6rem 1.25rem; border-radius: 999px; border: 1px solid var(--slate-600); background: var(--slate-800); color: var(--slate-200); font-weight: 600; font-size: 0.95rem; cursor: pointer; font-family: inherit; text-decoration: none; transition: border-color .2s, background-color .2s, color .2s; }
.navi-finder__brand:hover { border-color: var(--cyan-500); color: #fff; }
.navi-finder__brand.is-active { background: var(--cyan-500); border-color: var(--cyan-500); color: #fff; }
.navi-finder__brand--other { background: transparent; border-style: dashed; color: var(--slate-400); }
.navi-finder__results { margin-top: 1.75rem; }
.navi-finder__count { color: var(--slate-400); font-size: 0.9rem; margin: 0 0 1rem; }
.navi-finder__count strong, .navi-finder__empty strong { color: #fff; }
.navi-finder__empty { color: var(--slate-300); }
.navi-finder__empty a { color: var(--cyan-400); }
.navi-finder__list { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 640px) { .navi-finder__list { grid-template-columns: repeat(2, 1fr); } }
.navi-finder__svc { display: block; text-decoration: none; background: var(--slate-900); border: 1px solid var(--slate-700); border-radius: 12px; padding: 1.25rem; transition: border-color .2s, transform .2s, box-shadow .2s; }
.navi-finder__svc:hover { border-color: var(--cyan-500); transform: translateY(-2px); box-shadow: 0 12px 28px -14px rgba(6,182,212,0.4); }
.navi-finder__svc-head { display: flex; justify-content: space-between; align-items: baseline; gap: 0.75rem; }
.navi-finder__svc-head h4 { color: #fff; font-size: 1rem; font-weight: 600; margin: 0; }
.navi-finder__price { color: var(--cyan-400); font-weight: 700; font-size: 1.1rem; white-space: nowrap; }
.navi-finder__svc p { color: var(--slate-400); font-size: 0.85rem; line-height: 1.55; margin: 0.5rem 0 0.9rem; }
.navi-finder__svc-foot { display: flex; justify-content: space-between; align-items: center; }
.navi-finder__dur { color: var(--slate-500); font-size: 0.8rem; }
.navi-finder__go { color: var(--cyan-400); font-size: 0.85rem; font-weight: 600; display: inline-flex; align-items: center; gap: 0.3rem; }
.navi-finder__go svg { width: 15px; height: 15px; }
.navi-finder__or { text-align: center; color: var(--slate-500); font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.05em; margin: 2.5rem 0 1.25rem; position: relative; }
.navi-finder__cats { display: grid; grid-template-columns: 1fr; gap: 0.85rem; }
@media (min-width: 640px) { .navi-finder__cats { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .navi-finder__cats { grid-template-columns: repeat(3, 1fr); } }
.navi-finder__cat { display: flex; align-items: center; gap: 0.85rem; text-decoration: none; background: rgba(30,41,59,0.5); border: 1px solid var(--slate-700); border-radius: 12px; padding: 1rem 1.15rem; transition: border-color .2s, background-color .2s; }
.navi-finder__cat:hover { border-color: var(--cyan-500); background: rgba(6,182,212,0.06); }
.navi-finder__cat-icon { width: 2.25rem; height: 2.25rem; border-radius: 8px; background: rgba(6,182,212,0.1); color: var(--cyan-400); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.navi-finder__cat-icon svg { width: 18px; height: 18px; }
.navi-finder__cat-body { flex: 1; min-width: 0; }
.navi-finder__cat-name { display: block; color: #fff; font-weight: 600; font-size: 0.95rem; }
.navi-finder__cat-meta { display: block; color: var(--slate-400); font-size: 0.8rem; margin-top: 0.15rem; }
.navi-finder__cat-arrow { width: 16px; height: 16px; color: var(--slate-600); flex-shrink: 0; }
.navi-finder__cat:hover .navi-finder__cat-arrow { color: var(--cyan-400); }
.navi-finder__cta { text-align: center; margin-top: 2.5rem; }
/* Wizard step-1 category filter banner */
.navi-wizard__filter { background: rgba(6,182,212,0.08); border: 1px solid rgba(6,182,212,0.25); border-radius: 8px; padding: 0.6rem 1rem; margin-bottom: 1.25rem; color: var(--slate-300); font-size: 0.9rem; display: flex; flex-wrap: wrap; gap: 0.5rem 1rem; align-items: center; }
.navi-wizard__filter strong { color: var(--cyan-400); }
.navi-wizard__filter button { background: none; border: none; color: var(--slate-400); text-decoration: underline; cursor: pointer; font-family: inherit; font-size: 0.85rem; padding: 0; }
.navi-wizard__filter button:hover { color: var(--cyan-400); }

/* ---- About -------------------------------------------------------------- */
.navi-about__grid { display: grid; gap: 3rem; align-items: center; grid-template-columns: 1fr; }
@media (min-width: 1024px) { .navi-about__grid { grid-template-columns: repeat(2, 1fr); } }
.navi-about h2 { font-size: clamp(1.875rem, 1.4rem + 1.5vw, 2.25rem); font-weight: 700; color: #fff; margin-bottom: 1.5rem; }
.navi-about__lead { color: var(--slate-300); font-size: 1.125rem; line-height: 1.7; margin-bottom: 1.5rem; }
.navi-checklist { display: flex; flex-direction: column; gap: 1rem; list-style: none; margin: 0; padding: 0; }
.navi-checklist li { display: flex; align-items: center; gap: 0.75rem; color: var(--slate-300); }
.navi-checklist li::before {
	content: ""; width: 20px; height: 20px; flex-shrink: 0;
	background-color: var(--cyan-400);
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10Z'/%3E%3Cpath d='m9 12 2 2 4-4'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10Z'/%3E%3Cpath d='m9 12 2 2 4-4'/%3E%3C/svg%3E") center / contain no-repeat;
}
.navi-about__media { position: relative; }
.navi-about__media img { border-radius: 12px; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.5); width: 100%; height: auto; display: block; }
.navi-about__badge {
	position: absolute; bottom: -1rem; right: -1rem;
	background: var(--cyan-500); color: #fff;
	border-radius: 12px; padding: 1rem;
	box-shadow: 0 10px 20px rgba(0,0,0,0.3);
}
.navi-about__badge .num { font-size: 1.5rem; font-weight: 700; line-height: 1; }
.navi-about__badge .label { font-size: 0.875rem; }

/* ---- Steps -------------------------------------------------------------- */
.navi-grid--steps { display: grid; gap: 2rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .navi-grid--steps { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .navi-grid--steps { grid-template-columns: repeat(4, 1fr); } }
.navi-step { text-align: center; }
.navi-step__num {
	width: 4rem; height: 4rem;
	background: rgba(6,182,212,0.10);
	border: 1px solid rgba(6,182,212,0.30);
	border-radius: 999px;
	display: flex; align-items: center; justify-content: center;
	margin: 0 auto 1rem;
	color: var(--cyan-400); font-weight: 700; font-size: 1.125rem;
}
.navi-step h3 { color: #fff; font-weight: 600; font-size: 1.125rem; margin-bottom: 0.5rem; }
.navi-step p { color: var(--slate-400); font-size: 0.875rem; }

/* ---- Testimonials ------------------------------------------------------- */
.navi-grid--testi { display: grid; gap: 2rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .navi-grid--testi { grid-template-columns: repeat(3, 1fr); } }
.navi-testi {
	background: rgba(30,41,59,0.50);
	border: 1px solid var(--slate-700);
	border-radius: 12px;
	padding: 1.5rem;
}
.navi-stars { display: flex; gap: 0.25rem; margin-bottom: 1rem; color: var(--yellow-400); }
.navi-stars svg { width: 18px; height: 18px; fill: var(--yellow-400); }
.navi-testi__text { color: var(--slate-300); margin-bottom: 1rem; line-height: 1.7; }
.navi-testi__name { color: #fff; font-weight: 600; }
.navi-center-banner { margin-top: 3rem; position: relative; border-radius: 12px; overflow: hidden; }
.navi-center-banner img { width: 100%; height: 16rem; object-fit: cover; display: block; }
.navi-center-banner__overlay { position: absolute; inset: 0; background: linear-gradient(0deg, var(--slate-950) 0%, rgba(2,6,23,0) 100%); }
.navi-center-banner__caption { position: absolute; bottom: 1.5rem; left: 1.5rem; }
.navi-center-banner__caption .t { color: #fff; font-weight: 600; font-size: 1.125rem; margin: 0; }
.navi-center-banner__caption .s { color: var(--slate-300); font-size: 0.875rem; margin: 0; }

/* ---- Contact / footer --------------------------------------------------- */
.navi-contact { background: var(--slate-900); border-top: 1px solid var(--slate-800); padding: 5rem 0; }
.navi-contact__grid { display: grid; gap: 3rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .navi-contact__grid { grid-template-columns: repeat(3, 1fr); } }
.navi-contact__about { color: var(--slate-400); font-size: 0.875rem; line-height: 1.7; }
.navi-contact h3 { color: #fff; font-weight: 600; margin-bottom: 1rem; font-size: 1rem; }
.navi-contact__list { display: flex; flex-direction: column; gap: 0.75rem; }
.navi-contact__list .row { display: flex; align-items: center; gap: 0.75rem; color: var(--slate-400); font-size: 0.875rem; }
.navi-contact__list .navi-ic { color: var(--cyan-400); width: 18px; height: 18px; flex-shrink: 0; }
.navi-hours { display: flex; flex-direction: column; gap: 0.5rem; color: var(--slate-400); font-size: 0.875rem; }
.navi-hours p { margin: 0; }
.navi-footer-bottom { border-top: 1px solid var(--slate-800); margin-top: 3rem; padding-top: 2rem; display: flex; flex-direction: column; align-items: center; gap: 1rem; text-align: center; }
.navi-footer-bottom p { color: var(--slate-500); font-size: 0.875rem; margin: 0; }
.navi-legal-links { gap: 0.5rem 1.5rem; }
.navi-legal-links p { margin: 0; font-size: 0.85rem; }
.navi-legal-links a { color: var(--slate-500); text-decoration: none; transition: color .2s; }
.navi-legal-links a:hover { color: var(--cyan-400); }
@media (min-width: 768px) {
	.navi-footer-bottom { flex-direction: row; justify-content: space-between; text-align: left; }
}
.navi-brand--footer { margin-bottom: 1rem; }

/* ---- Booking page ------------------------------------------------------- */
.navi-booking-wrap { max-width: 640px; margin: 0 auto; }
.navi-booking-card {
	background: rgba(30,41,59,0.50);
	border: 1px solid var(--slate-700);
	border-radius: 12px;
	padding: 2rem;
}
.navi-form { display: flex; flex-direction: column; gap: 1.25rem; }
.navi-form__row { display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .navi-form__row { grid-template-columns: repeat(2, 1fr); } }
.navi-field { display: flex; flex-direction: column; gap: 0.4rem; }
.navi-field > span { color: var(--slate-300); font-size: 0.875rem; font-weight: 500; }
.navi-field input,
.navi-field select,
.navi-field textarea {
	background: var(--slate-900);
	border: 1px solid var(--slate-700);
	border-radius: 8px;
	color: #fff;
	padding: 0.7rem 0.85rem;
	font-family: inherit;
	font-size: 0.95rem;
}
.navi-field input::placeholder,
.navi-field textarea::placeholder { color: var(--slate-500); }
.navi-field input:focus,
.navi-field select:focus,
.navi-field textarea:focus { outline: 2px solid var(--cyan-500); outline-offset: 1px; border-color: var(--cyan-500); }

/* Date & time fields — visible light icons + dark, brand-tinted native calendar */
.navi-field input[type="date"],
.navi-field input[type="time"],
.navi-field select {
	color-scheme: dark; /* light picker icons + dark native calendar/time popup */
	cursor: pointer;
}
.navi-field input[type="date"]::-webkit-calendar-picker-indicator,
.navi-field input[type="time"]::-webkit-calendar-picker-indicator {
	cursor: pointer;
	opacity: 0.85;
	width: 20px;
	height: 20px;
	padding: 3px;
	margin-left: 4px;
	border-radius: 6px;
	filter: invert(74%) sepia(64%) saturate(720%) hue-rotate(140deg) brightness(95%) contrast(92%);
	transition: opacity .15s ease, background-color .15s ease;
}
.navi-field input[type="date"]:hover::-webkit-calendar-picker-indicator,
.navi-field input[type="time"]:hover::-webkit-calendar-picker-indicator,
.navi-field input[type="date"]:focus::-webkit-calendar-picker-indicator,
.navi-field input[type="time"]:focus::-webkit-calendar-picker-indicator {
	opacity: 1;
	background-color: rgba(6,182,212,0.18);
}
/* Style the editable date/time text segments */
.navi-field input[type="date"]::-webkit-datetime-edit,
.navi-field input[type="time"]::-webkit-datetime-edit { color: #fff; padding: 2px 0; }
.navi-field input[type="date"]::-webkit-datetime-edit-fields-wrapper,
.navi-field input[type="time"]::-webkit-datetime-edit-fields-wrapper { color: #fff; }
.navi-field input[type="date"]:in-range::-webkit-datetime-edit-text { color: var(--slate-400); }
/* Hover state on the whole field */
.navi-field input[type="date"]:hover,
.navi-field input[type="time"]:hover { border-color: var(--cyan-500); background: rgba(15,23,42,0.9); }
.navi-alert { border-radius: 8px; padding: 1rem; margin-bottom: 1.5rem; display: flex; flex-direction: column; gap: 0.25rem; font-size: 0.95rem; }
.navi-alert--success { background: rgba(74,222,128,0.10); border: 1px solid rgba(74,222,128,0.40); color: var(--green-400); }
.navi-alert--error { background: rgba(239,68,68,0.10); border: 1px solid rgba(239,68,68,0.40); color: #f87171; }

/* ---- Booking wizard (4-step) -------------------------------------------- */
.navi-wizard { max-width: 896px; margin: 0 auto; padding: 6rem 1rem 4rem; }
@media (min-width: 640px) { .navi-wizard { padding-left: 1.5rem; padding-right: 1.5rem; } }
@media (min-width: 1024px) { .navi-wizard { padding-left: 2rem; padding-right: 2rem; } }
.navi-wizard__h1 { font-size: 1.875rem; font-weight: 700; color: #fff; margin: 0 0 0.5rem; }
.navi-wizard__sub { color: var(--slate-400); margin: 0 0 2rem; }
.navi-wizard__noscript { color: var(--slate-300); }
/* Step indicator */
.navi-wizard__steps { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 2.5rem; }
.navi-wizard__step { display: flex; align-items: center; gap: 0.5rem; flex: 1; }
.navi-wizard__num { width: 2rem; height: 2rem; border-radius: 999px; display: flex; align-items: center; justify-content: center; font-size: 0.875rem; font-weight: 500; background: var(--slate-800); color: var(--slate-500); flex-shrink: 0; transition: background-color .3s, color .3s; }
.navi-wizard__num.is-done { background: var(--cyan-500); color: #fff; }
.navi-wizard__label { font-size: 0.875rem; color: var(--slate-500); display: none; }
.navi-wizard__label.is-done { color: var(--cyan-400); }
@media (min-width: 640px) { .navi-wizard__label { display: block; } }
.navi-wizard__line { flex: 1; height: 2px; background: var(--slate-800); transition: background-color .3s; }
.navi-wizard__line.is-done { background: var(--cyan-500); }
.navi-wizard__h2 { font-size: 1.25rem; font-weight: 600; color: #fff; margin: 0 0 1rem; }
.navi-wizard__h2--sub { margin-top: 2rem; }
/* Step 1 services */
.navi-wizard__services { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 640px) { .navi-wizard__services { grid-template-columns: repeat(2, 1fr); } }
.navi-wizard__svc { text-align: left; padding: 1.25rem; border-radius: 12px; border: 1px solid var(--slate-700); background: rgba(30,41,59,0.5); cursor: pointer; transition: border-color .2s, background-color .2s; color: inherit; font-family: inherit; }
.navi-wizard__svc:hover { border-color: var(--slate-600); }
.navi-wizard__svc.is-selected { border-color: var(--cyan-500); background: rgba(6,182,212,0.10); }
.navi-wizard__svc h3 { color: #fff; font-weight: 600; font-size: 1rem; margin: 0 0 0.25rem; }
.navi-wizard__svc p { color: var(--slate-400); font-size: 0.875rem; margin: 0 0 0.75rem; line-height: 1.5; }
.navi-wizard__svc-meta { display: flex; justify-content: space-between; align-items: center; }
.navi-wizard__svc-meta .price { color: var(--cyan-400); font-weight: 700; font-size: 1.125rem; }
.navi-wizard__svc-meta .dur { color: var(--slate-500); font-size: 0.75rem; }
/* Step 2 times */
.navi-wizard__times { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }
@media (min-width: 640px) { .navi-wizard__times { grid-template-columns: repeat(4, 1fr); } }
.navi-wizard__time { padding: 0.65rem; border-radius: 8px; border: 1px solid var(--slate-700); background: var(--slate-800); color: var(--slate-300); cursor: pointer; font-family: inherit; font-size: 0.95rem; transition: background-color .2s, color .2s, border-color .2s; }
.navi-wizard__time:hover { border-color: var(--slate-600); }
.navi-wizard__time.is-selected { background: var(--cyan-500); border-color: var(--cyan-500); color: #fff; }
/* Nav row */
.navi-wizard__nav { display: flex; justify-content: space-between; align-items: center; margin-top: 1.75rem; gap: 1rem; }
.navi-wizard__nav--end { justify-content: flex-end; }
.navi-btn[disabled] { opacity: 0.5; cursor: not-allowed; }
/* Step 4 review */
.navi-wizard__review { background: rgba(30,41,59,0.5); border: 1px solid var(--slate-700); border-radius: 12px; padding: 1.5rem; display: flex; flex-direction: column; gap: 0.85rem; }
.navi-wizard__rrow { display: flex; justify-content: space-between; gap: 1rem; }
.navi-wizard__rrow .k { color: var(--slate-400); }
.navi-wizard__rrow .v { color: #fff; text-align: right; }
.navi-wizard__total { border-top: 1px solid var(--slate-700); padding-top: 1rem; margin-top: 0.25rem; }
.navi-wizard__total .k { color: #fff; font-weight: 600; }
.navi-wizard__total .v { color: var(--cyan-400); font-weight: 700; font-size: 1.25rem; }
/* Wizard fields reuse .navi-field; ensure spacing */
.navi-wizard .navi-field { margin-bottom: 1.25rem; }
.navi-wizard .navi-form__row { display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .navi-wizard .navi-form__row { grid-template-columns: repeat(2, 1fr); } }
/* Success */
.navi-wizard__success { text-align: center; padding: 3rem 1rem; max-width: 540px; margin: 0 auto; }
.navi-wizard__check { width: 4.5rem; height: 4.5rem; border-radius: 999px; background: rgba(74,222,128,0.12); border: 1px solid rgba(74,222,128,0.4); color: var(--green-400); display: flex; align-items: center; justify-content: center; margin: 0 auto 1.5rem; }
.navi-wizard__check svg { width: 2.25rem; height: 2.25rem; }
.navi-wizard__success h2 { color: #fff; font-size: 1.5rem; margin: 0 0 0.75rem; }
.navi-wizard__success p { color: var(--slate-400); line-height: 1.7; margin: 0 0 1.75rem; }

/* ---- Blog --------------------------------------------------------------- */
.navi-blog { padding: 5rem 0; }
.navi-blog__grid { display: grid; gap: 2rem; grid-template-columns: 1fr; margin-top: 3rem; }
@media (min-width: 768px) { .navi-blog__grid { grid-template-columns: repeat(3, 1fr); } }
.navi-post-card { background: rgba(30,41,59,0.50); border: 1px solid var(--slate-700); border-radius: 12px; overflow: hidden; transition: border-color .3s; }
.navi-post-card:hover { border-color: rgba(6,182,212,0.50); }
.navi-post-card .thumb img { width: 100%; height: 12rem; object-fit: cover; display: block; }
.navi-post-card__body { padding: 1.5rem; }
.navi-post-card__body h3 { font-size: 1.15rem; margin-bottom: 0.5rem; }
.navi-post-card__body h3 a { color: #fff; text-decoration: none; }
.navi-post-card__body h3 a:hover { color: var(--cyan-400); }
.navi-post-card__meta { color: var(--slate-500); font-size: 0.8rem; margin-bottom: 0.75rem; }
.navi-post-card__excerpt { color: var(--slate-400); font-size: 0.9rem; line-height: 1.6; }
.navi-prose { color: var(--slate-300); }
.navi-prose > * { max-width: 100%; }
.navi-prose h1, .navi-prose h2, .navi-prose h3 { color: #fff; margin: 2rem 0 1rem; }
.navi-prose h2 { font-size: clamp(1.5rem, 1.2rem + 1vw, 1.875rem); }
.navi-prose p, .navi-prose li { line-height: 1.8; }
.navi-prose a { color: var(--cyan-400); }
.navi-prose img { border-radius: 12px; }

/* ---- Inline pseudo-icons (cyan) ----------------------------------------- */
.navi-ico { display: inline-flex; align-items: center; }
.navi-ico::before { content: ""; width: 18px; height: 18px; flex-shrink: 0; background-color: var(--cyan-400); -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center; mask-position: center; -webkit-mask-size: contain; mask-size: contain; }
.navi-contact__list .row { gap: 0.75rem; }
.navi-contact__list .row.navi-ico-pin::before { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 10c0 6-8 12-8 12s-8-6-8-12a8 8 0 0 1 16 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 10c0 6-8 12-8 12s-8-6-8-12a8 8 0 0 1 16 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E"); }
.navi-contact__list .row.navi-ico-phone::before { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.36 1.9.7 2.81a2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45c.9.34 1.85.57 2.81.7A2 2 0 0 1 22 16.92Z'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.36 1.9.7 2.81a2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45c.9.34 1.85.57 2.81.7A2 2 0 0 1 22 16.92Z'/%3E%3C/svg%3E"); }
.navi-contact__list .row.navi-ico-mail::before { -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='16' x='2' y='4' rx='2'/%3E%3Cpath d='m22 7-8.97 5.7a1.94 1.94 0 0 1-2.06 0L2 7'/%3E%3C/svg%3E"); mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='16' x='2' y='4' rx='2'/%3E%3Cpath d='m22 7-8.97 5.7a1.94 1.94 0 0 1-2.06 0L2 7'/%3E%3C/svg%3E"); }
.navi-contact__list .row::before { content: ""; width: 18px; height: 18px; flex-shrink: 0; background-color: var(--cyan-400); -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center; mask-position: center; -webkit-mask-size: contain; mask-size: contain; }

/* ---- Page header band --------------------------------------------------- */
.navi-page-hero { width: 100%; background: var(--slate-900); border-bottom: 1px solid var(--slate-800); padding: 4rem 0; text-align: center; }
/* Breadcrumbs */
.navi-breadcrumbs { margin-bottom: 1.25rem; }
.navi-breadcrumbs ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 0.25rem; font-size: 0.85rem; }
.navi-breadcrumbs li { display: inline-flex; align-items: center; gap: 0.25rem; }
.navi-breadcrumbs a { color: var(--slate-400); text-decoration: none; transition: color .2s; }
.navi-breadcrumbs a:hover { color: var(--cyan-400); }
.navi-breadcrumbs [aria-current="page"] { color: var(--slate-300); }
.navi-breadcrumbs__sep { width: 14px; height: 14px; color: var(--slate-600); margin-left: 0.25rem; }
.navi-page-hero h1 { font-size: clamp(2rem, 1.5rem + 2vw, 3rem); margin-bottom: 0.75rem; }
.navi-page-hero p { color: var(--slate-400); font-size: 1.125rem; }
/* Page content section padding */
.navi-page > .navi-section { padding-top: 4rem; padding-bottom: 4rem; }
/* Light (white) body variant — used on legal/standard pages for readable long-form text */
.navi-section--light { background: #ffffff; }
.navi-section--light .navi-prose { color: #334155; }
.navi-section--light .navi-prose h1,
.navi-section--light .navi-prose h2,
.navi-section--light .navi-prose h3,
.navi-section--light .navi-prose h4,
.navi-section--light .navi-prose strong { color: #0f172a; }
.navi-section--light .navi-prose a { color: #0e7490; text-decoration: underline; }
.navi-section--light .navi-prose a:hover { color: #155e75; }
.navi-section--light .navi-prose em { color: #475569; }
.navi-section--light .navi-prose hr { border-color: #e2e8f0; }
.navi-section--light .navi-prose blockquote { border-left: 3px solid #06b6d4; color: #475569; }
