/* RSDC v27 homepage styles restored */
:root {
      --rs-yellow: #ffd400;
      --rs-yellow-deep: #f4bc00;
      --rs-yellow-soft: #ffe078;
      --rs-yellow-hot: #ffef9d;
      --panel-border: rgba(255,255,255,0.18);
      --text: #ffffff;
      --muted: #cfd6dc;
      --hero-card-max: 620px;
      --footer-black: #020304;
    }

    * { box-sizing: border-box; }

    html, body {
      margin: 0;
      width: 100%;
      min-height: 100%;
      background: #050607;
      color: var(--text);
      font-family: Arial, Helvetica, sans-serif;
      overflow-x: hidden;
    }

    .rsdc-v27-bg {
      position: fixed;
      inset: 0;
      overflow: hidden;
      background: #050607;
      z-index: 0;
    }

    .rsdc-v27-bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center center;
      display: block;
      transform-origin: center center;
      animation: rsdc-v27-gentle-drift 34s ease-in-out infinite alternate;
    }

    @keyframes rsdc-v27-gentle-drift {
      0% { transform: scale(1.012) translate3d(0, 0, 0); }
      100% { transform: scale(1.028) translate3d(-0.28%, 0.10%, 0); }
    }

    .rsdc-v27-bg::after {
      content: "";
      position: absolute;
      inset: 0;
      pointer-events: none;
      background:
        linear-gradient(90deg, rgba(0,0,0,.06), rgba(0,0,0,.24) 44%, rgba(0,0,0,.50)),
        linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.28)),
        repeating-linear-gradient(0deg, rgba(255,255,255,.032) 0px, rgba(255,255,255,.032) 1px, transparent 1px, transparent 4px),
        repeating-linear-gradient(90deg, rgba(255,255,255,.016) 0px, rgba(255,255,255,.016) 1px, transparent 1px, transparent 4px);
    }

    .page-shell {
      position: relative;
      z-index: 1;
      min-height: 100vh;
      display: flex;
      flex-direction: column;
    }

    .top-chrome {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 1000;
      pointer-events: none;
    }

    .top-chrome > * {
      pointer-events: auto;
    }
    .top-strip {
      position: relative;
      height: 6px;
      background: linear-gradient(
        112deg,
        #fff000 0%,
        #ffd400 24%,
        #ffcb00 42%,
        #f4b700 58%,
        #d8a300 76%,
        #ffcb00 90%,
        #fff000 100%
      );
      background-size: 220% 220%;
      background-position: 0% 50%;
      box-shadow: 0 1px 0 rgba(0,0,0,.45);
      flex: 0 0 auto;
      overflow: hidden;
      animation: stripe-gold-shift 8.5s ease-in-out infinite alternate;
    }

    @keyframes stripe-gold-shift {
      0%   { background-position: 0% 50%; }
      100% { background-position: 100% 50%; }
    }

      100% { transform: translateX(calc(100vw + 40%)); }
    }

    .site-header {
      position: relative;
      z-index: 5;
      min-height: 96px;
      background:
        linear-gradient(90deg,
          rgba(0,0,0,0.00) 0%,
          rgba(0,0,0,0.00) 54%,
          rgba(0,0,0,0.46) 68%,
          rgba(0,0,0,0.78) 100%),
        linear-gradient(180deg,
          rgba(0,0,0,0.78),
          rgba(0,0,0,0.34),
          rgba(0,0,0,0.00));
      backdrop-filter: none;
      flex: 0 0 auto;
    }

    .page-shell {
      padding-top: 102px;
    }

    .header-contact-group {
      position: absolute;
      top: 10px;
      right: clamp(26px, 3vw, 56px);
      display: flex;
      align-items: flex-start;
      justify-content: flex-end;
      gap: clamp(12px, 1.5vw, 24px);
      width: min(560px, calc(100vw - 84px));
      max-width: calc(100vw - 84px);
      overflow: visible;
    }

    .header-logo {
      flex: 0 0 auto;
      margin-top: 12px;
      filter:
        drop-shadow(0 0 10px rgba(255,255,255,0.14))
        drop-shadow(0 4px 14px rgba(0,0,0,0.42));
    }

    .header-logo img {
      display: block;
      width: clamp(145px, 12vw, 205px);
      height: auto;
    }

    .phone {
      width: clamp(250px, 23vw, 330px);
      max-width: clamp(250px, 23vw, 330px);
      min-width: 0;
      display: flex;
      flex-direction: column;
      align-items: flex-end;
      gap: 1px;
      color: #fff;
      text-decoration: none;
      white-space: nowrap;
      text-shadow: 0 2px 12px rgba(0,0,0,.82);
      flex: 0 0 auto;
    }

    .phone .talk {
      display: block;
      width: 100%;
      text-align: right;
      font-size: clamp(20px, 1.65vw, 28px);
      line-height: 0.94;
      font-family: "Caveat", arial;
      font-weight: 600;
      padding-right: 2px;
    }

    .phone .number {
      display: block;
      width: 100%;
      text-align: right;
      font-size: clamp(25px, 2.15vw, 35px);
      line-height: 0.94;
      font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
      font-weight: 700;
      letter-spacing: 0.012em;
      font-kerning: normal;
      text-rendering: geometricPrecision;
    }

    .phone .flag {
      font-size: 0.58em;
      margin-right: 8px;
      vertical-align: middle;
      display: inline-block;

    }

    .hero {
      min-height: calc(100vh - 102px);
      display: grid;
      grid-template-columns: minmax(320px, 53vw) minmax(380px, var(--hero-card-max));
      align-items: center;
      gap: clamp(24px, 4vw, 72px);
      padding: clamp(22px, 4vw, 66px);
      padding-top: clamp(10px, 1.8vw, 34px);
      flex: 1 0 auto;
    }

    .hero-spacer { min-height: 50vh; }

    .hero-card-wrap {
      position: relative;
      padding-top: 0;
    }

    .hero-card {
      position: relative;
      border: 1px solid var(--panel-border);
      border-radius: 26px;
      padding: clamp(23px, 2.7vw, 38px);
      background: linear-gradient(145deg, rgba(16,20,24,0.76), rgba(5,7,9,0.58));
      box-shadow:
        0 26px 86px rgba(0,0,0,0.50),
        inset 0 1px 0 rgba(255,255,255,0.14);
      backdrop-filter: blur(14px);
      transform: perspective(1000px) rotateY(-3deg) rotateX(1deg);
    }

    .hero-card::before {
      content: "";
      position: absolute;
      inset: 10px;
      border-radius: 20px;
      border: 1px solid rgba(255,255,255,0.08);
      pointer-events: none;
    }

    .eyebrow {
      color: var(--rs-yellow);
      text-transform: uppercase;
      letter-spacing: .18em;
      font-size: 12px;
      font-weight: 900;
      margin-bottom: 14px;
      text-align: left;
    }

    h1 {
      margin: 0 0 16px;
      font-size: clamp(42px, 5vw, 74px);
      line-height: .94;
      letter-spacing: -0.055em;
      color: white;
    }

    .sub {
      margin: 0;
      color: var(--muted);
      font-size: clamp(16px, 1.25vw, 20px);
      line-height: 1.55;
      max-width: 560px;
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      margin-top: 28px;
      align-items: center;
      justify-content: center;
    }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 999px;
      padding: 13px 18px;
      min-height: 46px;
      color: white;
      text-decoration: none;
      font-weight: 900;
      letter-spacing: .01em;
      background: #000000;
      border: 1px solid rgba(255,255,255,.24);
      box-shadow:
        0 10px 24px rgba(0,0,0,.32),
        inset 0 1px 0 rgba(255,255,255,.05);
      transition:
        border-color 90ms linear,
        box-shadow 90ms linear,
        background-color 90ms linear;
    }

    .btn:hover,
    .btn:focus-visible {
      background: #000000;
      border-color: #ffd400;
      box-shadow:
        0 0 0 1px rgba(255,212,0,.18),
        0 0 14px rgba(255,212,0,.24),
        0 10px 24px rgba(0,0,0,.34),
        inset 0 1px 0 rgba(255,255,255,.05);
      outline: none;
    }

    .btn-express {
      padding: 8px 14px;
      min-height: 46px;
    }

    .btn-express img {
      display: block;
      width: 136px;
      height: auto;
    }

    .products-row {
      display: flex;
      justify-content: center;
      margin-top: 18px;
    }

    .btn-products {
      min-width: 220px;
      background: #000000;
      border-color: rgba(255,255,255,.24);
    }

    .footer-nav {
      margin-top: 28px;
      background:
        linear-gradient(180deg, rgba(0,0,0,0.88), rgba(0,0,0,0.94)),
        var(--footer-black);
      border-top: 1px solid rgba(255,255,255,0.10);
      box-shadow: 0 -10px 24px rgba(0,0,0,0.26);
      flex: 0 0 auto;
    }

    .footer-nav-inner {
      max-width: 1300px;
      margin: 0 auto;
      padding: 30px 26px 22px;
    }

    .footer-quick-links {
      display: grid;
      grid-template-columns: repeat(6, minmax(120px, 1fr));
      gap: 22px;
      align-items: start;
      justify-items: center;
      margin-bottom: 34px;
    }

    .quick-link {
      display: inline-flex;
      flex-direction: column;
      align-items: center;
      justify-content: flex-start;
      text-align: center;
      gap: 4px;
      min-width: 0;
      text-decoration: none;
      color: inherit;
      width: 126px;
      padding: 8px 6px 10px;
      border-radius: 6px;
      background: transparent;
      transition: none;
    }

    .quick-button {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 112px;
      height: 98px;
      overflow: visible;
      text-decoration: none;
      background: transparent;
      transition: none;
    }

    .quick-button img {
      width: 104px;
      height: auto;
      display: block;
      object-fit: contain;
      filter: none;
      transition: none;
      transform: translateZ(0);
      backface-visibility: hidden;
      will-change: auto;
      pointer-events: none;
    }

    .quick-label {
      color: var(--rs-yellow);
      font-family: Arial, Helvetica, sans-serif;
      font-size: 18px;
      font-style: italic;
      font-weight: 700;
      line-height: 1.15;
      text-shadow: 0 1px 4px rgba(0,0,0,0.50);
      white-space: nowrap;
      transition: none;
    }

    .quick-link:hover,
    .quick-link:focus-visible {
      background-color: #666666;
    }

    .quick-link:hover .quick-button img,
    .quick-link:focus-visible .quick-button img {
      filter: none;
      transform: translateZ(0);
    }

    .quick-link:hover .quick-label,
    .quick-link:focus-visible .quick-label {
      color: #fff36a;
      text-shadow: 0 1px 3px rgba(0,0,0,0.75);
    }

    .quick-link:focus-visible {
      outline: 2px solid var(--rs-yellow);
      outline-offset: 3px;
    }

    .footer-link-grid {
      max-width: 720px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: repeat(3, minmax(160px, 1fr));
      gap: 8px 44px;
      text-align: center;
      padding-bottom: 4px;
    }

    .footer-link-grid a {
      color: rgba(255,255,255,0.94);
      text-decoration: none;
      font-size: 17px;
      line-height: 1.35;
      letter-spacing: 0.01em;
      text-shadow: 0 1px 3px rgba(0,0,0,0.55);
    }

    .footer-link-grid a:hover {
      color: var(--rs-yellow);
    }

    .footer-slogan-strip {
      background: linear-gradient(180deg, #ffc400, #f4b700);
      border-top: 1px solid rgba(0,0,0,0.22);
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.22);
    }

    .footer-slogan-inner {
      max-width: 1200px;
      margin: 0 auto;
      min-height: 74px;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 18px;
      padding: 14px 20px;
      flex-wrap: wrap;
    }

    .footer-slogan-inner img {
      display: block;
      height: 22px;
      width: auto;
      image-rendering: auto;
    }

    .mock-note {
      position: fixed;
      left: 16px;
      bottom: 14px;
      z-index: 20;
      color: rgba(255,255,255,.72);
      font: 12px/1.35 Arial, Helvetica, sans-serif;
      background: rgba(0,0,0,.46);
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 999px;
      padding: 8px 12px;
    }

    @media (max-width: 1300px) {
      .header-logo img { width: 198px; }
    }

    @media (max-width: 1200px) {
      .site-header { min-height: 90px; }
      .page-shell { padding-top: 96px; }

      .header-contact-group {
        right: 34px;
        gap: 12px;
        width: min(510px, calc(100vw - 72px));
        max-width: calc(100vw - 72px);
      }

      .header-logo {
        margin-top: 12px;
      }

      .header-logo img {
        width: 160px;
      }

      .phone {
        width: 284px;
        max-width: 284px;
      }

      .phone .talk { font-size: 22px; }
      .phone .number {
        font-size: 29px;
        letter-spacing: 0.01em;
      }

      .hero { min-height: calc(100vh - 96px); }

      .footer-quick-links {
        grid-template-columns: repeat(3, minmax(140px, 1fr));
        row-gap: 26px;
      }
    }

    @media (max-width: 1000px) {
      .site-header { min-height: 84px; }
      .page-shell { padding-top: 90px; }

      .header-contact-group {
        right: 28px;
        gap: 10px;
        width: min(430px, calc(100vw - 60px));
        max-width: calc(100vw - 60px);
      }

      .header-logo {
        margin-top: 14px;
      }

      .header-logo img {
        width: 136px;
      }

      .phone {
        width: 248px;
        max-width: 248px;
      }

      .phone .talk { font-size: 20px; }
      .phone .number {
        font-size: 26px;
        letter-spacing: 0.006em;
      }

      .hero {
        grid-template-columns: 1fr;
        align-items: end;
      }

      .hero-spacer { min-height: 32vh; }
      .hero-card { transform: none; }

      .footer-quick-links {
        grid-template-columns: repeat(2, minmax(130px, 1fr));
      }

      .footer-link-grid {
        grid-template-columns: 1fr;
        gap: 4px;
      }
    }

    @media (max-width: 740px) {
      .site-header {
        min-height: 126px;
      }
      .page-shell { padding-top: 132px; }

      .header-contact-group {
        left: 16px;
        right: 16px;
        width: auto;
        max-width: none;
        justify-content: space-between;
        gap: 8px;
      }

      .header-logo img {
        width: 120px;
      }

      .phone {
        width: min(242px, 60vw);
        max-width: min(242px, 60vw);
      }
    }

    @media (max-width: 640px) {
      .phone .talk { font-size: 18px; }
      .phone .number {
        font-size: 22px;
        letter-spacing: 0.002em;
      }

      .footer-nav-inner {
        padding-left: 18px;
        padding-right: 18px;
      }

      .footer-quick-links {
        grid-template-columns: 1fr 1fr;
        gap: 20px 14px;
      }

      .quick-link {
        width: 118px;
        padding: 6px 4px 8px;
      }

      .quick-button {
        width: 98px;
        height: 88px;
      }

      .quick-button img {
        width: 92px;
        max-width: none;
        max-height: none;
        filter: none;
      }

      .quick-label {
        font-size: 16px;
        white-space: normal;
      }

      .footer-slogan-inner img {
        height: 18px;
      }
    }


    @media (max-width: 520px) {
      .site-header { min-height: 122px; }
      .page-shell { padding-top: 128px; }

      .header-contact-group {
        top: 9px;
        left: 12px;
        right: 12px;
      }

      .header-logo img {
        width: 104px;
      }

      .phone {
        width: calc(100vw - 148px);
        max-width: calc(100vw - 148px);
      }

      .phone .talk {
        font-size: 16px;
      }

      .phone .number {
        font-size: clamp(17px, 5vw, 21px);
        letter-spacing: 0;
      }

      .phone .flag {
        margin-right: 4px;
      }
    }


    .eyebrow,
    .promo-kicker {
      background: linear-gradient(
        112deg,
        #fff000 0%,
        #ffd400 24%,
        #ffcb00 42%,
        #f4b700 58%,
        #d8a300 76%,
        #ffcb00 90%,
        #fff000 100%
      );
      background-size: 220% 220%;
      background-position: 0% 50%;
      -webkit-background-clip: text;
      background-clip: text;
      -webkit-text-fill-color: transparent;
      color: transparent;
      animation: stripe-gold-shift 8.5s ease-in-out infinite alternate;
    }

    .promo-panel::before {
      background: linear-gradient(
        112deg,
        #fff000 0%,
        #ffd400 24%,
        #ffcb00 42%,
        #f4b700 58%,
        #d8a300 76%,
        #ffcb00 90%,
        #fff000 100%
      );
      background-size: 220% 220%;
      background-position: 0% 50%;
      animation: stripe-gold-shift 8.5s ease-in-out infinite alternate;
    }
@media (prefers-reduced-motion: reduce) {
      .rsdc-v27-bg img {
        animation: none;
        transform: scale(1.02);
      }

      .top-strip {
        animation: none;
        background-position: 35% 50%;
      }

      .eyebrow,
      .promo-kicker,
      .promo-panel::before {
        animation: none;
      }

    }
  
    .promo-section {
      max-width: 1220px;
      margin: 0 auto 26px;
      padding: 0 26px;
    }

    .promo-panel {
      position: relative;
      border: 1px solid rgba(255,255,255,.14);
      border-radius: 22px;
      overflow: hidden;
      background:
        linear-gradient(145deg, rgba(12,14,18,0.84), rgba(5,7,9,0.72));
      box-shadow:
        0 22px 54px rgba(0,0,0,.28),
        inset 0 1px 0 rgba(255,255,255,.08);
      backdrop-filter: blur(10px);
    }

    .promo-panel::before {
      content: "";
      position: absolute;
      inset: 0 0 auto 0;
      height: 4px;
      background: linear-gradient(90deg, #ffcf00, #ffd800, #ffc400);
      opacity: .95;
      z-index: 2;
    }

    .promo-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
      padding: 16px 20px 12px;
      position: relative;
      z-index: 2;
    }

    .promo-kicker {
      color: var(--rs-yellow);
      text-transform: uppercase;
      letter-spacing: .16em;
      font-size: 12px;
      font-weight: 900;
      margin: 0 0 4px;
    }

    .promo-title {
      color: #ffffff;
      font-size: 24px;
      line-height: 1.02;
      font-weight: 900;
      margin: 0;
      letter-spacing: -.02em;
    }

    .promo-sub {
      color: rgba(255,255,255,.74);
      font-size: 14px;
      margin: 0;
      line-height: 1.35;
    }

    .promo-actions {
      display: flex;
      align-items: center;
      gap: 10px;
      flex-wrap: wrap;
      justify-content: flex-end;
    }

    .promo-chip,
    .promo-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 38px;
      padding: 10px 16px;
      border-radius: 999px;
      text-decoration: none;
      font-weight: 800;
      letter-spacing: .01em;
      white-space: nowrap;
    }

    .promo-chip {
      background: rgba(255,212,0,.12);
      border: 1px solid rgba(255,212,0,.38);
      color: #fff2a8;
    }

    .promo-link {
      background: #000;
      border: 1px solid rgba(255,255,255,.24);
      color: #fff;
      transition: border-color 90ms linear, box-shadow 90ms linear;
    }

    .promo-link:hover,
    .promo-link:focus-visible {
      border-color: #ffd400;
      box-shadow: 0 0 12px rgba(255,212,0,.24);
      outline: none;
    }

    .promo-image-wrap {
      padding: 0 18px 18px;
      position: relative;
      z-index: 1;
    }

    .promo-image {
      display: block;
      width: 100%;
      height: auto;
      border-radius: 16px;
      border: 1px solid rgba(255,255,255,.10);
      box-shadow: 0 14px 28px rgba(0,0,0,.22);
      background: #111;
    }

    .promo-anchor-spacer {
      height: 10px;
    }

    .promo-fixed-toggle {
      position: fixed;
      right: 20px;
      bottom: 20px;
      z-index: 1200;
      display: inline-flex;
      align-items: center;
      gap: 10px;
      min-height: 46px;
      padding: 12px 18px;
      border-radius: 999px;
      background: rgba(10,12,16,.92);
      border: 1px solid rgba(255,212,0,.36);
      color: #fff;
      text-decoration: none;
      font-weight: 900;
      letter-spacing: .01em;
      box-shadow:
        0 12px 30px rgba(0,0,0,.34),
        0 0 14px rgba(255,212,0,.16);
      cursor: pointer;
      user-select: none;
    }

    .promo-fixed-toggle:hover,
    .promo-fixed-toggle:focus-visible {
      border-color: #ffd400;
      box-shadow:
        0 12px 30px rgba(0,0,0,.34),
        0 0 18px rgba(255,212,0,.24);
      outline: none;
    }

    .promo-fixed-drawer {
      position: fixed;
      right: 20px;
      bottom: 76px;
      z-index: 1199;
      width: min(540px, calc(100vw - 36px));
      transform: translateY(0);
      opacity: 1;
      visibility: visible;
      transition: opacity 120ms linear, transform 120ms linear, visibility 120ms linear;
    }

    .promo-fixed-drawer.is-collapsed {
      transform: translateY(12px);
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
    }

    .promo-fixed-close {
      background: transparent;
      border: 0;
      color: rgba(255,255,255,.74);
      font-size: 24px;
      line-height: 1;
      cursor: pointer;
      padding: 0 2px;
    }

    .promo-fixed-close:hover,
    .promo-fixed-close:focus-visible {
      color: #fff;
      outline: none;
    }

    @media (max-width: 900px) {
      .promo-head {
        flex-direction: column;
        align-items: flex-start;
      }
      .promo-actions {
        justify-content: flex-start;
      }
    }

    @media (max-width: 640px) {
      .promo-section {
        padding: 0 18px;
      }
      .promo-title {
        font-size: 21px;
      }
      .promo-fixed-toggle {
        right: 14px;
        bottom: 14px;
        min-height: 42px;
        padding: 10px 14px;
      }
      .promo-fixed-drawer {
        right: 14px;
        bottom: 66px;
        width: calc(100vw - 28px);
      }
    }