/* =========================
   Service Details Page Styles
   ========================= */
/* Fallback: if the reveal JS isn't present, don't hide animated elements */
[data-animate] { opacity: 1 !important; transform: none !important; }
[data-animate="sequence"] > * { opacity: 1 !important; transform: none !important; }

/* Page hero (reuses your services page pattern) */
.page-hero {
    position: relative;
    min-height: 360px;
    display: flex;
    align-items: center; /* This will vertically center the content */
    background-size: cover;
    background-position: center;
    isolation: isolate;
  }
  .page-hero::before {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(10,11,15,0.55) 0%, rgba(10,11,15,0.72) 100%);
    z-index: 0;
  }
  .page-hero .container {
    position: relative; z-index: 1;
    padding: 96px 20px 56px; text-align: center;
  }
  .page-hero-title {
    font-size: clamp(2rem, 6vw, 64px);
    font-weight: 800; color: #fff; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px;
  }
  .breadcrumbs { display: inline-flex; gap: 10px; align-items: center; color: rgba(255,255,255,0.9); font-weight: 600; }
  .breadcrumbs a { color: rgba(255,255,255,0.9); }
  .breadcrumbs a:hover { color: var(--primary-red); }
  .breadcrumbs .sep { color: rgba(255,255,255,0.65); font-size: 12px; }
  
  /* Layout */
  .service-details { padding: 90px 0 80px; background: #fff; }
  .service-grid {
    display: grid; grid-template-columns: 360px 1fr; gap: 40px; align-items: start;
  }
  @media (max-width: 1200px) {
    .service-grid { gap: 28px; grid-template-columns: 320px 1fr; }
  }
  @media (max-width: 992px) {
    .service-grid { grid-template-columns: 1fr; gap: 22px; }
  }
  
  /* Sidebar */
  .service-sidebar { position: sticky; top: calc(var(--total-header-height, 120px) + 24px); }
  @media (max-width: 992px) {
    .service-sidebar { position: static; top: auto; }
  }
  .site-footer { position: relative; z-index: 1; }

  .sidebar-card {
    background: var(--off-white-bg);
    border: 1px solid var(--border-dark);
    border-radius: 12px;
    padding: 22px;
  }
  .sidebar-card + .sidebar-card { margin-top: 24px; }
  
  .sidebar-title h3 { font-size: 20px; font-weight: 700; color: var(--dark-text); margin-bottom: 14px; }
  .sidebar-title .bar {
    display: inline-block; width: 28px; height: 3px; background: #222; border-radius: 3px; margin-right: 8px;
  }
  .sidebar-title .accent {
    display: inline-block; width: 28px; height: 3px; background: var(--primary-red); border-radius: 3px;
  }
  
  /* Services list */
  .service-list { display: grid; gap: 12px; }
  .service-link {
    display: flex; align-items: center; justify-content: space-between;
    background: #fff; color: var(--dark-text);
    border: 1px solid var(--border-dark); border-radius: 8px;
    padding: 16px 16px;
    font-weight: 600;
    transition: all .25s ease;
  }
  .service-link i { color: var(--primary-red); transition: transform .25s ease, color .25s ease; }
  .service-link:hover {
    transform: translateY(-2px);
    border-color: rgba(0,0,0,0.15);
    box-shadow: 0 10px 22px rgba(0,0,0,0.06);
  }
  .service-link.active {
    background: var(--primary-red);
    color: #fff;
    border-color: var(--primary-red);
  }
  .service-link.active i { color: #fff; transform: translateX(2px); }
  
  /* Download list */
  .download-list { list-style: none; display: grid; gap: 14px; margin: 0; padding: 0; }
  .download-list li {
    display: grid; grid-template-columns: 1fr auto; align-items: center;
    background: #fff; border: 1px solid var(--border-dark); border-radius: 8px; padding: 14px;
  }
  .file-meta { display: flex; align-items: center; gap: 12px; }
  .file-meta i { font-size: 26px; color: var(--primary-red); }
  .file-meta strong { display: block; color: var(--dark-text); }
  .file-meta small { display: block; color: var(--light-text); font-weight: 700; }
  .dl-btn {
    width: 42px; height: 42px; display: grid; place-items: center; border-radius: 8px;
    background: #111; color: #fff; text-decoration: none;
    transition: transform .2s ease, background .2s ease;
  }
  .dl-btn:hover { transform: translateY(-1px); background: var(--primary-red); }
  
  /* Help card */
  .help-card {
    position: relative;
    min-height: 220px;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border-dark);
    background: url('https://images.unsplash.com/photo-1503387762-592deb58ef4e?auto=format&fit=crop&w=1600&q=60') center/cover no-repeat;
  }
  .help-card::before {
    content: ""; position: absolute; inset: 0; background: rgba(0,0,0,0.55);
  }
  .help-content {
    position: relative; z-index: 1; padding: 22px;
    color: #fff; display: grid; align-content: center; min-height: 220px; gap: 14px;
  }
  .help-content h4 { font-size: 20px; line-height: 1.4; }
  .help-btn {
    display: inline-flex; align-items: center; gap: 10px;
    background: var(--primary-red); color: #fff; border: 2px solid var(--primary-red);
    padding: 12px 18px; border-radius: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: .5px;
  }
  .help-btn:hover { background: transparent; color: var(--primary-red); }
  
  /* Main content */
  .service-content h2 {
    font-size: clamp(1.8rem, 3.2vw, 42px);
    font-weight: 800; color: var(--dark-text); margin-bottom: 14px;
  }
  .service-content p { color: var(--light-text); line-height: 1.8; margin: 0 0 16px; }
  .cover { margin-bottom: 24px; }
  .cover img {
    width: 100%; height: auto; display: block;
    border-radius: 12px; border: 1px solid var(--border-dark);
  }
  
  .content-row {
    display: grid; grid-template-columns: 1.1fr .9fr; gap: 24px; align-items: start; margin: 10px 0 20px;
  }
  @media (max-width: 992px) {
    .content-row { grid-template-columns: 1fr; gap: 18px; }
  }
  .img-col img {
    width: 100%; height: auto; border-radius: 12px; border: 1px solid var(--border-dark);
  }
  
  .benefits { list-style: none; margin: 12px 0 18px; padding: 0; display: grid; gap: 10px; }
  .benefits li { display: flex; gap: 12px; align-items: flex-start; font-weight: 600; color: var(--dark-text); }
  .benefits i { color: var(--primary-red); margin-top: 3px; }
  
  /* CTAs */
  .cta-inline { display: flex; gap: 12px; margin-top: 16px; flex-wrap: wrap; }
  .cta-primary {
    background: var(--primary-red); color: #fff; border: 2px solid var(--primary-red);
    padding: 12px 18px; border-radius: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: .5px;
  }
  .cta-primary:hover { background: transparent; color: var(--primary-red); }
  .cta-ghost {
    background: transparent; color: var(--dark-text); border: 2px solid var(--border-dark);
    padding: 12px 18px; border-radius: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: .5px;
  }
  .cta-ghost:hover { border-color: var(--primary-red); color: var(--primary-red); }
  
  /* =========================
     Small-screen refinements
     ========================= */
  @media (max-width: 992px) {
    .page-hero { min-height: 300px; }
    .page-hero .container { padding: 84px 16px 42px; }
    .page-hero-title { font-size: clamp(28px, 6vw, 44px); }
    .breadcrumbs { flex-wrap: wrap; gap: 6px; }
  }
  @media (max-width: 560px) {
    .page-hero { min-height: 260px; }
    .page-hero .container { padding: 72px 14px 36px; }
    .sidebar-card { padding: 16px; }
    .service-link { padding: 14px; }
    .download-list li { padding: 12px; }
    .dl-btn { width: 44px; height: 44px; }
    .file-meta i { font-size: 22px; }
  }
  @media (max-width: 768px) {
    .cta-inline { gap: 10px; }
    .cta-inline .btn { flex: 1 1 100%; text-align: center; }
  }
  
  /* =========================
     Mobile/Tablet Navigation Enhancements
     (kept here so this page is fully responsive without editing global CSS)
     ========================= */
  
  /* Toggle button (hidden on desktop) */
  .menu-toggle {
    display: none;
    width: 44px; height: 44px;
    border: 1px solid var(--border-dark);
    background: #fff; border-radius: 10px;
    align-items: center; justify-content: center;
    gap: 5px; cursor: pointer;
  }
  .menu-toggle .menu-bar {
    display: block; width: 22px; height: 2px;
    background: #111; border-radius: 2px;
    transition: transform .25s ease, opacity .25s ease;
  }
  
  /* Overlay for mobile menu */
  .menu-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.45);
    opacity: 0; visibility: hidden;
    transition: opacity .25s ease, visibility .25s ease;
    z-index: 9998;
  }
  body.menu-open .menu-overlay { pointer-events: auto; }

  body.menu-open .menu-overlay { pointer-events: auto;  }
  body.menu-open { overflow: hidden; }
  
  /* Morph the toggle into an X when open */
  body.menu-open .menu-toggle .menu-bar:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  body.menu-open .menu-toggle .menu-bar:nth-child(2) { opacity: 0; }
  body.menu-open .menu-toggle .menu-bar:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
  
  /* Off-canvas primary nav on mobile/tablet */
  @media (max-width: 992px) {
    /* Show the toggle */
    .menu-toggle { display: inline-flex; }
  
    /* Slide-in panel for .main-menu */
    .main-menu {
      position: fixed;
      top: var(--total-header-height, 120px);
      right: 0;
      width: min(86vw, 360px);
      height: calc(100vh - var(--total-header-height, 120px));
      background: #fff;
      border-left: 1px solid var(--border-dark);
      box-shadow: -8px 0 24px rgba(0,0,0,.08);
      transform: translateX(100%);
      transition: transform .3s ease;
      overflow-y: auto;
      padding: 12px 10px 24px;
      z-index: 9999;
    }
    body.menu-open .main-menu { transform: translateX(0); }
  
    .main-menu > ul { display: flex; flex-direction: column; gap: 0; }
    .main-menu > ul > li > a {
      display: block;
      padding: 14px 12px;
      font-weight: 700;
      border-radius: 8px;
    }
  
    /* Show sub-menu inline for easy tapping */
    .main-menu .sub-menu {
      display: block;
      padding: 4px 0 10px 12px;
    }
    .main-menu .sub-menu a {
      display: block;
      padding: 10px 12px;
      border-radius: 8px;
      font-weight: 600;
    }
    .main-menu a:hover { background: var(--off-white-bg); }
  
    /* Compact call-box on tablet */
    .call-box small { display: none; }
    .call-box strong { font-size: 15px; }
  }
  /* Hide call-box completely on very small phones */
  @media (max-width: 560px) {
    .call-box { display: none; }
  }
  
  /* Top bar wrapping on narrow screens */
  @media (max-width: 600px) {
    .top-bar .container { display: grid; gap: 8px; }
    .tb-social { gap: 10px; }
    .tb-meta { justify-self: center; }
  }
  
  /* =========================
     Footer responsive helpers (safe overrides)
     ========================= */
  @media (max-width: 992px) {
    .footer-main { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
  }
  @media (max-width: 600px) {
    .footer-main { grid-template-columns: 1fr; }
  }
  
  /* Back-to-top spacing with iOS safe-area */
  #progress-scroll-btn { bottom: calc(22px + env(safe-area-inset-bottom, 0px)); right: 20px; }
  
  /* Reduced motion for users who prefer it */
  @media (prefers-reduced-motion: reduce) {
    * { transition: none !important; animation: none !important; }
  }