/* RESET & BASE */
* { margin:0; padding:0; box-sizing:border-box; }

:root {
  --bg:#000;
  --fg:#fff;
  --fg-muted:#b3b3b3;
  --border:#222;
  --max-width:1000px;
  --font-main:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --hornet-yellow:#ffd632;
  --link-grey:#9a9a9a;
  --pill-upcoming:#444;
  --pill-current:#00d18a;
  --pill-done:#555;
}

body {
  background:var(--bg);
  color:var(--fg);
  font-family:var(--font-main);
  -webkit-font-smoothing:antialiased;
}

a {
  color:var(--link-grey);
  text-decoration:none;
  transition:color .2s ease,opacity .2s ease;
}
a:hover { color:var(--fg); opacity:1; }

img { max-width:100%; display:block; }

/* LAYOUT */
.page {
  min-height:100vh;
  display:flex;
  flex-direction:column;
  padding:24px 16px;
}

.frame {
  max-width:var(--max-width);
  width:100%;
  margin:0 auto;
  border:1px solid var(--border);
  border-radius:24px;
  padding:24px 18px 28px;
  display:flex;
  flex-direction:column;
  gap:28px;
}

@media (min-width:768px){
  .page { padding:32px; }
  .frame { padding:36px 34px 40px; gap:36px; }
}

/* HEADER */
.top-row {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
}

.logo {
  display:flex;
  align-items:center;
}

.logo img {
  height:40px;   /* adjust 32–48px to taste */
  width:auto;
  display:block;
}

.lang-switch {
  display:inline-flex;
  border-radius:999px;
  border:1px solid #333;
  overflow:hidden;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.16em;
}
.lang-btn {
  border:none;
  background:transparent;
  color:var(--fg-muted);
  padding:6px 14px;
  cursor:pointer;
  transition:background .2s ease,color .2s ease;
}
.lang-btn.active {
  background:#fff;
  color:#000;
}

/* HERO */
.hero {
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
  gap:24px;
  align-items:flex-start;
  border-top:1px solid var(--border);
  padding-top:24px;
}
@media (max-width:768px){
  .hero { grid-template-columns:1fr; }
}

.headline {
  color: #fff;
  font-size:clamp(30px,4vw,40px);
  line-height:1.05;
  font-weight:500;
  margin-bottom: 1.5rem;
}
.tagline {
  margin-top:14px;
  color:var(--fg-muted);
  font-size:14px;
  max-width:480px;
}
.hero-meta {
  margin-top:18px;
  font-size:12px;
  color:var(--fg-muted);
  display:flex;
  flex-direction:column;
  gap:6px;
}

/* IMAGES – B/W → COLOR */
.hero-image,
.section-image {
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--border);
  max-width:420px;
  justify-self:end;
}

.section-image--car {
  display:flex;
  flex-direction:column;
  gap:10px;
  max-width:420px;
  justify-self:end;
}

.section-image--car .car-img {
  aspect-ratio:21/9;   /* narrower, more cinematic look */
}

/* Mobile: still full width */
@media (max-width:768px){
  .section-image--car {
    max-width:100%;
    justify-self:start;
  }
}

/* Normal images (hero, sections, cards) */
.hero-image img,
.section-image img,
.card-img img {
  width:100%;
  aspect-ratio:3/2;
  object-fit:cover;
  filter:grayscale(100%);
  transition:filter .35s ease,transform .35s ease;
}

.hero-image img:hover,
.section-image img:hover,
.card-img img:hover {
  filter:grayscale(0%);
  transform:scale(1.02);
}

/* Map – square, full color, no animation */
.hornet-map img {
  width:100%;
  aspect-ratio:1/1;      /* square */
  object-fit:cover;
  filter:none;
  transform:none;
}
.hornet-map img:hover {
  filter:none;
  transform:none;
}

@media (max-width:768px){
  .hero-image,
  .section-image {
    max-width:100%;
    justify-self:start;
  }
}

/* SECTIONS */
.section-block {
  border-top:1px solid var(--border);
  padding-top:24px;
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
  gap:24px;
  align-items:flex-start;   /* text + image at top */
}
.section-block.reverse {
  grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);
  align-items:flex-start;
}
@media (max-width:768px){
  .section-block,
  .section-block.reverse {
    grid-template-columns:1fr;
  }
}

.section-text {
  font-size:14px;
  line-height:1.6;
  color:var(--fg-muted);
}
.section-title {
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--fg);
  margin-bottom:10px;
}
.section-text p + p { margin-top:10px; }

/* DRIVERS */
.drivers-block { grid-template-columns:1fr; }
.drivers-block .drivers-text { grid-column:1 / -1; }

.team-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
  gap:16px;
  margin-top:12px;
}
.card {
  border-radius:18px;
  border:1px solid var(--border);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:8px;
  background:#050505;
}
.card-img {
  border-radius:14px;
  overflow:hidden;
}
.card-title {
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.16em;
}
.card-subtitle {
  font-size:11px;
  color:var(--fg-muted);
  text-transform:uppercase;
  letter-spacing:.16em;
}
.card-body {
  font-size:13px;
  color:var(--fg-muted);
}
.specs-list {
  margin-top: 10px;
  padding-left: 0;
}

.specs-category {
  font-weight: 600;
  margin-top: 12px;
  list-style: none;
  color: var(--fg);
}

.specs-sublist {
  padding-left: 18px;
  margin-top: 4px;
  margin-bottom: 6px;
  color: var(--fg-muted);
  font-size: 14px;
  line-height: 1.6;
}

/* HORNET BLOCK */
.hornet-block {
  border-top:1px solid var(--border);
  padding-top:24px;
}

.hornet-inner {
  border-radius:20px;
  background:var(--hornet-yellow);
  color:#000;
  padding:18px 18px 20px;
  display:grid;
  grid-template-columns: 1fr auto; /* text expands, map stays its width */
  gap:20px;
  align-items:flex-start;
}

.hornet-title {
  all: unset;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:10px;
  font-weight:500;
  color:#000;
  font-family:var(--font-main);
  display:block;
}

.hornet-text p {
  font-size:14px;
  line-height:1.6;
  color:#1e1e1e;
}
.hornet-text p + p { margin-top:8px; }

.hornet-actions {
  margin-top:12px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}

.btn-eshop {
  border-radius:999px;
  border:1px solid #000;
  background:#000;
  color:#fff;
  padding:8px 18px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.16em;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.btn-eshop:hover { opacity:.9; }

.hornet-note {
  font-size:12px;
  color:#333;
}

/* right column container */
.hornet-media {
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-end;  /* keep map on the right on desktop */
}

/* hide logo completely */
.hornet-logo { display:none; }

/* Map container – desktop: smaller; mobile: full width */
.hornet-map {
  max-width:220px;       /* desktop size */
  width:100%;
  border-radius:14px;
  overflow:hidden;
  border:none;
}

/* MOBILE: stack and make map full width */
@media (max-width:768px){
  .hornet-inner {
    grid-template-columns:1fr;   /* text above, media (map) below */
  }

  .hornet-media {
    align-items:stretch;         /* full width */
  }

  .hornet-map {
    max-width:100%;              /* full width like other images */
    border-radius:18px;
  }
}

/* SERVICES */
.services-block {
  grid-template-columns:0.8fr 1.2fr;
  align-items:flex-start;
}
@media (max-width:768px){
  .services-block { grid-template-columns:1fr; }
}
.services-columns {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:4px;
}
@media (max-width:768px){
  .services-columns { grid-template-columns:1fr; }
}
.service-col-title {
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--fg);
  margin-bottom:8px;
}
.services-list {
  list-style: circle;
  padding-left: 18px;
  font-size: 13px;
  color: var(--fg-muted);
  display: flex;
  flex-direction: column;
  gap: 6px;
  line-height: 1.5;
}
.services-cta {
  margin-top:16px;
  font-size:13px;
  color:var(--fg-muted);
}

/* CALENDAR */
.calendar-block {
  grid-template-columns:1fr 1fr;
  align-items:flex-start;
}
@media (max-width:768px){
  .calendar-block { grid-template-columns:1fr; }
}
.events-column-title {
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.2em;
  color:var(--fg-muted);
  margin-bottom:8px;
}
.events-list {
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
  font-size:13px;
  color:var(--fg-muted);
}
.event-item {
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:6px 0;
  border-bottom:1px solid #151515;
}
.event-main {
  display:flex;
  flex-direction:column;
  gap:2px;
}
.event-name { color:var(--fg); }
.event-meta {
  font-size:11px;
  color:#8a8a8a;
}
.event-pill {
  font-size:11px;
  padding:4px 10px;
  border-radius:999px;
  align-self:flex-start;
  text-transform:uppercase;
  letter-spacing:.12em;
  white-space:nowrap;
}
.event-pill.upcoming {
  background:var(--pill-upcoming);
  color:#fff;
}
.event-pill.current {
  background:var(--pill-current);
  color:#000;
}
.event-pill.done {
  background:var(--pill-done);
  color:#fff;
}

/* CONTACT */
.contact-list {
  list-style: circle;
  padding-left: 18px;
  font-size: 13px;
  color: var(--fg-muted);
  display: flex;
  flex-direction: column;
  gap: 6px;
  line-height: 1.5;
}

.contact-video {
  max-width: 420px;           /* matches hero image */
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border);
}

.contact-video iframe {
  width: 100%;
  aspect-ratio: 16 / 9;       /* clean widescreen */
  display: block;
}


/* FOOTER */
.footer {
  border-top:1px solid var(--border);
  padding-top:12px;
  margin-top:4px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  font-size:11px;
  color:var(--fg-muted);
  flex-wrap:wrap;
}
.footer-links {
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.footer a { opacity:.7; }
.footer a:hover { opacity:1; }
