/* ================================================================
   STYLESHEET — css/style.css
   ================================================================
   CARA EDIT WARNA UTAMA:
   Cari bahagian ":root" di bawah dan tukar nilai warna.
   --red        = warna merah utama (contoh: #D0021B)
   --red-dark   = warna merah gelap (hover)
   Contoh tukar kepada biru: --red: #0057A8;
   ================================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    :root {
      --red: #D0021B;
      --red-dark: #A80016;
      --red-light: #FF2D3A;
      --white: #FFFFFF;
      --off-white: #F7F7F7;
      --gray-100: #F2F2F2;
      --gray-200: #E5E5E5;
      --gray-500: #9E9E9E;
      --gray-700: #444444;
      --black: #111111;
    }

    html { scroll-behavior: smooth; }
    body { font-family: 'Inter', sans-serif; color: var(--black); background: var(--white); }

    /* NAV */
    nav {
      position: fixed; top: 0; left: 0; right: 0; z-index: 999;
      background: rgba(255,255,255,0.97);
      backdrop-filter: blur(8px);
      border-bottom: 1px solid var(--gray-200);
      display: flex; align-items: center; justify-content: space-between;
      padding: 0 5%;
      height: 64px;
    }
    .nav-logo {
      font-size: 1.1rem; font-weight: 800; letter-spacing: -0.5px;
      color: var(--red);
    }
    .nav-logo span { color: var(--black); }
    .nav-links { display: flex; gap: 2rem; list-style: none; }
    .nav-links a {
      text-decoration: none; font-size: 0.875rem; font-weight: 500;
      color: var(--gray-700); transition: color 0.2s;
    }
    .nav-links a:hover { color: var(--red); }
    .nav-cta {
      background: var(--red); color: white;
      border: none; border-radius: 6px;
      padding: 0.5rem 1.2rem;
      font-size: 0.875rem; font-weight: 600; cursor: pointer;
      text-decoration: none; transition: background 0.2s;
    }
    .nav-cta:hover { background: var(--red-dark); }

    /* HERO — Design D: Foto Penuh */
    .hero {
      min-height: 100vh;
      background: var(--red);
      display: flex; align-items: stretch;
      padding: 0; position: relative; overflow: hidden;
    }
    .hero-inner {
      max-width: 1200px; margin: 0 auto;
      display: grid; grid-template-columns: 1.1fr 0.9fr;
      align-items: stretch; width: 100%;
      position: relative; z-index: 1;
    }
    /* Left content */
    .hero-content {
      display: flex; flex-direction: column; justify-content: center;
      padding: 120px 4% 80px 5%;
      position: relative; z-index: 2;
    }
    .hero-badge {
      display: inline-flex; align-items: center; gap: 0.4rem;
      background: rgba(255,255,255,0.15);
      border: 1px solid rgba(255,255,255,0.3);
      color: white;
      font-size: 0.72rem; font-weight: 600; letter-spacing: 1.5px;
      text-transform: uppercase;
      padding: 0.35rem 1rem; border-radius: 99px;
      margin-bottom: 1.5rem; width: fit-content;
    }
    .hero h1 {
      font-size: clamp(2.8rem, 5vw, 4.2rem);
      font-weight: 800; color: white;
      line-height: 1.0; letter-spacing: -2px;
      margin-bottom: 1.25rem;
    }
    .hero h1 span {
      color: rgba(255,255,255,0.65);
      font-weight: 300; display: block;
      font-size: 0.55em; letter-spacing: 1px;
      margin-bottom: 0.2rem;
    }
    .hero-desc {
      color: rgba(255,255,255,0.75);
      font-size: 1rem; line-height: 1.75;
      margin-bottom: 2.25rem; max-width: 400px;
    }
    .hero-btns { display: flex; gap: 1rem; flex-wrap: wrap; }
    .btn-primary {
      background: white; color: var(--red);
      border: none; border-radius: 8px;
      padding: 0.9rem 1.8rem;
      font-size: 0.95rem; font-weight: 700; cursor: pointer;
      text-decoration: none;
      transition: transform 0.2s, box-shadow 0.2s;
      display: inline-flex; align-items: center; gap: 0.5rem;
    }
    .btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.25); }
    .btn-secondary {
      background: transparent; color: white;
      border: 2px solid rgba(255,255,255,0.45); border-radius: 8px;
      padding: 0.9rem 1.8rem;
      font-size: 0.95rem; font-weight: 600; cursor: pointer;
      text-decoration: none;
      transition: border-color 0.2s, background 0.2s;
      display: inline-flex; align-items: center; gap: 0.5rem;
    }
    .btn-secondary:hover { border-color: white; background: rgba(255,255,255,0.1); }

    /* Stats bar — full width strip at bottom of left column */
    .hero-stats {
      display: flex; gap: 2.5rem;
      margin-top: 3rem;
      padding-top: 2rem;
      border-top: 1px solid rgba(255,255,255,0.2);
    }
    .stat { color: white; }
    .stat-num { font-size: 2rem; font-weight: 800; line-height: 1; }
    .stat-label { font-size: 0.72rem; opacity: 0.65; margin-top: 0.25rem; letter-spacing: 0.3px; }

    /* Right — full-height photo */
    .hero-visual {
      position: relative; overflow: hidden;
    }
    /* Dark overlay wedge on left edge of photo panel */
    .hero-visual::before {
      content: '';
      position: absolute; inset: 0; z-index: 1;
      background: linear-gradient(to right, rgba(208,2,27,0.55) 0%, rgba(208,2,27,0.1) 40%, transparent 70%);
    }
    .hero-photo-wrap {
      width: 100%; height: 100%;
      min-height: 100vh;
    }
    .hero-photo-wrap img {
      width: 100%; height: 100%;
      object-fit: cover; object-position: center top;
      display: block;
    }
    /* Floating credential card */
    .hero-tag {
      position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%);
      background: rgba(255,255,255,0.12);
      backdrop-filter: blur(12px);
      border: 1px solid rgba(255,255,255,0.25);
      border-radius: 12px;
      padding: 0.75rem 1.25rem;
      display: flex; align-items: center; gap: 0.75rem;
      z-index: 2; white-space: nowrap;
    }
    .hero-tag-icon { font-size: 1.4rem; }
    .hero-tag-text { font-size: 0.8rem; font-weight: 600; color: white; }
    .hero-tag-sub { font-size: 0.7rem; color: rgba(255,255,255,0.65); }

    @media (max-width: 768px) {
      .hero {
        padding: 0;
        min-height: auto;
      }
      .hero-inner {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
      }
      /* Photo appears FIRST on mobile (top) */
      .hero-visual {
        display: block;
        order: -1;
        height: 380px;
        min-height: unset;
      }
      .hero-photo-wrap {
        height: 100%;
        min-height: unset;
      }
      .hero-photo-wrap img {
        object-position: center 35%;
      }
      /* Gradient overlay stronger on mobile so text below is clearly separated */
      .hero-visual::before {
        background: linear-gradient(to bottom, transparent 50%, var(--red) 100%);
      }
      /* Floating credential tag hidden on mobile (too cramped) */
      .hero-tag { display: none; }
      .hero-content {
        padding: 2rem 5% 3rem;
        order: 1;
      }
      .hero h1 { font-size: 2.6rem; }
      .hero-stats { gap: 1.5rem; }
      .stat-num { font-size: 1.5rem; }
      .hero-btns { flex-direction: column; }
      .btn-primary, .btn-secondary { text-align: center; justify-content: center; }
    }

    /* SECTION BASE */
    section { padding: 80px 5%; }
    .section-inner { max-width: 1100px; margin: 0 auto; }
    .section-label {
      font-size: 0.75rem; font-weight: 700; letter-spacing: 2px;
      text-transform: uppercase; color: var(--red); margin-bottom: 0.5rem;
    }
    .section-title {
      font-size: clamp(1.7rem, 3vw, 2.4rem);
      font-weight: 800; letter-spacing: -0.5px;
      color: var(--black); margin-bottom: 1rem;
    }
    .section-desc {
      color: var(--gray-700); font-size: 1rem; line-height: 1.7; max-width: 520px;
    }

    /* ABOUT */
    .about { background: var(--white); }
    .about-grid {
      display: grid; grid-template-columns: 1fr 1.5fr;
      gap: 4rem; align-items: center; margin-top: 3rem;
    }
    .about-photo {
      background: var(--gray-100); border-radius: 16px;
      aspect-ratio: 4/5;
      display: flex; align-items: center; justify-content: center;
      font-size: 5rem; color: var(--gray-500);
      position: relative; overflow: hidden;
    }
    .about-photo-badge {
      position: absolute; bottom: 1rem; left: 1rem; right: 1rem;
      background: var(--red); color: white;
      border-radius: 10px; padding: 0.75rem 1rem;
      font-size: 0.8rem; font-weight: 600; text-align: center;
      z-index: 1;
    }
    .about-perks { margin-top: 2rem; display: flex; flex-direction: column; gap: 1rem; }
    .perk {
      display: flex; align-items: flex-start; gap: 1rem;
      padding: 1rem; background: var(--gray-100); border-radius: 10px;
    }
    .perk-icon {
      width: 40px; height: 40px; border-radius: 8px;
      background: var(--red); color: white;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.1rem; flex-shrink: 0;
    }
    .perk-title { font-size: 0.9rem; font-weight: 600; margin-bottom: 0.2rem; }
    .perk-desc { font-size: 0.8rem; color: var(--gray-500); }

    /* CARS */
    .cars { background: var(--gray-100); }
    .cars-grid {
      display: grid;
      /* 4 columns on wide screens so 7 cards = 4+3, centred nicely */
      grid-template-columns: repeat(4, 1fr);
      gap: 1.5rem; margin-top: 3rem;
    }
    /* Last row: if only 3 cards remain, centre them */
    .cars-grid .car-card:nth-child(5),
    .cars-grid .car-card:nth-child(6),
    .cars-grid .car-card:nth-child(7) {
      /* offset so row of 3 aligns centre under row of 4 */
    }
    @media (max-width: 1100px) {
      .cars-grid { grid-template-columns: repeat(3, 1fr); }
    }
    @media (max-width: 700px) {
      .cars-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
    }
    @media (max-width: 420px) {
      .cars-grid { grid-template-columns: 1fr; }
    }
    .car-card {
      background: white; border-radius: 16px; overflow: hidden;
      transition: transform 0.2s, box-shadow 0.2s;
      box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    }
    .car-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,0.12); }
    .car-img {
      height: 190px; background: var(--gray-100);
      display: flex; align-items: center; justify-content: center;
      position: relative; overflow: hidden;
    }
    /* Real car photo — fills the image area */
    .car-photo {
      width: 100%; height: 100%;
      object-fit: contain;
      object-position: center center;
      display: block;
      padding: 0.75rem;
      transition: transform 0.35s ease;
    }
    .car-card:hover .car-photo { transform: scale(1.06); }
    .car-badge {
      position: absolute; top: 0.75rem; right: 0.75rem;
      background: var(--red); color: white;
      font-size: 0.65rem; font-weight: 700; letter-spacing: 0.5px;
      padding: 0.25rem 0.6rem; border-radius: 99px; text-transform: uppercase;
    }
    .car-body { padding: 1.25rem; }
    .car-name { font-size: 1.1rem; font-weight: 700; margin-bottom: 0.25rem; }
    .car-type { font-size: 0.75rem; color: var(--gray-500); margin-bottom: 0.75rem; }
    .car-price { font-size: 0.9rem; color: var(--red); font-weight: 700; margin-bottom: 1rem; }
    .car-btn {
      width: 100%; padding: 0.6rem;
      background: var(--red); color: white;
      border: none; border-radius: 8px;
      font-size: 0.85rem; font-weight: 600; cursor: pointer;
      transition: background 0.2s;
    }
    .car-btn:hover { background: var(--red-dark); }

    /* SERVIS */
    .servis { background: var(--white); }
    .servis-grid {
      display: grid; grid-template-columns: repeat(3, 1fr);
      gap: 2rem; margin-top: 3rem;
    }
    .servis-card {
      border: 1.5px solid var(--gray-200);
      border-radius: 20px; padding: 2.5rem 2rem;
      text-align: center; position: relative;
      transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
      overflow: hidden;
    }
    .servis-card::before {
      content: '';
      position: absolute; top: 0; left: 0; right: 0;
      height: 4px; background: var(--red);
      transform: scaleX(0); transform-origin: left;
      transition: transform 0.3s;
    }
    .servis-card:hover { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(0,0,0,0.1); border-color: transparent; }
    .servis-card:hover::before { transform: scaleX(1); }
    .servis-icon-wrap {
      width: 72px; height: 72px; border-radius: 50%;
      background: #fff0f0;
      display: flex; align-items: center; justify-content: center;
      margin: 0 auto 1.5rem;
      font-size: 2rem;
      transition: background 0.2s;
    }
    .servis-card:hover .servis-icon-wrap { background: var(--red); }
    .servis-card:hover .servis-icon-wrap .servis-icon-emoji { filter: brightness(0) invert(1); }
    .servis-title {
      font-size: 1.15rem; font-weight: 700;
      color: var(--black); margin-bottom: 0.75rem;
    }
    .servis-desc {
      font-size: 0.875rem; color: var(--gray-700);
      line-height: 1.75; margin-bottom: 1.75rem;
    }
    .servis-list {
      list-style: none; text-align: left;
      margin-bottom: 2rem;
    }
    .servis-list li {
      font-size: 0.82rem; color: var(--gray-700);
      padding: 0.35rem 0;
      display: flex; align-items: flex-start; gap: 0.6rem;
      border-bottom: 1px solid var(--gray-100);
    }
    .servis-list li:last-child { border-bottom: none; }
    .servis-list li::before {
      content: '✓';
      color: var(--red); font-weight: 700;
      font-size: 0.8rem; flex-shrink: 0; margin-top: 1px;
    }
    .servis-cta {
      display: inline-flex; align-items: center; gap: 0.5rem;
      background: var(--red); color: white;
      border: none; border-radius: 8px;
      padding: 0.7rem 1.5rem;
      font-size: 0.875rem; font-weight: 700;
      cursor: pointer; text-decoration: none;
      transition: background 0.2s, transform 0.2s;
      width: 100%; justify-content: center;
    }
    .servis-cta:hover { background: var(--red-dark); transform: translateY(-1px); }
    @media (max-width: 768px) {
      .servis-grid { grid-template-columns: 1fr; }
    }

    /* LOAN CALCULATOR */
    .calculator { background: var(--gray-100); }
    .calc-wrapper {
      display: grid; grid-template-columns: 1.1fr 1fr;
      gap: 2rem; margin-top: 3rem; align-items: start;
    }
    .calc-card {
      background: white; border-radius: 20px; padding: 2rem;
      box-shadow: 0 4px 24px rgba(0,0,0,0.07);
    }
    .calc-card-title {
      font-size: 1rem; font-weight: 700; margin-bottom: 1.5rem;
      color: var(--black); display: flex; align-items: center; gap: 0.5rem;
    }
    .calc-step {
      width: 26px; height: 26px; border-radius: 50%;
      background: var(--red); color: white;
      font-size: 0.75rem; font-weight: 800;
      display: inline-flex; align-items: center; justify-content: center;
      flex-shrink: 0;
    }
    .calc-group { margin-bottom: 1.25rem; }
    .calc-label {
      display: block; font-size: 0.78rem; font-weight: 600;
      color: var(--gray-700); margin-bottom: 0.4rem;
      text-transform: uppercase; letter-spacing: 0.5px;
    }
    .calc-select, .calc-input {
      width: 100%; padding: 0.75rem 1rem;
      border: 1.5px solid var(--gray-200); border-radius: 10px;
      font-size: 0.9rem; font-family: 'Inter', sans-serif;
      color: var(--black); background: var(--off-white);
      outline: none; transition: border-color 0.2s;
      appearance: none; -webkit-appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
      background-repeat: no-repeat; background-position: right 1rem center;
    }
    .calc-select:focus, .calc-input:focus { border-color: var(--red); background: white; }
    .calc-input { background-image: none; }
    .calc-input[readonly] { background: var(--gray-100); color: var(--gray-500); cursor: not-allowed; }
    .calc-price-display {
      background: linear-gradient(135deg, var(--red), var(--red-dark));
      border-radius: 10px; padding: 1rem 1.25rem;
      display: flex; justify-content: space-between; align-items: center;
      margin-bottom: 1.25rem;
    }
    .calc-price-label { font-size: 0.78rem; color: rgba(255,255,255,0.8); font-weight: 500; }
    .calc-price-val { font-size: 1.3rem; font-weight: 800; color: white; }
    .calc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
    /* SLIDERS */
    .slider-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.6rem; }
    .slider-val {
      font-size: 1.05rem; font-weight: 800; color: var(--red);
      background: rgba(208,2,27,0.08); padding: 0.2rem 0.7rem;
      border-radius: 6px;
    }
    .slider-input {
      width: 100%; -webkit-appearance: none; appearance: none;
      height: 6px; border-radius: 99px; outline: none; cursor: pointer;
      background: var(--gray-200);
    }
    .slider-input::-webkit-slider-thumb {
      -webkit-appearance: none; appearance: none;
      width: 24px; height: 24px; border-radius: 50%;
      background: var(--red); cursor: pointer;
      box-shadow: 0 2px 8px rgba(208,2,27,0.45);
      border: 3px solid white;
      transition: transform 0.15s;
    }
    .slider-input::-webkit-slider-thumb:hover { transform: scale(1.2); }
    .slider-input::-moz-range-thumb {
      width: 24px; height: 24px; border-radius: 50%;
      background: var(--red); cursor: pointer; border: 3px solid white;
      box-shadow: 0 2px 8px rgba(208,2,27,0.45);
    }
    .slider-minmax { display: flex; justify-content: space-between; font-size: 0.7rem; color: var(--gray-500); margin-top: 0.4rem; }
    .deposit-pct-tag {
      margin-top: 0.6rem; font-size: 0.8rem; color: var(--gray-700);
      display: flex; align-items: center; gap: 0.4rem;
    }
    .deposit-pct-tag span { font-weight: 800; color: var(--red); }
    /* Slider + Input row */
    .slider-input-row {
      display: grid; grid-template-columns: 1fr auto;
      gap: 0.75rem; align-items: center; margin-top: 0.75rem;
    }
    .manual-input-wrap {
      position: relative; display: flex; align-items: center;
    }
    .manual-input-prefix {
      position: absolute; left: 0.75rem;
      font-size: 0.82rem; font-weight: 700; color: var(--gray-700);
      pointer-events: none;
    }
    .manual-input-suffix {
      position: absolute; right: 0.75rem;
      font-size: 0.82rem; font-weight: 700; color: var(--gray-700);
      pointer-events: none;
    }
    .manual-input {
      width: 110px; padding: 0.55rem 0.75rem 0.55rem 2.2rem;
      border: 1.5px solid var(--gray-200); border-radius: 8px;
      font-size: 0.875rem; font-weight: 700; font-family: 'Inter', sans-serif;
      color: var(--black); background: var(--off-white);
      outline: none; transition: border-color 0.2s;
      text-align: right; padding-right: 0.75rem; padding-left: 2.2rem;
    }
    .manual-input.rate-input { padding-left: 0.75rem; padding-right: 2rem; width: 90px; }
    .manual-input:focus { border-color: var(--red); background: white; }
    /* Results card */
    .result-card {
      background: linear-gradient(160deg, var(--red) 0%, #6a0010 100%);
      border-radius: 20px; padding: 2rem;
      box-shadow: 0 8px 32px rgba(208,2,27,0.3);
      position: sticky; top: 84px;
    }
    .result-header { text-align: center; margin-bottom: 2rem; }
    .result-header-label { font-size: 0.78rem; color: rgba(255,255,255,0.7); font-weight: 600; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 0.5rem; }
    .result-monthly { font-size: 3rem; font-weight: 900; color: white; line-height: 1; }
    .result-monthly span { font-size: 1.2rem; font-weight: 400; opacity: 0.8; }
    .result-month-label { font-size: 0.85rem; color: rgba(255,255,255,0.7); margin-top: 0.4rem; }
    .result-divider { height: 1px; background: rgba(255,255,255,0.15); margin: 1.5rem 0; }
    .result-rows { display: flex; flex-direction: column; gap: 0.9rem; }
    .result-row { display: flex; justify-content: space-between; align-items: center; }
    .result-row-label { font-size: 0.82rem; color: rgba(255,255,255,0.7); }
    .result-row-val { font-size: 0.9rem; font-weight: 700; color: white; }
    .result-row-val.highlight { color: #FFD580; font-size: 1rem; }
    .result-cta {
      margin-top: 2rem; width: 100%;
      background: white; color: var(--red);
      border: none; border-radius: 10px;
      padding: 1rem; font-size: 0.95rem; font-weight: 800;
      cursor: pointer; transition: transform 0.2s, box-shadow 0.2s;
      display: flex; align-items: center; justify-content: center; gap: 0.5rem;
    }
    .result-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.2); }
    .result-disclaimer { font-size: 0.68rem; color: rgba(255,255,255,0.5); text-align: center; margin-top: 1rem; line-height: 1.5; }

    /* COLOUR PICKER */
    .colour-btn-row { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: 0.25rem; }
    .colour-btn {
      padding: 0.55rem 1.1rem; border-radius: 8px; border: 2px solid transparent;
      font-size: 0.8rem; font-weight: 600; cursor: pointer;
      background: var(--gray-100); color: var(--gray-700);
      transition: all 0.18s;
    }
    .colour-btn:hover { border-color: var(--red); color: var(--red); }
    .colour-btn.active {
      background: var(--red); color: white; border-color: var(--red);
      box-shadow: 0 2px 8px rgba(208,2,27,0.3);
    }

    @media (max-width: 900px) {
      .calc-wrapper { grid-template-columns: 1fr; }
      .result-card { position: static; }
    }

    /* PROOF OF DELIVERY / BUKTI PENGHANTARAN */
    .delivery { background: var(--white); }
    .tiktok-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
      gap: 1.5rem; margin-top: 3rem;
    }
    .tiktok-card {
      border-radius: 16px; overflow: hidden;
      background: #010101;
      box-shadow: 0 4px 20px rgba(0,0,0,0.12);
      transition: transform 0.2s, box-shadow 0.2s;
      text-decoration: none;
      display: block;
    }
    .tiktok-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,0.2); }
    .tiktok-thumb {
      height: 300px;
      background: #1a1a1a;
      position: relative;
      overflow: hidden;
    }
    /* Thumbnail image fills the card */
    .tiktok-thumb-img {
      width: 100%; height: 100%;
      object-fit: cover; object-position: center top;
      display: block;
      transition: transform 0.35s ease;
    }
    .tiktok-card:hover .tiktok-thumb-img { transform: scale(1.05); }
    /* Dark gradient overlay so play button & label stay readable */
    .tiktok-thumb::before {
      content: '';
      position: absolute; inset: 0; z-index: 1;
      background: linear-gradient(to bottom, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.65) 100%);
    }
    .tiktok-play-btn {
      position: absolute; top: 50%; left: 50%;
      transform: translate(-50%, -60%);
      width: 64px; height: 64px; border-radius: 50%;
      background: rgba(255,255,255,0.2);
      border: 3px solid rgba(255,255,255,0.7);
      display: flex; align-items: center; justify-content: center;
      font-size: 1.6rem; z-index: 2;
      transition: background 0.2s, transform 0.2s;
    }
    .tiktok-card:hover .tiktok-play-btn {
      background: rgba(255,0,80,0.75);
      transform: translate(-50%, -60%) scale(1.1);
    }
    .tiktok-label {
      position: absolute; bottom: 1rem; left: 1rem; right: 1rem;
      z-index: 1; color: white;
    }
    .tiktok-label-title { font-size: 0.9rem; font-weight: 700; margin-bottom: 0.2rem; }
    .tiktok-label-sub { font-size: 0.75rem; opacity: 0.7; }
    .tiktok-footer {
      padding: 1rem 1.25rem;
      display: flex; align-items: center; justify-content: space-between;
    }
    .tiktok-logo {
      display: flex; align-items: center; gap: 0.5rem;
      color: white; font-size: 0.85rem; font-weight: 700;
    }
    .tiktok-logo-icon {
      width: 28px; height: 28px; border-radius: 6px;
      background: linear-gradient(45deg, #010101, #1a1a1a);
      display: flex; align-items: center; justify-content: center;
      font-size: 1rem;
    }
    .tiktok-watch {
      background: linear-gradient(90deg, #ff0050, #00f2ea);
      color: white; border: none; border-radius: 6px;
      padding: 0.4rem 0.9rem;
      font-size: 0.78rem; font-weight: 700; cursor: pointer;
      -webkit-background-clip: text; -webkit-text-fill-color: transparent;
      background-clip: text;
      border: 1.5px solid;
      border-image: linear-gradient(90deg, #ff0050, #00f2ea) 1;
    }
    .tiktok-watch-btn {
      font-size: 0.78rem; font-weight: 700;
      background: linear-gradient(90deg, #ff0050, #00f2ea);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      border: 1.5px solid #ff0050;
      border-radius: 6px;
      padding: 0.4rem 0.9rem;
    }
    .add-more-card {
      border-radius: 16px;
      background: var(--gray-100);
      border: 2px dashed var(--gray-200);
      display: flex; flex-direction: column;
      align-items: center; justify-content: center;
      gap: 0.75rem; padding: 2rem;
      min-height: 370px;
      text-align: center;
    }
    .add-more-icon { font-size: 2.5rem; opacity: 0.4; }
    .add-more-text { font-size: 0.9rem; color: var(--gray-500); font-weight: 500; }

    /* TESTIMONIALS — infinite auto-scroll photo gallery */
    .testimonials {
      background: var(--gray-100);
      padding-bottom: 60px;
      /* Hide overflow so cards scroll edge-to-edge */
      overflow: hidden;
    }

    /* Keyframe: slide left by exactly half the track (= 6 original cards) */
    @keyframes testi-infinite-scroll {
      0%   { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    .testi-scroll-wrap {
      margin-top: 2.5rem;
      overflow: hidden;
      padding: 0.5rem 0 1.5rem;
      /* Fade edges for polished look */
      -webkit-mask-image: linear-gradient(to right, transparent 0%, black 4%, black 96%, transparent 100%);
      mask-image: linear-gradient(to right, transparent 0%, black 4%, black 96%, transparent 100%);
    }

    /* Pause on hover (desktop) or focus */
    .testi-scroll-wrap:hover .testi-scroll-track,
    .testi-scroll-wrap:focus-within .testi-scroll-track {
      animation-play-state: paused;
    }

    /* The inner flex row — animated */
    .testi-scroll-track {
      display: flex;
      gap: 1rem;
      width: max-content;
      animation: testi-infinite-scroll 28s linear infinite;
    }

    /* Each photo card — portrait phone screenshot ratio (~9:18) */
    .testi-img-card {
      flex-shrink: 0;
      width: 210px;
      height: 420px;
      border-radius: 18px;
      overflow: hidden;
      box-shadow: 0 4px 18px rgba(0,0,0,0.12);
      background: var(--gray-200);
      transition: transform 0.25s, box-shadow 0.25s;
    }
    .testi-img-card:hover {
      transform: scale(1.03);
      box-shadow: 0 14px 36px rgba(0,0,0,0.18);
    }
    .testi-img-card img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center top;
      display: block;
    }

    /* Mobile: slightly smaller, same ratio */
    @media (max-width: 768px) {
      .testi-img-card { width: 175px; height: 350px; }
      .testi-scroll-track { gap: 0.75rem; animation-duration: 22s; }
    }

    /* CONTACT */
    .contact { background: var(--white); }
    .contact-grid {
      display: grid; grid-template-columns: 1fr 1fr;
      gap: 4rem; align-items: start; margin-top: 3rem;
    }
    .contact-info { display: flex; flex-direction: column; gap: 1.5rem; }
    .contact-item { display: flex; align-items: flex-start; gap: 1rem; }
    .contact-icon {
      width: 44px; height: 44px; border-radius: 10px;
      background: var(--red); color: white;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.2rem; flex-shrink: 0;
    }
    .contact-label { font-size: 0.75rem; color: var(--gray-500); margin-bottom: 0.2rem; }
    .contact-val { font-size: 0.95rem; font-weight: 600; }
    .form-card {
      background: var(--gray-100); border-radius: 16px;
      padding: 2rem;
      box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    }
    .form-title { font-size: 1.2rem; font-weight: 700; margin-bottom: 1.5rem; }
    .form-group { margin-bottom: 1rem; }
    .form-group label {
      display: block; font-size: 0.8rem; font-weight: 600;
      margin-bottom: 0.4rem; color: var(--gray-700);
    }
    .form-group input,
    .form-group select,
    .form-group textarea {
      width: 100%; padding: 0.7rem 1rem;
      border: 1.5px solid var(--gray-200); border-radius: 8px;
      font-size: 0.875rem; font-family: 'Inter', sans-serif;
      outline: none; transition: border-color 0.2s;
      background: white;
    }
    .form-group input:focus,
    .form-group select:focus,
    .form-group textarea:focus { border-color: var(--red); }
    .form-group textarea { height: 100px; resize: vertical; }
    .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
    .form-submit {
      width: 100%; padding: 0.85rem;
      background: var(--red); color: white;
      border: none; border-radius: 8px;
      font-size: 0.95rem; font-weight: 700; cursor: pointer;
      margin-top: 0.5rem; transition: background 0.2s;
    }
    .form-submit:hover { background: var(--red-dark); }
    .form-submit:disabled { background: var(--gray-500); cursor: not-allowed; }
    .cf-status {
      margin-top: 0.85rem;
      padding: 0.75rem 1rem;
      border-radius: 8px;
      font-size: 0.875rem;
      font-weight: 600;
      text-align: center;
    }
    .cf-status.success { background: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
    .cf-status.error   { background: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }

    /* SYARIKAT SECTION */
    .syarikat { background: #f7f7f7; padding: 5rem 5%; }
    .syarikat-card {
      max-width: 960px;
      margin: 2.5rem auto 0;
      background: #fff;
      border-radius: 16px;
      box-shadow: 0 4px 24px rgba(0,0,0,0.10);
      padding: 2rem;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 2rem;
      align-items: stretch;
    }
    .syarikat-info-col {
      display: flex;
      flex-direction: column;
      gap: 1.2rem;
    }
    .syarikat-name-row { display: flex; align-items: center; gap: 1rem; }
    .syarikat-logo-badge {
      width: 52px; height: 52px;
      background: var(--red);
      border-radius: 12px;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.5rem;
      flex-shrink: 0;
    }
    .syarikat-name { font-size: 1.25rem; font-weight: 800; color: var(--black); margin: 0 0 0.15rem; }
    .syarikat-type { font-size: 0.8rem; color: var(--gray-500); margin: 0; }
    .syarikat-rating { display: flex; align-items: center; gap: 0.5rem; }
    .syarikat-stars { color: #f5a623; font-size: 1rem; letter-spacing: 1px; }
    .syarikat-rating-val { font-weight: 800; font-size: 0.95rem; color: var(--black); }
    .syarikat-reviews { font-size: 0.82rem; color: #1a73e8; text-decoration: underline; }
    .syarikat-divider { height: 1px; background: #eee; }
    .syarikat-info-list { display: flex; flex-direction: column; gap: 1rem; }
    .syarikat-info-item { display: flex; align-items: flex-start; gap: 0.8rem; }
    .syarikat-info-icon { font-size: 1.1rem; margin-top: 0.1rem; flex-shrink: 0; }
    .syarikat-info-item > div { display: flex; flex-direction: column; gap: 0.2rem; }
    .syarikat-info-label { font-size: 0.72rem; color: var(--gray-500); text-transform: uppercase; letter-spacing: 0.5px; }
    .syarikat-info-value { font-size: 0.92rem; font-weight: 600; color: var(--black); }
    .syarikat-phone-link { color: var(--red); text-decoration: none; font-weight: 700; }
    .syarikat-hours { display: flex; flex-direction: column; gap: 0.2rem; margin-top: 0.1rem; }
    .syarikat-hours-row { display: flex; justify-content: space-between; font-size: 0.88rem; color: var(--black); gap: 2rem; }
    .syarikat-closed { color: #e53935; font-weight: 700; }
    .syarikat-map-wrap { border-radius: 12px; overflow: hidden; line-height: 0; min-height: 320px; }
    @media (max-width: 700px) {
      .syarikat-card { grid-template-columns: 1fr; }
      .syarikat-map-wrap { min-height: 260px; }
    }

    /* CONTACT SECTION */
    .contact { background: var(--white); padding: 5rem 5%; }
    .contact-card {
      max-width: 480px;
      margin: 2.5rem auto 0;
      background: #fff;
      border-radius: 16px;
      box-shadow: 0 4px 24px rgba(0,0,0,0.10);
      padding: 2rem 2rem 2rem;
      display: flex;
      flex-direction: column;
      gap: 1.5rem;
    }
    .contact-info-list { display: flex; flex-direction: column; gap: 1.1rem; }
    .contact-info-item {
      display: flex;
      align-items: center;
      gap: 1rem;
    }
    .contact-icon {
      width: 44px; height: 44px;
      background: var(--red);
      border-radius: 10px;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.2rem;
      flex-shrink: 0;
    }
    .contact-info-text { display: flex; flex-direction: column; }
    .contact-info-label { font-size: 0.75rem; color: var(--gray-500); }
    .contact-info-value { font-size: 0.95rem; font-weight: 700; color: var(--black); }
    .contact-wa-btn {
      display: block;
      background: #25D366;
      color: #fff;
      text-align: center;
      padding: 0.95rem 1.5rem;
      border-radius: 50px;
      font-size: 1rem;
      font-weight: 700;
      text-decoration: none;
      transition: background 0.2s;
    }
    .contact-wa-btn:hover { background: #1ebe57; }

    /* FOOTER */
    footer {
      background: var(--black); color: white;
      padding: 2.5rem 5%; text-align: center;
    }
    .footer-inner { max-width: 1100px; margin: 0 auto; }
    .footer-logo { font-size: 1.2rem; font-weight: 800; color: var(--red); margin-bottom: 0.5rem; }
    .footer-sub { font-size: 0.8rem; color: var(--gray-500); }
    .footer-name { font-size: 1.1rem; font-weight: 800; color: var(--red); margin-bottom: 0.25rem; }
    .footer-tagline { font-size: 0.85rem; color: #aaa; margin-bottom: 0.5rem; }
    .footer-copy { font-size: 0.78rem; color: #666; }

    /* ============================================================
       FANCY HEADER — Shared design for all sections
       Ghost watermark bg word + badge + bold italic title + divider
    ============================================================ */
    .fancy-header {
      position: relative;
      text-align: center;
      overflow: hidden;
      padding-bottom: 2.5rem;
    }
    .fancy-bg-word {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -52%);
      font-size: clamp(70px, 14vw, 140px);
      font-weight: 900;
      font-style: italic;
      letter-spacing: 6px;
      white-space: nowrap;
      color: transparent;
      -webkit-text-stroke: 2px rgba(208, 2, 27, 0.09);
      text-stroke: 2px rgba(208, 2, 27, 0.09);
      pointer-events: none;
      user-select: none;
      z-index: 0;
      line-height: 1;
    }
    .fancy-header-inner {
      position: relative;
      z-index: 1;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0.85rem;
    }
    .fancy-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      background: var(--red);
      color: white;
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 2px;
      text-transform: uppercase;
      padding: 0.3rem 1rem;
      border-radius: 50px;
    }
    .fancy-title {
      font-size: clamp(1.4rem, 3.5vw, 2.2rem);
      font-weight: 900;
      font-style: italic;
      color: var(--black);
      line-height: 1.2;
      letter-spacing: 1px;
      text-transform: uppercase;
      margin: 0;
    }
    .fancy-accent {
      color: var(--red);
      position: relative;
    }
    .fancy-accent::after {
      content: '';
      position: absolute;
      bottom: -3px;
      left: 0; right: 0;
      height: 3px;
      background: var(--red);
      border-radius: 2px;
    }
    .fancy-divider {
      display: flex;
      align-items: center;
      gap: 0.6rem;
      width: 200px;
      margin: 0.1rem auto 0;
    }
    .fancy-divider span:first-child,
    .fancy-divider span:last-child {
      flex: 1;
      height: 1.5px;
      background: linear-gradient(to right, transparent, var(--red));
    }
    .fancy-divider span:last-child {
      background: linear-gradient(to left, transparent, var(--red));
    }
    .fancy-divider-dot {
      font-size: 0.6rem;
      color: var(--red);
      flex: none !important;
      height: auto !important;
      background: none !important;
    }
    .fancy-desc {
      font-size: 0.92rem;
      color: var(--gray-500);
      line-height: 1.7;
      max-width: 520px;
      margin: 0;
    }

    /* ============================================================
       TESTIMONIALS — REDESIGNED HEADER
    ============================================================ */
    .testi-header {
      position: relative;
      text-align: center;
      padding: 70px 5% 48px;
      overflow: hidden;
    }
    /* Giant ghost watermark word behind everything */
    .testi-bg-word {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -54%);
      font-size: clamp(80px, 16vw, 160px);
      font-weight: 900;
      font-style: italic;
      letter-spacing: 6px;
      white-space: nowrap;
      color: transparent;
      -webkit-text-stroke: 2px rgba(208, 2, 27, 0.10);
      text-stroke: 2px rgba(208, 2, 27, 0.10);
      pointer-events: none;
      user-select: none;
      z-index: 0;
      line-height: 1;
    }
    /* Foreground content sits above the ghost word */
    .testi-header-inner {
      position: relative;
      z-index: 1;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0.85rem;
    }
    /* Small red pill badge above title */
    .testi-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      background: var(--red);
      color: white;
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 2px;
      text-transform: uppercase;
      padding: 0.3rem 1rem;
      border-radius: 50px;
    }
    /* Main bold italic title */
    .testi-main-title {
      font-size: clamp(1.5rem, 4vw, 2.4rem);
      font-weight: 900;
      font-style: italic;
      color: var(--black);
      line-height: 1.2;
      letter-spacing: 1px;
      text-transform: uppercase;
      margin: 0;
    }
    /* Red accent on "SAYA" */
    .testi-title-accent {
      color: var(--red);
      position: relative;
    }
    .testi-title-accent::after {
      content: '';
      position: absolute;
      bottom: -3px;
      left: 0; right: 0;
      height: 3px;
      background: var(--red);
      border-radius: 2px;
    }
    /* Decorative divider line with diamond */
    .testi-divider {
      display: flex;
      align-items: center;
      gap: 0.6rem;
      width: 200px;
      margin: 0.25rem auto 0;
    }
    .testi-divider span:first-child,
    .testi-divider span:last-child {
      flex: 1;
      height: 1.5px;
      background: linear-gradient(to right, transparent, var(--red));
    }
    .testi-divider span:last-child {
      background: linear-gradient(to left, transparent, var(--red));
    }
    .testi-divider-dot {
      font-size: 0.6rem;
      color: var(--red);
      flex: none !important;
      height: auto !important;
      background: none !important;
    }
    /* Description text */
    .testi-sub-desc {
      font-size: 0.92rem;
      color: var(--gray-500);
      line-height: 1.7;
      max-width: 500px;
      margin: 0;
    }

    /* WHATSAPP FAB */
    .fab {
      position: fixed; bottom: 2rem; right: 2rem;
      background: #25D366; color: white;
      width: 56px; height: 56px; border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.5rem; text-decoration: none;
      box-shadow: 0 4px 16px rgba(37,211,102,0.5);
      z-index: 999; transition: transform 0.2s;
    }
    .fab:hover { transform: scale(1.1); }

    /* ============================================================
       INSURANCE SECTION
    ============================================================ */
    .insurance {
      position: relative;
      background: #0a0a0a;
      overflow: hidden;
      padding: 0;
    }
    .insurance-bg-overlay {
      position: absolute;
      inset: 0;
      background:
        linear-gradient(to right, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.75) 50%, rgba(0,0,0,0.55) 100%),
        url('https://images.unsplash.com/photo-1508697014387-db70aad34f4d?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
      z-index: 0;
    }
    .insurance-inner {
      position: relative; z-index: 1;
      max-width: 1200px; margin: 0 auto;
      display: grid; grid-template-columns: 1fr 1.1fr;
      align-items: center; gap: 3rem;
      padding: 80px 5%;
    }

    /* LEFT */
    .insurance-label {
      display: inline-block;
      background: var(--red);
      color: white;
      font-size: 0.72rem; font-weight: 700; letter-spacing: 2px;
      text-transform: uppercase;
      padding: 0.3rem 0.9rem;
      border-radius: 4px;
      margin-bottom: 1rem;
    }
    .insurance-title {
      font-size: clamp(2rem, 4vw, 3.2rem);
      font-weight: 900;
      font-style: italic;
      color: white;
      letter-spacing: 2px;
      margin-bottom: 1.25rem;
      line-height: 1;
    }
    .insurance-desc {
      color: rgba(255,255,255,0.8);
      font-size: 0.95rem;
      line-height: 1.75;
      margin-bottom: 0.85rem;
    }
    .insurance-btns {
      display: flex; flex-wrap: wrap; gap: 0.85rem;
      margin-top: 1.75rem;
    }
    .ins-btn {
      display: inline-flex; align-items: center; gap: 0.55rem;
      padding: 0.65rem 1.4rem;
      border-radius: 6px;
      font-size: 0.875rem; font-weight: 700;
      text-decoration: none;
      transition: transform 0.18s, background 0.18s;
    }
    .ins-btn:hover { transform: translateY(-2px); }
    .ins-btn-primary {
      background: var(--red);
      color: white;
    }
    .ins-btn-primary:hover { background: var(--red-dark); }
    .ins-btn-secondary {
      background: transparent;
      color: white;
      border: 2px solid rgba(255,255,255,0.5);
    }
    .ins-btn-secondary:hover {
      background: rgba(255,255,255,0.1);
      border-color: white;
    }

    /* RIGHT */
    .insurance-right {
      display: flex; flex-direction: column;
      align-items: center; gap: 1.5rem;
    }
    .road-assist-wrap {
      display: flex; flex-direction: column; align-items: center; gap: 0;
    }
    .road-assist-badge {
      display: flex; align-items: center; gap: 0.75rem;
      background: rgba(255,255,255,0.07);
      border: 2px solid rgba(255,255,255,0.25);
      border-bottom: none;
      padding: 1rem 1.5rem;
      border-radius: 8px 8px 0 0;
    }
    .road-assist-clock-svg {
      width: 64px; height: 64px; flex-shrink: 0;
    }
    .road-assist-text {
      display: flex; align-items: center; gap: 0.5rem;
    }
    .road-assist-num {
      font-size: 3.5rem; font-weight: 900;
      color: white; line-height: 1;
    }
    .road-assist-labels {
      display: flex; flex-direction: column;
      color: white; font-weight: 700;
      font-size: 0.85rem; letter-spacing: 1px;
    }
    .road-assist-phone {
      background: var(--red);
      color: white;
      font-size: 1.2rem; font-weight: 800;
      letter-spacing: 1px;
      padding: 0.5rem 2rem;
      border-radius: 0 0 8px 8px;
      width: 100%; text-align: center;
    }

    /* Service Icons Grid */
    .ins-icons-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 1rem;
      width: 100%;
    }
    .ins-icon-item {
      display: flex; flex-direction: column;
      align-items: center; gap: 0.5rem;
      text-align: center;
    }
    .ins-icon-circle {
      width: 68px; height: 68px;
      border-radius: 50%;
      border: 3px solid var(--red);
      background: rgba(208,2,27,0.15);
      display: flex; align-items: center; justify-content: center;
      transition: background 0.2s, transform 0.2s;
    }
    .ins-icon-circle:hover {
      background: var(--red);
      transform: scale(1.08);
    }
    .ins-icon-label {
      font-size: 0.72rem; font-weight: 600;
      color: rgba(255,255,255,0.85);
      line-height: 1.35;
      max-width: 90px;
    }
    /* 7th icon — center the last row of 3 */
    .ins-icons-grid .ins-icon-item:nth-child(5) { grid-column: 1; }
    .ins-icons-grid .ins-icon-item:nth-child(6) { grid-column: 2; }
    .ins-icons-grid .ins-icon-item:nth-child(7) { grid-column: 3; }

    /* INSURANCE RESPONSIVE */
    @media (max-width: 900px) {
      .insurance-inner { grid-template-columns: 1fr; gap: 2.5rem; }
      .ins-icons-grid { grid-template-columns: repeat(4, 1fr); }
    }
    @media (max-width: 480px) {
      .ins-icons-grid { grid-template-columns: repeat(2, 1fr); }
      .ins-icons-grid .ins-icon-item:nth-child(n) { grid-column: auto; }
    }

    /* ============================================================
       COMPANY SECTION
    ============================================================ */
    .company {
      background: var(--off-white);
      padding: 80px 0;
    }
    .company-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 2.5rem;
      margin-top: 2.5rem;
      align-items: start;
    }

    /* Rating Badge */
    .company-rating-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.75rem;
      background: white;
      border: 1.5px solid var(--gray-200);
      border-radius: 10px;
      padding: 0.75rem 1.25rem;
      margin-bottom: 1.5rem;
      box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    }
    .company-rating-stars { display: flex; gap: 2px; }
    .star { font-size: 1.2rem; color: var(--gray-200); }
    .star.filled { color: #f5a623; }
    .star.half {
      position: relative; color: var(--gray-200);
      background: linear-gradient(to right, #f5a623 50%, var(--gray-200) 50%);
      -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    }
    .company-rating-text { display: flex; flex-direction: column; }
    .company-rating-num { font-size: 1.3rem; font-weight: 800; color: var(--black); line-height: 1; }
    .company-rating-reviews { font-size: 0.75rem; color: var(--gray-500); font-weight: 500; }

    /* Info Cards */
    .company-info-cards {
      display: flex; flex-direction: column; gap: 0.85rem;
      margin-bottom: 1.75rem;
    }
    .company-info-card {
      display: flex; align-items: flex-start; gap: 0.9rem;
      background: white;
      border: 1.5px solid var(--gray-200);
      border-radius: 10px;
      padding: 1rem 1.25rem;
      box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    }
    .company-info-icon { font-size: 1.3rem; flex-shrink: 0; margin-top: 2px; }
    .company-info-label {
      font-size: 0.72rem; font-weight: 700; letter-spacing: 1px;
      text-transform: uppercase; color: var(--gray-500);
      margin-bottom: 0.25rem;
    }
    .company-info-val { font-size: 0.92rem; font-weight: 600; color: var(--black); line-height: 1.5; }
    .company-phone-link { color: var(--red); text-decoration: none; font-weight: 700; }
    .company-phone-link:hover { text-decoration: underline; }

    /* Operating Hours */
    .company-hours {
      background: white;
      border: 1.5px solid var(--gray-200);
      border-radius: 10px;
      padding: 1.25rem;
      margin-bottom: 1.5rem;
      box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    }
    .company-hours-title {
      font-size: 0.85rem; font-weight: 700;
      color: var(--black); margin-bottom: 1rem;
      padding-bottom: 0.75rem;
      border-bottom: 1.5px solid var(--gray-100);
    }
    .company-hours-grid { display: flex; flex-direction: column; gap: 0.5rem; }
    .hours-row {
      display: flex; justify-content: space-between; align-items: center;
      font-size: 0.875rem;
    }
    .hours-day { font-weight: 600; color: var(--gray-700); }
    .hours-time { color: var(--gray-700); }
    .hours-row.closed .hours-day { color: var(--gray-500); }
    .hours-row.closed .hours-time { color: var(--red); font-weight: 600; }

    /* Directions Button */
    .company-directions-btn {
      display: inline-flex; align-items: center; gap: 0.5rem;
      background: var(--red); color: white;
      padding: 0.7rem 1.5rem;
      border-radius: 8px;
      font-size: 0.875rem; font-weight: 700;
      text-decoration: none;
      transition: background 0.2s, transform 0.18s;
    }
    .company-directions-btn:hover { background: var(--red-dark); transform: translateY(-2px); }

    /* Map */
    .company-map-col { display: flex; flex-direction: column; gap: 0.75rem; }
    .company-map-wrap {
      width: 100%; height: 420px;
      border-radius: 14px; overflow: hidden;
      border: 2px solid var(--gray-200);
      box-shadow: 0 4px 20px rgba(0,0,0,0.10);
    }
    .company-map-caption {
      font-size: 0.78rem; color: var(--gray-500);
      text-align: center; font-weight: 500;
    }

    /* Company Responsive */
    @media (max-width: 900px) {
      .company-grid { grid-template-columns: 1fr; }
      .company-map-wrap { height: 300px; }
    }

    @media (max-width: 768px) {
      .about-grid, .contact-grid { grid-template-columns: 1fr; }
      .nav-links { display: none; }

      /* Ghost watermark words — smaller on mobile */
      .fancy-bg-word,
      .testi-bg-word {
        font-size: clamp(28px, 9vw, 56px);
        -webkit-text-stroke-width: 1.5px;
        letter-spacing: 3px;
      }

      /* Hero stats — centered on mobile */
      .hero-stats {
        justify-content: center;
        text-align: center;
      }

      /* Company info cards — centered on mobile */
      .company-info-card {
        flex-direction: column;
        align-items: center;
        text-align: center;
      }
      .company-rating-badge {
        justify-content: center;
        margin: 0;
        width: 100%;
      }
      .company-info-col {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
      }
      .company-info-col .company-rating-badge,
      .company-info-col .company-info-cards,
      .company-info-col .company-hours {
        margin-bottom: 0;
      }
      .company-info-cards {
        gap: 1rem;
      }
      .company-hours-title,
      .company-hours-grid {
        text-align: left;
      }
      .company-directions-btn {
        width: 100%;
        justify-content: center;
      }
    }
