/*
 * Styler Agency — main stylesheet
 * Tokens come from inline :root variables injected by inc/enqueue.php
 */

/* ============ Reset / base ============ */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: var(--base-size, 16px); scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--c-bg, #0B0B0F);
	color: var(--c-text, #F4F4F5);
	font-family: var(--font-body, "Inter", system-ui, sans-serif);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}
img, svg, video { max-width: 100%; display: block; height: auto; }
a { color: inherit; text-decoration: none; transition: color .2s ease, opacity .2s ease; }
a:hover { color: var(--c-accent); }
button { font-family: inherit; cursor: pointer; }
::selection { background: var(--c-accent); color: #000; }

h1, h2, h3, h4, h5 {
	font-family: var(--font-display);
	font-weight: 700;
	line-height: 1.1;
	margin: 0 0 .6em;
	letter-spacing: -0.015em;
}
h1, .styler-h1 { font-size: clamp(2.4rem, 5.5vw, 5rem); }
h2, .styler-h2 { font-size: clamp(1.8rem, 3.5vw, 3rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.6rem); }
p { margin: 0 0 1em; }

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px; width: 1px; overflow: hidden;
	word-wrap: normal !important;
}
.skip-link {
	position: absolute; top: -100px; left: 1rem;
	background: var(--c-accent); color: #000; padding: .6rem 1rem;
	border-radius: 8px; z-index: 9999;
}
.skip-link:focus { top: 1rem; }

/* ============ Layout ============ */
.container {
	width: 100%;
	max-width: var(--container-max, 1280px);
	margin: 0 auto;
	padding: 0 clamp(1rem, 3vw, 2rem);
}
.styler-section { padding: clamp(3rem, 7vw, 6rem) 0; position: relative; }
.styler-eyebrow {
	display: inline-flex; align-items: center; gap: .5rem;
	color: var(--c-muted);
	font-size: .8rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	margin: 0 0 1rem;
	font-weight: 500;
}
.styler-lede { color: var(--c-muted); font-size: 1.15rem; max-width: 60ch; }
.styler-prose { max-width: 70ch; }
.styler-prose img { border-radius: var(--radius-card); margin: 1.5rem 0; }
.styler-prose blockquote {
	border-left: 3px solid var(--c-accent);
	padding-left: 1.5rem; margin: 1.5rem 0; color: var(--c-muted);
	font-style: italic;
}
.styler-prose--center { margin-inline: auto; text-align: center; }

.styler-section-head { margin-bottom: clamp(1.5rem, 3vw, 2.5rem); }

/* Grids */
.styler-grid { display: grid; gap: clamp(1rem, 2vw, 1.75rem); }
.styler-grid--2 { grid-template-columns: repeat(2, 1fr); }
.styler-grid--3 { grid-template-columns: repeat(3, 1fr); }
.styler-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) {
	.styler-grid--3, .styler-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.styler-grid--2, .styler-grid--3, .styler-grid--4 { grid-template-columns: 1fr; }
}

/* ============ Buttons ============ */
.styler-btn {
	display: inline-flex; align-items: center; gap: .5rem;
	padding: .85rem 1.4rem;
	border-radius: var(--radius-pill);
	font-weight: 600; font-size: .95rem;
	border: 1px solid transparent;
	transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
	white-space: nowrap;
	line-height: 1;
}
.styler-btn--primary { background: var(--c-accent); color: #000; }
.styler-btn--primary:hover { transform: translateY(-2px); box-shadow: 0 12px 24px -10px color-mix(in srgb, var(--c-accent) 60%, transparent); color: #000; }
.styler-btn--ghost {
	background: transparent;
	color: var(--c-text);
	border-color: var(--c-border);
}
.styler-btn--ghost:hover { border-color: var(--c-accent); color: var(--c-text); }

/* ============ Header ============ */
.styler-header {
	position: sticky;
	top: 0; z-index: 100;
	background: color-mix(in srgb, var(--c-bg) 75%, transparent);
	backdrop-filter: blur(var(--blur-header, 12px));
	-webkit-backdrop-filter: blur(var(--blur-header, 12px));
	border-bottom: 1px solid color-mix(in srgb, var(--c-border) 50%, transparent);
}
.styler-no-header .styler-header { display: none; }
.styler-transparent-header .styler-header { background: transparent; border-bottom: 0; }

.styler-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 1rem; min-height: 72px;
}
.styler-logo { display: inline-flex; align-items: center; font-weight: 700; font-family: var(--font-display); font-size: 1.25rem; }
.styler-logo img, .styler-logo .custom-logo { max-height: 40px; width: auto; }

.styler-nav { display: flex; flex: 1; justify-content: center; }
.styler-menu { display: flex; gap: 1.5rem; list-style: none; margin: 0; padding: 0; }
.styler-menu a { font-size: .95rem; color: var(--c-text); opacity: .85; }
.styler-menu a:hover { opacity: 1; color: var(--c-text); }
.styler-menu .current-menu-item > a { color: var(--c-accent); opacity: 1; }

.styler-header__cta { display: flex; align-items: center; gap: .75rem; }
.styler-burger {
	display: none;
	background: transparent; border: 1px solid var(--c-border);
	border-radius: 999px; padding: .5rem; color: var(--c-text);
}
@media (max-width: 900px) {
	.styler-nav { display: none; }
	.styler-burger { display: inline-flex; }
}

.styler-mobile-menu {
	position: fixed; inset: 0; background: var(--c-bg);
	z-index: 99; opacity: 0; pointer-events: none;
	transition: opacity .25s ease;
	padding: 6rem 1.5rem 2rem;
}
.styler-mobile-menu.is-open { opacity: 1; pointer-events: auto; }
.styler-menu--mobile { flex-direction: column; gap: 1rem; font-size: 1.5rem; }

/* ============ Hero & sections ============ */
.styler-page-hero { padding-top: clamp(3rem, 8vw, 6rem); }
.styler-hero__inner { display: grid; grid-template-columns: 1.2fr 1fr; gap: 3rem; align-items: center; }
@media (max-width: 900px) { .styler-hero__inner { grid-template-columns: 1fr; } }
.styler-hero__cta { display: flex; gap: .75rem; margin-top: 1.5rem; flex-wrap: wrap; }
.styler-hero__media img { border-radius: calc(var(--radius-card) * 1.5); }

/* ============ Cards ============ */
.styler-card {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--radius-card);
	overflow: hidden;
	transition: transform .25s ease, border-color .25s ease;
}
.styler-card:hover { transform: translateY(-4px); border-color: color-mix(in srgb, var(--c-accent) 50%, var(--c-border)); }
.styler-card__media {
	display: block; aspect-ratio: 4/3; overflow: hidden; position: relative; background: var(--c-bg);
}
.styler-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.styler-card:hover .styler-card__media img { transform: scale(1.04); }
.styler-card__placeholder { position: absolute; inset: 0; background: linear-gradient(135deg, var(--c-surface), var(--c-bg)); }
.styler-card__hover {
	position: absolute; inset: 0;
	display: grid; place-items: center;
	background: color-mix(in srgb, var(--c-bg) 50%, transparent);
	opacity: 0; transition: opacity .25s ease;
}
.styler-card__hover span { background: var(--c-accent); color: #000; width: 56px; height: 56px; border-radius: 50%; display: grid; place-items: center; }
.styler-card:hover .styler-card__hover { opacity: 1; }

.styler-card__body { padding: 1.25rem 1.25rem 1.5rem; display: flex; flex-direction: column; gap: .6rem; }
.styler-card__meta { color: var(--c-muted); font-size: .85rem; margin: 0; }
.styler-card__title { margin: 0; font-size: 1.15rem; }
.styler-card__title a:hover { color: var(--c-text); }
.styler-card__excerpt { color: var(--c-muted); margin: 0; }
.styler-card__cta { display: inline-flex; align-items: center; gap: .4rem; margin-top: auto; color: var(--c-accent); font-weight: 600; }
.styler-card__icon { width: 56px; height: 56px; border-radius: 16px; background: color-mix(in srgb, var(--c-accent) 14%, transparent); display: grid; place-items: center; padding: 10px; }

.styler-tags { display: flex; flex-wrap: wrap; gap: .4rem; padding: 0; margin: .5rem 0 0; list-style: none; }
.styler-tags li { font-size: .75rem; padding: .25rem .6rem; border: 1px solid var(--c-border); border-radius: 999px; color: var(--c-muted); }

/* ============ Stats ============ */
.styler-stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; text-align: left; }
@media (max-width: 700px) { .styler-stats__grid { grid-template-columns: repeat(2, 1fr); } }
.styler-stat__value { font-size: clamp(2.5rem, 5vw, 4rem); margin: 0; color: var(--c-text); }
.styler-stat__label { color: var(--c-muted); margin: 0; font-size: .9rem; text-transform: uppercase; letter-spacing: .1em; }

/* ============ Logo marquee ============ */
.styler-marquee { overflow: hidden; padding-block: 2rem; }
.styler-marquee__track { display: flex; gap: 3rem; width: max-content; animation: styler-scroll 30s linear infinite; }
.styler-marquee__item { flex: 0 0 auto; opacity: .7; filter: grayscale(1); transition: opacity .3s; }
.styler-marquee__item img { max-height: 36px; width: auto; }
.styler-marquee__item:hover { opacity: 1; filter: none; }
@keyframes styler-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .styler-marquee__track { animation: none; } }

/* ============ Benefits ============ */
.styler-benefits__grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 3rem; align-items: start; }
@media (max-width: 900px) { .styler-benefits__grid { grid-template-columns: 1fr; gap: 1.5rem; } }
.styler-benefits__list { list-style: none; margin: 0; padding: 0; display: grid; gap: 1rem; }
.styler-benefits__list li {
	background: var(--c-surface); border: 1px solid var(--c-border);
	border-radius: var(--radius-card); padding: 1.25rem 1.5rem;
	display: grid; grid-template-columns: auto 1fr; gap: 1rem; align-items: center;
}
.styler-benefits__list li p { grid-column: 2; margin: .2rem 0 0; color: var(--c-muted); font-size: .92rem; }
.styler-benefits__bullet { width: 12px; height: 12px; border-radius: 50%; background: var(--c-accent); display: inline-block; }

/* ============ Image+Text ============ */
.styler-image-text__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.styler-image-text--flip .styler-image-text__media { order: 2; }
@media (max-width: 900px) { .styler-image-text__grid { grid-template-columns: 1fr; } .styler-image-text--flip .styler-image-text__media { order: 0; } }
.styler-image-text__media img { border-radius: calc(var(--radius-card) * 1.5); }

/* ============ Testimonials slider ============ */
.styler-slider { position: relative; }
.styler-slider__track { display: flex; gap: 1.5rem; overflow-x: auto; scroll-snap-type: x mandatory; padding: 1rem 0; scrollbar-width: none; }
.styler-slider__track::-webkit-scrollbar { display: none; }
.styler-testimonial {
	flex: 0 0 min(520px, 88%);
	scroll-snap-align: start;
	background: var(--c-surface); border: 1px solid var(--c-border);
	border-radius: var(--radius-card); padding: 2rem; margin: 0;
}
.styler-testimonial blockquote { font-size: 1.25rem; line-height: 1.5; margin: 0 0 1.25rem; color: var(--c-text); border: 0; padding: 0; font-style: normal; }
.styler-testimonial figcaption { display: flex; flex-direction: column; gap: .15rem; color: var(--c-muted); font-size: .92rem; }
.styler-testimonial figcaption strong { color: var(--c-text); }
.styler-slider__controls { display: flex; gap: .5rem; justify-content: flex-end; margin-top: 1rem; }
.styler-slider__controls button {
	width: 44px; height: 44px; border-radius: 50%;
	background: transparent; border: 1px solid var(--c-border); color: var(--c-text);
	font-size: 1.4rem; line-height: 1;
}
.styler-slider__controls button:hover { border-color: var(--c-accent); color: var(--c-accent); }

/* ============ FAQ accordion ============ */
.styler-faq__grid { display: grid; grid-template-columns: 1fr 1.6fr; gap: 3rem; align-items: start; }
@media (max-width: 900px) { .styler-faq__grid { grid-template-columns: 1fr; gap: 1.5rem; } }
.styler-accordion { display: grid; gap: .5rem; }
.styler-accordion__item {
	background: var(--c-surface); border: 1px solid var(--c-border);
	border-radius: var(--radius-card); overflow: hidden;
}
.styler-accordion__item summary {
	list-style: none; cursor: pointer;
	display: flex; align-items: center; justify-content: space-between; gap: 1rem;
	padding: 1.25rem 1.5rem; font-weight: 600;
}
.styler-accordion__item summary::-webkit-details-marker { display: none; }
.styler-accordion__item summary svg { transition: transform .25s ease; flex-shrink: 0; }
.styler-accordion__item[open] summary svg { transform: rotate(45deg); }
.styler-accordion__body { padding: 0 1.5rem 1.5rem; color: var(--c-muted); }

/* ============ Pricing ============ */
.styler-tier {
	background: var(--c-surface); border: 1px solid var(--c-border);
	border-radius: var(--radius-card); padding: 2rem;
	display: flex; flex-direction: column; gap: .75rem;
}
.styler-tier--featured { border-color: var(--c-accent); }
.styler-tier__price { font-size: 2.25rem; font-weight: 700; color: var(--c-text); margin: 0; font-family: var(--font-display); }
.styler-tier__name { margin: 0; }
.styler-tier__desc { color: var(--c-muted); margin: 0; }
.styler-tier__features { list-style: none; padding: 0; margin: .5rem 0 1rem; display: grid; gap: .5rem; }
.styler-tier__features li::before { content: "✓"; color: var(--c-accent); margin-right: .5rem; }
.styler-tier .styler-btn { margin-top: auto; justify-content: center; }

/* ============ CTA section ============ */
.styler-cta__inner {
	background: var(--c-surface); border: 1px solid var(--c-border);
	border-radius: calc(var(--radius-card) * 1.5);
	padding: clamp(2.5rem, 6vw, 5rem) clamp(1.5rem, 4vw, 3rem);
	text-align: center;
	background-image: radial-gradient(60% 80% at 50% 0%, color-mix(in srgb, var(--c-accent) 12%, transparent), transparent 70%);
}
.styler-cta__heading { font-size: clamp(2rem, 4vw, 3.5rem); margin: 0 0 1.25rem; }

/* ============ Service single ============ */
.styler-service-single__hero { display: flex; flex-direction: column; align-items: flex-start; gap: 1rem; }
.styler-service-single__icon { width: 72px; height: 72px; border-radius: 18px; background: color-mix(in srgb, var(--c-accent) 14%, transparent); padding: 14px; }
.styler-feature { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius-card); padding: 1.5rem; }
.styler-feature h3 { margin: 0 0 .5rem; font-size: 1.1rem; }
.styler-feature p { color: var(--c-muted); margin: 0; }
.styler-process { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; gap: 1rem; }
.styler-process li { display: grid; grid-template-columns: auto 1fr; gap: 1.25rem; padding: 1.25rem; background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius-card); }
.styler-process__num { font-family: var(--font-display); font-size: 2rem; color: var(--c-accent); line-height: 1; }
.styler-process h3 { margin: 0 0 .25rem; }
.styler-process p { margin: 0; color: var(--c-muted); }

/* ============ Work single ============ */
.styler-work-single__cover { margin-top: 1rem; border-radius: calc(var(--radius-card) * 1.5); overflow: hidden; }
.styler-work-single__cover img { width: 100%; height: auto; }
.styler-work-single__layout { display: grid; grid-template-columns: 320px 1fr; gap: 3rem; align-items: start; }
@media (max-width: 900px) { .styler-work-single__layout { grid-template-columns: 1fr; } }
.styler-work-single__meta { display: grid; gap: 1rem; background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius-card); padding: 1.5rem; position: sticky; top: 96px; }
.styler-work-single__meta > div { display: grid; gap: .25rem; }
.styler-work-single__meta span { color: var(--c-muted); font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; }
.styler-gallery { display: grid; gap: 1.5rem; }
.styler-gallery img { width: 100%; height: auto; border-radius: var(--radius-card); }

.styler-work-nav__inner { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.styler-work-nav__prev, .styler-work-nav__next { display: inline-flex; align-items: center; gap: .5rem; color: var(--c-muted); }
.styler-work-nav__prev:hover, .styler-work-nav__next:hover { color: var(--c-text); }
.styler-work-nav__prev svg { transform: rotate(180deg); }

/* ============ Footer ============ */
.styler-footer { border-top: 1px solid var(--c-border); padding: 4rem 0 2rem; }
.styler-no-footer .styler-footer { display: none; }
.styler-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 2.5rem; margin-bottom: 3rem; }
@media (max-width: 900px) { .styler-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .styler-footer__grid { grid-template-columns: 1fr; } }
.styler-footer__tagline { color: var(--c-muted); max-width: 32ch; }
.styler-footer__heading { color: var(--c-muted); font-size: .85rem; letter-spacing: .12em; text-transform: uppercase; margin: 0 0 1rem; font-weight: 600; }
.styler-footer__menu { list-style: none; padding: 0; margin: 0; display: grid; gap: .5rem; }
.styler-footer__menu a { color: var(--c-text); opacity: .8; }
.styler-footer__menu a:hover { opacity: 1; color: var(--c-accent); }
.styler-footer__bottom { border-top: 1px solid var(--c-border); padding-top: 1.5rem; color: var(--c-muted); }
.styler-footer__contact p { margin: 0 0 .5rem; }
.styler-footer__phone a { color: var(--c-text); font-weight: 700; font-size: 1.1rem; letter-spacing: -.01em; }
.styler-footer__phone a:hover { color: var(--c-accent); }
.styler-footer__email a { color: var(--c-text); opacity: .85; }
.styler-footer__email a:hover { opacity: 1; color: var(--c-accent); }
.styler-footer__serving { color: var(--c-muted); margin-top: .75rem !important; font-size: .9rem; }
.styler-footer__addresses { list-style: none; padding: 0; margin: .5rem 0 0; display: grid; gap: .5rem; color: var(--c-muted); font-size: .9rem; line-height: 1.5; }
.styler-footer__addresses li { padding-left: 1rem; position: relative; }
.styler-footer__addresses li::before { content: '•'; position: absolute; left: 0; color: var(--c-accent); }
.styler-benefits-list { list-style: none; padding: 0; margin: 1.5rem 0 0; display: grid; gap: 1rem; }
.styler-benefits-list li { padding: 1rem 1.25rem; background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius-card); position: relative; padding-left: 2.75rem; }
.styler-benefits-list li::before { content: '✓'; position: absolute; left: 1rem; top: 1rem; color: var(--c-accent); font-weight: 700; }

.styler-socials { display: flex; gap: .75rem; margin-top: 1rem; flex-wrap: wrap; }
.styler-social {
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px; border-radius: 50%;
	border: 1px solid var(--c-border); color: var(--c-text);
	transition: border-color .2s, color .2s;
}
.styler-social:hover { border-color: var(--c-accent); color: var(--c-accent); }

/* ============ Form ============ */
.styler-form { display: grid; gap: 1rem; max-width: 640px; }
.styler-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 600px) { .styler-form__row { grid-template-columns: 1fr; } }
.styler-form label { display: grid; gap: .35rem; font-size: .85rem; color: var(--c-muted); }
.styler-form input, .styler-form textarea {
	background: var(--c-surface);
	color: var(--c-text);
	border: 1px solid var(--c-border);
	border-radius: 12px; padding: .85rem 1rem; font: inherit;
	transition: border-color .2s;
}
.styler-form input:focus, .styler-form textarea:focus { outline: 2px solid color-mix(in srgb, var(--c-accent) 60%, transparent); outline-offset: 2px; border-color: var(--c-accent); }
.styler-form__success { color: var(--c-accent); }
.styler-form__error { color: #ff6b6b; }

/* ============ Pagination ============ */
.styler-pagination { display: flex; justify-content: center; gap: .5rem; margin-top: 2.5rem; }
.styler-pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 40px; height: 40px; padding: 0 .8rem; border-radius: 999px;
	background: var(--c-surface); border: 1px solid var(--c-border); color: var(--c-text);
}
.styler-pagination .page-numbers.current { background: var(--c-accent); color: #000; border-color: transparent; }

/* ============ Animations ============ */
[data-anim] { opacity: 0; transform: translateY(20px); transition: opacity .8s ease, transform .8s ease; will-change: opacity, transform; }
[data-anim].is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
	[data-anim] { opacity: 1; transform: none; transition: none; }
}
/* .styler-motion-on relies on the [data-anim] defaults above */

/* ============ Custom cursor ============ */
.styler-cursor-on { cursor: none; }
.styler-cursor-on a, .styler-cursor-on button { cursor: none; }
.styler-cursor {
	position: fixed; top: 0; left: 0; width: 28px; height: 28px; border: 1.5px solid var(--c-accent);
	border-radius: 50%; pointer-events: none; transform: translate(-50%,-50%);
	z-index: 9999; transition: transform .15s ease, width .15s ease, height .15s ease, background .15s ease;
	mix-blend-mode: difference;
}
.styler-cursor.is-hover { width: 56px; height: 56px; background: color-mix(in srgb, var(--c-accent) 30%, transparent); }

/* ============ Cal.com embed ============ */
.styler-cal-embed iframe { width: 100%; border: 0; border-radius: var(--radius-card); }

/* ============ Misc ============ */
.styler-page-cover img { width: 100%; max-height: 60vh; object-fit: cover; }
.styler-search { display: flex; gap: .5rem; max-width: 480px; margin-top: 1rem; }
.styler-search input { flex: 1; background: var(--c-surface); border: 1px solid var(--c-border); color: var(--c-text); border-radius: 999px; padding: .8rem 1.25rem; font: inherit; }
.widget-title { color: var(--c-muted); text-transform: uppercase; letter-spacing: .1em; font-size: .85rem; }
