    :root {
      --detective-black: #07090c;
      --detective-ink: #12161d;
      --detective-muted: #5c6674;
      --detective-line: #d9e2ea;
      --detective-soft: #f4f7f9;
      --detective-cyan: #2968d9;
      --detective-green: #21a67a;
      --detective-amber: #f4c64e;
      --detective-red: #ec5b55;
      --detective-shadow: 0 24px 70px rgba(7, 9, 12, 0.16);
    }



    body {
      background: #ffffff;
      color: var(--detective-ink);
    }

    .site-header.is-scrolled,
    .site-header.is-mega-open,
    .site-header.is-mobile-open,
    .site-header:hover,
    .site-header:focus-within {
      box-shadow: 0 12px 38px rgba(7, 9, 12, 0.08);
      background: rgba(255, 255, 255, 0.96);
      color: var(--detective-ink);
      border-bottom-color: rgba(18, 22, 29, 0.1);
    }

    .btn {
      min-height: 48px;
      padding: 0 22px;
      border-radius: 999px;
      letter-spacing: 0;
    }

    .btn--glass {
      border: 1px solid rgba(255, 255, 255, 0.28);
      background: rgba(255, 255, 255, 0.1);
      color: #ffffff;
      backdrop-filter: blur(12px);
    }

    .btn--header {
      border: 1px solid rgba(18, 22, 29, 0.12);
      box-shadow: 0 8px 24px rgba(7, 9, 12, 0.08);
      background: #ffffff;
      color: var(--detective-ink);
    }

    /* Corporate redesign for index main content. Header rules above are intentionally left untouched. */
    .clean-corporate {
      --cc-navy: #12356f;
      --cc-navy-soft: #1d4f9f;
      --cc-ink: #101820;
      --cc-muted: #687887;
      --cc-line: #dbe5ec;
      --cc-soft: #f5f8fa;
      --cc-accent: #2968d9;
      --cc-green: #16a085;
      background: #ffffff;
      color: var(--cc-ink);
    }

    .cc-hero {
      position: relative;
      overflow: hidden;
      background: var(--cc-navy);
      color: #ffffff;
    }

    .cc-hero__slider,
    .cc-hero__slide {
      min-height: 92svh;
    }

    .cc-hero__slider {
      position: relative;
    }

    .cc-hero__slide {
      display: flex;
      align-items: center;
      position: absolute;
      visibility: hidden;
      transition: opacity 900ms ease-in-out, visibility 900ms ease-in-out, transform 900ms ease-in-out;
      inset: 0;
      opacity: 0;
      transform: translateY(14px);
      will-change: opacity, transform;
    }

    .cc-hero__slide.is-active {
      position: relative;
      visibility: visible;
      opacity: 1;
      transform: translateY(0);
    }

    .cc-hero__slide::before {
      position: absolute;
      background: var(--cc-hero-image) center right / cover no-repeat;
      content: "";
      inset: 0;
    }

    .cc-hero__slide::after {
      position: absolute;
      background:
        linear-gradient(90deg, rgba(4, 20, 34, 0.9) 0%, rgba(4, 20, 34, 0.76) 34%, rgba(4, 20, 34, 0.28) 72%, rgba(4, 20, 34, 0.12) 100%),
        linear-gradient(180deg, rgba(4, 20, 34, 0.24) 0%, rgba(4, 20, 34, 0.04) 44%, rgba(4, 20, 34, 0.7) 100%);
      content: "";
      inset: 0;
    }

    .cc-hero__slide--trust {
      --cc-hero-image: url("../images/main_slide/main-slide-cleanup-ready.webp");
    }

    .cc-hero__slide--standard {
      --cc-hero-image: url("../images/main_slide/main-slide-sorting.webp");
    }

    .cc-hero__slide--result {
      --cc-hero-image: url("../images/main_slide/main-slide-consulting.webp");
    }

    .cc-hero__inner {
      position: relative;
      z-index: 1;
      width: 100%;
      padding-top: 132px;
      padding-bottom: 92px;
    }

    .cc-hero__content {
      max-width: 720px;
    }

    .cc-hero h1,
    .cc-hero h2 {
      margin: 0;
      font-size: 56px;
      font-weight: 700;
      line-height: 1.24;
      color: #ffffff;
      letter-spacing: 0;

    }

    .cc-hero p {
      max-width: 620px;
      margin: 28px 0 0;
      font-size: 18px;
      line-height: 1.8;
  color: #FFFFFF;

}

    .cc-actions {
      display: flex;
      justify-content: flex-start;
      gap: 12px;
      flex-wrap: wrap;
      margin-top: 36px;
    }

    .cc-button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 44px;
      padding: 0 24px;
      border: 1px solid rgba(255, 255, 255, 0.44);
      border-radius: 999px;
      font-size: 15px;
      font-weight: 700;
      color: #ffffff;
      transition: transform 180ms ease, background 180ms ease, border-color 180ms ease;
    }

    .cc-button--primary:hover,
    .cc-button--primary:focus-visible {
      transform: translateY(-1px);
    }

    .cc-button:hover,
    .cc-button:focus-visible {
      transform: translateY(-1px);
    }

    .cc-button--primary {
      background: #ffffff;
      color: #05141f;
      border-color: #ffffff;
    }

    .cc-button--accent {
      background: var(--cc-accent);
      color: #ffffff;
      border-color: var(--cc-accent);
    }

    .cc-hero__facts {
      display: grid;
      gap: 0;
      max-width: 760px;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      margin-top: 66px;
      border-top: 1px solid rgba(255, 255, 255, 0.36);
    }

    .cc-hero__facts div {
      padding: 20px 28px 0 0;
    }

    .cc-hero__facts strong {
      display: block;
      font-size: 12px;
      font-weight: 700;
      color: rgba(255, 255, 255, 0.58);
      letter-spacing: 0.08em;
    }

    .cc-hero__facts span {
      display: block;
      font-size: 17px;
      font-weight: 700;
      line-height: 1.45;
      color: #ffffff;
      margin-top: 8px;
    }

    .cc-hero__controls {
      display: flex;
      gap: 10px;
      align-items: center;
      position: absolute;
      left: max(24px, calc((100vw - var(--container-width)) / 2));
      bottom: 58px;
      z-index: 4;
    }

    .cc-hero__controls .hero-slider__arrow {
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }

    .cc-hero__controls .hero-slider__arrow svg {
      width: 22px;
      height: 22px;
      fill: none;
      stroke: currentColor;
      stroke-width: 2.4;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .cc-hero__controls .hero-slider__dots {
      display: inline-flex;
      gap: 12px;
      align-items: center;
    }

    .cc-hero__controls .hero-slider__dots button {
      position: relative;
      width: 10px;
      height: 24px;
      padding: 0;
      border: 0;
      background: transparent;
      transition: width 300ms cubic-bezier(0.25, 1, 0.5, 1);
    }

    .cc-hero__controls .hero-slider__dots button::after {
      position: absolute;
      top: 7px;
      right: 0;
      bottom: 7px;
      left: 0;
      content: "";
      background: rgba(255, 255, 255, 0.3);
      border-radius: 999px;
      transition: inset 300ms ease, background 300ms ease;
    }

    .cc-hero__controls .hero-slider__dots button.is-active {
      width: 40px;
      background: transparent;
    }

    .cc-hero__controls .hero-slider__dots button.is-active::after {
      right: 0;
      left: 0;
      background: var(--cc-accent);
    }

    .cc-section {
      position: relative;
      padding: 108px 0;
    }

    .cc-section--soft {
      background: var(--cc-soft);
    }

    .cc-section--dark {
      position: relative;
      background: var(--cc-navy);
      background-image: url("../images/page/special-cleaning-overview-20260521.webp");
      background-size: cover;
      background-position: center center;
      background-attachment: fixed;
      color: #ffffff;
    }

    .cc-section--dark .overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, rgba(0, 0, 0, 0.75), rgba(0, 0, 0, 0.90));
      z-index: 1;
    }

    .cc-section--dark .container {
      position: relative;
      z-index: 2;
    }

    .cc-needs {
      background: #ffffff;
    }

    .cc-needs__layout {
      display: block;
    }

    .cc-needs__intro {
      max-width: 860px;
      margin: 0 auto;
      margin-bottom: 88px;
text-align: center;
    }

    .cc-needs__intro h2 {
      margin: 0;
      font-size: 38px;
      line-height: 1.44;
      color: var(--cc-ink);
      letter-spacing: 0;

    }

    .cc-needs__intro p {
      margin: 14px 0 0;
      font-size: 17px;
      line-height: 1.44;
      color: var(--cc-muted);
    }

    .cc-needs .cc-needs__list {
      display: grid;
      gap: 94px;
    }

    .cc-needs .cc-need-row {
      display: grid;
      gap: clamp(28px, 4vw, 48px);
      align-items: center;
      grid-template-columns: minmax(0, 1fr) minmax(260px, 0.66fr);
    }

    .cc-needs .cc-need-row:nth-child(even) {
      grid-template-columns: minmax(260px, 0.66fr) minmax(0, 1fr);
    }

    .cc-needs .cc-need-row:nth-child(even) .cc-need-row__media {
      order: 2;
    }

    .cc-needs .cc-need-row:nth-child(even) .cc-need-row__content {
      order: 1;
    }

    .cc-needs .cc-need-row__media {
      margin: 0;
      border-radius: 36px 36px 36px 36px;
      overflow: hidden;
      background: #dce7ed;
    }


    .cc-needs .cc-need-row__media img {
      display: block;
      width: 100%;
      aspect-ratio: 1.42 / 1;
      object-fit: cover;
      filter: saturate(0.94) contrast(1.02);
    }

    .cc-needs .cc-need-row__content {
      min-width: 0;
      text-align: left;
    }

    .cc-needs .cc-need-row strong {
      display: block;
        font-size: 15px;
      font-weight: 700;
      color: var(--cc-accent);
      letter-spacing: 0.05em;
      margin-bottom: 8px;
    }

    .cc-needs .cc-need-row h3 {
      margin: 0;
      font-size: clamp(30px, 3vw, 40px);
      font-weight: 700;
      line-height: 1.34;
      color: var(--cc-ink);
    }

    .cc-needs .cc-need-row p {
      max-width: 660px;
      margin: 14px 0 0;
      font-size: 17px;
      font-weight: 500;
      line-height: 1.44;
      color: #1A1A1A;
    }

    .cc-section__head {
      display: flex;
      gap: 16px;
      align-items: center;
      justify-content: center;
      flex-direction: column;
      text-align: center;
      grid-template-columns: minmax(0, 0.82fr) minmax(320px, 0.48fr);
      margin-bottom: 48px;
    }

    .cc-label {
      display: block;
      font-size: 15px;
      font-weight: 700;
      color: var(--cc-accent);
  letter-spacing: 1px;
      margin-bottom: 14px;


}

    .cc-section h2 {
      margin: 0;
      font-size: clamp(24px, 4.2vw, 36px);
      font-weight: 700;
      line-height: 1.4;
      color: inherit;
      letter-spacing: 0;
    }

    .cc-section__head p,
    .cc-lead {
      margin: 0;
      font-size: 17px;
      line-height: 1.44;
      color: var(--cc-muted);
    }

    .cc-section--dark .cc-section__head p,
    .cc-section--dark .cc-lead {
      color: rgba(255, 255, 255, 0.72);
    }

    .cc-service-grid {
      display: grid;
      gap: 24px;
      grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .cc-service-grid .cc-service-card {
      grid-column: span 2;
    }

    .cc-service-grid .cc-service-card:nth-child(-n + 2) {
      grid-column: span 3;
    }

    .cc-service-card {
      display: grid;
      gap: 0px;
      min-width: 0;
      color: inherit;
      padding: 0;
      border: 1px solid var(--color-border);
      border-radius: 8px;
      box-shadow: none;
      overflow: hidden;
      background: rgba(255, 255, 255, 0.78);
      transition: transform 220ms ease, border-color 220ms ease;
    }

    .cc-service-card:hover,
    .cc-service-card:focus-visible {
      box-shadow: none;
      transform: translateY(-4px);
      border-color: var(--color-primary);
    }

    .cc-service-card figure {
      position: relative;
      height: 250px;
      margin: 0;
      border-radius: 0;
      overflow: hidden;
      background:
        linear-gradient(135deg, rgba(47, 110, 216, 0.14), rgba(255, 255, 255, 0.72)),
        #eaf1f8;
    }

    .cc-service-card:hover figure::after {
      opacity: 1;
      transform: translateY(0);
    }

    .cc-service-card img {
      display: block;
      width: 100%;
      height: 100%;
      transition: transform 360ms ease;

      object-fit: cover;

    }

    .cc-service-card:hover img {
      transform: scale(1.035);
    }

    .cc-service-card__body {
      padding: 20px 40px;
      text-align:center;
    }

    .cc-service-card__body strong {
      display: block;
      font-size: 13px;
      font-weight: 700;
      color: var(--cc-accent);
      letter-spacing: 0;
    }

    .cc-service-card h3 {
      margin: 8px 0 10px;
      font-size: clamp(22px, 2vw, 30px);
      font-weight: 700;
      line-height: 1.34;
    }

    .cc-service-card p {
      margin: 0;
      line-height: 1.44;
      color: var(--cc-muted);
    }

    .cc-process {
      display: grid;
      margin: 0;
      padding: 0;
      list-style: none;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      border-top: 1px solid rgba(255, 255, 255, 0.24);
      border-bottom: 1px solid rgba(255, 255, 255, 0.24);
    }

    .cc-process li {
      min-width: 0;
      padding: 34px 26px 38px 0;
      border-right: 1px solid rgba(255, 255, 255, 0.18);
    }

    .cc-process li+li {
      padding-left: 26px;
    }

    .cc-process li:first-child {
      padding-left: 10px;
    }

    .cc-process li:last-child {
      border-right: 0;
      padding-right: 10px;
    }

    .cc-process span {
      display: block;
      font-size: 13px;
      font-weight: 700;
      color: var(--cc-accent);
    }

    .cc-process strong {
      display: block;
      font-size: 24px;
      font-weight: 700;
      line-height: 1.28;
      color: #ffffff;
      margin-top: 18px;
    }

    .cc-process p {
      margin: 14px 0 0;
      line-height: 1.44;
      color: rgba(255, 255, 255, 0.72);
    }

    .cc-standard-section {
      position: relative;
      background: #061724;
      color: #ffffff;
    }



    .cc-standard {
      position: relative;
      z-index: 2;
    }

    .cc-standard__head {
      justify-items: center;
      max-width: 860px;
      margin: 0 auto;
      text-align: center;
      margin-bottom: clamp(66px, 8vw, 112px);
    }

    .cc-standard__head h2 {
      font-size: clamp(36px, 5.4vw, 36px);
      line-height: 1.44;
      color: #ffffff;
    }

    .cc-standard__head .cc-lead {
      max-width: 820px;
      font-size: 18px;
  line-height: 1.6;
      color: rgba(255, 255, 255, 0.68);
      margin-top: 28px;

}

    .cc-standard__list {
      display: flex;
      flex-direction: column;
      gap: 0;
      margin: 0;
      padding: 0;
      list-style: none;
      border-top: 1px solid rgba(255, 255, 255, 0.2);
    }

    .cc-standard__list li {
      display: flex;
      align-items: center;

      gap: clamp(28px, 5vw, 72px);
      min-height: 146px;
      padding: 34px 125px;
      border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    }

    .cc-standard__icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 110px;
      height: 110px;
      color: #ffffff;
      background: linear-gradient(145deg, rgba(41, 104, 217, 0.95), rgba(41, 104, 217, 0.58));
      border: 1px solid rgba(255, 255, 255, 0.16);
      border-radius: 28px;
      box-shadow: 0 24px 60px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.18);
    }

    .cc-standard__icon svg {
      width: 42px;
      height: 42px;
      fill: none;
      stroke: currentColor;
      stroke-width: 1.8;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .cc-standard__content {
      min-width: 0;
      padding-top: 4px;
    }

    .cc-standard__list strong {
      display: block;
      font-size: 14px;
      font-weight: 700;
      color: var(--cc-accent);
      letter-spacing: 0.08em;
      margin-bottom: 8px;
    }

    .cc-standard__list h3 {
      margin: 0;
      font-size: clamp(30px, 3vw, 36px);
      line-height: 1.16;
      color: #ffffff;
    }

    .cc-standard__list p {
      max-width: 580px;
      margin: 16px 0 0;
      font-size: 16px;
      line-height: 1.84;
      color: rgba(255, 255, 255, 0.68);
    }

    .cc-gallery-section {
      background: #ffffff;
      color: var(--cc-ink);
    }

    /* --- Horizontal Ticker Style --- */
    .cc-gallery-ticker-container {
      position: relative;
      width: 100%;
      overflow: hidden;
      padding: 10px 0;
    }

    .cc-gallery-track {
      display: flex;
      gap: 30px;
      width: max-content;
      animation: galleryMarquee 25s linear infinite;
      will-change: transform;
    }

    .cc-gallery-track:hover {
      animation-play-state: paused;
    }

    .cc-gallery-card {
      flex: 0 0 380px;
      display: grid;
      align-content: start;
      min-width: 0;
      color: inherit;
      padding: 0;
      border: 1px solid var(--color-border);
      border-radius: 8px;
      box-shadow: none;
      overflow: hidden;
      background: rgba(255, 255, 255, 0.78);
      transition: transform 220ms ease, border-color 220ms ease;
    }

    @keyframes galleryMarquee {
      0% {
        transform: translateX(0);
      }
      100% {
        /* (380px card + 30px gap) * 3 items = 1230px */
        transform: translateX(-1230px);
      }
    }

    .cc-gallery-card:hover,
    .cc-gallery-card:focus-visible {
      box-shadow: none;
      transform: translateY(-4px);
      border-color: var(--color-primary);
    }

    .cc-gallery-card figure {
      margin: 0 0 0;
      border-radius: 0;
      overflow: hidden;
      background:
        linear-gradient(135deg, rgba(47, 110, 216, 0.14), rgba(255, 255, 255, 0.72)),
        #eaf1f8;
    }

    .cc-gallery-card img {
      display: block;
      width: 100%;
      transition: transform 320ms ease;
      aspect-ratio: 1.46 / 1;
      object-fit: cover;
    }

    .cc-gallery-card__placeholder {
      display: grid;
      width: 100%;
      aspect-ratio: 1.46 / 1;
      place-items: center;
      color: rgba(18, 22, 29, 0.48);
      font-size: 16px;
      font-weight: 700;
      background: #eef3f8;
    }

    .cc-gallery-card:hover img {
      transform: scale(1.035);
    }

    .cc-gallery-card h3 {
      display: -webkit-box;
      margin: 0;
      overflow: hidden;
      font-size: 24px;
      font-weight: 700;
      line-height: 1.38;
      color: var(--cc-ink);
      text-overflow: ellipsis;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 2;
      letter-spacing: 0;
    }

    .cc-gallery-card p {
      display: -webkit-box;
      margin: 0;
      overflow: hidden;
      font-size: 15px;
      line-height: 1.75;
      color: var(--cc-muted);
      text-overflow: ellipsis;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 2;
    }

    .cc-gallery-card time {
      display: block;
      font-size: 16px;
      font-weight: 700;
      color: rgba(18, 22, 29, 0.42);
      margin-top: 26px;
    }

    .cc-support {
      background: #ffffff;
    }

    .cc-support__grid {
      display: grid;
      grid-auto-rows: 1fr;
      gap: 48px;
      align-items: stretch;
      grid-template-columns: minmax(0, 1fr) minmax(360px, 0.86fr);
    }

    .cc-support-card,
    .live-reservation {
      min-height: 100%;
      border: 1px solid rgba(18, 22, 29, 0.12);
      border-radius: 8px;
      box-shadow: 0 18px 54px rgba(7, 9, 12, 0.08);
      background: #ffffff;
    }

    .cc-support-card {
      display: flex;
      flex-direction: column;
      padding: 32px;
    }

    .cc-support-card .cc-panel-title {
      display: block;
      max-width: none;
      margin: 0 0 28px;
    }

    .cc-support-card .cc-panel-title .cc-label,
    .live-reservation .cc-label {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      min-height: 30px;
      padding: 0 12px;
      border: 1px solid rgba(41, 104, 217, 0.32);
      border-radius: 999px;
      background: rgba(41, 104, 217, 0.08);
      color: var(--cc-accent);
    }

    .cc-panel-title h3 {
      font-size: clamp(32px, 3vw, 36px);
      font-weight: 700;
      line-height: 1.3;
      margin-top: 0;

    }

    .cc-panel-title p {
      font-size: 16px;
      line-height: 1.6;
      color: var(--cc-muted);
      margin-top: 14px;
    }

    .cc-faq-list {
      display: grid;
      gap: 12px;
      flex: 1;
    }

    .cc-faq-item {
      border: 1px solid var(--cc-line);
      border-radius: 8px;
      background: #ffffff;
    }

    .cc-faq-item summary {
      display: flex;
      align-items: center;
      position: relative;
      min-height: 66px;
      padding: 18px 54px 18px 20px;
  font-size: 19px;
      font-weight: 700;
      color: var(--cc-ink);
      transition: background 180ms ease;
      list-style: none;
      cursor: pointer;

}

    .cc-faq-item summary:hover {
      background: #f8fafc;
    }

    .cc-faq-item[open] p {
      animation: faqFadeInDown 0.35s ease-out forwards;
    }

    @keyframes faqFadeInDown {
      from {
        opacity: 0;
        transform: translateY(-8px);
      }

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

    .cc-faq-item summary::-webkit-details-marker {
      display: none;
    }

    .cc-faq-item summary::after {
      position: absolute;
      top: 50%;
      right: 20px;
      width: 8px;
      height: 8px;
      transition: transform 180ms ease;
      content: "";
      border-right: 2px solid var(--cc-accent);
      border-bottom: 2px solid var(--cc-accent);
      transform: translateY(-62%) rotate(45deg);
    }

    .cc-faq-item[open] summary::after {
      transform: translateY(-38%) rotate(225deg);
    }

    .cc-faq-item p {
      margin: 0;
      padding: 0 20px 20px;
      line-height: 1.76;
      color: var(--cc-muted);
    }

    .live-reservation {
      display: flex;
      flex-direction: column;
      overflow: hidden;
      color: var(--cc-ink);
    }

    .live-reservation__head {
      display: flex;
      gap: 18px;
      align-items: flex-start;
      justify-content: space-between;
      padding: 28px 28px 20px;
      border-bottom: 1px solid rgba(18, 22, 29, 0.1);
    }

    .live-reservation__head h3 {
      margin: 0;
      font-size: 36px;
      font-weight: 700;
      line-height: 1.3;
      color: var(--cc-ink);
    }

    .live-reservation__head p {
      margin: 8px 0 0;
      line-height: 1.65;
      color: var(--cc-muted);
    }

    .live-reservation__badge {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      min-height: 30px;
      padding: 0 12px;
      border-radius: 999px;
      background: var(--cc-accent);
      font-size: 12px;
      font-weight: 700;
      color: #ffffff;
      white-space: nowrap;
    }

    .live-reservation__viewport {
      flex: 0 0 auto;
      position: relative;
      height: auto;
      min-height: 0;
      padding: 20px 22px 26px;
      overflow: hidden;
      mask-image: none;
    }

    .live-reservation__track {
      display: grid;
      gap: 12px;
      animation: none;
      transition: transform 540ms cubic-bezier(0.22, 1, 0.36, 1);
      will-change: transform;
    }

    .live-reservation__track.is-resetting {
      transition: none;
      will-change: auto;
    }

    .live-reservation__track.is-rolling {
      will-change: transform;
    }

    .live-reservation:hover .live-reservation__track {
      animation-play-state: initial;
    }

    .live-reservation__item {
      display: grid;
      grid-template-columns: minmax(100px, 1.08fr) minmax(100px, 1fr) minmax(108px, 0.95fr) minmax(84px, auto);
      gap: 14px;
      align-items: center;
      padding: 16px 18px;
      border: 1px solid var(--color-border);
      border-radius: 14px;
      background: #ffffff;
      transition: transform 180ms ease, border-color 180ms ease;
    }

    .live-reservation__item:hover {
      background: #ffffff;
      transform: translateY(-2px);
      border-color: var(--color-primary);
    }

    .live-reservation__field {
      display: inline-flex;
      min-width: 0;
      gap: 9px;
      align-items: center;
      color: #1f2937;
      font-size: 15px;
      font-weight: 700;
      line-height: 1.35;
    }

    .live-reservation__field i {
      flex: 0 0 auto;
      color: #173aab;
      font-size: 20px;
      line-height: 1;
    }

    .live-reservation__field strong,
    .live-reservation__field span {
      min-width: 0;
      overflow: hidden;
      color: var(--cc-ink);
      white-space: nowrap;
      text-overflow: ellipsis;
      word-break: keep-all;
    }

    .live-reservation__field--customer {
      color: #475569;
      font-weight: 600;
    }

    .live-reservation__field--customer i {
      font-size: 21px;
    }

    .live-reservation__status {
      display: inline-flex;
      gap: 6px;
      align-items: center;
      justify-content: center;
      position: relative;
      justify-self: end;
      min-width: 92px;
      min-height: 34px;
      padding: 0 14px;
      border: 1px solid rgba(41, 104, 217, 0.2);
      border-radius: 999px;
      background: #f8fafc;
      box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
      font-size: 13px;
      font-weight: 700;
      color: #061b2b;
      white-space: nowrap;
    }

    .live-reservation__status::before {
      content: none;
    }

    .live-reservation__status[data-status="scheduled"],
    .live-reservation__status[data-status="estimate"] {
      color: var(--detective-green);
      border-color: rgba(33, 166, 122, 0.28);
      background: rgba(33, 166, 122, 0.1);
    }

    .live-reservation__status[data-status="consulting"] {
      color: var(--cc-accent);
      border-color: rgba(41, 104, 217, 0.26);
      background: rgba(41, 104, 217, 0.1);
    }

    .live-reservation__status[data-status="coordinating"] {
      color: #d97706;
      border-color: rgba(217, 119, 6, 0.28);
      background: rgba(245, 158, 11, 0.12);
    }

    .live-reservation__status[data-status="working"] {
      color: #0f766e;
      border-color: rgba(20, 184, 166, 0.3);
      background: rgba(20, 184, 166, 0.12);
    }

    @keyframes pulseGreen {
      0% {
        box-shadow: 0 0 0 0 rgba(33, 166, 122, 0.6);
      }

      70% {
        box-shadow: 0 0 0 4px rgba(33, 166, 122, 0);
      }

      100% {
        box-shadow: 0 0 0 0 rgba(33, 166, 122, 0);
      }
    }

    @keyframes pulseBlue {
      0% {
        box-shadow: 0 0 0 0 rgba(41, 104, 217, 0.6);
      }

      70% {
        box-shadow: 0 0 0 4px rgba(41, 104, 217, 0);
      }

      100% {
        box-shadow: 0 0 0 0 rgba(41, 104, 217, 0);
      }
    }

    @keyframes pulseYellow {
      0% {
        box-shadow: 0 0 0 0 rgba(217, 119, 6, 0.6);
      }

      70% {
        box-shadow: 0 0 0 4px rgba(217, 119, 6, 0);
      }

      100% {
        box-shadow: 0 0 0 0 rgba(217, 119, 6, 0);
      }
    }

    .live-reservation__text {
      flex: 1;
      min-width: 0;
      overflow: hidden;
      font-size: 15px;
      color: var(--cc-muted);
      white-space: nowrap;
      text-overflow: ellipsis;
    }

    .live-reservation__text strong {
      font-weight: 700;
      color: var(--cc-ink);
    }

    .live-reservation__text .divider {
      margin: 0 4px;
      color: #cbd5e1;
    }

    .live-reservation__details {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
      width: 100%;
      margin: 0;
    }

    .live-reservation__details div {
      min-width: 0;
      padding: 12px 14px;
      border: 1px solid rgba(226, 232, 240, 0.9);
      border-radius: 8px;
      background: #f8fafc;
    }

    .live-reservation__details dt {
      margin: 0 0 5px;
      font-size: 12px;
      font-weight: 700;
      line-height: 1.4;
      color: #64748b;
    }

    .live-reservation__details dd {
      margin: 0;
      font-size: 14px;
      font-weight: 700;
      line-height: 1.45;
      color: var(--cc-ink);
      word-break: keep-all;
    }





    @keyframes liveReservationRoll {
      from {
        transform: translateY(0);
      }

      to {
        transform: translateY(-50%);
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .live-reservation__track {
        transition-duration: 350ms;
      }
    }

    .cc-cta {
      overflow: hidden;
      background:
        linear-gradient(90deg, rgba(3, 24, 39, 0.92), rgba(8, 37, 63, 0.76)),
        url("../images/main_slide/main-slide-consulting.webp") center / cover no-repeat;
      color: #ffffff;
      text-align: center;
    }

    .cc-cta__inner {
      max-width: 820px;
    }

    .cc-cta h2 {
      max-width: 760px;
      margin: 16px auto 0;
      font-size: clamp(38px, 4.6vw, 36px);
      line-height: 1.44;
      color: #ffffff;
    }

    .cc-cta p {
      max-width: 620px;
      margin: 22px auto 0;
      font-size: 17px;
      line-height: 1.44;
      color: rgba(255, 255, 255, 0.72);
    }

    .cc-cta .cc-actions {
      justify-content: center;
    }

    .site-footer__body a,
    .site-footer__policy a {
      display: inline-flex;
      min-height: 32px;
      align-items: center;
    }

    @media (max-width: 1080px) {
      .cc-hero__slider,
      .cc-hero__slide {
        min-height: 820px;
      }

      .cc-hero__inner {
        padding-top: 120px;
        padding-bottom: 86px;
      }

      .cc-hero h1,
      .cc-hero h2 {
        font-size: 46px;
        line-height: 1.44;
      }

      .cc-hero p {
        max-width: 560px;
        font-size: 17px;
      }

      .cc-section {
        padding: 92px 0;
      }

      .cc-section__head,
      .cc-needs__layout,
      .cc-standard,
      .cc-cta__inner,
      .cc-gallery-board,
      .cc-support__grid {
        grid-template-columns: 1fr;
      }

      .cc-service-grid,
      .cc-gallery-board {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .cc-service-grid .cc-service-card,
      .cc-service-grid .cc-service-card:nth-child(-n + 2) {
        grid-column: span 1;
      }

      .cc-needs__intro {
        margin-bottom: 68px;
      }

      .cc-needs .cc-needs__list {
        gap: 72px;
      }

      .cc-needs .cc-need-row,
      .cc-needs .cc-need-row:nth-child(even) {
        grid-template-columns: minmax(0, 1fr) minmax(240px, 0.78fr);
      }

      .cc-service-card figure {
        height: 230px;
      }

      .cc-process {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .cc-process li:nth-child(2) {
        border-right: 0;
      }

      .cc-process li:nth-child(n + 3) {
        border-top: 1px solid rgba(255, 255, 255, 0.18);
      }

      .cc-standard__list li {
        padding-right: 48px;
        padding-left: 48px;
      }

      .cc-support__grid {
        gap: 32px;
      }

      .live-reservation__head h3 {
        font-size: 30px;
      }
    }

    @media (max-width: 720px) {
      .cc-hero__slider,
      .cc-hero__slide {
        min-height: 760px;
      }

      .cc-hero__slide::before {
        background-position: 70% center;
      }

      .cc-hero__slide::after {
        background: linear-gradient(90deg, rgba(4, 20, 34, 0.94), rgba(4, 20, 34, 0.72));
      }

      .cc-hero__inner {
        padding-top: 106px;
        padding-bottom: 78px;
      }

      .cc-hero h1,
      .cc-hero h2 {
        font-size: 34px;
        line-height: 1.26;
        font-weight: 700;
      }

      .cc-hero p {
        font-size: 16px;
        line-height: 1.44;
      }

      .cc-needs .cc-needs__list,
      .cc-service-grid,
      .cc-process,
      .cc-gallery-board {
        grid-template-columns: 1fr;
      }

      .cc-service-grid .cc-service-card,
      .cc-service-grid .cc-service-card:nth-child(-n + 2) {
        grid-column: auto;
      }

      .cc-hero__facts {
        margin-top: 36px;
      }

      .cc-hero__facts div {
        padding: 18px 0 0;
      }

      .cc-hero__facts {
        display: none;
      }

      .cc-hero__controls {
        gap: 10px;
        left: 18px;
        bottom: 28px;
      }

      .cc-hero__controls .hero-slider__arrow {
        width: 38px;
        height: 38px;
      }

      .cc-section {
        padding: 72px 0;
      }

      .cc-section__head {
        gap: 12px;
        margin-bottom: 42px;
      }

      .cc-process li,
      .cc-process li+li {
        padding: 26px 0;
        border-right: 0;
        text-align: center;
      }

      .cc-process li:first-child {
        padding-left: 0;
      }

      .cc-process li:last-child {
        padding-right: 0;
      }

      .cc-process li+li {
        border-top: 1px solid rgba(255, 255, 255, 0.18);
      }

      .cc-actions {

        width: 80%;
        margin-top:20px;
      }

      .cc-button {
        min-height: 50px;
        width: 100%;
      }

      .cc-needs .cc-need-row {
        gap: 26px;
        grid-template-columns: 1fr;
      }

      .cc-needs .cc-need-row:nth-child(even) {
        grid-template-columns: 1fr;
      }

      .cc-needs .cc-need-row:nth-child(even) .cc-need-row__media,
      .cc-needs .cc-need-row:nth-child(even) .cc-need-row__content {
        order: initial;
      }

      .cc-needs .cc-needs__list {
        gap: 54px;
      }

      .cc-needs__intro {
        margin-bottom: 48px;
      }

      .cc-needs .cc-need-row h3 {
        font-size: 28px;
      }

      .cc-needs .cc-need-row__media {
        border-radius: 18px;
      }

      .cc-needs .cc-need-row__media img {
        aspect-ratio: 16 / 11;
      }

      .cc-service-card figure {
        height: auto;
        aspect-ratio: 16 / 10;
      }

      .cc-service-card__body {
        padding: 22px 20px 24px;
      }

      .cc-standard__head {
        margin-bottom: 36px;
      }

      .cc-standard__head h2 {
        font-size: clamp(24px, 9vw, 28px);
      }

      .cc-standard__head .cc-lead {
        font-size: 16px;
      }

      .cc-standard__list li {
        flex-direction: column;
        align-items: center;
        gap: 18px;
        min-height: 0;
        padding: 28px 0 30px;
        text-align: center;
      }

      .cc-standard__icon {
        width: 76px;
        height: 76px;
        border-radius: 22px;
      }

      .cc-standard__icon svg {
        width: 34px;
        height: 34px;
      }

      .cc-standard__list h3 {
        font-size: 29px;
      }

      .cc-standard__list p {
        max-width: none;
        margin: 12px 0 0;
      }

      .cc-gallery-card {
        flex: 0 0 280px;
        margin-bottom: 0;
      }

      .cc-gallery-track {
        gap: 20px;
        animation: galleryMarqueeMobile 20s linear infinite;
      }

      .cc-gallery-card figure {
        border-radius: 14px;
        margin-bottom: 12px;
      }

      @keyframes galleryMarqueeMobile {
        0% {
          transform: translateX(0);
        }
        100% {
          /* (280px card + 20px gap) * 3 items = 900px */
          transform: translateX(-900px);
        }
      }

      .cc-gallery-card h3 {
        min-height: 0;
        font-size: 22px;
      }

      .cc-gallery-card p {
        min-height: 0;
        margin-top: 14px;
      }

      .cc-gallery-card time {
        font-size: 14px;
        margin-top: 18px;
      }

      .cc-support__grid {
        gap: 32px;
      }

      .cc-support-card {
        padding: 22px 18px;
      }

      .cc-faq-item summary {
        display: flex;
        align-items: center;
        position: relative;
        min-height: 66px;
        padding: 18px 20px 18px 18px;
        font-size: 17px;
        font-weight: 700;
        color: var(--cc-ink);
        transition: background 180ms ease;
        list-style: none;
        cursor: pointer;
      }

      .cc-faq-item summary:hover {
        background: #f8fafc;
      }

      .cc-faq-item[open] p {
        animation: faqFadeInDown 0.35s ease-out forwards;
      }

      .cc-faq-item p {
        padding: 0 16px 18px;
      }


      .cc-section h2 {margin-top:10px;}
      .cc-cta h2 {
        margin: 16px auto 0;
        font-size: clamp(24px, 9vw, 24px);
        line-height: 1.44;
        color: #ffffff;
      }

      .live-reservation__head {
        display: grid;
        padding: 22px 18px 16px;
      }

      .live-reservation__head h3 {
        font-size: 24px;
      }

      .live-reservation__viewport {
        flex-basis: auto;
        height: auto;
        padding: 16px;
      }

      .live-reservation__item {
        min-height: 0;
        padding: 15px 16px;
        border: 1px solid rgba(15, 23, 42, 0.1);
        border-radius: 14px;
        background: #ffffff;
      }

      .live-reservation__item:hover {
        transform: translateY(-2px);
        border-color: rgba(41, 104, 217, 0.28);
      }
    }


    @keyframes ccKenBurns {
      0% {
        transform: scale(1);
      }

      100% {
        transform: scale(1.08);
      }
    }

    .reveal-on-scroll {
      padding: 0px;
      transition: opacity 800ms cubic-bezier(0.25, 1, 0.5, 1), transform 800ms cubic-bezier(0.25, 1, 0.5, 1);
      opacity: 0;
      transform: translateY(30px);
      padding-top: 0px;
      padding-left: 0px;
      padding-right: 0px;
      padding-bottom: 0px;

    }

    .reveal-on-scroll.is-revealed {
      opacity: 1;
      transform: translateY(0);
    }

    .delay-100 {
      transition-delay: 100ms;
    }

    .delay-200 {
      transition-delay: 200ms;
    }

    .delay-300 {
      transition-delay: 300ms;
    }



    @media (max-width: 640px) {

.cc-process span {font-size:16px;}


.cc-label {
      margin-bottom:5px;
    }
.cc-needs .cc-need-row p {margin:8px 0 0;}
.cc-cta p {font-size:15px;}
.cc-process strong {margin-top:5px;}
.live-reservation .cc-label {font-size:12px; min-height:auto; padding:3px 12px;}
      .cc-service-card,
      .cc-gallery-card {
        padding: 14px;
      }

      .cc-service-card p,
      .cc-gallery-card p,
      .cc-faq-item p,
      .live-reservation__text {
        word-break: keep-all;
      }

      .live-reservation__item {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px 10px;
        padding: 14px;
      }

      .live-reservation__field {
        gap: 7px;
        font-size: 13px;
      }

      .live-reservation__field i {
        font-size: 18px;
      }

      .live-reservation__status {
        justify-self: stretch;
        min-width: 0;
        min-height: 32px;
        font-size: 12px;
      }
    }
