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

/* CUSTOM REC CURSOR */
@keyframes rec-pulse {
  0%   { width:10px; height:10px; box-shadow: 0 0 0 0 rgba(230,50,50,0.85), 0 0 6px 1px rgba(230,50,50,0.5); }
  35%  { width:14px; height:14px; box-shadow: 0 0 0 4px rgba(230,50,50,0.3),  0 0 8px 2px rgba(230,50,50,0.4); }
  70%  { width:10px; height:10px; box-shadow: 0 0 0 12px rgba(230,50,50,0),   0 0 10px 2px rgba(230,50,50,0.1); }
  100% { width:10px; height:10px; box-shadow: 0 0 0 0 rgba(230,50,50,0),      0 0 6px 1px rgba(230,50,50,0.5); }
}
.cursor {
  display:none; position:fixed; top:0; left:0;
  width:10px; height:10px;
  background:#e63232; border-radius:50%;
  pointer-events:none; z-index:9999;
  animation:rec-pulse 1.4s ease-in-out infinite;
  transition:width .22s cubic-bezier(.34,1.56,.64,1),height .22s cubic-bezier(.34,1.56,.64,1),background .2s,box-shadow .22s;
  will-change:transform;
}
@media (hover:hover) and (pointer:fine) {
  body,a,button{cursor:none;}
  .cursor{display:block;}
}
.cursor.hover {
  width:28px; height:28px;
  background:transparent;
  box-shadow:0 0 0 2px #e63232,0 0 12px rgba(230,50,50,0.35);
  animation:none;
}
@media (hover:none),(pointer:coarse) {
  body,a,button{cursor:auto;}
  .cursor{display:none;}
}
:root {
  --bg: #050505; --fg: #f5f5f0; --accent: #d8ff00;
  --muted: #5a5a56; --muted2: #8a8a86; --line: rgba(255,255,255,0.1);
  --glass: rgba(255,255,255,0.04);
  --display: 'Space Grotesk', sans-serif;
  --body: 'Inter Tight', sans-serif;
}

html { scroll-behavior: smooth; }

body {
  color: var(--fg);
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  background:
    linear-gradient(to bottom,
      rgba(5,5,5,0.55) 0%,
      rgba(5,5,5,0.65) 40%,
      rgba(5,5,5,0.80) 100%),
    url('/assets/seo-bg.jpg') center 30% / cover fixed;
  min-height: 100vh;
}

body::after {
  content: '';
  position: fixed;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(20,180,200,0.04) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}

.sh, .hero, .pillars, .price-strip,
.portfolio-section, .reviews-section, .section-reviews-wrap,
.faq-section, .cta-block, .site-footer {
  position: relative;
  z-index: 1;
}

/* HEADER */
.sh {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 40px;
  background:
    linear-gradient(135deg,
      rgba(255,255,255,0.08) 0%,
      rgba(255,255,255,0.03) 30%,
      rgba(255,255,255,0.00) 50%,
      rgba(255,255,255,0.03) 100%),
    rgba(10,14,20,0.72);
  backdrop-filter: blur(24px) saturate(1.4);
  -webkit-backdrop-filter: blur(24px) saturate(1.4);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 4px 24px rgba(0,0,0,0.35);
}
.sh-logo {
  font-family: var(--display); font-size: 12px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg);
  text-decoration: none; display: flex; align-items: center; gap: 8px;
}
.sh-dot {
  width: 6px; height: 6px; background: #e63232; border-radius: 50%;
  animation: blink 2s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.3} }
.sh-links { display: flex; align-items: center; gap: 24px; }
.sh-links a {
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--muted2); text-decoration: none; transition: color 0.2s;
}
.sh-links a:hover, .sh-links a.active { color: var(--fg); }

/* LANG SWITCHER */
.lang-switcher {
  display: flex; align-items: center; gap: 2px;
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 999px; padding: 3px;
}
.lang-btn {
  font-size: 11px; letter-spacing: 0.08em; font-weight: 600;
  padding: 3px 10px; border-radius: 999px; cursor: pointer;
  transition: all 0.2s; color: var(--muted2); user-select: none;
  line-height: 1.4;
}
.lang-btn.active { color: #000; background: var(--accent); }
.lang-btn:hover:not(.active) { color: var(--fg); }

/* HERO */
.hero { padding: 130px 40px 64px; max-width: 1100px; margin: 0 auto; }
.hero-tag {
  font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 14px; display: flex; align-items: center; gap: 10px;
}
.hero-tag::before { content: ''; width: 20px; height: 1px; background: var(--accent); }
.hero h1 {
  font-family: var(--display); font-size: clamp(32px,5vw,64px); font-weight: 700;
  line-height: 1.06; letter-spacing: -0.03em; margin-bottom: 18px;
}
.hero h1 em { font-style: normal; color: var(--accent); }
.hero-sub {
  color: var(--muted2); font-size: clamp(14px,1.3vw,17px); max-width: 560px;
  margin-bottom: 32px; line-height: 1.65;
}

/* Hero about card */
.hero-about {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 32px; padding: 18px 22px;
  border-radius: 20px; max-width: 480px;
  background:
    linear-gradient(135deg,
      rgba(255,255,255,0.14) 0%,
      rgba(255,255,255,0.05) 30%,
      rgba(255,255,255,0.00) 50%,
      rgba(255,255,255,0.04) 100%),
    rgba(15,20,28,0.18);
  backdrop-filter: blur(20px) saturate(1.5);
  -webkit-backdrop-filter: blur(20px) saturate(1.5);
  border: 1px solid rgba(255,255,255,0.16);
  box-shadow: 0 0 60px rgba(216,255,0,0.03), 0 15px 40px rgba(0,0,0,0.4),
    inset 0 1px 0 rgba(255,255,255,0.28);
}
.hero-about-avatar {
  width: 42px; height: 42px; border-radius: 50%;
  background: rgba(216,255,0,0.12); border: 1px solid rgba(216,255,0,0.25);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.hero-about-text { font-size: 13px; color: var(--muted2); line-height: 1.5; }
.hero-about-text strong { display: block; color: var(--fg); font-weight: 600; margin-bottom: 2px; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }

/* BUTTONS */
.btn-accent {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--accent); color: #000; font-family: var(--body);
  font-size: 14px; font-weight: 700; letter-spacing: 0.04em;
  padding: 14px 28px; border-radius: 40px; text-decoration: none;
  transition: opacity 0.2s, transform 0.15s; white-space: nowrap;
}
.btn-accent:hover { opacity: 0.88; transform: translateY(-1px); }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,0.06); color: var(--fg); font-size: 13px;
  font-weight: 500; padding: 14px 24px; border-radius: 40px;
  border: 1px solid rgba(255,255,255,0.14); text-decoration: none;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  transition: border-color 0.2s, transform 0.15s; white-space: nowrap;
}
.btn-ghost:hover { border-color: rgba(255,255,255,0.3); transform: translateY(-1px); }

/* PILLARS */
.pillars {
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  display: grid; grid-template-columns: repeat(3,1fr);
  background:
    linear-gradient(135deg,
      rgba(255,255,255,0.08) 0%,
      rgba(255,255,255,0.02) 30%,
      rgba(255,255,255,0.00) 50%,
      rgba(255,255,255,0.03) 100%),
    rgba(10,14,20,0.55);
  backdrop-filter: blur(20px) saturate(1.3);
  -webkit-backdrop-filter: blur(20px) saturate(1.3);
}
.pillar {
  padding: 28px 40px; display: flex; align-items: flex-start; gap: 12px;
  border-right: 1px solid rgba(255,255,255,0.08);
}
.pillar:last-child { border-right: none; }
.pillar-check { color: var(--accent); font-size: 16px; flex-shrink: 0; margin-top: 2px; }
.pillar-text { font-size: 14px; color: var(--muted2); line-height: 1.5; }
.pillar-text strong { display: block; color: var(--fg); font-weight: 600; margin-bottom: 2px; font-size: 14px; }

/* PRICE STRIP */
.price-strip {
  max-width: 1100px; margin: 28px auto; padding: 28px 40px;
  display: flex; align-items: flex-start; gap: 32px;
  border-radius: 24px;
  background:
    linear-gradient(135deg,
      rgba(216,255,0,0.06) 0%,
      rgba(255,255,255,0.03) 40%,
      transparent 70%),
    rgba(15,20,28,0.25);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border: 1px solid rgba(216,255,0,0.18);
  box-shadow: 0 0 60px rgba(216,255,0,0.04), 0 20px 50px rgba(0,0,0,0.4),
    inset 0 1px 0 rgba(255,255,255,0.2);
}
.price-left { min-width: 120px; flex-shrink: 0; }
.price-from {
  font-family: var(--display); font-size: 11px; letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--muted); margin-bottom: 4px;
}
.price-num {
  font-family: var(--display); font-size: clamp(24px,3vw,36px);
  font-weight: 700; color: var(--accent); letter-spacing: -0.02em;
}
.price-services { flex: 1; }
.price-services-title {
  font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 10px;
}
.price-services-list {
  list-style: none; display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px;
}
.price-services-list li {
  font-size: 12px; color: var(--muted2); padding: 4px 12px;
  border: 1px solid rgba(255,255,255,0.1); border-radius: 999px;
  display: flex; align-items: center; gap: 5px;
}
.price-services-list li::before { content: '✓'; color: var(--accent); font-weight: 700; }
.price-offer {
  font-size: 13px; color: var(--muted2); line-height: 1.5;
}
.price-cta { align-self: center; flex-shrink: 0; }

/* PORTFOLIO SECTION */
.portfolio-section { max-width: 1100px; margin: 0 auto; padding: 60px 40px 0; }
.portfolio-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
.portfolio-item {
  border-radius: 20px; overflow: hidden;
  background:
    linear-gradient(135deg,
      rgba(255,255,255,0.10) 0%,
      rgba(255,255,255,0.03) 40%,
      transparent 70%),
    rgba(15,20,28,0.20);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.13);
  box-shadow: 0 10px 30px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.18);
}
.portfolio-video {
  position: relative; padding-bottom: 56.25%; /* 16:9 */
}
.portfolio-video iframe {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none;
}
.portfolio-title {
  padding: 12px 16px; font-size: 13px; color: var(--muted2); line-height: 1.4;
}

/* REVIEWS */
.section-reviews-wrap {
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.reviews-section { max-width: 1100px; margin: 0 auto; padding: 60px 40px; }
.section-label {
  font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 28px; display: flex; align-items: center; gap: 10px;
}
.section-label::before { content: ''; width: 20px; height: 1px; background: var(--accent); }
.reviews-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin-bottom: 24px; }

/* Review card */
.review-card {
  border-radius: 20px; padding: 28px;
  display: block; text-decoration: none; cursor: pointer;
  background:
    linear-gradient(135deg,
      rgba(255,255,255,0.14) 0%,
      rgba(255,255,255,0.05) 30%,
      rgba(255,255,255,0.00) 50%,
      rgba(255,255,255,0.04) 100%),
    rgba(15,20,28,0.18);
  backdrop-filter: blur(20px) saturate(1.5);
  -webkit-backdrop-filter: blur(20px) saturate(1.5);
  border: 1px solid rgba(255,255,255,0.16);
  box-shadow: 0 0 60px rgba(216,255,0,0.03), 0 20px 50px rgba(0,0,0,0.4),
    0 8px 20px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.28),
    inset 2px 2px 0 -1px rgba(255,255,255,0.10);
}
.review-stars { color: var(--accent); font-size: 13px; letter-spacing: 2px; margin-bottom: 12px; }
.review-text { font-size: 14px; color: var(--muted2); line-height: 1.65; margin-bottom: 16px; font-style: italic; }
.review-author { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg); }
.review-service { font-size: 11px; color: var(--muted); margin-top: 2px; }
.review-gbp-hint {
  font-size: 11px; color: var(--accent); letter-spacing: 0.06em;
  margin-top: 12px; opacity: 0; transition: opacity 0.2s;
}
.review-card:hover .review-gbp-hint { opacity: 1; }
.review-card:hover { border-color: rgba(255,255,255,0.26); }

/* GBP strip */
.reviews-gbp {
  display: flex; align-items: center; gap: 16px;
  padding: 18px 22px; border-radius: 16px;
  background:
    linear-gradient(135deg,
      rgba(255,255,255,0.10) 0%,
      rgba(255,255,255,0.03) 40%,
      transparent 70%),
    rgba(15,20,28,0.20);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.13);
  box-shadow: 0 10px 30px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.18);
}
.reviews-gbp-badge { font-size: 22px; }
.reviews-gbp-text { font-size: 13px; color: var(--muted2); }
.reviews-gbp-text strong { color: var(--fg); }
.reviews-gbp a {
  margin-left: auto; font-size: 12px; color: var(--accent);
  text-decoration: none; letter-spacing: 0.06em; white-space: nowrap;
}

/* FAQ */
.faq-section { max-width: 1100px; margin: 0 auto; padding: 0 40px 60px; }
.faq-item { border-top: 1px solid rgba(255,255,255,0.08); padding: 22px 0; }
.faq-item:last-child { border-bottom: 1px solid rgba(255,255,255,0.08); }
.faq-q {
  font-family: var(--display); font-size: 16px; font-weight: 600;
  margin-bottom: 10px; letter-spacing: -0.01em;
}
.faq-a { font-size: 14px; color: var(--muted2); line-height: 1.7; max-width: 760px; }

/* CTA */
.cta-block {
  margin: 0 40px 80px; padding: 56px 48px;
  background:
    linear-gradient(135deg,
      rgba(216,255,0,0.07) 0%,
      rgba(255,255,255,0.04) 30%,
      rgba(255,255,255,0.01) 60%,
      transparent 80%),
    rgba(15,20,28,0.22);
  backdrop-filter: blur(24px) saturate(1.4);
  -webkit-backdrop-filter: blur(24px) saturate(1.4);
  border: 1px solid rgba(216,255,0,0.18);
  border-radius: 28px; text-align: center;
  box-shadow: 0 0 80px rgba(216,255,0,0.05), 0 30px 70px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.24);
}
.cta-block h2 {
  font-family: var(--display); font-size: clamp(24px,3.5vw,44px);
  font-weight: 700; letter-spacing: -0.02em; margin-bottom: 12px;
}
.cta-block h2 em { font-style: normal; color: var(--accent); }
.cta-block p { color: var(--muted2); font-size: 15px; margin-bottom: 32px; }

/* FOOTER */
.site-footer {
  border-top: 1px solid rgba(255,255,255,0.07); padding: 24px 40px;
  display: flex; justify-content: space-between; align-items: center;
  background: rgba(5,5,5,0.6);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}
.site-footer p { font-size: 12px; color: var(--muted); }
.site-footer a { color: var(--muted2); text-decoration: none; font-size: 12px; transition: color 0.2s; }
.site-footer a:hover { color: var(--fg); }
.footer-links { display: flex; gap: 24px; }

/* MOBILE */
@media (max-width: 768px) {
  body {
    background:
      linear-gradient(to bottom, rgba(5,5,5,0.6) 0%, rgba(5,5,5,0.8) 100%),
      url('/assets/seo-bg.jpg') center 30% / cover no-repeat;
    background-attachment: scroll;
  }
  .sh { padding: 14px 20px; }
  .sh-links { gap: 12px; }
  .hero { padding: 100px 20px 48px; }
  .pillars { grid-template-columns: 1fr; }
  .pillar { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.08); padding: 20px; }
  .pillar:last-child { border-bottom: none; }
  .price-strip {
    padding: 20px; margin: 16px 20px;
    flex-direction: column; gap: 20px;
  }
  .price-cta { width: 100%; }
  .price-cta .btn-accent { width: 100%; justify-content: center; }
  .portfolio-section { padding: 48px 20px 0; }
  .portfolio-grid { grid-template-columns: 1fr; }
  .reviews-section { padding: 48px 20px; }
  .reviews-grid { grid-template-columns: 1fr; }
  .faq-section { padding: 0 20px 48px; }
  .cta-block { margin: 0 20px 60px; padding: 40px 24px; }
  .site-footer { padding: 20px; flex-direction: column; gap: 12px; text-align: center; }
}
