
@font-face { font-family: 'Aerospace'; src: url('fonts/Aerospace.otf') format('opentype'), url('fonts/Aerospace.ttf') format('truetype'); font-weight: 400; font-style: normal; font-display: swap; }
:root {
  --bg-void: #08080a; --bg-deep: #0d0d10; --bg-charcoal: #131318; --bg-elevated: #1a1a21;
  --red: #e11d2a; --red-bright: #ff2d3a; --red-deep: #8b0a14; --red-darker: #5a0810;
  --red-glow: rgba(225, 29, 42, 0.35); --red-soft: rgba(225, 29, 42, 0.08);
  --text-primary: #f4f4f6; --text-secondary: #9a9aa3; --text-muted: #5e5e68;
  --glass-bg: rgba(255, 255, 255, 0.035); --glass-bg-strong: rgba(255, 255, 255, 0.06); --glass-bg-deep: rgba(13, 13, 16, 0.7);
  --glass-border: rgba(255, 255, 255, 0.08); --glass-border-strong: rgba(255, 255, 255, 0.14);
  --shadow-soft: 0 10px 40px rgba(0, 0, 0, 0.4); --shadow-deep: 0 20px 60px rgba(0, 0, 0, 0.6); --shadow-glow: 0 0 60px rgba(225, 29, 42, 0.15);
  --font: 'Outfit', system-ui, sans-serif;
  --container: 1280px; --radius: 16px; --radius-sm: 10px; --radius-lg: 24px;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1); --ease-smooth: cubic-bezier(0.65, 0, 0.35, 1); --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font); background: var(--bg-void); color: var(--text-primary); line-height: 1.6; overflow-x: hidden; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-weight: 400; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
::selection { background: var(--red); color: white; }
body::before { content: ''; position: fixed; inset: 0; background: radial-gradient(ellipse 60% 50% at 20% 0%, rgba(225, 29, 42, 0.10), transparent 60%), radial-gradient(ellipse 50% 40% at 100% 50%, rgba(225, 29, 42, 0.05), transparent 60%), radial-gradient(ellipse 80% 60% at 50% 100%, rgba(20, 20, 30, 0.6), transparent 70%); pointer-events: none; z-index: 0; }
body::after { content: ''; position: fixed; inset: 0; background-image: linear-gradient(rgba(255, 255, 255, 0.018) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px); background-size: 60px 60px; pointer-events: none; z-index: 0; mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%); -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%); }
main, nav, footer { position: relative; z-index: 1; }
.container { max-width: var(--container); margin: 0 auto; padding: 0 28px; }
.eyebrow { display: inline-flex; align-items: center; gap: 12px; font-size: 12px; font-weight: 600; letter-spacing: 0.22em; color: var(--red-bright); text-transform: uppercase; margin-bottom: 18px; }
.eyebrow::before { content: ''; width: 28px; height: 1px; background: var(--red-bright); }
.section-title { font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1.05; letter-spacing: -0.02em; font-weight: 700; color: var(--text-primary); margin-bottom: 18px; }
.section-title .accent { color: var(--red); font-style: italic; font-weight: 600; }
.section-subtitle { color: var(--text-secondary); max-width: 620px; font-size: 1.05rem; line-height: 1.7; font-weight: 300; }
.section-header { text-align: center; margin: 0 auto 70px; max-width: 760px; }
.section-header .eyebrow { justify-content: center; }
.section-header .section-subtitle { margin: 0 auto; }
section { padding: 110px 0; position: relative; }
.btn { display: inline-flex; align-items: center; gap: 10px; padding: 15px 26px; font-family: var(--font); font-size: 14px; font-weight: 600; letter-spacing: 0.02em; border-radius: 100px; transition: all 0.4s var(--ease-out); position: relative; overflow: hidden; white-space: nowrap; }
.btn-primary { background: linear-gradient(135deg, var(--red-bright) 0%, var(--red) 50%, var(--red-deep) 100%); background-size: 200% 200%; background-position: 0% 50%; color: white; box-shadow: 0 6px 24px rgba(225, 29, 42, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.2); }
.btn-primary:hover { background-position: 100% 50%; transform: translateY(-2px); box-shadow: 0 12px 32px rgba(225, 29, 42, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.25); }
.btn-primary::before { content: ''; position: absolute; top: 0; left: -100%; width: 60%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent); transition: left 0.7s var(--ease-out); }
.btn-primary:hover::before { left: 130%; }
.btn-ghost { background: var(--glass-bg); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid var(--glass-border); color: var(--text-primary); }
.btn-ghost:hover { background: var(--glass-bg-strong); border-color: rgba(225, 29, 42, 0.4); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(225, 29, 42, 0.15); }
.btn .arrow { transition: transform 0.4s var(--ease-out); }
.btn:hover .arrow { transform: translateX(4px); }
nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 16px 28px; transition: all 0.4s var(--ease-out); }
nav.scrolled { padding: 12px 28px; }
.nav-inner { max-width: var(--container); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; padding: 8px 14px 8px 8px; background: rgba(13, 13, 16, 0.7); backdrop-filter: blur(28px) saturate(180%); -webkit-backdrop-filter: blur(28px) saturate(180%); border: 1px solid var(--glass-border); border-radius: 100px; transition: all 0.4s var(--ease-out); }
nav.scrolled .nav-inner { background: rgba(8, 8, 10, 0.88); box-shadow: var(--shadow-soft); }
.nav-logo { display: flex; align-items: center; gap: 14px; padding-right: 12px; }
.nav-logo .logo-frame { width: 56px; height: 56px; border-radius: 50%; background: white; padding: 6px; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(255, 255, 255, 0.06); flex-shrink: 0; }
.nav-logo .logo-frame img { width: 100%; height: 100%; object-fit: contain; }
.nav-logo .name { font-size: 15px; font-weight: 700; letter-spacing: -0.005em; line-height: 1.1; color: var(--text-primary); }
.nav-logo .name small { display: block; font-size: 10px; font-weight: 500; color: var(--red-bright); letter-spacing: 0.18em; margin-top: 4px; text-transform: uppercase; }
.nav-menu { display: flex; align-items: center; gap: 4px; list-style: none; }
.nav-menu a { padding: 11px 18px; font-size: 14px; font-weight: 500; color: var(--text-secondary); border-radius: 100px; transition: all 0.3s; position: relative; }
.nav-menu a:hover { color: var(--text-primary); background: rgba(255, 255, 255, 0.04); }
.nav-menu a.active { color: var(--text-primary); }
.nav-menu a.active::after { content: ''; position: absolute; bottom: 4px; left: 50%; transform: translateX(-50%); width: 4px; height: 4px; background: var(--red); border-radius: 50%; box-shadow: 0 0 10px var(--red); }
.nav-cta { display: flex; align-items: center; gap: 10px; padding: 11px 22px; background: linear-gradient(135deg, var(--red-bright), var(--red), var(--red-deep)); background-size: 200% 200%; color: white; border-radius: 100px; font-size: 13px; font-weight: 600; letter-spacing: 0.01em; transition: all 0.4s var(--ease-out); box-shadow: 0 4px 18px rgba(225, 29, 42, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.2); }
.nav-cta:hover { transform: translateY(-1px); background-position: 100% 50%; box-shadow: 0 8px 24px rgba(225, 29, 42, 0.5); }
.nav-cta .pulse { width: 8px; height: 8px; background: white; border-radius: 50%; animation: nav-pulse 2s infinite; }
@keyframes nav-pulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.6); } 50% { box-shadow: 0 0 0 8px rgba(255, 255, 255, 0); } }
.menu-toggle { display: none; width: 44px; height: 44px; border-radius: 50%; background: var(--glass-bg); border: 1px solid var(--glass-border); flex-direction: column; justify-content: center; align-items: center; gap: 5px; }
.menu-toggle span { width: 18px; height: 1.5px; background: white; transition: all 0.3s; }
.hero { min-height: 680px; height: 100vh; max-height: 860px; display: flex; align-items: center; position: relative; padding: 130px 28px 70px; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-bg .glow-orb { position: absolute; top: 50%; left: 65%; transform: translate(-50%, -50%); width: 900px; height: 900px; background: radial-gradient(circle at center, var(--red-glow) 0%, transparent 55%); filter: blur(70px); opacity: 0.55; animation: pulse-glow 7s ease-in-out infinite; }
@keyframes pulse-glow { 0%, 100% { opacity: 0.4; transform: translate(-50%, -50%) scale(0.95); } 50% { opacity: 0.65; transform: translate(-50%, -50%) scale(1.06); } }
.hero-inner { max-width: var(--container); margin: 0 auto; width: 100%; display: grid; grid-template-columns: 1.05fr 1fr; gap: 60px; align-items: center; position: relative; z-index: 2; }
.hero-pill { display: inline-flex; align-items: center; gap: 12px; padding: 8px 20px 8px 14px; background: var(--glass-bg-deep); backdrop-filter: blur(20px) saturate(160%); -webkit-backdrop-filter: blur(20px) saturate(160%); border: 1px solid var(--glass-border); border-radius: 100px; font-size: 13px; font-weight: 400; color: var(--text-secondary); margin-bottom: 22px; position: relative; overflow: hidden; }
.hero-pill::before { content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 3px; background: linear-gradient(180deg, var(--red-bright), var(--red-deep)); border-radius: 2px; }
.hero-pill .pill-icon { width: 22px; height: 22px; border-radius: 50%; background: rgba(225, 29, 42, 0.15); display: flex; align-items: center; justify-content: center; color: var(--red-bright); flex-shrink: 0; margin-left: 6px; }
.hero-pill strong { color: var(--text-primary); font-weight: 600; }
.hero h1 { font-size: clamp(2rem, 4.2vw, 3.25rem); line-height: 1.05; font-weight: 700; letter-spacing: -0.025em; margin-bottom: 18px; color: var(--text-primary); }
.hero h1 .accent { font-style: italic; font-weight: 600; color: var(--red); position: relative; display: inline-block; }
.hero h1 .accent::after { content: ''; position: absolute; bottom: 6px; left: 0; right: 0; height: 14px; background: var(--red); opacity: 0.18; filter: blur(20px); z-index: -1; }
.hero-sub { font-size: 1rem; color: var(--text-secondary); max-width: 520px; line-height: 1.6; margin-bottom: 24px; font-weight: 300; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-trust { display: flex; gap: 12px; flex-wrap: wrap; }
.trust-pill { display: flex; align-items: center; gap: 12px; padding: 10px 18px 10px 10px; background: var(--glass-bg); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border: 1px solid var(--glass-border); border-radius: 100px; transition: all 0.3s; }
.trust-pill:hover { background: var(--glass-bg-strong); border-color: rgba(225, 29, 42, 0.3); }
.trust-pill .ti-icon { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, var(--red), var(--red-deep)); display: flex; align-items: center; justify-content: center; color: white; flex-shrink: 0; box-shadow: 0 2px 8px rgba(225, 29, 42, 0.4); }
.trust-pill .ti-text { display: flex; flex-direction: column; line-height: 1; }
.trust-pill .ti-text strong { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.trust-pill .ti-text small { font-size: 10px; color: var(--text-muted); margin-top: 4px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 500; }
.hero-visual { position: relative; width: 100%; aspect-ratio: 1; max-width: 420px; margin-left: auto; display: block; }
.gauge-stage { position: relative; width: 100%; height: 100%; }
.gauge-stage::before { content: ''; position: absolute; inset: 8%; background: radial-gradient(circle at center, var(--red-glow) 0%, transparent 65%); filter: blur(40px); z-index: 0; }
.gauge-svg { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 1; }
.gauge-svg.spin-slow { animation: gauge-rotate 60s linear infinite; transform-origin: center; }
.gauge-svg.spin-rev { animation: gauge-rotate-rev 80s linear infinite; transform-origin: center; }
@keyframes gauge-rotate { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes gauge-rotate-rev { from { transform: rotate(360deg); } to { transform: rotate(0deg); } }
.gauge-needle { transform-origin: 250px 250px; animation: needle-sweep 7s ease-in-out infinite; }
@keyframes needle-sweep { 0% { transform: rotate(-115deg); } 50% { transform: rotate(115deg); } 100% { transform: rotate(-115deg); } }
.gauge-arc { stroke-dasharray: 800; stroke-dashoffset: 800; animation: arc-fill 4s var(--ease-out) forwards 0.8s; }
@keyframes arc-fill { to { stroke-dashoffset: 280; } }
.hero-floating-card { position: absolute; padding: 14px 18px; background: rgba(13, 13, 16, 0.78); backdrop-filter: blur(24px) saturate(180%); -webkit-backdrop-filter: blur(24px) saturate(180%); border: 1px solid var(--glass-border-strong); border-radius: 14px; display: flex; align-items: center; gap: 12px; z-index: 3; box-shadow: var(--shadow-soft); animation: float 6s ease-in-out infinite; }
.hero-floating-card.tl { top: 4%; left: 2%; }
.hero-floating-card.br { bottom: 4%; right: 2%; animation-delay: 2.5s; }
@keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.hero-floating-card .dot { width: 8px; height: 8px; background: #22c55e; border-radius: 50%; box-shadow: 0 0 10px #22c55e; animation: nav-pulse 2s infinite; }
.hero-floating-card .text small { display: block; font-size: 10px; font-weight: 500; color: var(--text-muted); letter-spacing: 0.16em; text-transform: uppercase; }
.hero-floating-card .text span { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.marquee { padding: 22px 0; background: linear-gradient(90deg, var(--red-darker) 0%, var(--red-deep) 20%, var(--red) 50%, var(--red-deep) 80%, var(--red-darker) 100%); overflow: hidden; position: relative; border-top: 1px solid rgba(255, 255, 255, 0.12); border-bottom: 1px solid rgba(0, 0, 0, 0.4); box-shadow: 0 6px 24px rgba(225, 29, 42, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.08); }
.marquee::before, .marquee::after { content: ''; position: absolute; top: 0; bottom: 0; width: 100px; z-index: 2; pointer-events: none; }
.marquee::before { left: 0; background: linear-gradient(90deg, var(--red-darker), transparent); }
.marquee::after { right: 0; background: linear-gradient(-90deg, var(--red-darker), transparent); }
.marquee-track { display: flex; align-items: center; gap: 44px; animation: scroll-marquee 38s linear infinite; width: max-content; }
@keyframes scroll-marquee { to { transform: translateX(-50%); } }
.marquee-item { display: flex; align-items: center; gap: 44px; font-family: var(--font); font-size: 1.15rem; font-weight: 700; color: white; letter-spacing: 0.1em; white-space: nowrap; text-transform: uppercase; }
.marquee-pair { display: inline-flex; align-items: center; gap: 14px; }
.marquee-pair svg { flex-shrink: 0; color: white; width: 26px; height: 26px; }
.marquee-pair-tyre svg { animation: mq-spin 8s linear infinite; }
.marquee-pair-mech .mq-bolt { animation: mq-spin 4s linear infinite; transform-origin: center; transform-box: fill-box; }
.marquee-pair-paint .mq-drop { animation: mq-paint-drop 1.6s ease-in-out infinite; }
.marquee-pair-paint .mq-drop-2 { animation-delay: 0.4s; }
.marquee-pair-paint .mq-drop-3 { animation-delay: 0.8s; }
@keyframes mq-paint-drop { 0%, 60% { transform: translateY(0); opacity: 1; } 100% { transform: translateY(6px); opacity: 0; } }
.marquee-pair-check .mq-check { stroke-dasharray: 16; stroke-dashoffset: 16; animation: mq-draw 2s ease-in-out infinite; }
@keyframes mq-draw { 0% { stroke-dashoffset: 16; } 50%, 70% { stroke-dashoffset: 0; } 100% { stroke-dashoffset: -16; } }
.marquee-pair-brake .mq-caliper { animation: mq-pulse 1.4s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
@keyframes mq-pulse { 0%, 100% { transform: scale(1); opacity: 1; } 50% { transform: scale(0.92); opacity: 0.7; } }
.marquee-pair-align .mq-arrow { animation: mq-shift 1.6s ease-in-out infinite; }
@keyframes mq-shift { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(2px); } }
.marquee-pair-exhaust .mq-puff { animation: mq-puff 1.8s ease-out infinite; }
.marquee-pair-exhaust .mq-puff-2 { animation-delay: 0.6s; }
.marquee-pair-exhaust .mq-puff-3 { animation-delay: 1.2s; }
@keyframes mq-puff { 0% { transform: translateX(0) scale(0.6); opacity: 0; } 30% { opacity: 0.8; } 100% { transform: translateX(8px) scale(1.4); opacity: 0; } }
.marquee-pair-mot .mq-shield-tick { stroke-dasharray: 10; stroke-dashoffset: 10; animation: mq-draw 2.4s ease-in-out infinite; }
@keyframes mq-spin { to { transform: rotate(360deg); } }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.service-card { padding: 44px 36px 36px; background: var(--glass-bg); backdrop-filter: blur(22px) saturate(160%); -webkit-backdrop-filter: blur(22px) saturate(160%); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); position: relative; overflow: hidden; transition: all 0.5s var(--ease-out); display: flex; flex-direction: column; }
.service-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--glass-border-strong), transparent); }
.service-card::after { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 50% 0%, var(--red-soft), transparent 60%); opacity: 0; transition: opacity 0.5s; pointer-events: none; }
.service-card:hover { transform: translateY(-10px); border-color: rgba(225, 29, 42, 0.3); background: var(--glass-bg-strong); box-shadow: 0 20px 60px rgba(225, 29, 42, 0.15), 0 0 0 1px rgba(225, 29, 42, 0.1); }
.service-card:hover::after { opacity: 0.6; }
.service-num { position: absolute; top: 24px; right: 28px; font-size: 12px; font-weight: 700; letter-spacing: 0.2em; color: var(--text-muted); background: var(--glass-bg-strong); padding: 6px 12px; border-radius: 100px; border: 1px solid var(--glass-border); }
.service-icon-wrap { width: 100px; height: 100px; border-radius: 24px; background: linear-gradient(135deg, rgba(225, 29, 42, 0.22), rgba(225, 29, 42, 0.04)); border: 1px solid rgba(225, 29, 42, 0.3); display: flex; align-items: center; justify-content: center; margin-bottom: 30px; position: relative; overflow: hidden; transition: all 0.5s var(--ease-out); }
.service-icon-wrap::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.18), transparent 60%); }
/* Hover effect: clean scale+rotate (Arvo style — no rotating shine, no orbit dot) */
.service-card:hover .service-icon-wrap {
  background: linear-gradient(135deg, rgba(225, 29, 42, 0.32), rgba(225, 29, 42, 0.1));
  border-color: rgba(225, 29, 42, 0.5);
  transform: scale(1.06) rotate(-3deg);
}
.service-icon-wrap svg { width: 60px; height: 60px; position: relative; z-index: 1; color: var(--red-bright); }
/* TYRE — radar pulse always playing, rim spins continuously, rotates faster on hover */
.ico-tyre .tyre-pulse { transform-origin: 20px 20px; animation: tyrePulse 2.4s ease-out infinite; }
.ico-tyre .tyre-pulse-2 { animation-delay: 1.2s; }
@keyframes tyrePulse { 0% { transform: scale(0.55); opacity: 0.9; } 100% { transform: scale(1.18); opacity: 0; } }
.ico-tyre .tyre-rim { transform-origin: 20px 20px; animation: tyreSpin 22s linear infinite; }
.service-card:hover .ico-tyre .tyre-rim { animation-duration: 3s; }
.ico-tyre .tyre-tread { transform-origin: 20px 20px; animation: tyreSpin 30s linear infinite reverse; opacity: 0.85; }
.service-card:hover .ico-tyre .tyre-tread { animation-duration: 5s; }
@keyframes tyreSpin { to { transform: rotate(360deg); } }
/* MECHANICS — wrench sways always, bolt rotates, sparks pulse */
.ico-wrench .wrench-tool { transform-origin: 24px 13px; animation: wrenchSway 2.4s ease-in-out infinite; }
.service-card:hover .ico-wrench .wrench-tool { animation-duration: 1s; }
@keyframes wrenchSway { 0%, 100% { transform: rotate(-4deg); } 50% { transform: rotate(4deg); } }
.ico-wrench .wrench-bolt { transform-origin: 12px 11px; animation: wrenchBoltSpin 8s linear infinite; }
.service-card:hover .ico-wrench .wrench-bolt { animation-duration: 1.4s; }
@keyframes wrenchBoltSpin { to { transform: rotate(360deg); } }
.ico-wrench .wrench-spark { animation: wrenchSpark 1.6s ease-out infinite; opacity: 0; }
.ico-wrench .wrench-spark-1 { animation-delay: 0s; }
.ico-wrench .wrench-spark-2 { animation-delay: 0.4s; }
.ico-wrench .wrench-spark-3 { animation-delay: 0.8s; }
@keyframes wrenchSpark { 0%, 80% { opacity: 0; transform: scale(0.6); } 30% { opacity: 1; transform: scale(1.2); } 50% { opacity: 0.6; } }
/* BODY WORK — particles always drift from gun, on hover the spray-gun pulses */
.ico-spray .spray-p { animation: sprayDrift 2s ease-out infinite; }
.ico-spray .spray-p1 { animation-delay: 0s; }
.ico-spray .spray-p2 { animation-delay: 0.3s; }
.ico-spray .spray-p3 { animation-delay: 0.6s; }
.ico-spray .spray-p4 { animation-delay: 0.9s; }
.ico-spray .spray-p5 { animation-delay: 1.2s; }
@keyframes sprayDrift { 0% { transform: translate(0, 0) scale(0.6); opacity: 0; } 25% { opacity: 1; } 100% { transform: translate(-2px, 8px) scale(1.1); opacity: 0; } }
.ico-spray .spray-gun { transform-origin: 33px 9px; animation: sprayGunBob 2.4s ease-in-out infinite; }
.service-card:hover .ico-spray .spray-gun { animation-duration: 1s; }
@keyframes sprayGunBob { 0%, 100% { transform: translateY(0) rotate(-2deg); } 50% { transform: translateY(1px) rotate(2deg); } }
/* Subtle inner highlight on the icon container (not animated) */
.service-icon-wrap::before { content: ''; position: absolute; inset: 4px; border-radius: 18px; background: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.18), transparent 60%); pointer-events: none; z-index: 2; }
.service-card h3 { font-size: 1.5rem; font-weight: 700; margin-bottom: 14px; letter-spacing: -0.015em; color: var(--text-primary); }
.service-card > p { color: var(--text-secondary); font-size: 0.97rem; line-height: 1.7; margin-bottom: 24px; font-weight: 300; flex-grow: 0; }
.service-features { list-style: none; display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }
.service-features li { display: flex; align-items: center; gap: 12px; font-size: 0.92rem; color: var(--text-secondary); font-weight: 400; }
.service-features li svg { width: 16px; height: 16px; color: var(--red-bright); flex-shrink: 0; }
.service-cta { margin-top: auto; display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 14px 22px; background: linear-gradient(135deg, var(--red-bright) 0%, var(--red) 50%, var(--red-deep) 100%); background-size: 200% 200%; background-position: 0% 50%; border: none; border-radius: 100px; font-size: 13px; font-weight: 600; color: white; transition: all 0.4s var(--ease-out); text-transform: uppercase; letter-spacing: 0.06em; width: 100%; box-shadow: 0 4px 16px rgba(225, 29, 42, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.2); position: relative; overflow: hidden; }
.service-cta::before { content: ''; position: absolute; top: 0; left: -100%; width: 60%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent); transition: left 0.7s var(--ease-out); }
.service-cta:hover { background-position: 100% 50%; box-shadow: 0 10px 28px rgba(225, 29, 42, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.25); transform: translateY(-2px); }
.service-cta:hover::before { left: 130%; }
.service-cta svg { transition: transform 0.4s; }
.service-cta:hover svg { transform: translateX(4px); }
.stats-section { padding: 60px 0 130px; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.stat-card { padding: 40px 28px; background: var(--glass-bg); backdrop-filter: blur(22px) saturate(160%); -webkit-backdrop-filter: blur(22px) saturate(160%); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); position: relative; overflow: hidden; text-align: center; transition: all 0.5s var(--ease-out); }
.stat-card::before { content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 80%; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); opacity: 0.6; }
.stat-card::after { content: ''; position: absolute; inset: -1px; border-radius: inherit; padding: 1px; background: linear-gradient(135deg, transparent, var(--red), transparent); -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity: 0; transition: opacity 0.5s; }
.stat-card:hover { transform: translateY(-6px); background: var(--glass-bg-strong); }
.stat-card:hover::after { opacity: 1; }
.stat-icon-wrap { width: 64px; height: 64px; margin: 0 auto 22px; display: flex; align-items: center; justify-content: center; border-radius: 18px; background: linear-gradient(135deg, rgba(225, 29, 42, 0.2), rgba(225, 29, 42, 0.04)); border: 1px solid rgba(225, 29, 42, 0.25); color: var(--red-bright); position: relative; transition: all 0.5s var(--ease-out); }
.stat-card:hover .stat-icon-wrap { transform: scale(1.08) rotate(-3deg); box-shadow: 0 8px 24px rgba(225, 29, 42, 0.3); }
.stat-icon-wrap .stat-ico { width: 36px; height: 36px; color: var(--red-bright); }
/* People icon — figures bob, heart pulses */
.ico-people .people-grp-1 { transform-origin: 13px 26px; animation: peopleBob 2.4s ease-in-out infinite; }
.ico-people .people-grp-2 { transform-origin: 27px 26px; animation: peopleBob 2.4s ease-in-out infinite 0.6s; }
@keyframes peopleBob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-1.5px); } }
.ico-people .people-heart { transform-origin: 20px 8px; animation: peopleHeart 1.4s ease-in-out infinite; transform-box: fill-box; }
@keyframes peopleHeart { 0%, 100% { transform: scale(1); } 30% { transform: scale(1.25); } 60% { transform: scale(1); } }
/* Clock — hands rotate */
.ico-clock .clock-hour { transform-origin: 20px 20px; animation: clockHour 8s linear infinite; }
.ico-clock .clock-min { transform-origin: 20px 20px; animation: clockMin 1.4s linear infinite; }
@keyframes clockHour { to { transform: rotate(360deg); } }
@keyframes clockMin { to { transform: rotate(360deg); } }
/* Stack — layers fan out and back */
.ico-stack .stack-l1 { animation: stackFan 2.4s ease-in-out infinite; }
.ico-stack .stack-l2 { animation: stackFan 2.4s ease-in-out infinite 0.2s; }
.ico-stack .stack-l3 { animation: stackFan 2.4s ease-in-out infinite 0.4s; }
@keyframes stackFan { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-1.5px); } }
/* Star — main twinkle, sparkles around */
.ico-star .star-main { transform-origin: 20px 20px; animation: starTwinkle 2.6s ease-in-out infinite; transform-box: fill-box; }
@keyframes starTwinkle { 0%, 100% { transform: scale(1) rotate(0deg); } 50% { transform: scale(1.05) rotate(8deg); } }
.ico-star .star-sp { animation: sparkPulse 1.6s ease-in-out infinite; opacity: 0; }
.ico-star .star-sp-1 { animation-delay: 0s; }
.ico-star .star-sp-2 { animation-delay: 0.4s; }
.ico-star .star-sp-3 { animation-delay: 0.8s; }
.ico-star .star-sp-4 { animation-delay: 1.2s; }
@keyframes sparkPulse { 0%, 80% { opacity: 0; transform: scale(0.5); } 30%, 60% { opacity: 1; transform: scale(1.2); } }
.stat-number { font-size: 3.2rem; font-weight: 700; line-height: 1; letter-spacing: -0.03em; background: linear-gradient(180deg, var(--text-primary) 30%, var(--text-secondary)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; margin-bottom: 12px; font-feature-settings: "tnum"; }
.stat-number .plus { color: var(--red); -webkit-text-fill-color: var(--red); font-weight: 600; }
.stat-label { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; color: var(--text-secondary); text-transform: uppercase; }
.about-section { padding-bottom: 120px; }
.about-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 80px; align-items: center; }
.about-visual { position: relative; aspect-ratio: 1; border-radius: var(--radius-lg); overflow: hidden; background: radial-gradient(circle at 30% 30%, rgba(225, 29, 42, 0.18), transparent 55%), radial-gradient(circle at 70% 80%, rgba(225, 29, 42, 0.08), transparent 50%), linear-gradient(135deg, var(--bg-charcoal), var(--bg-deep)); border: 1px solid var(--glass-border-strong); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 30px 60px rgba(0, 0, 0, 0.3); }
.about-visual::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px); background-size: 40px 40px; mask-image: radial-gradient(circle at center, black 30%, transparent 80%); -webkit-mask-image: radial-gradient(circle at center, black 30%, transparent 80%); }
.about-visual-inner { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.about-orbit { position: absolute; inset: 6%; border: 1px dashed rgba(225, 29, 42, 0.25); border-radius: 50%; animation: gauge-rotate 60s linear infinite; }
.about-orbit::before, .about-orbit::after { content: ''; position: absolute; width: 12px; height: 12px; background: var(--red); border-radius: 50%; box-shadow: 0 0 20px var(--red); }
.about-orbit::before { top: -6px; left: 50%; transform: translateX(-50%); }
.about-orbit::after { bottom: -6px; left: 50%; transform: translateX(-50%); }
.about-orbit-2 { position: absolute; inset: 14%; border: 1px dashed rgba(255, 255, 255, 0.08); border-radius: 50%; animation: gauge-rotate-rev 80s linear infinite; }
.about-logo-display { width: 58%; aspect-ratio: 1; background: linear-gradient(135deg, #ffffff 0%, #f5f5f7 100%); border-radius: 50%; padding: 22px; display: flex; align-items: center; justify-content: center; position: relative; box-shadow: 0 0 120px var(--red-glow), 0 30px 80px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(225, 29, 42, 0.2), inset 0 -2px 6px rgba(0, 0, 0, 0.05); overflow: hidden; z-index: 2; }
.about-logo-display::before { content: ''; position: absolute; inset: 6%; border-radius: 50%; background: radial-gradient(circle at 30% 25%, rgba(255, 255, 255, 0.6), transparent 50%); pointer-events: none; }
.about-logo-display img { width: 100%; height: 100%; object-fit: contain; }
.about-visual-badge { position: absolute; top: 22px; left: 22px; padding: 8px 14px; background: rgba(13, 13, 16, 0.8); backdrop-filter: blur(12px); border: 1px solid var(--glass-border-strong); border-radius: 100px; font-size: 11px; font-weight: 600; letter-spacing: 0.16em; color: var(--red-bright); text-transform: uppercase; z-index: 3; display: inline-flex; align-items: center; gap: 8px; }
.about-visual-badge::before { content: ''; width: 6px; height: 6px; background: var(--red); border-radius: 50%; box-shadow: 0 0 8px var(--red); }
.about-text { padding: 20px 0; }
.about-text .section-title { margin-bottom: 24px; }
.about-text > p { color: var(--text-secondary); font-size: 1.05rem; line-height: 1.8; margin-bottom: 36px; font-weight: 300; }
.about-features { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 38px; }
.about-feature { display: flex; gap: 14px; align-items: flex-start; padding: 18px; background: var(--glass-bg); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid var(--glass-border); border-radius: var(--radius); transition: all 0.4s var(--ease-out); position: relative; overflow: hidden; }
.about-feature::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background: linear-gradient(90deg, transparent, rgba(225, 29, 42, 0.08), transparent); transition: left 0.6s; }
.about-feature:hover { transform: translateY(-4px); background: var(--glass-bg-strong); border-color: rgba(225, 29, 42, 0.3); }
.about-feature:hover::before { left: 100%; }
.about-feature-icon { width: 44px; height: 44px; border-radius: 12px; background: linear-gradient(135deg, rgba(225, 29, 42, 0.2), rgba(225, 29, 42, 0.04)); border: 1px solid rgba(225, 29, 42, 0.25); display: flex; align-items: center; justify-content: center; color: var(--red-bright); flex-shrink: 0; transition: transform 0.4s var(--ease-bounce); }
.about-feature:hover .about-feature-icon { transform: rotate(-8deg) scale(1.08); }
.about-feature h4 { font-size: 14px; font-weight: 600; margin-bottom: 4px; letter-spacing: -0.01em; color: var(--text-primary); }
.about-feature p { font-size: 0.85rem; color: var(--text-secondary); line-height: 1.5; font-weight: 300; }


/* ========== WHY CHOOSE US ========== */
.why-section { padding: 120px 0; position: relative; }
.why-section::before { content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 80px; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.why-card { padding: 38px 30px; background: var(--glass-bg); backdrop-filter: blur(22px) saturate(160%); -webkit-backdrop-filter: blur(22px) saturate(160%); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); position: relative; overflow: hidden; transition: all 0.5s var(--ease-out); }
.why-card::before { content: ''; position: absolute; top: 0; left: 30px; right: 30px; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); opacity: 0.5; }
.why-card::after { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 50% 0%, var(--red-soft), transparent 60%); opacity: 0; transition: opacity 0.5s; pointer-events: none; }
.why-card:hover { transform: translateY(-8px); border-color: rgba(225, 29, 42, 0.35); background: var(--glass-bg-strong); box-shadow: 0 20px 50px rgba(225, 29, 42, 0.12); }
.why-card:hover::after { opacity: 0.7; }
.why-ico-wrap { width: 72px; height: 72px; border-radius: 18px; background: linear-gradient(135deg, rgba(225, 29, 42, 0.22), rgba(225, 29, 42, 0.04)); border: 1px solid rgba(225, 29, 42, 0.3); display: grid; place-items: center; margin-bottom: 22px; color: var(--red-bright); position: relative; overflow: hidden; transition: all 0.4s var(--ease-out); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); }
.why-ico-wrap::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.18), transparent 60%); pointer-events: none; }
.why-card:hover .why-ico-wrap { background: linear-gradient(135deg, rgba(225, 29, 42, 0.34), rgba(225, 29, 42, 0.1)); border-color: rgba(225, 29, 42, 0.55); transform: scale(1.06) rotate(-3deg); }
.why-ico-wrap svg { width: 40px; height: 40px; position: relative; z-index: 1; }
.why-card h4 { font-size: 1.18rem; font-weight: 700; margin-bottom: 10px; letter-spacing: -0.015em; color: var(--text-primary); }
.why-card p { color: var(--text-secondary); font-size: 0.92rem; line-height: 1.6; font-weight: 300; }
/* Why icon animations */
.pin-shadow { transform-origin: 20px 34px; opacity: 0; animation: pinRipple 2.2s ease-out infinite; }
.pin-shadow-2 { animation-delay: 1.1s; }
@keyframes pinRipple { 0% { transform: scale(0.4); opacity: 0.85; } 100% { transform: scale(2.6); opacity: 0; } }
.medal-spin { transform-origin: 20px 26px; animation: medalPulse 2.4s ease-in-out infinite; transform-box: fill-box; }
@keyframes medalPulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.04); } }
.cog-spin { transform-origin: 20px 20px; animation: cogRot 14s linear infinite; }
.why-card:hover .cog-spin { animation-duration: 2.4s; }
@keyframes cogRot { to { transform: rotate(360deg); } }
.shield-check { stroke-dasharray: 18; stroke-dashoffset: 18; animation: shieldDraw 2.6s ease-in-out infinite; }
@keyframes shieldDraw { 0% { stroke-dashoffset: 18; } 50%, 70% { stroke-dashoffset: 0; } 100% { stroke-dashoffset: -18; } }
.rcpt-line { stroke-dasharray: 14; stroke-dashoffset: 14; animation: rcptFlow 3s ease-in-out infinite; }
.rcpt-l2 { animation-delay: 0.3s; }
.rcpt-l3 { animation-delay: 0.6s; }
@keyframes rcptFlow { 0% { stroke-dashoffset: 14; } 50%, 70% { stroke-dashoffset: 0; } 100% { stroke-dashoffset: -14; } }
.bolt-flash { animation: boltFlash 1.6s ease-in-out infinite; transform-origin: 20px 20px; transform-box: fill-box; }
@keyframes boltFlash { 0%, 100% { transform: scale(1); fill-opacity: 0.2; } 50% { transform: scale(1.08); fill-opacity: 0.4; } }
@media (max-width: 1024px) { .why-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 768px) { .why-grid { grid-template-columns: 1fr; } .why-section { padding: 80px 0; } }
/* About feature icon animations */
.about-feature-icon .af-ico { width: 20px; height: 20px; color: var(--red-bright); }
.af-tag .af-tag-check { stroke-dasharray: 14; stroke-dashoffset: 14; animation: afDraw 2.4s ease-in-out infinite; }
@keyframes afDraw { 0% { stroke-dashoffset: 14; } 50%, 70% { stroke-dashoffset: 0; } 100% { stroke-dashoffset: -14; } }
.af-hands .af-hands-spin { transform-origin: 12px 12px; animation: afHandsRot 6s ease-in-out infinite; }
@keyframes afHandsRot { 0%, 100% { transform: rotate(-4deg); } 50% { transform: rotate(4deg); } }
.af-hands .af-spark { animation: afSpark 1.8s ease-out infinite; opacity: 0; }
.af-hands .af-spark-2 { animation-delay: 0.9s; }
@keyframes afSpark { 0%, 80% { opacity: 0; transform: scale(0.6); } 30%, 50% { opacity: 1; transform: scale(1.2); } }
.af-shield .af-shield-tick { stroke-dasharray: 10; stroke-dashoffset: 10; animation: afDraw 2.6s ease-in-out infinite; }
.af-clock .af-clock-h { transform-origin: 12px 12px; animation: afClockH 6s linear infinite; }
.af-clock .af-clock-m { transform-origin: 12px 12px; animation: afClockM 1.4s linear infinite; }
@keyframes afClockH { to { transform: rotate(360deg); } }
@keyframes afClockM { to { transform: rotate(360deg); } }
.process-section { background: linear-gradient(180deg, transparent, rgba(225, 29, 42, 0.025), transparent); }
.process-track { position: relative; display: grid; grid-template-columns: repeat(4, 1fr); gap: 36px; padding: 0 30px; }
/* SVG connectors between cards */
.process-connector { position: absolute; top: 80px; opacity: 1 !important; transform: none !important; height: 32px; width: 36px; pointer-events: none; z-index: 0; display: flex; align-items: center; justify-content: center; }
.process-connector svg { width: 100%; height: 100%; overflow: visible; }
.process-connector .conn-path { stroke: rgba(225, 29, 42, 0.3); stroke-width: 1.5; fill: none; stroke-dasharray: 3 4; }
.process-connector .conn-arrow { fill: var(--red-bright); }
.process-connector .conn-dot { fill: var(--red-bright); animation: connDotFlow 2.4s linear infinite; offset-rotate: 0deg; filter: drop-shadow(0 0 4px var(--red-glow)); }
.process-connector .conn-dot-2 { animation-delay: 0.8s; }
@keyframes connDotFlow {
  0% { offset-distance: 0%; opacity: 0; }
  10% { opacity: 1; }
  85% { opacity: 1; }
  100% { offset-distance: 100%; opacity: 0; }
}
.process-card { padding: 36px 28px; background: var(--glass-bg); backdrop-filter: blur(22px) saturate(160%); -webkit-backdrop-filter: blur(22px) saturate(160%); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); position: relative; overflow: hidden; transition: all 0.5s var(--ease-out); display: flex; flex-direction: column; min-height: 240px; }
.process-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--glass-border-strong), transparent); }
.process-card::after { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 50% 0%, var(--red-soft), transparent 60%); opacity: 0; transition: opacity 0.5s; pointer-events: none; }
.process-card:hover { transform: translateY(-8px); border-color: rgba(225, 29, 42, 0.3); background: var(--glass-bg-strong); box-shadow: 0 20px 50px rgba(225, 29, 42, 0.12); }
.process-card:hover::after { opacity: 0.6; }
.process-num { position: absolute; top: 24px; right: 24px; font-family: var(--font); font-size: 12px; font-weight: 700; letter-spacing: 0.2em; color: var(--text-muted); background: var(--glass-bg-strong); padding: 6px 12px; border-radius: 100px; border: 1px solid var(--glass-border); }
.process-ico { width: 60px; height: 60px; border-radius: 16px; background: linear-gradient(135deg, rgba(225, 29, 42, 0.2), rgba(225, 29, 42, 0.04)); border: 1px solid rgba(225, 29, 42, 0.3); display: grid; place-items: center; margin-bottom: 24px; color: var(--red-bright); position: relative; overflow: hidden; transition: all 0.4s var(--ease-out); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); }
.process-ico::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.15), transparent 60%); }
.process-card:hover .process-ico { background: linear-gradient(135deg, rgba(225, 29, 42, 0.32), rgba(225, 29, 42, 0.1)); border-color: rgba(225, 29, 42, 0.5); transform: scale(1.06) rotate(-3deg); }
.process-ico svg { width: 36px; height: 36px; position: relative; z-index: 1; }
.process-card h4 { font-size: 1.15rem; font-weight: 700; margin-bottom: 10px; letter-spacing: -0.01em; color: var(--text-primary); }
.process-card p { color: var(--text-secondary); font-size: 0.9rem; line-height: 1.6; font-weight: 300; }
/* Process icon animations — Arvo-style */
.ico-call .call-pulse { transform-origin: 20px 20px; opacity: 0; animation: callPulse 2.2s ease-out infinite; }
.ico-call .call-pulse-2 { animation-delay: 1.1s; }
@keyframes callPulse { 0% { transform: scale(0.4); opacity: 0.85; } 100% { transform: scale(1.15); opacity: 0; } }
.ico-search .search-line { stroke-dasharray: 12; stroke-dashoffset: 12; animation: searchScan 2.4s ease-in-out infinite; }
@keyframes searchScan { 0% { stroke-dashoffset: 12; } 50% { stroke-dashoffset: 0; } 100% { stroke-dashoffset: -12; } }
.ico-tools .tool-gear-1 { transform-origin: 13px 14px; animation: toolSpin1 6s linear infinite; }
.ico-tools .tool-gear-2 { transform-origin: 27px 26px; animation: toolSpin2 5s linear infinite reverse; }
@keyframes toolSpin1 { to { transform: rotate(360deg); } }
@keyframes toolSpin2 { to { transform: rotate(-360deg); } }
.ico-car .car-line { stroke-dasharray: 8; stroke-dashoffset: 0; animation: carLines 1.4s linear infinite; }
.ico-car .car-line-2 { animation-delay: 0.4s; }
.ico-car .car-line-3 { animation-delay: 0.8s; }
@keyframes carLines { 0% { transform: translateX(2px); opacity: 0; } 50% { opacity: 1; } 100% { transform: translateX(-6px); opacity: 0; } }
.ico-car .car-wheel { transform-origin: center; animation: carWheel 2s linear infinite; transform-box: fill-box; }
@keyframes carWheel { to { transform: rotate(360deg); } }
.testimonials-section { overflow: hidden; }
.testimonial-slider { position: relative; margin: 0 -10px; }
.slider-viewport { overflow: hidden; padding: 20px 10px 10px; }
.slider-track { display: flex; gap: 24px; transition: transform 0.7s var(--ease-out); }
.testimonial-card { flex: 0 0 calc((100% - 48px) / 3); padding: 36px 32px; background: var(--glass-bg); backdrop-filter: blur(22px) saturate(160%); -webkit-backdrop-filter: blur(22px) saturate(160%); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); position: relative; transition: all 0.4s var(--ease-out); }
.testimonial-card::before { content: ''; position: absolute; top: 0; left: 30px; right: 30px; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); opacity: 0.5; }
.testimonial-card:hover { transform: translateY(-6px); background: var(--glass-bg-strong); border-color: rgba(225, 29, 42, 0.3); }
.t-quote-icon { display: inline-flex; width: 44px; height: 44px; border-radius: 12px; background: linear-gradient(135deg, rgba(225, 29, 42, 0.2), rgba(225, 29, 42, 0.04)); border: 1px solid rgba(225, 29, 42, 0.3); align-items: center; justify-content: center; color: var(--red-bright); margin-bottom: 18px; }
.testimonial-stars { display: flex; gap: 4px; margin-bottom: 16px; color: #fbbf24; }
.testimonial-card p { color: var(--text-primary); font-size: 1rem; line-height: 1.7; margin-bottom: 26px; font-weight: 300; }
.testimonial-author { display: flex; align-items: center; gap: 14px; padding-top: 22px; border-top: 1px solid var(--glass-border); }
.author-avatar { width: 48px; height: 48px; border-radius: 50%; background: linear-gradient(135deg, var(--red), var(--red-deep)); display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; color: white; letter-spacing: 0.02em; box-shadow: 0 4px 14px rgba(225, 29, 42, 0.3); }
.author-info h5 { font-size: 14px; margin-bottom: 2px; font-weight: 600; }
.author-info span { font-size: 12px; color: var(--text-muted); font-weight: 400; }
.slider-controls { display: flex; align-items: center; justify-content: center; gap: 28px; margin-top: 50px; }
.slider-btn { width: 52px; height: 52px; border-radius: 50%; background: var(--glass-bg); backdrop-filter: blur(14px); border: 1px solid var(--glass-border); color: var(--text-primary); display: flex; align-items: center; justify-content: center; transition: all 0.3s; }
.slider-btn:hover:not(:disabled) { background: linear-gradient(135deg, var(--red-bright), var(--red-deep)); border-color: transparent; color: white; transform: scale(1.05); box-shadow: 0 6px 20px rgba(225, 29, 42, 0.4); }
.slider-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.slider-dots { display: flex; gap: 8px; }
.slider-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--glass-border-strong); cursor: pointer; transition: all 0.3s; border: none; padding: 0; }
.slider-dot.active { background: var(--red); width: 28px; border-radius: 100px; box-shadow: 0 0 10px var(--red-glow); }
.contact-section { padding-bottom: 100px; }
.contact-card { padding: 70px 60px; background: radial-gradient(circle at 80% 0%, rgba(225, 29, 42, 0.18), transparent 50%), radial-gradient(circle at 20% 100%, rgba(225, 29, 42, 0.08), transparent 50%), var(--glass-bg); backdrop-filter: blur(24px) saturate(180%); -webkit-backdrop-filter: blur(24px) saturate(180%); border: 1px solid var(--glass-border-strong); border-radius: var(--radius-lg); position: relative; overflow: hidden; }
.contact-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); }
.contact-card::after { content: ''; position: absolute; top: -50%; right: -20%; width: 600px; height: 600px; background: radial-gradient(circle, var(--red-glow), transparent 70%); filter: blur(60px); pointer-events: none; }
.contact-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px; align-items: center; position: relative; z-index: 1; }
.contact-card h2 { font-size: clamp(2rem, 4.5vw, 3rem); line-height: 1.05; margin-bottom: 20px; letter-spacing: -0.025em; font-weight: 700; }
.contact-card h2 .accent { color: var(--red); font-style: italic; font-weight: 600; }
.contact-card > .contact-grid > div:first-child > p { color: var(--text-secondary); font-size: 1.05rem; line-height: 1.7; margin-bottom: 36px; max-width: 460px; font-weight: 300; }
.contact-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.contact-info { display: flex; flex-direction: column; gap: 16px; }
.contact-info-item { display: flex; gap: 16px; align-items: flex-start; padding: 22px; background: rgba(8, 8, 10, 0.6); backdrop-filter: blur(10px); border: 1px solid var(--glass-border); border-radius: var(--radius); transition: all 0.3s; }
.contact-info-item:hover { background: rgba(8, 8, 10, 0.8); border-color: rgba(225, 29, 42, 0.3); transform: translateX(4px); }
.contact-info-icon { width: 46px; height: 46px; border-radius: 12px; background: linear-gradient(135deg, rgba(225, 29, 42, 0.2), rgba(225, 29, 42, 0.04)); border: 1px solid rgba(225, 29, 42, 0.3); display: flex; align-items: center; justify-content: center; color: var(--red-bright); flex-shrink: 0; }
.contact-info-text small { display: block; font-size: 10px; font-weight: 600; color: var(--text-muted); letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 4px; }
.contact-info-text span { font-size: 15px; font-weight: 500; color: var(--text-primary); line-height: 1.4; }

/* ========== MAP / FIND US ========== */
.map-section { padding: 100px 0 60px; }
.map-wrap { position: relative; height: 480px; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--glass-border-strong); box-shadow: var(--shadow-deep), 0 0 0 1px rgba(225, 29, 42, 0.08); background: var(--bg-deep); }
.map-iframe { width: 100%; height: 100%; border: 0; display: block; }
.map-info-card { position: absolute; top: 22px; left: 22px; right: auto; max-width: 380px; padding: 20px 22px; background: rgba(13, 13, 16, 0.94); backdrop-filter: blur(28px) saturate(180%); -webkit-backdrop-filter: blur(28px) saturate(180%); border: 1px solid var(--glass-border-strong); border-radius: var(--radius); box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.06); z-index: 5; }
.map-place { display: flex; gap: 14px; align-items: flex-start; }
.map-logo { width: 48px; height: 48px; border-radius: 12px; background: white; padding: 5px; flex-shrink: 0; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3); display: grid; place-items: center; }
.map-logo img { width: 100%; height: 100%; object-fit: contain; }
.map-place-text { flex: 1; min-width: 0; }
.map-place-text h4 { font-size: 1rem; font-weight: 700; margin-bottom: 4px; letter-spacing: -0.005em; color: var(--text-primary); }
.map-place-text p { font-size: 0.82rem; color: var(--text-secondary); line-height: 1.5; margin-bottom: 10px; font-weight: 300; }
.map-rating { display: flex; align-items: center; gap: 8px; font-size: 0.85rem; }
.map-stars { display: inline-flex; gap: 2px; color: #fbbf24; }
.map-rating strong { color: var(--text-primary); font-weight: 700; }
.map-rating .map-reviews { color: var(--text-muted); font-size: 0.78rem; font-weight: 500; }
.map-actions { display: flex; gap: 8px; margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--glass-border); }
.map-btn { width: 42px; height: 42px; border-radius: 11px; background: rgba(255, 255, 255, 0.06); border: 1px solid var(--glass-border); display: grid; place-items: center; color: var(--text-primary); transition: all 0.3s var(--ease-out); flex-shrink: 0; }
.map-btn:hover { background: rgba(255, 255, 255, 0.1); border-color: var(--glass-border-strong); transform: translateY(-2px); }
.map-btn-primary { background: linear-gradient(135deg, var(--red-bright), var(--red), var(--red-deep)); border-color: transparent; color: white; box-shadow: 0 4px 12px rgba(225, 29, 42, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.2); flex: 1; padding: 0 16px; font-size: 13px; font-weight: 600; letter-spacing: 0.04em; gap: 8px; width: auto; display: flex; flex-direction: row; align-items: center; justify-content: center; }
.map-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(225, 29, 42, 0.5); }
.map-btn-primary::after { content: 'Directions'; display: inline; }
@media (max-width: 768px) {
  .map-section { padding: 60px 0 40px; }
  .map-wrap { height: 380px; }
  .map-info-card { left: 14px; right: 14px; top: 14px; max-width: none; padding: 16px 18px; }
}
footer { padding: 90px 0 32px; border-top: 1px solid var(--glass-border); background: linear-gradient(180deg, var(--bg-deep), var(--bg-void)); position: relative; overflow: hidden; }
footer::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); }
footer::after { content: ''; position: absolute; bottom: -40%; left: 50%; transform: translateX(-50%); width: 800px; height: 400px; background: radial-gradient(ellipse, var(--red-glow), transparent 70%); filter: blur(60px); opacity: 0.4; pointer-events: none; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 60px; margin-bottom: 60px; position: relative; z-index: 1; }
.footer-brand .footer-logo-frame { width: 96px; height: 96px; border-radius: 20px; background: white; padding: 12px; display: flex; align-items: center; justify-content: center; margin-bottom: 24px; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(255, 255, 255, 0.06); }
.footer-brand .footer-logo-frame img { width: 100%; height: 100%; object-fit: contain; }
.footer-brand h4 { font-size: 1.2rem; font-weight: 700; margin-bottom: 14px; letter-spacing: -0.015em; }
.footer-brand p { color: var(--text-secondary); font-size: 0.92rem; line-height: 1.7; max-width: 340px; margin-bottom: 28px; font-weight: 300; }
.social-links { display: flex; gap: 10px; }
.social-link { width: 42px; height: 42px; border-radius: 12px; background: var(--glass-bg); border: 1px solid var(--glass-border); display: flex; align-items: center; justify-content: center; transition: all 0.3s; color: var(--text-secondary); }
.social-link:hover { background: linear-gradient(135deg, var(--red-bright), var(--red-deep)); border-color: transparent; color: white; transform: translateY(-3px); box-shadow: 0 8px 20px rgba(225, 29, 42, 0.4); }
.footer-col h5 { font-size: 11px; font-weight: 700; letter-spacing: 0.22em; color: var(--red); text-transform: uppercase; margin-bottom: 24px; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.footer-col a { color: var(--text-secondary); font-size: 0.93rem; font-weight: 400; transition: all 0.3s; display: inline-flex; align-items: center; gap: 8px; }
.footer-col a::before { content: ''; width: 0; height: 1px; background: var(--red); transition: width 0.3s; }
.footer-col a:hover { color: var(--red-bright); }
.footer-col a:hover::before { width: 12px; }
.footer-col.contact-col p { color: var(--text-secondary); font-size: 0.93rem; line-height: 1.7; margin-bottom: 16px; font-weight: 300; }
.footer-bottom { padding-top: 32px; border-top: 1px solid var(--glass-border); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; font-size: 0.85rem; color: var(--text-muted); position: relative; z-index: 1; }
.footer-bottom .credit { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-secondary); }
.footer-bottom .credit span { color: var(--red-bright); }
.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-stagger > * { opacity: 0; transform: translateY(30px); transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out); }
.reveal-stagger.visible > *:nth-child(1) { transition-delay: 0s; opacity: 1; transform: translateY(0); }
.reveal-stagger.visible > *:nth-child(2) { transition-delay: 0.12s; opacity: 1; transform: translateY(0); }
.reveal-stagger.visible > *:nth-child(3) { transition-delay: 0.24s; opacity: 1; transform: translateY(0); }
.reveal-stagger.visible > *:nth-child(4) { transition-delay: 0.36s; opacity: 1; transform: translateY(0); }
.reveal-stagger.visible > *:nth-child(5) { transition-delay: 0.48s; opacity: 1; transform: translateY(0); }
.reveal-stagger.visible > *:nth-child(6) { transition-delay: 0.6s; opacity: 1; transform: translateY(0); }
.reveal-stagger.visible > *:nth-child(7) { transition-delay: 0.72s; opacity: 1; transform: translateY(0); }
.reveal-stagger.visible > *:nth-child(8) { transition-delay: 0.84s; opacity: 1; transform: translateY(0); }
.reveal-stagger.visible > *:nth-child(n+9) { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .reveal, .reveal-stagger > * { opacity: 1 !important; transform: none !important; transition: none !important; animation: none !important; } }
@media (max-width: 1024px) {
  .hero { height: auto; max-height: none; padding: 120px 28px 60px; }
  .hero-inner { grid-template-columns: 1fr; gap: 50px; }
  .hero-visual { max-width: 460px; margin: 0 auto; }
  .hero-floating-card.tl { left: 0; }
  .hero-floating-card.br { right: 0; }
  .services-grid { grid-template-columns: 1fr 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .about-grid { grid-template-columns: 1fr; gap: 60px; }
  .about-visual { max-width: 480px; margin: 0 auto; }
  .testimonial-card { flex: 0 0 calc((100% - 24px) / 2); }
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .process-track { grid-template-columns: 1fr 1fr; row-gap: 24px; padding: 0; }
  .process-connector { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 768px) {
  section { padding: 80px 0; }
  .hero { padding: 110px 20px 60px; }
  .container { padding: 0 20px; }
  .nav-menu { display: none; }
  .menu-toggle { display: flex; }
  .nav-cta { padding: 9px 16px; font-size: 12px; }
  .nav-logo .name { display: none; }
  .services-grid, .stats-grid { grid-template-columns: 1fr; }
  .stats-grid { gap: 14px; }
  .stat-number { font-size: 2.4rem; }
  .stat-card { padding: 28px 18px; }
  .about-features { grid-template-columns: 1fr; }
  .process-track { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .contact-card { padding: 44px 28px; }
  .hero-actions { flex-direction: column; align-items: center; }
  .hero-actions .btn { justify-content: center; }
  .hero-content { text-align: center; }
  .hero-content .hero-pill { margin-left: auto; margin-right: auto; }
  .hero-content .hero-sub { margin-left: auto; margin-right: auto; }
  .hero-trust { gap: 8px; }
  .marquee-item { font-size: 1.15rem; gap: 36px; }
  .testimonial-card { flex: 0 0 100%; }
  .footer-bottom { flex-direction: column; text-align: center; }
}

/* ========== LUXURY POLISH ========== */
/* Refined section header eyebrow */
.section-header .eyebrow { padding: 6px 14px; background: rgba(225, 29, 42, 0.08); border: 1px solid rgba(225, 29, 42, 0.15); border-radius: 100px; margin-bottom: 22px; }
.section-header .eyebrow::before { display: none; }
/* Refine section transitions with subtle decorative line */
section + section:not(.marquee + section)::before, .why-section::before, #find-us::before { content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 60px; height: 2px; background: linear-gradient(90deg, transparent, var(--red), transparent); z-index: 1; opacity: 0.6; }
#find-us { position: relative; }
/* Better card depth */
.service-card, .why-card, .stat-card, .process-card, .testimonial-card { box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25); }
.service-card:hover, .why-card:hover, .stat-card:hover, .process-card:hover, .testimonial-card:hover { box-shadow: 0 20px 50px rgba(225, 29, 42, 0.15), 0 0 0 1px rgba(225, 29, 42, 0.08); }
/* Refined typography */
.section-title { font-weight: 700; letter-spacing: -0.025em; }
/* Glow accent on hover for cards (subtle) */
.service-card::after, .why-card::after, .process-card::after { transition: opacity 0.6s var(--ease-out); }


/* ========== CONTACT FORM ========== */
.form-section { padding: 80px 0 110px; position: relative; }
.form-card { max-width: 820px; margin: 0 auto; padding: 56px 56px 48px; background: var(--glass-bg); backdrop-filter: blur(24px) saturate(180%); -webkit-backdrop-filter: blur(24px) saturate(180%); border: 1px solid var(--glass-border-strong); border-radius: var(--radius-lg); position: relative; overflow: hidden; box-shadow: var(--shadow-deep); }
.form-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); }
.form-card::after { content: ''; position: absolute; top: -40%; right: -10%; width: 360px; height: 360px; background: radial-gradient(circle, var(--red-glow), transparent 70%); filter: blur(50px); pointer-events: none; }
.form-header { text-align: center; margin-bottom: 36px; position: relative; z-index: 1; }
.form-header h3 { font-size: clamp(1.6rem, 3vw, 2.1rem); font-weight: 700; letter-spacing: -0.02em; margin-bottom: 10px; color: var(--text-primary); }
.form-header h3 .accent { font-style: italic; font-weight: 600; color: var(--red); }
.form-header p { color: var(--text-secondary); font-size: 0.95rem; font-weight: 300; }
form.contact-form { position: relative; z-index: 1; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 22px; }
.field { display: flex; flex-direction: column; }
.field.full { grid-column: span 2; }
.field label { display: block; font-size: 11px; font-weight: 600; letter-spacing: 0.16em; color: var(--text-muted); margin-bottom: 8px; text-transform: uppercase; }
.field input, .field select, .field textarea { width: 100%; padding: 14px 18px; background: rgba(8, 8, 10, 0.6); border: 1px solid var(--glass-border); border-radius: 12px; color: var(--text-primary); font-family: var(--font); font-size: 14px; font-weight: 400; transition: all 0.3s var(--ease-out); resize: vertical; }
.field textarea { min-height: 120px; line-height: 1.6; }
.field select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239a9aa3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px; cursor: pointer; }
.field select option { background: var(--bg-deep); color: var(--text-primary); }
.field input::placeholder, .field textarea::placeholder { color: var(--text-muted); }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: rgba(225, 29, 42, 0.5); background: rgba(8, 8, 10, 0.85); box-shadow: 0 0 0 3px rgba(225, 29, 42, 0.12); }
.form-submit { display: flex; justify-content: center; margin-top: 8px; }
.form-submit .btn { min-width: 240px; justify-content: center; padding: 17px 30px; font-size: 14px; }
.form-status { text-align: center; margin-top: 18px; font-size: 0.88rem; color: var(--text-secondary); min-height: 22px; transition: color 0.3s; }
.form-status.success { color: #22c55e; }
.form-status.error { color: var(--red-bright); }
@media (max-width: 768px) {
  .form-card { padding: 38px 24px 32px; }
  .form-grid { grid-template-columns: 1fr; gap: 14px; }
  .field.full { grid-column: span 1; }
  .form-submit .btn { width: 100%; }
}

/* ========== PAGE HEADER (for non-home pages) ========== */
.page-header { padding: 180px 0 80px; position: relative; text-align: center; overflow: hidden; }
.page-header::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(225, 29, 42, 0.12), transparent 60%); pointer-events: none; }
.page-header .container { position: relative; z-index: 1; }
.page-header .eyebrow { justify-content: center; margin-bottom: 18px; }
.page-header h1 { font-size: clamp(2.5rem, 5vw, 4rem); line-height: 1.05; font-weight: 700; letter-spacing: -0.025em; margin-bottom: 18px; color: var(--text-primary); }
.page-header h1 .accent { font-style: italic; font-weight: 600; color: var(--red); }
.page-header p { color: var(--text-secondary); font-size: 1.05rem; line-height: 1.7; max-width: 640px; margin: 0 auto; font-weight: 300; }
.breadcrumb { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: 100px; font-size: 12px; color: var(--text-secondary); margin-top: 24px; }
.breadcrumb a { color: var(--text-secondary); transition: color 0.3s; }
.breadcrumb a:hover { color: var(--red-bright); }
.breadcrumb .sep { color: var(--text-muted); }
.breadcrumb .current { color: var(--red-bright); font-weight: 500; }
@media (max-width: 768px) {
  .page-header { padding: 140px 0 60px; }
}

/* ========== ABOUT PAGE ========== */
.story-section { padding: 100px 0; }
.story-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: center; }
.story-text .eyebrow { margin-bottom: 22px; }
.story-text h2 { font-size: clamp(2rem, 4vw, 2.8rem); line-height: 1.1; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 22px; }
.story-text h2 .accent { font-style: italic; color: var(--red); font-weight: 600; }
.story-text p { color: var(--text-secondary); font-size: 1.02rem; line-height: 1.75; margin-bottom: 18px; font-weight: 300; }
.story-text p strong { color: var(--text-primary); font-weight: 500; }
.story-visual { aspect-ratio: 4/5; border-radius: var(--radius-lg); background: radial-gradient(circle at 30% 30%, rgba(225, 29, 42, 0.18), transparent 55%), linear-gradient(135deg, var(--bg-charcoal), var(--bg-deep)); border: 1px solid var(--glass-border-strong); position: relative; overflow: hidden; box-shadow: var(--shadow-deep); }
.story-visual::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px); background-size: 40px 40px; mask-image: radial-gradient(circle at center, black 30%, transparent 80%); -webkit-mask-image: radial-gradient(circle at center, black 30%, transparent 80%); }
.story-visual-inner { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; padding: 40px; }
.story-logo { width: 65%; aspect-ratio: 1; background: linear-gradient(135deg, #ffffff 0%, #f5f5f7 100%); border-radius: 50%; padding: 28px; display: flex; align-items: center; justify-content: center; box-shadow: 0 0 120px var(--red-glow), 0 30px 80px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(225, 29, 42, 0.2); position: relative; z-index: 2; }
.story-logo::before { content: ''; position: absolute; inset: 6%; border-radius: 50%; background: radial-gradient(circle at 30% 25%, rgba(255, 255, 255, 0.6), transparent 50%); pointer-events: none; }
.story-logo img { width: 100%; height: 100%; object-fit: contain; position: relative; z-index: 1; }
.story-orbit { position: absolute; inset: 8%; border: 1px dashed rgba(225, 29, 42, 0.25); border-radius: 50%; animation: gauge-rotate 60s linear infinite; }
.story-orbit::before { content: ''; position: absolute; top: -6px; left: 50%; transform: translateX(-50%); width: 12px; height: 12px; background: var(--red); border-radius: 50%; box-shadow: 0 0 20px var(--red); }
.story-badge { position: absolute; top: 22px; left: 22px; padding: 8px 14px; background: rgba(13, 13, 16, 0.8); backdrop-filter: blur(12px); border: 1px solid var(--glass-border-strong); border-radius: 100px; font-size: 11px; font-weight: 600; letter-spacing: 0.16em; color: var(--red-bright); text-transform: uppercase; z-index: 3; display: inline-flex; align-items: center; gap: 8px; }
.story-badge::before { content: ''; width: 6px; height: 6px; background: var(--red); border-radius: 50%; box-shadow: 0 0 8px var(--red); }
.founder-section { padding: 80px 0; position: relative; }
.founder-card { max-width: 920px; margin: 0 auto; padding: 56px 50px; background: var(--glass-bg); backdrop-filter: blur(20px); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); position: relative; overflow: hidden; }
.founder-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); }
.founder-quote-mark { position: absolute; top: 30px; right: 36px; font-family: 'Times New Roman', serif; font-size: 8rem; line-height: 1; color: var(--red); opacity: 0.18; pointer-events: none; }
.founder-quote { font-size: 1.3rem; line-height: 1.6; font-weight: 300; color: var(--text-primary); margin-bottom: 32px; font-style: italic; max-width: 720px; }
.founder-quote::before { content: '"'; color: var(--red); }
.founder-quote::after { content: '"'; color: var(--red); }
.founder-meta { display: flex; align-items: center; gap: 18px; padding-top: 24px; border-top: 1px solid var(--glass-border); }
.founder-avatar { width: 56px; height: 56px; border-radius: 50%; background: linear-gradient(135deg, var(--red-bright), var(--red-deep)); display: grid; place-items: center; color: white; font-size: 16px; font-weight: 700; box-shadow: 0 6px 18px rgba(225, 29, 42, 0.35); }
.founder-info h5 { font-size: 1rem; font-weight: 700; margin-bottom: 2px; color: var(--text-primary); }
.founder-info span { font-size: 0.85rem; color: var(--text-muted); }
@media (max-width: 1024px) {
  .story-grid { grid-template-columns: 1fr; gap: 50px; }
  .story-visual { max-width: 480px; margin: 0 auto; aspect-ratio: 1; }
}

/* ========== CONTACT PAGE ========== */
.contact-info-section { padding: 60px 0 80px; }
.contact-info-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.cinfo-card { padding: 32px 26px; text-align: center; background: var(--glass-bg); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border: 1px solid var(--glass-border); border-radius: var(--radius); transition: all 0.5s var(--ease-out); position: relative; overflow: hidden; }
.cinfo-card::before { content: ''; position: absolute; top: 0; left: 30px; right: 30px; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); opacity: 0.5; }
.cinfo-card:hover { transform: translateY(-6px); border-color: rgba(225, 29, 42, 0.35); box-shadow: 0 20px 40px rgba(225, 29, 42, 0.12); }
.cinfo-icon { width: 56px; height: 56px; margin: 0 auto 18px; border-radius: 14px; background: linear-gradient(135deg, rgba(225, 29, 42, 0.22), rgba(225, 29, 42, 0.04)); border: 1px solid rgba(225, 29, 42, 0.3); display: grid; place-items: center; color: var(--red-bright); transition: all 0.4s var(--ease-out); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); }
.cinfo-card:hover .cinfo-icon { transform: scale(1.06) rotate(-3deg); background: linear-gradient(135deg, rgba(225, 29, 42, 0.34), rgba(225, 29, 42, 0.1)); }
.cinfo-card h4 { font-size: 11px; font-weight: 600; color: var(--text-muted); letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 8px; }
.cinfo-card p { font-size: 0.95rem; font-weight: 500; color: var(--text-primary); line-height: 1.5; }
.cinfo-card p a { transition: color 0.3s; }
.cinfo-card p a:hover { color: var(--red-bright); }
.contact-split { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; padding: 0 0 100px; }
.contact-split .form-card { max-width: none; padding: 44px 40px; margin: 0; }
.contact-split .map-wrap { height: 100%; min-height: 560px; }
@media (max-width: 1024px) {
  .contact-info-grid { grid-template-columns: 1fr 1fr; }
  .contact-split { grid-template-columns: 1fr; gap: 28px; }
  .contact-split .map-wrap { min-height: 400px; }
}
@media (max-width: 768px) {
  .contact-info-grid { grid-template-columns: 1fr; }
}

/* ========== SERVICES PAGE ========== */
.svc-detail-section { padding: 60px 0 100px; }
.svc-detail-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.svc-detail-card { padding: 40px 32px; background: var(--glass-bg); backdrop-filter: blur(22px) saturate(160%); -webkit-backdrop-filter: blur(22px) saturate(160%); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); position: relative; overflow: hidden; transition: all 0.5s var(--ease-out); display: flex; gap: 24px; align-items: flex-start; }
.svc-detail-card::before { content: ''; position: absolute; top: 0; left: 30px; right: 30px; height: 1px; background: linear-gradient(90deg, transparent, var(--red), transparent); opacity: 0.5; }
.svc-detail-card:hover { transform: translateY(-6px); border-color: rgba(225, 29, 42, 0.3); background: var(--glass-bg-strong); box-shadow: 0 20px 50px rgba(225, 29, 42, 0.12); }
.svc-detail-ico { width: 84px; height: 84px; flex-shrink: 0; border-radius: 20px; background: linear-gradient(135deg, rgba(225, 29, 42, 0.22), rgba(225, 29, 42, 0.04)); border: 1px solid rgba(225, 29, 42, 0.3); display: grid; place-items: center; color: var(--red-bright); position: relative; overflow: hidden; transition: all 0.4s var(--ease-out); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); }
.svc-detail-ico::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.18), transparent 60%); pointer-events: none; }
.svc-detail-card:hover .svc-detail-ico { transform: scale(1.06) rotate(-3deg); background: linear-gradient(135deg, rgba(225, 29, 42, 0.34), rgba(225, 29, 42, 0.1)); }
.svc-detail-ico svg { width: 48px; height: 48px; position: relative; z-index: 1; }
.svc-detail-body { flex: 1; min-width: 0; }
.svc-detail-body h3 { font-size: 1.35rem; font-weight: 700; margin-bottom: 8px; letter-spacing: -0.015em; color: var(--text-primary); }
.svc-detail-body p { color: var(--text-secondary); font-size: 0.95rem; line-height: 1.65; margin-bottom: 14px; font-weight: 300; }
.svc-detail-tag { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; background: rgba(225, 29, 42, 0.08); border: 1px solid rgba(225, 29, 42, 0.2); border-radius: 100px; font-size: 11px; font-weight: 600; color: var(--red-bright); text-transform: uppercase; letter-spacing: 0.1em; }
.svc-detail-tag::before { content: ''; width: 5px; height: 5px; background: var(--red-bright); border-radius: 50%; box-shadow: 0 0 6px var(--red-bright); }
@media (max-width: 768px) {
  .svc-detail-grid { grid-template-columns: 1fr; }
  .svc-detail-card { flex-direction: column; gap: 18px; padding: 30px 22px; }
}

/* =====================================================================
   LUXURY ENHANCEMENT LAYER — premium polish on top of the base design
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,500;0,600;0,700;1,500;1,600;1,700&display=swap');

:root {
  --gold: #d4a955;
  --gold-bright: #f0c674;
  --gold-deep: #8a6f33;
  --gold-glow: rgba(212, 169, 85, 0.35);
  --champagne: #e8d4a8;
  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --shadow-luxury: 0 30px 80px rgba(0,0,0,0.55), 0 0 0 1px rgba(212,169,85,0.08), inset 0 1px 0 rgba(255,255,255,0.06);
}

/* ---- Premium film grain overlay (always-on, super subtle) ---- */
body::before {
  background:
    radial-gradient(ellipse 60% 50% at 20% 0%, rgba(225, 29, 42, 0.12), transparent 60%),
    radial-gradient(ellipse 45% 40% at 90% 30%, rgba(212, 169, 85, 0.06), transparent 60%),
    radial-gradient(ellipse 50% 40% at 100% 50%, rgba(225, 29, 42, 0.05), transparent 60%),
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(20, 20, 30, 0.6), transparent 70%);
}
.lux-grain {
  position: fixed; inset: 0; z-index: 1;
  pointer-events: none; opacity: 0.5; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ---- Premium scroll progress indicator ---- */
.lux-progress {
  position: fixed; top: 0; left: 0; height: 2px; width: 0%;
  background: linear-gradient(90deg, var(--red-bright), var(--gold-bright), var(--red));
  background-size: 200% 100%;
  z-index: 200; pointer-events: none;
  box-shadow: 0 0 12px var(--red-glow), 0 0 22px rgba(212,169,85,0.25);
  animation: lux-progress-shimmer 4s linear infinite;
  transition: width 0.1s linear;
}
@keyframes lux-progress-shimmer { to { background-position: -200% 0; } }

/* ---- Premium page loader ---- */
.lux-loader {
  position: fixed; inset: 0; z-index: 9999;
  background: radial-gradient(circle at center, #0d0d10 0%, #08080a 60%, #050507 100%);
  display: grid; place-items: center;
  transition: opacity 0.7s var(--ease-out), visibility 0.7s;
}
.lux-loader.done { opacity: 0; visibility: hidden; }
.lux-loader-inner {
  position: relative; width: 130px; height: 130px;
  display: grid; place-items: center;
}
.lux-loader-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 1px solid transparent;
  background: conic-gradient(from 0deg, transparent 0deg, var(--red-bright) 60deg, var(--gold-bright) 110deg, transparent 180deg, transparent 360deg) border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  animation: lux-spin 1.4s linear infinite;
  filter: drop-shadow(0 0 8px var(--red-glow));
}
.lux-loader-ring.r2 {
  inset: 14px;
  background: conic-gradient(from 180deg, transparent 0deg, var(--gold-bright) 70deg, transparent 180deg, transparent 360deg) border-box;
  animation-direction: reverse; animation-duration: 2s;
  filter: drop-shadow(0 0 6px var(--gold-glow));
}
.lux-loader-mark {
  position: relative; z-index: 2;
  width: 64px; height: 64px; border-radius: 50%;
  background: white; padding: 6px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5), 0 0 60px var(--red-glow);
  display: grid; place-items: center; overflow: hidden;
}
.lux-loader-mark img { width: 100%; height: 100%; object-fit: contain; }
.lux-loader-text {
  position: absolute; top: calc(100% + 26px); left: 50%; transform: translateX(-50%);
  font-family: var(--serif); font-style: italic;
  font-size: 14px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--gold-bright); white-space: nowrap;
  background: linear-gradient(90deg, transparent, var(--gold-bright), transparent);
  background-size: 200% 100%; -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: lux-shine 2.4s linear infinite;
}
@keyframes lux-spin { to { transform: rotate(360deg); } }
@keyframes lux-shine { to { background-position: -200% 0; } }

/* ---- Custom cursor follower (desktop only) ---- */
@media (hover: hover) and (pointer: fine) {
  .lux-cursor {
    position: fixed; top: 0; left: 0; pointer-events: none; z-index: 199;
    width: 320px; height: 320px; border-radius: 50%;
    background: radial-gradient(circle at center, rgba(225,29,42,0.18) 0%, rgba(212,169,85,0.06) 35%, transparent 70%);
    transform: translate(-50%, -50%);
    transition: opacity 0.35s, width 0.35s var(--ease-out), height 0.35s var(--ease-out);
    mix-blend-mode: screen; opacity: 0;
    filter: blur(2px);
  }
  .lux-cursor.active { opacity: 1; }
  .lux-cursor.focus { width: 460px; height: 460px; }
  .lux-cursor-dot {
    position: fixed; top: 0; left: 0; pointer-events: none; z-index: 200;
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--red-bright); transform: translate(-50%, -50%);
    box-shadow: 0 0 10px var(--red-bright), 0 0 24px var(--red-glow);
    transition: opacity 0.3s, width 0.25s var(--ease-out), height 0.25s var(--ease-out), background 0.25s;
    opacity: 0;
  }
  .lux-cursor-dot.active { opacity: 1; }
  .lux-cursor-dot.focus { width: 14px; height: 14px; background: var(--gold-bright); box-shadow: 0 0 14px var(--gold-bright), 0 0 30px var(--gold-glow); }
}

/* ---- Premium typography refinement: serif accent ---- */
.hero h1 .accent,
.section-title .accent,
.contact-card h2 .accent,
.story-text h2 .accent,
.page-header h1 .accent,
.form-header h3 .accent {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 600;
  letter-spacing: -0.005em;
  background: linear-gradient(180deg, var(--red-bright) 0%, var(--red) 55%, var(--gold) 130%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  text-shadow: 0 0 40px rgba(225,29,42,0.25);
  position: relative;
}
.hero h1 .accent::after { background: var(--red); opacity: 0.25; }

/* ---- Hero pill: refined gold border accent ---- */
.hero-pill {
  background: linear-gradient(135deg, rgba(13,13,16,0.85), rgba(13,13,16,0.6));
  border-image: linear-gradient(135deg, rgba(212,169,85,0.35), rgba(225,29,42,0.3), rgba(212,169,85,0.15)) 1;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 4px 20px rgba(0,0,0,0.4);
}
.hero-pill::before {
  background: linear-gradient(180deg, var(--gold-bright), var(--red-bright), var(--gold-deep));
}
.hero-pill .pill-icon {
  background: linear-gradient(135deg, rgba(225,29,42,0.25), rgba(212,169,85,0.18));
  color: var(--gold-bright);
  box-shadow: 0 0 12px rgba(212,169,85,0.3);
  animation: lux-icon-glow 3s ease-in-out infinite;
}
@keyframes lux-icon-glow {
  0%,100% { box-shadow: 0 0 8px rgba(212,169,85,0.2); }
  50% { box-shadow: 0 0 16px rgba(212,169,85,0.5); }
}

/* ---- Premium section eyebrow with gold dot ---- */
.eyebrow {
  position: relative;
  background: rgba(225, 29, 42, 0.08);
  border: 1px solid rgba(225, 29, 42, 0.18);
  padding: 6px 16px 6px 30px;
  border-radius: 100px;
}
.eyebrow::before {
  content: ''; display: block;
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  width: 8px; height: 8px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--gold-bright), var(--gold-deep));
  box-shadow: 0 0 10px var(--gold-glow);
  margin: 0;
  animation: lux-icon-glow 2.4s ease-in-out infinite;
}

/* ---- Premium animated gradient border on key cards ---- */
.service-card, .why-card, .process-card, .stat-card, .testimonial-card,
.svc-detail-card, .cinfo-card, .form-card, .contact-card, .founder-card {
  position: relative;
}
.service-card::before, .why-card::before, .process-card::before, .stat-card::before,
.svc-detail-card::before, .cinfo-card::before, .testimonial-card::before, .founder-card::before {
  background: linear-gradient(90deg, transparent, var(--gold-bright), var(--red), transparent) !important;
  height: 1px !important; opacity: 0.55;
}
.service-card:hover::before, .why-card:hover::before, .process-card:hover::before,
.stat-card:hover::before, .svc-detail-card:hover::before, .cinfo-card:hover::before,
.testimonial-card:hover::before, .founder-card:hover::before {
  opacity: 1;
}

/* ---- 3D tilt scaffolding ---- */
.lux-tilt {
  transform-style: preserve-3d;
  transition: transform 0.5s var(--ease-out), box-shadow 0.5s var(--ease-out);
  will-change: transform;
}
.lux-tilt > * { transform: translateZ(0); }
.lux-tilt-inner { transform: translateZ(40px); }
.lux-tilt-shine {
  position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), rgba(255,255,255,0.08), transparent 40%);
  opacity: 0; transition: opacity 0.4s; pointer-events: none; z-index: 2;
}
.lux-tilt:hover .lux-tilt-shine { opacity: 1; }

/* ---- Premium button refinements (magnetic-ready) ---- */
.btn { will-change: transform; transition: transform 0.25s var(--ease-out), box-shadow 0.4s var(--ease-out), background 0.4s, border-color 0.4s; }
.btn-primary {
  background: linear-gradient(135deg, var(--red-bright) 0%, var(--red) 40%, var(--red-deep) 75%, #4a0810 100%);
  border: 1px solid rgba(212,169,85,0.18);
  box-shadow: 0 6px 24px rgba(225,29,42,0.4), 0 0 0 1px rgba(212,169,85,0.08), inset 0 1px 0 rgba(255,255,255,0.22), inset 0 -1px 0 rgba(0,0,0,0.25);
}
.btn-primary:hover {
  box-shadow: 0 14px 36px rgba(225,29,42,0.55), 0 0 0 1px rgba(212,169,85,0.22), inset 0 1px 0 rgba(255,255,255,0.28), inset 0 -1px 0 rgba(0,0,0,0.25), 0 0 40px rgba(212,169,85,0.1);
}
.btn-ghost {
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}
.btn-ghost:hover {
  border-image: linear-gradient(135deg, var(--gold-bright), var(--red-bright), var(--gold-deep)) 1;
  box-shadow: 0 8px 24px rgba(212,169,85,0.18), inset 0 1px 0 rgba(255,255,255,0.06);
}

/* ---- Nav refinement: thin gold under-glow when scrolled ---- */
nav.scrolled .nav-inner {
  border-color: rgba(212,169,85,0.18);
  box-shadow: var(--shadow-soft), 0 0 30px rgba(225,29,42,0.08), 0 0 60px rgba(212,169,85,0.05);
}
.nav-cta {
  background: linear-gradient(135deg, var(--red-bright), var(--red), var(--red-deep));
  border: 1px solid rgba(212,169,85,0.2);
  box-shadow: 0 4px 18px rgba(225, 29, 42, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.22);
}
.nav-cta:hover { box-shadow: 0 10px 28px rgba(225, 29, 42, 0.55), 0 0 22px rgba(212,169,85,0.18); }

/* ---- Service icon wrapper: gold-tinted hover glow ---- */
.service-card:hover .service-icon-wrap,
.why-card:hover .why-ico-wrap,
.process-card:hover .process-ico,
.stat-card:hover .stat-icon-wrap,
.svc-detail-card:hover .svc-detail-ico,
.cinfo-card:hover .cinfo-icon {
  box-shadow:
    0 12px 32px rgba(225,29,42,0.35),
    0 0 22px rgba(212,169,85,0.18),
    inset 0 1px 0 rgba(255,255,255,0.12);
}

/* ---- Sparkle on hero gauge ---- */
.gauge-stage::after {
  content: ''; position: absolute; inset: -4%;
  background: conic-gradient(from 0deg, transparent 0deg, rgba(212,169,85,0.18) 30deg, transparent 60deg, transparent 360deg);
  border-radius: 50%; filter: blur(28px);
  animation: lux-spin 14s linear infinite; pointer-events: none; z-index: 0;
}

/* ---- Hero floating cards: refined gold accent ---- */
.hero-floating-card {
  background: linear-gradient(135deg, rgba(13,13,16,0.85), rgba(20,20,25,0.65));
  border: 1px solid;
  border-image: linear-gradient(135deg, rgba(212,169,85,0.32), rgba(255,255,255,0.05), rgba(225,29,42,0.18)) 1;
  box-shadow: var(--shadow-deep), 0 0 24px rgba(212,169,85,0.08);
}

/* ---- Marquee refinement ---- */
.marquee {
  background: linear-gradient(90deg, #4a0608 0%, var(--red-deep) 18%, var(--red) 50%, var(--red-deep) 82%, #4a0608 100%);
  box-shadow: 0 6px 30px rgba(225,29,42,0.22), inset 0 1px 0 rgba(212,169,85,0.18), inset 0 -1px 0 rgba(0,0,0,0.4);
}
.marquee::after, .marquee-track::after { content: ''; }
.marquee-pair span:not(svg span) { background: linear-gradient(180deg, #fff 30%, #f0d8a8 130%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* ---- Testimonial cards: serif quote ---- */
.testimonial-card p {
  font-family: var(--serif);
  font-size: 1.18rem;
  font-weight: 500;
  font-style: italic;
  line-height: 1.55;
  color: #ece8df;
}
.testimonial-card p::before { content: '"'; color: var(--gold-bright); font-size: 1.4em; margin-right: 4px; }
.testimonial-card p::after  { content: '"'; color: var(--gold-bright); font-size: 1.4em; margin-left: 4px; }

/* ---- Stats: gold-tinted gradient on numbers ---- */
.stat-number {
  background: linear-gradient(180deg, #fff 20%, var(--gold-bright) 90%, var(--gold-deep) 130%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 4px 12px rgba(212,169,85,0.15));
}
.stat-number .plus { color: var(--red-bright); -webkit-text-fill-color: var(--red-bright); }

/* ---- Footer luxury accent ---- */
footer { background: linear-gradient(180deg, var(--bg-deep) 0%, #07070a 60%, #050507 100%); }
footer::before { background: linear-gradient(90deg, transparent, var(--gold-bright), var(--red), var(--gold-bright), transparent); height: 1px; }
.footer-bottom .credit span { color: var(--gold-bright); }

/* ---- Section divider — premium animated SVG-like underline ---- */
section.svc-detail-section + .why-section::before,
section + section:not(.marquee + section)::before, .why-section::before, #find-us::before {
  background: linear-gradient(90deg, transparent, var(--gold-bright), var(--red), var(--gold-bright), transparent) !important;
  height: 1px !important;
}

/* ---- Form field refinement ---- */
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: rgba(212,169,85,0.55);
  box-shadow: 0 0 0 3px rgba(212,169,85,0.15), 0 0 18px rgba(225,29,42,0.12);
}
.field label { color: var(--gold-bright); opacity: 0.85; }

/* ---- Founder quote serif treatment ---- */
.founder-quote {
  font-family: var(--serif);
  font-size: 1.55rem;
  line-height: 1.4;
  font-weight: 500;
}
.founder-quote-mark { color: var(--gold); opacity: 0.22; }

/* ---- Premium reveal: clip-path mask reveal for headlines ---- */
.lux-reveal-mask {
  display: inline-block;
  background: linear-gradient(110deg, transparent 0%, transparent 40%, rgba(212,169,85,0.2) 50%, transparent 60%, transparent 100%);
  background-size: 200% 100%;
  background-position: 200% 0;
  -webkit-background-clip: text; background-clip: text;
  animation: lux-shine-headline 4s ease-in-out infinite;
  animation-delay: 1.2s;
}
@keyframes lux-shine-headline {
  0%, 60%, 100% { background-position: 200% 0; }
  80% { background-position: -200% 0; }
}

/* ---- Subtle floating particles container ---- */
.lux-particles {
  position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 0;
}
.lux-particle {
  position: absolute; width: 4px; height: 4px; border-radius: 50%;
  background: var(--gold-bright);
  box-shadow: 0 0 8px var(--gold-bright), 0 0 16px var(--gold-glow);
  opacity: 0;
  animation: lux-float-up linear infinite;
}
@keyframes lux-float-up {
  0% { transform: translateY(0) translateX(0); opacity: 0; }
  10% { opacity: 0.7; }
  90% { opacity: 0.4; }
  100% { transform: translateY(-220px) translateX(var(--drift, 30px)); opacity: 0; }
}

/* ---- Subtle border-glow conic animation on key cards ---- */
.service-card, .why-card, .process-card, .testimonial-card, .svc-detail-card, .cinfo-card, .stat-card {
  isolation: isolate;
}
.service-card::after, .why-card::after, .process-card::after { z-index: 0; }

/* ---- Premium hover halo for service-card / why-card ---- */
.service-card .lux-halo,
.why-card .lux-halo,
.process-card .lux-halo,
.svc-detail-card .lux-halo,
.testimonial-card .lux-halo {
  position: absolute; inset: -1px; border-radius: inherit; pointer-events: none;
  background: conic-gradient(from var(--ang, 0deg), transparent 0deg, rgba(212,169,85,0.5) 30deg, rgba(225,29,42,0.7) 60deg, transparent 90deg, transparent 360deg);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding: 1px;
  opacity: 0; transition: opacity 0.6s var(--ease-out);
  animation: lux-conic-rotate 4s linear infinite;
  z-index: 3;
}
@property --ang { syntax: '<angle>'; initial-value: 0deg; inherits: false; }
@keyframes lux-conic-rotate { to { --ang: 360deg; } }
.service-card:hover .lux-halo,
.why-card:hover .lux-halo,
.process-card:hover .lux-halo,
.svc-detail-card:hover .lux-halo,
.testimonial-card:hover .lux-halo { opacity: 1; }

/* ---- Section header: serif italic accent for "premium" feel ---- */
.section-title { font-weight: 700; }
.section-header .section-subtitle { color: rgba(180, 180, 195, 0.85); }

/* ---- Refined nav-logo glow on hover ---- */
.nav-logo .logo-frame { transition: transform 0.4s var(--ease-out), box-shadow 0.4s; }
.nav-logo:hover .logo-frame {
  transform: rotate(-6deg) scale(1.05);
  box-shadow: 0 6px 24px rgba(225,29,42,0.3), 0 0 0 1px rgba(212,169,85,0.3);
}

/* ---- Animated underline for nav links ---- */
.nav-menu a {
  position: relative; overflow: hidden;
}
.nav-menu a::before {
  content: ''; position: absolute; bottom: 6px; left: 50%; transform: translateX(-50%);
  width: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-bright), transparent);
  transition: width 0.4s var(--ease-out);
}
.nav-menu a:hover::before { width: 60%; }

/* ---- Better contact info icon hover ---- */
.contact-info-item:hover .contact-info-icon {
  background: linear-gradient(135deg, rgba(225,29,42,0.34), rgba(212,169,85,0.18));
  border-color: rgba(212,169,85,0.4);
  transform: scale(1.06) rotate(-4deg);
  box-shadow: 0 6px 18px rgba(225,29,42,0.3), 0 0 14px rgba(212,169,85,0.15);
}

/* ---- Premium scrollbar (webkit) ---- */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg-void); }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--red-bright), var(--red-deep) 60%, #3a060c 100%);
  border-radius: 100px; border: 2px solid var(--bg-void);
}
::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, var(--gold-bright), var(--red-bright) 50%, var(--red-deep) 100%); }

/* ---- Reduced motion respect ---- */
@media (prefers-reduced-motion: reduce) {
  .lux-cursor, .lux-cursor-dot, .lux-particle, .gauge-stage::after, .lux-progress { animation: none !important; transition: none !important; }
  .lux-loader { display: none; }
}

/* ---- Disable custom cursor on touch devices ---- */
@media (hover: none), (pointer: coarse) {
  .lux-cursor, .lux-cursor-dot { display: none; }
}

/* ---- Premium CTA banner accent (contact-card) ---- */
.contact-card {
  background:
    radial-gradient(circle at 80% 0%, rgba(225, 29, 42, 0.22), transparent 50%),
    radial-gradient(circle at 20% 100%, rgba(212, 169, 85, 0.12), transparent 55%),
    linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015));
}
.contact-card::before { background: linear-gradient(90deg, transparent, var(--gold-bright), var(--red), var(--gold-bright), transparent); }

/* ---- Page header polish ---- */
.page-header::before {
  background:
    radial-gradient(ellipse 60% 50% at 50% 0%, rgba(225, 29, 42, 0.14), transparent 60%),
    radial-gradient(ellipse 40% 30% at 30% 20%, rgba(212, 169, 85, 0.08), transparent 60%);
}
.breadcrumb { background: linear-gradient(135deg, rgba(13,13,16,0.7), rgba(20,20,25,0.5)); border-color: rgba(212,169,85,0.2); }

/* ---- Service-card / process-card on hover slight gold tint ---- */
.service-card:hover, .why-card:hover, .process-card:hover, .svc-detail-card:hover, .testimonial-card:hover, .stat-card:hover, .cinfo-card:hover {
  border-color: rgba(212,169,85,0.4) !important;
  box-shadow: 0 26px 60px rgba(225, 29, 42, 0.18), 0 0 0 1px rgba(212, 169, 85, 0.15), 0 0 40px rgba(212,169,85,0.06);
}

/* ---- Service CTA (button on cards) — premium gold hairline ---- */
.service-cta { border: 1px solid rgba(212,169,85,0.25); }
.service-cta:hover { border-color: rgba(212,169,85,0.5); }

/* ---- Hero h1 - subtle text glow for luxurious depth ---- */
.hero h1 { text-shadow: 0 0 30px rgba(225,29,42,0.05); }

/* ---- "Approved" badges feel: gold dot ---- */
.about-visual-badge::before, .story-badge::before {
  background: radial-gradient(circle at 30% 30%, var(--gold-bright), var(--gold-deep));
  box-shadow: 0 0 8px var(--gold-glow);
}

/* ---- Marquee item separator: gold dot ---- */
.marquee-item { gap: 56px; }
.marquee-pair::after {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--gold-bright), var(--gold-deep));
  box-shadow: 0 0 8px var(--gold-glow); opacity: 0.7; margin-left: 12px;
}

/* ---- Accent on map card ---- */
.map-info-card { border-color: rgba(212,169,85,0.22); box-shadow: 0 12px 40px rgba(0,0,0,0.55), inset 0 1px 0 rgba(212,169,85,0.1); }
.map-rating strong { color: var(--gold-bright); }

