    :root {
      /* Brand palette — overridable from admin via inline :root in home.blade.php.
         --portal-primary-rgb holds the same colour as space-separated channels
         so it can drive rgb(... / alpha) shadows/tints. */
      --portal-primary: #0E9F6E;
      --portal-primary-rgb: 14 159 110;
      --portal-secondary: #0B7E58;
      --portal-accent: #f59e0b;
      --portal-primary-hover: #0B7E58;
      --portal-primary-dark: #064E3B;
      --ink: #0f172a;
      --muted: #64748b;
      --pale: #f8fafc;
      --line: #e2e8f0;
      --line-soft: #f1f5f9;
      --radius: 16px;
      --ease-spring: cubic-bezier(.22, 1, .36, 1);
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    }

    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      min-height: 100vh;
      margin: 0;
      color: var(--ink);
      background: #fff;
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      -webkit-font-smoothing: antialiased;
    }

    a {
      color: inherit;
      text-decoration: none;
    }

    .sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }

    button,
    input {
      font: inherit;
    }

    .container {
      width: min(100% - 48px, 1224px);
      margin-inline: auto;
    }

    .top-spacer {
      height: 66px;
    }

    .site-header {
      position: fixed;
      z-index: 50;
      top: 0;
      left: 0;
      right: 0;
      background: rgba(255, 255, 255, .98);
      box-shadow: 0 1px 0 rgba(15, 23, 42, .06);
    }

    .header-inner {
      position: relative;
      height: 66px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
      padding-inline: 26px 24px;
    }

    .brand {
      color: var(--portal-primary);
      font-size: 20px;
      font-weight: 800;
      letter-spacing: 0;
      white-space: nowrap;
    }

    .nav {
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      align-items: center;
      gap: 7px;
    }

    .nav a,
    .login {
      position: relative;
      display: inline-flex;
      align-items: center;
      min-height: 38px;
      padding: 8px 12px;
      border-radius: 8px;
      color: #005984;
      font-size: 14px;
      font-weight: 650;
      transition: color .2s, background .2s;
    }

    .nav a:hover,
    .login:hover {
      color: var(--portal-primary);
      background: rgba(0, 0, 0, .05);
    }

    .nav a.active::after {
      content: "";
      position: absolute;
      left: 12px;
      right: 12px;
      bottom: 1px;
      height: 2px;
      border-radius: 999px;
      background: var(--portal-primary);
    }

    .header-actions {
      display: flex;
      align-items: center;
      gap: 12px;
      margin-left: auto;
    }

    .header-cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      min-height: 38px;
      padding: 8px 19px;
      border-radius: 12px;
      color: #fff;
      background: linear-gradient(135deg, var(--portal-primary), var(--portal-primary-hover));
      box-shadow: 0 3px 12px rgb(var(--portal-primary-rgb) / .34);
      font-size: 14px;
      font-weight: 750;
      transition: transform .25s var(--ease-spring), box-shadow .25s;
    }

    .header-cta:hover {
      transform: translateY(-1px);
      box-shadow: 0 6px 18px rgb(var(--portal-primary-rgb) / .42);
    }

    .menu-button {
      display: none;
      width: 40px;
      height: 40px;
      align-items: center;
      justify-content: center;
      border: 0;
      border-radius: 10px;
      color: #111827;
      background: transparent;
      cursor: pointer;
    }

    .hero {
      position: relative;
      min-height: 461px;
      padding: 84px 0 104px;
      overflow: hidden;
      text-align: center;
      color: #fff;
      background:
        radial-gradient(circle at 12% 8%, rgb(var(--portal-primary-rgb) / .55) 0, rgb(var(--portal-primary-rgb) / .3) 20%, transparent 43%),
        radial-gradient(circle at 90% 42%, rgb(var(--portal-primary-rgb) / .44) 0, transparent 30%),
        linear-gradient(135deg, var(--portal-primary), var(--portal-secondary) 52%, var(--portal-primary-dark));
    }

    .hero-inner {
      position: relative;
      z-index: 2;
      width: min(100% - 48px, 860px);
      margin-inline: auto;
      text-align: center;
    }

    .hero::before,
    .hero::after {
      content: "";
      position: absolute;
      border-radius: 999px;
      filter: blur(74px);
      opacity: .42;
      pointer-events: none;
    }

    .hero::before {
      width: 520px;
      height: 520px;
      top: -230px;
      left: -130px;
      background: rgb(var(--portal-primary-rgb) / .5);
      animation: drift-one 13s ease-in-out infinite;
    }

    .hero::after {
      width: 470px;
      height: 470px;
      right: -90px;
      top: 58px;
      background: rgb(var(--portal-primary-rgb) / .28);
      animation: drift-two 15s ease-in-out infinite;
    }

    .hero-noise {
      position: absolute;
      inset: 0;
      opacity: .032;
      mix-blend-mode: overlay;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
      background-size: 256px 256px;
    }

    .hero-wave {
      position: absolute;
      left: 0;
      right: 0;
      bottom: -1px;
      display: block;
      width: 100%;
      height: 47px;
      color: #f8fafc;
      pointer-events: none;
    }

    .hero-content {
      position: relative;
      z-index: 2;
      min-width: 0;
    }

    h1 {
      margin: 0 0 16px;
      color: #fff;
      font-size: clamp(34px, 3.4vw, 48px);
      font-weight: 850;
      line-height: 1.08;
      letter-spacing: 0;
    }

    .hero-subtitle {
      max-width: 600px;
      margin: 0 auto 30px;
      color: rgba(255, 255, 255, .83);
      font-size: 18px;
      line-height: 1.5;
    }

    .search-wrap {
      width: 100%;
      max-width: 640px;
      margin: 0 auto 24px;
    }

    .hero-search {
      display: flex;
      align-items: center;
      gap: 4px;
      padding: 6px 6px 6px 8px;
      border-radius: 16px;
      background: rgba(255, 255, 255, .97);
      box-shadow: 0 8px 32px rgba(0, 0, 0, .15), 0 2px 8px rgba(0, 0, 0, .08);
    }

    .hs-field {
      display: flex;
      align-items: center;
      gap: 9px;
      min-width: 0;
      padding: 0 12px;
    }

    .hs-keyword { flex: 1.4; }
    .hs-city { flex: 1; }

    .hs-icon {
      flex-shrink: 0;
      width: 18px;
      height: 18px;
      color: var(--portal-primary);
    }

    .hs-field input,
    .hs-field select {
      min-width: 0;
      width: 100%;
      border: 0;
      outline: 0;
      padding: 15px 0;
      color: var(--ink);
      background: transparent;
      font-size: 15px;
      font-family: inherit;
    }

    .hs-field input::placeholder {
      color: #9ca3af;
    }

    .hs-field select {
      appearance: none;
      -webkit-appearance: none;
      cursor: pointer;
    }

    .hs-divider {
      flex-shrink: 0;
      width: 1px;
      height: 28px;
      background: var(--line);
    }

    .hs-submit {
      flex-shrink: 0;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 14px 22px;
      border: 0;
      border-radius: 12px;
      color: #fff;
      background: var(--portal-primary);
      font-size: 15px;
      font-weight: 700;
      font-family: inherit;
      cursor: pointer;
      transition: filter .2s, transform .2s;
    }

    .hs-submit:hover {
      filter: brightness(1.06);
      transform: translateY(-1px);
    }

    .popular-label {
      margin: 0 0 10px;
      color: rgba(255, 255, 255, .6);
      font-size: 14px;
      font-weight: 600;
    }

    .city-tags {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 9px;
    }

    .city-tags a {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      min-height: 34px;
      padding: 7px 15px;
      border: 1px solid rgba(255, 255, 255, .21);
      border-radius: 999px;
      color: #fff;
      background: rgba(255, 255, 255, .09);
      backdrop-filter: blur(8px);
      font-size: 14px;
      font-weight: 760;
      box-shadow: inset 0 1px rgba(255, 255, 255, .08);
      transition: background .2s, transform .2s;
    }

    .city-tags a:hover {
      background: rgba(255, 255, 255, .18);
      transform: translateY(-1px);
    }

    @media (max-width: 600px) {
      .hero-search {
        flex-wrap: wrap;
      }

      .hs-divider {
        display: none;
      }

      .hs-field {
        flex-basis: 100%;
        padding: 4px 12px;
      }

      .hs-submit {
        flex-basis: 100%;
        justify-content: center;
      }
    }

    .stats-band {
      padding: 26px 0;
      background: #f8fafc;
      border-bottom: 1px solid var(--line-soft);
    }

    .stats-strip {
      display: flex;
      align-items: center;
      justify-content: center;
      flex-wrap: wrap;
      gap: 16px 32px;
      width: min(100% - 48px, 960px);
      margin-inline: auto;
    }

    .stat-item {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .stat-icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      width: 42px;
      height: 42px;
      border-radius: 12px;
      color: var(--portal-primary);
      background: rgb(var(--portal-primary-rgb) / .1);
    }

    .stat-icon-star {
      color: var(--portal-accent);
      background: rgb(245 158 11 / .14);
    }

    .stat-text {
      display: flex;
      flex-direction: column;
      line-height: 1.15;
    }

    .stat-text .trust-value {
      color: var(--ink);
      font-size: 22px;
      font-weight: 850;
    }

    .stat-label {
      color: #94a3b8;
      font-size: 12.5px;
      font-weight: 650;
    }

    .stat-sep {
      width: 1px;
      height: 34px;
      background: var(--line);
    }

    @media (max-width: 620px) {
      .stat-sep {
        display: none;
      }

      /* Mobil: 2x2 hizalı grid (flex-wrap + center kaymasını giderir). */
      .stats-strip {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 22px 12px;
        width: 100%;
        padding-inline: 16px;
      }

      .stat-item {
        justify-content: center;
      }
    }

    @media (max-width: 360px) {
      .stats-strip { grid-template-columns: 1fr; }
      .stat-item { justify-content: flex-start; padding-left: 24px; }
    }

    .section-light {
      padding: 74px 0 72px;
      background: #fff;
    }

    .section-heading {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      gap: 24px;
      margin-bottom: 40px;
    }

    .section-title h2 {
      margin: 0;
      color: var(--ink);
      font-size: 30px;
      line-height: 1.15;
      font-weight: 870;
      letter-spacing: 0;
    }

    .underline {
      width: 41px;
      height: 3px;
      margin-top: 15px;
      border-radius: 3px;
      background: var(--portal-primary);
    }

    .section-title p {
      margin: 13px 0 0;
      color: var(--muted);
      font-size: 16px;
    }

    .all-link {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      color: #005984;
      font-size: 14px;
      font-weight: 760;
      transition: color .2s;
    }

    .all-link:hover {
      color: var(--portal-primary);
    }

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

    .company-card {
      position: relative;
      overflow: hidden;
      border: 1px solid var(--line-soft);
      border-radius: 16px;
      background: #fff;
      box-shadow: 0 1px 3px rgba(0, 0, 0, .06);
      transition: transform .4s var(--ease-spring), box-shadow .4s, border-color .4s;
    }

    /* Full-card click target — text hidden, sits beneath the action buttons. */
    .card-link {
      position: absolute;
      inset: 0;
      z-index: 1;
      border-radius: inherit;
      font-size: 0;
      color: transparent;
      background: transparent;
    }

    .card-link:focus-visible {
      outline: 2px solid var(--portal-primary);
      outline-offset: 2px;
    }

    .company-card:hover {
      border-color: transparent;
      transform: translateY(-8px);
      box-shadow: 0 20px 40px -12px rgba(0, 0, 0, .15);
    }

    .company-image {
      position: relative;
      aspect-ratio: 16 / 10;
      overflow: hidden;
      background: #e2e8f0;
    }

    .company-image img {
      width: 100%;
      height: 100%;
      display: block;
      object-fit: cover;
      transition: transform .5s;
    }

    .company-card:hover .company-image img {
      transform: scale(1.08);
    }

    .company-image::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(to top, rgba(0, 0, 0, .5), rgba(0, 0, 0, .1), transparent);
      pointer-events: none;
    }

    .rating-badge {
      position: absolute;
      z-index: 2;
      right: 12px;
      bottom: 12px;
      display: inline-flex;
      align-items: center;
      gap: 4px;
      padding: 5px 10px;
      border-radius: 8px;
      color: var(--ink);
      background: rgba(255, 255, 255, .92);
      box-shadow: 0 2px 8px rgba(0, 0, 0, .12);
      backdrop-filter: blur(8px);
      font-size: 12px;
      font-weight: 800;
    }

    .rating-badge span:last-child {
      color: #94a3b8;
      font-weight: 600;
    }

    .card-content {
      padding: 20px;
    }

    .card-content h3 {
      margin: 0 0 7px;
      overflow: hidden;
      color: var(--ink);
      font-size: 16px;
      font-weight: 800;
      line-height: 1.28;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .stars {
      display: flex;
      align-items: center;
      gap: 2px;
      margin-bottom: 9px;
      color: var(--portal-accent);
    }

    .stars .muted-star {
      color: #d1d5db;
    }

    .review-count {
      margin-left: 8px;
      color: #94a3b8;
      font-size: 12px;
      font-weight: 500;
    }

    .address,
    .time {
      display: flex;
      align-items: center;
      gap: 6px;
      overflow: hidden;
      color: #94a3b8;
      font-size: 12px;
      line-height: 1.5;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .actions {
      position: relative;
      z-index: 2;
      display: flex;
      gap: 8px;
      margin-top: 16px;
      padding-top: 13px;
      border-top: 1px solid var(--line-soft);
    }

    .action-btn {
      display: inline-flex;
      flex: 1;
      align-items: center;
      justify-content: center;
      gap: 7px;
      min-height: 41px;
      padding: 8px 12px;
      border: 1px solid var(--line);
      border-radius: 10px;
      color: #475569;
      background: #fff;
      font-size: 13px;
      font-weight: 750;
      transition: transform .25s var(--ease-spring), background .25s, border-color .25s, color .25s;
    }

    .action-btn:hover {
      color: var(--portal-primary);
      border-color: rgb(var(--portal-primary-rgb) / .4);
      background: rgb(var(--portal-primary-rgb) / .08);
      transform: translateY(-1px);
    }

    .action-btn.primary {
      border: 0;
      color: #fff;
      background: linear-gradient(135deg, var(--portal-primary), var(--portal-primary-hover));
      box-shadow: 0 2px 8px rgb(var(--portal-primary-rgb) / .25);
    }

    .action-btn.primary:hover {
      color: #fff;
      box-shadow: 0 4px 16px rgb(var(--portal-primary-rgb) / .35);
    }

    .discover-list {
      width: min(100% - 48px, 1180px);
      margin: 72px auto 19px;
      border: 1px solid #d8dee8;
      border-radius: 3px;
      overflow: hidden;
      background: #fff;
    }

    .discover-list h3 {
      margin: 0;
      padding: 15px 20px;
      background: #f8fafc;
      color: #334155;
      font-size: 18px;
      font-weight: 770;
    }

    .discover-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      min-height: 58px;
      padding: 0 18px 0 20px;
      border-top: 1px solid #edf2f7;
      color: #1f2937;
      font-size: 16px;
    }

    .discover-row svg {
      color: #9aa3ad;
    }

    /* Beliebte Städte grid (replaces the old "Mehr entdecken" list) */
    .cities-discover {
      width: min(100% - 48px, 1224px);
      margin: 60px auto 0;
    }

    .cities-discover-title {
      margin: 0 0 20px;
      color: var(--ink);
      font-size: 22px;
      font-weight: 800;
    }

    .cities-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
      gap: 12px;
    }

    @media (max-width: 600px) {
      .cities-grid {
        grid-template-columns: 1fr 1fr;
      }
    }

    .city-tile {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: 4px;
      padding: 14px 16px;
      border: 1px solid var(--line);
      border-radius: 12px;
      background: #fff;
      transition: border-color .2s, transform .2s, box-shadow .2s;
    }

    .city-tile:hover {
      border-color: rgb(var(--portal-primary-rgb) / .5);
      transform: translateY(-2px);
      box-shadow: 0 10px 24px -12px rgb(var(--portal-primary-rgb) / .35);
    }

    .city-tile-name {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      overflow: hidden;
      color: var(--ink);
      font-size: 15px;
      font-weight: 700;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .city-tile-name svg {
      flex-shrink: 0;
      color: var(--portal-primary);
    }

    .city-tile-count {
      flex-shrink: 0;
      color: var(--muted);
      font-size: 12.5px;
      font-weight: 600;
      white-space: nowrap;
    }

    .claim-section {
      position: relative;
      overflow: hidden;
      margin-top: 0;
      padding: 76px 0;
      color: #fff;
      background:
        radial-gradient(circle at 88% 12%, rgba(255, 255, 255, .14), transparent 42%),
        linear-gradient(135deg, var(--portal-primary), var(--portal-secondary));
    }

    .claim-inner {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: 1.25fr .9fr;
      align-items: center;
      gap: 48px;
      width: min(100% - 48px, 1224px);
      margin-inline: auto;
    }

    .claim-glow {
      position: absolute;
      left: -80px;
      bottom: -120px;
      width: 320px;
      height: 320px;
      border-radius: 999px;
      background: rgba(255, 255, 255, .1);
      filter: blur(40px);
      pointer-events: none;
    }

    .claim-paw {
      position: absolute;
      right: 26px;
      bottom: -22px;
      color: rgba(255, 255, 255, .08);
      pointer-events: none;
    }

    .claim-paw svg {
      width: 150px;
      height: 150px;
    }

    .claim-text {
      position: relative;
      z-index: 1;
    }

    .claim-section h2 {
      margin: 0 0 12px;
      font-size: 30px;
      line-height: 1.15;
      font-weight: 850;
      letter-spacing: 0;
    }

    .claim-section p {
      margin: 0;
      color: rgba(255, 255, 255, .85);
      font-size: 16.5px;
      line-height: 1.55;
    }

    .claim-points {
      list-style: none;
      margin: 22px 0 0;
      padding: 0;
      display: flex;
      flex-direction: column;
      gap: 11px;
    }

    .claim-points li {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      color: rgba(255, 255, 255, .92);
      font-size: 15px;
      font-weight: 600;
    }

    .claim-points svg {
      flex-shrink: 0;
      color: #6ee7b7;
    }

    .claim-action {
      position: relative;
      z-index: 1;
      display: flex;
      flex-direction: column;
      gap: 14px;
      padding: 26px;
      border-radius: 20px;
      background: rgba(255, 255, 255, .97);
      box-shadow: 0 20px 45px -20px rgba(0, 0, 0, .4);
    }

    .claim-badge {
      align-self: flex-start;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 5px 11px;
      border-radius: 999px;
      color: var(--portal-primary);
      background: rgb(var(--portal-primary-rgb) / .12);
      font-size: 12.5px;
      font-weight: 800;
    }

    .claim-actions {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .claim-button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 9px;
      min-height: 50px;
      padding: 12px 22px;
      border-radius: 12px;
      font-size: 15px;
      font-weight: 800;
      transition: filter .2s, background .2s;
    }

    .claim-button.light {
      color: #fff;
      background: var(--portal-primary);
    }

    .claim-button.light:hover {
      filter: brightness(1.06);
    }

    .claim-button.ghost {
      color: var(--portal-primary);
      border: 1px solid var(--line);
      background: #fff;
    }

    .claim-button.ghost:hover {
      background: rgb(var(--portal-primary-rgb) / .06);
    }

    .trust-line {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      color: var(--muted);
      font-size: 13px;
      font-weight: 600;
    }

    @media (max-width: 760px) {
      .claim-inner {
        grid-template-columns: 1fr;
        gap: 26px;
        padding: 38px 26px;
      }

      .claim-paw {
        display: none;
      }
    }

    .footer-container {
      width: min(100% - 48px, 1828px);
      margin-inline: auto;
    }

    .site-footer {
      color: #fff;
      background: #0f172a;
    }

    .footer-newsletter {
      padding: 40px 0;
      background: var(--portal-primary);
    }

    .footer-newsletter-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 40px;
    }

    .footer-newsletter h3 {
      margin: 0 0 6px;
      color: #fff;
      font-size: 18px;
      line-height: 1.2;
      font-weight: 850;
    }

    .footer-newsletter p {
      margin: 0;
      color: rgba(255, 255, 255, .72);
      font-size: 14px;
      line-height: 1.45;
    }

    .newsletter-form {
      display: flex;
      align-items: center;
      gap: 10px;
      width: min(100%, 560px);
    }

    .newsletter-form input {
      flex: 1;
      min-width: 0;
      height: 48px;
      padding: 0 20px;
      border: 1px solid rgba(255, 255, 255, .28);
      border-radius: 12px;
      color: #fff;
      background: rgba(255, 255, 255, .2);
      outline: 0;
      font-size: 15px;
      transition: border-color .2s, box-shadow .2s, background .2s;
    }

    .newsletter-form input::placeholder {
      color: rgba(255, 255, 255, .62);
    }

    .newsletter-form input:focus {
      border-color: rgba(255, 255, 255, .62);
      background: rgba(255, 255, 255, .26);
      box-shadow: 0 0 0 3px rgba(255, 255, 255, .15);
    }

    .newsletter-form button {
      flex: 0 0 auto;
      height: 48px;
      min-width: 138px;
      border: 0;
      border-radius: 12px;
      color: #005984;
      background: #fff;
      cursor: pointer;
      font-size: 15px;
      font-weight: 750;
      transition: transform .2s var(--ease-spring), box-shadow .2s;
    }

    .newsletter-form button:hover {
      transform: translateY(-1px);
      box-shadow: 0 8px 18px rgba(0, 0, 0, .16);
    }

    .footer-main {
      padding: 60px 0 40px;
      background: #0f172a;
    }

    .footer-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 64px;
    }

    .footer-heading {
      margin: 0 0 16px;
      color: #fff;
      font-size: 14px;
      line-height: 1.2;
      font-weight: 750;
      letter-spacing: .05em;
      text-transform: uppercase;
    }

    .footer-list {
      display: grid;
      gap: 23px;
      margin: 0;
      padding: 0;
      list-style: none;
    }

    .footer-link {
      color: #94a3b8;
      font-size: 14px;
      line-height: 1.25;
      transition: color .2s;
    }

    .footer-link:hover {
      color: #fff;
    }

    .footer-bottom {
      padding: 16px 0;
      color: #64748b;
      background: #020617;
      border-top: 1px solid rgba(255, 255, 255, .05);
      font-size: 13px;
    }

    .footer-bottom-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .footer-bottom p {
      margin: 0;
    }

    .footer-heart {
      color: #f87171;
    }

    /* Cookie banner styles live solely in public/css/site-footer.css. */

    .star-icon {
      width: 16px;
      height: 16px;
      fill: currentColor;
    }

    .icon-sm {
      width: 16px;
      height: 16px;
    }

    @keyframes drift-one {
      0%,
      100% {
        transform: translate3d(0, 0, 0) scale(1);
      }
      50% {
        transform: translate3d(56px, 42px, 0) scale(1.06);
      }
    }

    @keyframes drift-two {
      0%,
      100% {
        transform: translate3d(0, 0, 0) scale(1);
      }
      50% {
        transform: translate3d(-52px, 38px, 0) scale(1.08);
      }
    }

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

    @media (max-width: 980px) {
      .container {
        width: min(100% - 32px, 1224px);
      }

      .header-inner {
        padding-inline: 16px;
      }

      .nav,
      .header-actions {
        display: none;
      }

      .menu-button {
        display: inline-flex;
      }

      .top-spacer,
      .header-inner {
        height: 72px;
      }

      .hero {
        min-height: 417px;
        padding: 50px 0 65px;
      }

      h1 {
        margin-bottom: 16px;
        font-size: 25px;
        line-height: 1.24;
      }

      .hero-subtitle {
        margin-bottom: 29px;
        font-size: 16px;
      }

      .search-wrap {
        margin-bottom: 27px;
      }

      .hero-search {
        border-radius: 16px;
      }

      .hero-search input {
        padding: 15px 20px;
        font-size: 16px;
      }

      .hero-search button {
        width: 60px;
      }

      .popular-label {
        margin-bottom: 9px;
      }

      .city-tags {
        flex-wrap: nowrap;
        justify-content: flex-start;
        overflow-x: auto;
        margin-inline: -16px;
        padding-inline: 16px;
        padding-bottom: 2px;
        scrollbar-width: none;
      }

      .city-tags::-webkit-scrollbar {
        display: none;
      }

      .city-tags a {
        flex: 0 0 auto;
      }

      .stats-band {
        padding: 58px 0 39px;
      }

      .stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
      }

      .trust-card {
        min-height: 128px;
        padding: 16px 12px;
      }

      .trust-icon {
        width: 40px;
        height: 40px;
        margin-bottom: 8px;
      }

      .trust-value {
        font-size: 24px;
      }

      .trust-label {
        font-size: 11px;
      }

      .section-light {
        min-height: 1032px;
        padding-top: 74px;
      }

      .section-heading {
        margin-bottom: 16px;
      }

      .all-link {
        display: none;
      }

      .section-title h2 {
        font-size: 28px;
      }

      .cards-grid {
        display: flex;
        gap: 16px;
        overflow-x: auto;
        margin-inline: -16px;
        padding: 0 16px 12px;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
      }

      .cards-grid::-webkit-scrollbar {
        display: none;
      }

      .company-card {
        flex: 0 0 min(80vw, 320px);
        scroll-snap-align: start;
      }

      .discover-list {
        width: min(100% - 32px, 1180px);
        margin-top: 48px;
      }

      .claim-section {
        padding: 56px 0;
      }

      .claim-section h2 {
        font-size: 24px;
      }

      .footer-newsletter-inner,
      .footer-bottom-inner {
        flex-direction: column;
        align-items: stretch;
        text-align: center;
      }

      .newsletter-form {
        width: 100%;
      }

      .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 42px;
      }
    }

    @media (max-width: 520px) {
      .brand {
        font-size: 19px;
      }

      .hero {
        padding-top: 48px;
      }

      .hero-content {
        width: calc(100% - 32px);
      }

      .stats-band {
        padding-top: 58px;
      }

      .section-light {
        padding-top: 74px;
      }

      .footer-container {
        width: min(100% - 32px, 1828px);
      }

      .footer-newsletter {
        padding: 32px 0;
      }

      .footer-newsletter h3 {
        font-size: 18px;
      }

      .footer-newsletter p,
      .footer-link,
      .footer-bottom {
        font-size: 14px;
      }

      .newsletter-form {
        flex-direction: column;
      }

      .newsletter-form input,
      .newsletter-form button {
        width: 100%;
        height: 48px;
      }

      .footer-main {
        padding: 40px 0 32px;
      }

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

      .footer-heading {
        margin-bottom: 16px;
        font-size: 14px;
      }

      .footer-list {
        gap: 14px;
      }
    }

/* ── Home SEO content section (keyword-rich H2 blocks) ── */
.home-seo-content {
  padding: 56px 0;
  background: #fff;
}
.home-seo-content .container {
  max-width: 900px;
}
.home-seo-content h2 {
  font-size: 22px;
  font-weight: 700;
  color: #17467b;
  margin: 28px 0 10px;
}
.home-seo-content h2:first-child {
  margin-top: 0;
}
.home-seo-content p {
  font-size: 16px;
  line-height: 1.7;
  color: #444;
  margin: 0;
}
@media (max-width: 640px) {
  .home-seo-content { padding: 36px 0; }
  .home-seo-content h2 { font-size: 19px; }
  .home-seo-content p { font-size: 15px; }
}