/*
Theme Name: BeHeard Agency
Theme URI: https://beheard.agency
Author: BeHeard Agency
Description: Custom full-service marketing and PR agency theme with EN/SK language switcher.
Version: 1.0
License: Private
Text Domain: beheard
*/

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --ink: #0f0f0f; --paper: #f5f2ec; --accent: #d63a1f;
  --accent2: #1a1a5e; --muted: #6b6b6b;
  --border: rgba(15,15,15,0.12); --white: #ffffff;
}
html { scroll-behavior: smooth; }
body { font-family: 'DM Sans', sans-serif; background: var(--paper); color: var(--ink); overflow-x: hidden; cursor: none; }
.cursor { position: fixed; width: 12px; height: 12px; background: var(--accent); border-radius: 50%; pointer-events: none; z-index: 9999; transform: translate(-50%,-50%); transition: width .2s,height .2s; }
.cursor-ring { position: fixed; width: 36px; height: 36px; border: 1.5px solid var(--accent); border-radius: 50%; pointer-events: none; z-index: 9998; transform: translate(-50%,-50%); transition: width .2s,height .2s,opacity .2s; opacity: .5; }
body:has(a:hover) .cursor, body:has(button:hover) .cursor { width: 6px; height: 6px; }
body:has(a:hover) .cursor-ring, body:has(button:hover) .cursor-ring { width: 52px; height: 52px; opacity: .3; }
nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; display: flex; align-items: center; justify-content: space-between; padding: 1.4rem 3rem; background: transparent; transition: background .4s,border-bottom .4s; }
nav.scrolled { background: var(--paper); border-bottom: 1px solid var(--border); }
.nav-logo { font-family: 'Syne',sans-serif; font-weight: 800; font-size: 1.4rem; letter-spacing: -.03em; color: var(--ink); text-decoration: none; }
.nav-logo span { color: var(--accent); }
.nav-center { display: flex; gap: 2.5rem; list-style: none; }
.nav-center a { font-size: .85rem; font-weight: 400; letter-spacing: .06em; text-transform: uppercase; color: var(--ink); text-decoration: none; opacity: .65; transition: opacity .2s; }
.nav-center a:hover { opacity: 1; }
.nav-right { display: flex; align-items: center; gap: 1.2rem; }
.lang-switcher { display: flex; align-items: center; background: rgba(15,15,15,.07); border-radius: 2px; padding: 3px; gap: 2px; }
.lang-btn { font-family: 'Syne',sans-serif; font-size: .7rem; font-weight: 700; letter-spacing: .1em; padding: .35rem .75rem; border: none; background: transparent; color: var(--ink); opacity: .38; cursor: none; border-radius: 1px; transition: background .22s,opacity .22s,color .22s; }
.lang-btn.active { background: var(--ink); color: var(--paper); opacity: 1; }
.lang-btn:hover:not(.active) { opacity: .7; }
.nav-cta { font-size: .8rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; background: var(--ink); color: var(--paper); border: none; padding: .65rem 1.6rem; cursor: none; text-decoration: none; transition: background .2s; }
.nav-cta:hover { background: var(--accent); }
.hero { min-height: 100vh; display: grid; grid-template-rows: 1fr auto; padding: 0 3rem 3rem; position: relative; overflow: hidden; }
.hero-content { display: flex; flex-direction: column; justify-content: flex-end; padding-bottom: 3rem; padding-top: 9rem; }
.hero-eyebrow { font-size: .75rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: 2rem; display: flex; align-items: center; gap: 1rem; }
.hero-eyebrow::before { content: ''; display: block; width: 2.5rem; height: 1px; background: var(--accent); }
.hero-headline { font-family: 'Syne',sans-serif; font-size: clamp(4.5rem,10vw,10rem); font-weight: 800; line-height: .92; letter-spacing: -.04em; color: var(--ink); margin-bottom: 3rem; }
.hero-headline .line-accent { color: var(--accent); display: block; }
.hero-headline .line-outline { -webkit-text-stroke: 2px var(--ink); color: transparent; display: block; }
.hero-bottom { display: flex; align-items: flex-end; justify-content: space-between; border-top: 1px solid var(--border); padding-top: 2rem; gap: 2rem; }
.hero-desc { max-width: 340px; font-size: 1rem; line-height: 1.7; color: var(--muted); font-weight: 300; }
.hero-scroll { display: flex; align-items: center; gap: .8rem; font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.scroll-line { width: 3rem; height: 1px; background: var(--muted); position: relative; overflow: hidden; }
.scroll-line::after { content: ''; position: absolute; left: -100%; top: 0; bottom: 0; width: 100%; background: var(--accent); animation: scrollAnim 1.8s ease-in-out infinite; }
@keyframes scrollAnim { 0%{left:-100%} 100%{left:100%} }
.marquee-wrap { background: var(--ink); color: var(--paper); padding: 1.2rem 0; overflow: hidden; }
.marquee-track { display: flex; white-space: nowrap; animation: marquee 22s linear infinite; }
.marquee-item { font-family: 'Syne',sans-serif; font-size: .75rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; padding: 0 2.5rem; display: flex; align-items: center; gap: 2.5rem; }
.marquee-item::after { content: ''; width: 5px; height: 5px; background: var(--accent); border-radius: 50%; display: inline-block; }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
section { padding: 6rem 3rem; }
.section-label { font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin-bottom: 1rem; display: flex; align-items: center; gap: .8rem; }
.section-label::before { content: ''; width: 1.5rem; height: 1px; background: var(--accent); display: block; }
.section-title { font-family: 'Syne',sans-serif; font-size: clamp(2.4rem,5vw,4.5rem); font-weight: 800; letter-spacing: -.03em; line-height: 1.05; color: var(--ink); margin-bottom: .5rem; }
.services { background: var(--white); }
.services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; margin-top: 4rem; border: 1px solid var(--border); }
.service-card { padding: 2.5rem; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); position: relative; overflow: hidden; transition: background .3s; }
.service-card:nth-child(3n) { border-right: none; }
.service-card:hover { background: var(--ink); }
.service-card:hover .service-num,.service-card:hover .service-name,.service-card:hover .service-desc { color: var(--paper); }
.service-card:hover .service-arrow { color: var(--accent); }
.service-num { font-family: 'Syne',sans-serif; font-size: .7rem; letter-spacing: .15em; color: var(--muted); margin-bottom: 3rem; display: block; transition: color .3s; }
.service-name { font-family: 'Syne',sans-serif; font-size: 1.4rem; font-weight: 700; color: var(--ink); line-height: 1.2; margin-bottom: 1rem; transition: color .3s; }
.service-desc { font-size: .9rem; line-height: 1.65; color: var(--muted); font-weight: 300; transition: color .3s; }
.service-arrow { position: absolute; bottom: 2.5rem; right: 2.5rem; font-size: 1.4rem; color: var(--border); transition: color .3s,transform .3s; }
.service-card:hover .service-arrow { transform: translate(4px,-4px); }
.numbers { background: var(--accent); color: var(--white); padding: 5rem 3rem; }
.numbers-inner { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; border-top: 1px solid rgba(255,255,255,.25); border-left: 1px solid rgba(255,255,255,.25); }
.stat { padding: 3rem 2.5rem; border-right: 1px solid rgba(255,255,255,.25); border-bottom: 1px solid rgba(255,255,255,.25); }
.stat-value { font-family: 'Syne',sans-serif; font-size: 4rem; font-weight: 800; line-height: 1; letter-spacing: -.04em; margin-bottom: .5rem; }
.stat-label { font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; opacity: .7; font-weight: 300; }
.process { background: var(--paper); }
.process-steps { margin-top: 4rem; display: flex; flex-direction: column; }
.process-step { display: grid; grid-template-columns: 5rem 1fr 1fr; align-items: start; gap: 2rem; padding: 2.5rem 0; border-top: 1px solid var(--border); }
.step-num { font-family: 'Syne',sans-serif; font-size: .75rem; font-weight: 700; letter-spacing: .12em; color: var(--accent); padding-top: .3rem; }
.step-title { font-family: 'Syne',sans-serif; font-size: 1.5rem; font-weight: 700; color: var(--ink); line-height: 1.2; }
.step-desc { font-size: .95rem; line-height: 1.7; color: var(--muted); font-weight: 300; }
.work { background: var(--white); }
.work-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5px; margin-top: 4rem; background: var(--border); }
.work-card { background: var(--paper); padding: 3rem; aspect-ratio: 4/3; display: flex; flex-direction: column; justify-content: space-between; position: relative; overflow: hidden; cursor: none; }
.work-card.featured { grid-column: span 2; aspect-ratio: 16/7; }
.work-card-bg { position: absolute; inset: 0; opacity: 0; transition: opacity .5s; }
.work-card:nth-child(1) .work-card-bg { background: var(--accent2); }
.work-card:nth-child(2) .work-card-bg { background: #1e4030; }
.work-card:nth-child(3) .work-card-bg { background: #4a1b0c; }
.work-card:hover .work-card-bg { opacity: 1; }
.work-card:hover .work-client,.work-card:hover .work-title,.work-card:hover .work-tags span { color: var(--paper); }
.work-card:hover .work-tags span { border-color: rgba(255,255,255,.25); }
.work-card:hover .work-cta { background: var(--accent); color: var(--white); }
.work-card-top,.work-card-bottom { position: relative; z-index: 1; }
.work-client { font-size: .72rem; letter-spacing: .15em; text-transform: uppercase; color: var(--muted); margin-bottom: .6rem; transition: color .3s; }
.work-title { font-family: 'Syne',sans-serif; font-size: 1.8rem; font-weight: 700; line-height: 1.15; color: var(--ink); transition: color .3s; }
.work-card.featured .work-title { font-size: 2.6rem; }
.work-tags { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.work-tags span { font-size: .7rem; letter-spacing: .08em; text-transform: uppercase; border: 1px solid var(--border); padding: .3rem .7rem; color: var(--muted); transition: color .3s,border-color .3s; }
.work-cta { display: inline-flex; align-items: center; gap: .5rem; font-size: .8rem; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; padding: .6rem 1.2rem; border: 1px solid var(--border); color: var(--ink); background: transparent; cursor: none; transition: background .3s,color .3s; text-decoration: none; }
.testimonials { background: var(--ink); color: var(--paper); }
.testimonials .section-label { color: rgba(245,242,236,.4); }
.testimonials .section-label::before { background: var(--accent); }
.testimonials .section-title { color: var(--paper); }
.testi-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 4rem; }
.testi-card { border: 1px solid rgba(245,242,236,.1); padding: 2.5rem; }
.testi-quote { font-size: .9rem; line-height: 1.75; color: rgba(245,242,236,.7); font-weight: 300; font-style: italic; margin-bottom: 2rem; }
.testi-quote::before { content: '\201C'; font-family: 'Syne',sans-serif; font-size: 4rem; line-height: 1; color: var(--accent); display: block; margin-bottom: .5rem; }
.testi-author { display: flex; align-items: center; gap: 1rem; }
.testi-avatar { width: 40px; height: 40px; background: var(--accent); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'Syne',sans-serif; font-size: .8rem; font-weight: 700; color: var(--white); flex-shrink: 0; }
.testi-name { font-family: 'Syne',sans-serif; font-weight: 700; font-size: .95rem; color: var(--paper); }
.testi-role { font-size: .8rem; color: rgba(245,242,236,.4); }
.logos { background: var(--paper); padding: 4rem 3rem; }
.logos-label { font-size: .7rem; letter-spacing: .15em; text-transform: uppercase; color: var(--muted); text-align: center; margin-bottom: 3rem; }
.logos-row { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 3rem 4rem; }
.logo-item { font-family: 'Syne',sans-serif; font-weight: 800; font-size: 1.1rem; letter-spacing: -.02em; color: rgba(15,15,15,.2); text-transform: uppercase; }
.cta-section { background: var(--accent2); color: var(--paper); padding: 8rem 3rem; text-align: center; position: relative; overflow: hidden; }
.cta-section::before { content: 'BEHEARD'; position: absolute; font-family: 'Syne',sans-serif; font-weight: 800; font-size: 22vw; letter-spacing: -.06em; color: rgba(255,255,255,.03); top: 50%; left: 50%; transform: translate(-50%,-50%); white-space: nowrap; pointer-events: none; }
.cta-title { font-family: 'Syne',sans-serif; font-size: clamp(3rem,7vw,7rem); font-weight: 800; letter-spacing: -.04em; line-height: 1; margin-bottom: 2rem; position: relative; }
.cta-sub { font-size: 1rem; font-weight: 300; opacity: .6; margin-bottom: 3rem; position: relative; }
.cta-btn { display: inline-block; background: var(--accent); color: var(--white); font-size: .85rem; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; padding: 1.1rem 3rem; text-decoration: none; cursor: none; position: relative; transition: background .2s,transform .2s; }
.cta-btn:hover { background: #bf3118; transform: translateY(-2px); }
footer { background: var(--ink); color: var(--paper); padding: 4rem 3rem 2rem; }
.footer-top { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 3rem; margin-bottom: 4rem; padding-bottom: 3rem; border-bottom: 1px solid rgba(245,242,236,.08); }
.footer-brand { font-family: 'Syne',sans-serif; font-weight: 800; font-size: 2rem; letter-spacing: -.04em; color: var(--paper); margin-bottom: 1rem; }
.footer-brand span { color: var(--accent); }
.footer-tagline { font-size: .85rem; line-height: 1.65; color: rgba(245,242,236,.4); font-weight: 300; }
.footer-col-title { font-size: .7rem; letter-spacing: .15em; text-transform: uppercase; color: rgba(245,242,236,.3); margin-bottom: 1.4rem; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: .8rem; }
.footer-links a { font-size: .9rem; color: rgba(245,242,236,.6); text-decoration: none; transition: color .2s; }
.footer-links a:hover { color: var(--paper); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; font-size: .75rem; color: rgba(245,242,236,.25); }
.reveal { opacity: 0; transform: translateY(30px); transition: opacity .7s,transform .7s; }
.reveal.visible { opacity: 1; transform: translateY(0); }
@media (max-width: 900px) {
  nav { padding: 1.2rem 1.5rem; }
  .nav-center,.nav-cta { display: none; }
  section { padding: 4rem 1.5rem; }
  .hero { padding: 0 1.5rem 2rem; }
  .hero-headline { font-size: clamp(3.5rem,14vw,6rem); }
  .services-grid,.work-grid { grid-template-columns: 1fr; }
  .service-card { border-right: none; }
  .numbers-inner { grid-template-columns: 1fr 1fr; }
  .work-card.featured { grid-column: span 1; aspect-ratio: 4/3; }
  .testi-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .process-step { grid-template-columns: 3rem 1fr; }
  .step-desc { grid-column: 2; }
  body { cursor: auto; }
  .cursor,.cursor-ring { display: none; }
}
