html,
    body {
      max-width: 100%;
      overflow-x: hidden;
    }

    [x-cloak] {
      display: none !important;
    }

    #main {
      max-width: 100%;
      overflow-x: clip;
    }

    section .grid > * {
      min-width: 0;
    }

    .home-hero-premium {
      position: relative;
      overflow: hidden;
      background:
        radial-gradient(circle at 12% 18%, rgba(56, 189, 248, 0.16), transparent 26rem),
        radial-gradient(circle at 88% 84%, rgba(14, 165, 233, 0.08), transparent 24rem),
        linear-gradient(135deg, #081222 0%, #0b1730 52%, #0d1c35 100%);
      color: #f8fbff;
    }

    .home-hero-premium::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 78% 18%, rgba(59, 130, 246, 0.10), transparent 26rem),
        linear-gradient(180deg, rgba(6, 11, 23, 0.12), rgba(6, 11, 23, 0.04));
      pointer-events: none;
    }

    .home-hero-shell {
      position: relative;
      z-index: 1;
      display: grid;
      gap: 2.5rem;
      align-items: center;
    }

    .home-hero-copy {
      max-width: 41rem;
    }

    .home-hero-topline {
      display: flex;
      flex-wrap: wrap;
      gap: 0.75rem;
      align-items: center;
    }

    .home-hero-pill {
      display: inline-flex;
      align-items: center;
      gap: 0.55rem;
      padding: 0.72rem 1rem;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, 0.14);
      background: rgba(255, 255, 255, 0.09);
      color: #eff6ff;
      font-size: 0.9rem;
      font-weight: 700;
      line-height: 1;
      backdrop-filter: blur(12px);
      white-space: nowrap;
    }

    .home-hero-pill--cities {
      color: rgba(239, 246, 255, 0.92);
      font-size: 0.84rem;
      font-weight: 600;
    }

    .home-hero-pill-dot {
      width: 0.48rem;
      height: 0.48rem;
      border-radius: 999px;
      background: #5eead4;
      box-shadow: 0 0 0 0.22rem rgba(94, 234, 212, 0.14);
    }

    .home-hero-title {
      margin-top: 1.2rem;
      max-width: 15.2ch;
      font-size: clamp(2.15rem, 3.35vw, 3.72rem);
      line-height: 1.05;
      letter-spacing: -0.052em;
      font-weight: 900;
      color: #ffffff;
      text-wrap: balance;
    }

    .home-hero-title span {
      display: block;
      margin-top: 0.38rem;
      font-size: 0.36em;
      line-height: 1.12;
      letter-spacing: -0.025em;
      color: rgba(220, 231, 243, 0.72);
    }

    .home-hero-lead {
      margin-top: 1rem;
      max-width: 38.5rem;
      font-size: clamp(1rem, 1.24vw, 1.12rem);
      line-height: 1.72;
      color: rgba(226, 236, 248, 0.92);
    }

    .home-hero-trustline {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 0.42rem 0.58rem;
      margin-top: 1rem;
      font-size: 0.9rem;
      font-weight: 700;
      line-height: 1.55;
      color: rgba(226, 236, 248, 0.9);
    }

    .home-hero-segments {
      display: flex;
      flex-wrap: wrap;
      gap: 0.7rem;
      margin-top: 1.2rem;
      max-width: 46rem;
    }

    .home-hero-segment {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.55rem;
      min-height: 2.5rem;
      padding: 0.66rem 0.88rem;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, 0.12);
      background: rgba(255, 255, 255, 0.08);
      color: #eff6ff;
      text-decoration: none;
      font-size: 0.88rem;
      font-weight: 700;
      line-height: 1;
      transition: transform 160ms ease, background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
    }

    .home-hero-segment:hover,
    .home-hero-segment:focus-visible {
      transform: translateY(-1px);
      background: rgba(255, 255, 255, 0.13);
      border-color: rgba(255, 255, 255, 0.2);
      box-shadow: 0 12px 26px rgba(2, 6, 23, 0.18);
      outline: none;
    }

    .home-hero-segment.is-active {
      background: rgba(56, 189, 248, 0.18);
      border-color: rgba(125, 211, 252, 0.36);
      color: #ffffff;
      box-shadow: 0 14px 30px rgba(14, 116, 144, 0.22);
    }

    .home-hero-segment-icon {
      display: inline-flex;
      width: 1.6rem;
      height: 1.6rem;
      align-items: center;
      justify-content: center;
      border-radius: 999px;
      font-size: 0.86rem;
      flex: 0 0 auto;
    }

    .home-hero-segment-title {
      display: flex;
      align-items: center;
      gap: 0.45rem;
      font-size: 0.92rem;
      font-weight: 800;
      line-height: 1.25;
      color: #ffffff;
    }

    .home-hero-segment-title i {
      color: #93c5fd;
      font-size: 1rem;
    }

    .home-hero-segment-copy {
      display: none;
    }

    .home-hero-actions {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 0.85rem;
      margin-top: 1.45rem;
    }

    .home-hero-link {
      display: inline-flex;
      align-items: center;
      gap: 0.45rem;
      width: fit-content;
      color: #fde68a;
      font-size: 0.9rem;
      font-weight: 800;
      line-height: 1.2;
      text-decoration: none;
      border-bottom: 1px solid rgba(253, 230, 138, 0.85);
      padding-bottom: 0.1rem;
    }

    .home-hero-link-row {
      margin-top: 0.9rem;
    }

        .home-hero-link:hover,
    .home-hero-link:focus-visible {
      color: #ffffff;
      border-bottom-color: rgba(255, 255, 255, 0.92);
      outline: none;
    }

    .home-hero-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.55rem;
      min-height: 3.35rem;
      padding: 0.9rem 1.35rem;
      border-radius: 1rem;
      font-size: 0.95rem;
      font-weight: 800;
      text-decoration: none;
      white-space: nowrap;
      box-shadow: 0 16px 34px rgba(15, 23, 42, 0.18);
      transition: transform 160ms ease, background-color 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
    }

    .home-hero-btn:hover,
    .home-hero-btn:focus-visible {
      transform: translateY(-2px);
      outline: none;
    }

    .home-hero-btn--primary {
      background: linear-gradient(180deg, #3b82f6 0%, #2563eb 100%);
      color: #ffffff;
      box-shadow: 0 18px 38px rgba(37, 99, 235, 0.28);
    }

    .home-hero-btn--primary:hover,
    .home-hero-btn--primary:focus-visible {
      background: linear-gradient(180deg, #5291ff 0%, #2d6df1 100%);
    }

    .home-hero-btn--secondary {
      border: 1px solid rgba(255, 255, 255, 0.16);
      background: rgba(255, 255, 255, 0.08);
      color: #ffffff;
      backdrop-filter: blur(10px);
      box-shadow: 0 16px 34px rgba(2, 6, 23, 0.22);
    }

    .home-hero-btn--secondary:hover,
    .home-hero-btn--secondary:focus-visible {
      background: rgba(255, 255, 255, 0.14);
      border-color: rgba(255, 255, 255, 0.22);
    }

    .home-hero-meta {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 0.7rem;
      margin-top: 1.1rem;
      max-width: 46rem;
    }

    .home-hero-stat {
      min-height: 7.3rem;
      padding: 0.95rem 1rem;
      border-radius: 1.2rem;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.06));
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }

    .home-hero-stat-head {
      display: flex;
      align-items: center;
      gap: 0.58rem;
    }

    .home-hero-stat-icon {
      display: inline-flex;
      width: auto;
      height: auto;
      align-items: center;
      justify-content: center;
      border-radius: 0;
      font-size: 1.05rem;
      flex: 0 0 auto;
    }

    .home-hero-stat-icon--emerald {
      color: #6ee7b7;
    }

    .home-hero-stat-icon--amber {
      color: #fcd34d;
    }

    .home-hero-stat-icon--sky {
      color: #93c5fd;
    }

    .home-hero-stat strong {
      font-size: 0.88rem;
      font-weight: 800;
      line-height: 1.2;
      color: #ffffff;
    }

    .home-hero-stat span {
      display: block;
      margin-top: 0.35rem;
      font-size: 0.8rem;
      line-height: 1.45;
      color: rgba(220, 231, 243, 0.84);
    }

    .home-hero-visual {
      position: relative;
      min-height: 0;
      padding: 0.8rem;
      margin-top: 0.35rem;
      border-radius: 1.9rem;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.05));
      box-shadow: 0 22px 54px rgba(3, 11, 23, 0.26);
      overflow: hidden;
    }

    .home-hero-media {
      position: relative;
      min-height: 18.4rem;
      border-radius: 1.45rem;
      overflow: hidden;
      background: #0f172a;
    }

    .home-hero-media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center 42%;
      transform: scale(1.01);
    }

    .home-hero-media::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(8, 15, 28, 0.04), rgba(8, 15, 28, 0.26));
      pointer-events: none;
    }

    .home-hero-panel {
      display: grid;
      grid-template-columns: 1fr;
      gap: 0.85rem;
      margin-top: -1rem;
      padding-inline: 0.8rem;
      position: relative;
      z-index: 2;
    }

    .home-hero-panel-card {
      padding: 1rem 1.05rem;
      border-radius: 1.35rem;
      background: rgba(255, 255, 255, 0.94);
      border: 1px solid rgba(148, 163, 184, 0.16);
      box-shadow: 0 16px 34px rgba(15, 23, 42, 0.12);
      color: #0f172a;
    }

    .home-hero-panel-card--wide {
      grid-column: 1 / -1;
    }

    .home-hero-panel-label {
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      color: #1d4ed8;
      font-size: 0.74rem;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.06em;
    }

    .home-hero-panel-title {
      margin-top: 0.35rem;
      font-size: 1rem;
      font-weight: 800;
      line-height: 1.3;
      color: #0f172a;
    }

    .home-hero-panel-copy {
      margin-top: 0.35rem;
      font-size: 0.86rem;
      line-height: 1.5;
      color: #475569;
    }

    .home-hero-calc-head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 0.9rem;
    }

    .home-hero-calc-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 0.75rem;
      margin-top: 0.8rem;
    }

    .home-hero-calc-field {
      display: block;
    }

    .home-hero-calc-field span {
      display: block;
      margin-bottom: 0.35rem;
      font-size: 0.76rem;
      font-weight: 800;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: #475569;
    }

    .home-hero-calc-select {
      width: 100%;
      min-height: 3rem;
      border-radius: 0.95rem;
      border: 1px solid #dbe5f0;
      background: #ffffff;
      color: #0b1220;
      padding: 0.78rem 0.92rem;
      font-size: 0.94rem;
      line-height: 1.4;
      outline: none;
      transition: border-color 160ms ease, box-shadow 160ms ease;
    }

    .home-hero-calc-select:focus {
      border-color: rgba(47, 158, 219, 0.55);
      box-shadow: 0 0 0 4px rgba(47, 158, 219, 0.12);
    }

    .home-hero-calc-actions {
      display: flex;
      flex-direction: column;
      align-items: stretch;
      gap: 0.6rem;
      margin-top: 0.8rem;
    }

    .home-hero-calc-actions .home-hero-btn {
      min-height: 3rem;
      width: 100%;
      padding-inline: 1.05rem;
    }

    .home-hero-calc-note {
      font-size: 0.75rem;
      line-height: 1.4;
      color: #1d4ed8;
      font-weight: 800;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      text-align: center;
    }

    .home-hero-mini-proof {
      display: none;
    }

    .hero-compare-alt {
      position: relative;
      overflow: hidden;
      background:
        radial-gradient(circle at top left, rgba(47, 158, 219, 0.16), transparent 28rem),
        radial-gradient(circle at bottom right, rgba(53, 193, 107, 0.12), transparent 24rem),
        #f6f8fb;
      color: #0b1220;
    }

    .hero-compare-shell {
      display: grid;
      gap: 2rem;
      align-items: center;
    }

    .hero-compare-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 0.55rem;
      padding: 0.72rem 1rem;
      border-radius: 999px;
      background: rgba(47, 158, 219, 0.1);
      border: 1px solid rgba(47, 158, 219, 0.12);
      color: #1d4ed8;
      font-size: 0.86rem;
      font-weight: 800;
      line-height: 1;
    }

    .hero-compare-title {
      margin-top: 1rem;
      max-width: 12ch;
      font-size: clamp(1.9rem, 3.6vw, 3.6rem);
      line-height: 1.02;
      letter-spacing: -0.05em;
      font-weight: 900;
      color: #0b1220;
      text-wrap: balance;
    }

    .hero-compare-title span {
      display: block;
      color: #334155;
    }

    .hero-compare-lead {
      margin-top: 1rem;
      max-width: 41rem;
      font-size: 1.02rem;
      line-height: 1.7;
      color: #334155;
    }

    .hero-compare-tabs {
      display: flex;
      flex-wrap: wrap;
      gap: 0.7rem;
      margin-top: 1.3rem;
    }

    .hero-compare-tab {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 2.5rem;
      padding: 0.72rem 0.95rem;
      border-radius: 999px;
      border: 1px solid #dbe5f0;
      background: #ffffff;
      color: #334155;
      font-size: 0.93rem;
      font-weight: 700;
      line-height: 1;
      transition: transform 160ms ease, border-color 160ms ease, background-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
      box-shadow: 0 6px 18px rgba(15, 23, 42, 0.05);
    }

    .hero-compare-tab:hover,
    .hero-compare-tab:focus-visible {
      transform: translateY(-1px);
      border-color: rgba(47, 158, 219, 0.4);
      color: #0f172a;
      outline: none;
    }

    .hero-compare-tab.is-active {
      background: rgba(47, 158, 219, 0.1);
      border-color: rgba(47, 158, 219, 0.35);
      color: #1d4ed8;
      box-shadow: 0 10px 24px rgba(47, 158, 219, 0.12);
    }

    .hero-compare-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 0.75rem;
      margin-top: 1.35rem;
    }

    .hero-compare-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.55rem;
      min-height: 3rem;
      padding: 0.85rem 1.25rem;
      border-radius: 1rem;
      font-size: 0.98rem;
      font-weight: 700;
      text-decoration: none;
      transition: transform 160ms ease, background-color 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
    }

    .hero-compare-btn:hover,
    .hero-compare-btn:focus-visible {
      transform: translateY(-1px);
      outline: none;
    }

    .hero-compare-btn--primary {
      background: #2f9edb;
      color: #ffffff;
      box-shadow: 0 14px 30px rgba(47, 158, 219, 0.2);
    }

    .hero-compare-btn--primary:hover,
    .hero-compare-btn--primary:focus-visible {
      background: #238cc6;
    }

    .hero-compare-btn--secondary {
      background: #ffffff;
      border: 1px solid #dbe5f0;
      color: #0b1220;
    }

    .hero-compare-btn--secondary:hover,
    .hero-compare-btn--secondary:focus-visible {
      border-color: #2f9edb;
      color: #1d4ed8;
    }

    .hero-compare-proof {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 0.8rem;
      margin-top: 1.4rem;
      max-width: 46rem;
    }

    .hero-compare-proof-item {
      display: flex;
      align-items: flex-start;
      gap: 0.7rem;
      padding: 0.95rem 1rem;
      border-radius: 1.1rem;
      background: rgba(255, 255, 255, 0.9);
      border: 1px solid #e2e8f0;
      box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
    }

    .hero-compare-proof-icon {
      display: inline-flex;
      width: 2.25rem;
      height: 2.25rem;
      align-items: center;
      justify-content: center;
      border-radius: 999px;
      background: rgba(47, 158, 219, 0.12);
      color: #2f9edb;
      flex: 0 0 auto;
    }

    .hero-compare-proof-item strong {
      display: block;
      font-size: 0.9rem;
      font-weight: 800;
      line-height: 1.3;
      color: #0b1220;
    }

    .hero-compare-proof-item span {
      display: block;
      margin-top: 0.2rem;
      font-size: 0.79rem;
      line-height: 1.45;
      color: #475569;
    }

    .hero-compare-visual {
      position: relative;
    }

    .hero-compare-media {
      position: relative;
      overflow: hidden;
      min-height: 24rem;
      border-radius: 2rem;
      border: 1px solid #dbe5f0;
      box-shadow: 0 24px 70px rgba(15, 23, 42, 0.1);
      background: #0f172a;
    }

    .hero-compare-media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center 42%;
    }

    .hero-compare-media::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(8, 18, 32, 0.1), rgba(8, 18, 32, 0.46));
      pointer-events: none;
    }

    .hero-compare-dashboard {
      position: absolute;
      top: 1rem;
      right: 1rem;
      width: min(18rem, calc(100% - 2rem));
      padding: 1rem;
      border-radius: 1.4rem;
      background: rgba(255, 255, 255, 0.94);
      border: 1px solid rgba(148, 163, 184, 0.16);
      box-shadow: 0 18px 42px rgba(15, 23, 42, 0.16);
      z-index: 1;
    }

    .hero-compare-dashboard-label,
    .hero-compare-quick-label {
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      font-size: 0.72rem;
      font-weight: 800;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: #1d4ed8;
    }

    .hero-compare-dashboard-title,
    .hero-compare-quick-title {
      margin-top: 0.45rem;
      font-size: 1rem;
      font-weight: 800;
      line-height: 1.3;
      color: #0b1220;
    }

    .hero-compare-dashboard-row {
      display: flex;
      flex-wrap: wrap;
      gap: 0.5rem;
      align-items: center;
      margin-top: 0.75rem;
      color: #475569;
      font-size: 0.82rem;
      line-height: 1.45;
    }

    .hero-compare-status {
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      padding: 0.35rem 0.55rem;
      border-radius: 999px;
      background: rgba(53, 193, 107, 0.14);
      color: #137a3e;
      font-weight: 700;
    }

    .hero-compare-quick {
      margin-top: -2.1rem;
      margin-left: auto;
      width: min(100%, 24rem);
      padding: 1.05rem;
      border-radius: 1.6rem;
      background: rgba(255, 255, 255, 0.96);
      border: 1px solid #dbe5f0;
      box-shadow: 0 22px 54px rgba(15, 23, 42, 0.12);
      position: relative;
      z-index: 2;
    }

    .hero-compare-quick-grid {
      display: grid;
      gap: 0.75rem;
      margin-top: 0.9rem;
    }

    .hero-compare-field span {
      display: block;
      margin-bottom: 0.35rem;
      font-size: 0.76rem;
      font-weight: 800;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: #475569;
    }

    .hero-compare-select {
      width: 100%;
      min-height: 2.95rem;
      border-radius: 0.95rem;
      border: 1px solid #dbe5f0;
      background: #ffffff;
      color: #0b1220;
      padding: 0.75rem 0.9rem;
      font-size: 0.94rem;
      line-height: 1.4;
      outline: none;
      transition: border-color 160ms ease, box-shadow 160ms ease;
    }

    .hero-compare-select:focus {
      border-color: rgba(47, 158, 219, 0.55);
      box-shadow: 0 0 0 4px rgba(47, 158, 219, 0.12);
    }

    .hero-compare-note {
      margin-top: 0.8rem;
      font-size: 0.8rem;
      line-height: 1.5;
      color: #64748b;
    }

    .hero-hybrid-alt {
      position: relative;
      overflow: hidden;
      background:
        radial-gradient(circle at top left, rgba(47, 158, 219, 0.13), transparent 30rem),
        radial-gradient(circle at 100% 20%, rgba(53, 193, 107, 0.1), transparent 24rem),
        linear-gradient(180deg, #f8fbff 0%, #eef5fb 100%);
      color: #0b1220;
    }

    .hero-hybrid-shell {
      display: grid;
      gap: 2rem;
      align-items: center;
    }

    .hero-hybrid-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 0.6rem;
      padding: 0.74rem 1rem;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.92);
      border: 1px solid rgba(47, 158, 219, 0.12);
      box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
      color: #0f172a;
      font-size: 0.86rem;
      font-weight: 800;
      line-height: 1;
    }

    .hero-hybrid-dot {
      width: 0.58rem;
      height: 0.58rem;
      border-radius: 999px;
      background: #35c16b;
      box-shadow: 0 0 0 0.28rem rgba(53, 193, 107, 0.16), 0 0 18px rgba(53, 193, 107, 0.44);
      animation: hero-hybrid-pulse 2.1s ease-in-out infinite;
      flex: 0 0 auto;
    }

    @keyframes hero-hybrid-pulse {
      0%, 100% {
        transform: scale(1);
        box-shadow: 0 0 0 0.28rem rgba(53, 193, 107, 0.16), 0 0 18px rgba(53, 193, 107, 0.44);
      }
      50% {
        transform: scale(1.06);
        box-shadow: 0 0 0 0.4rem rgba(53, 193, 107, 0.11), 0 0 24px rgba(53, 193, 107, 0.52);
      }
    }

    .hero-hybrid-title {
      margin-top: 1rem;
      max-width: 11.5ch;
      font-size: clamp(1.7rem, 3vw, 2.72rem);
      line-height: 1.02;
      letter-spacing: -0.05em;
      font-weight: 900;
      color: #0b1220;
      text-wrap: balance;
    }

    .hero-hybrid-title span {
      display: block;
      margin-top: 0.28rem;
      font-size: 0.43em;
      line-height: 1.14;
      letter-spacing: -0.02em;
      color: #64748b;
    }

    .hero-hybrid-lead {
      margin-top: 0.95rem;
      max-width: 38rem;
      font-size: 1rem;
      line-height: 1.68;
      color: #334155;
    }

    .hero-hybrid-tabs {
      display: flex;
      flex-wrap: wrap;
      gap: 0.7rem;
      margin-top: 1.25rem;
    }

    .hero-hybrid-tab {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 2.6rem;
      padding: 0.72rem 1rem;
      border-radius: 999px;
      border: 1px solid #dbe5f0;
      background: rgba(255, 255, 255, 0.86);
      color: #334155;
      font-size: 0.93rem;
      font-weight: 700;
      line-height: 1;
      box-shadow: 0 8px 22px rgba(15, 23, 42, 0.04);
      transition: transform 160ms ease, border-color 160ms ease, color 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
    }

    .hero-hybrid-tab:hover,
    .hero-hybrid-tab:focus-visible {
      transform: translateY(-1px);
      border-color: rgba(47, 158, 219, 0.36);
      color: #0f172a;
      outline: none;
    }

    .hero-hybrid-tab.is-active {
      background: rgba(47, 158, 219, 0.1);
      border-color: rgba(47, 158, 219, 0.32);
      color: #1d4ed8;
      box-shadow: 0 12px 26px rgba(47, 158, 219, 0.1);
    }

    .hero-hybrid-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 0.8rem;
      margin-top: 1.35rem;
    }

    .hero-hybrid-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.55rem;
      min-height: 3.15rem;
      padding: 0.88rem 1.28rem;
      border-radius: 1rem;
      font-size: 0.96rem;
      font-weight: 800;
      text-decoration: none;
      transition: transform 160ms ease, background-color 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
    }

    .hero-hybrid-btn:hover,
    .hero-hybrid-btn:focus-visible {
      transform: translateY(-1px);
      outline: none;
    }

    .hero-hybrid-btn--primary {
      background: linear-gradient(180deg, #2f9edb 0%, #247fb2 100%);
      color: #ffffff;
      box-shadow: 0 14px 30px rgba(47, 158, 219, 0.2);
    }

    .hero-hybrid-btn--primary:hover,
    .hero-hybrid-btn--primary:focus-visible {
      background: linear-gradient(180deg, #3aa8e3 0%, #2387be 100%);
    }

    .hero-hybrid-btn--secondary {
      background: #ffffff;
      border: 1px solid #dbe5f0;
      color: #0b1220;
    }

    .hero-hybrid-btn--secondary:hover,
    .hero-hybrid-btn--secondary:focus-visible {
      border-color: rgba(47, 158, 219, 0.4);
      color: #1d4ed8;
    }

    .hero-hybrid-link {
      display: inline-flex;
      align-items: center;
      gap: 0.45rem;
      margin-top: 0.95rem;
      color: #1d4ed8;
      font-size: 0.92rem;
      font-weight: 700;
      text-decoration: none;
    }

    .hero-hybrid-link:hover,
    .hero-hybrid-link:focus-visible {
      color: #0f172a;
      outline: none;
    }

    .hero-hybrid-proof {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 0.8rem;
      margin-top: 1.35rem;
      max-width: 44rem;
    }

    .hero-hybrid-proof-item {
      display: flex;
      align-items: flex-start;
      gap: 0.7rem;
      padding: 0.95rem 1rem;
      border-radius: 1.15rem;
      background: rgba(255, 255, 255, 0.88);
      border: 1px solid #e2e8f0;
      box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
    }

    .hero-hybrid-proof-icon {
      display: inline-flex;
      width: 2.2rem;
      height: 2.2rem;
      align-items: center;
      justify-content: center;
      border-radius: 999px;
      background: rgba(47, 158, 219, 0.1);
      color: #2f9edb;
      flex: 0 0 auto;
    }

    .hero-hybrid-proof-item strong {
      display: block;
      font-size: 0.9rem;
      font-weight: 800;
      line-height: 1.3;
      color: #0b1220;
    }

    .hero-hybrid-proof-item span {
      display: block;
      margin-top: 0.2rem;
      font-size: 0.79rem;
      line-height: 1.45;
      color: #475569;
    }

    .hero-hybrid-visual {
      position: relative;
    }

    .hero-hybrid-media {
      position: relative;
      overflow: hidden;
      min-height: 24.5rem;
      border-radius: 2rem;
      border: 1px solid rgba(219, 229, 240, 0.92);
      background: #0f172a;
      box-shadow: 0 24px 70px rgba(15, 23, 42, 0.1);
    }

    .hero-hybrid-media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center 44%;
      transform: scale(1.02);
    }

    .hero-hybrid-media::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(8, 18, 32, 0.06), rgba(8, 18, 32, 0.24));
      pointer-events: none;
    }

    .hero-hybrid-quick {
      margin-top: 1rem;
      padding: 1.1rem;
      border-radius: 1.6rem;
      background: rgba(255, 255, 255, 0.95);
      border: 1px solid #dbe5f0;
      box-shadow: 0 22px 54px rgba(15, 23, 42, 0.1);
    }

    .hero-hybrid-quick-head {
      display: flex;
      flex-direction: column;
      gap: 0.38rem;
    }

    .hero-hybrid-quick-label {
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      color: #1d4ed8;
      font-size: 0.72rem;
      font-weight: 800;
      letter-spacing: 0.06em;
      text-transform: uppercase;
    }

    .hero-hybrid-quick-title {
      font-size: 1rem;
      font-weight: 800;
      line-height: 1.3;
      color: #0b1220;
    }

    .hero-hybrid-quick-copy {
      font-size: 0.86rem;
      line-height: 1.55;
      color: #475569;
    }

    .hero-hybrid-quick-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 0.8rem;
      margin-top: 0.95rem;
    }

    .hero-hybrid-field {
      display: block;
    }

    .hero-hybrid-field--wide {
      grid-column: 1 / -1;
    }

    .hero-hybrid-field span {
      display: block;
      margin-bottom: 0.35rem;
      font-size: 0.76rem;
      font-weight: 800;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: #475569;
    }

    .hero-hybrid-select,
    .hero-hybrid-input {
      width: 100%;
      min-height: 3rem;
      border-radius: 0.95rem;
      border: 1px solid #dbe5f0;
      background: #ffffff;
      color: #0b1220;
      padding: 0.78rem 0.92rem;
      font-size: 0.94rem;
      line-height: 1.4;
      outline: none;
      transition: border-color 160ms ease, box-shadow 160ms ease;
    }

    .hero-hybrid-select:focus,
    .hero-hybrid-input:focus {
      border-color: rgba(47, 158, 219, 0.55);
      box-shadow: 0 0 0 4px rgba(47, 158, 219, 0.12);
    }

    .hero-hybrid-quick-actions {
      display: grid;
      grid-template-columns: 1.1fr 1fr;
      gap: 0.75rem;
      margin-top: 0.95rem;
    }

    .mobile-swipe-hint {
      display: inline-flex;
      align-items: center;
      gap: 0.45rem;
      margin-top: 0.95rem;
      color: #64748b;
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      text-transform: uppercase;
    }

    @media (min-width: 1024px) {
      .home-hero-shell {
        grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
      }

      .hero-compare-shell {
        grid-template-columns: minmax(0, 1.02fr) minmax(22rem, 0.98fr);
      }

      .hero-hybrid-shell {
        grid-template-columns: minmax(0, 1.02fr) minmax(22rem, 0.98fr);
      }
    }

    @media (max-width: 1023.98px) {
      .home-hero-shell {
        gap: 1.6rem;
      }
    }

    @media (max-width: 767.98px) {
      #main > section:not(.home-hero-premium) {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
      }

      .home-hero-shell {
        display: block;
      }

      .home-hero-topline {
        flex-wrap: nowrap;
        gap: 0.32rem;
      }

      .home-hero-pill {
        font-size: 0.54rem;
        padding: 0.44rem 0.48rem;
        gap: 0.3rem;
        min-width: 0;
      }

      .home-hero-pill--cities {
        font-size: 0.52rem;
        padding-inline: 0.42rem;
      }

      .home-hero-premium {
        background-color: #081222;
        background-image:
          radial-gradient(circle at 12% 18%, rgba(56, 189, 248, 0.14), transparent 18rem),
          radial-gradient(circle at 88% 84%, rgba(14, 165, 233, 0.08), transparent 16rem),
          linear-gradient(135deg, #081222 0%, #0b1730 52%, #0d1c35 100%);
        border-bottom: 1px solid rgba(148, 163, 184, 0.2);
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
      }

      .home-hero-premium::before {
        display: none;
      }

      .home-hero-title {
        margin-top: 1.02rem;
        font-size: clamp(1.78rem, 7vw, 2.24rem);
        max-width: 100%;
        line-height: 1.16;
        letter-spacing: -0.04em;
      }

      .home-hero-lead {
        margin-top: 0.78rem;
        font-size: 0.91rem;
        line-height: 1.68;
      }

      .home-hero-trustline {
        margin-top: 0.9rem;
        font-size: 0.84rem;
        line-height: 1.5;
      }

      .home-hero-segments {
        overflow-x: auto;
        flex-wrap: nowrap;
        gap: 0.7rem;
        margin-top: 0.95rem;
        max-width: none;
        width: 100%;
        margin-inline: 0;
        padding-inline: 0;
        padding-bottom: 0.25rem;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
      }

      .home-hero-segments::-webkit-scrollbar {
        display: none;
      }

      .home-hero-segment {
        flex: 0 0 auto;
        min-width: max-content;
        padding: 0.62rem 0.74rem;
        font-size: 0.78rem;
        scroll-snap-align: start;
      }

      .home-hero-segment-icon {
        width: 1.45rem;
        height: 1.45rem;
        font-size: 0.8rem;
      }

      .home-hero-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: start;
        gap: 0.58rem;
        margin-top: 0.98rem;
      }

      .home-hero-btn {
        width: 100%;
        min-height: 3rem;
        padding-inline: 0.72rem;
        font-size: 0.82rem;
        gap: 0.3rem;
      }

      .home-hero-btn i {
        display: inline-flex;
        font-size: 0.82rem;
      }

      .home-hero-link {
        grid-column: 1 / -1;
        justify-content: flex-start;
        font-size: 0.84rem;
      }

      .home-hero-link-row {
        margin-top: 0.68rem;
      }

      
      .home-hero-copy {
        max-width: none;
        width: 100%;
      }

      .home-hero-visual {
        display: block;
        width: 100%;
        max-width: 100%;
        min-height: 0;
        padding: 0;
        border: 0;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
        overflow: visible;
      }

      .home-hero-media {
        display: block;
        min-height: 8.6rem;
        margin-bottom: 0;
        border-radius: 1.1rem 1.1rem 0 0;
        box-shadow: 0 16px 36px rgba(2, 6, 23, 0.2);
      }

      .home-hero-media img {
        object-position: center 40%;
      }

      .home-hero-panel {
        width: 100%;
        gap: 0.65rem;
        margin-top: 0;
        padding-inline: 0;
        position: relative;
        z-index: 3;
      }

      .home-hero-panel-card {
        width: 100%;
        min-width: 0;
        padding: 0.95rem 0.95rem;
        border-top-left-radius: 0;
        border-top-right-radius: 0;
        border-top: 0;
      }

      .home-hero-calc-head {
        gap: 0.5rem;
      }

      .home-hero-calc-grid {
        grid-template-columns: 1fr;
      }

      .home-hero-calc-field,
      .home-hero-calc-select {
        min-width: 0;
      }

      .home-hero-calc-actions {
        flex-direction: column;
        align-items: stretch;
        gap: 0.45rem;
      }

      .home-hero-calc-actions .home-hero-btn {
        width: 100%;
        flex: 1 1 auto;
      }

      
      .hero-compare-title {
        font-size: clamp(1.5rem, 6vw, 2.2rem);
        max-width: 100%;
      }

      .hero-compare-lead {
        font-size: 0.92rem;
        line-height: 1.58;
      }

      .hero-compare-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
        width: 100%;
        margin-inline: 0;
        padding-inline: 0;
        padding-bottom: 0.2rem;
        scrollbar-width: none;
      }

      .hero-compare-tabs::-webkit-scrollbar {
        display: none;
      }

      .hero-compare-tab {
        flex: 0 0 auto;
        white-space: nowrap;
      }

      .hero-compare-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
      }

      .hero-compare-btn {
        width: 100%;
        min-height: 3.25rem;
      }

      .hero-compare-proof {
        grid-template-columns: 1fr;
      }

      .hero-compare-media {
        min-height: 18rem;
      }

      .hero-compare-dashboard {
        position: relative;
        top: auto;
        right: auto;
        width: 100%;
        margin-top: 0.9rem;
      }

      .hero-compare-quick {
        width: 100%;
        margin-top: 0.9rem;
      }

      .hero-hybrid-title {
        font-size: clamp(1.45rem, 5.9vw, 2.05rem);
        max-width: 100%;
      }

      .hero-hybrid-title span {
        font-size: 0.4em;
      }

      .hero-hybrid-lead {
        font-size: 0.9rem;
        line-height: 1.55;
      }

      .hero-hybrid-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
        width: 100%;
        margin-inline: 0;
        padding-inline: 0;
        padding-bottom: 0.2rem;
        scrollbar-width: none;
      }

      .hero-hybrid-tabs::-webkit-scrollbar {
        display: none;
      }

      .hero-hybrid-tab {
        flex: 0 0 auto;
        white-space: nowrap;
      }

      .hero-hybrid-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
      }

      .hero-hybrid-btn {
        width: 100%;
        min-height: 3.2rem;
      }

      .hero-hybrid-link {
        justify-content: center;
      }

      .hero-hybrid-proof {
        grid-template-columns: 1fr;
      }

      .hero-hybrid-media {
        min-height: 18rem;
        border-radius: 1.5rem;
      }

      .hero-hybrid-quick {
        padding: 1rem;
        border-radius: 1.3rem;
      }

      .hero-hybrid-quick-grid {
        grid-template-columns: 1fr;
      }

      .hero-hybrid-field--wide {
        grid-column: auto;
      }

      .hero-hybrid-quick-actions {
        grid-template-columns: 1fr;
      }

      .mobile-swipe-rail {
        display: flex !important;
        overflow-x: auto;
        gap: 1rem;
        padding-bottom: 0.4rem;
        width: 100%;
        max-width: 100%;
        margin-inline: 0;
        padding-inline: 0;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
      }

      .mobile-swipe-rail::-webkit-scrollbar {
        display: none;
      }

      .mobile-swipe-card {
        flex: 0 0 84%;
        min-width: 84%;
        scroll-snap-align: start;
      }

      .mobile-swipe-rail--wide .mobile-swipe-card {
        flex-basis: 88%;
        min-width: 88%;
      }

      .mobile-swipe-rail--tight .mobile-swipe-card {
        flex-basis: 78%;
        min-width: 78%;
      }

      .process-rail .mobile-swipe-card {
        flex-basis: 64%;
        min-width: 64%;
      }

      .subscription-rail {
        scroll-padding-inline: 20%;
      }

      .subscription-rail .mobile-swipe-card {
        flex-basis: 62%;
        min-width: 62%;
        scroll-snap-align: center;
      }

      #faq [data-faq-grid] {
        gap: 0.8rem;
      }

      #faq [data-faq-item] {
        padding: 1rem;
        border-radius: 1.2rem;
      }

      #faq [data-faq-item] summary {
        gap: 0.85rem;
        font-size: 0.96rem;
        line-height: 1.45;
      }

      #faq [data-faq-item] p {
        margin-top: 0.85rem;
        padding-right: 0;
        line-height: 1.62;
      }

      #ponuda .luxe-glass {
        padding: 1.35rem 1.15rem 1.45rem;
        border-radius: 2rem;
      }
    }

    @media (max-width: 430px) {
      .home-hero-segment {
        flex-basis: auto;
        min-width: max-content;
      }

      .mobile-swipe-card {
        flex-basis: 86%;
        min-width: 86%;
      }

      .mobile-swipe-rail--wide .mobile-swipe-card {
        flex-basis: 82%;
        min-width: 82%;
      }

      .mobile-swipe-rail--tight .mobile-swipe-card {
        flex-basis: 58%;
        min-width: 58%;
      }

      .process-rail .mobile-swipe-card {
        flex-basis: 68%;
        min-width: 68%;
      }

      .subscription-rail .mobile-swipe-card {
        flex-basis: 66%;
        min-width: 66%;
      }
    }

    .process-step-card {
      overflow: visible;
      display: flex;
      flex-direction: column;
      min-height: 100%;
    }

    .process-step-badge {
      position: absolute;
      left: 1.25rem;
      top: 0;
      transform: translateY(-50%);
    }

    .process-step-line {
      display: block;
      width: 2px;
      height: 2.35rem;
      margin: 0.2rem 0 1rem 1.4rem;
      border-radius: 999px;
      background: linear-gradient(180deg, rgba(148,163,184,0.16) 0%, rgba(56,189,248,0.85) 100%);
      box-shadow: 0 10px 18px rgba(56,189,248,0.15);
    }

    .deep-cleaning-feature {
      display: flex;
      align-items: flex-start;
      gap: 0.95rem;
    }

    .deep-cleaning-feature-body {
      min-width: 0;
    }

    .deep-cleaning-overlay {
      border: 1px solid rgba(255, 255, 255, 0.14);
      background: rgba(2, 6, 23, 0.74);
      color: #ffffff;
    }

    .deep-cleaning-overlay-label {
      color: rgba(125, 211, 252, 0.92);
    }

    .deep-cleaning-overlay-copy {
      color: rgba(241, 245, 249, 0.96);
    }

    .booking-select {
      color: #f8fafc;
      background-color: rgba(14, 165, 233, 0.14);
      border-color: rgba(125, 211, 252, 0.26);
      color-scheme: dark;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
    }

    .booking-select:focus {
      background-color: rgba(14, 165, 233, 0.18);
    }

    .booking-select option,
    .booking-select optgroup {
      color: #082f49;
      background: #e0f2fe;
    }

    .pac-container {
      z-index: 90 !important;
      margin-top: 0.35rem;
      border: 1px solid rgba(125, 211, 252, 0.32);
      border-radius: 1rem;
      background: linear-gradient(180deg, rgba(248, 250, 252, 0.98), rgba(224, 242, 254, 0.98));
      box-shadow: 0 20px 48px rgba(2, 6, 23, 0.34);
      overflow: hidden;
      font-family: inherit;
    }

    .pac-item {
      padding: 0.8rem 1rem;
      border-top: 1px solid rgba(148, 163, 184, 0.16);
      color: #0f172a;
      font-size: 0.94rem;
      line-height: 1.45;
      cursor: pointer;
    }

    .pac-item:hover,
    .pac-item-selected {
      background: rgba(14, 165, 233, 0.12);
    }

    .pac-item-query {
      color: #0369a1;
      font-size: 0.94rem;
      padding-right: 0.3rem;
    }

    .pac-matched {
      font-weight: 700;
    }

    .pac-icon {
      display: none;
    }

    .booking-date-field {
      position: relative;
      display: block;
    }

    .booking-date-input {
      cursor: pointer;
      padding-right: 3.35rem;
    }

    .booking-date-input::placeholder {
      color: #94a3b8;
    }

    .booking-date-icon {
      pointer-events: none;
      position: absolute;
      top: 50%;
      right: 1rem;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      color: #7dd3fc;
      transform: translateY(-50%);
      font-size: 1.1rem;
    }

    .flatpickr-calendar {
      border: 1px solid rgba(14, 165, 233, 0.18) !important;
      border-radius: 1.2rem !important;
      background: #f8fbff !important;
      box-shadow: 0 26px 70px rgba(15, 23, 42, 0.22) !important;
      overflow: hidden !important;
    }

    .flatpickr-months {
      background: linear-gradient(180deg, #eff6ff 0%, #e0f2fe 100%) !important;
      padding: 0.35rem 0.25rem 0 !important;
    }

    .flatpickr-current-month,
    .flatpickr-monthDropdown-months,
    .flatpickr-weekday,
    .flatpickr-months .flatpickr-prev-month,
    .flatpickr-months .flatpickr-next-month {
      color: #0f172a !important;
      fill: #0f172a !important;
    }

    .flatpickr-weekdays {
      background: #f8fbff !important;
    }

    .flatpickr-day {
      border-radius: 0.9rem !important;
      color: #0f172a !important;
    }

    .flatpickr-day:hover,
    .flatpickr-day:focus,
    .flatpickr-day.selected,
    .flatpickr-day.startRange,
    .flatpickr-day.endRange {
      background: #0ea5e9 !important;
      border-color: #0ea5e9 !important;
      color: #ffffff !important;
    }

    .flatpickr-day.today {
      border-color: rgba(14, 165, 233, 0.4) !important;
    }

    @media (max-width: 767.98px) {
      .process-step-card {
        padding-top: 4.25rem;
      }

      .process-step-badge {
        left: 1rem;
        top: 1rem;
        transform: none;
      }

      .process-step-line {
        display: block;
        position: absolute;
        left: 4.15rem;
        right: 1rem;
        top: 2rem;
        height: 5px;
        border-radius: 999px;
        background: linear-gradient(90deg, rgba(14,165,233,0.38) 0%, rgba(16,185,129,0.34) 50%, rgba(124,58,237,0.32) 100%);
        box-shadow: inset 0 0 0 1px rgba(255,255,255,0.35), 0 6px 16px rgba(148,163,184,0.16);
        opacity: 1;
      }

      .deep-cleaning-feature h3 {
        margin-top: 0;
      }

      .deep-cleaning-feature p {
        margin-top: 0.35rem;
        line-height: 1.55;
      }
    }


    /* April 2026 hero + city entry refinement */
    @media (min-width: 1024px) {
      .home-hero-shell {
        grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
        gap: 3rem;
      }

      .home-hero-link-row {
        padding-left: 1.42rem;
      }

      .home-hero-media {
        min-height: 20.75rem;
      }
    }

    .home-hero-btn-icon {
      display: inline-flex;
      width: 2rem;
      height: 2rem;
      align-items: center;
      justify-content: center;
      border-radius: 999px;
      flex: 0 0 auto;
      font-size: 1rem;
    }

    .home-hero-btn--primary {
      padding-inline: 1.4rem 1.55rem;
      gap: 0.72rem;
      background: linear-gradient(180deg, #3d8dff 0%, #2563eb 100%);
      box-shadow: 0 20px 42px rgba(37, 99, 235, 0.26);
    }

    .home-hero-btn--primary .home-hero-btn-icon {
      background: rgba(255, 255, 255, 0.18);
      color: #ffffff;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
    }

    .home-hero-btn--secondary {
      padding-inline: 1.3rem 1.45rem;
      gap: 0.72rem;
      background: rgba(255, 255, 255, 0.1);
      border-color: rgba(255, 255, 255, 0.18);
    }

    .home-hero-btn--secondary .home-hero-btn-icon {
      background: rgba(125, 211, 252, 0.14);
      color: #bae6fd;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }

    .home-hero-link {
      font-size: 0.98rem;
      font-weight: 600;
      letter-spacing: 0.01em;
      border-bottom-width: 2px;
      padding-bottom: 0.18rem;
    }

    .home-hero-trustline {
      gap: 0.8rem;
      margin-top: 1.1rem;
    }

    .home-hero-trust-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.62rem;
      min-height: 2.7rem;
      padding: 0.68rem 0.95rem;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, 0.14);
      background: rgba(255, 255, 255, 0.08);
      color: #eef6ff;
      font-size: 0.9rem;
      font-weight: 700;
      line-height: 1;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.07);
      backdrop-filter: blur(10px);
    }

    .home-hero-trust-badge i {
      display: inline-flex;
      width: 1.7rem;
      height: 1.7rem;
      align-items: center;
      justify-content: center;
      border-radius: 999px;
      font-size: 0.92rem;
      flex: 0 0 auto;
    }

    .home-hero-trust-badge--sky i {
      background: rgba(56, 189, 248, 0.16);
      color: #7dd3fc;
    }

    .home-hero-trust-badge--emerald i {
      background: rgba(16, 185, 129, 0.16);
      color: #6ee7b7;
    }

    .home-hero-trust-badge--amber i {
      background: rgba(251, 191, 36, 0.18);
      color: #fcd34d;
    }

    .home-hero-visual {
      padding: 0;
      border-radius: 2.05rem;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.03));
      box-shadow: 0 26px 60px rgba(3, 11, 23, 0.3);
      overflow: hidden;
    }

    .home-hero-media {
      border-radius: 0;
    }

    .home-hero-media::after {
      background: linear-gradient(180deg, rgba(8, 15, 28, 0.02), rgba(8, 15, 28, 0.24));
    }

    .home-hero-panel {
      margin-top: 0;
      padding-inline: 0;
      gap: 0;
      background: linear-gradient(180deg, rgba(241, 245, 249, 0.98), rgba(233, 241, 248, 0.98));
    }

    .home-hero-panel-card {
      padding: 1.08rem 1.15rem 1.15rem;
      border-radius: 0;
      border: 0;
      border-top: 1px solid rgba(148, 163, 184, 0.16);
      box-shadow: none;
      background: transparent;
    }

    .home-hero-panel-title {
      font-size: 1.02rem;
    }

    .home-hero-calc-grid {
      gap: 0.72rem;
    }

    .home-hero-calc-actions {
      margin-top: 0.9rem;
    }

    .city-map-card {
      position: relative;
      width: 16rem;
      min-height: 10.75rem;
      border-radius: 1.75rem;
      border: 1px solid rgba(148, 163, 184, 0.16);
      background:
        radial-gradient(circle at 26% 28%, rgba(56, 189, 248, 0.16), transparent 3.8rem),
        radial-gradient(circle at 76% 34%, rgba(16, 185, 129, 0.12), transparent 4rem),
        radial-gradient(circle at 70% 76%, rgba(251, 191, 36, 0.12), transparent 4rem),
        linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
      box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
      overflow: hidden;
    }

    .city-map-card::before {
      content: "";
      position: absolute;
      inset: 1.1rem;
      border-radius: 1.2rem;
      background:
        linear-gradient(90deg, rgba(148, 163, 184, 0.14) 1px, transparent 1px) 0 0 / 2.6rem 2.6rem,
        linear-gradient(rgba(148, 163, 184, 0.14) 1px, transparent 1px) 0 0 / 2.6rem 2.6rem;
      opacity: 0.45;
    }

    .city-map-card__pin {
      position: absolute;
      z-index: 1;
      display: inline-flex;
      flex-direction: column;
      align-items: center;
      gap: 0.34rem;
      font-size: 0.68rem;
      font-weight: 700;
      color: #0f172a;
    }

    .city-map-card__pin span {
      width: 0.95rem;
      height: 0.95rem;
      border-radius: 999px;
      border: 3px solid #ffffff;
      box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.16), 0 10px 18px rgba(15, 23, 42, 0.12);
    }

    .city-map-card__pin small {
      padding: 0.24rem 0.48rem;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.92);
      box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
      font-size: 0.68rem;
      letter-spacing: 0.01em;
    }

    .city-map-card__pin--zadar {
      left: 26%;
      top: 28%;
    }

    .city-map-card__pin--zadar span {
      background: #0ea5e9;
    }

    .city-map-card__pin--split {
      left: 45%;
      top: 49%;
    }

    .city-map-card__pin--split span {
      background: #10b981;
    }

    .city-map-card__pin--zagreb {
      left: 67%;
      top: 24%;
    }

    .city-map-card__pin--zagreb span {
      background: #f59e0b;
    }

    @media (max-width: 767.98px) {
      .home-hero-btn-icon {
        width: 1.8rem;
        height: 1.8rem;
        font-size: 0.92rem;
      }

      .home-hero-link {
        font-size: 0.88rem;
        font-weight: 600;
      }

      .home-hero-trustline {
        gap: 0.5rem;
      }

      .home-hero-trust-badge {
        min-height: 2.35rem;
        padding: 0.58rem 0.72rem;
        font-size: 0.8rem;
        gap: 0.45rem;
      }

      .home-hero-trust-badge i {
        width: 1.45rem;
        height: 1.45rem;
        font-size: 0.78rem;
      }

      .home-hero-media {
        min-height: 8rem;
      }

      .home-hero-panel {
        background: #f8fbff;
      }

      .home-hero-panel-card {
        padding: 0.95rem 0.95rem 1rem;
      }
    }


    .home-hero-btn--secondary .home-hero-btn-icon {
      background: rgba(255, 255, 255, 0.14);
      color: #ffffff;
    }


    .home-hero-btn {
      font-weight: 700;
      letter-spacing: 0.005em;
    }

    .home-hero-link-row {
      margin-top: 1.08rem;
    }

    .home-hero-link {
      gap: 0.56rem;
      font-size: 1.08rem;
      font-weight: 600;
      letter-spacing: 0.015em;
      padding-bottom: 0.22rem;
    }

    .process-step-badge {
      z-index: 2;
      box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
    }

    @media (max-width: 767.98px) {
      .home-hero-btn {
        font-weight: 700;
      }

      .home-hero-link-row {
        margin-top: 0.82rem;
      }

      .home-hero-link {
        font-size: 0.94rem;
        gap: 0.5rem;
      }
    }


    .home-hero-btn {
      font-weight: 600;
      letter-spacing: 0.003em;
    }

    .home-hero-btn span:last-child {
      font-weight: 600;
    }

    .home-hero-link-row {
      margin-top: 1.2rem;
    }

    .home-hero-link {
      gap: 0.62rem;
      font-size: 1.14rem;
      font-weight: 500;
      letter-spacing: 0.018em;
      padding-bottom: 0.28rem;
    }

    .home-hero-link i {
      font-size: 1rem;
    }

    .process-step-badge {
      z-index: 3;
      color: #ffffff;
      box-shadow: 0 14px 30px rgba(15, 23, 42, 0.16);
    }

    [data-featured-card] {
      background: linear-gradient(180deg, #10253a 0%, #17324b 52%, #1a3044 100%);
      border-color: rgba(252, 211, 77, 0.36);
      box-shadow: 0 34px 90px rgba(15, 23, 42, 0.26), inset 0 1px 0 rgba(253, 230, 138, 0.12);
    }

    [data-featured-card] h3,
    [data-featured-card] .text-5xl,
    [data-featured-card] .text-xl {
      text-shadow: 0 1px 0 rgba(15, 23, 42, 0.18);
    }

    [data-featured-card] li span:last-child {
      color: #f8fafc;
    }

    .planner-control {
      min-height: 3.85rem;
      padding: 1rem 1rem;
      font-size: 1rem;
      line-height: 1.35;
      color: #0f172a;
      background: linear-gradient(180deg, #f8fbff 0%, #eef5ff 100%);
      border-color: rgba(148, 163, 184, 0.38);
    }

    .planner-control::placeholder {
      color: #475569;
    }

    .planner-control option {
      color: #0f172a;
      background: #ffffff;
    }

    .planner-control::-webkit-calendar-picker-indicator {
      opacity: 0.9;
      filter: invert(17%) sepia(10%) saturate(1516%) hue-rotate(176deg) brightness(94%) contrast(92%);
    }

    .planner-shell {
      position: relative;
    }

    .planner-scenario-card {
      display: flex;
      align-items: flex-start;
      gap: 0.95rem;
      width: 100%;
      padding: 1rem;
      border-radius: 1.5rem;
      border: 1px solid rgba(255,255,255,0.1);
      transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
    }

    .planner-scenario-card--idle {
      background: rgba(255,255,255,0.04);
      color: #e2e8f0;
    }

    .planner-scenario-card--active {
      background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(241,245,249,0.96) 100%);
      color: #0f172a;
      border-color: rgba(125,211,252,0.38);
      box-shadow: 0 22px 50px rgba(2,6,23,0.18);
      transform: translateY(-1px);
    }

    .planner-scenario-card--idle h3,
    .planner-scenario-card--idle p,
    .planner-scenario-card--idle .planner-scenario-tag {
      color: inherit;
    }

    .planner-scenario-icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 2.9rem;
      height: 2.9rem;
      border-radius: 1rem;
      font-size: 1.25rem;
      flex-shrink: 0;
    }

    .planner-scenario-tag {
      display: inline-flex;
      align-items: center;
      border-radius: 999px;
      padding: 0.28rem 0.7rem;
      font-size: 0.68rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      background: rgba(255,255,255,0.08);
      color: rgba(226,232,240,0.92);
    }

    .planner-scenario-card--active .planner-scenario-tag {
      background: rgba(14,165,233,0.12);
      color: #0369a1;
    }

    .planner-chip-row {
      display: flex;
      flex-wrap: wrap;
      gap: 0.65rem;
    }

    .planner-chip {
      display: inline-flex;
      align-items: center;
      gap: 0.55rem;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,0.12);
      background: rgba(255,255,255,0.05);
      padding: 0.68rem 0.95rem;
      font-size: 0.94rem;
      color: #e2e8f0;
    }

    .planner-chip input {
      width: 1rem;
      height: 1rem;
      accent-color: #38bdf8;
    }

    .planner-result-panel {
      position: relative;
    }

    .planner-metric {
      min-height: 100%;
    }

    .planner-info-card ul,
    .planner-result-panel ul {
      list-style: none;
      margin: 0;
      padding: 0;
    }

    @media (max-width: 767.98px) {
      .home-hero-btn {
        font-weight: 600;
      }

      .home-hero-link-row {
        margin-top: 0.9rem;
      }

      .home-hero-link {
        font-size: 0.98rem;
        gap: 0.52rem;
      }
    }


    .home-hero-actions {
      gap: 0.92rem;
      margin-top: 1.6rem;
    }

    .home-hero-btn {
      min-height: 3.42rem;
      padding: 0.92rem 1.42rem;
      border-radius: 1.15rem;
      font-size: 0.95rem;
      font-weight: 600;
      letter-spacing: 0.004em;
      box-shadow: 0 14px 30px rgba(15, 23, 42, 0.16);
    }

    .home-hero-btn-icon {
      width: 1.92rem;
      height: 1.92rem;
      font-size: 0.96rem;
    }

    .home-hero-btn--primary {
      background: linear-gradient(180deg, #5b9cff 0%, #2563eb 100%);
      border: 1px solid rgba(191, 219, 254, 0.2);
      box-shadow: 0 18px 40px rgba(37, 99, 235, 0.24);
    }

    .home-hero-btn--primary:hover,
    .home-hero-btn--primary:focus-visible {
      background: linear-gradient(180deg, #76acff 0%, #2c6df1 100%);
      box-shadow: 0 20px 44px rgba(37, 99, 235, 0.28);
    }

    .home-hero-btn--secondary {
      background: rgba(255, 255, 255, 0.07);
      border-color: rgba(255, 255, 255, 0.16);
      box-shadow: 0 14px 30px rgba(2, 6, 23, 0.18);
    }

    .home-hero-btn--secondary:hover,
    .home-hero-btn--secondary:focus-visible {
      background: rgba(255, 255, 255, 0.12);
      border-color: rgba(255, 255, 255, 0.24);
    }

    .home-hero-link-row {
      margin-top: 1.22rem;
    }

    .home-hero-link {
      gap: 0.66rem;
      font-size: 1.18rem;
      font-weight: 500;
      letter-spacing: 0.018em;
      padding-bottom: 0.28rem;
    }

    .modular-gallery {
      align-self: start;
    }

    .deep-cleaning-visual {
      align-self: start;
    }

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

    .home-fastlink-card {
      display: flex;
      flex-direction: column;
      min-height: 100%;
    }

    .home-fastlink-media {
      height: 13.2rem;
    }

    .home-fastlink-pill {
      background: rgba(7, 18, 45, 0.55);
      backdrop-filter: blur(8px);
      border: 1px solid rgba(255, 255, 255, 0.12);
    }

    .home-fastlink-content {
      left: 0.95rem;
      right: 0.95rem;
      bottom: 0.95rem;
      z-index: 2;
      padding: 0.82rem 0.95rem 0.9rem;
      border: 1px solid rgba(255, 255, 255, 0.12);
      border-radius: 1.08rem;
      background: linear-gradient(180deg, rgba(15,23,42,0.28) 0%, rgba(15,23,42,0.72) 24%, rgba(15,23,42,0.92) 100%);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
      box-shadow: 0 16px 36px rgba(2, 6, 23, 0.24);
    }

    .home-fastlink-title {
      display: block;
      max-width: 100%;
      padding: 0;
      border-radius: 0;
      background: transparent;
      box-shadow: none;
      color: rgba(255, 255, 255, 0.98);
      text-shadow: 0 1px 10px rgba(2, 6, 23, 0.42);
      line-height: 1.22;
      font-weight: 600;
      letter-spacing: -0.014em;
      font-size: 1.05rem;
    }

    .home-fastlink-card > span:last-child {
      margin-top: auto;
      font-weight: 600;
    }

    .home-fastlink-text {
      min-height: 5.25rem;
      font-size: 0.92rem;
      line-height: 1.7;
      font-weight: 400;
      color: rgba(226, 232, 240, 0.9);
    }

    @media (max-width: 767.98px) {
      .home-hero-btn {
        min-height: 3.06rem;
        padding-inline: 0.9rem;
        font-size: 0.82rem;
        gap: 0.44rem;
      }

      .home-hero-btn-icon {
        width: 1.7rem;
        height: 1.7rem;
        font-size: 0.84rem;
      }

      .home-hero-link-row {
        margin-top: 0.92rem;
      }

      .home-hero-link {
        font-size: 0.98rem;
        gap: 0.5rem;
      }

      .home-fastlinks-row {
        display: flex;
        gap: 0.95rem;
        overflow-x: auto;
        padding-bottom: 0.25rem;
        scroll-snap-type: x proximity;
      }

      .home-fastlinks-row .mobile-swipe-card {
        flex-basis: 84%;
        min-width: 84%;
        scroll-snap-align: start;
      }

      .home-fastlink-card {
        padding: 0.9rem;
        border-radius: 1.45rem;
      }

      .home-fastlink-media {
        height: 10.6rem;
      }

      .home-fastlink-title {
        font-size: 0.94rem;
        font-weight: 600 !important;
        line-height: 1.18;
      }

      .planner-scenario-card {
        padding: 0.92rem;
        border-radius: 1.3rem;
      }

      .planner-scenario-icon {
        width: 2.55rem;
        height: 2.55rem;
        border-radius: 0.92rem;
      }

      .planner-chip {
        font-size: 0.88rem;
        padding: 0.62rem 0.82rem;
      }

      .home-fastlink-text {
        min-height: 0;
        font-size: 0.76rem;
        line-height: 1.48;
      }
    }


    #paketi .mobile-swipe-card {
      overflow: hidden;
    }

    @media (max-width: 767.98px) {
      #paketi .mobile-swipe-card {
        padding: 1rem !important;
        border-radius: 1.45rem;
      }

      #paketi .mobile-swipe-card .mt-6 {
        margin-top: 0.9rem !important;
      }

      #paketi .mobile-swipe-card .mt-5 {
        margin-top: 0.8rem !important;
      }

      #paketi .mobile-swipe-card .text-5xl {
        font-size: 2.35rem;
        line-height: 1;
      }

      #paketi .mobile-swipe-card .space-y-3 > * + * {
        margin-top: 0.6rem;
      }

      #paketi .subscription-rail .mobile-swipe-card {
        flex-basis: 68%;
        min-width: 68%;
      }

      #provjera-smjene .rounded-\[1\.5rem\] {
        border-radius: 1.3rem;
      }
    }

    @media (max-width: 430px) {
      #paketi .subscription-rail .mobile-swipe-card {
        flex-basis: 72%;
        min-width: 72%;
      }
    }


    .model-card {
      display: flex;
      flex-direction: column;
      min-height: 100%;
    }

    .model-card__cta {
      width: 100%;
      margin-top: auto;
    }

    .model-card__badge {
      white-space: nowrap;
    }


    .model-card__actions {
      margin-top: auto;
      padding-top: 1.25rem;
      border-top: 1px solid rgba(226, 232, 240, 0.8);
    }

    .model-card__points {
      margin-bottom: 0.25rem;
    }

/* April 2026 hero refinement v3 */
.home-hero-premium {
  background:
    radial-gradient(circle at 12% 16%, rgba(56, 189, 248, 0.12), transparent 24rem),
    radial-gradient(circle at 86% 82%, rgba(14, 165, 233, 0.07), transparent 23rem),
    linear-gradient(135deg, #091321 0%, #0c172a 48%, #10203a 100%);
}

.home-hero-premium::before {
  background:
    radial-gradient(circle at 78% 18%, rgba(59, 130, 246, 0.08), transparent 24rem),
    linear-gradient(180deg, rgba(6, 11, 23, 0.08), rgba(6, 11, 23, 0.03));
}

.home-hero-title {
  max-width: 10.5ch;
  margin-top: 1.35rem;
  font-size: clamp(2.25rem, 4vw, 4.35rem);
  line-height: 0.98;
  letter-spacing: -0.062em;
}

.home-hero-lead {
  margin-top: 1.3rem;
  max-width: 43rem;
  font-size: clamp(1rem, 1.15vw, 1.12rem);
  line-height: 1.8;
  color: rgba(226, 236, 248, 0.9);
}

.home-hero-topline {
  gap: 0.7rem;
}

.home-hero-pill {
  padding: 0.72rem 1rem;
}

.home-hero-pill--cities {
  padding-inline: 0.92rem;
  font-size: 0.8rem;
  font-weight: 600;
  opacity: 0.92;
}

.home-hero-actions {
  gap: 0.95rem;
  margin-top: 1.75rem;
}

.home-hero-btn {
  min-height: 3.5rem;
  border-radius: 1.15rem;
  padding: 0.95rem 1.45rem;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.002em;
}

.home-hero-btn--primary {
  background: linear-gradient(180deg, #64a7ff 0%, #2563eb 100%);
  border: 1px solid rgba(191, 219, 254, 0.22);
  box-shadow: 0 20px 44px rgba(37, 99, 235, 0.24);
}

.home-hero-btn--secondary {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 14px 28px rgba(2, 6, 23, 0.16);
}

.home-hero-btn-icon {
  width: 1.9rem;
  height: 1.9rem;
  font-size: 0.96rem;
}

.home-hero-link-row {
  margin-top: 1.05rem;
  padding-left: 0;
}

.home-hero-link {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.home-hero-trustline {
  gap: 0.7rem;
  margin-top: 1.2rem;
}

.home-hero-trust-badge {
  min-height: 2.68rem;
  padding: 0.65rem 0.92rem;
  font-size: 0.88rem;
  font-weight: 700;
}

.home-hero-helper-row {
  margin-top: 1.2rem;
}

.home-hero-helper-label {
  display: inline-flex;
  margin-bottom: 0.7rem;
  color: rgba(203, 213, 225, 0.84);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.home-hero-helper-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
}

.home-hero-helper-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 2.65rem;
  padding: 0.68rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.11);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(239, 246, 255, 0.92);
  font-size: 0.86rem;
  font-weight: 600;
  transition: transform 160ms ease, background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.home-hero-helper-chip:hover,
.home-hero-helper-chip:focus-visible {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.09);
  border-color: rgba(255, 255, 255, 0.18);
  outline: none;
}

.home-hero-helper-chip.is-active {
  background: rgba(56, 189, 248, 0.15);
  border-color: rgba(125, 211, 252, 0.34);
  box-shadow: 0 12px 26px rgba(14, 116, 144, 0.18);
}

.home-hero-helper-chip-icon {
  display: inline-flex;
  width: 1.6rem;
  height: 1.6rem;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 0.86rem;
  flex: 0 0 auto;
}

.home-hero-visual {
  box-shadow: 0 26px 58px rgba(3, 11, 23, 0.28);
}

.home-hero-media {
  min-height: 18.4rem;
}

.home-hero-media img {
  object-position: center 40%;
}

.home-hero-panel {
  background: linear-gradient(180deg, rgba(242, 247, 252, 0.98), rgba(233, 241, 248, 0.98));
}

.home-hero-panel-card {
  padding: 1.1rem 1.15rem 1.18rem;
}

.home-hero-panel-title {
  font-size: 1.06rem;
}

.home-hero-panel-copy {
  margin-top: 0.4rem;
  font-size: 0.88rem;
  line-height: 1.55;
  color: #475569;
}

.home-hero-calc-grid--hero {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.78rem;
}

.home-hero-calc-field--wide {
  grid-column: 1 / -1;
}

.home-hero-calc-select {
  min-height: 3.15rem;
  border-radius: 1rem;
}

@media (min-width: 1024px) {
  .home-hero-shell {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: 3.45rem;
  }

  .home-hero-copy {
    max-width: 43.5rem;
  }

  .home-hero-visual {
    margin-top: 0.4rem;
  }

  .home-hero-media {
    min-height: 18.9rem;
  }
}

@media (max-width: 767.98px) {
  .home-hero-title {
    max-width: 11.5ch;
    font-size: clamp(2.05rem, 10vw, 2.85rem);
  }

  .home-hero-lead {
    line-height: 1.7;
  }

  .home-hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .home-hero-btn {
    width: 100%;
  }

  .home-hero-helper-row {
    margin-top: 1rem;
  }

  .home-hero-helper-chips {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.1rem;
    scrollbar-width: none;
  }

  .home-hero-helper-chips::-webkit-scrollbar {
    display: none;
  }

  .home-hero-helper-chip {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  .home-hero-calc-grid--hero {
    grid-template-columns: 1fr;
  }

  .home-hero-media {
    min-height: 7.8rem;
  }
}

.home-hero-panel-copy--dynamic {
  margin-top: 0.55rem;
  color: #334155;
}

/* April 2026 final home stabilization */
@media (min-width: 1024px) {
  .home-hero-shell {
    grid-template-columns: minmax(0, 1.04fr) minmax(0, 0.96fr);
    grid-template-areas:
      "copy visual"
      "helper visual";
    align-items: start;
    gap: 2.5rem 3rem;
  }

  .home-hero-copy {
    grid-area: copy;
    max-width: 41rem;
  }

  .home-hero-visual {
    grid-area: visual;
    align-self: start;
    margin-top: 0.15rem;
  }

  .home-hero-helper-row {
    grid-area: helper;
    max-width: 41rem;
    margin-top: 0.2rem;
  }

  .home-hero-helper-chips {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.72rem;
  }

  .home-hero-helper-chip {
    justify-content: center;
    min-width: 0;
    text-align: center;
    padding: 0.66rem 0.72rem;
    font-size: 0.81rem;
  }

  .home-hero-link-row {
    padding-left: 0.3rem;
  }

  .home-hero-media {
    min-height: 16.2rem;
  }

  .modular-layout {
    grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
    align-items: start;
  }

  .modular-gallery {
    grid-column: 2;
    align-self: start;
    padding-left: 1rem;
  }

  .modular-gallery-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
  }
}

.home-hero-pill {
  padding: 0.78rem 1.12rem;
  font-size: 0.95rem;
  font-weight: 800;
}

.home-hero-pill-dot {
  width: 0.56rem;
  height: 0.56rem;
  background: #34d399;
  box-shadow: 0 0 0 0.3rem rgba(52, 211, 153, 0.14), 0 0 18px rgba(52, 211, 153, 0.42);
}

.home-hero-title {
  max-width: 12.4ch;
  margin-top: 1.18rem;
  font-size: clamp(2rem, 3.2vw, 3.2rem);
  line-height: 1.03;
  letter-spacing: -0.055em;
}

.home-hero-lead {
  margin-top: 1.08rem;
  max-width: 42rem;
  font-size: clamp(0.98rem, 1.06vw, 1.08rem);
  line-height: 1.74;
}

.home-hero-actions {
  gap: 1rem;
  margin-top: 1.45rem;
}

.home-hero-btn {
  min-height: 3.28rem;
  padding: 0.88rem 1.22rem;
  border-radius: 1.08rem;
  font-size: 0.92rem;
  font-weight: 600;
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.16);
}

.home-hero-btn-icon {
  width: 1.88rem;
  height: 1.88rem;
  font-size: 0.96rem;
}

.home-hero-btn--primary .home-hero-btn-icon {
  background: rgba(255, 255, 255, 0.18);
}

.home-hero-btn--secondary .home-hero-btn-icon {
  background: rgba(255, 255, 255, 0.12);
}

.home-hero-link-row {
  margin-top: 1.06rem;
}

.home-hero-link {
  margin-left: 0.16rem;
  font-size: 1.05rem;
  font-weight: 500;
}

.home-hero-trustline {
  margin-top: 1.12rem;
}

.home-hero-helper-label {
  margin-bottom: 0.55rem;
}

.process-step-header {
  display: flex;
  align-items: center;
  gap: 0.78rem;
  position: relative;
  z-index: 2;
}

.process-step-badge {
  position: relative;
  left: auto;
  top: auto;
  transform: none;
  flex: 0 0 auto;
}

.process-step-line {
  width: calc(100% - 2.9rem);
  height: 5px;
  margin: 0.9rem 0 1rem 1.45rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(56, 189, 248, 0.45) 0%, rgba(16, 185, 129, 0.38) 50%, rgba(124, 58, 237, 0.34) 100%);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.36), 0 8px 18px rgba(148, 163, 184, 0.16);
}

@media (max-width: 767.98px) {
  .home-hero-shell {
    display: flex;
    flex-direction: column;
    gap: 0.95rem;
  }

  .home-hero-copy {
    order: 1;
  }

  .home-hero-visual {
    order: 2;
  }

  .home-hero-helper-row {
    order: 3;
    width: 100%;
    margin-top: 0.2rem;
  }

  .home-hero-pill {
    font-size: 0.67rem;
    padding: 0.5rem 0.72rem;
    gap: 0.38rem;
  }

  .home-hero-pill-dot {
    width: 0.48rem;
    height: 0.48rem;
  }

  .home-hero-title {
    max-width: 13ch;
    font-size: clamp(1.78rem, 8.4vw, 2.28rem);
    line-height: 1.08;
  }

  .home-hero-lead {
    margin-top: 0.82rem;
    font-size: 0.92rem;
    line-height: 1.66;
  }

  .home-hero-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0.66rem;
    margin-top: 1rem;
  }

  .home-hero-btn {
    width: 100%;
    min-height: 2.96rem;
    padding: 0.78rem 0.8rem;
    font-size: 0.79rem;
    gap: 0.38rem;
  }

  .home-hero-btn-icon {
    width: 1.58rem;
    height: 1.58rem;
    font-size: 0.82rem;
  }

  .home-hero-link-row {
    margin-top: 0.72rem;
    padding-left: 0.14rem;
  }

  .home-hero-link {
    font-size: 0.91rem;
  }

  .home-hero-trustline {
    gap: 0.44rem;
    margin-top: 0.86rem;
  }

  .home-hero-trust-badge {
    min-height: 2.1rem;
    padding: 0.5rem 0.58rem;
    font-size: 0.74rem;
    gap: 0.4rem;
  }

  .home-hero-trust-badge i {
    width: 1.38rem;
    height: 1.38rem;
    font-size: 0.75rem;
  }

  .home-hero-media {
    min-height: 7rem;
  }

  .home-hero-panel-card {
    padding: 0.86rem 0.9rem 0.94rem;
  }

  .home-hero-helper-label {
    display: block;
  }

  .home-hero-helper-chips {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem;
    overflow: visible;
  }

  .home-hero-helper-chip {
    min-width: 0;
    justify-content: center;
    white-space: normal;
    text-align: center;
    padding: 0.58rem 0.44rem;
    border-radius: 1rem;
    font-size: 0.72rem;
    line-height: 1.22;
  }

  .home-hero-helper-chip-icon {
    display: none;
  }

  #gradovi {
    padding-top: 2.55rem !important;
    padding-bottom: 2.8rem !important;
  }

  #gradovi .mobile-swipe-rail--cities {
    gap: 0.8rem;
    padding-right: 1rem;
  }

  #gradovi .mobile-swipe-rail--cities .mobile-swipe-card {
    flex: 0 0 71%;
    min-width: 71%;
    padding: 1rem 1rem 1.05rem;
    border-radius: 1.38rem;
  }

  #gradovi .mobile-swipe-rail--cities h3 {
    font-size: 1.34rem;
  }

  #gradovi .mobile-swipe-rail--cities p {
    font-size: 0.82rem;
    line-height: 1.58;
  }

  #gradovi .mobile-swipe-rail--cities .h-12.w-12 {
    width: 2.45rem;
    height: 2.45rem;
  }

  .process-step-card {
    padding-top: 1.15rem;
  }

  .process-step-header {
    gap: 0.68rem;
  }

  .process-step-badge {
    width: 2.75rem;
    height: 2.75rem;
    font-size: 0.78rem;
  }

  .process-step-label {
    padding: 0.4rem 0.68rem;
    font-size: 0.66rem;
  }

  .process-step-line {
    width: calc(100% - 4rem);
    margin: 0.72rem 0 0.95rem 3.2rem;
    height: 4px;
  }

  .mobile-swipe-rail--wide .mobile-swipe-card,
  .mobile-swipe-rail--tight .mobile-swipe-card {
    flex-basis: 72%;
    min-width: 72%;
  }

  .process-rail .mobile-swipe-card {
    flex-basis: 74%;
    min-width: 74%;
  }

  .subscription-rail .plan-card--pro {
    order: 1;
  }

  .subscription-rail .plan-card--standard {
    order: 2;
  }

  .subscription-rail .plan-card--start {
    order: 3;
  }

  #paketi .subscription-rail .mobile-swipe-card {
    flex-basis: 70%;
    min-width: 70%;
    scroll-snap-align: start;
  }

  .modular-layout {
    display: block;
  }

  .modular-gallery {
    margin-top: 1.2rem;
    padding-left: 0;
  }

  .modular-gallery-grid {
    display: flex !important;
    grid-template-columns: none !important;
  }
}

@media (max-width: 430px) {
  #gradovi .mobile-swipe-rail--cities .mobile-swipe-card {
    flex-basis: 76%;
    min-width: 76%;
  }

  .mobile-swipe-rail--wide .mobile-swipe-card,
  .mobile-swipe-rail--tight .mobile-swipe-card {
    flex-basis: 76%;
    min-width: 76%;
  }

  #paketi .subscription-rail .mobile-swipe-card {
    flex-basis: 74%;
    min-width: 74%;
  }
}


/* 2026-04-02 hero + modal polish */
@media (max-width: 767.98px) {
  .home-hero-pill {
    font-size: 0.74rem;
    padding: 0.62rem 0.94rem;
    gap: 0.46rem;
  }

  .home-hero-pill-dot {
    width: 0.56rem;
    height: 0.56rem;
  }

  .home-hero-title {
    max-width: 14ch;
    font-size: clamp(1.66rem, 7.8vw, 2.08rem);
    line-height: 1.16;
    letter-spacing: -0.028em;
    font-weight: 760;
  }

  .home-hero-actions {
    gap: 0.82rem;
    margin-top: 1.08rem;
  }

  .home-hero-link-row {
    margin-top: 0.98rem;
    padding-left: 0.28rem;
  }

  .home-hero-trustline {
    gap: 0.56rem;
    margin-top: 1.02rem;
  }

  .home-hero-helper-row {
    margin-top: 0.85rem;
  }

  .home-hero-helper-label {
    display: none;
  }

  .home-hero-helper-chips {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.6rem;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 0.2rem;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }

  .home-hero-helper-chips::-webkit-scrollbar {
    display: none;
  }

  .home-hero-helper-chip {
    flex: 0 0 auto;
    min-width: max-content;
    white-space: nowrap;
    padding: 0.62rem 0.82rem;
    border-radius: 999px;
    font-size: 0.74rem;
    line-height: 1.1;
    gap: 0.5rem;
  }

  .home-hero-helper-chip-icon {
    display: inline-flex;
  }
}


/* 2026-04-02 unified mobile swipe rails + contact heading */
@media (max-width: 767.98px) {
  .mobile-swipe-rail {
    gap: 0.88rem;
    padding-right: 0.6rem;
    scroll-padding-inline: 1rem;
  }

  .mobile-swipe-rail .mobile-swipe-card,
  .mobile-swipe-rail--wide .mobile-swipe-card,
  .mobile-swipe-rail--tight .mobile-swipe-card,
  .process-rail .mobile-swipe-card,
  .subscription-rail .mobile-swipe-card,
  #gradovi .mobile-swipe-rail--cities .mobile-swipe-card,
  #paketi .subscription-rail .mobile-swipe-card,
  .home-fastlinks-row .mobile-swipe-card {
    flex: 0 0 70%;
    min-width: 70%;
    max-width: 70%;
    scroll-snap-align: start;
  }

  #ponuda h2 {
    font-size: clamp(1.9rem, 8vw, 2.35rem);
    line-height: 1.08;
  }
}

@media (max-width: 430px) {
  .mobile-swipe-rail .mobile-swipe-card,
  .mobile-swipe-rail--wide .mobile-swipe-card,
  .mobile-swipe-rail--tight .mobile-swipe-card,
  .process-rail .mobile-swipe-card,
  .subscription-rail .mobile-swipe-card,
  #gradovi .mobile-swipe-rail--cities .mobile-swipe-card,
  #paketi .subscription-rail .mobile-swipe-card,
  .home-fastlinks-row .mobile-swipe-card {
    flex-basis: 70%;
    min-width: 70%;
    max-width: 70%;
  }
}


/* 2026-04-02 trustline + reference modal polish */
@media (max-width: 767.98px) {
  .home-hero-trustline {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.42rem;
    align-items: stretch;
  }

  .home-hero-trust-badge {
    min-width: 0;
    width: 100%;
    justify-content: center;
    text-align: center;
    padding: 0.54rem 0.38rem;
    font-size: 0.72rem;
    line-height: 1.22;
    gap: 0.3rem;
    border-radius: 1rem;
  }

  .home-hero-trust-badge i {
    font-size: 0.86rem;
  }

  .home-hero-trust-badge span {
    display: block;
    min-width: 0;
  }
}

/* 2026-04-02 process + modular + fastlinks polish */
.process-rail .process-step-card[data-step-index="1"] .process-step-line {
  background: linear-gradient(90deg, rgba(14,165,233,0.95) 0%, rgba(16,185,129,0.82) 100%);
  box-shadow: 0 10px 22px rgba(14,165,233,0.18);
}

.process-rail .process-step-card[data-step-index="2"] .process-step-line {
  background: linear-gradient(90deg, rgba(16,185,129,0.95) 0%, rgba(245,158,11,0.84) 100%);
  box-shadow: 0 10px 22px rgba(16,185,129,0.18);
}

.process-rail .process-step-card[data-step-index="3"] .process-step-line {
  background: linear-gradient(90deg, rgba(245,158,11,0.96) 0%, rgba(124,58,237,0.82) 100%);
  box-shadow: 0 10px 22px rgba(124,58,237,0.16);
}

.process-rail .process-step-card[data-step-index="4"] .process-step-line {
  display: none;
}

@media (min-width: 1024px) {
  .modular-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
    align-items: start;
  }

  .modular-gallery {
    margin-top: 0;
    padding-left: 1.25rem;
    align-self: start;
  }

  .modular-gallery-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 1rem !important;
    overflow: visible !important;
    white-space: normal !important;
  }
}

.modular-gallery-card {
  box-shadow: 0 20px 54px rgba(2, 6, 23, 0.26);
}

.modular-gallery-copy {
  left: 0.95rem;
  right: 0.95rem;
  bottom: 0.95rem;
  padding: 0.82rem 0.95rem 0.9rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 1.08rem;
  background: linear-gradient(180deg, rgba(15,23,42,0.26) 0%, rgba(15,23,42,0.72) 24%, rgba(15,23,42,0.92) 100%);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 16px 36px rgba(2, 6, 23, 0.24);
}

.modular-gallery-copy p:last-child {
  color: rgba(255, 255, 255, 0.98);
  text-shadow: 0 1px 10px rgba(2, 6, 23, 0.42);
}

.home-fastlink-title {
  font-weight: 700;
  text-shadow: 0 2px 14px rgba(2, 6, 23, 0.5);
}

@media (max-width: 767.98px) {
  .home-fastlink-content {
    padding: 0.78rem 0.84rem 0.84rem;
  }

  .home-fastlink-title {
    font-size: 0.94rem !important;
    line-height: 1.2;
    font-weight: 700 !important;
    letter-spacing: -0.01em;
  }

  .home-fastlink-card .text-sm.leading-7.text-slate-300 {
    font-size: 0.78rem;
    line-height: 1.5;
  }
}


/* 2026-04-02 hero city badge + trustline polish */
.home-hero-pill--cities {
  padding-inline: 0.82rem;
  font-size: 0.78rem;
  font-weight: 600;
}

.home-hero-pill--cities i {
  font-size: 0.92rem;
}

@media (max-width: 767.98px) {
  .home-hero-pill--cities-mobile {
    display: inline-flex;
    width: auto;
    max-width: 100%;
    justify-content: center;
    padding: 0.64rem 0.9rem;
    font-size: 0.72rem;
  }

  .home-hero-trust-badge {
    font-size: 0.68rem;
    gap: 0.28rem;
    padding: 0.5rem 0.28rem;
  }

  .home-hero-trust-badge span {
    white-space: nowrap;
  }
}
