/* ORVEXIA GLOBAL BASE */
html,
body {
  width: 100%;
  min-height: 100%;
  overflow-x: hidden;
}

body {
  font-family: 'Inter', Arial, sans-serif;
  font-variant: small-caps;
  background: #000;
  color: #fff;
}

a{
  color:#fff;
  text-decoration: none;
}

a:hover{
  color:#EE1C25;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
span,
a,
button,
input,
textarea,
select,
label,
td,
th {
  font-family: 'Inter', Arial, sans-serif;
  font-variant: small-caps;
}

img,
video,
canvas,
iframe {
  max-width: 100%;
}

:root {
  --primary: #EE1C25;
  --dark: #000;
  --light: #fff;
  --muted: rgba(255, 255, 255, .62);
}

/* ================================================================
   RESET & BASE
================================================================ */
html {
  height: 100%;
}

body {
  background: #030308;
  color: #fff;
  height: 100%;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* ================================================================
   STARS CANVAS
================================================================ */
#stars-canvas {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

/* ================================================================
   SHARE OVERLAY
================================================================ */
.share-overlay {
  position: fixed;
  inset: 0;
  z-index: 2000;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}

.share-overlay.active {
  pointer-events: auto;
}

.share-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 3, 8, 0.82);
  backdrop-filter: blur(8px);
  opacity: 0;
  transition: opacity 0.4s;
}

.share-overlay.active .share-backdrop {
  opacity: 1;
}

.share-card {
  position: relative;
  z-index: 1;
  background: rgba(12, 12, 22, 0.98);
  border: 1px solid rgba(238, 28, 37, 0.15);
  border-radius: 2px;
  padding: 40px;
  width: min(380px, 90vw);
  transform: translateY(30px) scale(0.95);
  opacity: 0;
  transition: transform 0.45s cubic-bezier(0.2, 0.9, 0.4, 1), opacity 0.4s;
}

.share-overlay.active .share-card {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.share-card-title {
  font-size: 10.4px;
  letter-spacing: 4px;
  color: rgba(255, 255, 255, 0.3);
  margin-bottom: 24px;
}

.share-buttons {
  display: flex;
  flex-direction: column;
  gap: 11.2px;
}

.share-btn {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 13.6px 19.2px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 2px;
  color: #fff;
  font-size: 13.12px;
  font-weight: 500;
  letter-spacing: 1px;
  cursor: pointer;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: color 0.3s, border-color 0.3s;
}

.share-btn::before {
  content: '';
  position: absolute;
  top: 0;
  right: -100%;
  bottom: 0;
  width: 100%;
  background: rgba(238, 28, 37, 0.08);
  transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.share-btn:hover::before {
  right: 0;
}

.share-btn:hover {
  border-color: rgba(238, 28, 37, 0.3);
  color: #EE1C25;
}

.share-btn i {
  width: 16px;
  text-align: center;
  flex-shrink: 0;
  position: relative;
}

.share-url-row {
  margin-top: 19.2px;
  display: flex;
  gap: 8px;
}

.share-url-input {
  flex: 1;
  padding: 11.2px 16px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 2px;
  color: rgba(255, 255, 255, 0.5);
  font-size: 12px;
  outline: none;
  user-select: text;
}

.share-copy-btn {
  padding: 11.2px 19.2px;
  background: rgba(238, 28, 37, 0.1);
  border: 1px solid rgba(238, 28, 37, 0.25);
  border-radius: 2px;
  color: #EE1C25;
  font-size: 11.52px;
  font-weight: 700;
  letter-spacing: 2px;
  cursor: pointer;
  transition: all 0.3s;
}

.share-copy-btn:hover {
  background: rgba(238, 28, 37, 0.2);
}

.share-close {
  position: absolute;
  top: 12.8px;
  right: 16px;
  background: none;
  border: none;
  color: rgba(255, 255, 255, 0.3);
  font-size: 22.4px;
  cursor: pointer;
  transition: color 0.3s;
  line-height: 1;
}

.share-close:hover {
  color: #EE1C25;
}

/* ================================================================
   TOPNAV
================================================================ */
.topnav {
  position: relative;
  z-index: 150;
  height: 60px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 clamp(16px, 3vw, 32px);
  background: rgba(8, 8, 14, 0.85);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}

.logo-img {
  height: 46px;
  width: auto;
  object-fit: contain;
}

.logo-text {
  font-size: 16.8px;
  font-weight: 800;
  letter-spacing: 3px;
  color: #fff;
  line-height: 1;
}

.logo-text small {
  display: block;
  font-size: 7.04px;
  letter-spacing: 4px;
  color: rgba(255, 255, 255, 0.28);
  margin-top: 3px;
}

.nav-center {
  flex: 1;
  display: flex;
  justify-content: center;
  gap: 40px;
}

.nav-contact {
  display: flex;
  align-items: center;
  gap: 9.6px;
  font-size: 10.88px;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.28);
}

.nav-contact strong {
  color: #fff;
  font-weight: 600;
}

.nav-sep {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(238, 28, 37, 0.5);
}

.menu-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  background: none;
  border: none;
  cursor: pointer;
  color: #fff;
  font-size: 11.2px;
  font-weight: 700;
  letter-spacing: 3px;
  transition: color 0.3s;
  padding: 8px 0;
  flex-shrink: 0;
}

.menu-btn:hover {
  color: #EE1C25;
}

.burger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: 22px;
}

.burger span {
  display: block;
  height: 1.5px;
  background: currentColor;
  border-radius: 2px;
  transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  transform-origin: left center;
}

.burger span:nth-child(2) {
  width: 65%;
}

.menu-btn.open .burger span:nth-child(1) {
  transform: rotate(45deg) translateY(-1px);
}

.menu-btn.open .burger span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.menu-btn.open .burger span:nth-child(3) {
  transform: rotate(-45deg) translateY(1px);
}

/* ================================================================
   MAIN LAYOUT — 3 columns
================================================================ */
.page-layout {
  flex: 1;
  display: flex;
  overflow: hidden;
  position: relative;
  z-index: 1;
  min-height: 0;
}

/* ================================================================
   LEFT SIDEBAR (fixed, no scroll)
================================================================ */
.left-sidebar {
  width: clamp(50px, 8vw, 88px);
  flex-shrink: 0;
  background: rgba(6, 6, 12, 0.78);
  border-right: 1px solid rgba(255, 255, 255, 0.06);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 24px 0 16px;
  z-index: 10;
}

.brand-vert {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-size: 8.32px;
  letter-spacing: 4px;
  color: rgba(255, 255, 255, 0.14);
  font-weight: 600;
  margin-bottom: auto;
}

.sidebar-divider {
  width: 20px;
  height: 1px;
  background: rgba(255, 255, 255, 0.07);
  margin: 16px 0;
}

.social-icons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.social-icons a {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.22);
  text-decoration: none;
  transition: color 0.3s, transform 0.3s;
}

.social-icons a:hover {
  color: #EE1C25;
  transform: scale(1.2);
}

.social-icons i {
  font-size: 13px;
}

.share-vert {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-size: 8px;
  letter-spacing: 4px;
  color: rgba(255, 255, 255, 0.12);
  margin-top: 19.2px;
  cursor: pointer;
  transition: color 0.3s;
}

.share-vert:hover {
  color: #EE1C25;
}

/* ================================================================
   CONTENT AREA
================================================================ */
.content-area {
  flex: 1;
  display: flex;
  overflow: hidden;
  min-height: 0;
}

/* LEFT SCROLLABLE PANEL */
.left-panel {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0;
  scrollbar-width: none;
  -ms-overflow-style: none;
  position: relative;
}

.left-panel::-webkit-scrollbar {
  display: none;
}

.left-panel::before {
  content: '';
  position: fixed;
  top: 60px;
  bottom: 0;
  left: clamp(50px, 8vw, 88px);
  width: clamp(55px, 13vw, 190px);
  pointer-events: none;
  background-image:
    radial-gradient(circle, rgba(238, 28, 37, 0.12) 1px, transparent 1px),
    linear-gradient(rgba(238, 28, 37, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(238, 28, 37, 0.025) 1px, transparent 1px);
  background-size: 26px 26px, 80px 80px, 80px 80px;
  z-index: 0;
  animation: driftDots 18s linear infinite;
}

@keyframes driftDots {
  0% {
    background-position: 0 0, 0 0, 0 0;
  }

  100% {
    background-position: 52px 52px, 80px 80px, 80px 80px;
  }
}

.extra-spacer {
  width: clamp(55px, 13vw, 190px);
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
  pointer-events: none;
}

.dot-grid {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(238, 28, 37, 0.18) 1px, transparent 1px);
  background-size: 26px 26px;
  animation: driftDots 18s linear infinite;
}

.scan-line {
  position: absolute;
  top: -60%;
  left: 50%;
  width: 1px;
  height: 60%;
  background: linear-gradient(to bottom, transparent, rgba(238, 28, 37, 0.4), transparent);
  animation: scanDown 4s ease-in-out infinite;
}

@keyframes scanDown {
  0% {
    top: -60%;
    opacity: 0;
  }

  15% {
    opacity: 1;
  }

  85% {
    opacity: 1;
  }

  100% {
    top: 120%;
    opacity: 0;
  }
}

.spin-ring {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: clamp(36px, 5vw, 64px);
  height: clamp(36px, 5vw, 64px);
  border: 1px solid rgba(238, 28, 37, 0.2);
  border-top-color: rgba(238, 28, 37, 0.65);
  border-radius: 50%;
  animation: spinRing 9s linear infinite;
}

@keyframes spinRing {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

.plus-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: clamp(16px, 2.5vw, 26px);
  color: rgba(238, 28, 37, 0.25);
  animation: pulsePlus 3s ease-in-out infinite;
  line-height: 1;
}

@keyframes pulsePlus {

  0%,
  100% {
    opacity: 0.25;
    transform: translate(-50%, -50%) scale(1);
  }

  50% {
    opacity: 0.6;
    transform: translate(-50%, -50%) scale(1.18);
  }
}

.bracket {
  position: absolute;
  width: 16px;
  height: 16px;
  border-color: rgba(238, 28, 37, 0.14);
  border-style: solid;
}

.bracket.tl {
  top: 16px;
  left: 16px;
  border-width: 1px 0 0 1px;
}

.bracket.br {
  bottom: 16px;
  right: 16px;
  border-width: 0 1px 1px 0;
}

.scroll-content {
  padding: 64px 56px 80px clamp(24px, 3vw, 40px);
  position: relative;
  z-index: 1;
}

/* ================================================================
   SECTION — ABOUT INTRO
================================================================ */
.about-eyebrow {
  display: flex;
  align-items: center;
  gap: 12.8px;
  margin-bottom: 32px;
  animation: fadeSlideUp 0.7s 0.1s ease both;
}

.about-eyebrow-line {
  display: block;
  width: 36px;
  height: 2px;
  background: #EE1C25;
}

.about-eyebrow span {
  font-size: 11.2px;
  letter-spacing: 5px;
  color: rgba(255, 255, 255, 0.45);
  font-weight: 500;
}

.about-title {
  font-size: clamp(32px, 5vw, 60.8px);
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1.0;
  color: #fff;
  margin-bottom: 25.6px;
  animation: fadeSlideUp 0.7s 0.2s ease both;
}

.about-title em {
  font-style: normal;
  color: #EE1C25;
}

.about-intro-text {
  font-size: clamp(13.12px, 1.5vw, 14.4px);
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.85;
  max-width: 600px;
  font-weight: 300;
  margin-bottom: 48px;
  animation: fadeSlideUp 0.7s 0.3s ease both;
}

/* ================================================================
   TWO COLUMN
================================================================ */
.about-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-bottom: 64px;
  animation: fadeSlideUp 0.7s 0.35s ease both;
}

.about-col-text h3 {
  font-size: clamp(22.4px, 3vw, 30.4px);
  font-weight: 900;
  letter-spacing: 1px;
  color: #fff;
  margin-bottom: 19.2px;
}

.about-col-text h3 span {
  color: #EE1C25;
}

.about-col-text p {
  font-size: 13.12px;
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.9;
  font-weight: 300;
  letter-spacing: 0.02em;
}

.about-col-visual {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.img-placeholder {
  width: 100%;
  aspect-ratio: 4/3;
  background-image: url('../images/orvexia-studio.png');
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  border: 1px solid rgba(238, 28, 37, 0.12);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 12.8px;
  color: rgba(238, 28, 37, 0.3);
  font-size: 10.4px;
  letter-spacing: 3px;
}

.img-placeholder i {
  font-size: 40px;
  opacity: 0.3;
}

.video-link {
  display: inline-flex;
  align-items: center;
  gap: 12.8px;
  font-size: 11.52px;
  letter-spacing: 3px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  transition: color 0.3s;
}

.play-btn {
  width: 36px;
  height: 36px;
  border: 1px solid rgba(238, 28, 37, 0.4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
  flex-shrink: 0;
}

.play-btn i {
  font-size: 12px;
  margin-left: 2px;
}

.video-link:hover {
  color: #EE1C25;
}

.video-link:hover .play-btn {
  background: rgba(238, 28, 37, 0.12);
  border-color: #EE1C25;
}

/* ================================================================
   DETAIL SECTION
================================================================ */
.detail-section {
  margin-bottom: 64px;
  padding: 40px;
  background: rgba(255, 255, 255, 0.022);
  border: 1px solid rgba(255, 255, 255, 0.055);
  border-radius: 2px;
  animation: fadeSlideUp 0.7s 0.4s ease both;
}

.detail-section h3 {
  font-size: clamp(19.2px, 2.5vw, 27.2px);
  font-weight: 900;
  letter-spacing: 1px;
  color: #fff;
  margin-bottom: 19.2px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.detail-section h3 span {
  color: #EE1C25;
}

.detail-section p {
  font-size: 13.6px;
  color: rgba(255, 255, 255, 0.48);
  line-height: 1.9;
  font-weight: 300;
  margin-bottom: 16px;
}

/* ================================================================
   STATS COUNTERS (0 to target animation)
================================================================ */
.stats-section {
  margin-bottom: 64px;
  animation: fadeSlideUp 0.7s 0.45s ease both;
}

.stats-title {
  font-size: clamp(19.2px, 2.5vw, 27.2px);
  font-weight: 900;
  letter-spacing: 1px;
  color: #fff;
  margin-bottom: 6.4px;
}

.stats-sub {
  font-size: 12.48px;
  color: rgba(255, 255, 255, 0.35);
  letter-spacing: 2px;
  margin-bottom: 32px;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.stat-box {
  background: #030308;
  padding: 32px 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: background 0.3s;
}

.stat-box::before {
  content: '';
  position: absolute;
  bottom: -100%;
  left: 0;
  right: 0;
  height: 100%;
  background: rgba(238, 28, 37, 0.04);
  transition: bottom 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.stat-box:hover::before {
  bottom: 0;
}

.stat-num {
  font-size: clamp(35.2px, 4vw, 56px);
  font-weight: 900;
  color: #EE1C25;
  line-height: 1;
  display: block;
}

.stat-plus {
  font-size: 24px;
}

.stat-label {
  display: block;
  font-size: 9.92px;
  letter-spacing: 3px;
  color: rgba(255, 255, 255, 0.35);
  margin-top: 8px;
}

/* ================================================================
   FEATURE CARDS
================================================================ */
.feature-section {
  margin-bottom: 64px;
  animation: fadeSlideUp 0.7s 0.5s ease both;
}

.feature-header {
  margin-bottom: 32px;
}

.feature-header h3 {
  font-size: clamp(19.2px, 2.5vw, 27.2px);
  font-weight: 900;
  letter-spacing: 1px;
  color: #fff;
  margin-bottom: 4.8px;
}

.feature-header p {
  font-size: 12.48px;
  color: rgba(255, 255, 255, 0.35);
}

.features-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: rgba(255, 255, 255, 0.06);
}

.feature-card {
  background: #030308;
  padding: 32px;
  position: relative;
  overflow: hidden;
  transition: background 0.3s;
}

.feature-card::before {
  content: '';
  position: absolute;
  top: 0;
  right: -100%;
  bottom: 0;
  width: 100%;
  background: rgba(238, 28, 37, 0.04);
  transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.feature-card:hover::before {
  right: 0;
}

.feature-num {
  font-size: 9.6px;
  letter-spacing: 3px;
  color: rgba(238, 28, 37, 0.35);
  margin-bottom: 12.8px;
  display: block;
}

.feature-card h4 {
  font-size: 17.6px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #fff;
  margin-bottom: 11.2px;
}

.feature-card p {
  font-size: 12.8px;
  color: rgba(255, 255, 255, 0.4);
  line-height: 1.7;
  font-weight: 300;
}

/* ================================================================
   TESTIMONIALS CAROUSEL (horizontal swipe)
================================================================ */
.testimonials-section {
  margin-bottom: 64px;
  animation: fadeSlideUp 0.7s 0.55s ease both;
}

.section-heading {
  font-size: clamp(19.2px, 2.5vw, 27.2px);
  font-weight: 900;
  letter-spacing: 1px;
  color: #fff;
  margin-bottom: 4.8px;
}

.section-sub {
  font-size: 12.48px;
  color: rgba(255, 255, 255, 0.35);
  margin-bottom: 32px;
}

.swiper {
  width: 100%;
  height: auto;
  padding-bottom: 8px;
}

.testi-card {
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.06);
  padding: 28.8px;
  position: relative;
  transition: border-color 0.3s, background 0.3s;
  height: 100%;
}

.testi-card:hover {
  border-color: rgba(238, 28, 37, 0.2);
  background: rgba(238, 28, 37, 0.02);
}

.testi-quote {
  font-size: 40px;
  line-height: 1;
  color: rgba(238, 28, 37, 0.15);
  margin-bottom: 12.8px;
}

.testi-text {
  font-size: 13.12px;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.75;
  font-weight: 300;
  margin-bottom: 22.4px;
  font-style: italic;
}

.testi-author {
  display: flex;
  align-items: center;
  gap: 12.8px;
}

.avatar-fallback {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(238, 28, 37, 0.08);
  border: 1px solid rgba(238, 28, 37, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 700;
  color: #EE1C25;
  flex-shrink: 0;
}

.testi-info {
  flex: 1;
}

.testi-name {
  font-size: 15.2px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #fff;
}

.testi-role {
  font-size: 11.52px;
  color: rgba(255, 255, 255, 0.35);
}

.testi-via {
  display: inline-block;
  margin-top: 4.8px;
  font-size: 10.4px;
  letter-spacing: 2px;
  color: rgba(238, 28, 37, 0.5);
  text-decoration: none;
  transition: color 0.3s;
}

.testi-via:hover {
  color: #EE1C25;
}

/* Swiper navigation custom */
.swiper-button-next,
.swiper-button-prev {
  color: #EE1C25;
  opacity: 0.7;
  transition: opacity 0.3s;
  width: 30px;
  height: 30px;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 50%;
}

.swiper-button-next:after,
.swiper-button-prev:after {
  font-size: 19.2px;
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
  opacity: 1;
}

/* ================================================================
   GOOGLE REVIEWS SECTION
================================================================ */
.google-reviews {
  margin-bottom: 64px;
  animation: fadeSlideUp 0.7s 0.6s ease both;
}

.review-stars {
  display: flex;
  gap: 3.2px;
  margin: 8px 0 16px;
}

.star-filled {
  color: #fbbc04;
  font-size: 17.6px;
}

.star-half {
  color: #fbbc04;
  font-size: 17.6px;
  position: relative;
  display: inline-block;
}

.star-half:after {
  content: "★";
  position: absolute;
  left: 0;
  width: 50%;
  overflow: hidden;
  color: #fbbc04;
}

.star-empty {
  color: rgba(255, 255, 255, 0.2);
  font-size: 17.6px;
}

.google-rating-box {
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  padding: 19.2px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.google-icon {
  background: #fff;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.google-icon i {
  font-size: 22px;
  color: #4285F4;
}

.google-rating-text h4 {
  font-size: 14.4px;
  font-weight: 600;
}

.google-rating-text .stars {
  margin: 3.2px 0;
}

.google-review-count {
  font-size: 11.2px;
  color: rgba(255, 255, 255, 0.5);
}

.google-view-btn {
  margin-left: auto;
  background: rgba(238, 28, 37, 0.1);
  border: 1px solid rgba(238, 28, 37, 0.3);
  padding: 8px 16px;
  border-radius: 30px;
  font-size: 11.2px;
  letter-spacing: 1px;
  color: #fff;
  text-decoration: none;
  transition: all 0.3s;
}

.google-view-btn:hover {
  background: rgba(238, 28, 37, 0.2);
  color: #EE1C25;
}

/* ================================================================
   FOOTER & COPYRIGHT
================================================================ */
.about-footer {
  padding: 40px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.055);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-bottom: 32px;
  animation: fadeSlideUp 0.7s 0.65s ease both;
}

.footer-logo-text {
  font-size: 28.8px;
  font-weight: 900;
  letter-spacing: 2px;
  color: #fff;
  margin-bottom: 12.8px;
}

.footer-logo-text span {
  color: #EE1C25;
}

.footer-tagline {
  font-size: 12.8px;
  color: rgba(255, 255, 255, 0.38);
  line-height: 1.7;
  font-weight: 300;
  margin-bottom: 24px;
}

.contact-list {
  display: flex;
  flex-direction: column;
  gap: 9.6px;
}

.contact-item {
  display: flex;
  align-items: flex-start;
  gap: 9.6px;
  font-size: 12.8px;
  color: rgba(255, 255, 255, 0.45);
}

.contact-item strong {
  color: rgba(255, 255, 255, 0.7);
  min-width: 50px;
}

.contact-item a {
  color: rgba(255, 255, 255, 0.45);
  text-decoration: none;
  transition: color 0.3s;
}

.contact-item a:hover {
  color: #EE1C25;
}

.cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 12.8px;
  margin-top: 24px;
  padding: 13.6px 28.8px;
  border: 1px solid rgba(238, 28, 37, 0.3);
  font-size: 11.52px;
  letter-spacing: 3px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: color 0.3s, border-color 0.3s;
}

.cta-btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  bottom: 0;
  width: 100%;
  background: rgba(238, 28, 37, 0.1);
  transition: left 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.cta-btn:hover::before {
  left: 0;
}

.cta-btn:hover {
  color: #EE1C25;
  border-color: #EE1C25;
}

.footer-contact-form h4 {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 16px;
}

.footer-contact-form p {
  font-size: 12.8px;
  color: rgba(255, 255, 255, 0.35);
  line-height: 1.7;
}

.copyright {
  text-align: center;
  font-size: 10.4px;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.15);
  padding: 16px 0 32px;
}

/* ================================================================
   RIGHT FIXED PANEL (no changes)
================================================================ */
.right-fixed {
  width: min(380px, 34vw);
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
  border-left: 1px solid rgba(255, 255, 255, 0.06);
}

.right-bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: brightness(0.55) saturate(0.8);
  z-index: 0;
}

.right-bg-fallback {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:   linear-gradient(160deg, rgba(238, 28, 37, 0.85) 0%, rgba(10, 10, 30, 0.9) 60%),
  radial-gradient(ellipse at 60% 30%, rgba(238, 28, 37, 0.06) 0%, transparent 70%);;
}

.right-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to bottom, rgba(3, 3, 8, 0.35) 0%, rgba(3, 3, 8, 0.1) 35%, rgba(3, 3, 8, 0.1) 60%, rgba(3, 3, 8, 0.7) 100%);
}

.right-overlay::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(3, 3, 8, 0.4) 0%, transparent 30%);
}

.scroll-down-indicator {
  position: absolute;
  top: 32px;
  left: 32px;
  z-index: 10;
  display: flex;
  align-items: center;
  gap: 12.8px;
}

.scroll-down-line {
  width: 1px;
  height: 36px;
  background: linear-gradient(to bottom, rgba(238, 28, 37, 0.6), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}

@keyframes scrollPulse {

  0%,
  100% {
    opacity: 0.4;
    transform: scaleY(1);
  }

  50% {
    opacity: 1;
    transform: scaleY(1.2);
    transform-origin: top;
  }
}

.scroll-down-text {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-size: 8.32px;
  letter-spacing: 4px;
  color: rgba(255, 255, 255, 0.25);
  font-weight: 600;
}

.right-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 10;
  padding: 32px 32px 40px;
  background: linear-gradient(to top, rgba(3, 3, 8, 0.92) 0%, rgba(3, 3, 8, 0.6) 60%, transparent 100%);
}

.right-brand-title {
  font-size: clamp(35.2px, 4vw, 60.8px);
  font-weight: 900;
  letter-spacing: -0.01em;
  line-height: 0.92;
  color: #fff;
  margin-bottom: 19.2px;
}

.right-brand-title em {
  font-style: normal;
  color: #EE1C25;
  display: block;
}

.right-desc {
  font-size: clamp(12px, 1.2vw, 13.76px);
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.75;
  font-weight: 300;
  /* text-align: center; */
}

/* ================================================================
   MENU PANEL
================================================================ */
.menu-panel {
  position: fixed;
  top: 60px;
  right: 0;
  bottom: 0;
  width: 0;
  overflow: hidden;
  background: rgba(5, 5, 13, 0.98);
  backdrop-filter: blur(24px);
  border-left: 1px solid rgba(255, 255, 255, 0.06);
  z-index: 500;
  transition: width 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}

.menu-panel.open {
  width: min(320px, 88vw);
}

.mp-inner {
  width: min(320px, 88vw);
  height: 100%;
  position: relative;
  overflow: hidden;
}

.mp-screen {
  position: absolute;
  inset: 0;
  padding: 40px 32px 32px;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s;
}

.mp-main {
  transform: translateX(0);
  opacity: 1;
}

.mp-main.slide-out {
  transform: translateX(-100%);
  opacity: 0;
  pointer-events: none;
}

.mp-sub {
  transform: translateX(100%);
  opacity: 0;
  pointer-events: none;
}

.mp-sub.slide-in {
  transform: translateX(0);
  opacity: 1;
  pointer-events: auto;
}

.mp-label {
  font-size: 9.28px;
  letter-spacing: 4px;
  color: rgba(255, 255, 255, 0.18);
  padding-bottom: 12.8px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  margin-bottom: 16px;
}

.mp-nav {
  flex: 1;
}

.mp-nav a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 18.4px;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.32);
  text-decoration: none;
  padding: 14.08px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  position: relative;
  overflow: hidden;
  transition: color 0.3s, padding-left 0.3s;
}

.mp-nav a::before {
  content: '';
  position: absolute;
  top: 0;
  right: -100%;
  bottom: 0;
  width: 100%;
  background: rgba(238, 28, 37, 0.06);
  transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.mp-nav a:hover::before {
  right: 0;
}

.mp-nav a:hover {
  color: #fff;
  padding-left: 6.4px;
}

.mp-nav a.active {
  color: #EE1C25;
}

.mp-nav a i {
  font-size: 12px;
  opacity: 0.35;
  transition: opacity 0.3s, transform 0.3s;
  flex-shrink: 0;
  position: relative;
}

.mp-nav a:hover i {
  opacity: 1;
  transform: translateX(4px);
}

.mp-back {
  display: flex;
  align-items: center;
  gap: 11.2px;
  background: none;
  border: none;
  color: rgba(255, 255, 255, 0.35);
  font-size: 10.88px;
  letter-spacing: 3px;
  font-weight: 600;
  cursor: pointer;
  padding: 0 0 19.2px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  margin-bottom: 16px;
  transition: color 0.3s;
}

.mp-back:hover {
  color: #EE1C25;
}

.mp-sub-title {
  font-size: 9.6px;
  letter-spacing: 4px;
  color: rgba(255, 255, 255, 0.18);
  margin-bottom: 16px;
  padding-bottom: 9.6px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.mp-sub-nav {
  flex: 1;
}

.mp-sub-nav a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.28);
  text-decoration: none;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  position: relative;
  overflow: hidden;
  transition: color 0.3s, padding-left 0.3s;
}

.mp-sub-nav a::before {
  content: '';
  position: absolute;
  top: 0;
  right: -100%;
  bottom: 0;
  width: 100%;
  background: rgba(238, 28, 37, 0.06);
  transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.mp-sub-nav a:hover::before {
  right: 0;
}

.mp-sub-nav a:hover {
  color: #fff;
  padding-left: 5.6px;
}

.mp-sub-nav a i {
  font-size: 10px;
  opacity: 0.3;
  transition: 0.3s;
  position: relative;
}

.mp-sub-nav a:hover i {
  opacity: 1;
  transform: translateX(3px);
}

.mp-follow {
  font-size: 9.28px;
  letter-spacing: 4px;
  color: rgba(255, 255, 255, 0.18);
  margin-top: 32px;
  margin-bottom: 12.8px;
}

.mp-socials {
  display: flex;
  gap: 9.6px;
  flex-wrap: wrap;
}

.mp-socials a {
  width: 38px;
  height: 38px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.32);
  text-decoration: none;
  transition: all 0.3s;
}

.mp-socials a:hover {
  border-color: #EE1C25;
  color: #EE1C25;
  background: rgba(238, 28, 37, 0.07);
}

.mp-socials i {
  font-size: 14px;
}

/* ================================================================
   RESPONSIVE
================================================================ */
@media (max-width:1100px) {
  .right-fixed {
    width: min(300px, 30vw);
  }

  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width:900px) {
  .nav-center {
    display: none;
  }

  .right-fixed {
    display: none;
  }

  .extra-spacer {
    width: 50px;
  }

  .left-sidebar {
    width: 52px;
  }

  .about-row {
    grid-template-columns: 1fr;
  }

  .features-grid {
    grid-template-columns: 1fr;
  }

  .about-footer {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

@media (max-width:680px) {
  .left-sidebar {
    display: none;
  }

  .extra-spacer {
    display: none;
  }

  .scroll-content {
    padding: 48px 24px 80px;
  }

  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .features-grid {
    grid-template-columns: 1fr;
  }
}

@keyframes fadeSlideUp {
  from {
    transform: translateY(30px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}


/* CLEANED HELPERS */
.scroll-progress {
  position: fixed;
  top: 60px;
  left: 0;
  right: 0;
  height: 2px;
  z-index: 200;
  background: rgba(255, 255, 255, 0.04);
}

.scroll-progress-fill {
  height: 100%;
  background: #EE1C25;
  width: 0%;
  transition: width 0.1s;
}

.left-panel-offset {
  margin-left: clamp(55px, 13vw, 190px);
}

.share-close i {
  font-size: 16px;
}

.cta-btn i,
.google-view-btn i {
  position: relative;
}

.mp-back i {
  font-size: 14px;
}

@media(max-width:680px) {
  .left-panel-offset {
    margin-left: 0;
  }
}

.logo-text {
  display: none;
}

.extra-spacer {
  position: fixed;
  top: 60px;
  bottom: 0;
  z-index: 0;
  pointer-events: none;
}

@media(max-width:680px) {
  .extra-spacer {
    display: none;
  }
}


/* ================================================================
   HOME PAGE / HERO SLIDER
================================================================ */
.home-layout {
  flex: 1;
  display: flex;
  overflow: hidden;
  position: relative;
  z-index: 1;
  min-height: 0;
}

.home-layout .extra-spacer {
  position: relative;
  top: auto;
  bottom: auto;
  width: clamp(60px, 14vw, 200px);
  z-index: 2;
}

.hero {
  flex: 1;
  position: relative;
  overflow: hidden;
  min-width: 0;
}

.slides-container,
.slide {
  position: absolute;
  inset: 0;
}

.slide {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.9s cubic-bezier(0.2, 0.9, 0.4, 1), visibility 0s linear 0.9s;
  z-index: 1;
}

.slide.active {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.9s cubic-bezier(0.2, 0.9, 0.4, 1), visibility 0s linear 0s;
  z-index: 2;
}

.slide-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 115%;
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  will-change: transform;
}

.slide.active .slide-bg {
  animation: kenBurns 10s ease-in-out forwards;
}

@keyframes kenBurns {
  0% {
    transform: translateY(0) scale(1.04);
  }

  100% {
    transform: translateY(-12%) scale(1);
  }
}

.slide::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(3, 3, 8, 0.55);
  z-index: 1;
  pointer-events: none;
}

.slide-content {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  padding: 0 48px 80px clamp(24px, 4vw, 56px);
}

.text-block {
  max-width: 600px;
}

.eyebrow {
  display: flex;
  align-items: center;
  gap: 12.8px;
  margin-bottom: 22.4px;
  overflow: hidden;
}

.eyebrow-line {
  display: block;
  width: 0;
  height: 2px;
  background: #EE1C25;
}

.slide.active .eyebrow-line {
  animation: growLine 0.6s 0.2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes growLine {
  to {
    width: 42px;
  }
}

.eyebrow span:last-child {
  font-size: 11.52px;
  letter-spacing: 5px;
  color: rgba(255, 255, 255, 0.55);
  font-weight: 500;
  transform: translateX(-10px);
  opacity: 0;
}

.slide.active .eyebrow span:last-child {
  animation: fadeSlideX 0.5s 0.35s ease forwards;
}

@keyframes fadeSlideX {
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

.slide-title {
  font-size: clamp(35.2px, 5.5vw, 72px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: #fff;
  margin-bottom: 19.2px;
  transform: translateY(50px);
  opacity: 0;
}

.slide.active .slide-title {
  animation: slideUpFade 0.75s 0.15s cubic-bezier(0.2, 0.9, 0.4, 1) forwards;
}

@keyframes slideUpFade {
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.slide-title em {
  font-style: normal;
  color: #EE1C25;
}

.slide-sub {
  font-size: clamp(13.12px, 1.8vw, 15.68px);
  color: rgba(255, 255, 255, 0.62);
  line-height: 1.7;
  margin-bottom: 32px;
  max-width: 480px;
  font-weight: 300;
  transform: translateY(30px);
  opacity: 0;
}

.slide.active .slide-sub {
  animation: slideUpFade 0.75s 0.32s cubic-bezier(0.2, 0.9, 0.4, 1) forwards;
}

.more-link {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  font-size: 13.12px;
  letter-spacing: 3px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  transform: translateY(20px);
  opacity: 0;
  transition: color 0.3s;
}

.slide.active .more-link {
  animation: slideUpFade 0.75s 0.46s cubic-bezier(0.2, 0.9, 0.4, 1) forwards;
}

.more-link:hover {
  color: #EE1C25;
}

.more-arrow {
  display: block;
  width: 44px;
  height: 2px;
  background: currentColor;
  position: relative;
  transition: width 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  flex-shrink: 0;
}

.more-arrow::after {
  content: '';
  position: absolute;
  right: 0;
  top: -4px;
  width: 9px;
  height: 9px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.more-link:hover .more-arrow {
  width: 68px;
}

.slide-numbers {
  position: absolute;
  right: 28.8px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 6.4px;
}

.slide-num-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7.2px 9.6px 7.2px 0;
  cursor: pointer;
  transform: translateX(40px);
  opacity: 0;
  animation: numSlideIn 0.5s ease forwards;
  background: none;
  border: 0;
}

.slide-num-item:nth-child(1) {
  animation-delay: 0.3s;
}

.slide-num-item:nth-child(2) {
  animation-delay: 0.38s;
}

.slide-num-item:nth-child(3) {
  animation-delay: 0.46s;
}

.slide-num-item:nth-child(4) {
  animation-delay: 0.54s;
}

.slide-num-item:nth-child(5) {
  animation-delay: 0.62s;
}

@keyframes numSlideIn {
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

.num-line {
  width: 0;
  height: 2px;
  background: #EE1C25;
  transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  order: 1;
}

.num-label {
  font-size: 13.12px;
  font-weight: 700;
  letter-spacing: 1px;
  color: rgba(255, 255, 255, 0.28);
  transition: color 0.3s;
  order: 2;
}

.slide-num-item.active .num-label {
  color: #fff;
}

.slide-num-item.active .num-line {
  width: 42px;
}

.slide-num-item:hover .num-label {
  color: rgba(255, 255, 255, 0.65);
}

.bottom-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 62px;
  display: flex;
  align-items: center;
  background: rgba(6, 6, 12, 0.72);
  backdrop-filter: blur(14px);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  z-index: 25;
  overflow: hidden;
}

.explore-btn {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12.8px;
  padding: 0 32px;
  height: 100%;
  border-right: 1px solid rgba(255, 255, 255, 0.06);
  font-size: 10.88px;
  letter-spacing: 3px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  overflow: hidden;
  flex-shrink: 0;
  transition: color 0.35s;
  white-space: nowrap;
}

.explore-btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  bottom: 0;
  width: 100%;
  background: rgba(238, 28, 37, 0.13);
  transition: left 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.explore-btn:hover::before {
  left: 0;
}

.explore-btn:hover {
  color: #EE1C25;
}

.explore-icon {
  width: 28px;
  height: 28px;
  border: 1px solid rgba(238, 28, 37, 0.4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13.6px;
  flex-shrink: 0;
  transition: transform 0.35s, border-color 0.35s;
  position: relative;
}

.explore-btn:hover .explore-icon {
  transform: rotate(45deg);
  border-color: #EE1C25;
}

.progress-area {
  flex: 1;
  display: flex;
  align-items: center;
  padding: 0 32px;
  gap: 19.2px;
  overflow: hidden;
}

.progress-track {
  flex: 1;
  max-width: 200px;
  height: 2px;
  background: rgba(255, 255, 255, 0.09);
  flex-shrink: 0;
}

.progress-fill {
  height: 100%;
  width: 0%;
  background: #EE1C25;
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.counter {
  font-size: 14.08px;
  color: rgba(255, 255, 255, 0.35);
  display: flex;
  align-items: baseline;
  gap: 5px;
  white-space: nowrap;
}

.counter .current {
  font-size: 20px;
  font-weight: 800;
  color: #fff;
  line-height: 1;
}

.nav-buttons {
  display: flex;
  border-left: 1px solid rgba(255, 255, 255, 0.06);
  flex-shrink: 0;
}

.nav-btn {
  position: relative;
  padding: 0 28.8px;
  height: 62px;
  background: none;
  border: 0;
  color: rgba(255, 255, 255, 0.45);
  font-size: 10.88px;
  letter-spacing: 3px;
  font-weight: 700;
  cursor: pointer;
  transition: color 0.3s;
  overflow: hidden;
  white-space: nowrap;
}

.nav-btn::before {
  content: '';
  position: absolute;
  bottom: -100%;
  left: 0;
  right: 0;
  height: 100%;
  background: rgba(255, 255, 255, 0.05);
  transition: bottom 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.nav-btn:hover::before {
  bottom: 0;
}

.nav-btn:hover {
  color: #fff;
}

.nav-btn+.nav-btn {
  border-left: 1px solid rgba(255, 255, 255, 0.06);
}

.nav-btn i {
  position: relative;
}

@media (max-width:1024px) {
  .home-layout .extra-spacer {
    width: clamp(40px, 8vw, 100px);
  }
}

@media (max-width:900px) {
  .slide-numbers {
    display: none;
  }

  .home-layout .extra-spacer {
    width: 50px;
  }
}

@media (max-width:680px) {
  .home-layout .extra-spacer {
    display: none;
  }

  .slide-content {
    padding: 0 19.2px 80px;
  }

  .slide-title {
    font-size: clamp(30.4px, 8vw, 44.8px);
  }

  .explore-btn {
    padding: 0 19.2px;
    font-size: 9.6px;
  }

  .progress-area {
    padding: 0 16px;
  }

  .nav-btn {
    padding: 0 17.6px;
    font-size: 9.6px;
  }
}

@media (max-width:420px) {
  .slide-title {
    font-size: 28.8px;
  }

  .bottom-bar {
    height: 54px;
  }

  .nav-btn {
    height: 54px;
  }

  .explore-btn {
    gap: 8px;
  }

  .explore-icon {
    display: none;
  }
}

/* ================================================================
   COMMON ANIMATED SIDE PATTERN
   Same code used on every page through includes/animated-sidebar.php
================================================================ */
.extra-spacer .spin-ring,
.extra-spacer .plus-center,
.side-brand-marquee {
  display: none;
}

.side-brand-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(2px, 0.35vw, 6px);
  font-size: clamp(24.8px, 2.65vw, 50.4px);
  font-weight: 900;
  line-height: 0.82;
  letter-spacing: 0;
  color: #EE1C25;
  text-shadow: 0 0 18px rgba(238, 28, 37, 0.36);
}

.side-letter {
  display: block;
  opacity: 0;
  transform: scale(0.15) rotate(-10deg);
  filter: blur(5px);
  animation: letterBuildVertical 6.2s cubic-bezier(0.2, 0.9, 0.35, 1) infinite;
  animation-delay: calc(var(--i) * 0.20s);
}

.side-space {
  height: clamp(9px, 1.2vw, 18px);
  opacity: 1;
  animation: none;
}

.side-brand-text::before,
.side-brand-text::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 1px;
  height: 72%;
  transform: translateY(-50%) scaleY(0);
  background: rgba(238, 28, 37, 0.42);
  box-shadow: 0 0 12px rgba(238, 28, 37, 0.55);
  animation: sideLineBuildVertical 6.2s ease infinite;
}

.side-brand-text::before {
  left: -16px;
}

.side-brand-text::after {
  right: -16px;
}

@keyframes letterBuildVertical {
  0% {
    opacity: 0;
    transform: scale(0.15) rotate(-10deg);
    filter: blur(5px);
  }

  8% {
    opacity: 1;
    transform: scale(1.08) rotate(0deg);
    filter: blur(0);
  }

  13% {
    opacity: 1;
    transform: scale(1) rotate(0deg);
    filter: blur(0);
  }

  78% {
    opacity: 1;
    transform: scale(1) rotate(0deg);
    filter: blur(0);
  }

  100% {
    opacity: 0;
    transform: scale(0.88) translateY(-8px);
    filter: blur(2px);
  }
}

@keyframes sideLineBuildVertical {

  0%,
  8% {
    transform: translateY(-50%) scaleY(0);
    opacity: 0;
  }

  35%,
  78% {
    transform: translateY(-50%) scaleY(1);
    opacity: 1;
  }

  100% {
    transform: translateY(-50%) scaleY(0);
    opacity: 0;
  }
}

@media(max-width:680px) {
  .side-brand-text {
    display: none;
  }
}


/* ================================================================
   SIMPLE INNER PAGES
================================================================ */
.simple-page {
  flex: 1;
  min-height: calc(100vh - 60px);
  overflow-y: auto;
  padding: clamp(32px, 5vw, 80px);
  position: relative;
  z-index: 1;
}

.simple-hero {
  max-width: 760px;
  padding: clamp(32px, 4vw, 64px);
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 2px;
  animation: fadeSlideUp 0.7s ease both;
}

.simple-hero .cta-btn i {
  position: relative;
}


/* ===== FINAL REPAIR PATCH ===== */
body {
  min-height: 100vh;
}

.page-layout {
  flex: 1;
  display: flex;
  overflow: hidden;
  position: relative;
  z-index: 1;
  min-height: 0;
}

.content-area {
  flex: 1;
  display: flex;
  overflow: hidden;
  min-height: 0;
}

.left-panel {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  position: relative;
  min-width: 0;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.left-panel::-webkit-scrollbar {
  display: none;
}

.left-panel-offset {
  margin-left: clamp(55px, 13vw, 190px);
}

.simple-page,
.blog-page-main {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  position: relative;
  min-width: 0;
  padding: 64px 56px 80px calc(clamp(55px, 13vw, 190px) + clamp(24px, 3vw, 40px));
}

.blog-page-main {
  padding-top: 48px
}

.blog-page-main .extra-spacer {
  display: none
}

@media(max-width:680px) {

  .simple-page,
  .blog-page-main {
    padding: 48px 24px 80px
  }

  .left-panel-offset {
    margin-left: 0
  }
}

.slide-bg {
  height: 100%;
  background-size: cover;
  background-position: center center;
  transform: none
}

.slide.active .slide-bg {
  animation: kenBurnsClean 10s ease-in-out forwards
}

@keyframes kenBurnsClean {
  0% {
    transform: scale(1.05)
  }

  100% {
    transform: scale(1.01)
  }
}

.extra-spacer .spin-ring,
.extra-spacer .plus-center,
.side-brand-text,
.side-brand-marquee {
  display: none
}

.draw-brand {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(0px, .15vw, 3px);
  filter: drop-shadow(0 0 14px rgba(238, 28, 37, .35))
}

.draw-letter {
  width: clamp(42px, 4.5vw, 76px);
  height: clamp(42px, 4.5vw, 76px);
  overflow: visible
}

.draw-letter text {
  font-size: 76px;
  font-weight: 900;
  fill: rgba(238, 28, 37, 0);
  stroke: #EE1C25;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 360;
  stroke-dashoffset: 360;
  animation: drawLetter 11s ease-in-out infinite;
  animation-delay: calc(var(--i) * .45s)
}

.draw-letter-space {
  display: block;
  height: clamp(10px, 1vw, 18px)
}

.draw-brand:before,
.draw-brand:after {
  content: '';
  position: absolute;
  top: 50%;
  height: 80%;
  width: 1px;
  background: rgba(238, 28, 37, .35);
  box-shadow: 0 0 15px rgba(238, 28, 37, .55);
  transform: translateY(-50%) scaleY(0);
  animation: drawSideLine 11s ease-in-out infinite
}

.draw-brand:before {
  left: -12px
}

.draw-brand:after {
  right: -12px
}

@keyframes drawLetter {

  0%,
  5% {
    stroke-dashoffset: 360;
    fill: rgba(238, 28, 37, 0);
    opacity: .35
  }

  14%,
  72% {
    stroke-dashoffset: 0;
    fill: rgba(238, 28, 37, .95);
    opacity: 1
  }

  88%,
  100% {
    stroke-dashoffset: 0;
    fill: rgba(238, 28, 37, 0);
    opacity: .25
  }
}

@keyframes drawSideLine {

  0%,
  5% {
    transform: translateY(-50%) scaleY(0);
    opacity: 0
  }

  18%,
  74% {
    transform: translateY(-50%) scaleY(1);
    opacity: 1
  }

  100% {
    transform: translateY(-50%) scaleY(0);
    opacity: 0
  }
}

.portfolio-header,
.contact-header {
  margin-bottom: 48px;
  animation: fadeSlideUp .7s ease both
}

.portfolio-eyebrow,
.contact-eyebrow {
  display: flex;
  align-items: center;
  gap: 12.8px;
  margin-bottom: 24px
}

.portfolio-eyebrow-line,
.contact-eyebrow-line {
  display: block;
  width: 36px;
  height: 2px;
  background: #EE1C25
}

.portfolio-eyebrow span,
.contact-eyebrow span {
  font-size: 11.2px;
  letter-spacing: 5px;
  color: rgba(255, 255, 255, .45)
}

.portfolio-title,
.contact-title {
  font-size: clamp(35.2px, 6vw, 64px);
  font-weight: 900;
  letter-spacing: -.02em;
  color: #fff;
  margin-bottom: 12.8px;
  line-height: 1
}

.portfolio-title em,
.contact-title em {
  font-style: normal;
  color: #EE1C25
}

.portfolio-sub,
.contact-sub {
  font-size: 14.4px;
  color: rgba(255, 255, 255, .5);
  max-width: 660px;
  line-height: 1.7
}

.filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 12.8px;
  margin-bottom: 40px
}

.filter-btn {
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .08);
  color: rgba(255, 255, 255, .55);
  padding: 12px 17.6px;
  border-radius: 4px;
  letter-spacing: 1.5px;
  font-size: 10.88px;
  font-weight: 700;
  cursor: pointer;
  transition: .3s;
}

.filter-btn:hover,
.filter-btn.active {
  color: #EE1C25;
  border-color: rgba(238, 28, 37, .35);
  background: rgba(238, 28, 37, .08)
}

.projects-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .06)
}

.project-card {
  background: #030308;
  overflow: hidden;
  position: relative;
  animation: fadeSlideUp .5s ease both
}

.project-img {
  height: 230px;
  background-size: cover;
  background-position: center;
  filter: saturate(.9);
  transition: transform .5s, filter .3s;
  background-color: rgba(238, 28, 37, .04)
}

.project-card:hover .project-img {
  transform: scale(1.05);
  filter: saturate(1.1)
}

.project-info {
  padding: 24px;
  position: relative;
  z-index: 1;
  background: linear-gradient(to top, rgba(3, 3, 8, .98), rgba(3, 3, 8, .82))
}

.project-category {
  font-size: 9.92px;
  letter-spacing: 3px;
  color: rgba(238, 28, 37, .65);
  margin-bottom: 9.6px
}

.project-title {
  font-size: 21.6px;
  letter-spacing: 1px;
  margin-bottom: 9.6px;
  color: #fff
}

.project-desc {
  font-size: 13.12px;
  line-height: 1.7;
  color: rgba(255, 255, 255, .48);
  margin-bottom: 16px
}

.project-link,
.contact-cta,
.urgent-link {
  color: #fff;
  text-decoration: none;
  font-size: 11.2px;
  letter-spacing: 2px;
  font-weight: 700;
  transition: .3s
}

.project-link:hover,
.contact-cta:hover,
.urgent-link:hover {
  color: #EE1C25
}

.right-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 9.6px;
  margin: 16px 0
}

.stat-item {
  /* text-align: center; */
  background: rgba(255, 255, 255, .045);
  padding: 12.8px;
  border: 1px solid rgba(255, 255, 255, .06)
}

.stat-number {
  font-size: 22.4px;
  font-weight: 900;
  color: #EE1C25
}

.no-projects {
  grid-column: 1/-1;
  text-align: center;
  padding: 48px;
  color: rgba(255, 255, 255, .5)
}

@media(max-width:850px) {
  .projects-grid {
    grid-template-columns: 1fr
  }

  .right-stats {
    grid-template-columns: 1fr
  }
}

.contact-info-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .06);
  margin-bottom: 40px
}

.info-card {
  background: #030308;
  padding: 28.8px;
  transition: .3s
}

.info-card:hover {
  background: rgba(238, 28, 37, .035)
}

.info-icon {
  width: 48px;
  height: 48px;
  border: 1px solid rgba(238, 28, 37, .28);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #EE1C25;
  margin-bottom: 16px;
  font-size: 19.2px
}

.info-card h3 {
  letter-spacing: 1px;
  margin-bottom: 11.2px
}

.info-card p,
.info-card a {
  font-size: 13.12px;
  line-height: 1.7;
  color: rgba(255, 255, 255, .52);
  text-decoration: none
}

.info-card a:hover {
  color: #EE1C25
}

.form-container,
.map-section,
.faq-section {
  margin-bottom: 40px
}

.section-title,
.map-title,
.faq-title {
  font-size: 22.4px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 16px;
  color: #fff
}

.contact-form {
  background: rgba(255, 255, 255, .025);
  border: 1px solid rgba(255, 255, 255, .06);
  padding: 32px
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px
}

.form-group {
  margin-bottom: 16px
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 14.4px 16px;
  background: rgba(255, 255, 255, .05);
  border: 1px solid rgba(255, 255, 255, .1);
  color: #fff;
  border-radius: 3px;
  outline: none
}

.form-group textarea {
  min-height: 150px;
  resize: vertical
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: rgba(238, 28, 37, .45);
  background: rgba(255, 255, 255, .075)
}

.submit-btn {
  padding: 14.4px 28.8px;
  background: rgba(238, 28, 37, .1);
  border: 1px solid rgba(238, 28, 37, .32);
  color: #EE1C25;
  font-weight: 800;
  letter-spacing: 2px;
  cursor: pointer
}

.form-status {
  margin-top: 16px;
  color: #EE1C25
}

.map-container {
  border: 1px solid rgba(255, 255, 255, .06);
  background: rgba(255, 255, 255, .025);
  padding: 16px
}

.map-placeholder {
  min-height: 210px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  color: rgba(255, 255, 255, .45);
  gap: 9.6px;
  text-align: center
}

.map-placeholder i {
  font-size: 40px;
  color: rgba(238, 28, 37, .45)
}

.faq-grid {
  display: grid;
  gap: 12.8px
}

.faq-item {
  border: 1px solid rgba(255, 255, 255, .06);
  background: rgba(255, 255, 255, .025);
}

.faq-question {
  padding: 16px;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  cursor: pointer;
  color: #fff;
  font-weight: 700
}

.faq-question span:first-child {
  color: #EE1C25
}

.faq-answer {
  display: none;
  padding: 0 16px 16px;
  color: rgba(255, 255, 255, .48);
  font-size: 13.6px;
  line-height: 1.7
}

.faq-item.active .faq-answer {
  display: block
}

.availability {
  margin: 16px 0;
  color: rgba(255, 255, 255, .55);
  font-size: 13.6px
}

@media(max-width:900px) {
  .contact-info-row {
    grid-template-columns: 1fr
  }

  .form-row {
    grid-template-columns: 1fr
  }
}

.comment-section {
  margin-top: 32px;
  border-top: 1px solid rgba(255, 255, 255, .08);
  padding-top: 32px
}

.comment-card {
  background: rgba(255, 255, 255, .025);
  border: 1px solid rgba(255, 255, 255, .06);
  padding: 16px;
  margin-bottom: 16px
}

.comment-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  color: #fff;
  font-weight: 700
}

.comment-date {
  font-size: 11.52px;
  color: rgba(255, 255, 255, .35);
  font-weight: 400
}

.comment-body {
  margin-top: 9.6px;
  color: rgba(255, 255, 255, .52);
  font-size: 13.76px;
  line-height: 1.7
}

.comment-form {
  background: rgba(255, 255, 255, .025);
  border: 1px solid rgba(255, 255, 255, .06);
  padding: 24px;
  margin-top: 24px
}

.comment-message {
  padding: 16px;
  margin-bottom: 16px;
  border-radius: 6px;
  background: rgba(238, 28, 37, .08);
  border: 1px solid rgba(238, 28, 37, .22);
  color: #EE1C25
}

/* Final red theme and shared sidebar fixes */
.extra-spacer {
  width: clamp(58px, 10vw, 150px);
  display: flex;
  align-items: center;
  justify-content: center
}

.draw-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  position: relative;
  z-index: 2;
  max-height: 88vh;
  overflow: hidden
}

.draw-letter {
  width: clamp(28px, 3vw, 42px);
  height: clamp(30px, 3.2vw, 46px);
  flex: 0 0 auto
}

.draw-letter text {
  font-size: 64px;
  font-weight: 900;
  fill: transparent;
  stroke: #EE1C25;
  stroke-width: 1.6;
  stroke-dasharray: 230;
  stroke-dashoffset: 230;
  animation: drawCharacter 1.2s ease forwards;
  animation-delay: calc(var(--i) * .42s)
}

.draw-letter-space {
  height: clamp(8px, 1vw, 14px)
}

@keyframes drawCharacter {
  0% {
    stroke-dashoffset: 230;
    fill: transparent;
    filter: drop-shadow(0 0 0 rgba(238, 28, 37, 0))
  }

  75% {
    stroke-dashoffset: 0;
    fill: transparent
  }

  100% {
    stroke-dashoffset: 0;
    fill: #EE1C25;
    filter: drop-shadow(0 0 8px rgba(238, 28, 37, .45))
  }
}

@media(max-width:900px) {
  .extra-spacer {
    width: 50px
  }

  .draw-letter {
    width: 26px;
    height: 30px
  }

  .draw-letter text {
    font-size: 58px
  }
}

@media(max-width:680px) {
  .extra-spacer {
    display: none
  }
}

/* Auth/user header */
.topnav .user-mini {
  max-width: 320px
}

.page-layout {
  background: #030308
}

.comment-body,
.comment-text,
.post-content {
  overflow-wrap: anywhere;
  word-break: break-word
}

.comments-list,
.comment-item {
  max-width: 100%
}

/* ===== FINAL UNIFIED LAYOUT / SIDEBAR / AUTH ===== */
:root {
  --ovx-red: #EE1C25;
  --ovx-black: #000;
  --ovx-white: #fff;
}

.top-account-chip {
  margin-right: 50px;
  display: flex;
  align-items: center;
  gap: 8.8px;
  text-decoration: none;
  color: #fff;
  border: 1px solid rgba(238, 28, 37, .25);
  background: rgba(238, 28, 37, .08);
  padding: 8.8px 14.4px;
  border-radius: 999px;
  font-size: 12.16px;
  letter-spacing: .5px;
  white-space: nowrap;
  transition: .25s
}

.top-account-chip i,
.top-account-chip strong {
  color: var(--ovx-red)
}

.top-account-chip:hover {
  background: rgba(238, 28, 37, .16);
  border-color: var(--ovx-red)
}

.mp-auth-box {
  margin-top: 22.4px;
  padding-top: 17.6px;
  border-top: 1px solid rgba(255, 255, 255, .07);
  display: grid;
  gap: 11.2px
}

.mp-auth-btn {
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9.6px;
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 10px;
  background: rgba(255, 255, 255, .04);
  color: #fff;
  text-decoration: none;
  font-size: 12.16px;
  letter-spacing: 2px;
  font-weight: 800;
  padding: 0 16px
}

.mp-auth-btn:before {
  display: none
}

.mp-auth-btn:hover {
  border-color: var(--ovx-red);
  background: rgba(238, 28, 37, .12);
  color: var(--ovx-red);
  padding-left: 16px
}

.mp-auth-btn.primary {
  background: var(--ovx-red);
  border-color: var(--ovx-red);
  color: #fff
}

.mp-auth-btn.danger {
  border-color: rgba(238, 28, 37, .32);
  color: #ff8080
}

.page-layout.unified-page-layout,
.blog-shell,
.account-page {
  flex: 1;
  display: flex;
  overflow: hidden;
  position: relative;
  z-index: 1;
  min-height: 0;
  background: #030308
}

.unified-page-layout>.left-sidebar,
.blog-shell>.left-sidebar,
.account-page>.left-sidebar {
  position: relative;
  z-index: 10;
  flex: 0 0 clamp(50px, 8vw, 88px)
}

.unified-page-layout>.extra-spacer,
.blog-shell>.extra-spacer,
.account-page>.extra-spacer {
  position: relative;
  top: auto;
  bottom: auto;
  left: auto;
  z-index: 1;
  flex: 0 0 clamp(54px, 9vw, 128px);
  width: clamp(54px, 9vw, 128px);
  min-height: calc(100vh - 60px);
  border-right: 1px solid rgba(255, 255, 255, .04);
  background: rgba(3, 3, 8, .35)
}

.left-sidebar {
  background: rgba(0, 0, 0, .72);
  border-right: 1px solid rgba(255, 255, 255, .06)
}

.brand-vert {
  color: rgba(255, 255, 255, .18)
}

.social-icons a:hover,
.share-vert:hover {
  color: var(--ovx-red)
}

.nav-sep,
.about-eyebrow-line,
.progress-fill,
.num-line {
  background: var(--ovx-red)
}

.about-title em,
.slide-title em,
.right-brand-title em,
.feature-num,
.stat-num,
.logo-text small {
  color: var(--ovx-red)
}

.cta-btn,
.play-btn {
  border-color: rgba(238, 28, 37, .35)
}

.cta-btn:hover,
.video-link:hover {
  color: var(--ovx-red);
  border-color: var(--ovx-red)
}

.feature-card:before,
.stat-box:before,
.share-btn:before,
.cta-btn:before {
  background: rgba(238, 28, 37, .08)
}

.draw-brand {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1px;
  max-height: 82vh;
  filter: drop-shadow(0 0 10px rgba(238, 28, 37, .28))
}

.draw-letter {
  width: clamp(22px, 2.4vw, 36px);
  height: clamp(23px, 2.5vw, 38px);
  flex: 0 0 auto;
  overflow: visible
}

.draw-letter text {
  font-size: 58px;
  font-weight: 900;
  fill: transparent;
  stroke: var(--ovx-red);
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 320;
  stroke-dashoffset: 320;
  animation: ovxDrawChar 14s ease-in-out infinite;
  animation-delay: calc(var(--i) * .55s)
}

.draw-letter-space {
  height: clamp(8px, .9vw, 13px)
}

.draw-brand:before,
.draw-brand:after {
  display: none
}

@keyframes ovxDrawChar {

  0%,
  5% {
    stroke-dashoffset: 320;
    fill: transparent;
    opacity: .2
  }

  15%,
  75% {
    stroke-dashoffset: 0;
    fill: rgba(238, 28, 37, .95);
    opacity: 1
  }

  90%,
  100% {
    stroke-dashoffset: 0;
    fill: transparent;
    opacity: .2
  }
}

.blog-page-main,
.simple-page,
.account-main {
  flex: 1;
  min-width: 0;
  overflow: auto;
  padding: 0;
  max-height: calc(100vh - 60px)
}

.left-panel-offset {
  margin-left: clamp(55px, 13vw, 190px)
}

@media(max-width:900px) {
  .top-account-chip span {
    display: none
  }

  .unified-page-layout>.extra-spacer,
  .blog-shell>.extra-spacer,
  .account-page>.extra-spacer {
    flex-basis: 52px;
    width: 52px
  }

  .draw-letter {
    width: 23px;
    height: 25px
  }

  .draw-letter text {
    font-size: 54px
  }
}

@media(max-width:680px) {

  .unified-page-layout>.left-sidebar,
  .blog-shell>.left-sidebar,
  .account-page>.left-sidebar,
  .unified-page-layout>.extra-spacer,
  .blog-shell>.extra-spacer,
  .account-page>.extra-spacer {
    display: none
  }

  .blog-page-main,
  .simple-page,
  .account-main {
    max-height: calc(100vh - 60px)
  }
}

.account-main {
  padding: 48px 32px 80px
}

.account-grid {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 22.4px;
  margin-bottom: 22.4px
}

.account-card {
  background: rgba(255, 255, 255, .025);
  border: 1px solid rgba(255, 255, 255, .07);
  border-radius: 18px;
  padding: 22.4px
}

.account-avatar {
  width: 78px;
  height: 78px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(238, 28, 37, .12);
  border: 1px solid rgba(238, 28, 37, .35);
  font-size: 32px;
  color: var(--ovx-red);
  margin-bottom: 16px
}

.account-card h2,
.account-card h3 {
  letter-spacing: 1px;
}

.account-card p,
.account-empty {
  color: rgba(255, 255, 255, .55);
  line-height: 1.7;
}

.account-status,
.comment-status {
  display: inline-flex;
  margin-top: 12.8px;
  padding: 5.6px 12px;
  border-radius: 999px;
  font-size: 11.2px;
  letter-spacing: 1px;
  border: 1px solid rgba(238, 28, 37, .35);
  color: var(--ovx-red);
  background: rgba(238, 28, 37, .08);
}

.detail-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12.8px;
  margin-top: 16px
}

.detail-list div {
  background: rgba(255, 255, 255, .035);
  border: 1px solid rgba(255, 255, 255, .05);
  border-radius: 12px;
  padding: 13.6px
}

.detail-list span {
  display: block;
  color: rgba(255, 255, 255, .38);
  font-size: 11.52px;
  letter-spacing: 1px;
  margin-bottom: 4px
}

.detail-list strong {
  color: #fff;
  overflow-wrap: anywhere
}

.account-comments {
  display: grid;
  gap: 12.8px;
  margin-top: 16px
}

.account-comment-item {
  background: rgba(255, 255, 255, .035);
  border: 1px solid rgba(255, 255, 255, .06);
  border-radius: 14px;
  padding: 16px
}

.account-comment-item>div {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap
}

.account-comment-item span {
  color: rgba(255, 255, 255, .38);
  font-size: 12.16px
}

.account-comment-item p {
  margin: 11.2px 0;
  color: rgba(255, 255, 255, .65);
  overflow-wrap: anywhere
}

@media(max-width:900px) {
  .account-grid {
    grid-template-columns: 1fr
  }

  .detail-list {
    grid-template-columns: 1fr
  }

  .account-main {
    padding: 32px 16px 64px
  }
}

/* Final premium navigation audio/transition overlay */
.orvexia-page-wipe {
  position: fixed;
  inset: 0;
  z-index: 999999;
  pointer-events: none;
  background: radial-gradient(circle at center, rgba(238, 28, 37, .22), transparent 45%), #030308;
  transform: translateY(100%);
  transition: transform .42s cubic-bezier(.75, 0, .2, 1);
}

.orvexia-page-wipe.active {
  transform: translateY(0);
}

.orvexia-page-wipe::after {
  content: 'ORVEXIA STUDIO';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  font-size: clamp(20.8px, 4vw, 51.2px);
  font-weight: 900;
  letter-spacing: .18em;
  color: #fff;
  text-shadow: 0 0 24px rgba(238, 28, 37, .4);
  white-space: nowrap;
}

select option {
  background: #111118;
  color: #fff;
}

/* Universal close icon alignment for messages */
.alert,
.auth-alert,
.success,
.error,
.info,
.message {
  position: relative;
  padding-right: 48px
}

.alert-close,
.dismiss-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 30px;
  height: 30px;
  min-width: 30px;
  min-height: 30px;
  margin: 0;
  padding: 0;
  border-radius: 9px;
  border: 1px solid rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .08);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  cursor: pointer
}

.alert-close i,
.dismiss-close i {
  font-size: 14px;
  line-height: 1
}

.alert-close:hover,
.dismiss-close:hover {
  background: #EE1C25;
  border-color: #EE1C25
}

/* ============================================================
   FINAL FRONTEND RESPONSIVE + ACCOUNT + POPUP POLISH
============================================================ */
.site-message,
.comment-message,
.auth-alert {
  position: relative;
  border-radius: 14px;
  padding: 14px 48px 14px 16px;
  margin: 0 0 18px;
  line-height: 1.55;
  overflow: hidden;
}

.site-message.success,
.comment-message.success,
.auth-alert.success {
  background: rgba(39, 197, 94, .10);
  border: 1px solid rgba(39, 197, 94, .28);
  color: #a7ffc7;
}

.site-message.error,
.comment-message.error,
.auth-alert.error {
  background: rgba(238, 28, 37, .12);
  border: 1px solid rgba(238, 28, 37, .35);
  color: #ff9aa0;
}

.msg-close,
.auth-alert .alert-close,
.site-message .alert-close {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .14);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  font-size: 13px;
  line-height: 1;
  cursor: pointer;
}

.site-confirm-layer {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(0, 0, 0, .74);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: .2s;
}

.site-confirm-layer.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.site-confirm-box {
  position: relative;
  width: min(420px, 94vw);
  background: #08080f;
  border: 1px solid rgba(238, 28, 37, .45);
  border-radius: 22px;
  padding: 34px 26px 24px;
  text-align: center;
  box-shadow: 0 30px 90px rgba(0, 0, 0, .55);
}

.site-confirm-x {
  position: absolute;
  right: 14px;
  top: 14px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .08);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  font-size: 13px;
}

.site-confirm-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(238, 28, 37, .12);
  color: #EE1C25;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
  font-size: 28px;
}

.site-confirm-box h3 {
  color: #fff;
  font-size: 28px;
  letter-spacing: 1px;
  margin: 0 0 8px;
}

.site-confirm-box p {
  color: rgba(255, 255, 255, .65);
  line-height: 1.6;
  margin: 0 0 22px;
}

.site-confirm-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.site-confirm-cancel,
.site-confirm-yes {
  min-height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, .12);
  font-weight: 800;
  letter-spacing: 1px;
  cursor: pointer
}

.site-confirm-cancel {
  background: rgba(255, 255, 255, .06);
  color: #fff
}

.site-confirm-yes {
  background: #EE1C25;
  color: #fff;
  border-color: #EE1C25
}

.account-main {
  padding: clamp(18px, 3vw, 42px);
}

.account-main .account-hero,
.account-main .account-grid,
.account-main .comments-card,
.account-main .danger-zone {
  max-width: 1180px;
  margin-left: auto;
  margin-right: auto;
}

.danger-zone{
  margin-top: 20px;
}

.account-edit-grid {
  display: grid;
  grid-template-columns: minmax(260px, 340px) 1fr;
  gap: 24px;
  align-items: start;
}

.account-card {
  background: rgba(255, 255, 255, .035);
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 20px;
  padding: clamp(18px, 2vw, 26px);
  box-shadow: 0 24px 80px rgba(0, 0, 0, .18);
}

.image-avatar {
  width: 112px;
  height: 112px;
  border-radius: 50%;
  overflow: hidden;
  /* margin: 0 auto 14px; */
  background: rgba(238, 28, 37, .12);
  border: 1px solid rgba(238, 28, 37, .35);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #EE1C25;
  font-size: 38px;
}

.image-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.account-edit-form h3,
.comments-card h3,
.danger-zone h3 {
  color: #fff;
  font-size: clamp(21.6px, 2.4vw, 29.6px);
  letter-spacing: 1px;
  margin-bottom: 18px;
}

.account-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.account-form-grid label {
  display: grid;
  gap: 7px;
  color: rgba(255, 255, 255, .55);
  font-size: 12px;
  letter-spacing: 1.5px;
}

.account-form-grid input {
  width: 100%;
  min-height: 46px;
  background: rgba(255, 255, 255, .055);
  border: 1px solid rgba(255, 255, 255, .10);
  border-radius: 12px;
  color: #fff;
  padding: 12.8px 16px;
  outline: none;
}

.account-form-grid input:focus {
  border-color: #EE1C25;
  box-shadow: 0 0 0 3px rgba(238, 28, 37, .12)
}

.account-actions {
  margin-top: 18px
}

.account-actions .cta-btn,
.danger-zone .cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: 12px;
  background: #EE1C25;
  color: #fff;
  border-color: #EE1C25
}

.danger-zone .cta-btn.danger {
  background: rgba(238, 28, 37, .13);
  color: #ff9096;
  border-color: rgba(238, 28, 37, .35)
}

.danger-zone p {
  color: rgba(255, 255, 255, .58);
  line-height: 1.7;
  margin-bottom: 16px
}

.account-comments {
  display: grid;
  gap: 12px
}

.account-comment-item {
  background: rgba(0, 0, 0, .22);
  border: 1px solid rgba(255, 255, 255, .07);
  border-radius: 14px;
  padding: 14px;
  overflow-wrap: anywhere
}

.account-comment-item div {
  display: flex;
  gap: 12px;
  justify-content: space-between;
  flex-wrap: wrap
}

.account-comment-item span {
  color: rgba(255, 255, 255, .42);
  font-size: 12.8px
}

.account-comment-item p {
  color: rgba(255, 255, 255, .66);
  line-height: 1.7;
  margin: 10px 0
}

.comment-status {
  display: inline-flex;
  border-radius: 999px;
  padding: 4px 10.4px;
  font-size: 11.2px;
  letter-spacing: 1px
}

.comment-status.draft {
  background: rgba(255, 170, 0, .12);
  color: #ffd479
}

.comment-status.approved {
  background: rgba(37, 180, 90, .13);
  color: #8dffbd
}

.comment-status.rejected {
  background: rgba(238, 28, 37, .13);
  color: #ff858b
}

.blog-container,
.single-layout {
  max-width: 1180px;
  margin: 0 auto;
  width: 100%;
}

.blog-page-main {
  padding: clamp(18px, 3vw, 42px)
}

.single-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
  gap: 28px;
  align-items: start
}

.single-post,
.blog-sidebar {
  min-width: 0
}

.comment-card,
.comment-body {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word
}

.comment-section textarea {
  max-width: 100%;
}

@media(max-width:900px) {
  .account-edit-grid {
    grid-template-columns: 1fr
  }

  .single-layout {
    grid-template-columns: 1fr
  }

  .blog-sidebar {
    order: 2
  }

  .blog-page-main,
  .account-main {
    padding: 18px
  }

  .blog-container,
  .single-layout {
    max-width: 100%
  }

  .site-confirm-actions {
    grid-template-columns: 1fr
  }
}

@media(max-width:680px) {

  .page-layout.unified-page-layout,
  .blog-shell,
  .account-page {
    display: block;
    overflow: auto;
    min-height: calc(100vh - 60px)
  }

  .blog-page-main,
  .simple-page,
  .account-main {
    max-height: none;
    overflow: visible;
    width: 100%
  }

  .account-form-grid {
    grid-template-columns: 1fr
  }

  .topnav {
    position: sticky;
    top: 0
  }

  .nav-center,
  .top-account-chip span {
    display: none
  }

  .site-message,
  .comment-message,
  .auth-alert {
    font-size: 14.4px
  }

  .account-card {
    border-radius: 16px
  }
}


/* =========================================================
   FINAL UI POLISH / SEO READY LAYOUT HELPERS
========================================================= */
.site-message,
.comment-message,
.auth-alert,
.form-status {
  position: relative;
  display: block;
  padding: 14px 50px 14px 16px;
  border-radius: 12px;
  margin: 14px 0;
  border: 1px solid rgba(255, 255, 255, .1);
  line-height: 1.6
}

.site-message.success,
.comment-message.success,
.form-status.success {
  background: rgba(0, 160, 80, .12);
  border-color: rgba(0, 255, 120, .25);
  color: #b7ffd1
}

.site-message.error,
.comment-message.error,
.form-status.error {
  background: rgba(238, 28, 37, .12);
  border-color: rgba(238, 28, 37, .35);
  color: #ffd4d8
}

.msg-close,
.alert-close,
.dismiss-close {
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, .1);
  color: #fff;
  display: grid;
  place-items: center;
  padding: 0;
  line-height: 1;
  cursor: pointer
}

.site-confirm-layer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, .72);
  backdrop-filter: blur(10px);
  padding: 20px
}

.site-confirm-layer.active {
  display: flex
}

.site-confirm-box {
  position: relative;
  width: min(420px, 92vw);
  background: #0d0d14;
  border: 1px solid rgba(238, 28, 37, .4);
  border-radius: 18px;
  text-align: center;
  padding: 32px 24px 24px;
  box-shadow: 0 30px 90px rgba(0, 0, 0, .55)
}

.site-confirm-x {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .07);
  color: #fff;
  display: grid;
  place-items: center;
  cursor: pointer
}

.site-confirm-icon {
  font-size: 38px;
  color: #EE1C25;
  margin-bottom: 12px
}

.site-confirm-box h3 {
  font-size: 25.6px;
  letter-spacing: 1px;
  margin-bottom: 8px
}

.site-confirm-box p {
  color: rgba(255, 255, 255, .62);
  line-height: 1.6
}

.site-confirm-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 22px
}

.site-confirm-actions button {
  height: 44px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, .14);
  font-weight: 900;
  letter-spacing: 1px;
  cursor: pointer
}

.site-confirm-cancel {
  background: rgba(255, 255, 255, .06);
  color: #fff
}

.site-confirm-yes {
  background: #EE1C25;
  border-color: #EE1C25;
  color: #fff
}

.compact-contact-form .logged-comment-user {
  margin-bottom: 16px
}

.compact-contact-form textarea {
  min-height: 180px;
  resize: vertical
}

.page-layout,
.home-layout,
.unified-page-layout {
  max-width: 100vw
}

.left-panel,
.blog-page-main {
  min-width: 0
}

.blog-container {
  max-width: 1180px;
  margin-inline: auto
}

.single-content img {
  max-width: 100%;
  height: auto
}

.comment-body,
.comment-text-full {
  overflow-wrap: anywhere;
  word-break: break-word
}

.orvexia-page-wipe {
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  background: #000;
  opacity: 0;
  transition: opacity .32s ease
}

.orvexia-page-wipe.active {
  opacity: .9
}

/* Service detail polish */
.service-seo-copy h2,
.service-faq h2 {
  letter-spacing: 1px;
}

.faq-item {
  padding: 16px;
  border-top: 1px solid rgba(255, 255, 255, .07)
}

.faq-item h3 {
  color: #fff;
  font-size: 16.8px;
  letter-spacing: 1px;
  margin-bottom: 5.6px
}

.faq-item p {
  margin: 0;
  color: rgba(255, 255, 255, .55)
}

.feature-card h3 i {
  color: #EE1C25;
  margin-right: 7.2px
}

/* 404 PAGE */
.error-page {
  min-height: calc(100vh - 60px);
  display: flex;
  background: radial-gradient(circle at center, rgba(238, 28, 37, .18), transparent 48%), #000;
}

.error-content {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 80px 24px;
}

.error-planet {
  width: 220px;
  height: 220px;
  border: 2px solid rgba(238, 28, 37, .55);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 80px rgba(238, 28, 37, .25);
  animation: errorFloat 4s ease-in-out infinite;
  position: relative;
  margin-bottom: 34px;
}

.error-planet:before {
  content: '';
  position: absolute;
  inset: -18px;
  border: 1px dashed rgba(255, 255, 255, .25);
  border-radius: 50%;
  animation: spinRing 18s linear infinite;
}

.error-planet span {
  font-size: 54px;
  font-weight: 900;
  color: #EE1C25;
  letter-spacing: 5px;
}

.error-content h1 {
  font-size: 44px;
  font-weight: 900;
  margin-bottom: 14px;
}

.error-content p {
  max-width: 620px;
  color: rgba(255, 255, 255, .72);
  font-size: 18px;
  line-height: 1.7;
  margin-bottom: 28px;
}

.error-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
}

.cta-btn.ghost {
  background: transparent;
}

@keyframes errorFloat {

  0%,
  100% {
    transform: translateY(0)
  }

  50% {
    transform: translateY(-16px)
  }
}