/* =========================================================
 * ROADCREW — Theme styles
 * ========================================================= */

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
section[id] { scroll-margin-top: 80px; }
body {
	margin: 0;
	background: var(--rc-bg, #09090B);
	color: var(--rc-text, #FAFAFA);
	font-family: var(--rc-font-body, 'Chivo', sans-serif);
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
body::before {
	content: "";
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 1;
	opacity: 0.06;
	mix-blend-mode: overlay;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.7'/></svg>");
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--rc-primary); }

h1, h2, h3, h4 {
	font-family: var(--rc-font-heading, 'Anton', sans-serif);
	font-weight: 400;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	line-height: 0.95;
	color: var(--rc-text);
	margin: 0;
}
h1 { font-size: clamp(2.75rem, 6vw + 1rem, 6.5rem); letter-spacing: -0.02em; }
h2 { font-size: clamp(2rem, 4vw + 1rem, 4.5rem); }
h3 { font-size: 1.5rem; }
h4 { font-size: 1rem; }
p { margin: 0 0 1rem; color: #A1A1AA; }

.screen-reader-text { position: absolute !important; clip: rect(1px,1px,1px,1px); padding: 0; border: 0; height: 1px; width: 1px; overflow: hidden; }
.rc-skip-link { position: absolute; left: -9999px; top: 1rem; z-index: 999; background: var(--rc-primary); color: #000; padding: .75rem 1rem; font-family: 'JetBrains Mono', monospace; }
.rc-skip-link:focus { left: 1rem; }

.rc-overline { font-family: 'JetBrains Mono', monospace; font-size: .75rem; letter-spacing: .2em; text-transform: uppercase; color: var(--rc-primary); display: inline-block; }

/* Buttons */
.rc-btn { display: inline-flex; align-items: center; justify-content: center; padding: 1rem 1.75rem; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; font-size: .8rem; letter-spacing: .12em; font-weight: 700; border: 2px solid transparent; transition: transform .2s, background-color .2s, color .2s, border-color .2s; cursor: pointer; }
.rc-btn--primary { background: var(--rc-primary); color: #000; }
.rc-btn--primary:hover { background: #fff; color: #000; transform: translate(-2px, -2px); box-shadow: 4px 4px 0 0 var(--rc-primary); }
.rc-btn--ghost { background: transparent; color: var(--rc-text); border-color: #3f3f46; }
.rc-btn--ghost:hover { border-color: var(--rc-primary); color: var(--rc-primary); }

/* Header */
.rc-header { position: sticky; top: 0; z-index: 60; backdrop-filter: blur(14px); background: color-mix(in srgb, var(--rc-bg) 78%, transparent); border-bottom: 1px solid #27272A; transition: background-color .3s; }
.rc-header.is-scrolled { background: color-mix(in srgb, var(--rc-bg) 94%, transparent); }
.rc-header__inner { display: flex; align-items: center; justify-content: space-between; max-width: 1440px; margin: 0 auto; padding: 1.15rem 1.5rem; }
.rc-brand { display: inline-flex; align-items: center; gap: .5rem; }
.rc-brand__mark { font-family: var(--rc-font-heading); font-size: 1.45rem; letter-spacing: -.01em; text-transform: uppercase; color: var(--rc-text); }
.rc-brand__mark::after { content: "."; color: var(--rc-primary); }
.rc-brand__logo { height: 44px; width: auto; object-fit: contain; display: block; }
.rc-brand__logo--footer { height: 56px; }
@media (min-width: 900px) { .rc-brand__logo { height: 48px; } }
.rc-nav__list { display: none; gap: 2.25rem; list-style: none; margin: 0; padding: 0; font-family: 'JetBrains Mono', monospace; font-size: .78rem; text-transform: uppercase; letter-spacing: .14em; }
.rc-nav__list li a { color: #A1A1AA; transition: color .2s; }
.rc-nav__list li a:hover { color: var(--rc-primary); }
.rc-nav__cta { border: 1px solid var(--rc-primary); color: var(--rc-primary) !important; padding: .55rem .9rem; }
.rc-nav__toggle { display: inline-flex; flex-direction: column; gap: 5px; background: transparent; border: 1px solid #3f3f46; padding: .65rem; cursor: pointer; }
.rc-nav__toggle span { display: block; width: 20px; height: 2px; background: var(--rc-text); }
.rc-mobile-nav { border-top: 1px solid #27272A; padding: 1rem 1.5rem 1.5rem; }
.rc-mobile-nav__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1rem; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; font-size: .85rem; letter-spacing: .12em; }

@media (min-width: 900px) {
	.rc-nav__list { display: flex; }
	.rc-nav__toggle { display: none; }
	.rc-mobile-nav { display: none !important; }
}

/* Hero */
.rc-hero { position: relative; min-height: 88vh; padding: 8rem 1.5rem 6rem; overflow: hidden; display: block; }
.rc-hero__bg, .rc-hero__bg-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; background-size: cover; background-position: center; z-index: 0; }
.rc-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(9,9,11,0.6) 0%, rgba(9,9,11,0.85) 70%, var(--rc-bg) 100%); z-index: 1; }
.rc-hero__inner { position: relative; z-index: 2; max-width: 1100px; width: 100%; margin-left: auto; margin-right: auto; min-height: calc(88vh - 14rem); display: flex; flex-direction: column; justify-content: center; text-align: left; }
.rc-hero__title { margin: 1.5rem 0 1rem; font-size: clamp(2.75rem, 5.5vw + 1rem, 6rem); line-height: 0.95; letter-spacing: -0.02em; text-wrap: balance; }
.rc-hero__subtitle { font-size: clamp(1rem, 1.2vw + .5rem, 1.25rem); max-width: 620px; color: #D4D4D8; }
.rc-hero__ctas { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.25rem; }

/* Marquee */
.rc-marquee { border-top: 1px solid #27272A; border-bottom: 1px solid #27272A; padding: 1rem 0; overflow: hidden; background: var(--rc-surface); position: relative; z-index: 2; }
.rc-marquee__track { display: flex; gap: 2.5rem; animation: rc-marquee 38s linear infinite; white-space: nowrap; font-family: var(--rc-font-heading); font-size: 2rem; text-transform: uppercase; letter-spacing: .03em; color: var(--rc-text); }
.rc-marquee__track span:nth-child(even) { color: var(--rc-primary); font-family: 'JetBrains Mono', monospace; font-size: 1rem; }
@keyframes rc-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* Section shell */
.rc-section { max-width: 1440px; margin: 0 auto; padding: 7rem 1.5rem; position: relative; z-index: 2; }
.rc-section__head { margin-bottom: 4rem; display: grid; gap: 1rem; max-width: 720px; }
.rc-section__lead { font-size: 1.1rem; color: #A1A1AA; max-width: 580px; }

/* Services bento */
.rc-services__grid { display: grid; grid-template-columns: repeat(1, 1fr); gap: 1px; background: #27272A; border: 1px solid #27272A; }
.rc-service { padding: 2.5rem 2rem; background: var(--rc-bg); position: relative; transition: background-color .3s; min-height: 260px; display: flex; flex-direction: column; gap: 1rem; }
.rc-service:hover { background: var(--rc-surface); }
.rc-service__icon { color: var(--rc-primary); }
.rc-service h3 { margin-top: .5rem; }
.rc-service p { color: #A1A1AA; }
.rc-service__num { position: absolute; top: 1rem; right: 1.5rem; font-family: 'JetBrains Mono', monospace; font-size: .75rem; color: #52525B; letter-spacing: .1em; }
.rc-service__image { margin-top: auto; aspect-ratio: 16/9; overflow: hidden; }
.rc-service__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.rc-service:hover .rc-service__image img { transform: scale(1.05); }

@media (min-width: 700px)  { .rc-services__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .rc-services__grid { grid-template-columns: repeat(3, 1fr); } }

/* Portfolio masonry */
.rc-portfolio__grid { display: grid; grid-template-columns: repeat(1, 1fr); gap: 1rem; }
@media (min-width: 700px)  { .rc-portfolio__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .rc-portfolio__grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 320px; } .rc-portfolio__item:nth-child(3n+1) { grid-row: span 2; } }
.rc-portfolio__item { margin: 0; position: relative; overflow: hidden; background: var(--rc-surface); aspect-ratio: 4/5; }
@media (min-width: 1100px) { .rc-portfolio__item { aspect-ratio: auto; height: 100%; } }
.rc-portfolio__item img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.rc-portfolio__item:hover img { transform: scale(1.06); }
.rc-portfolio__item figcaption { position: absolute; inset: auto 0 0 0; padding: 1.5rem; background: linear-gradient(transparent, rgba(9,9,11,.92)); }
.rc-portfolio__item figcaption h3 { color: #fff; }
.rc-portfolio__item figcaption p { color: #D4D4D8; margin: .25rem 0 0; font-size: .9rem; }

/* Collaborator */
.rc-collab__card { background: var(--rc-surface); border: 1px solid #27272A; display: grid; grid-template-columns: 1fr; gap: 0; }
@media (min-width: 900px) { .rc-collab__card { grid-template-columns: 1fr 1fr; } }
.rc-collab__media { background: #000; min-height: 300px; display: flex; align-items: center; justify-content: center; padding: 2rem; overflow: hidden; }
.rc-collab__media img { max-width: 100%; max-height: 320px; object-fit: contain; filter: grayscale(1) contrast(1.1); opacity: .92; }
.rc-collab__body { padding: 3rem 2rem; display: flex; flex-direction: column; gap: 1rem; }

/* FAQ */
.rc-faq__list { display: flex; flex-direction: column; border-top: 1px solid #27272A; }
.rc-faq__item { border-bottom: 1px solid #27272A; }
.rc-faq__item summary { list-style: none; padding: 1.5rem 0; cursor: pointer; display: flex; justify-content: space-between; align-items: center; font-family: 'JetBrains Mono', monospace; font-size: 1rem; color: var(--rc-text); text-transform: uppercase; letter-spacing: .06em; }
.rc-faq__item summary::-webkit-details-marker { display: none; }
.rc-faq__icon { font-size: 1.25rem; color: var(--rc-primary); transition: transform .25s; font-family: var(--rc-font-heading); }
.rc-faq__item[open] .rc-faq__icon { transform: rotate(45deg); }
.rc-faq__answer { padding: 0 0 1.5rem; color: #A1A1AA; font-size: 1rem; line-height: 1.7; max-width: 780px; }

/* Testimonials */
.rc-testimonials__grid { display: grid; grid-template-columns: repeat(1, 1fr); gap: 1rem; }
@media (min-width: 700px)  { .rc-testimonials__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .rc-testimonials__grid { grid-template-columns: repeat(3, 1fr); } }
.rc-testimonial { background: var(--rc-surface); border: 1px solid #27272A; padding: 2rem; margin: 0; display: flex; flex-direction: column; gap: 1.5rem; }
.rc-testimonial p { font-family: var(--rc-font-body); font-style: italic; color: #D4D4D8; font-size: 1.05rem; line-height: 1.6; margin: 0; }
.rc-testimonial footer { display: flex; flex-direction: column; gap: .25rem; font-family: 'JetBrains Mono', monospace; }
.rc-testimonial__author { color: var(--rc-text); text-transform: uppercase; font-size: .8rem; letter-spacing: .1em; }
.rc-testimonial__role { color: #71717A; font-size: .75rem; letter-spacing: .06em; }

/* Contact */
.rc-contact__grid { display: grid; grid-template-columns: 1fr; gap: 3rem; }
@media (min-width: 900px) { .rc-contact__grid { grid-template-columns: 1.4fr 1fr; } }
.rc-contact__form { display: flex; flex-direction: column; gap: 1rem; }
.rc-contact__form label { display: grid; gap: .4rem; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; font-size: .75rem; letter-spacing: .14em; color: #A1A1AA; }
.rc-contact__form input, .rc-contact__form textarea { background: var(--rc-surface); border: 1px solid #27272A; color: var(--rc-text); padding: 1rem; font-family: var(--rc-font-body); font-size: 1rem; transition: border-color .2s; }
.rc-contact__form input:focus, .rc-contact__form textarea:focus { outline: none; border-color: var(--rc-primary); }
.rc-contact__form textarea { resize: vertical; }
.rc-contact__form button { align-self: flex-start; }
.rc-contact__aside { display: flex; flex-direction: column; gap: 2rem; padding: 2rem; background: var(--rc-surface); border: 1px solid #27272A; }
.rc-contact__aside a { color: var(--rc-text); }
.rc-contact__aside a:hover { color: var(--rc-primary); }
.rc-contact__socials div { display: flex; gap: 1rem; margin-top: .5rem; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; font-size: .85rem; letter-spacing: .1em; }

/* WhatsApp float */
.rc-whatsapp-float { position: fixed; bottom: 1.5rem; right: 1.5rem; background: var(--rc-primary); color: #000; width: 56px; height: 56px; display: inline-flex; align-items: center; justify-content: center; z-index: 70; transition: transform .2s, background-color .2s; }
.rc-whatsapp-float:hover { background: #fff; transform: translateY(-3px); }

/* Footer */
.rc-footer { background: var(--rc-surface); border-top: 1px solid #27272A; margin-top: 4rem; }
.rc-footer__inner { max-width: 1440px; margin: 0 auto; padding: 4rem 1.5rem 2rem; display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 900px) { .rc-footer__inner { grid-template-columns: 1.2fr 2fr; } }
.rc-footer__brand p { max-width: 280px; }
.rc-footer__cols { display: grid; grid-template-columns: repeat(1, 1fr); gap: 2rem; }
@media (min-width: 700px) { .rc-footer__cols { grid-template-columns: repeat(3, 1fr); } }
.rc-footer h4 { font-family: 'JetBrains Mono', monospace; font-size: .75rem; text-transform: uppercase; letter-spacing: .18em; color: var(--rc-primary); margin-bottom: 1rem; }
.rc-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; font-size: .9rem; }
.rc-footer__bottom { border-top: 1px solid #27272A; padding: 1.25rem 1.5rem; text-align: center; font-family: 'JetBrains Mono', monospace; font-size: .7rem; color: #71717A; letter-spacing: .08em; }

/* Studio / Taller section */
.rc-studio { position: relative; overflow: hidden; margin: 5rem 0; }
.rc-studio__bg { position: absolute; inset: 0; background-size: cover; background-position: center; filter: grayscale(0.2) contrast(1.05); z-index: 0; }
.rc-studio__overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(10,9,6,0.92) 0%, rgba(10,9,6,0.72) 55%, rgba(10,9,6,0.5) 100%); z-index: 1; }
.rc-studio__inner { position: relative; z-index: 2; max-width: 1440px; margin: 0 auto; padding: 6rem 1.5rem; display: grid; gap: 3rem; align-items: center; }
.rc-studio__body { display: flex; flex-direction: column; gap: 1.25rem; max-width: 540px; }
.rc-studio__title { font-size: clamp(2.25rem, 5vw + 1rem, 5rem); line-height: 0.95; margin: 0; }
.rc-studio__desc { color: #D4D4D8; font-size: 1.05rem; line-height: 1.7; margin: 0; max-width: 520px; }
.rc-studio__aside { display: none; }
.rc-studio__card { border: 1px solid var(--rc-border); background: rgba(0,0,0,0.4); backdrop-filter: blur(2px); padding: 1.25rem; max-width: 260px; font-family: 'JetBrains Mono', monospace; }
.rc-studio__card p { margin: .25rem 0 0; color: var(--rc-text); font-size: .9rem; line-height: 1.5; }
.rc-studio__card--primary { border-color: color-mix(in srgb, var(--rc-primary) 40%, transparent); }
.rc-overline--muted { color: var(--rc-muted-2); }

@media (min-width: 900px) {
	.rc-studio__inner { grid-template-columns: 1fr 1fr; padding: 8rem 1.5rem; }
	.rc-studio__aside { display: flex; flex-direction: column; gap: 1rem; justify-self: end; }
}
@media (min-width: 1100px) {
	.rc-studio { margin: 7rem 0; }
}

/* =========================================================
 * Brick wall texture — staggered inline SVG pattern.
 * Apply via class `rc-brick-bg`; intensity via CSS var.
 * ========================================================= */
.rc-brick-bg { position: relative; isolation: isolate; }
.rc-brick-bg::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	opacity: calc(var(--rc-brick-opacity, 0.2) * var(--rc-brick-multiplier, 1));
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='60' viewBox='0 0 120 60'><g fill='rgba(245,241,232,0.04)'><rect x='0' y='0' width='60' height='30'/><rect x='60' y='0' width='60' height='30'/><rect x='30' y='30' width='60' height='30'/></g><g fill='none' stroke='rgba(245,241,232,0.55)' stroke-width='1.2'><path d='M0 0 L120 0 M0 30 L120 30 M0 60 L120 60'/><path d='M60 0 L60 30'/><path d='M0 30 L0 60 M30 30 L30 60 M90 30 L90 60 M120 30 L120 60'/></g></svg>");
	background-size: 240px 120px;
	background-repeat: repeat;
}
.rc-brick-bg > * { position: relative; z-index: 1; }

/* Apply to key surfaces subtly */
.rc-hero         { --rc-brick-opacity: 0.06; }
.rc-services     { --rc-brick-opacity: 0.05; }
.rc-portfolio    { --rc-brick-opacity: 0.05; }
.rc-collab       { --rc-brick-opacity: 0.05; }
.rc-faq          { --rc-brick-opacity: 0.06; }
.rc-marquee      { --rc-brick-opacity: 0.24; }
.rc-testimonials { --rc-brick-opacity: 0.11; }
.rc-footer       { --rc-brick-opacity: 0.13; }

/* Blog */
.rc-blog__grid { display: grid; grid-template-columns: repeat(1, 1fr); gap: 1.5rem; }
@media (min-width: 700px)  { .rc-blog__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .rc-blog__grid { grid-template-columns: repeat(3, 1fr); } }
.rc-blog__card { background: var(--rc-surface); border: 1px solid #27272A; overflow: hidden; display: flex; flex-direction: column; }
.rc-blog__thumb img { aspect-ratio: 16/10; object-fit: cover; width: 100%; }
.rc-blog__body { padding: 1.75rem; display: flex; flex-direction: column; gap: .75rem; flex: 1; }
.rc-blog__body h3 { font-size: 1.25rem; }
.rc-link { color: var(--rc-primary); font-family: 'JetBrains Mono', monospace; text-transform: uppercase; font-size: .8rem; letter-spacing: .1em; margin-top: auto; }

/* Single & page */
.rc-single, .rc-page { max-width: 780px; margin: 0 auto; padding: 6rem 1.5rem; }
.rc-single__header, .rc-page__header { margin-bottom: 2.5rem; display: grid; gap: .75rem; }
.rc-single__thumb img { aspect-ratio: 16/9; object-fit: cover; margin-bottom: 2rem; }
.rc-single__content p, .rc-page__content p { font-size: 1.05rem; line-height: 1.8; color: #D4D4D8; }
.rc-page__hero { max-width: 1440px; margin: 0 auto; padding: 8rem 1.5rem 2rem; display: grid; gap: 1rem; }
