/**
 * Web Vision Centric – global responsive layer
 * Loaded after page styles. Improves layout/UX on phones, tablets, and small laptops.
 */

/* -------------------------------------------------------------------------- */
/* Document & safe area                                                       */
/* -------------------------------------------------------------------------- */

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  overflow-x: hidden;
  max-width: 100vw;
}

/* Home (arc): allow vertical scroll on small viewports; keeps horizontal tidy */
@media (max-width: 991px) {
  html:has(#arcContainer) body {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    height: auto !important;
    min-height: 100vh;
    min-height: 100dvh;
  }

  /* Give the hero arc room so thumbnails are not clipped at the sides */
  html:has(#arcContainer) .background-elements {
    min-height: min(100dvh, 920px);
    padding-bottom: max(24px, env(safe-area-inset-bottom));
    box-sizing: border-box;
  }

  /* Logo block sits above the fixed bottom social bar */
  html:has(#arcContainer) .branding-bottom {
    bottom: calc(92px + env(safe-area-inset-bottom)) !important;
    z-index: 10052 !important;
    max-width: calc(100vw - 24px);
    padding-left: 8px;
    padding-right: 8px;
    box-sizing: border-box;
  }

  html:has(#arcContainer) .arc-container {
    z-index: 4 !important;
  }

  #arcContainer .arc-item {
    width: clamp(44px, 11vw, 68px) !important;
    height: clamp(44px, 11vw, 68px) !important;
  }
}

/* Home arc: lift pivot on phones so the semicircle wraps the logo (not only below it) */
@media (max-width: 767px) {
  html:has(#arcContainer) .arc-container {
    bottom: clamp(104px, 30vw, 175px) !important;
  }
}

/* Home: keep social docked to bottom (not mid-right) through tablet widths */
@media (min-width: 993px) and (max-width: 1199px) {
  html:has(#arcContainer) .social-buttons {
    display: flex !important;
    position: fixed !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: max(10px, env(safe-area-inset-bottom)) !important;
    transform: translateX(-50%) !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    width: calc(100vw - 16px) !important;
    max-width: 440px !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 8px !important;
    z-index: 10050 !important;
  }

  html:has(#arcContainer) body {
    padding-bottom: calc(72px + env(safe-area-inset-bottom)) !important;
  }
}

@media (max-width: 480px) {
  html:has(#arcContainer) .branding-bottom img {
    width: clamp(72px, 22vw, 100px) !important;
    height: clamp(72px, 22vw, 100px) !important;
  }

  html:has(#arcContainer) .branding-bottom h6 {
    font-size: clamp(0.85rem, 3.8vw, 1rem) !important;
  }
}

/* Fixed backgrounds are heavy on mobile; scroll attachment improves stability */
@media (max-width: 768px) {
  body {
    background-attachment: scroll !important;
  }
}

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

/* Keep fixed-size UI / arc thumbnails sharp */
.arc-item img {
  max-width: none !important;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.nav-logo-container img,
.footer-logo-container img {
  max-width: none;
}

/* Tables / wide content */
table {
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

/* -------------------------------------------------------------------------- */
/* Navbar (all variants)                                                      */
/* -------------------------------------------------------------------------- */

/* Bootstrap adds a caret on .dropdown-toggle::after; we use one small FA chevron only */
.navbar .dropdown-services > .dropdown-toggle::after,
.navbar .dropdown-services > .dropdown-toggle::before {
  display: none !important;
  content: none !important;
  border: none !important;
  margin-left: 0 !important;
}

.navbar .dropdown-services > .dropdown-toggle i.fa-chevron-down {
  font-size: 12px !important;
  line-height: 1 !important;
}

@media (max-width: 1199px) {
  .navbar {
    padding-left: max(14px, env(safe-area-inset-left)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    row-gap: 10px !important;
    column-gap: 8px !important;
  }

  .nav-logo-container img {
    width: clamp(40px, 10vw, 50px) !important;
    height: clamp(40px, 10vw, 50px) !important;
  }

  .nav-logo-text h6 {
    font-size: clamp(0.72rem, 2.4vw, 0.9rem) !important;
  }
}

@media (max-width: 991px) {
  .navbar {
    justify-content: center !important;
  }

  .navbar .nav-logo-container {
    flex: 1 1 auto;
    justify-content: center;
    min-width: 0;
  }

  .navbar .ms-auto,
  .navbar > .ms-auto,
  .navbar .nav-links,
  .navbar-links {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    gap: 6px 10px !important;
    padding-top: 4px !important;
  }

  .navbar a:not(.login-btn),
  .navbar .dropdown-toggle {
    margin-left: 6px !important;
    margin-right: 6px !important;
    font-size: clamp(12px, 3vw, 14px) !important;
  }

  .navbar .login-btn {
    padding: 8px 16px !important;
    margin-left: 8px !important;
    margin-right: 8px !important;
    font-size: clamp(12px, 3vw, 14px) !important;
  }

}

@media (max-width: 576px) {
  .navbar {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }

  .navbar a:not(.login-btn),
  .navbar .dropdown-toggle {
    margin-left: 4px !important;
    margin-right: 4px !important;
  }
}

/* -------------------------------------------------------------------------- */
/* Fixed social sidebar → bottom bar (touch-friendly)                         */
/* -------------------------------------------------------------------------- */

@media (max-width: 992px) {
  .social-buttons {
    display: flex !important;
    position: fixed !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: max(10px, env(safe-area-inset-bottom)) !important;
    transform: translateX(-50%) !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    width: calc(100vw - 16px) !important;
    max-width: 440px !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 8px !important;
    z-index: 10050 !important;
  }

  /* Icons only on narrow screens – avoids overlap / odd expansion */
  .social-btn,
  .social-btn-side {
    width: 46px !important;
    height: 46px !important;
    min-width: 44px;
    min-height: 44px;
    touch-action: manipulation !important;
    cursor: pointer !important;
    -webkit-tap-highlight-color: rgba(255, 204, 0, 0.2);
  }

  .social-buttons a {
    touch-action: manipulation !important;
  }

  .social-btn:hover,
  .social-btn-side:hover {
    width: 46px !important;
    transform: none !important;
  }

  .social-btn:hover .btn-text,
  .social-btn-side:hover .btn-text {
    opacity: 0 !important;
    width: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  body:has(.social-buttons) {
    padding-bottom: calc(72px + env(safe-area-inset-bottom)) !important;
  }
}

/* -------------------------------------------------------------------------- */
/* Footers                                                                    */
/* -------------------------------------------------------------------------- */

@media (max-width: 991px) {
  .footer-container {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    padding-left: max(16px, env(safe-area-inset-left)) !important;
    padding-right: max(16px, env(safe-area-inset-right)) !important;
    gap: 28px !important;
  }

  .footer-about,
  .footer-links,
  .footer-contact {
    width: 100% !important;
    max-width: 520px !important;
  }

  .footer-links ul {
    padding-left: 0 !important;
    list-style: none !important;
  }

  .footer-bottom {
    flex-direction: column !important;
    gap: 12px !important;
    text-align: center !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .payments img {
    max-width: min(280px, 90vw) !important;
    height: auto !important;
  }

  /* Match centered footer: stack icon + text so contact block aligns with other columns */
  .footer-contact {
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
  }

  .footer-contact h3 {
    text-align: center !important;
    width: 100%;
  }

  .footer-contact .contact-item {
    justify-content: center !important;
    align-items: center !important;
    flex-direction: column !important;
    text-align: center !important;
    gap: 10px !important;
    max-width: 100%;
  }

  .footer-contact .contact-icon {
    margin-bottom: 0 !important;
  }

  .footer-contact .contact-text,
  .footer-contact .contact-detail {
    text-align: center !important;
  }

  .footer-contact .contact-text strong {
    text-align: center !important;
  }
}

/*
 * Services mega-menu (tablet / small laptop / home): keep panel horizontally centered
 * and anchored under the navbar — not vertically centered in the viewport (too far from nav on iPad).
 */
@media (max-width: 1199px) {
  .dropdown-services .dropdown-menu-custom {
    --wvc-dropdown-top: max(72px, calc(env(safe-area-inset-top, 0px) + 52px));
    position: fixed !important;
    left: 50% !important;
    right: auto !important;
    top: var(--wvc-dropdown-top) !important;
    bottom: auto !important;
    transform: translate(-50%, 0) !important;
    width: min(1100px, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    margin: 0 !important;
    margin-top: 0 !important;
    box-sizing: border-box !important;
    max-height: calc(100dvh - var(--wvc-dropdown-top) - 16px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    z-index: 10060 !important;
  }

  .dropdown-services:hover .dropdown-menu-custom,
  .dropdown-menu-custom:hover {
    transform: translate(-50%, 0) !important;
  }

  .dropdown-menu-custom::before {
    display: none !important;
  }

  .navbar .dropdown-services .services-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 575px) {
  .navbar .dropdown-services .services-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Wide desktop: constrain width so mega-menu stays in viewport */
@media (min-width: 1200px) {
  .dropdown-services .dropdown-menu-custom {
    width: min(1100px, calc(100vw - 48px)) !important;
    max-width: calc(100vw - 48px) !important;
    box-sizing: border-box !important;
  }
}

/* Floating section nav on service pages: clear fixed social bar, readable tap targets */
@media (max-width: 992px) {
  .inner-nav-container:not(.sticky) {
    bottom: calc(82px + env(safe-area-inset-bottom)) !important;
    z-index: 10055 !important;
  }

  .inner-nav-container.sticky {
    z-index: 10055 !important;
  }

  .inner-nav-pill {
    position: relative !important;
    max-width: min(420px, calc(100vw - 24px)) !important;
    padding-right: 48px !important;
    box-sizing: border-box !important;
  }

  .mobile-nav-toggle {
    position: absolute !important;
    right: 6px !important;
    left: auto !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
  }
}

@media (max-width: 768px) {
  /* Inline resize() used to set display:none; ensure .show can open the panel */
  .inner-nav-links.show {
    display: flex !important;
    flex-direction: column !important;
  }

  .inner-nav-link {
    white-space: normal !important;
  }
}

/* Service pages: floating section nav vs CTA + rating — reserve space so pill/social bar do not cover hero actions */
@media (max-width: 992px) {
  .hero-wrapper:has(#innerNav) {
    padding-bottom: clamp(170px, 36vw, 240px) !important;
  }

  .hero-wrapper:has(#innerNav) .hero-content {
    padding-bottom: 8px !important;
  }
}

/* -------------------------------------------------------------------------- */
/* Contact page                                                               */
/* -------------------------------------------------------------------------- */

@media (max-width: 991px) {
  .contact-container {
    flex-direction: column !important;
    align-items: stretch !important;
    padding-left: max(14px, env(safe-area-inset-left)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    gap: 28px !important;
  }

  .contact-info,
  .contact-form-wrapper,
  .contact-form-section {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .plan-context-banner {
    margin-left: 0 !important;
    margin-right: 0 !important;
    font-size: clamp(13px, 3.5vw, 15px) !important;
  }
}

@media (max-width: 576px) {
  .form-group {
    margin-bottom: 18px !important;
  }

  .submit-btn {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* -------------------------------------------------------------------------- */
/* Headings & hero blocks                                                     */
/* -------------------------------------------------------------------------- */

@media (max-width: 991px) {
  .headings-container .main-heading,
  .main-heading {
    font-size: clamp(1.75rem, 6vw, 2.75rem) !important;
    line-height: 1.15 !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .headings-container .second-heading,
  .second-heading {
    font-size: clamp(0.95rem, 3.5vw, 1.25rem) !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .about-container {
    padding-left: max(16px, env(safe-area-inset-left)) !important;
    padding-right: max(16px, env(safe-area-inset-right)) !important;
  }
}

/* -------------------------------------------------------------------------- */
/* Policy / legal                                                              */
/* -------------------------------------------------------------------------- */

@media (max-width: 768px) {
  .policy-wrapper {
    padding-left: max(12px, env(safe-area-inset-left)) !important;
    padding-right: max(12px, env(safe-area-inset-right)) !important;
  }

  .policy-card {
    padding: 22px 16px !important;
  }

  .policy-card h1 {
    font-size: clamp(1.35rem, 5vw, 1.85rem) !important;
  }

  .policy-card h2 {
    font-size: clamp(1.1rem, 4vw, 1.35rem) !important;
  }
}

/* -------------------------------------------------------------------------- */
/* Portfolio                                                                  */
/* -------------------------------------------------------------------------- */

/* Tablet: two project cards per row */
@media (min-width: 768px) and (max-width: 991px) {
  .professional-project-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
  }

  .professional-project-card {
    height: 320px !important;
  }

  .project-grid-section {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

/* Phone: one card per row, readable title + arrow */
@media (max-width: 767px) {
  .professional-project-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  .professional-project-card {
    height: auto !important;
    min-height: 260px !important;
    max-height: none !important;
  }

  .professional-image-container {
    min-height: 220px !important;
    height: 240px !important;
  }

  .professional-project-title {
    font-size: clamp(1rem, 4.5vw, 1.35rem) !important;
    line-height: 1.25 !important;
    flex: 1 !important;
    min-width: 0 !important;
    padding-right: 8px !important;
  }

  .professional-card-footer {
    padding: 14px 16px !important;
    align-items: center !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
  }

  .professional-small-arrow {
    flex-shrink: 0 !important;
    font-size: 1.1rem !important;
  }

  .professional-category-label {
    font-size: 10px !important;
    padding: 5px 10px !important;
    max-width: calc(100% - 30px);
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
  }

  .project-grid-section {
    padding: 16px 12px !important;
  }

  .projects-grid-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
  }
}

@media (max-width: 768px) {
  .categories-strip {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 8px !important;
  }
}

/* -------------------------------------------------------------------------- */
/* Home (index): vertical side copy clashes on narrow screens               */
/* -------------------------------------------------------------------------- */

@media (max-width: 768px) {
  .left-text {
    display: none !important;
  }

  .branding-bottom {
    bottom: max(24px, env(safe-area-inset-bottom)) !important;
    padding-left: 12px;
    padding-right: 12px;
    max-width: 100vw;
  }

  .branding-bottom img {
    width: clamp(72px, 22vw, 100px) !important;
    height: clamp(72px, 22vw, 100px) !important;
  }
}

/* -------------------------------------------------------------------------- */
/* Hosting: tabs & expert modal                                             */
/* -------------------------------------------------------------------------- */

@media (max-width: 768px) {
  .tabs-header {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 8px !important;
  }

  .tab-btn {
    font-size: clamp(11px, 2.8vw, 14px) !important;
    padding: 8px 12px !important;
  }

  .expert-modal-container {
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
    margin: 12px auto !important;
  }

  .expert-modal-body {
    padding: 16px !important;
    max-height: min(70vh, 520px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* -------------------------------------------------------------------------- */
/* intl-tel-input: country list above modals (hosting expert popup, etc.)      */
/* Contact page uses inline dropdown — keep its own z-index from contactus.css */
/* -------------------------------------------------------------------------- */

body:not(.wvc-contact-page) .iti__country-list {
  z-index: 100100 !important;
}

/* Hosting expert modal: keep country dropdown stacking sane inside modal (not behind overlay hacks) */
body:not(.wvc-contact-page) .phone-input-container-expert .iti__country-list {
  z-index: 12000 !important;
}

@media (max-width: 576px) {
  .iti {
    width: 100% !important;
  }

  /* Contact form: keep intl-tel-input’s internal layout (flag + input row) */
  body:not(.wvc-contact-page) .iti {
    display: block !important;
  }

  .iti__flag-container {
    z-index: 2;
  }
}

/* -------------------------------------------------------------------------- */
/* Reduce motion (accessibility)                                               */
/* -------------------------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* -------------------------------------------------------------------------- */
/* Current page – navbar accent                                                */
/* -------------------------------------------------------------------------- */

.navbar a.wvc-nav-active:not(.login-btn),
.navbar .ms-auto a.wvc-nav-active:not(.login-btn),
.navbar .nav-links a.wvc-nav-active:not(.login-btn),
.navbar .navbar-links a.wvc-nav-active:not(.login-btn),
.navbar .navbar-right a.wvc-nav-active:not(.login-btn),
.navbar .dropdown-services > .dropdown-toggle.wvc-nav-active {
  color: #fdcf08 !important;
  font-weight: 800 !important;
}

.navbar a.login-btn.wvc-nav-active,
.navbar .ms-auto a.login-btn.wvc-nav-active,
.navbar .nav-links a.login-btn.wvc-nav-active {
  background: #fdcf08 !important;
  color: #111 !important;
  border-color: #fdcf08 !important;
}

.dropdown-menu-custom a.wvc-nav-active {
  color: #fdcf08 !important;
  font-weight: 800 !important;
}

/* -------------------------------------------------------------------------- */
/* Footer Quick Links – prevent default / visited blue on mobile               */
/* -------------------------------------------------------------------------- */

.footer .footer-links ul li a,
.footer .footer-links ul li a:visited {
  color: #bbb !important;
  text-decoration: none !important;
  -webkit-tap-highlight-color: rgba(253, 207, 8, 0.22);
}

.footer .footer-links ul li a:hover,
.footer .footer-links ul li a:focus-visible {
  color: #ffcc00 !important;
}

.footer .bottom-links a,
.footer .bottom-links a:visited {
  color: #ccc !important;
}

.footer .bottom-links a:hover,
.footer .bottom-links a:focus-visible {
  color: #ffcc00 !important;
}

/* Footer contact column – icons readable on yellow circles (same as service pages; overrides stray .contact-icon rules) */
.footer .footer-contact .contact-icon i {
  color: #000 !important;
}

/* -------------------------------------------------------------------------- */
/* Login – readable fixed navbar above auth card (tablet / phone)             */
/* -------------------------------------------------------------------------- */

@media (max-width: 992px) {
  body.wvc-login-page .navbar {
    background: rgba(0, 0, 0, 0.85) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35);
    padding-bottom: 12px !important;
  }

  body.wvc-login-page #container.container {
    position: relative;
    z-index: 1;
  }
}

/* -------------------------------------------------------------------------- */
/* Packages – mobile / tablet layout                                           */
/* -------------------------------------------------------------------------- */

@media (max-width: 1199px) {
  html:has(body.packages-page) {
    overflow-y: auto !important;
    height: auto !important;
  }

  body.packages-page {
    overflow-x: hidden !important;
    overflow-y: auto !important;
    height: auto !important;
    min-height: 100vh !important;
    min-height: 100dvh !important;
  }

  body.packages-page .main-layout {
    height: auto !important;
    min-height: 0 !important;
    padding-left: max(12px, env(safe-area-inset-left)) !important;
    padding-right: max(12px, env(safe-area-inset-right)) !important;
    padding-bottom: clamp(160px, 42vw, 220px) !important;
  }

  body.packages-page .services-sidebar {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    gap: 10px !important;
    width: 100% !important;
    max-height: none !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    padding: 12px 4px 18px !important;
    margin: 0 -4px 8px !important;
    border-right: none !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1) !important;
  }

  body.packages-page .services-sidebar .service-item {
    flex: 0 0 auto !important;
    margin-bottom: 0 !important;
    margin-right: 0 !important;
    padding: 12px 18px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(0, 0, 0, 0.12) !important;
    border-right: 1px solid rgba(0, 0, 0, 0.12) !important;
    font-size: 13px !important;
    white-space: nowrap !important;
    scroll-snap-align: start;
    transform: none !important;
    max-width: min(280px, 85vw);
  }

  body.packages-page .services-sidebar .service-item:hover {
    transform: none !important;
    padding-left: 18px !important;
  }

  body.packages-page .services-sidebar .service-item.active {
    padding-left: 18px !important;
  }

  body.packages-page .services-sidebar .service-item.active::before {
    display: none !important;
  }

  body.packages-page .services-sidebar .service-item.active::after {
    display: none !important;
  }

  body.packages-page .content-area {
    padding-left: 0 !important;
    padding-top: 12px !important;
  }

  body.packages-page .main-container {
    flex-direction: column !important;
    gap: 28px !important;
    height: auto !important;
  }

  body.packages-page .details-column,
  body.packages-page .price-column {
    width: 100% !important;
    padding-right: 0 !important;
  }

  body.packages-page .complete-package-name {
    white-space: normal !important;
    font-size: clamp(1.35rem, 5.5vw, 2rem) !important;
    line-height: 1.2 !important;
  }

  body.packages-page .features-cup-container {
    height: auto !important;
    min-height: 240px !important;
    max-height: min(52vh, 420px) !important;
  }

  body.packages-page .features-list-scroll {
    max-height: min(46vh, 380px) !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  body.packages-page .price-display {
    justify-content: center !important;
  }

  body.packages-page .packages-thumbnails-container {
    left: max(10px, env(safe-area-inset-left)) !important;
    right: max(10px, env(safe-area-inset-right)) !important;
    bottom: max(calc(72px + env(safe-area-inset-bottom)), 12px) !important;
    height: auto !important;
    min-height: 72px !important;
    padding: 8px 0 !important;
  }

  body.packages-page .packages-thumbnails {
    gap: 8px !important;
    padding: 4px 4px !important;
  }

  body.packages-page .package-thumb {
    min-width: 72px !important;
    height: 58px !important;
  }
}

@media (max-width: 576px) {
  body.packages-page .price-number {
    font-size: clamp(3rem, 16vw, 5rem) !important;
  }

  body.packages-page .tagline-1,
  body.packages-page .tagline-2 {
    text-align: center !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
}

/* ===== 404 page ===== */
body.wvc-404-page {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

body.wvc-404-page .wvc-404-main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 24px 80px;
  position: relative;
  z-index: 2;
}

body.wvc-404-page .wvc-404-card {
  max-width: 560px;
  width: 100%;
  text-align: center;
  padding: 40px 36px 44px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 2px solid rgba(255, 204, 0, 0.45);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.12);
}

body.wvc-404-page .wvc-404-icon-wrap {
  margin: 0 auto 8px;
  width: min(200px, 70vw);
}

body.wvc-404-page .wvc-404-icon {
  width: 100%;
  height: auto;
  display: block;
}

body.wvc-404-page .wvc-404-code {
  margin: 0 0 4px;
  font-size: clamp(4.5rem, 18vw, 7rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, #f8b000 0%, #ffcc00 45%, #00e9f8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

body.wvc-404-page .wvc-404-title {
  font-size: clamp(1.5rem, 4.5vw, 2rem);
  font-weight: 800;
  color: #111;
  margin: 0 0 14px;
}

body.wvc-404-page .wvc-404-text {
  font-size: 1.05rem;
  line-height: 1.65;
  color: #444;
  margin: 0 0 28px;
  font-weight: 500;
}

body.wvc-404-page .wvc-404-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
}

body.wvc-404-page .wvc-404-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  border-radius: 50px;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  transition: all 0.3s ease;
  border: 2px solid transparent;
}

body.wvc-404-page .wvc-404-btn-primary {
  background: #111;
  color: #ffcc00;
  border-color: #111;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.2);
}

body.wvc-404-page .wvc-404-btn-primary:hover {
  background: #ffcc00;
  color: #111;
  border-color: #ffcc00;
  transform: translateY(-2px);
}

body.wvc-404-page .wvc-404-btn-secondary {
  background: transparent;
  color: #111;
  border-color: #111;
}

body.wvc-404-page .wvc-404-btn-secondary:hover {
  background: #111;
  color: #ffcc00;
  transform: translateY(-2px);
}

@media (max-width: 768px) {
  body.wvc-404-page .wvc-404-card {
    padding: 32px 22px 36px;
  }

  body.wvc-404-page .wvc-404-actions {
    flex-direction: column;
    align-items: stretch;
  }

  body.wvc-404-page .wvc-404-btn {
    justify-content: center;
  }
}
