/* =========================================================================
   Components: buttons, header, navigation, footer, floating actions,
   accessibility widget, cards. (Site-wide chrome.)
   ========================================================================= */

/* --- Buttons ---------------------------------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	font-family: var(--font-body);
	font-weight: var(--fw-semibold);
	font-size: 0.975rem;
	line-height: 1;
	padding: 1rem 1.7rem;
	border-radius: var(--r-pill);
	border: 2px solid transparent;
	cursor: pointer;
	text-align: center;
	transition: transform var(--t-fast) var(--ease),
		box-shadow var(--t-base) var(--ease),
		background-color var(--t-fast) var(--ease),
		color var(--t-fast) var(--ease);
	will-change: transform;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
.btn__icon { transition: transform var(--t-base) var(--ease); }
.btn:hover .btn__icon { transform: translateX(3px); }

/* The brand CTA uses a 6-stop gradient that traces the logo tooth icon
   left-to-right (coral -> yellow -> sage -> teal -> navy -> purple). The
   yellow stop is intentionally narrow so the white text never sits on a
   low-contrast band. Hover slides the gradient position for a subtle
   "alive" feel. Exact colours sampled from Assets/simbolo@4x-8.png.

   90deg keeps the gradient bands perfectly vertical — a diagonal angle
   on a wide pill button creates a visible coral wedge on the bottom-left.
   background-clip: padding-box stops the gradient from leaking into the
   transparent border the base .btn rule paints. */
.btn--accent {
	background-image: linear-gradient(
		90deg,
		#F09D58 0%,
		#F3BD43 12%,
		#85B688 30%,
		#027298 55%,
		#505BA6 78%,
		#9064AC 100%
	);
	background-size: 200% 100%;
	background-position: 0% 50%;
	background-clip: padding-box;
	border-color: transparent;
	color: #fff;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
	box-shadow: var(--sh-md);
	transition:
		background-position var(--t-base) var(--ease),
		transform var(--t-fast) var(--ease),
		box-shadow var(--t-base) var(--ease);
}
.btn--accent:hover {
	background-position: 100% 50%;
	transform: translateY(-1px);
	box-shadow: var(--sh-lg);
	color: #fff;
}

/* Footer "Book your appointment": the multicolor gradient leaves white text
   unreadable on its light segments against the dark footer — use a solid,
   high-contrast coral instead. */
.site-footer .btn--accent {
	background-image: none;
	background-color: var(--c-coral-700);
}
.site-footer .btn--accent:hover {
	background-color: var(--c-coral-600);
}

/* Rating stars must read as filled shapes, not outlines. */
.ns-icon--star {
	fill: currentColor;
}

.btn--primary {
	background: var(--color-primary);
	color: var(--color-on-primary);
	box-shadow: var(--sh-sm);
}
.btn--primary:hover { background: var(--color-primary-dark); color: #fff; }

.btn--ghost {
	background: transparent;
	color: var(--color-primary);
	border-color: currentColor;
}
.btn--ghost:hover { background: var(--c-teal-50); }

.btn--on-teal {
	background: #fff;
	color: var(--color-primary-dark);
}
.btn--on-teal:hover { background: var(--c-teal-50); }

.btn--sm { padding: 0.7rem 1.2rem; font-size: 0.9rem; }
.btn--lg { padding: 1.15rem 2.1rem; font-size: 1.05rem; }
.btn--block { width: 100%; }

.text-link {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: var(--fw-semibold);
	color: var(--color-primary);
}
.text-link svg { transition: transform var(--t-base) var(--ease); }
.text-link:hover svg { transform: translateX(4px); }

.ns-icon { flex: none; }

/* --- Skip link / screen reader --------------------------------------- */
.skip-link {
	position: fixed;
	top: -100px;
	left: 1rem;
	z-index: 999;
	background: var(--color-primary);
	color: #fff;
	padding: 0.75rem 1.25rem;
	border-radius: var(--r-sm);
	transition: top var(--t-fast) var(--ease);
}
.skip-link:focus { top: 1rem; color: #fff; }

.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0 0 0 0);
	white-space: nowrap; border: 0;
}

/* --- Site header ------------------------------------------------------ */
.site-header {
	position: sticky;
	top: 0;
	z-index: var(--z-header);
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: saturate(150%) blur(12px);
	-webkit-backdrop-filter: saturate(150%) blur(12px);
	border-bottom: 1px solid transparent;
	transition: box-shadow var(--t-base) var(--ease),
		border-color var(--t-base) var(--ease),
		background-color var(--t-base) var(--ease);
}
.site-header.is-stuck {
	box-shadow: var(--sh-sm);
	border-color: var(--color-border);
}
.site-header__inner {
	display: flex;
	align-items: center;
	gap: clamp(1.5rem, 0.8rem + 2vw, 3rem);
	min-height: 100px;
}
.site-header__brand {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}
.site-logo {
	height: 64px;
	width: auto;
	aspect-ratio: 960 / 220;
	flex-shrink: 0;
	display: block;
}
.site-footer__logo { height: 56px; width: auto; }
.site-logo--text {
	font-family: var(--font-display);
	font-size: 1.5rem;
	color: var(--color-primary);
	font-weight: var(--fw-medium);
}

.site-nav { margin-inline: auto; }
.site-nav__list {
	display: flex;
	align-items: center;
	gap: clamp(1.4rem, 0.6rem + 1.8vw, 2.75rem);
	list-style: none;
	margin: 0; padding: 0;
}
.site-nav__list a {
	position: relative;
	color: var(--color-text);
	font-weight: var(--fw-medium);
	font-size: 0.97rem;
	padding-block: 0.5rem;
}
.site-nav__list a::after {
	content: "";
	position: absolute;
	left: 0; bottom: 0;
	width: 100%; height: 2px;
	background: var(--color-accent);
	transform: scaleX(0);
	transform-origin: right;
	transition: transform var(--t-base) var(--ease);
}
.site-nav__list a:hover,
.site-nav__list .current-menu-item > a { color: var(--color-primary); }
.site-nav__list a:hover::after,
.site-nav__list .current-menu-item > a::after { transform: scaleX(1); transform-origin: left; }

/* Dropdown (services) */
.site-nav__list .menu-item-has-children { position: relative; }
.site-nav__list .sub-menu {
	position: absolute;
	top: 100%; left: 50%;
	transform: translateX(-50%) translateY(8px);
	min-width: 250px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--r-md);
	box-shadow: var(--sh-md);
	padding: 0.5rem;
	list-style: none;
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.site-nav__list .menu-item-has-children:hover > .sub-menu,
.site-nav__list .menu-item-has-children:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(4px);
}
.site-nav__list .sub-menu a {
	display: block;
	padding: 0.7rem 0.9rem;
	border-radius: var(--r-sm);
	font-size: 0.92rem;
}
.site-nav__list .sub-menu a::after { display: none; }
.site-nav__list .sub-menu a:hover { background: var(--c-teal-50); }

.site-header__actions { display: flex; align-items: center; gap: var(--sp-5); margin-left: auto; }
.site-header__call {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	font-weight: var(--fw-semibold);
	font-size: 0.92rem;
	color: var(--color-primary);
}
.site-header__call span { white-space: nowrap; }

.nav-toggle {
	display: none;
	color: var(--color-primary);
	background: var(--c-teal-50);
	border: 1.5px solid var(--c-teal-100);
	border-radius: var(--r-md);
	padding: 0.6rem;
	min-width: 44px;
	min-height: 44px;
	transition: background-color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.nav-toggle:hover,
.nav-toggle:focus-visible {
	background: var(--c-teal-100);
	border-color: var(--color-primary);
}
.nav-toggle__close { display: none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__open { display: none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__close { display: block; }

/* --- Mobile nav ------------------------------------------------------- */
.mobile-nav {
	position: fixed;
	inset: 100px 0 0 0;
	z-index: var(--z-mobile-nav);
	background: #fff;
	padding: var(--sp-6) var(--gutter) var(--sp-8);
	overflow-y: auto;
	box-shadow: var(--sh-lg);
	border-top: 1px solid var(--color-border);
	transform: translateY(-12px);
	opacity: 0;
	transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.mobile-nav:not([hidden]) { opacity: 1; transform: none; }
/* Safety net: some browsers cache stale aria-expanded state and the JS
   sets panel.hidden directly, but we belt-and-suspenders with the attr. */
.nav-toggle[aria-expanded="true"] ~ .mobile-nav { opacity: 1; transform: none; }
.mobile-nav__list { list-style: none; margin: 0; padding: 0; }
.mobile-nav__list a {
	display: block;
	padding: 1rem 0;
	font-family: var(--font-display);
	font-size: 1.35rem;
	color: var(--color-text);
	border-bottom: 1px solid var(--color-border);
}
.mobile-nav__list .sub-menu { list-style: none; padding-left: 1rem; }
.mobile-nav__list .sub-menu a { font-size: 1.05rem; color: var(--color-text-muted); }
.mobile-nav__cta { display: grid; gap: var(--sp-3); margin-top: var(--sp-6); }

/* --- Floating actions ------------------------------------------------- */
.floating-actions {
	position: fixed;
	right: clamp(1rem, 2vw, 1.75rem);
	bottom: clamp(1rem, 2vw, 1.75rem);
	z-index: var(--z-float);
	display: flex;
	flex-direction: row;
	align-items: flex-end;
	gap: var(--sp-3);
}
.floating-actions__btn {
	width: 56px; height: 56px;
	display: grid;
	place-items: center;
	border-radius: var(--r-pill);
	color: #fff;
	box-shadow: var(--sh-md);
	transition: transform var(--t-fast) var(--ease), box-shadow var(--t-base) var(--ease);
}
.floating-actions__btn:hover { transform: scale(1.07); color: #fff; }
.floating-actions__btn--wa { background: #25D366; }
.floating-actions__btn--call { background: var(--color-primary); }
.floating-actions__btn--call { display: none; }

/* Cherry "Pay over time" floating pill — matches Cherry's widget design */
.floating-actions__btn--cherry {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	width: auto;
	height: auto;
	padding: 0.55rem 1.1rem 0.55rem 0.6rem;
	background: #4f63d2;
	color: #fff;
	border-radius: var(--r-pill);
	text-align: left;
	white-space: nowrap;
}
.floating-actions__cherry-icon {
	display: grid;
	place-items: center;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.22);
	flex: none;
}
.floating-actions__cherry-text {
	display: flex;
	flex-direction: column;
	line-height: 1.18;
}
.floating-actions__cherry-text strong { font-size: 0.92rem; font-weight: 700; }
.floating-actions__cherry-text small { font-size: 0.7rem; opacity: 0.92; }
@media (max-width: 520px) {
	.floating-actions__cherry-text small { display: none; }
}

/* --- Accessibility widget -------------------------------------------- */
.a11y-widget {
	position: fixed;
	left: clamp(1rem, 2vw, 1.75rem);
	bottom: clamp(1rem, 2vw, 1.75rem);
	z-index: var(--z-a11y);
}
.a11y-widget__toggle {
	width: 52px; height: 52px;
	border-radius: var(--r-pill);
	background: var(--color-primary);
	color: #fff;
	display: grid;
	place-items: center;
	box-shadow: var(--sh-md);
	transition: transform var(--t-fast) var(--ease);
}
.a11y-widget__toggle:hover { transform: scale(1.06); }
.a11y-widget__panel {
	position: absolute;
	left: 0;
	bottom: calc(100% + 12px);
	width: 248px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--r-md);
	box-shadow: var(--sh-lg);
	padding: var(--sp-4);
}
.a11y-widget__title {
	font-family: var(--font-display);
	font-weight: var(--fw-medium);
	margin-bottom: var(--sp-3);
	color: var(--color-primary);
}
.a11y-btn {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	width: 100%;
	padding: 0.7rem 0.75rem;
	border-radius: var(--r-sm);
	font-size: 0.9rem;
	color: var(--color-text);
	transition: background-color var(--t-fast) var(--ease);
}
.a11y-btn + .a11y-btn { margin-top: 0.25rem; }
.a11y-btn:hover { background: var(--c-teal-50); }
.a11y-btn[aria-pressed="true"] { background: var(--c-teal-100); color: var(--color-primary-dark); }
.a11y-btn__state { margin-left: auto; font-weight: var(--fw-bold); }
.a11y-btn--reset { justify-content: center; color: var(--color-text-muted); }

/* --- Footer ----------------------------------------------------------- */
.site-footer {
	background: var(--c-teal-900);
	color: #cfe6ed;
	margin-top: var(--section-y);
}
.site-footer__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 0.9fr;
	gap: clamp(2rem, 1rem + 3vw, 4rem);
	padding-block: clamp(3rem, 2rem + 4vw, 5.5rem);
}
.site-footer__logo { filter: brightness(0) invert(1); opacity: 0.95; }
.site-footer__tagline { margin-top: var(--sp-4); color: #9fc4cf; max-width: 38ch; font-size: 0.95rem; }
.site-footer__title {
	font-size: 1.1rem;
	color: #fff;
	margin-bottom: var(--sp-4);
	font-weight: var(--fw-medium);
}
.site-footer a { color: #cfe6ed; }
.site-footer a:hover { color: #fff; }
.site-footer__address { font-style: normal; display: grid; gap: var(--sp-3); }
.site-footer__address a { display: flex; gap: 0.6rem; align-items: flex-start; }
.site-footer__address small { display: block; color: #8fb6c2; }
.hours-list { list-style: none; margin: 0 0 var(--sp-5); padding: 0; }
.hours-list li {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.4rem 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	font-size: 0.92rem;
}
.hours-list__time { color: #fff; }
.site-footer__menu { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--sp-3); }
.social-list { list-style: none; display: flex; gap: var(--sp-3); margin: var(--sp-5) 0 0; padding: 0; }
.social-list a {
	width: 42px; height: 42px;
	display: grid; place-items: center;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--r-pill);
	transition: background-color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.social-list a:hover { background: var(--color-accent); border-color: var(--color-accent); }
.site-footer__bar { border-top: 1px solid rgba(255, 255, 255, 0.1); }
.site-footer__bar-inner {
	display: flex;
	justify-content: space-between;
	gap: var(--sp-4);
	padding-block: var(--sp-5);
	font-size: 0.82rem;
	color: #8fb6c2;
	flex-wrap: wrap;
}

.site-footer__credits {
	flex-basis: 100%;
	font-size: 0.72rem;
	opacity: 0.65;
	margin-top: calc(-1 * var(--sp-3));
}

/* --- Generic card ----------------------------------------------------- */
.card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--r-lg);
	padding: var(--sp-6);
	box-shadow: var(--sh-xs);
	transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }

/* --- Responsive ------------------------------------------------------- */
@media (max-width: 1024px) {
	.site-nav, .site-header__call { display: none; }
	.nav-toggle { display: grid; place-items: center; }
	.site-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 700px) {
	.floating-actions__btn--call { display: grid; }
	.site-footer__grid { grid-template-columns: 1fr; }
	/* Hide the CTA label on phones so the button collapses to a calendar icon
	   that fits the narrow header — the full label stays in the aria-label
	   for screen readers, and the mobile nav offers the full CTA button. */
	.site-header__cta .btn__label { display: none; }
	.site-header__cta { padding-inline: 0.85rem; gap: 0; }
}

/* =========================================================================
   Narrow-mobile header — shrink the logo so the hamburger + book CTA fit
   inside narrow phone viewports (<= 700px / iPhone SE territory). The
   intrinsic aspect ratio scales the width down with the height, so the
   logo stays proportional, never deformed.
   ========================================================================= */
@media (max-width: 700px) {
	.site-logo { height: 52px; }
	.site-header__inner { min-height: 84px; }
	.mobile-nav { inset: 84px 0 0 0; }
}
@media (max-width: 420px) {
	.site-logo { height: 44px; }
	.site-header__inner { min-height: 76px; }
	.mobile-nav { inset: 76px 0 0 0; }
	.site-header__inner { gap: var(--sp-3); }
}
