/*
Theme Name:  TrackAttack Pro
Theme URI:   https://trackattack-pro.netlify.app
Author:      Hoosier Racing Tire
Description: Official TrackAttack Pro landing page theme — Velocity Performance design system.
Version:     2.8.0
License:     GNU General Public License v2 or later
Text Domain: trackattack-pro
*/

/* ─────────────────────────────────────────────
   DESIGN TOKENS
───────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --surface: #131313;
  --surface-dim: #131313;
  --surface-bright: #3a3939;
  --surface-container-lowest: #0e0e0e;
  --surface-container-low: #1c1b1b;
  --surface-container: #201f1f;
  --surface-container-high: #2a2a2a;
  --surface-container-highest: #353534;
  --on-surface: #e5e2e1;
  --on-surface-variant: #e6bdbb;
  --inverse-surface: #e5e2e1;
  --inverse-on-surface: #313030;
  --outline: #ad8886;
  --outline-variant: #5d3f3e;
  --primary: #ffb3b1;
  --on-primary: #680011;
  --primary-container: #e31837;
  --on-primary-container: #fffaf9;
  --inverse-primary: #bf0029;
  --secondary: #adc6ff;
  --on-secondary: #002e69;
  --secondary-container: #4b8eff;
  --tertiary: #c6c6cf;
  --on-tertiary: #2f3037;
  --tertiary-container: #72737b;
  --on-tertiary-container: #fcfaff;
  --error: #ffb4ab;
  --error-container: #93000a;
  --background: #131313;
  --on-background: #e5e2e1;
  --surface-variant: #353534;
  --unit: 4px;
  --gutter: 24px;
  --margin-desktop: 64px;
  --margin-mobile: 20px;
  --container-max: 1100px;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Hanken Grotesk', sans-serif;
  font-size: 16px;
  line-height: 24px;
  color: var(--on-background);
  background: var(--background);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ─── HEADER ─── */
header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px var(--margin-mobile);
  border-bottom: 2px solid var(--outline-variant);
  background: var(--background);
  transition: background 0.3s, padding 0.3s;
}
@media (min-width: 768px) { header { padding: 16px var(--margin-desktop); } }
header.scrolled { background: rgba(19,19,19,0.95); backdrop-filter: blur(10px); }

.logo { font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic; font-size: 24px; color: var(--on-surface); text-transform: uppercase; letter-spacing: -0.02em; text-decoration: none; }
.logo span { color: var(--primary-container); }

.cta-btn {
  font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic;
  font-size: 14px; line-height: 1; letter-spacing: 0.02em; text-transform: uppercase;
  text-decoration: none; color: var(--on-primary-container); background: var(--primary-container);
  padding: 10px 24px; border: none; cursor: pointer; white-space: nowrap;
  transform: skewX(-5deg); transition: background 0.3s, color 0.3s;
}
.cta-btn:hover { background: var(--secondary-container); color: var(--on-primary-container); }

.header-right { display: flex; align-items: center; gap: 16px; }

.version-badge {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 700;
  line-height: 16px; letter-spacing: 0.1em; color: var(--outline); text-transform: uppercase;
  padding: 2px 8px; border: 1px solid var(--outline-variant); white-space: nowrap;
}

.hamburger { display: flex; flex-direction: column; gap: 6px; cursor: pointer; padding: 8px; }
.hamburger span { display: block; width: 28px; height: 2px; background: var(--on-surface); transition: 0.3s; }

/* ─── HERO ─── */
.hero {
  position: relative; height: 100vh; min-height: 700px;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 80px var(--margin-desktop); overflow: hidden;
  clip-path: polygon(0 0, 100% 0, 100% 85%, 0% 100%);
}
.hero-bg {
  position: absolute; inset: 0;
  background: url('assets/images/racetrack_camera_03.jpg') center/cover no-repeat;
  z-index: 0; filter: grayscale(100%); opacity: 0.6;
  transition: filter 1s, opacity 1s;
}
.hero:hover .hero-bg { filter: grayscale(0%); opacity: 0.7; }
.hero-bg::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.4) 50%, transparent 100%);
}
.hero-content { position: relative; z-index: 1; max-width: 700px; }
.hero h1 {
  font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic;
  font-size: clamp(36px, 8vw, 72px); line-height: 1; letter-spacing: -0.02em;
  color: var(--on-surface); text-transform: uppercase; margin-bottom: 16px;
  opacity: 0; transform: translateY(40px);
  animation: heroReveal 1s ease-out 0.3s forwards;
}
.hero .subtitle {
  font-family: 'Hanken Grotesk', sans-serif; font-size: 18px; line-height: 28px;
  color: var(--on-surface-variant); border-left: 4px solid var(--primary-container);
  padding-left: var(--gutter); opacity: 0; transform: translateY(20px);
  animation: heroReveal 1s ease-out 0.6s forwards;
}
@keyframes heroReveal { to { opacity: 1; transform: translateY(0); } }

/* ─── PRESENTED BY ─── */
.presented-by { text-align: center; padding: 50px var(--margin-mobile); background: var(--surface-container); border-bottom: 2px solid var(--outline-variant); }
.presented-by p { font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700; line-height: 16px; letter-spacing: 0.1em; color: var(--secondary); text-transform: uppercase; }

/* ─── FEATURES ─── */
.features { display: flex; align-items: center; gap: 60px; max-width: var(--container-max); margin: 0 auto; padding: 80px var(--margin-desktop); }
.features-image { flex: 1; display: flex; justify-content: center; }
.tire-render { width: 420px; height: 350px; background: url('assets/images/Tire-angle-lrg.png') center/contain no-repeat; filter: drop-shadow(0 0 40px rgba(227,24,55,0.15)); }
.features-list { flex: 1; list-style: none; display: flex; flex-direction: column; gap: 20px; }
.features-list li { display: flex; align-items: flex-start; gap: 14px; font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; line-height: 24px; color: var(--on-surface-variant); }
.features-list li strong { color: var(--on-surface); font-weight: 600; }
.check-icon { flex-shrink: 0; width: 22px; height: 22px; background: var(--primary-container); display: flex; align-items: center; justify-content: center; margin-top: 2px; }
.check-icon svg { width: 12px; height: 12px; fill: none; stroke: var(--on-primary-container); stroke-width: 2.5; stroke-linecap: square; stroke-linejoin: miter; }

/* ─── VIDEO ─── */
.video-section {
  position: relative; height: 500px; display: flex; align-items: center; justify-content: center;
  background: url('assets/images/Tire-angle-lrg-web-no-text.jpg') center/cover no-repeat;
  overflow: hidden; border-top: 4px solid var(--primary-container); border-bottom: 4px solid var(--primary-container);
}
.video-section::before { content: ''; position: absolute; inset: 0; background: rgba(19,19,19,0.7); }
.play-btn { position: relative; z-index: 1; width: 80px; height: 80px; background: var(--primary-container); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: transform 0.3s, box-shadow 0.3s; box-shadow: 0 0 30px rgba(227,24,55,0.4); }
.play-btn:hover { transform: scale(1.1); background: var(--secondary-container); box-shadow: 0 0 40px rgba(75,142,255,0.4); }
.play-btn svg { width: 28px; height: 28px; fill: var(--on-primary-container); margin-left: 4px; }
.play-label { position: relative; z-index: 1; margin-top: 16px; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--primary); }
.video-inner { display: flex; flex-direction: column; align-items: center; }

/* ─── TECH CALLOUTS ─── */
.tech-callouts {
  position: relative; padding: 100px var(--margin-desktop); overflow: hidden;
  background-color: var(--surface-container-low);
  background-image: linear-gradient(45deg, #1a1a1a 25%, transparent 25%, transparent 75%, #1a1a1a 75%, #1a1a1a), linear-gradient(45deg, #1a1a1a 25%, transparent 25%, transparent 75%, #1a1a1a 75%, #1a1a1a);
  background-size: 4px 4px; background-position: 0 0, 2px 2px;
}
.tech-inner { max-width: var(--container-max); margin: 0 auto; position: relative; min-height: 500px; }
.tire-center { width: 320px; height: 320px; background: url('assets/images/Tire-angle-lrg.png') center/cover; margin: 0 auto; border: 1px solid var(--outline-variant); position: relative; }
.callout-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: var(--gutter); margin-top: 50px; }
.callout { text-align: center; padding: var(--gutter); border: 1px solid var(--outline-variant); background: var(--surface-container); transition: border-color 0.3s; }
.callout:hover { border-color: var(--primary-container); }
.callout-icon { width: 48px; height: 48px; background: var(--primary-container); margin: 0 auto 16px; display: flex; align-items: center; justify-content: center; }
.callout-icon svg { width: 20px; height: 20px; stroke: var(--on-primary-container); fill: none; stroke-width: 1.5; stroke-linecap: square; }
.callout p { font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; line-height: 24px; color: var(--on-surface-variant); }
.callout strong { color: var(--on-surface); }

/* ─── GALLERY ─── */
.gallery { padding: 80px var(--margin-desktop); background: var(--surface); border-top: 4px solid var(--outline-variant); }
.gallery-header { max-width: 600px; margin-bottom: 40px; }
.gallery-header h2 { font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic; font-size: 48px; line-height: 48px; color: var(--primary-container); text-transform: uppercase; margin-bottom: 8px; }
.gallery-header p { font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; line-height: 24px; color: var(--on-surface-variant); }
.gallery-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gutter); }
.gallery-img { width: 100%; height: 400px; object-fit: cover; filter: grayscale(50%); transition: filter 0.5s, transform 0.5s; border: 1px solid var(--outline-variant); }
.gallery-img:hover { filter: grayscale(0%); transform: scale(1.02); }

/* ─── ABOUT ─── */
.about-overlay { position: relative; min-height: 500px; display: flex; align-items: center; background: url('assets/images/TAP-2000x1000-master6.jpg') center/cover no-repeat; }
.about-overlay::before { content: ''; position: absolute; inset: 0; background: linear-gradient(to right, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.6) 100%); }
.about-content { position: relative; z-index: 1; max-width: 550px; padding: 80px var(--margin-desktop); }
.about-content h2 { font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic; font-size: 48px; line-height: 48px; color: var(--on-surface); text-transform: uppercase; margin-bottom: 20px; }
.about-content p { font-family: 'Hanken Grotesk', sans-serif; font-size: 18px; line-height: 28px; color: var(--on-surface-variant); border-left: 4px solid var(--primary-container); padding-left: var(--gutter); }

/* ─── CTA BANNER ─── */
.cta-banner {
  position: relative; padding: 80px var(--margin-desktop); text-align: center;
  background: url('assets/images/TAP-2000x1000-master-1.jpg') center/cover no-repeat;
  overflow: hidden; border-top: 4px solid var(--primary-container); border-bottom: 4px solid var(--primary-container);
}
.cta-banner::before { content: ''; position: absolute; inset: 0; background: rgba(19,19,19,0.8); }
.cta-banner-content { position: relative; z-index: 1; max-width: 800px; margin: 0 auto; }
.cta-banner h2 { font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic; font-size: clamp(24px, 4vw, 48px); line-height: 1; color: var(--on-surface); text-transform: uppercase; margin-bottom: 16px; }
.cta-banner p { font-family: 'Hanken Grotesk', sans-serif; font-size: 18px; line-height: 28px; color: var(--on-surface-variant); font-style: italic; }

/* ─── CINEMATIC + HOTSPOTS ─── */
.cinematic-tire { position: relative; display: flex; align-items: center; justify-content: center; overflow: hidden; background: var(--surface-container-lowest); padding: 40px var(--margin-mobile); }
.cinematic-tire .night-bg { position: absolute; inset: 0; background: url('assets/images/Tire-angle-lrg-web-no-text.jpg') center/cover no-repeat; z-index: 0; }
.tire-hotspots { position: relative; z-index: 1; width: 1100px; max-width: 100%; aspect-ratio: 1100 / 900; }
.tire-hotspots .tire-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; filter: drop-shadow(0 0 60px rgba(227,24,55,0.3)); animation: floatTire 4s ease-in-out infinite; }
@keyframes floatTire { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }

.hotspot { position: absolute; transform: translate(-50%, -50%); z-index: 2; }
.hotspot__btn {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--on-surface); border: 2px solid var(--primary-container);
  cursor: pointer; position: relative; display: block; padding: 0;
}
.hotspot__btn::before {
  content: ''; position: absolute; inset: -7px; border-radius: 50%;
  border: 2px solid var(--primary-container);
  animation: hsBeat 1.8s ease-out infinite;
}
@keyframes hsBeat { 0% { transform: scale(0.55); opacity: 0.9; } 100% { transform: scale(1.7); opacity: 0; } }

.hotspot__tip {
  position: absolute; bottom: 150%; left: 50%;
  transform: translateX(-50%) translateY(8px);
  width: 210px; max-width: 60vw; padding: 10px 14px;
  background: var(--primary-container); color: var(--on-primary-container);
  font-family: 'Hanken Grotesk', sans-serif; font-size: 14px; line-height: 1.4;
  text-align: center; box-shadow: 0 8px 24px rgba(0,0,0,0.4);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.25s ease, transform 0.25s ease; z-index: 5;
}
.hotspot__tip::after {
  content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  border: 7px solid transparent; border-top-color: var(--primary-container);
}
.hotspot:hover .hotspot__tip, .hotspot:focus-within .hotspot__tip {
  opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0);
}

/* ─── SPECS SUMMARY ─── */
.specs-summary { position: relative; padding: 60px var(--margin-desktop); background: var(--surface-container-lowest); color: var(--on-surface); overflow: hidden; border-top: 2px solid var(--outline-variant); border-bottom: 2px solid var(--outline-variant); }
.specs-summary::before { content: ''; position: absolute; inset: 0; background: url('assets/images/IMG_3706.jpg') center/cover no-repeat; opacity: 0.08; filter: grayscale(100%); }
.specs-header { position: relative; z-index: 1; text-align: center; margin-bottom: 40px; }
.specs-sub { font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--secondary); margin-top: 8px; }

/* ─── RADAR ─── */
.radar-section { position: relative; padding: 80px var(--margin-desktop); overflow: hidden; background: var(--surface); }
.radar-section::before { content: ''; position: absolute; inset: 0; background: url('assets/images/IMG_3706.jpg') center/cover no-repeat; opacity: 0.05; filter: grayscale(100%); }
.radar-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 60px; max-width: var(--container-max); margin: 0 auto; }
.radar-card { text-align: center; border: 1px solid var(--outline-variant); padding: var(--gutter); background: var(--surface-container); position: relative; overflow: hidden; }

/* ─── H-DNA ─── */
.hdna-section { display: flex; align-items: center; gap: 60px; max-width: var(--container-max); margin: 0 auto; padding: 100px var(--margin-desktop); }
.hdna-image { flex: 0 0 340px; height: 420px; background: var(--surface-container-lowest); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 20px; padding: 40px; border: 1px solid var(--outline-variant); position: relative; overflow: hidden; }
.hdna-image::before { content: ''; position: absolute; top: -50%; left: -50%; width: 200%; height: 200%; background: conic-gradient(from 0deg, transparent, var(--primary-container), transparent, transparent); animation: rotateDNA 8s linear infinite; opacity: 0.1; }
@keyframes rotateDNA { to { transform: rotate(360deg); } }
.hdna-content h2 { font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic; font-size: 48px; line-height: 48px; color: var(--on-surface); text-transform: uppercase; margin-bottom: 20px; }
.hdna-content p { font-family: 'Hanken Grotesk', sans-serif; font-size: 18px; line-height: 28px; color: var(--on-surface-variant); }

/* ─── DOMINANCE ─── */
.dominance { padding: 80px var(--margin-desktop); max-width: var(--container-max); margin: 0 auto; border-top: 2px solid var(--outline-variant); }
.dominance h2 { font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic; font-size: 36px; line-height: 36px; color: var(--on-surface); text-transform: uppercase; margin-bottom: 20px; opacity: 0.7; }
.dominance p { font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; line-height: 24px; color: var(--on-surface-variant); }

/* ─── PRODUCT TABLE ─── */
.availability-note { max-width: var(--container-max); margin: 0 auto; padding: 20px var(--margin-desktop) 10px; border-top: 4px solid var(--primary-container); }
.availability-note h3 { font-family: 'Anton', sans-serif; font-weight: 400; font-size: 24px; line-height: 28px; color: var(--primary-container); text-transform: uppercase; margin-bottom: 4px; }
.availability-note p { font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; line-height: 24px; color: var(--on-surface-variant); }
.product-data-header { max-width: var(--container-max); margin: 40px auto 20px; padding: 0 var(--margin-desktop); display: flex; align-items: baseline; gap: 20px; }
.product-data-header .pd-label { font-family: 'JetBrains Mono', monospace; font-size: 20px; font-weight: 500; line-height: 24px; color: var(--primary); }
.table-container { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--margin-mobile) 20px; overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; font-family: 'JetBrains Mono', monospace; font-size: 11px; white-space: nowrap; }
.data-table thead th { background: var(--surface-container-highest); color: var(--on-surface); padding: 8px 6px; text-align: center; font-weight: 700; font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; border: 1px solid var(--outline-variant); position: sticky; top: 0; }
.data-table tbody td { padding: 5px 6px; text-align: center; border: 1px solid var(--outline-variant); font-size: 11px; font-weight: 500; color: var(--on-surface-variant); background: var(--surface-container); }
.data-table tbody tr:nth-child(even) td { background: var(--surface-container-low); }
.data-table tbody tr:hover td { background: var(--surface-container-high); color: var(--on-surface); }
.rim-group td:first-child { background: var(--primary-container) !important; color: var(--on-primary-container); font-weight: 700; font-size: 13px; }
.badge { display: inline-block; padding: 2px 8px; font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.badge-available { background: rgba(76,175,80,0.15); color: #66bb6a; border: 1px solid rgba(76,175,80,0.3); }
.badge-upcoming { background: rgba(255,179,177,0.1); color: var(--primary); border: 1px solid rgba(255,179,177,0.2); }
.usdot-note { text-align: center; padding: 16px; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-surface); border-bottom: 2px solid var(--outline-variant); }

/* ─── RESOURCES ─── */
.resources-banner { background: var(--surface-container-lowest); padding: 30px var(--margin-desktop); text-align: center; position: relative; overflow: hidden; border-top: 4px solid var(--primary-container); }
.resources-banner::before { content: ''; position: absolute; inset: 0; background: url('assets/images/racetrack_camera_03.jpg') center/cover no-repeat; opacity: 0.05; filter: grayscale(100%); }
.resources-banner h2 { font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic; font-size: 48px; line-height: 48px; color: var(--on-surface); text-transform: uppercase; position: relative; z-index: 1; }
.resources-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gutter); max-width: var(--container-max); margin: 0 auto; padding: 60px var(--margin-desktop); }
.resource-card { display: flex; align-items: center; gap: var(--gutter); padding: var(--gutter); background: var(--surface-container); border: 1px solid var(--outline-variant); transition: border-color 0.3s; }
.resource-card:hover { border-color: var(--primary-container); }
.resource-img { flex: 0 0 200px; height: 160px; background: url('assets/images/tire-3-views@2x.png') center/cover no-repeat; border: 1px solid var(--outline-variant); }
.resource-img.tech-img { background: url('assets/images/LC3_2618.jpg') center/cover no-repeat; }
.resource-info h3 { font-family: 'Anton', sans-serif; font-weight: 400; font-size: 24px; line-height: 28px; color: var(--on-surface); text-transform: uppercase; margin-bottom: 10px; }
.resource-info p { font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; line-height: 24px; color: var(--on-surface-variant); margin-bottom: 6px; }
.resource-info .note { font-style: italic; font-size: 14px; color: var(--outline); margin-bottom: 16px; }
.download-btn { display: inline-block; padding: 10px 28px; border: 2px solid var(--outline); background: transparent; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; cursor: pointer; transition: all 0.3s; color: var(--on-surface); text-decoration: none; }
.download-btn:hover { background: var(--primary-container); color: var(--on-primary-container); border-color: var(--primary-container); }

/* ─── CONTACT FORM ─── */
.contact-section { padding: 80px var(--margin-desktop); background: var(--surface-container-low); border-top: 4px solid var(--primary-container); direction: rtl; }
.contact-inner { max-width: var(--container-max); margin: 0 auto; }
.contact-section h2 { font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic; font-size: 48px; line-height: 48px; color: var(--on-surface); text-align: center; margin-bottom: 48px; }
.contact-form { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.form-group-title { font-family: 'Anton', sans-serif; font-weight: 400; font-size: 24px; line-height: 28px; color: var(--primary-container); margin-bottom: 24px; padding-bottom: 12px; border-bottom: 2px solid var(--outline-variant); }
.form-field { margin-bottom: 20px; }
.form-field label { display: block; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--secondary); margin-bottom: 8px; }
.form-field input, .form-field textarea { width: 100%; padding: 12px 16px; background: var(--surface-container); border: none; border-bottom: 2px solid var(--outline-variant); color: var(--on-surface); font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; line-height: 24px; direction: rtl; transition: border-color 0.3s, box-shadow 0.3s; outline: none; }
.form-field input:focus, .form-field textarea:focus { border-bottom-color: var(--primary-container); box-shadow: 0 2px 0 0 var(--primary-container); }
.form-field input::placeholder, .form-field textarea::placeholder { color: var(--outline); }
.form-field textarea { min-height: 100px; resize: vertical; }

/* Multi-select */
.multiselect-wrapper { position: relative; }
.multiselect-trigger { width: 100%; padding: 12px 16px; background: var(--surface-container); border: none; border-bottom: 2px solid var(--outline-variant); color: var(--outline); font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; line-height: 24px; direction: rtl; cursor: pointer; display: flex; align-items: center; justify-content: space-between; transition: border-color 0.3s; }
.multiselect-trigger.has-selection { color: var(--on-surface); }
.multiselect-trigger:hover, .multiselect-trigger.open { border-bottom-color: var(--primary-container); }
.multiselect-trigger .arrow { font-size: 10px; transition: transform 0.3s; color: var(--outline); }
.multiselect-trigger.open .arrow { transform: rotate(180deg); }
.multiselect-dropdown { display: none; position: absolute; top: 100%; right: 0; left: 0; z-index: 20; max-height: 280px; overflow-y: auto; background: var(--surface-container-high); border: 1px solid var(--outline-variant); border-top: none; }
.multiselect-dropdown.open { display: block; }
.multiselect-dropdown label { display: flex; align-items: center; gap: 10px; padding: 10px 16px; cursor: pointer; font-family: 'JetBrains Mono', monospace; font-size: 13px; font-weight: 500; color: var(--on-surface-variant); transition: background 0.15s; direction: rtl; letter-spacing: 0; text-transform: none; margin-bottom: 0; }
.multiselect-dropdown label:hover { background: var(--surface-container-highest); }
.multiselect-dropdown input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--primary-container); cursor: pointer; flex-shrink: 0; }
.selected-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.selected-tag { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; background: var(--surface-container-highest); border: 1px solid var(--outline-variant); font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 700; color: var(--on-surface); }
.selected-tag .remove-tag { cursor: pointer; color: var(--primary-container); font-size: 14px; line-height: 1; }
.selected-tag .remove-tag:hover { color: var(--primary); }

.submit-btn { display: block; width: 100%; padding: 16px 40px; margin-top: 12px; background: var(--primary-container); color: var(--on-primary-container); border: none; cursor: pointer; font-family: 'Anton', sans-serif; font-weight: 400; font-style: italic; font-size: 24px; line-height: 28px; text-transform: uppercase; letter-spacing: 0.02em; transition: background 0.3s; }
.submit-btn:hover { background: var(--secondary-container); }

.form-notice { display: none; text-align: center; padding: 16px; margin-top: 16px; font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; line-height: 24px; }
.form-notice.success { display: block; border: 1px solid rgba(76,175,80,0.4); color: #66bb6a; background: rgba(76,175,80,0.1); }
.form-notice.error { display: block; border: 1px solid rgba(227,24,55,0.4); color: var(--primary); background: rgba(227,24,55,0.1); }

/* ─── FOOTER ─── */
footer { border-top: 4px solid var(--outline); padding: 50px var(--margin-desktop) 30px; background: var(--surface-container-lowest); }
.footer-inner { max-width: var(--container-max); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; margin-bottom: 40px; }
.footer-logo { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.social-icons { display: flex; gap: 16px; }
.social-icons a { width: 44px; height: 44px; background: var(--surface-container-highest); border: 1px solid var(--outline-variant); display: flex; align-items: center; justify-content: center; transition: all 0.3s; text-decoration: none; }
.social-icons a:hover { background: var(--primary-container); border-color: var(--primary-container); }
.social-icons svg { width: 20px; height: 20px; fill: var(--on-surface); }
.footer-bottom { max-width: var(--container-max); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; padding-top: 20px; border-top: 1px solid var(--outline-variant); }
.footer-bottom p { font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 700; letter-spacing: 0.1em; color: var(--outline); text-transform: uppercase; }
.footer-links { display: flex; gap: 24px; }
.footer-links a { font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700; letter-spacing: 0.1em; color: var(--on-surface-variant); text-decoration: none; text-transform: uppercase; transition: color 0.3s; }
.footer-links a:hover { color: var(--primary); }

/* ─── ANIMATIONS ─── */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  .features { flex-direction: column; padding: 60px var(--margin-mobile); }
  .tire-render { width: 280px; height: 230px; }
  .gallery-grid { grid-template-columns: 1fr; }
  .radar-grid { grid-template-columns: 1fr; }
  .hdna-section { flex-direction: column; padding: 60px var(--margin-mobile); }
  .hdna-image { flex: none; width: 100%; height: 300px; }
  .resources-grid { grid-template-columns: 1fr; }
  .resource-card { flex-direction: column; }
  .resource-img { flex: none; width: 100%; height: 200px; }
  .footer-inner { flex-direction: column; gap: 24px; }
  .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }
  .contact-form { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 600px) {
  header { padding: 16px var(--margin-mobile); }
  .hero { padding: 60px var(--margin-mobile); clip-path: polygon(0 0, 100% 0, 100% 92%, 0% 100%); }
  .hero h1 { font-size: 36px; line-height: 36px; }
  .gallery-header h2 { font-size: 36px; line-height: 36px; }
  .callout-grid { grid-template-columns: 1fr; }
  .about-content { padding: 40px var(--margin-mobile); }
}

/* ─── Elementor Pro contact form (RTL) ─── */
.tap-rtl-form, .tap-rtl-form .elementor-form, .tap-rtl-form .elementor-field-group { direction: rtl; text-align: right; }
.tap-rtl-form .elementor-field { direction: rtl; }
.tap-rtl-form .elementor-button { font-family: 'Anton', sans-serif; font-style: italic; text-transform: uppercase; }

/* ─── Elementor Pro form — match the dark Velocity design ─── */
.tap-rtl-form .elementor-field-group > label,
.tap-rtl-form .elementor-field-label {
  font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--secondary); margin-bottom: 8px;
}
.tap-rtl-form .elementor-field-group .elementor-field-required-indicator { color: var(--primary-container); }
.tap-rtl-form .elementor-field.elementor-field-textual,
.tap-rtl-form .elementor-field-textual,
.tap-rtl-form select.elementor-field,
.tap-rtl-form textarea.elementor-field {
  background: var(--surface-container) !important;
  color: var(--on-surface) !important;
  border: none !important;
  border-bottom: 2px solid var(--outline-variant) !important;
  border-radius: 0 !important;
  font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; padding: 12px 16px;
  box-shadow: none !important; direction: rtl;
}
.tap-rtl-form .elementor-field.elementor-field-textual:focus,
.tap-rtl-form select.elementor-field:focus,
.tap-rtl-form textarea.elementor-field:focus {
  border-bottom-color: var(--primary-container) !important;
  box-shadow: 0 2px 0 0 var(--primary-container) !important; outline: none;
}
.tap-rtl-form .elementor-field::placeholder,
.tap-rtl-form textarea.elementor-field::placeholder { color: var(--outline); }
.tap-rtl-form select.elementor-field option { background: var(--surface-container); color: var(--on-surface); }
.tap-rtl-form select[multiple].elementor-field { min-height: 140px; }
.tap-rtl-form select[multiple].elementor-field option:checked {
  background: var(--primary-container) linear-gradient(0deg, var(--primary-container), var(--primary-container));
  color: #fff;
}
.tap-rtl-form .elementor-button {
  background: var(--primary-container) !important; color: var(--on-primary-container) !important;
  font-family: 'Anton', sans-serif !important; font-style: italic; font-size: 22px;
  text-transform: uppercase; border-radius: 0 !important; padding: 16px 40px;
}
.tap-rtl-form .elementor-button:hover { background: var(--secondary-container) !important; }
.tap-rtl-form .elementor-field-group { margin-bottom: 6px; }
.tap-rtl-form .elementor-field-subgroup { max-height:300px; overflow-y:auto; border:1px solid var(--outline-variant); background:var(--surface-container); padding:4px 16px; direction:rtl; }
.tap-rtl-form .elementor-field-subgroup .elementor-field-option { display:flex; align-items:center; gap:14px; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.06); }
.tap-rtl-form .elementor-field-subgroup label { font-size:19px !important; color:var(--on-surface); cursor:pointer; }
.tap-rtl-form .elementor-field-subgroup input[type=checkbox] { width:24px; height:24px; accent-color:var(--primary-container); flex:none; cursor:pointer; }

/* ─── Header: burger color ─── */
.tap-eheader .elementor-menu-toggle svg,
.tap-eheader .elementor-menu-toggle i { fill: #ffffff !important; color: #ffffff !important; }

/* ─── Velocity 01 CTA — Global Button (.tap-cta-btn) + Header fallback ─── */
@keyframes tap-sheen {
  0%        { transform: translateX(-160%) skewX(-20deg); }
  55%, 100% { transform: translateX(260%)  skewX(-20deg); }
}

.tap-cta-btn .elementor-button,
.tap-cta-btn .elementor-button.elementor-size-sm,
.tap-cta-btn .elementor-button.elementor-size-md,
.tap-cta-btn .elementor-button.elementor-size-lg,
.tap-eheader .elementor-button,
.tap-eheader .elementor-button.elementor-size-sm,
.tap-eheader .elementor-button.elementor-size-md,
.tap-eheader .elementor-button.elementor-size-lg {
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  gap: 11px !important;
  padding: 20px 40px !important;
  width: 100% !important;
  max-width: 450px !important;
  margin: 0 auto !important;
  height: 65px !important;
  justify-content: center !important;
  border: none !important;
  border-radius: 11px !important;
  background: linear-gradient(135deg, #8B3FD4 0%, #6A1FB0 100%) !important;
  color: #ffffff !important;
  font-family: 'Heebo', sans-serif !important;
  font-weight: 800 !important;
  font-size: 19px !important;
  letter-spacing: 0 !important;
  cursor: pointer !important;
  box-shadow: 0 8px 26px -8px rgba(124,47,201,.7), inset 0 1px 0 rgba(255,255,255,.28) !important;
  transition: transform .18s ease, box-shadow .18s ease !important;
  text-decoration: none !important;
}
.tap-cta-btn .elementor-button::before,
.tap-eheader .elementor-button::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; bottom: 0 !important;
  width: 55% !important;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.45), transparent) !important;
  animation: tap-sheen 3.6s ease-in-out infinite !important;
  pointer-events: none !important;
}
.tap-cta-btn .elementor-button::after,
.tap-eheader .elementor-button::after {
  content: '❮' !important;
  font-size: 14px !important;
  line-height: 1 !important;
  opacity: .85 !important;
  position: relative !important;
}
.tap-cta-btn .elementor-button:hover,
.tap-eheader .elementor-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 16px 42px -8px rgba(157,78,221,.95), inset 0 1px 0 rgba(255,255,255,.35) !important;
  background: linear-gradient(135deg, #9B4FE4 0%, #7A2FC0 100%) !important;
}
@media (prefers-reduced-motion: reduce) {
  .tap-cta-btn .elementor-button::before,
  .tap-eheader .elementor-button::before { animation: none !important; }
  .tap-cta-btn .elementor-button:hover,
  .tap-eheader .elementor-button:hover   { transform: none !important; }
}
@media (max-width: 1200px) {
  .tap-cta-btn .elementor-button,
  .tap-cta-btn .elementor-button.elementor-size-sm,
  .tap-cta-btn .elementor-button.elementor-size-md,
  .tap-cta-btn .elementor-button.elementor-size-lg,
  .tap-eheader .elementor-button,
  .tap-eheader .elementor-button.elementor-size-sm,
  .tap-eheader .elementor-button.elementor-size-md,
  .tap-eheader .elementor-button.elementor-size-lg {
    padding: 16px 80px !important;
    font-size: 17px !important;
  }
}
@media (max-width: 768px) {
  .tap-cta-btn .elementor-button,
  .tap-cta-btn .elementor-button.elementor-size-sm,
  .tap-cta-btn .elementor-button.elementor-size-md,
  .tap-cta-btn .elementor-button.elementor-size-lg,
  .tap-eheader .elementor-button,
  .tap-eheader .elementor-button.elementor-size-sm,
  .tap-eheader .elementor-button.elementor-size-md,
  .tap-eheader .elementor-button.elementor-size-lg {
    padding: 12px 32px !important;
    font-size: 15px !important;
  }
}
