/* REVLINE GRAPHICS — Mobile & Fix Overrides */

/* === EMOJI CENTERING FIX === */
.rl-service-icon {
  margin: 0 auto var(--rl-6) !important;
}
.rl-service-card {
  text-align: center !important;
}

/* === TABLET (max-width: 1024px) === */
@media (max-width: 1024px) {
  .rl-services-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .rl-portfolio-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .rl-why-grid { grid-template-columns: 1fr !important; gap: var(--rl-12) !important; }
  .rl-why-visual { position: static !important; }
  .rl-timeline { grid-template-columns: repeat(2, 1fr) !important; gap: var(--rl-8) !important; }
  .rl-timeline::before { display: none !important; }
  .rl-footer-grid { grid-template-columns: 1fr 1fr !important; }
}

/* === MOBILE (max-width: 768px) === */
@media (max-width: 768px) {
  :root { --rl-32: 80px; --rl-24: 56px; --rl-20: 48px; --rl-16: 40px; --rl-12: 32px; }
  html, body { overflow-x: hidden !important; max-width: 100vw !important; }
  .rl-container { padding-left: var(--rl-4) !important; padding-right: var(--rl-4) !important; max-width: 100% !important; }
  .rl-nav-links { display: none !important; }
  .rl-nav-links.active { display: flex !important; flex-direction: column !important; position: absolute !important; top: 80px !important; left: 0 !important; right: 0 !important; background: rgba(245,245,245,0.98) !important; backdrop-filter: blur(20px) !important; padding: var(--rl-6) !important; gap: var(--rl-5) !important; border-bottom: 1px solid var(--rl-border) !important; z-index: 999 !important; }
  .rl-nav-toggle { display: block !important; }
  .rl-nav { padding: 0 var(--rl-4) !important; }

  /* HERO FIX — stack vertically on mobile */
  .rl-hero { flex-direction: column !important; align-items: stretch !important; }
  .rl-hero-video-bg { position: absolute !important; top: 0 !important; left: 0 !important; width: 100% !important; height: 100% !important; z-index: 0 !important; opacity: 0.15 !important; }
  .rl-hero-grid { display: none !important; }
  .rl-hero-content { width: 100% !important; max-width: 100% !important; position: relative !important; z-index: 1 !important; flex: 1 1 100% !important; box-sizing: border-box !important; }
  .rl-hero { padding-top: 48px !important; min-height: auto !important; }
  .rl-hero-content { text-align: center !important; }
  .rl-hero h1 { font-size: clamp(1.75rem, 6vw, 2.25rem) !important; line-height: 1.2 !important; }
  .rl-hero p { max-width: 100% !important; box-sizing: border-box !important; margin-left: auto !important; margin-right: auto !important; font-size: var(--rl-text-sm) !important; }
  .rl-hero-badge { font-size: var(--rl-text-xs) !important; }
  .rl-hero-stats { flex-direction: column !important; gap: var(--rl-5) !important; align-items: center !important; margin-top: var(--rl-8) !important; width: 100% !important; }
  .rl-hero-stat { text-align: center !important; }
  .rl-hero-buttons { flex-direction: column !important; align-items: center !important; gap: var(--rl-3) !important; width: 100% !important; }
  .rl-hero-buttons .rl-btn { text-align: center !important; width: 100% !important; max-width: 300px !important; padding: var(--rl-4) var(--rl-6) !important; box-sizing: border-box !important; }

  .rl-trust-items { flex-direction: column !important; align-items: center !important; text-align: center !important; gap: var(--rl-5) !important; }
  .rl-services-grid { grid-template-columns: 1fr !important; max-width: 400px !important; margin: 0 auto !important; }
  .rl-portfolio-grid { grid-template-columns: 1fr 1fr !important; gap: var(--rl-3) !important; }
  .rl-portfolio-filters { justify-content: center !important; flex-wrap: wrap !important; }
  .rl-why-grid { grid-template-columns: 1fr !important; }
  .rl-timeline { grid-template-columns: 1fr 1fr !important; max-width: 100% !important; gap: var(--rl-4) !important; }
  .rl-timeline-step { text-align: center !important; padding: var(--rl-5) var(--rl-3) !important; }
  .rl-cta-content { text-align: center !important; }
  .rl-cta-content h2 { font-size: var(--rl-text-2xl) !important; }
  .rl-form-row { grid-template-columns: 1fr !important; }
  .rl-quote-section { padding: var(--rl-10) 0 !important; }
  .rl-quote-form { padding: var(--rl-5) var(--rl-4) !important; max-width: 100% !important; }
  .rl-quote-header { text-align: center !important; }
  .rl-form-group input, .rl-form-group select, .rl-form-group textarea { font-size: 16px !important; padding: var(--rl-3) !important; }
  .rl-form-submit { padding: var(--rl-4) !important; font-size: 14px !important; letter-spacing: 1.5px !important; }
  .rl-faq-header { text-align: center !important; }
  .rl-footer-grid { grid-template-columns: 1fr !important; gap: var(--rl-6) !important; text-align: center !important; }
  .rl-footer-brand { text-align: center !important; }
  .rl-footer-links { align-items: center !important; }
  .rl-footer-bottom { flex-direction: column !important; gap: var(--rl-4) !important; text-align: center !important; }
  .rl-section-title, .rl-section-subtitle, .rl-section-label, .rl-section-header { text-align: center !important; }
  .rl-section-title { font-size: var(--rl-text-2xl) !important; }
  .rl-section-subtitle { font-size: var(--rl-text-sm) !important; }

  /* Portfolio CTA alignment */
  .rl-portfolio-more { text-align: center !important; padding: 0 var(--rl-4) !important; }
  .rl-portfolio-more .rl-btn { display: block !important; width: auto !important; max-width: 100% !important; margin: 0 auto !important; box-sizing: border-box !important; text-align: center !important; white-space: normal !important; word-wrap: break-word !important; padding: 16px 24px !important; font-size: 13px !important; letter-spacing: 1.5px !important; }
}

/* === SMALL PHONE (max-width: 480px) === */
@media (max-width: 480px) {
  .rl-hero h1 { font-size: 1.625rem !important; }
  .rl-hero p { font-size: 0.8125rem !important; }
  .rl-portfolio-grid { grid-template-columns: 1fr !important; }
  .rl-timeline { grid-template-columns: 1fr !important; }
  .rl-trust-items { gap: var(--rl-4) !important; }
  .rl-quote-form { padding: var(--rl-4) var(--rl-3) !important; margin: 0 var(--rl-2) !important; }
  .rl-quote-header { padding: 0 var(--rl-2) !important; }
  .rl-services-grid { max-width: 100% !important; }
  .rl-section-title { font-size: var(--rl-text-xl) !important; }
  .rl-container { padding-left: var(--rl-3) !important; padding-right: var(--rl-3) !important; }
  .rl-service-card { padding: var(--rl-6) var(--rl-4) !important; }
  .rl-timeline-step { padding: var(--rl-4) var(--rl-2) !important; }
  .rl-hero-buttons .rl-btn { font-size: var(--rl-text-xs) !important; padding: var(--rl-3) var(--rl-5) !important; }
}

/* === NAV HEADER FIX — remove top gap on mobile === */
@media (max-width: 768px) {
  .rl-nav { margin-top: 0 !important; top: 0 !important; left: 0 !important; right: 0 !important; width: 100% !important; border-radius: 0 !important; }
}

/* === HAMBURGER MENU IMPROVEMENTS === */
.rl-nav-toggle {
  display: none;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 8px !important;
  z-index: 1001 !important;
  position: relative !important;
}
.rl-nav-toggle .hamburger-line {
  display: block !important;
  width: 24px !important;
  height: 2px !important;
  background: var(--rl-navy) !important;
  margin: 5px 0 !important;
  transition: all 0.3s ease !important;
  border-radius: 2px !important;
}
/* Animate to X when active */
.rl-nav-toggle.active .hamburger-line:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px) !important;
}
.rl-nav-toggle.active .hamburger-line:nth-child(2) {
  opacity: 0 !important;
}
.rl-nav-toggle.active .hamburger-line:nth-child(3) {
  transform: rotate(-45deg) translate(5px, -5px) !important;
}

@media (max-width: 768px) {
  .rl-nav-toggle { display: flex !important; flex-direction: column !important; justify-content: center !important; align-items: center !important; }
}

/* Mobile menu slide-down animation */
.rl-nav-links {
  transition: max-height 0.35s ease, opacity 0.25s ease !important;
}
@media (max-width: 768px) {
  .rl-nav-links { display: none !important; }
  .rl-nav-links.active {
    display: flex !important;
    flex-direction: column !important;
    position: fixed !important;
    top: 80px !important;
    left: 0 !important;
    right: 0 !important;
    background: rgba(245,245,245,0.98) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    padding: 24px 20px !important;
    gap: 8px !important;
    border-bottom: 2px solid var(--rl-red) !important;
    z-index: 999 !important;
    box-shadow: 0 8px 32px rgba(27,42,74,0.12) !important;
    animation: menuSlideDown 0.3s ease forwards !important;
  }
  .rl-nav-links.active a {
    font-size: 16px !important;
    padding: 12px 16px !important;
    border-radius: 8px !important;
    transition: background 0.2s ease !important;
    text-align: center !important;
  }
  .rl-nav-links.active a:hover,
  .rl-nav-links.active a:active {
    background: rgba(27,42,74,0.06) !important;
  }
  .rl-nav-links.active .rl-nav-cta {
    margin-top: 8px !important;
    background: var(--rl-red) !important;
    color: white !important;
    text-align: center !important;
    padding: 14px 16px !important;
    border-radius: 8px !important;
    font-weight: 600 !important;
  }
}

@keyframes menuSlideDown {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* === WPAUTOP P-TAG FIX === */
.rl-nav-inner p {
  display: contents !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* === SECTION HEADER CENTERING (correct selectors) === */
.rl-services-header,
.rl-portfolio .rl-section-header,
.rl-process .rl-section-header,
.rl-faq .rl-section-header,
.rl-quote-section .rl-section-header {
  text-align: center !important;
}
.rl-services-header .rl-section-label,
.rl-services-header .rl-section-title,
.rl-services-header .rl-section-subtitle {
  text-align: center !important;
}
.rl-services-header .rl-section-subtitle {
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: 640px !important;
}
/* ===== ACCESSIBILITY FIXES ===== */

/* Fix: Red accent text contrast ratio (3.9:1 → 5.2:1 for WCAG AA) */
.rl-highlight,
.rl-hero h1 span,
.rl-section-title span {
  color: #A93226 !important;
}

/* Fix: Visible focus states for keyboard navigation */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid #A93226 !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 4px rgba(169, 50, 38, 0.25) !important;
}

/* Fix: Form input focus states */
.rl-quote-form input:focus,
.rl-quote-form select:focus,
.rl-quote-form textarea:focus {
  border-color: #A93226 !important;
  outline: 2px solid #A93226 !important;
  outline-offset: -1px !important;
  box-shadow: 0 0 0 3px rgba(169, 50, 38, 0.2) !important;
}

/* ===== FONT PERFORMANCE ===== */

/* Ensure Inter uses font-display: swap to prevent render blocking */
@font-face {
  font-family: 'Inter';
  font-display: swap;
}

/* ===== PORTFOLIO IMAGE STYLES ===== */

/* Portfolio image container - matches placeholder sizing */
.rl-portfolio-image {
  width: 100%;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  border-radius: 8px 8px 0 0;
}

.rl-portfolio-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.rl-portfolio-item:hover .rl-portfolio-image img {
  transform: scale(1.05);
}

/* Ensure overlay sits on top of the image */
.rl-portfolio-item {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
}

.rl-portfolio-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 20px;
  background: linear-gradient(transparent, rgba(27, 42, 74, 0.85));
  color: #fff;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.rl-portfolio-item:hover .rl-portfolio-overlay {
  opacity: 1;
}

.rl-portfolio-overlay h4 {
  color: #fff;
  margin: 0 0 4px 0;
  font-size: 1.1rem;
  font-weight: 600;
}

.rl-portfolio-overlay span {
  color: rgba(255,255,255,0.8);
  font-size: 0.85rem;
}

/* ===== HERO BACKGROUND IMAGE ===== */

.rl-hero {
  background: linear-gradient(135deg, rgba(27, 42, 74, 0.85) 0%, rgba(27, 42, 74, 0.6) 100%), url('https://revline.graphics/wp-content/uploads/2026/03/TrevorLyden-GreenAPU-6294-1024x683.jpg') !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.rl-hero h1 {
  color: #fff !important;
}

.rl-hero p {
  color: rgba(255,255,255,0.85) !important;
}

.rl-hero h1 span {
  color: #E74C3C !important;
}

.rl-hero .rl-btn-outline {
  color: #fff !important;
  border-color: #fff !important;
}

@media (max-width: 768px) {
  .rl-hero {
    background-position: center center !important;
  }
}
