/* ============================================
   DAILY CAR RENTALS GR — MAIN STYLESHEET
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&display=swap');

:root {
  --black: #0a0a0a;
  --white: #ffffff;
  --red: #e81c2e;
  --red-dark: #b5101f;
  --red-light: #ff3347;
  --gray-100: #f5f5f5;
  --gray-200: #e8e8e8;
  --gray-400: #999999;
  --gray-600: #555555;
  --gray-800: #222222;

  --font-display: 'Outfit', sans-serif;
  --font-body: 'DM Sans', sans-serif;

  --nav-height: 80px;
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background: var(--white); color: var(--black); overflow-x: hidden; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* CURSOR */
.cursor { width: 10px; height: 10px; background: var(--red); border-radius: 50%; position: fixed; top: 0; left: 0; pointer-events: none; z-index: 99999; transform: translate(-50%,-50%); transition: width .2s, height .2s; mix-blend-mode: multiply; }
.cursor-ring { width: 38px; height: 38px; border: 1.5px solid rgba(232,28,46,0.5); border-radius: 50%; position: fixed; top: 0; left: 0; pointer-events: none; z-index: 99998; transform: translate(-50%,-50%); transition: all .1s var(--ease); }
body:hover .cursor { opacity: 1; }

/* LOADER */
#loader { position: fixed; inset: 0; background: var(--black); z-index: 99997; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 20px; transition: opacity .7s var(--ease), visibility .7s; }
#loader.gone { opacity: 0; visibility: hidden; pointer-events: none; }
.loader-brand { font-family: var(--font-display); font-size: 2rem; font-weight: 900; color: #fff; letter-spacing: -1px; }
.loader-brand span { color: var(--red); }
.loader-track { width: 180px; height: 2px; background: rgba(255,255,255,.08); border-radius: 2px; overflow: hidden; }
.loader-fill { height: 100%; background: var(--red); width: 0; animation: lf 1.8s var(--ease-out) forwards; }
@keyframes lf { to { width: 100%; } }

/* NAVBAR */
#nav { position: fixed; top: 0; left: 0; right: 0; width: 100%; height: var(--nav-height); z-index: 1000; transition: background .4s, box-shadow .4s, height .3s; overflow: hidden; }
#nav.solid { background: rgba(10,10,10,.97); backdrop-filter: blur(20px); box-shadow: 0 2px 40px rgba(0,0,0,.3); height: 68px; }
.nav-in { width: 100%; max-width: 100%; margin: 0; padding: 0 32px; display: flex; align-items: center; justify-content: space-between; height: 100%; gap: 16px; }
.nav-logo { font-family: var(--font-display); font-size: 1.4rem; font-weight: 900; color: #fff; letter-spacing: -.5px; flex-shrink: 0; }
.nav-logo span { color: var(--red); }
.nav-logo small { display: block; font-size: .5rem; font-weight: 400; letter-spacing: 3px; color: rgba(255,255,255,.3); text-transform: uppercase; margin-top: -3px; }
.nav-links { display: flex; align-items: center; gap: 2px; flex-shrink: 0; }
.nav-links a { font-family: var(--font-display); font-size: .8rem; font-weight: 500; color: rgba(255,255,255,.65); padding: 8px 12px; border-radius: 6px; transition: color .2s, background .2s; position: relative; white-space: nowrap; }
.nav-links a::after { content: ''; position: absolute; bottom: 2px; left: 12px; right: 12px; height: 1.5px; background: var(--red); transform: scaleX(0); transition: transform .3s var(--ease); }
.nav-links a:hover, .nav-links a.on { color: #fff; }
.nav-links a:hover::after, .nav-links a.on::after { transform: scaleX(1); }
.nav-cta { background: var(--red) !important; color: #fff !important; padding: 10px 18px !important; border-radius: 8px !important; font-weight: 700 !important; transition: all .25s !important; white-space: nowrap !important; flex-shrink: 0 !important; }
.nav-cta:hover { background: var(--red-light) !important; transform: translateY(-1px); }
.nav-cta::after { display: none !important; }
.hamburger { display: none; flex-direction: column; gap: 5px; padding: 8px; }
.hamburger span { display: block; width: 24px; height: 2px; background: #fff; border-radius: 2px; transition: transform .3s, opacity .3s; }
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.mob-nav { position: fixed; top: var(--nav-height); left: 0; right: 0; background: rgba(10,10,10,.98); backdrop-filter: blur(20px); padding: 24px 40px 48px; transform: translateY(-120%); opacity: 0; transition: transform .5s var(--ease-out), opacity .5s; z-index: 999; pointer-events: none; }
.mob-nav.open { transform: translateY(0); opacity: 1; pointer-events: all; }
.mob-nav a { display: block; font-family: var(--font-display); font-size: 1.6rem; font-weight: 700; color: rgba(255,255,255,.6); padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,.07); transition: color .2s; }
.mob-nav a:hover { color: var(--red); }
.mob-nav .mob-cta { display: inline-flex !important; margin-top: 28px; background: var(--red); color: #fff !important; padding: 16px 36px !important; border-radius: 10px; font-size: 1rem !important; border-bottom: none !important; }

/* BUTTONS */
.btn-r { display: inline-flex; align-items: center; gap: 10px; background: var(--red); color: #fff; font-family: var(--font-display); font-size: .95rem; font-weight: 700; padding: 16px 32px; border-radius: 10px; transition: all .3s; position: relative; overflow: hidden; }
.btn-r:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(232,28,46,.4); background: var(--red-light); }
.btn-outline { display: inline-flex; align-items: center; gap: 10px; background: transparent; color: #fff; font-family: var(--font-display); font-size: .95rem; font-weight: 600; padding: 15px 28px; border-radius: 10px; border: 1.5px solid rgba(255,255,255,.18); transition: all .3s; }
.btn-outline:hover { border-color: rgba(255,255,255,.5); background: rgba(255,255,255,.05); transform: translateY(-2px); }
.btn-dark { display: inline-flex; align-items: center; gap: 10px; background: var(--black); color: #fff; font-family: var(--font-display); font-size: .9rem; font-weight: 700; padding: 12px 24px; border-radius: 8px; transition: all .25s; }
.btn-dark:hover { background: var(--red); transform: translateY(-1px); }
.btn-white { display: inline-flex; align-items: center; gap: 10px; background: #fff; color: var(--red); font-family: var(--font-display); font-size: .95rem; font-weight: 700; padding: 16px 32px; border-radius: 10px; transition: all .3s; }
.btn-white:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,.15); }

/* SECTION COMMONS */
.section { padding: 100px 0; }
.wrap { max-width: 1400px; margin: 0 auto; padding: 0 40px; }
.s-tag { font-family: var(--font-display); font-size: .7rem; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); margin-bottom: 12px; display: flex; align-items: center; gap: 10px; }
.s-tag::before { content: ''; width: 28px; height: 2px; background: var(--red); flex-shrink: 0; }
.s-title { font-family: var(--font-display); font-size: clamp(2rem,3.5vw,3.2rem); font-weight: 800; color: var(--black); letter-spacing: -1.5px; line-height: 1.1; }
.s-title span { color: var(--red); }
.s-title.w { color: #fff; }
.s-sub { font-size: 1rem; color: var(--gray-600); line-height: 1.7; max-width: 520px; margin-top: 14px; }
.s-sub.w { color: rgba(255,255,255,.45); }

/* REVEAL */
.rv { opacity: 0; transform: translateY(36px); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.rv.in { opacity: 1; transform: none; }
.rv.d1 { transition-delay: .1s; } .rv.d2 { transition-delay: .2s; } .rv.d3 { transition-delay: .3s; } .rv.d4 { transition-delay: .4s; }

/* =========== HERO =========== */
.hero { min-height: 100vh; background: var(--black); display: flex; align-items: center; position: relative; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: radial-gradient(ellipse 80% 60% at 70% 50%, rgba(232,28,46,.13) 0%, transparent 60%), radial-gradient(ellipse 40% 40% at 15% 80%, rgba(232,28,46,.07) 0%, transparent 55%); }
.hero-grid-bg { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: 80px 80px; mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%); }
.hero-wrap { position: relative; z-index: 2; max-width: 1400px; width: 100%; margin: 0 auto; padding: 140px 40px 80px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(232,28,46,.1); border: 1px solid rgba(232,28,46,.28); border-radius: 100px; padding: 6px 16px; margin-bottom: 26px; opacity: 0; animation: fu .8s 1.8s var(--ease-out) forwards; }
.badge-dot { width: 6px; height: 6px; background: var(--red); border-radius: 50%; animation: pd 2s infinite; }
@keyframes pd { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.5)} }
.hero-badge-txt { font-family: var(--font-display); font-size: .72rem; font-weight: 700; color: var(--red); letter-spacing: 2px; text-transform: uppercase; }
.hero-h1 { font-family: var(--font-display); font-size: clamp(3rem,5vw,5.5rem); font-weight: 900; color: #fff; line-height: 1; letter-spacing: -2px; margin-bottom: 22px; opacity: 0; animation: fu .9s 2s var(--ease-out) forwards; }
.hero-h1 em { font-style: normal; color: var(--red); }
.hero-h1 .sub-line { display: block; font-size: .42em; font-weight: 300; color: rgba(255,255,255,.35); letter-spacing: 4px; text-transform: uppercase; margin-bottom: 8px; }
.hero-p { font-size: 1rem; color: rgba(255,255,255,.5); line-height: 1.75; margin-bottom: 36px; max-width: 460px; opacity: 0; animation: fu .9s 2.15s var(--ease-out) forwards; }
.hero-btns { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; opacity: 0; animation: fu .9s 2.3s var(--ease-out) forwards; }
.hero-stats { display: flex; gap: 36px; margin-top: 52px; padding-top: 36px; border-top: 1px solid rgba(255,255,255,.07); opacity: 0; animation: fu .9s 2.5s var(--ease-out) forwards; }
.hs-val { font-family: var(--font-display); font-size: 2rem; font-weight: 800; color: #fff; line-height: 1; }
.hs-val span { color: var(--red); }
.hs-lbl { font-size: .72rem; color: rgba(255,255,255,.35); text-transform: uppercase; letter-spacing: 1.5px; margin-top: 4px; }

/* Hero Visual */
.hero-vis { opacity: 0; animation: fi 1.2s 1.9s var(--ease-out) forwards; position: relative; }
.hero-card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 24px; padding: 36px; position: relative; overflow: visible; }
.hero-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(232,28,46,.5), transparent); }
.car-img-box { width: 100%; aspect-ratio: 16/9; background: linear-gradient(135deg, rgba(232,28,46,.08), rgba(255,255,255,.02)); border-radius: 14px; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; position: relative; }
.price-pill { position: absolute; top: 12px; right: 12px; background: var(--red); color: #fff; font-family: var(--font-display); font-weight: 800; font-size: 1.05rem; padding: 8px 14px; border-radius: 8px; text-align: center; }
.price-pill small { display: block; font-size: .6rem; font-weight: 400; opacity: .8; }
.feat-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.feat-item { background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); border-radius: 10px; padding: 12px; text-align: center; }
.feat-ico { font-size: 1.3rem; margin-bottom: 5px; }
.feat-txt { font-size: .68rem; color: rgba(255,255,255,.45); font-weight: 500; line-height: 1.3; }
.fl-tag { position: absolute; background: rgba(10,10,10,.92); border: 1px solid rgba(255,255,255,.1); border-radius: 10px; padding: 10px 14px; backdrop-filter: blur(12px); display: flex; align-items: center; gap: 8px; }
.fl-tag:first-of-type { top: -20px; left: 20px; animation: fl 4s ease-in-out infinite; }
.fl-tag:last-of-type { top: -20px; right: 20px; animation: fl 4s 2s ease-in-out infinite; }
@keyframes fl { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
.fl-ico { font-size: 1.1rem; }
.fl-txt { font-family: var(--font-display); font-size: .78rem; font-weight: 600; color: #fff; }
.fl-sub { font-size: .65rem; color: rgba(255,255,255,.4); }
.scroll-hint { position: absolute; bottom: 36px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 6px; color: rgba(255,255,255,.25); font-size: .65rem; letter-spacing: 2px; text-transform: uppercase; font-family: var(--font-display); animation: fi 1s 3s both; }
.scroll-line { width: 1px; height: 44px; background: linear-gradient(to bottom, rgba(232,28,46,.6), transparent); animation: sl 2s ease-in-out infinite; }
@keyframes sl { 0%{transform:scaleY(0);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* =========== WHY US =========== */
.why { background: #f5f5f5; }
.why-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 56px; }
.why-c { background: #fff; border-radius: 20px; padding: 36px 28px; position: relative; overflow: hidden; transition: transform .4s var(--ease-out), box-shadow .4s; border: 1px solid transparent; }
.why-c::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: var(--red); transform: scaleX(0); transition: transform .4s var(--ease); }
.why-c:hover { transform: translateY(-8px); box-shadow: 0 24px 60px rgba(0,0,0,.1); }
.why-c:hover::after { transform: scaleX(1); }
.why-num { font-family: var(--font-display); font-size: 4rem; font-weight: 900; color: rgba(0,0,0,.04); position: absolute; top: 16px; right: 20px; line-height: 1; }
.why-icon { width: 54px; height: 54px; background: rgba(232,28,46,.08); border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; margin-bottom: 22px; }
.why-c h3 { font-family: var(--font-display); font-size: 1.15rem; font-weight: 700; margin-bottom: 10px; }
.why-c p { font-size: .88rem; color: var(--gray-600); line-height: 1.7; }

/* =========== BOOKING STRIP =========== */
.booking { background: var(--black); padding: 70px 0; }
.book-form { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 14px; align-items: end; margin-top: 40px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 20px; padding: 28px; }
.fg label { display: block; font-family: var(--font-display); font-size: .68rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.38); margin-bottom: 8px; }
.fg input, .fg select { width: 100%; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 10px; padding: 13px 15px; color: #fff; font-family: var(--font-body); font-size: .88rem; outline: none; transition: border-color .3s, background .3s; }
.fg input:focus, .fg select:focus { border-color: var(--red); background: rgba(255,255,255,.09); }
.fg select option { background: #111; }
.fg input::placeholder { color: rgba(255,255,255,.3); }
.book-btn { background: var(--red); color: #fff; font-family: var(--font-display); font-size: .92rem; font-weight: 700; padding: 13px 28px; border-radius: 10px; height: 48px; white-space: nowrap; transition: all .3s; display: flex; align-items: center; gap: 8px; }
.book-btn:hover { background: var(--red-light); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(232,28,46,.35); }

/* =========== FLEET CARDS =========== */
.fleet-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px,1fr)); gap: 26px; margin-top: 56px; }
.car-c { background: #fff; border-radius: 20px; overflow: hidden; border: 1px solid var(--gray-200); transition: transform .4s var(--ease-out), box-shadow .4s, border-color .4s; }
.car-c:hover { transform: translateY(-8px); box-shadow: 0 24px 60px rgba(0,0,0,.12); border-color: rgba(232,28,46,.25); }
.car-c-img { height: 190px; background: linear-gradient(135deg,#f0f0f0,#e4e4e4); display: flex; align-items: center; justify-content: center; position: relative; }
.car-cat { position: absolute; top: 12px; left: 12px; background: var(--red); color: #fff; font-family: var(--font-display); font-size: .65rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 4px 10px; border-radius: 4px; }
.car-c-body { padding: 22px; }
.car-name { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; color: var(--black); }
.car-type-lbl { font-size: .78rem; color: var(--gray-400); margin-bottom: 14px; }
.car-specs { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 18px; }
.spec-i { display: flex; align-items: center; gap: 5px; font-size: .78rem; color: var(--gray-600); }
.car-c-ft { display: flex; align-items: center; justify-content: space-between; padding-top: 14px; border-top: 1px solid var(--gray-200); }
.price-fr { font-size: .68rem; color: var(--gray-400); }
.price-big { font-family: var(--font-display); font-size: 1.4rem; font-weight: 800; color: var(--black); }
.price-big span { font-size: .72rem; font-weight: 400; color: var(--gray-400); }

/* =========== LOCATIONS =========== */
.loc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 56px; }
.loc-c { background: #fff; border-radius: 20px; padding: 32px 26px; border: 1px solid var(--gray-200); transition: transform .4s var(--ease-out), box-shadow .4s; position: relative; overflow: hidden; }
.loc-c::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--red); }
.loc-c:hover { transform: translateY(-6px); box-shadow: 0 20px 50px rgba(0,0,0,.1); }
.loc-ico { font-size: 2.2rem; margin-bottom: 14px; }
.loc-c h3 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; margin-bottom: 8px; }
.loc-c p { font-size: .85rem; color: var(--gray-600); line-height: 1.6; }

/* =========== REVIEWS =========== */
.reviews { background: var(--black); padding: 100px 0; overflow: hidden; }
.rv-track-wrap { overflow: hidden; margin-top: 56px; }
.rv-track { display: flex; gap: 22px; animation: scroll-rv 28s linear infinite; width: max-content; }
.rv-track:hover { animation-play-state: paused; }
@keyframes scroll-rv { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.rv-card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07); border-radius: 18px; padding: 26px; width: 340px; flex-shrink: 0; transition: border-color .3s; }
.rv-card:hover { border-color: rgba(232,28,46,.3); }
.rv-stars { color: #fbbf24; font-size: .95rem; margin-bottom: 14px; letter-spacing: 2px; }
.rv-text { font-size: .88rem; color: rgba(255,255,255,.6); line-height: 1.7; margin-bottom: 18px; font-style: italic; }
.rv-author { display: flex; align-items: center; gap: 10px; }
.rv-avatar { width: 38px; height: 38px; background: var(--red); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; color: #fff; font-size: .85rem; flex-shrink: 0; }
.rv-name { font-family: var(--font-display); font-weight: 600; color: #fff; font-size: .85rem; }
.rv-date { font-size: .7rem; color: rgba(255,255,255,.28); }

/* =========== CTA BANNER =========== */
.cta-band { background: var(--red); padding: 76px 0; position: relative; overflow: hidden; }
.cta-band::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.08), transparent 60%); }
.cta-in { display: flex; align-items: center; justify-content: space-between; gap: 40px; position: relative; }
.cta-title { font-family: var(--font-display); font-size: clamp(1.7rem,3vw,2.8rem); font-weight: 800; color: #fff; letter-spacing: -1px; line-height: 1.15; }
.cta-sub { font-size: .95rem; color: rgba(255,255,255,.68); margin-top: 8px; }
.cta-acts { display: flex; gap: 14px; align-items: center; flex-shrink: 0; }
.btn-wt { display: inline-flex; align-items: center; gap: 8px; background: #fff; color: var(--red); font-family: var(--font-display); font-size: .9rem; font-weight: 700; padding: 15px 28px; border-radius: 10px; transition: all .3s; }
.btn-wt:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,.2); }
.btn-wt-out { display: inline-flex; align-items: center; gap: 8px; background: transparent; color: #fff; font-family: var(--font-display); font-size: .9rem; font-weight: 600; padding: 14px 26px; border-radius: 10px; border: 2px solid rgba(255,255,255,.4); transition: all .3s; }
.btn-wt-out:hover { border-color: #fff; background: rgba(255,255,255,.12); transform: translateY(-2px); }

/* =========== FOOTER =========== */
footer { background: var(--black); padding: 80px 0 0; border-top: 1px solid rgba(255,255,255,.06); }
.ft-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.4fr; gap: 56px; padding-bottom: 60px; }
.ft-brand .nav-logo { font-size: 1.5rem; margin-bottom: 14px; }
.ft-desc { font-size: .85rem; color: rgba(255,255,255,.38); line-height: 1.7; margin-bottom: 22px; max-width: 270px; }
.ft-socials { display: flex; gap: 10px; }
.soc-btn { width: 38px; height: 38px; background: rgba(255,255,255,.06); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.4); font-size: .9rem; transition: background .2s, color .2s; }
.soc-btn:hover { background: var(--red); color: #fff; }
.ft-col h4 { font-family: var(--font-display); font-size: .68rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.28); margin-bottom: 18px; }
.ft-col a { display: block; font-size: .85rem; color: rgba(255,255,255,.5); padding: 4px 0; transition: color .2s, padding .2s; }
.ft-col a:hover { color: #fff; padding-left: 5px; }
.ft-ci { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 14px; }
.ft-ci-ico { color: var(--red); font-size: .95rem; flex-shrink: 0; margin-top: 2px; }
.ft-ci-txt { font-size: .82rem; color: rgba(255,255,255,.48); line-height: 1.5; }
.ft-ci-txt strong { color: rgba(255,255,255,.78); display: block; font-family: var(--font-display); margin-bottom: 2px; }
.ft-bot { border-top: 1px solid rgba(255,255,255,.06); padding: 22px 0; display: flex; align-items: center; justify-content: space-between; }
.ft-copy { font-size: .75rem; color: rgba(255,255,255,.22); }
.ft-rating { display: flex; align-items: center; gap: 6px; font-size: .75rem; color: rgba(255,255,255,.22); }
.ft-stars { color: #fbbf24; }

/* =========== PAGE HEADER =========== */
.pg-header { background: var(--black); padding: 160px 0 80px; position: relative; overflow: hidden; }
.pg-header-bg { position: absolute; inset: 0; background: radial-gradient(ellipse 60% 80% at 60% 50%, rgba(232,28,46,.1), transparent 60%); }
.pg-grid-bg { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px); background-size: 60px 60px; }
.pg-header-in { position: relative; z-index: 2; }
.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: .78rem; color: rgba(255,255,255,.3); margin-bottom: 22px; font-family: var(--font-display); }
.breadcrumb a:hover { color: var(--red); }
.breadcrumb-sep { opacity: .3; }
.pg-header h1 { font-family: var(--font-display); font-size: clamp(2.5rem,5vw,5rem); font-weight: 900; color: #fff; letter-spacing: -2px; line-height: 1; margin-bottom: 18px; }
.pg-header h1 span { color: var(--red); }
.pg-header p { font-size: 1rem; color: rgba(255,255,255,.48); max-width: 480px; line-height: 1.7; }

/* =========== CONTACT =========== */
.contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 60px; margin-top: 60px; }
.c-info-cards { display: flex; flex-direction: column; gap: 18px; }
.c-info-c { background: #fff; border: 1px solid var(--gray-200); border-radius: 16px; padding: 26px; display: flex; align-items: flex-start; gap: 18px; transition: transform .3s, box-shadow .3s; }
.c-info-c:hover { transform: translateX(6px); box-shadow: 0 8px 30px rgba(0,0,0,.08); }
.c-info-ico { width: 50px; height: 50px; background: rgba(232,28,46,.08); border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; }
.c-info-lbl { font-family: var(--font-display); font-size: .68rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gray-400); margin-bottom: 5px; }
.c-info-val { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--black); }
.c-info-sub { font-size: .8rem; color: var(--gray-600); margin-top: 3px; }
.c-form-wrap { background: #fff; border: 1px solid var(--gray-200); border-radius: 24px; padding: 44px; box-shadow: 0 4px 40px rgba(0,0,0,.06); }
.c-form-wrap h3 { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; margin-bottom: 28px; }
.c-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.c-form .fgl { margin-bottom: 18px; }
.c-form .fgl label { display: block; font-family: var(--font-display); font-size: .72rem; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--gray-600); margin-bottom: 7px; }
.c-form input, .c-form select, .c-form textarea { width: 100%; background: var(--gray-100); border: 2px solid transparent; border-radius: 10px; padding: 13px 15px; color: var(--black); font-family: var(--font-body); font-size: .9rem; outline: none; transition: border-color .3s, background .3s; }
.c-form input:focus, .c-form select:focus, .c-form textarea:focus { border-color: var(--red); background: #fff; }
.c-form textarea { resize: vertical; min-height: 110px; }
.c-submit { background: var(--red); color: #fff; font-family: var(--font-display); font-size: .95rem; font-weight: 700; padding: 16px; border-radius: 10px; width: 100%; margin-top: 8px; transition: all .3s; display: flex; align-items: center; justify-content: center; gap: 8px; }
.c-submit:hover { background: var(--red-dark); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(232,28,46,.3); }

/* =========== ABOUT =========== */
.about-story { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.about-vis { position: relative; }
.about-img { background: linear-gradient(135deg, #1a1a1a, #2a2a2a); border-radius: 24px; height: 420px; display: flex; align-items: center; justify-content: center; font-size: 6rem; position: relative; overflow: hidden; }
.about-img::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 60% 40%, rgba(232,28,46,.2), transparent 55%); }
.a-stat { position: absolute; background: #fff; border-radius: 14px; padding: 14px 20px; box-shadow: 0 10px 40px rgba(0,0,0,.14); display: flex; align-items: center; gap: 12px; }
.a-stat:nth-child(2) { bottom: -18px; left: -18px; }
.a-stat:nth-child(3) { top: 28px; right: -18px; }
.a-stat-num { font-family: var(--font-display); font-size: 1.7rem; font-weight: 800; color: var(--black); line-height: 1; }
.a-stat-num span { color: var(--red); }
.a-stat-lbl { font-size: .72rem; color: var(--gray-600); max-width: 75px; line-height: 1.3; }
.values-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 56px; }
.val-c { background: var(--gray-100); border-radius: 14px; padding: 24px 20px; border-left: 4px solid var(--red); }
.val-c h3 { font-family: var(--font-display); font-size: .95rem; font-weight: 700; margin-bottom: 7px; }
.val-c p { font-size: .83rem; color: var(--gray-600); line-height: 1.6; }

/* =========== KEYFRAMES =========== */
@keyframes fu { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:none} }
@keyframes fi { from{opacity:0} to{opacity:1} }

/* =========== RESPONSIVE =========== */
@media(max-width:1100px){
  .hero-wrap{grid-template-columns:1fr;gap:0}
  .hero-vis{display:none}
  .why-cards{grid-template-columns:1fr 1fr}
  .ft-grid{grid-template-columns:1fr 1fr;gap:36px}
  .about-story{grid-template-columns:1fr}
  .about-vis{display:none}
}
@media(max-width:900px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .book-form{grid-template-columns:1fr 1fr}
  .book-form .book-btn{grid-column:1/-1}
  .loc-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .cta-in{flex-direction:column;text-align:center}
  .cta-acts{justify-content:center}
}
@media(max-width:640px){
  :root{--nav-height:66px}
  .section{padding:70px 0}
  .wrap{padding:0 20px}
  .nav-in{padding:0 20px}
  .hero-wrap{padding:110px 20px 60px}
  .hero-stats{gap:22px}
  .why-cards,.values-grid{grid-template-columns:1fr}
  .book-form{grid-template-columns:1fr;padding:20px}
  .ft-grid{grid-template-columns:1fr}
  .ft-bot{flex-direction:column;gap:8px;text-align:center}
  .c-form-wrap{padding:24px 20px}
  .c-form .form-row{grid-template-columns:1fr}
  .cta-acts{flex-direction:column;width:100%}
  .btn-wt,.btn-wt-out{justify-content:center}
  .fleet-grid{grid-template-columns:1fr}
}
