:root {
      --bg: #071c35;
      --bg-soft: #0b3d7a;
      --primary: #0d58b1;
      --primary-2: #1f73d1;
      --accent: #f5f1ea;
      --text: #f7fbff;
      --text-soft: rgba(247, 251, 255, 0.84);
      --dark: #111827;
      --card: rgba(255, 255, 255, 0.12);
      --stroke: rgba(255, 255, 255, 0.14);
      --shadow: 0 20px 60px rgba(0, 0, 0, 0.28);
      --radius-xl: 32px;
      --radius-lg: 24px;
      --radius-md: 18px;
      --container: min(1200px, calc(100% - 32px));
      --nav-h: 82px;
    }

    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      margin: 0;
      font-family: "Manrope", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      color: var(--text);
      background:
        radial-gradient(circle at top right, rgba(255,255,255,.12), transparent 22%),
        linear-gradient(180deg, #edf4fb 0%, #d6e8fb 18%, #0c4f9d 42%, #0a3f7e 100%);
      overflow-x: hidden;
    }

    img {
      display: block;
      max-width: 100%;
      height: auto;
    }

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

    button,
    input {
      font: inherit;
    }

    .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;
    }

    .container {
      width: var(--container);
      margin-inline: auto;
    }

    /* Header */
    .site-header {
      position: sticky;
      top: 0;
      z-index: 1000;
      backdrop-filter: blur(16px);
      background: rgba(255, 255, 255, 0.8);
      border-bottom: 1px solid rgba(10, 63, 126, 0.12);
      box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
    }

    .site-header__inner {
      min-height: var(--nav-h);
      display: grid;
      grid-template-columns: auto 1fr auto;
      align-items: center;
      gap: 24px;
    }

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      font-weight: 800;
      color: var(--dark);
    }

    .brand__icon {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      display: grid;
      place-items: center;
      background: linear-gradient(135deg, #3f83f8, #a855f7);
      color: white;
      box-shadow: 0 12px 24px rgba(63, 131, 248, 0.28);
      flex-shrink: 0;
    }

    .brand__name {
      font-size: 1.02rem;
      letter-spacing: -0.02em;
    }

    .main-nav {
      display: flex;
      justify-content: center;
      gap: 26px;
      align-items: center;
    }

    .main-nav a {
      position: relative;
      color: #1f2937;
      font-weight: 600;
      padding: 8px 2px;
    }

    .main-nav a::after {
      content: "";
      position: absolute;
      left: 0;
      bottom: 0;
      width: 100%;
      height: 2px;
      background: linear-gradient(90deg, #0d58b1, #a855f7);
      transform: scaleX(0);
      transform-origin: left;
      transition: transform 0.35s ease;
    }

    .main-nav a:hover::after,
    .main-nav a:focus-visible::after {
      transform: scaleX(1);
    }

    .header-actions {
      display: flex;
      align-items: center;
      gap: 14px;
    }

    .search {
      position: relative;
      min-width: min(360px, 42vw);
    }

    .search svg {
      position: absolute;
      left: 16px;
      top: 50%;
      transform: translateY(-50%);
      color: #0a3f7e;
      opacity: 0.85;
      pointer-events: none;
    }

    .search input {
      width: 100%;
      height: 46px;
      padding: 0 16px 0 46px;
      border-radius: 999px;
      border: 2px solid rgba(10, 63, 126, 0.85);
      background: rgba(255, 255, 255, 0.92);
      color: #0f172a;
      outline: none;
      transition: box-shadow 0.25s ease, transform 0.25s ease;
    }

    .search input:focus {
      box-shadow: 0 0 0 6px rgba(13, 88, 177, 0.12);
      transform: translateY(-1px);
    }

    .btn,
    .btn-secondary {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      min-height: 48px;
      padding: 0 24px;
      border-radius: 999px;
      border: none;
      cursor: pointer;
      font-weight: 800;
      letter-spacing: -0.01em;
      transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
      will-change: transform;
    }

    .btn {
      color: #fff;
      background: linear-gradient(135deg, #0d58b1, #0a468d);
      box-shadow: 0 12px 30px rgba(10, 70, 141, 0.25);
    }

    .btn:hover,
    .btn:focus-visible,
    .btn-secondary:hover,
    .btn-secondary:focus-visible {
      transform: translateY(-2px);
    }

    .btn-secondary {
      color: #0f172a;
      background: #f5f1ea;
      box-shadow: 0 10px 24px rgba(245, 241, 234, 0.2);
    }

    /* Hero */
    .hero {
      position: relative;
      min-height: calc(100svh - var(--nav-h));
      display: flex;
      align-items: center;
      overflow: clip;
      background-image: linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)), url(images/background.jpg);
      background-size: cover;
      background-position: center;
    }

    .hero::before {
      content: "";
      position: absolute;
      inset: auto -10% -10% auto;
      width: 560px;
      height: 560px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(168,85,247,0.20), transparent 62%);
      filter: blur(30px);
      pointer-events: none;
    }

    .hero__world {
      position: absolute;
      inset: 4% 0 0 0;
      display: grid;
      place-items: center;
      pointer-events: none;
      opacity: 0.62;
      filter: saturate(0.9);
    }

    .hero__world svg {
      width: min(1100px, 94vw);
      height: auto;
    }

    .hero__pins {
      position: absolute;
      inset: 0;
      pointer-events: none;
    }

    .pin {
      position: absolute;
      width: clamp(52px, 7vw, 88px);
      aspect-ratio: 1;
      filter: drop-shadow(0 16px 18px rgba(0, 0, 0, 0.18));
      animation: floatPin 5s ease-in-out infinite;
    }

    .pin:nth-child(2) { animation-delay: -1s; }
    .pin:nth-child(3) { animation-delay: -2s; }
    .pin:nth-child(4) { animation-delay: -3s; }
    .pin:nth-child(5) { animation-delay: -1.5s; }

    .hero__content {
      position: relative;
      z-index: 2;
      width: var(--container);
      margin-inline: auto;
      padding: 120px 0 90px;
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 10px 14px;
      border-radius: 999px;
      background: rgba(255,255,255,0.12);
      border: 1px solid rgba(255,255,255,0.16);
      backdrop-filter: blur(8px);
      font-size: 0.92rem;
      font-weight: 700;
      margin-bottom: 18px;
    }

    h1,
    h2,
    h3 {
      margin: 0;
      line-height: 1;
      letter-spacing: -0.04em;
    }

    h1 {
      font-size: clamp(3.25rem, 8vw, 6.2rem);
      max-width: 8ch;
      text-wrap: balance;
      text-shadow: 0 10px 30px rgba(0, 0, 0, 0.16);
    }

    .hero h1 span,
    .section-title span {
      font-family: "Libre Caslon Text", Georgia, serif;
      font-style: italic;
      font-weight: 700;
    }

    .hero__lead {
      max-width: 640px;
      font-size: clamp(1.08rem, 1.8vw, 1.46rem);
      line-height: 1.6;
      color: var(--text-soft);
      margin: 22px 0 34px;
      text-wrap: pretty;
    }

    .hero__cta {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 14px;
    }

    .hero__meta {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
      margin-top: 42px;
      max-width: 760px;
    }

    .meta-card {
      padding: 18px 18px 16px;
      border-radius: var(--radius-md);
      background: linear-gradient(180deg, rgba(255,255,255,0.14), rgba(255,255,255,0.08));
      border: 1px solid rgba(255,255,255,0.16);
      backdrop-filter: blur(10px);
      box-shadow: var(--shadow);
    }

    .meta-card strong {
      display: block;
      font-size: 1.45rem;
      margin-bottom: 8px;
    }

    .meta-card span {
      color: var(--text-soft);
      font-size: 0.95rem;
      line-height: 1.5;
    }

    /* Sections */
    main {
      position: relative;
      z-index: 1;
    }

    .section {
      position: relative;
      padding: 88px 0;
    }

    .section--info {
      background: linear-gradient(180deg, #0f56a8 0%, #0a3f7e 100%);
      overflow: clip;
    }

    .section--info::before,
    .section--popular::before {
      content: "";
      position: absolute;
      inset: auto auto -120px -120px;
      width: 360px;
      height: 360px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(255,255,255,0.18), transparent 68%);
      filter: blur(40px);
      pointer-events: none;
    }

    .section-grid {
      display: grid;
      grid-template-columns: 1.2fr 0.8fr;
      gap: 40px;
      align-items: center;
    }

    .section-kicker {
      display: inline-block;
      font-size: 0.95rem;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: rgba(255,255,255,0.72);
      margin-bottom: 14px;
    }

    .section-title {
      font-size: clamp(2rem, 5vw, 4rem);
      margin-bottom: 18px;
      text-wrap: balance;
    }

    .section-text {
      font-size: 1.12rem;
      line-height: 1.8;
      color: var(--text-soft);
      max-width: 68ch;
      text-wrap: pretty;
    }

    .info-card {
      position: relative;
      padding: 28px;
      border-radius: var(--radius-xl);
      background: linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.08));
      border: 1px solid var(--stroke);
      box-shadow: var(--shadow);
      backdrop-filter: blur(14px);
    }

    .info-card__visual {
      display: grid;
      place-items: center;
      min-height: 280px;
    }

    .map-badge {
      width: min(260px, 70%);
      filter: drop-shadow(0 22px 20px rgba(0, 0, 0, 0.22));
      transform: translateY(0);
      animation: badgeHover 6s ease-in-out infinite;
    }

    /* Map */
    .map-section {
      background: #f5f7fb;
      color: #0f172a;
      padding-top: 0;
    }

    .map-header {
      padding: 20px 0 16px;
    }

    .map-label {
      color: #111827;
      font-weight: 800;
      font-size: 1.25rem;
    }

    .map-wrap {
      position: relative;
      border-radius: 0;
      overflow: hidden;
      min-height: 540px;
      border-top: 1px solid rgba(15, 23, 42, 0.08);
      border-bottom: 1px solid rgba(15, 23, 42, 0.08);
      background: #dbeafe;
    }

    #map {
      width: 100%;
      height: 540px;
      z-index: 1;
    }

    .map-overlay {
      position: absolute;
      top: 20px;
      left: 20px;
      z-index: 2;
      max-width: min(360px, calc(100% - 40px));
      padding: 18px 18px 16px;
      background: rgba(255, 255, 255, 0.92);
      backdrop-filter: blur(12px);
      border: 1px solid rgba(15, 23, 42, 0.08);
      border-radius: 20px;
      box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
    }

    .map-overlay h3 {
      color: #111827;
      font-size: 1.05rem;
      margin-bottom: 8px;
      line-height: 1.3;
    }

    .map-overlay p {
      color: #334155;
      line-height: 1.6;
      margin: 0;
      font-size: 0.96rem;
    }

    /* Popular */
    .section--popular {
      background:
        radial-gradient(circle at right top, rgba(255,255,255,0.08), transparent 24%),
        linear-gradient(180deg, #0d58b1 0%, #0a3f7e 100%);
      overflow: clip;
    }

    .popular-head {
      display: flex;
      align-items: end;
      justify-content: space-between;
      gap: 24px;
      margin-bottom: 34px;
    }

    .popular-head p {
      margin: 8px 0 0;
      color: var(--text-soft);
      font-size: 1.05rem;
    }

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

    .place-card {
      position: relative;
      overflow: hidden;
      border-radius: 34px;
      background: rgba(255,255,255,0.08);
      border: 1px solid rgba(255,255,255,0.12);
      min-height: 420px;
      box-shadow: var(--shadow);
      transform-style: preserve-3d;
      isolation: isolate;
    }

    .place-card::before {
      content: "";
      position: absolute;
      inset: auto 0 0 0;
      height: 55%;
      background: linear-gradient(180deg, transparent, rgba(0,0,0,0.58));
      z-index: 1;
    }

    .place-card img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      transform: scale(1.02);
      transition: transform 0.6s ease;
    }

    .place-card:hover img,
    .place-card:focus-within img {
      transform: scale(1.08);
    }

    .place-card__content {
      position: absolute;
      inset: auto 0 0 0;
      z-index: 2;
      padding: 24px;
    }

    .place-card__tag {
      display: inline-flex;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(255,255,255,0.18);
      border: 1px solid rgba(255,255,255,0.14);
      backdrop-filter: blur(8px);
      font-size: 0.86rem;
      font-weight: 700;
      margin-bottom: 12px;
    }

    .place-card h3 {
      font-size: 1.7rem;
      line-height: 1.12;
      margin-bottom: 10px;
      text-wrap: balance;
    }

    .place-card p {
      margin: 0;
      color: rgba(255,255,255,0.86);
      line-height: 1.6;
    }

    /* Footer */
    .site-footer {
      position: relative;
      background: #082d58;
      color: rgba(255,255,255,0.88);
      border-top: 1px solid rgba(255,255,255,0.08);
    }

    .site-footer__inner {
      min-height: 92px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
      flex-wrap: wrap;
      padding: 16px 0;
    }

    .footer-links {
      display: flex;
      gap: 18px;
      flex-wrap: wrap;
    }

    .footer-links a {
      opacity: 0.9;
    }

    .back-top {
      position: fixed;
      right: 18px;
      bottom: 18px;
      z-index: 999;
      width: 58px;
      height: 58px;
      border-radius: 50%;
      border: 1px solid rgba(255,255,255,0.18);
      background: rgba(7, 28, 53, 0.78);
      color: white;
      backdrop-filter: blur(14px);
      box-shadow: 0 12px 30px rgba(0, 0, 0, 0.22);
      display: grid;
      place-items: center;
      opacity: 0;
      visibility: hidden;
      transform: translateY(12px);
      transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease;
    }

    .back-top.is-visible {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
    }

    /* Reveal Animations */
    [data-reveal] {
      opacity: 0;
      transform: translateY(42px) scale(0.98);
      transition:
        opacity 0.9s cubic-bezier(.2,.8,.2,1),
        transform 0.9s cubic-bezier(.2,.8,.2,1),
        filter 0.9s cubic-bezier(.2,.8,.2,1);
      filter: blur(12px);
      will-change: transform, opacity, filter;
    }

    [data-reveal].is-visible {
      opacity: 1;
      transform: translateY(0) scale(1);
      filter: blur(0);
    }

    [data-stagger] > * {
      transition-delay: calc(var(--i, 0) * 110ms);
    }

    /* Responsive */
    @media (max-width: 1080px) {
      .site-header__inner {
        grid-template-columns: 1fr;
        padding: 14px 0;
      }

      .main-nav {
        justify-content: flex-start;
        overflow-x: auto;
        padding-bottom: 4px;
      }

      .header-actions {
        justify-content: space-between;
      }

      .search {
        min-width: 0;
        width: 100%;
      }

      .hero__meta,
      .section-grid,
      .cards {
        grid-template-columns: 1fr;
      }

      .popular-head {
        align-items: start;
        flex-direction: column;
      }
    }

    @media (max-width: 720px) {
      :root {
        --container: min(100% - 24px, 1200px);
        --nav-h: 76px;
      }

      .brand__name {
        display: none;
      }

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

      .btn {
        width: 100%;
      }

      .hero__content {
        padding: 86px 0 56px;
      }

      .hero__cta {
        flex-direction: column;
        align-items: stretch;
      }

      .meta-card,
      .info-card {
        padding: 20px;
      }

      .map-wrap,
      #map {
        min-height: 420px;
        height: 420px;
      }

      .place-card {
        min-height: 360px;
        border-radius: 24px;
      }

      .site-footer__inner {
        justify-content: center;
        text-align: center;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto !important;
      }

      [data-reveal] {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
      }
    }

    @keyframes floatPin {
      0%, 100% { transform: translateY(0px) rotate(0deg); }
      50% { transform: translateY(-10px) rotate(1.5deg); }
    }

    @keyframes badgeHover {
      0%, 100% { transform: translateY(0px); }
      50% { transform: translateY(-8px); }
    }