:root {
  --red: #ff1212;
  --deep-red: #700000;
  --hot: #ff4b4b;
  --text: #f8f8f8;
  --muted: #b9b9b9;
  --line: rgba(255, 38, 38, .34);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: hidden; background: #020202; color: var(--text); font-family: Inter, system-ui, sans-serif; }
body::before { content: ""; position: fixed; inset: 0; z-index: -5; background: radial-gradient(circle at 18% 10%, rgba(255,0,0,.22), transparent 30%), radial-gradient(circle at 88% 20%, rgba(255,0,0,.16), transparent 28%), linear-gradient(180deg, #030303 0%, #120202 48%, #020202 100%); }
a { color: inherit; text-decoration: none; }
img, video { display: block; max-width: 100%; }
.noise, .fx-layer { pointer-events: none; position: fixed; inset: 0; }
.noise { z-index: 50; opacity: .045; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.fx-layer { z-index: 40; }
.spark { position: fixed; width: 12px; height: 12px; border-radius: 999px; background: radial-gradient(circle, #fff 0 10%, var(--hot) 30%, transparent 72%); box-shadow: 0 0 18px var(--red), 0 0 42px var(--red); transform: translate(-50%, -50%); animation: spark .72s ease-out forwards; }
.slash { position: fixed; width: 86px; height: 2px; background: linear-gradient(90deg, transparent, var(--hot), transparent); box-shadow: 0 0 18px var(--red); transform-origin: center; animation: slash .55s ease-out forwards; }
.site-header { position: fixed; inset: 0 0 auto; z-index: 30; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 22px; padding: 16px clamp(16px, 4vw, 64px); background: linear-gradient(180deg, rgba(0,0,0,.9), rgba(0,0,0,.22)); border-bottom: 1px solid rgba(255,22,22,.16); backdrop-filter: blur(18px); }
.brand { font-weight: 900; letter-spacing: .18em; text-shadow: 0 0 18px rgba(255,0,0,.5); }
.main-nav, .language-switch, .hero-actions, .contact-actions, .social-strip { display: flex; align-items: center; }
.main-nav { justify-content: center; gap: clamp(14px, 2.2vw, 34px); color: var(--muted); font-weight: 900; font-size: 12px; text-transform: uppercase; }
.main-nav a:hover { color: #fff; text-shadow: 0 0 18px var(--red); }
.language-switch { gap: 6px; }
.language-switch button { color: var(--muted); background: rgba(0,0,0,.5); border: 1px solid var(--line); padding: 8px 10px; font-weight: 900; cursor: pointer; }
.language-switch button.active { color: #fff; background: var(--deep-red); box-shadow: 0 0 20px rgba(255,0,0,.28); }
.hero { min-height: 100svh; position: relative; display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, 420px); align-items: end; gap: clamp(24px,5vw,80px); padding: 138px clamp(18px,5vw,80px) 76px; overflow: hidden; perspective: 1200px; }
.hero-bg { position: absolute; inset: 0; z-index: -4; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center; transform: scale(1.012); filter: contrast(1.08) saturate(1.05) brightness(.86); }
.hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.82), rgba(0,0,0,.28) 48%, rgba(0,0,0,.86)), linear-gradient(180deg, rgba(0,0,0,.2), transparent 48%, #020202); }
.hero-grid { position: absolute; inset: 0; z-index: -3; opacity: .18; background-image: linear-gradient(rgba(255,20,20,.24) 1px, transparent 1px), linear-gradient(90deg, rgba(255,20,20,.24) 1px, transparent 1px); background-size: 72px 72px; mask-image: linear-gradient(180deg, transparent, #000 18%, transparent 85%); animation: gridDrift 18s linear infinite; }
.auto-bolts, .floating-shapes { position: absolute; inset: 0; z-index: -2; pointer-events: none; overflow: hidden; }
.auto-bolts span { position: absolute; width: 2px; height: 46vh; background: linear-gradient(180deg, transparent, rgba(255,255,255,.9), var(--hot), transparent); box-shadow: 0 0 22px var(--red), 0 0 70px rgba(255,0,0,.45); transform: rotate(38deg); opacity: 0; animation: autoBolt 4.4s infinite; }
.auto-bolts span:nth-child(1) { left: 9%; top: 8%; animation-delay: .4s; } .auto-bolts span:nth-child(2) { right: 16%; top: 4%; animation-delay: 1.5s; } .auto-bolts span:nth-child(3) { left: 54%; bottom: 1%; animation-delay: 2.6s; } .auto-bolts span:nth-child(4) { right: 36%; bottom: 26%; animation-delay: 3.5s; }
.floating-shapes span { position: absolute; width: 140px; height: 140px; border: 1px solid rgba(255,45,45,.28); transform: rotate(45deg); box-shadow: inset 0 0 28px rgba(255,0,0,.08), 0 0 44px rgba(255,0,0,.12); animation: floatShape 9s ease-in-out infinite; }
.floating-shapes span:nth-child(1) { left: 8%; bottom: 18%; } .floating-shapes span:nth-child(2) { right: 8%; top: 30%; animation-delay: 2s; } .floating-shapes span:nth-child(3) { left: 58%; top: 12%; animation-delay: 4s; }
.hero-content { max-width: 980px; align-self: center; }
.eyebrow { margin: 0 0 16px; color: var(--hot); font-size: 12px; font-weight: 900; letter-spacing: .22em; text-transform: uppercase; }
h1, h2, h3 { margin: 0; line-height: .94; }
h1 { font-family: Anton, Impact, sans-serif; font-size: clamp(58px, 12vw, 178px); text-transform: uppercase; text-shadow: 0 0 34px rgba(255,0,0,.72), 7px 7px 0 #120000; }
h2 { font-family: Anton, Impact, sans-serif; font-size: clamp(38px, 6.8vw, 96px); text-transform: uppercase; }
h3 { font-size: 24px; }
.hero-copy, .section-head p, .showcase-copy p, .contact-panel p, .hero-panel p, .intro-card p { max-width: 780px; color: var(--muted); font-size: clamp(16px,1.5vw,21px); line-height: 1.62; }
.social-strip { gap: 12px; flex-wrap: wrap; margin: 28px 0 0; }
.social-card { min-width: 230px; padding: 16px 18px; background: linear-gradient(135deg, rgba(255,0,0,.18), rgba(0,0,0,.62)); border: 1px solid var(--line); clip-path: polygon(7% 0,100% 0,93% 100%,0 100%); }
.social-card span { display: block; color: var(--muted); font-size: 12px; text-transform: uppercase; font-weight: 900; }
.social-card strong { display: block; margin-top: 5px; font-size: 18px; }
.hero-actions, .contact-actions { gap: 14px; flex-wrap: wrap; margin-top: 28px; }
.primary-btn, .ghost-btn { border: 1px solid var(--line); padding: 14px 20px; font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; clip-path: polygon(8% 0,100% 0,92% 100%,0 100%); transition: transform .18s ease, box-shadow .18s ease; }
.primary-btn { background: linear-gradient(135deg, var(--red), #5a0000); box-shadow: 0 0 34px rgba(255,0,0,.36); }
.ghost-btn { background: rgba(0,0,0,.44); }
.intro-card, .hero-panel, .contact-toast { padding: 24px; background: linear-gradient(145deg, rgba(12,12,14,.86), rgba(0,0,0,.76)); border: 1px solid var(--line); box-shadow: 0 0 60px rgba(255,0,0,.18); }
.intro-card { position: absolute; top: 108px; right: clamp(18px,5vw,80px); z-index: 2; width: min(380px, calc(100vw - 36px)); transform-style: preserve-3d; animation: cardFloat 5.5s ease-in-out infinite; }
.intro-card span, .hero-panel span, .contact-toast span { color: var(--hot); font-weight: 900; text-transform: uppercase; font-size: 12px; letter-spacing: .15em; }
.intro-card strong, .hero-panel strong, .contact-toast strong { display: block; margin-top: 14px; font-family: Anton, Impact, sans-serif; font-size: 38px; line-height: 1; text-transform: uppercase; }
.marquee { overflow: hidden; border-block: 1px solid var(--line); background: #080808; }
.marquee-track { display: flex; width: max-content; animation: marquee 28s linear infinite; }
.marquee span { padding: 17px 34px; font-family: Anton, Impact, sans-serif; font-size: clamp(24px,4vw,50px); color: transparent; -webkit-text-stroke: 1px rgba(255,255,255,.7); text-transform: uppercase; }
.section { padding: clamp(82px,10vw,150px) clamp(18px,5vw,80px); }
.section-head { max-width: 1000px; margin-bottom: 50px; }
.service-grid, .video-grid, .timeline { display: grid; gap: 18px; }
.service-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.web-service { grid-column: span 3; min-height: 220px; background: radial-gradient(circle at 80% 20%, rgba(255,0,0,.26), transparent 36%), linear-gradient(145deg, rgba(30,30,34,.88), rgba(3,3,3,.95)); }
.video-grid { grid-template-columns: repeat(3, 1fr); perspective: 1200px; }
.timeline { grid-template-columns: repeat(4, 1fr); }
.service-card, .step, .contact-panel, .video-card { position: relative; overflow: hidden; background: linear-gradient(145deg, rgba(25,25,28,.84), rgba(3,3,3,.94)); border: 1px solid rgba(255,34,34,.28); box-shadow: inset 0 0 0 1px rgba(255,255,255,.03), 0 24px 80px rgba(0,0,0,.4); }
.service-card, .step { min-height: 270px; padding: 28px; }
.service-card::before, .step::before, .video-card::before, .contact-panel::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent, rgba(255,0,0,.22), transparent); transform: translateX(-110%); transition: transform .75s ease; }
.service-card:hover::before, .step:hover::before, .video-card:hover::before, .contact-panel:hover::before { transform: translateX(110%); }
.line-icon { display: inline-grid; place-items: center; width: 56px; height: 48px; margin-bottom: 70px; border: 1px solid var(--line); color: var(--hot); font-family: Anton, Impact, sans-serif; font-size: 28px; box-shadow: 0 0 24px rgba(255,0,0,.18); }
.service-card p, .step p, .video-card p { color: var(--muted); line-height: 1.56; }
.reels { background: linear-gradient(180deg, #020202, #110202, #020202); }
.website-teaser {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(320px, 1.1fr);
  gap: clamp(28px, 5vw, 80px);
  align-items: center;
  background:
    radial-gradient(circle at 15% 15%, rgba(255,0,0,.18), transparent 30%),
    linear-gradient(180deg, #020202, #120202 48%, #020202);
  overflow: hidden;
}
.website-teaser::before {
  content: "";
  position: absolute;
  inset: 12%;
  border: 1px solid rgba(255,35,35,.16);
  transform: skewY(-4deg);
  box-shadow: 0 0 80px rgba(255,0,0,.12);
}
.website-copy { position: relative; z-index: 1; }
.website-copy .primary-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 4px;
}
.web-tags { display: flex; flex-wrap: wrap; gap: 10px; margin: 24px 0 30px; }
.web-tags span {
  padding: 10px 12px;
  border: 1px solid var(--line);
  background: rgba(255,0,0,.07);
  color: #fff;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.browser-mockup {
  position: relative;
  z-index: 1;
  min-height: 480px;
  border: 1px solid rgba(255,45,45,.38);
  background: linear-gradient(145deg, rgba(18,18,22,.96), rgba(0,0,0,.88));
  box-shadow: 0 38px 120px rgba(255,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.04);
  transform-style: preserve-3d;
  animation: mockFloat 6s ease-in-out infinite;
  overflow: hidden;
}
.browser-mockup::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 0 34%, rgba(255,255,255,.1) 45%, transparent 55% 100%);
  transform: translateX(-120%);
  animation: mockShine 4.8s ease-in-out infinite;
}
.portfolio-preview {
  min-height: 0;
}
.portfolio-preview::after {
  pointer-events: none;
}
.browser-top {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  background: rgba(0,0,0,.58);
}
.browser-top span {
  width: 11px;
  height: 11px;
  border-radius: 999px;
  background: var(--red);
  box-shadow: 0 0 12px var(--red);
}
.browser-top span:nth-child(2) { opacity: .65; }
.browser-top span:nth-child(3) { opacity: .35; }
.browser-top b {
  margin-left: auto;
  color: var(--muted);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.preview-screen {
  position: relative;
  display: block;
  margin: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,45,45,.34);
  background: #000;
  box-shadow: 0 22px 60px rgba(0,0,0,.42);
}
.preview-screen img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: top center;
  filter: saturate(1.08) contrast(1.06) brightness(.9);
  transform: scale(1.02);
  transition: transform .5s ease, filter .5s ease;
}
.preview-screen:hover img {
  transform: scale(1.07);
  filter: saturate(1.2) contrast(1.12) brightness(1.02);
}
.preview-overlay {
  position: absolute;
  inset: auto 0 0 0;
  padding: 46px 18px 18px;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.9));
}
.preview-overlay span {
  color: var(--hot);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.preview-overlay strong {
  display: block;
  margin-top: 8px;
  color: #fff;
  font-family: Anton, Impact, sans-serif;
  font-size: clamp(28px, 4vw, 46px);
  line-height: .95;
  text-shadow: 0 0 22px rgba(255,0,0,.55);
}
.preview-overlay em {
  display: inline-block;
  margin-top: 12px;
  color: #fff;
  font-style: normal;
  font-weight: 900;
  font-size: 12px;
  text-transform: uppercase;
}
.preview-meta {
  padding: 0 18px 22px;
}
.preview-meta p {
  margin: 0 0 14px;
  color: var(--muted);
  line-height: 1.55;
}
.preview-meta b {
  color: #fff;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.mock-hero {
  min-height: 210px;
  display: grid;
  place-content: center;
  text-align: center;
  background:
    radial-gradient(circle at 50% 35%, rgba(255,0,0,.24), transparent 42%),
    linear-gradient(135deg, rgba(255,0,0,.14), transparent 40%);
}
.mock-hero strong {
  font-family: Anton, Impact, sans-serif;
  font-size: clamp(58px, 7vw, 104px);
  line-height: .9;
  text-shadow: 0 0 34px rgba(255,0,0,.72), 5px 5px 0 #130000;
}
.mock-hero em {
  margin-top: 12px;
  color: var(--muted);
  font-style: normal;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.mock-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 18px;
}
.mock-grid span {
  min-height: 108px;
  border: 1px solid rgba(255,45,45,.22);
  background: linear-gradient(145deg, rgba(255,0,0,.14), rgba(0,0,0,.5));
  animation: mockPulse 2.8s ease-in-out infinite;
}
.mock-grid span:nth-child(2) { animation-delay: .35s; }
.mock-grid span:nth-child(3) { animation-delay: .7s; }
.code-rain i {
  position: absolute;
  bottom: -80px;
  width: 2px;
  height: 90px;
  background: linear-gradient(180deg, transparent, var(--hot), transparent);
  box-shadow: 0 0 14px var(--red);
  animation: codeRain 3.4s linear infinite;
}
.code-rain i:nth-child(1) { left: 14%; animation-delay: .1s; }
.code-rain i:nth-child(2) { left: 34%; animation-delay: .8s; }
.code-rain i:nth-child(3) { left: 52%; animation-delay: 1.5s; }
.code-rain i:nth-child(4) { left: 71%; animation-delay: .45s; }
.code-rain i:nth-child(5) { left: 88%; animation-delay: 2.1s; }
.video-card { transform-style: preserve-3d; transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease; }
.video-card::after { content: "PLAY"; position: absolute; top: 18px; right: 18px; z-index: 3; padding: 9px 12px; border: 1px solid var(--line); background: rgba(0,0,0,.62); font-weight: 900; font-size: 11px; letter-spacing: .16em; transform: translateZ(34px); }
.video-card:hover { border-color: rgba(255,80,80,.74); box-shadow: 0 34px 100px rgba(255,0,0,.22), 0 18px 60px rgba(0,0,0,.56); }
.video-card video { width: 100%; aspect-ratio: 16/10; object-fit: cover; background: #000; border-bottom: 1px solid var(--line); filter: saturate(1.15) contrast(1.08); transition: transform .45s ease, filter .45s ease; }
.video-card:hover video { transform: scale(1.045); filter: saturate(1.3) contrast(1.14) brightness(1.08); }
.video-card.tall video { aspect-ratio: 9/13; }
.video-card div { padding: 22px; transform: translateZ(28px); }
.video-card span { color: var(--hot); font-family: Anton, Impact, sans-serif; font-size: 48px; text-shadow: 0 0 22px rgba(255,0,0,.62); transition: transform .35s ease, text-shadow .35s ease; }
.video-card:hover span { transform: translateZ(44px) scale(1.18) rotate(-4deg); text-shadow: 0 0 34px var(--red), 6px 6px 0 #190000; }
.showcase { display: grid; grid-template-columns: minmax(0,1.35fr) minmax(300px,.65fr); gap: clamp(28px,5vw,80px); align-items: center; padding: 90px clamp(18px,5vw,80px); }
.showcase-media img { width: 100%; border: 1px solid var(--line); box-shadow: 0 0 80px rgba(255,0,0,.24); }
.contact-panel { max-width: 1120px; margin: 0 auto; padding: clamp(28px,6vw,76px); }
.legal-section {
  position: relative;
  overflow: hidden;
  padding: clamp(58px, 8vw, 110px) clamp(18px, 5vw, 80px);
  border-top: 1px solid rgba(255,38,38,.18);
  background: #030303;
}
.legal-bg {
  position: absolute;
  inset: 0;
  opacity: .16;
  filter: saturate(.9) contrast(1.15);
}
.legal-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.96), rgba(0,0,0,.74), rgba(0,0,0,.94)),
    linear-gradient(180deg, #020202, transparent 45%, #020202);
}
.legal-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.legal-inner {
  position: relative;
  z-index: 1;
  max-width: 1120px;
  margin: 0 auto;
}
.legal-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 26px;
}
.legal-head h2 {
  max-width: 680px;
  font-size: clamp(34px, 5vw, 72px);
  text-align: right;
}
.legal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.legal-grid article {
  border: 1px solid rgba(255,38,38,.2);
  background: rgba(0,0,0,.58);
  padding: 18px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}
.legal-grid h3 {
  margin-bottom: 10px;
  color: #fff;
  font-size: 14px;
  line-height: 1.25;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.legal-grid p {
  margin: 0;
  color: rgba(248,248,248,.72);
  font-size: 13px;
  line-height: 1.65;
}
.legal-grid a {
  color: #fff;
  font-weight: 800;
  text-shadow: 0 0 12px rgba(255,0,0,.45);
}
.legal-wide {
  grid-column: span 2;
}
.reveal { opacity: 0; transform: translateY(36px) scale(.985); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1); }
.reveal.visible { opacity: 1; transform: translateY(0) scale(1); }
.back-top { position: fixed; right: 18px; bottom: 18px; z-index: 35; width: 52px; height: 52px; border: 1px solid var(--line); color: #fff; background: linear-gradient(135deg, var(--red), #360000); box-shadow: 0 0 34px rgba(255,0,0,.38); cursor: pointer; opacity: 0; transform: translateY(20px) scale(.9); transition: opacity .25s ease, transform .25s ease; font-size: 24px; font-weight: 900; }
.back-top.visible { opacity: 1; transform: translateY(0) scale(1); }
.contact-toast { position: fixed; top: 92px; right: 22px; z-index: 36; width: min(340px, calc(100vw - 28px)); transform: translateX(120%) rotateY(-18deg); opacity: 0; transition: transform .55s cubic-bezier(.2,.8,.2,1), opacity .35s ease; }
.contact-toast.visible { transform: translateX(0) rotateY(0deg); opacity: 1; }
.contact-toast a { display: inline-block; margin-top: 12px; color: #fff; font-weight: 900; text-shadow: 0 0 12px var(--red); }
.toast-close { position: absolute; top: 8px; right: 10px; border: 0; color: #fff; background: transparent; font-size: 24px; cursor: pointer; }
@keyframes marquee { to { transform: translateX(-50%); } }
@keyframes gridDrift { to { background-position: 72px 72px; } }
@keyframes autoBolt { 0%, 78%, 100% { opacity: 0; filter: blur(5px); transform: rotate(38deg) translateY(-18px); } 82%, 88% { opacity: 1; filter: blur(0); transform: rotate(38deg) translateY(0); } 91% { opacity: .25; } }
@keyframes cardFloat { 0%, 100% { transform: rotateX(0deg) rotateY(-5deg) translateY(0); } 50% { transform: rotateX(4deg) rotateY(6deg) translateY(-10px); } }
@keyframes floatShape { 0%, 100% { transform: rotate(45deg) translateY(0) scale(1); opacity: .18; } 50% { transform: rotate(66deg) translateY(-22px) scale(1.15); opacity: .42; } }
@keyframes mockFloat { 0%, 100% { transform: rotateX(0deg) rotateY(-5deg) translateY(0); } 50% { transform: rotateX(3deg) rotateY(6deg) translateY(-14px); } }
@keyframes mockShine { 0%, 55% { transform: translateX(-120%); } 100% { transform: translateX(130%); } }
@keyframes mockPulse { 0%, 100% { transform: translateY(0); box-shadow: none; } 50% { transform: translateY(-8px); box-shadow: 0 18px 40px rgba(255,0,0,.14); } }
@keyframes codeRain { to { transform: translateY(-650px); opacity: 0; } }
@keyframes spark { to { opacity: 0; transform: translate(-50%, -50%) scale(2.8); } }
@keyframes slash { 0% { opacity: 0; transform: translate(-50%, -50%) rotate(var(--angle)) scaleX(.2); } 18% { opacity: 1; } 100% { opacity: 0; transform: translate(-50%, -50%) rotate(var(--angle)) scaleX(1.2); } }
@media (max-width: 1040px) {
  .site-header { grid-template-columns: 1fr auto; }
  .main-nav { display: none; }
  .hero, .showcase, .timeline, .video-grid, .service-grid, .website-teaser { grid-template-columns: 1fr; }
  .web-service { grid-column: span 1; }
  .intro-card { position: relative; top: auto; right: auto; width: 100%; align-self: start; animation: none; }
  .hero-panel { max-width: 620px; }
}
@media (max-width: 640px) {
  .site-header { padding: 12px; gap: 10px; }
  .brand { font-size: 12px; letter-spacing: .08em; }
  .language-switch { justify-content: flex-end; flex-wrap: wrap; max-width: 158px; }
  .language-switch button { padding: 6px 7px; font-size: 11px; }
  .hero { padding: 112px 14px 58px; min-height: auto; }
  h1 { font-size: clamp(54px,17vw,84px); }
  h2 { font-size: clamp(36px,11vw,58px); }
  .social-card, .hero-actions a, .contact-actions a { width: 100%; text-align: center; }
  .section { padding-inline: 14px; }
  .website-teaser {
    gap: 34px;
    padding-top: 74px;
    padding-bottom: 88px;
  }
  .website-teaser::before {
    inset: 4% 8%;
    transform: skewY(-2deg);
  }
  .website-copy {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }
  .website-copy h2 {
    margin-bottom: 18px;
    line-height: 1;
  }
  .website-copy p {
    margin: 0;
    font-size: 16px;
    line-height: 1.7;
  }
  .web-tags {
    margin: 26px 0 24px;
    gap: 8px;
  }
  .web-tags span {
    flex: 1 1 calc(50% - 8px);
    min-width: 132px;
    text-align: center;
    padding: 11px 9px;
    font-size: 11px;
  }
  .website-copy .primary-btn {
    width: 100%;
    margin-top: 10px;
    padding: 16px 18px;
    clip-path: polygon(5% 0,100% 0,95% 100%,0 100%);
  }
  .service-card, .step { min-height: auto; }
  .line-icon { margin-bottom: 38px; }
  .video-card.tall video, .video-card video { aspect-ratio: 9/14; }
  .browser-mockup {
    min-height: 0;
    animation: none;
  }
  .browser-top b {
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .mock-hero {
    min-height: 160px;
    padding: 24px 12px;
  }
  .mock-hero strong {
    font-size: clamp(48px, 16vw, 66px);
  }
  .mock-hero em {
    font-size: 11px;
    letter-spacing: .12em;
  }
  .mock-grid { grid-template-columns: 1fr; }
  .mock-grid span { min-height: 72px; }
  .preview-screen {
    margin: 12px;
  }
  .preview-screen img {
    aspect-ratio: 4 / 5;
  }
  .preview-overlay {
    padding: 70px 14px 14px;
  }
  .preview-overlay strong {
    font-size: 28px;
  }
  .preview-meta {
    padding: 0 14px 18px;
  }
  .back-top { width: 46px; height: 46px; right: 12px; bottom: 12px; }
  .contact-toast { top: auto; bottom: 72px; right: 14px; }
  .legal-section {
    padding: 54px 14px 72px;
  }
  .legal-bg {
    opacity: .11;
  }
  .legal-head {
    display: block;
  }
  .legal-head h2 {
    margin-top: 10px;
    text-align: left;
  }
  .legal-grid {
    grid-template-columns: 1fr;
  }
  .legal-wide {
    grid-column: span 1;
  }
  .legal-grid article {
    padding: 15px;
  }
  .legal-grid p {
    font-size: 12px;
  }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
}
