@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Oswald:wght@200;300;400;500;600&family=Raleway:wght@200;300;400;500;600&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --ink:        #07070A;
  --charcoal:   #111111;
  --mid:        #282828;
  --grey:       #4A4A4A;
  --silver:     #8A9299;
  --mist:       #CACDD2;
  --off-white:  #F2F1EF;
  --white:      #FFFFFF;
  --text-body:  #2A2A2A;
  --text-muted: #555555;
  --gold:       #C9A84C;
  --gold-light: #E8D08A;
  --gold-dim:   #8A6D28;
}

html { scroll-behavior: smooth; }

body {
  background: var(--white);
  color: var(--text-body);
  font-family: 'Raleway', sans-serif;
  font-weight: 400;
  line-height: 1.7;
  overflow-x: hidden;
}

::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--off-white); }
::-webkit-scrollbar-thumb { background: var(--charcoal); }

/* ─── NAV ─── */
#site-navigation {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 64px;
  height: 76px;
  background: rgba(255,255,255,0.96);
  border-bottom: 1px solid rgba(26,26,26,0.08);
  backdrop-filter: blur(12px);
  transition: box-shadow 0.3s;
}

#site-navigation.scrolled { box-shadow: 0 2px 24px rgba(0,0,0,0.07); }

.nav-logo {
  display: flex;
  align-items: center;
  gap: 18px;
  text-decoration: none;
}

.logo-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 42px;
  letter-spacing: 3px;
  color: var(--charcoal);
  line-height: 1;
}

.logo-divider { display: flex; flex-direction: column; align-items: center; }
.logo-line { width: 22px; height: 1.5px; background: var(--grey); opacity: 0.4; }
.logo-dot  { width: 4px; height: 4px; background: var(--grey); border-radius: 50%; margin: 4px 0; opacity: 0.6; }
.logo-text { display: flex; flex-direction: column; gap: 1px; }
.logo-repair    { font-family:'Oswald',sans-serif; font-weight:600; font-size:13px; letter-spacing:4px; text-transform:uppercase; color:var(--charcoal); line-height:1; }
.logo-solutions { font-family:'Oswald',sans-serif; font-weight:200; font-size:13px; letter-spacing:4px; text-transform:uppercase; color:var(--grey); line-height:1; }

.main-navigation ul { display:flex; align-items:center; gap:40px; list-style:none; }
.main-navigation a {
  font-family:'Raleway',sans-serif; font-weight:500; font-size:11px;
  letter-spacing:3px; text-transform:uppercase; color:var(--charcoal);
  text-decoration:none; opacity:0.7; transition:opacity 0.2s; position:relative;
}
.main-navigation a::after {
  content:''; position:absolute; bottom:-3px; left:0; width:0; height:1px;
  background:var(--charcoal); transition:width 0.3s;
}
.main-navigation a:hover { opacity:1; }
.main-navigation a:hover::after { width:100%; }

.nav-cta {
  background:var(--charcoal) !important; color:var(--white) !important;
  opacity:1 !important; padding:10px 24px !important;
  letter-spacing:3px !important; font-size:10px !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { background:var(--mid) !important; }

.menu-toggle {
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  padding:4px; background:none; border:none;
}
.menu-toggle span { display:block; width:24px; height:1.5px; background:var(--charcoal); }

/* ─── HERO ─── */
.hero {
  min-height:100vh; display:flex; align-items:center;
  position:relative; overflow:hidden; background:var(--ink); padding:0 64px;
}

.hero-bg { position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(26,26,26,0.0) 0%, rgba(90,90,90,0.06) 100%);
}
.hero-bg::before {
  content:''; position:absolute; inset:0;
  background-image: linear-gradient(rgba(255,255,255,0.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.02) 1px,transparent 1px);
  background-size:60px 60px;
}
.hero-bg::after {
  content:''; position:absolute; top:0; bottom:0; left:56px;
  width:1px; background:linear-gradient(180deg,transparent,rgba(255,255,255,0.08),transparent);
}

.hero-content { position:relative; z-index:2; max-width:700px; animation:heroIn 1s ease both; }

@keyframes heroIn { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }

.hero-eyebrow { display:flex; align-items:center; gap:16px; margin-bottom:32px; }
.eyebrow-line { width:40px; height:1px; background:var(--grey); }
.eyebrow-text { font-size:10px; letter-spacing:5px; text-transform:uppercase; color:var(--silver); font-family:'Raleway',sans-serif; font-weight:300; }

.hero-num {
  font-family:'Bebas Neue',sans-serif; font-size:clamp(100px,18vw,200px);
  line-height:0.85; letter-spacing:8px; color:transparent;
  -webkit-text-stroke:1.5px rgba(255,255,255,0.1);
  position:absolute; right:64px; top:50%; transform:translateY(-50%);
  pointer-events:none; animation:heroIn 1.2s 0.2s ease both; user-select:none;
}

.hero-title {
  font-family:'Oswald',sans-serif; font-weight:600;
  font-size:clamp(42px,5vw,68px); line-height:1.05;
  letter-spacing:2px; color:var(--white); text-transform:uppercase; margin-bottom:24px;
}
.hero-title span { color:transparent; -webkit-text-stroke:1px rgba(255,255,255,0.4); }

.hero-sub {
  font-size:16px; line-height:1.8; color:var(--silver);
  max-width:480px; margin-bottom:48px;
  font-family:'Raleway',sans-serif; font-weight:300;
}

.hero-actions { display:flex; align-items:center; gap:28px; }

.btn-primary {
  font-family:'Oswald',sans-serif; font-weight:500; font-size:12px;
  letter-spacing:4px; text-transform:uppercase; color:var(--ink);
  background:var(--white); padding:16px 36px; text-decoration:none;
  transition:all 0.25s; display:inline-block;
}
.btn-primary:hover { background:var(--mist); }

.btn-ghost {
  font-family:'Raleway',sans-serif; font-weight:400; font-size:11px;
  letter-spacing:3px; text-transform:uppercase; color:var(--silver);
  text-decoration:none; display:flex; align-items:center; gap:10px; transition:color 0.25s;
}
.btn-ghost::after { content:'→'; transition:transform 0.25s; }
.btn-ghost:hover { color:var(--white); }
.btn-ghost:hover::after { transform:translateX(5px); }

.hero-stats {
  position:absolute; bottom:52px; left:64px; right:64px;
  display:flex; gap:48px; border-top:1px solid rgba(255,255,255,0.06);
  padding-top:32px; animation:heroIn 1s 0.4s ease both;
}
.stat-num { font-family:'Bebas Neue',sans-serif; font-size:36px; letter-spacing:2px; color:var(--white); line-height:1; margin-bottom:4px; }
.stat-label { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--grey); }

/* ─── SHARED SECTION STYLES ─── */
section { padding:120px 64px; }

.section-label { display:flex; align-items:center; gap:16px; margin-bottom:20px; }
.section-label-line { width:32px; height:1px; background:var(--grey); opacity:0.4; }
.section-label-text { font-size:9px; letter-spacing:5px; text-transform:uppercase; color:#777; }

.section-title {
  font-family:'Oswald',sans-serif; font-weight:600;
  font-size:clamp(32px,4vw,50px); letter-spacing:2px;
  text-transform:uppercase; color:var(--charcoal); line-height:1.1; margin-bottom:20px;
}
.section-title-light { color:var(--white); }

.section-sub { font-size:15px; line-height:1.9; color:var(--text-muted); max-width:520px; }

/* ─── INTRO STRIP ─── */
.intro-strip {
  background:var(--off-white); padding:64px;
  display:flex; align-items:center; justify-content:space-between;
  gap:48px; border-top:2px solid var(--charcoal);
}
.intro-strip-text {
  font-family:'Oswald',sans-serif; font-weight:300;
  font-size:clamp(18px,2.5vw,26px); letter-spacing:1px;
  color:#111; max-width:640px; line-height:1.5;
}
.intro-strip-text strong { font-weight:600; color:#000; }
.intro-strip-cta {
  font-size:10px; letter-spacing:4px; text-transform:uppercase;
  color:var(--charcoal); text-decoration:none; white-space:nowrap;
  display:flex; align-items:center; gap:12px;
  border-bottom:1px solid var(--charcoal); padding-bottom:2px; transition:opacity 0.2s;
  font-family:'Raleway',sans-serif; font-weight:500;
}
.intro-strip-cta:hover { opacity:0.6; }

/* ─── SERVICES ─── */
.services-section { background:var(--white); }
.services-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:2px; margin-top:72px; }

.service-card {
  background:var(--off-white); padding:52px 48px;
  position:relative; overflow:hidden; transition:background 0.3s; cursor:default;
}
.service-card::before {
  content:''; position:absolute; top:0; left:0;
  width:3px; height:0; background:var(--charcoal); transition:height 0.4s ease;
}
.service-card:hover { background:#EEECEA; }
.service-card:hover::before { height:100%; }

.service-num {
  font-family:'Bebas Neue',sans-serif; font-size:72px; letter-spacing:2px;
  color:transparent; -webkit-text-stroke:1px rgba(26,26,26,0.12);
  line-height:1; margin-bottom:24px; transition:-webkit-text-stroke 0.3s;
}
.service-card:hover .service-num { -webkit-text-stroke:1px rgba(26,26,26,0.25); }

.service-title {
  font-family:'Oswald',sans-serif; font-weight:600; font-size:22px;
  letter-spacing:2px; text-transform:uppercase; color:var(--charcoal);
  margin-bottom:16px; line-height:1.2;
}
.service-desc { font-size:14px; line-height:1.9; color:var(--text-muted); margin-bottom:28px; }

.service-tags { display:flex; flex-wrap:wrap; gap:8px; }
.tag {
  font-size:9px; letter-spacing:2px; text-transform:uppercase;
  color:var(--charcoal); border:1px solid rgba(26,26,26,0.2); padding:5px 12px;
}

/* ─── WHY US ─── */
.feature-section { background:var(--ink); position:relative; overflow:hidden; }
.feature-section::before {
  content:''; position:absolute; inset:0;
  background-image: linear-gradient(rgba(255,255,255,0.015) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.015) 1px,transparent 1px);
  background-size:80px 80px;
}
.feature-inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }

.feature-big-num {
  font-family:'Bebas Neue',sans-serif; font-size:160px; letter-spacing:6px;
  color:transparent; -webkit-text-stroke:1px rgba(255,255,255,0.07);
  line-height:0.85; margin-bottom:40px; user-select:none;
}

.feature-item { padding:32px 0; border-bottom:1px solid rgba(255,255,255,0.06); }
.feature-item:first-child { border-top:1px solid rgba(255,255,255,0.06); }
.feature-item-num { font-family:'Bebas Neue',sans-serif; font-size:13px; letter-spacing:3px; color:var(--grey); margin-bottom:10px; }
.feature-item-title { font-family:'Oswald',sans-serif; font-weight:500; font-size:18px; letter-spacing:2px; text-transform:uppercase; color:var(--white); margin-bottom:10px; }
.feature-item-desc { font-size:13px; line-height:1.8; color:var(--grey); }

/* ─── WHO WE SERVE ─── */
.audience-section { background:var(--off-white); }
.audience-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:72px; }

.audience-card {
  background:var(--white); padding:44px 36px; border:1px solid var(--mist);
  position:relative; transition:border-color 0.3s, transform 0.3s, box-shadow 0.3s;
}
.audience-card:hover { border-color:var(--charcoal); transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,0.08); }

.audience-icon-wrap { width:52px; height:52px; margin-bottom:24px; }
.audience-icon-wrap svg { width:100%; height:100%; }

.audience-title { font-family:'Oswald',sans-serif; font-weight:600; font-size:16px; letter-spacing:3px; text-transform:uppercase; color:var(--charcoal); margin-bottom:14px; }
.audience-desc { font-size:14px; line-height:1.9; color:#444; }

/* ─── PROCESS ─── */
.process-section { background:var(--white); }
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; margin-top:72px; }

.process-step { padding:44px 32px; background:var(--off-white); position:relative; }
.process-step::after {
  content:'→'; position:absolute; right:-14px; top:50%; transform:translateY(-50%);
  font-size:18px; color:var(--mist); z-index:1;
}
.process-step:last-child::after { display:none; }

.step-num { font-family:'Bebas Neue',sans-serif; font-size:52px; letter-spacing:2px; color:transparent; -webkit-text-stroke:1px rgba(26,26,26,0.15); line-height:1; margin-bottom:16px; }
.step-title { font-family:'Oswald',sans-serif; font-weight:500; font-size:15px; letter-spacing:2px; text-transform:uppercase; color:var(--charcoal); margin-bottom:12px; }
.step-desc { font-size:13px; line-height:1.8; color:var(--text-muted); }

/* ─── COVERAGE ─── */
.coverage-section { background:var(--ink); padding:80px 64px; position:relative; overflow:hidden; }
.coverage-section::before {
  content:''; position:absolute; inset:0;
  background-image: linear-gradient(rgba(255,255,255,0.015) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.015) 1px,transparent 1px);
  background-size:80px 80px; pointer-events:none;
}
.coverage-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.coverage-card {
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06);
  padding:36px 32px; transition:background 0.3s;
}
.coverage-card:hover { background:rgba(255,255,255,0.08); }
.coverage-card-num { font-family:'Bebas Neue',sans-serif; font-size:48px; letter-spacing:2px; color:transparent; -webkit-text-stroke:1px rgba(255,255,255,0.1); line-height:1; margin-bottom:16px; }
.coverage-card-city { font-family:'Oswald',sans-serif; font-weight:600; font-size:20px; letter-spacing:3px; text-transform:uppercase; color:var(--white); margin-bottom:10px; }
.coverage-card-desc { font-size:13px; color:var(--grey); line-height:1.8; }
.coverage-notice {
  margin-top:48px; padding:28px 36px; background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08); display:flex; align-items:center; gap:24px;
}
.coverage-notice svg { flex-shrink:0; }
.coverage-notice p { font-size:14px; color:var(--silver); line-height:1.8; }
.coverage-notice strong { color:var(--white); }

/* ─── CONTACT ─── */
.contact-section { background:var(--off-white); }
.contact-inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.contact-form { display:flex; flex-direction:column; gap:20px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-label { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--grey); }
.form-input, .form-select, .form-textarea {
  background:var(--white); border:1px solid var(--mist); padding:14px 16px;
  font-family:'Raleway',sans-serif; font-size:14px; color:var(--charcoal);
  outline:none; transition:border-color 0.2s; width:100%; appearance:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--charcoal); }
.form-textarea { resize:vertical; min-height:120px; line-height:1.6; }
.btn-submit {
  font-family:'Oswald',sans-serif; font-weight:500; font-size:12px;
  letter-spacing:5px; text-transform:uppercase; color:var(--white);
  background:var(--charcoal); border:none; padding:18px 36px;
  cursor:pointer; transition:background 0.2s; align-self:flex-start;
}
.btn-submit:hover { background:var(--mid); }

.contact-info-title { font-family:'Oswald',sans-serif; font-weight:600; font-size:28px; letter-spacing:2px; text-transform:uppercase; color:var(--charcoal); margin-bottom:24px; }
.contact-info-desc { font-size:14px; line-height:1.9; color:var(--text-muted); margin-bottom:44px; }
.contact-details { display:flex; flex-direction:column; gap:24px; }
.contact-detail-item { display:flex; gap:20px; align-items:flex-start; }
.contact-detail-icon { font-size:16px; margin-top:2px; flex-shrink:0; }
.contact-detail-label { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--grey); margin-bottom:4px; }
.contact-detail-value { font-size:14px; color:var(--charcoal); font-weight:500; }

/* ─── FOOTER ─── */
.site-footer { background:var(--ink); padding:80px 64px 40px; }

.footer-top {
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:60px;
  padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,0.06);
}
.footer-logo-num { font-family:'Bebas Neue',sans-serif; font-size:52px; letter-spacing:4px; color:var(--white); line-height:1; margin-bottom:6px; }
.footer-logo-sub { font-family:'Oswald',sans-serif; font-weight:200; font-size:12px; letter-spacing:5px; text-transform:uppercase; color:var(--grey); margin-bottom:24px; }
.footer-tagline { font-size:13px; line-height:1.8; color:var(--grey); max-width:260px; }
.footer-col-title { font-family:'Oswald',sans-serif; font-weight:500; font-size:11px; letter-spacing:4px; text-transform:uppercase; color:var(--white); margin-bottom:20px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-links a { font-size:13px; color:var(--grey); text-decoration:none; transition:color 0.2s; }
.footer-links a:hover { color:var(--white); }

.footer-bottom { display:flex; align-items:center; justify-content:space-between; padding-top:32px; }
.footer-copy { font-size:11px; color:var(--grey); letter-spacing:1px; }
.footer-legal { display:flex; gap:28px; }
.footer-legal a { font-size:11px; color:var(--grey); text-decoration:none; letter-spacing:1px; transition:color 0.2s; }
.footer-legal a:hover { color:var(--white); }

.footer-gdpr {
  border-top:1px solid rgba(255,255,255,0.06); margin-top:28px; padding-top:24px;
}
.footer-gdpr-box {
  display:flex; align-items:flex-start; gap:16px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.07);
  padding:20px 24px; margin-bottom:24px;
}
.footer-gdpr-box p { font-size:11px; color:rgba(255,255,255,0.38); line-height:1.9; }
.footer-gdpr-box strong { color:rgba(255,255,255,0.55); letter-spacing:1px; }
.footer-gdpr-box a { color:rgba(255,255,255,0.5); text-decoration:underline; }
.footer-bottom-tag { text-align:center; }
.footer-bottom-tag span { font-family:'Oswald',sans-serif; font-weight:300; font-size:11px; letter-spacing:5px; text-transform:uppercase; color:rgba(255,255,255,0.18); }

/* ─── REVEAL ANIMATIONS ─── */
.reveal { opacity:1; transform:translateY(0); transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal.hidden { opacity:0; transform:translateY(24px); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ─── WORDPRESS DEFAULTS ─── */
.wp-block-image img { max-width:100%; height:auto; }
.aligncenter { text-align:center; }
img { max-width:100%; height:auto; }
a { color:inherit; }
p { margin-bottom:1em; }
p:last-child { margin-bottom:0; }

/* ─── RESPONSIVE ─── */
@media (max-width:900px) {
  #site-navigation { padding:0 24px; }
  .main-navigation ul { display:none; }
  .main-navigation.toggled ul { display:flex; flex-direction:column; position:absolute; top:76px; left:0; right:0; background:#fff; padding:24px; border-bottom:1px solid #eee; gap:20px; }
  .menu-toggle { display:flex; }
  section { padding:80px 24px; }
  .coverage-section { padding:80px 24px; }
  .hero { padding:0 24px; }
  .hero-num { display:none; }
  .services-grid { grid-template-columns:1fr; }
  .feature-inner { grid-template-columns:1fr; }
  .audience-grid { grid-template-columns:1fr; }
  .process-steps { grid-template-columns:1fr 1fr; }
  .process-step::after { display:none; }
  .contact-inner { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .footer-bottom { flex-direction:column; gap:16px; }
  .intro-strip { flex-direction:column; padding:48px 24px; }
  .hero-stats { display:none; }
  .form-row { grid-template-columns:1fr; }
  .coverage-grid { grid-template-columns:1fr 1fr; }
}

@media (max-width:600px) {
  .audience-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; }
  .coverage-grid { grid-template-columns:1fr; }
}
