:root {
    --bg: #f4f8ff;
    --bg-soft: #edf4ff;
    --surface: rgba(255, 255, 255, 0.96);
    --surface-strong: #ffffff;
    --surface-blue: #eff6ff;
    --ink: #0f172a;
    --muted: #64748b;
    --line: rgba(148, 163, 184, 0.22);
    --line-strong: rgba(148, 163, 184, 0.34);
    --primary: #2563eb;
    --primary-strong: #1d4ed8;
    --primary-soft: rgba(37, 99, 235, 0.1);
    --accent: #60a5fa;
    --accent-soft: rgba(96, 165, 250, 0.12);
    --success-soft: rgba(37, 99, 235, 0.08);
    --money: #2563eb;
    --warning-soft: rgba(245, 158, 11, 0.12);
    --danger-soft: rgba(239, 68, 68, 0.1);
    --shadow-xl: 0 24px 52px rgba(15, 23, 42, 0.08);
    --shadow-lg: 0 16px 30px rgba(15, 23, 42, 0.06);
    --shadow-soft: 0 8px 18px rgba(15, 23, 42, 0.05);
    --radius-2xl: 28px;
    --radius-xl: 22px;
    --radius-lg: 18px;
    --radius-md: 16px;
    --radius-sm: 12px;
    --page-width: 1260px;
    --display-font: "Plus Jakarta Sans", "Segoe UI", sans-serif;
    --body-font: "Manrope", "Segoe UI", sans-serif;
    --mono-font: "Plus Jakarta Sans", "Segoe UI", sans-serif;
    --ease-standard: cubic-bezier(0.22, 1, 0.36, 1);
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--body-font);
    color: var(--ink);
    background:
        radial-gradient(circle at 12% 14%, rgba(96, 165, 250, 0.18), transparent 22%),
        radial-gradient(circle at 84% 8%, rgba(191, 219, 254, 0.42), transparent 18%),
        linear-gradient(180deg, #ffffff 0%, var(--bg) 100%);
    min-height: 100vh;
}

body.is-loading * {
    transition: none !important;
}

.site-backdrop {
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 20% 22%, rgba(255, 255, 255, 0.7), transparent 34%),
        radial-gradient(circle at 80% 76%, rgba(219, 234, 254, 0.28), transparent 28%),
        repeating-linear-gradient(90deg, rgba(148, 163, 184, 0.028), rgba(148, 163, 184, 0.028) 1px, transparent 1px, transparent 88px);
    opacity: 0.88;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.7), transparent 84%);
}

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

button,
input {
    font: inherit;
}

button,
a,
input {
    -webkit-tap-highlight-color: transparent;
}

button {
    border: 0;
    background: none;
}

:focus-visible {
    outline: 2px solid rgba(37, 99, 235, 0.32);
    outline-offset: 3px;
}

input::placeholder {
    color: rgba(100, 116, 139, 0.85);
}

.page-shell {
    position: relative;
    z-index: 1;
    width: min(calc(100% - 30px), var(--page-width));
    margin: 0 auto;
    padding: 0;
}

.topbar {
    position: relative;
    z-index: 5;
    display: grid;
    grid-template-columns: auto auto 1fr;
    align-items: center;
    justify-content: start;
    gap: 18px;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    padding: 16px max(16px, calc((100vw - var(--page-width)) / 2 + 15px));
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-left: 0;
    border-right: 0;
    border-top: 0;
    border-radius: 0;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.08);
    backdrop-filter: blur(14px);
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    padding: 6px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(37, 99, 235, 0.12);
    box-shadow: 0 14px 28px rgba(37, 99, 235, 0.08);
    overflow: hidden;
    flex-shrink: 0;
}

.brand-mark__image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.brand-copy {
    display: grid;
    gap: 4px;
}

.brand-text {
    display: inline-flex;
    align-items: baseline;
    font-family: var(--display-font);
    font-size: 1.06rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    text-transform: none;
}

.brand-text-primary,
.brand-text-secondary,
.brand-text-divider {
    color: inherit;
    font: inherit;
}

.brand-text-divider {
    margin-inline: 0.34rem;
}

.brand-tagline {
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.73rem;
    letter-spacing: 0;
    text-transform: none;
}

.topbar-nav {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 16px;
    color: var(--muted);
    font-family: var(--body-font);
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
}

.topbar-nav a {
    position: relative;
    transition: color 180ms var(--ease-standard);
}

.topbar-nav a:hover,
.topbar-nav a:focus-visible {
    color: var(--primary);
}

.topbar-action,
.primary-button,
.ghost-button,
.cookie-button,
.hero-country-button,
.faq-topic-button {
    transition:
        transform 180ms var(--ease-standard),
        box-shadow 180ms var(--ease-standard),
        border-color 180ms var(--ease-standard),
        background-color 180ms var(--ease-standard),
        color 180ms var(--ease-standard),
        opacity 180ms var(--ease-standard);
}

.topbar-action,
.primary-button,
.cookie-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 13px 20px;
    border-radius: 999px;
    border: 1px solid rgba(37, 99, 235, 0.06);
    background: linear-gradient(135deg, var(--primary) 0%, #3b82f6 100%);
    color: white;
    font-weight: 800;
    box-shadow: 0 12px 24px rgba(37, 99, 235, 0.18);
    text-transform: none;
    letter-spacing: 0;
}

.ghost-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 13px 20px;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.98);
    color: var(--ink);
    font-weight: 700;
    text-transform: none;
    letter-spacing: 0;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.03);
}

.topbar-action:hover,
.primary-button:hover,
.cookie-button:hover,
.ghost-button:hover,
.hero-country-button:hover,
.faq-topic-button:hover {
    transform: translateY(-2px);
}

main {
    display: grid;
    gap: 72px;
    margin-top: 24px;
}

.hero,
.steps-section,
.journey-section,
.benefits-section,
.reviews-section,
.faq-section,
.catalog-section,
.support-card,
.site-footer {
    position: relative;
    overflow: visible;
    padding: 0;
    border-radius: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
    transition:
        opacity 420ms var(--ease-standard),
        transform 420ms var(--ease-standard);
}

body.is-loading .hero,
body.is-loading .steps-section,
body.is-loading .journey-section,
body.is-loading .benefits-section,
body.is-loading .reviews-section,
body.is-loading .faq-section,
body.is-loading .catalog-section,
body.is-loading .countries-page-hero,
body.is-loading .country-detail-hero,
body.is-loading .support-card {
    opacity: 0.72;
    transform: translateY(10px);
}

body.is-loading .topbar-progress {
    transition:
        opacity 180ms var(--ease-standard),
        transform 180ms var(--ease-standard) !important;
}

body.is-loading .topbar-progress__bar {
    transition: width 260ms var(--ease-standard) !important;
}

.topbar-progress {
    position: relative;
    z-index: 4;
    width: 100vw;
    height: 4px;
    margin-left: calc(50% - 50vw);
    overflow: hidden;
    background:
        linear-gradient(90deg, rgba(191, 219, 254, 0.14), rgba(191, 219, 254, 0.32), rgba(191, 219, 254, 0.14));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.62),
        0 10px 28px rgba(37, 99, 235, 0.06);
    opacity: 0;
    transform: scaleY(0.72);
    transform-origin: center top;
    pointer-events: none;
    transition:
        opacity 180ms var(--ease-standard),
        transform 180ms var(--ease-standard);
}

.topbar-progress[hidden] {
    display: none;
}

.topbar-progress.is-active,
.topbar-progress.is-complete {
    opacity: 1;
    transform: scaleY(1);
}

.topbar-progress__bar {
    display: block;
    width: 0;
    height: 100%;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.44), rgba(255, 255, 255, 0) 34%) no-repeat,
        linear-gradient(90deg, #2563eb 0%, #3b82f6 46%, #93c5fd 100%);
    background-size: 140px 100%, 100% 100%;
    box-shadow:
        0 0 22px rgba(37, 99, 235, 0.22),
        0 0 8px rgba(96, 165, 250, 0.3);
    transition: width 260ms var(--ease-standard) !important;
    animation: topbar-progress-sheen 1.2s linear infinite;
}

.topbar-progress.is-complete .topbar-progress__bar {
    transition-duration: 160ms !important;
}

.page-loading-shell {
    position: relative;
    display: grid;
}

.page-loading-shell[aria-busy="false"] .page-loading-overlay {
    display: none;
}

.countries-page-shell .page-loading-shell {
    gap: 20px;
}

.country-page-shell .page-loading-shell {
    gap: 56px;
}

.page-loading-blurable {
    transition:
        filter 220ms var(--ease-standard),
        opacity 220ms var(--ease-standard),
        transform 220ms var(--ease-standard);
}

body.is-loading .page-loading-shell .page-loading-blurable {
    filter: blur(14px);
    opacity: 0.42;
    transform: scale(0.994);
    pointer-events: none;
    user-select: none;
}

.page-loading-overlay {
    position: absolute;
    inset: 0;
    z-index: 7;
    display: grid;
    align-content: start;
    justify-items: center;
    gap: 14px;
    padding: 42px 24px 24px;
    text-align: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 220ms var(--ease-standard);
}

body.is-loading .page-loading-overlay {
    opacity: 1;
}

.page-loading-overlay strong {
    font-size: clamp(1.2rem, 2vw, 1.55rem);
    line-height: 1.15;
}

.page-loading-overlay p {
    max-width: 42ch;
    margin: 0;
    color: var(--muted);
    line-height: 1.72;
}

.page-loading-overlay__spinner {
    width: 68px;
    height: 68px;
    border-radius: 50%;
    border: 5px solid rgba(191, 219, 254, 0.72);
    border-top-color: var(--primary);
    box-shadow: 0 18px 34px rgba(37, 99, 235, 0.14);
    animation: activation-spin 900ms linear infinite;
}

.hero::before,
.journey-section::before,
.support-card::before {
    display: none;
}

.seo-copy-section {
    padding: 0;
}

.seo-copy {
    display: grid;
    gap: 14px;
    max-width: 920px;
    margin: 0 auto;
}

.seo-copy h2 {
    margin: 0;
    font-family: var(--display-font);
    font-size: clamp(1.32rem, 2.2vw, 1.82rem);
    letter-spacing: -0.03em;
}

.seo-copy p {
    margin: 0;
    color: #334155;
    font-size: 0.98rem;
    line-height: 1.72;
}

.hero::before {
    display: none;
}

.journey-section::before {
    width: 220px;
    height: 220px;
    left: -90px;
    bottom: -80px;
}

.support-card::before {
    display: none;
}

.hero {
    display: block;
    overflow: visible;
    z-index: 3;
    padding: 12px 0 0;
    background: transparent;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    padding-inline: max(16px, calc((100vw - var(--page-width)) / 2 + 15px));
}

.hero::after {
    display: none;
}

.hero-copy {
    display: grid;
    gap: 20px;
    align-content: start;
}

.hero-copy--centered {
    justify-items: stretch;
    text-align: left;
}

.eyebrow {
    margin: 0;
    color: var(--primary);
    font-family: var(--mono-font);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

h1,
h2,
h3,
p {
    margin: 0;
}

h1 {
    max-width: none;
    font-family: var(--display-font);
    font-size: clamp(2.5rem, 4.6vw, 4.6rem);
    line-height: 0.96;
    letter-spacing: -0.04em;
    text-transform: none;
}

h2 {
    font-family: var(--display-font);
    font-size: clamp(1.95rem, 3vw, 2.9rem);
    line-height: 0.98;
    letter-spacing: -0.03em;
    text-transform: none;
}

h3 {
    font-family: var(--display-font);
    font-size: 1.16rem;
    line-height: 1.15;
    letter-spacing: -0.02em;
    text-transform: none;
}

.hero-lead,
.section-copy,
.section-heading p,
.step-text,
.benefit-text,
.review-text,
.review-trip,
.faq-answer,
.status-banner,
.support-link span,
.support-link small,
.footer-legal,
.cookie-copy p,
.phone-copy,
.float-card p {
    color: var(--muted);
    line-height: 1.72;
}

.search-panel {
    display: grid;
    gap: 12px;
}

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

.hero-search-layout {
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    gap: 20px;
    width: min(100%, 640px);
}

.search-panel--compact {
    width: min(100%, 620px);
    flex: 1 1 620px;
}

.search-heading {
    font-size: 1.15rem;
    font-weight: 700;
}

.search-heading--compact {
    font-size: 0.96rem;
    color: var(--muted);
}

.search-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(148, 163, 184, 0.24);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.8),
        0 8px 18px rgba(15, 23, 42, 0.04);
}

.search-row::before {
    content: "";
    flex: none;
    width: 18px;
    height: 18px;
    margin-left: 6px;
    background:
        center / contain no-repeat
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2360708d' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E");
    opacity: 0.88;
}

.search-row--compact {
    gap: 10px;
    padding: 8px;
    border-radius: 20px;
}

.search-row:focus-within {
    border-color: rgba(37, 99, 235, 0.34);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.82),
        0 12px 24px rgba(37, 99, 235, 0.1);
}

.search-row input {
    width: 100%;
    min-height: 52px;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--ink);
}

.search-row--compact input {
    min-height: 37px;
    padding: 0 10px 0 0;
}

.search-submit-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 20px;
    border-radius: 999px;
    border: 1px solid rgba(37, 99, 235, 0.08);
    background: linear-gradient(135deg, var(--primary), #3b82f6);
    color: white;
    font-weight: 800;
    cursor: pointer;
    box-shadow: 0 12px 24px rgba(37, 99, 235, 0.16);
    text-transform: none;
    letter-spacing: 0;
}

.hero-title {
    width: 100%;
    max-width: none;
    font-size: clamp(1.2rem, 2.4vw, 2.3rem);
    text-wrap: pretty;
}

.hero-title-line {
    display: inline;
}

.hero-title-line--mobile-break {
    margin-left: 0.24em;
}

.hero-random-line {
    max-width: min(100%, 680px);
    margin-top: -5px;
    padding: 0;
    border-radius: 0;
    border-left: 0;
    background: transparent;
    color: #334155;
    font-family: var(--body-font);
    font-size: clamp(0.98rem, 1.3vw, 1.12rem);
    font-style: normal;
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1.55;
    text-transform: none;
    box-shadow: none;
}

.arrival-inline-hint {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    padding: 0;
    border-radius: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    max-width: none;
    min-height: 42px;
    text-align: left;
    flex: 0 0 auto;
}

.arrival-inline-hint__text {
    color: #334155;
    font-family: var(--body-font);
    font-size: 0.84rem;
    line-height: 1.45;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
    white-space: nowrap;
}

.arrival-inline-hint__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    padding: 0;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.22);
    background: rgba(239, 246, 255, 0.98);
    color: var(--primary);
    font-size: 0.95rem;
    font-weight: 800;
    cursor: pointer;
    box-shadow: none;
}

.arrival-inline-hint__button:hover,
.arrival-inline-hint__button:focus-visible {
    border-color: rgba(37, 99, 235, 0.28);
    box-shadow: 0 8px 18px rgba(37, 99, 235, 0.08);
    outline: none;
}

.arrival-inline-hint__popover {
    position: absolute;
    top: calc(100% + 12px);
    left: 0;
    width: min(320px, calc(100vw - 40px));
    padding: 14px 16px;
    border-radius: 16px;
    background: rgba(15, 23, 42, 0.96);
    color: white;
    font-size: 0.84rem;
    line-height: 1.55;
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.22);
    z-index: 5;
}

.arrival-inline-hint__popover[hidden] {
    display: none;
}

.hero-country-grid {
    display: grid;
    width: 100%;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0 24px;
}

.hero-country-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px 0;
    border: 0;
    border-radius: 0;
    border-bottom: 1px solid rgba(148, 163, 184, 0.16);
    background: transparent;
    cursor: pointer;
    text-align: left;
    box-shadow: none;
}

.hero-country-button.is-active,
.hero-country-button:focus-visible {
    border-color: rgba(37, 99, 235, 0.28);
    box-shadow: none;
    outline: none;
}

.hero-country-button:hover {
    transform: none;
}

.hero-country-button--empty {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 4px;
    cursor: default;
}

.hero-country-button--empty .hero-country-name {
    display: block;
    color: var(--ink);
    font-family: var(--body-font);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.35;
}

.hero-country-button--empty .hero-country-price {
    color: var(--ink);
    font-family: var(--body-font);
    font-size: 0.84rem;
    font-weight: 400;
    line-height: 1.35;
    text-align: left;
    white-space: normal;
}

.hero-country-name {
    display: flex;
    align-items: center;
    justify-items: start;
    gap: 12px;
    min-width: 0;
}

.hero-country-flag,
.country-directory-emoji,
.country-emoji {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 1), rgba(239, 246, 255, 0.98));
    border: 1px solid rgba(191, 219, 254, 0.9);
    box-shadow: 0 8px 18px rgba(37, 99, 235, 0.06);
    line-height: 1;
    font-size: 1.5rem;
    flex: none;
}

.hero-country-label {
    font-family: var(--display-font);
    font-weight: 600;
    line-height: 1.3;
    font-size: 1rem;
}

.hero-country-price {
    color: var(--ink);
    font-family: var(--mono-font);
    font-size: 0.86rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
    text-align: right;
    white-space: nowrap;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.hero-actions--split {
    position: relative;
    z-index: 2;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    padding-top: 10px;
}

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

.hero-stat-card {
    padding: 18px;
    border-radius: 18px;
    background: var(--surface-blue);
    border: 1px solid rgba(191, 219, 254, 0.9);
}

.hero-stat-value {
    display: block;
    font-family: var(--display-font);
    font-size: 1.4rem;
    font-weight: 800;
    margin-bottom: 4px;
}

.hero-stat-label {
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.74rem;
    letter-spacing: 0;
    text-transform: none;
}

.hero-visual {
    display: grid;
    place-items: center;
}

.phone-shell {
    position: relative;
    width: min(100%, 430px);
    padding: 22px;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 248, 255, 0.98));
    border: 1px solid rgba(191, 219, 254, 0.92);
    box-shadow: 0 22px 40px rgba(15, 23, 42, 0.08);
}

.phone-top {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 18px;
}

.phone-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(37, 99, 235, 0.18);
}

.phone-card {
    display: grid;
    gap: 14px;
    padding: 22px;
    border-radius: 20px;
    background: var(--surface-strong);
    border: 1px solid rgba(148, 163, 184, 0.16);
}

.mini-label,
.panel-badge {
    display: inline-flex;
    width: fit-content;
    padding: 8px 12px;
    border-radius: 999px;
    background: var(--primary-soft);
    color: var(--primary);
    font-family: var(--mono-font);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: none;
}

.phone-title {
    font-size: 1.5rem;
}

.phone-route {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.route-stop,
.phone-stat-card {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 18px;
    background: var(--surface-blue);
}

.route-arrow {
    color: var(--primary);
    font-weight: 700;
}

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

.phone-stat-card strong {
    display: block;
    font-size: 1rem;
}

.phone-stat-card span {
    color: var(--muted);
    font-size: 0.9rem;
}

.float-card {
    position: absolute;
    display: flex;
    align-items: start;
    gap: 12px;
    max-width: 220px;
    padding: 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(191, 219, 254, 0.92);
    box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
}

.float-card-primary {
    left: -36px;
    bottom: 72px;
}

.float-card-secondary {
    right: -22px;
    top: 76px;
}

.float-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 42px;
    border-radius: 12px;
    background: var(--accent-soft);
    font-size: 1.1rem;
}

.float-card strong {
    display: block;
    margin-bottom: 4px;
}

.section-heading {
    display: grid;
    gap: 8px;
    max-width: 720px;
}

.section-heading::before {
    display: none;
}

.section-heading > p:not(.eyebrow) {
    max-width: 62ch;
}

.steps-grid,
.benefits-grid,
.review-grid,
.countries-grid {
    display: grid;
    gap: 18px;
}

.steps-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px 26px;
    margin-top: 24px;
}

.steps-section--home .steps-grid {
    width: min(100%, 900px);
    justify-self: center;
    gap: 22px 32px;
}

.steps-section--home .section-heading h2,
.faq-section--home .section-heading h2 {
    font-size: clamp(1.3rem, 2vw, 1.95rem);
    line-height: 1.08;
    letter-spacing: -0.02em;
}

.step-card,
.benefit-card,
.review-card,
.country-card,
.faq-item,
.support-link,
.review-badge,
.journey-panel {
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.step-card,
.benefit-card,
.review-card,
.country-card {
    position: relative;
    padding: 20px 0 8px;
    overflow: hidden;
}

.steps-section--home .step-card {
    display: grid;
    align-content: start;
    min-height: 236px;
    padding: 28px 0 20px;
}

.step-card::after,
.benefit-card::after,
.review-card::after,
.country-card::after {
    display: none;
}

.step-card,
.benefit-card,
.review-card,
.country-card,
.review-badge {
    transition:
        transform 180ms var(--ease-standard),
        box-shadow 180ms var(--ease-standard),
        border-color 180ms var(--ease-standard);
}

.step-card:hover,
.benefit-card:hover,
.review-card:hover,
.country-card:hover,
.review-badge:hover,
.step-card:focus-within,
.benefit-card:focus-within,
.review-card:focus-within,
.country-card:focus-within,
.review-badge:focus-within {
    transform: translateY(0);
    border-color: transparent;
    box-shadow: none;
}

.step-number,
.benefit-icon,
.country-emoji {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: rgba(239, 246, 255, 0.96);
    border: 1px solid rgba(191, 219, 254, 0.92);
    color: var(--primary);
    font-family: var(--mono-font);
    font-weight: 800;
    margin-bottom: 14px;
}

.step-title,
.benefit-title,
.country-name {
    margin-bottom: 8px;
}

.step-card-action {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    justify-self: start;
    margin-top: 10px;
    padding: 0;
    border: 0;
    border-bottom: 1px solid rgba(37, 99, 235, 0.18);
    border-radius: 0;
    background: transparent;
    color: #64748b;
    font-family: var(--body-font);
    font-size: 0.92rem;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.25;
    box-shadow: none;
    transition:
        color 180ms var(--ease-standard),
        border-color 180ms var(--ease-standard),
        transform 180ms var(--ease-standard);
}

.step-card-action::after {
    content: "›";
    font-size: 1rem;
    line-height: 1;
}

.step-card-action:hover,
.step-card-action:focus-visible {
    color: var(--primary);
    border-bottom-color: rgba(37, 99, 235, 0.42);
    transform: translateX(2px);
}

.journey-section {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    gap: 28px;
    align-items: center;
    background: transparent;
}

.journey-copy {
    display: grid;
    gap: 18px;
}

.journey-highlights {
    display: grid;
    gap: 12px;
}

.journey-highlight,
.journey-item {
    display: flex;
    align-items: start;
    gap: 12px;
    padding: 12px 0;
    border-radius: 0;
    background: transparent;
    border: 0;
}

.journey-highlight::before,
.journey-item-icon {
    content: "•";
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--primary-soft);
    color: var(--primary);
    font-weight: 800;
}

.journey-panel {
    display: grid;
    gap: 16px;
    padding: 0;
    box-shadow: none;
    background: transparent;
}

.journey-panel-header {
    display: grid;
    gap: 12px;
}

.journey-list {
    display: grid;
    gap: 12px;
}

.journey-item strong {
    display: block;
    margin-bottom: 4px;
}

.benefits-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px 26px;
    margin-top: 24px;
}

.reviews-section {
    display: grid;
    gap: 20px;
}

.review-badges {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px 26px;
}

.review-badge {
    display: grid;
    gap: 6px;
    padding: 0;
    border-left: 0;
}

.review-badge strong {
    font-family: var(--display-font);
    font-size: 1.65rem;
    line-height: 1;
}

.review-badge span {
    color: var(--muted);
}

.review-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px 26px;
}

.steps-section .section-heading,
.benefits-section .section-heading,
.reviews-section .section-heading,
.faq-section .section-heading,
.support-card .section-heading {
    max-width: none;
    justify-items: center;
    text-align: center;
}

.steps-section .section-heading > p:not(.eyebrow),
.benefits-section .section-heading > p:not(.eyebrow),
.reviews-section .section-heading > p:not(.eyebrow),
.faq-section .section-heading > p:not(.eyebrow),
.support-card .section-heading > p:not(.eyebrow) {
    max-width: 60ch;
}

.review-stars {
    letter-spacing: 0.14em;
    color: #e3a14f;
    font-size: 0.95rem;
    margin-bottom: 12px;
}

.review-trip {
    margin-bottom: 14px;
}

.review-text {
    margin-bottom: 18px;
}

.review-author {
    font-weight: 700;
}

.faq-section {
    display: grid;
    gap: 22px;
}

.faq-section--home .section-heading {
    justify-items: start;
    text-align: left;
}

.faq-section--home .section-heading > p:not(.eyebrow) {
    max-width: 60ch;
}

.faq-header {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 18px;
}

.faq-topics {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.faq-topic-button {
    cursor: pointer;
    padding: 12px 16px;
    border-radius: 999px;
    border: 1px solid var(--line-strong);
    background: rgba(255, 255, 255, 0.98);
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
}

.faq-topic-button.is-active,
.faq-topic-button:focus-visible {
    background: var(--primary);
    border-color: rgba(37, 99, 235, 0.1);
    color: white;
    outline: none;
}

.faq-list {
    display: grid;
    gap: 0;
}

.faq-item {
    padding: 0;
    overflow: hidden;
    border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}

.faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    width: 100%;
    cursor: pointer;
    padding: 22px 0;
    text-align: left;
    font-weight: 800;
    color: var(--ink);
}

.faq-question::after {
    content: "+";
    flex: none;
    color: var(--primary);
    font-size: 1.4rem;
    line-height: 1;
}

.faq-item.is-open .faq-question::after {
    content: "−";
}

.faq-answer {
    display: none;
    padding: 0 0 22px;
}

.faq-item.is-open .faq-answer {
    display: block;
}

.catalog-header {
    display: none;
    align-items: end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 18px;
}

.catalog-summary {
    padding: 0;
    border-radius: 0;
    background: transparent;
    border: 0;
    text-align: right;
}

.catalog-summary strong {
    display: block;
    font-family: var(--display-font);
    font-size: 2rem;
    line-height: 1;
}

.catalog-summary-label {
    color: var(--muted);
    font-size: 0.95rem;
}

.status-banner {
    margin-bottom: 18px;
    padding: 16px 18px;
    border-radius: 16px;
    border: 1px solid rgba(191, 219, 254, 0.9);
    border-left: 6px solid var(--primary);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(239, 246, 255, 0.98));
    box-shadow: var(--shadow-soft);
}

.status-banner.is-warning {
    background: var(--warning-soft);
    border-color: rgba(245, 158, 11, 0.24);
    border-left-color: var(--primary);
}

.status-banner.is-error {
    background: var(--danger-soft);
    border-color: rgba(239, 68, 68, 0.22);
    border-left-color: #dc2626;
}

.countries-grid {
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.country-card {
    display: grid;
    gap: 14px;
}

.country-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.country-emoji {
    margin-bottom: 0;
    font-size: 1.4rem;
}

.country-code {
    display: inline-flex;
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(239, 246, 255, 0.96);
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: none;
}

.country-price {
    font-family: var(--display-font);
    font-size: 1.24rem;
    font-weight: 700;
}

.country-caption {
    color: var(--muted);
}

.country-card.empty-card {
    place-items: center;
    min-height: 220px;
    text-align: center;
}

.countries-page-shell {
    --page-width: 1280px;
    --countries-card-width: 420px;
    --countries-card-gap: 6px;
    --countries-row-width: calc((var(--countries-card-width) * 2) + var(--countries-card-gap));
}

.countries-page-shell main {
    gap: 20px;
}

.countries-page-hero {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 18px;
    padding: 12px 0 0;
    border-radius: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
}

.countries-page-route {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
}

.countries-page-route a:hover {
    color: var(--primary);
}

.countries-page-hero .section-heading {
    justify-items: center;
    margin-inline: auto;
    text-align: center;
}

.countries-page-hero .section-heading h1 {
    font-size: clamp(1.7rem, 2.3vw, 3rem);
    line-height: 1.02;
    letter-spacing: -0.03em;
}

.countries-page-toolbar {
    display: flex;
    align-items: start;
    justify-content: center;
    gap: 18px;
    width: min(100%, var(--countries-row-width));
    margin-inline: auto;
}

.countries-page-search {
    width: 100%;
    max-width: none;
    margin-inline: 0;
    flex: 0 1 auto;
}

.country-directory {
    display: grid;
    width: min(100%, var(--countries-row-width));
    margin-inline: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
    gap: var(--countries-card-gap);
}

.country-directory-card {
    display: block;
    width: 100%;
    padding: 15px 16px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(191, 219, 254, 0.72);
    box-shadow: none;
    transition:
        transform 200ms var(--ease-standard),
        box-shadow 200ms var(--ease-standard),
        border-color 200ms var(--ease-standard);
}

.country-directory-card:hover,
.country-directory-card:focus-within {
    transform: translateY(-2px);
    border-color: rgba(37, 99, 235, 0.28);
    box-shadow: 0 14px 28px rgba(37, 99, 235, 0.06);
}

.country-directory-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.country-directory-link {
    display: block;
    min-width: 0;
}

.country-directory-link--card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 0;
}

.country-directory-title {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    flex: 1 1 auto;
}

.country-directory-emoji {
    width: 36px;
    height: 36px;
    font-size: 1.3rem;
}

.country-directory-name {
    margin: 0;
    font-family: var(--display-font);
    font-size: 1.02rem;
    line-height: 1.05;
    letter-spacing: 0.01em;
    white-space: nowrap;
}

.country-directory-meta span,
.package-pill {
    display: inline-flex;
    align-items: center;
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(239, 246, 255, 0.96);
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: none;
}

.country-directory-price {
    display: flex;
    align-items: baseline;
    gap: 6px;
    text-align: right;
    flex: none;
    white-space: nowrap;
}

.country-directory-price span {
    color: var(--muted);
    font-size: 0.76rem;
}

.country-directory-price strong {
    color: var(--muted);
    font-family: var(--display-font);
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1;
}

.package-item {
    display: grid;
    gap: 10px;
    padding: 8px 0 0 14px;
    border-radius: 0;
    background: transparent;
    border: 0;
    border-left: 2px solid rgba(191, 219, 254, 0.7);
}

.package-item-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.package-item-title {
    display: block;
    font-weight: 700;
    line-height: 1.45;
}

.package-item-code {
    display: inline-block;
    margin-top: 6px;
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.72rem;
    letter-spacing: 0.02em;
    text-transform: none;
}

.package-item-price {
    flex: none;
    font-family: var(--display-font);
    font-size: 1.08rem;
    font-weight: 800;
    white-space: nowrap;
}

.package-item-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.directory-empty {
    display: grid;
    place-items: center;
    min-height: 220px;
    padding: 28px;
    border-radius: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    text-align: center;
    grid-column: 1 / -1;
}

.country-page-shell {
    --page-width: 1280px;
    --plan-card-width: 360px;
    --plan-card-gap: 14px;
    --plan-group-width: calc(
        var(--plan-card-width) +
        var(--plan-card-width) +
        var(--plan-card-width) +
        var(--plan-card-gap) +
        var(--plan-card-gap)
    );
}

.country-page-shell main {
    gap: 56px;
    margin-top: 16px;
}

.country-detail-hero {
    position: relative;
    display: grid;
    gap: 14px;
    padding: 12px 0 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
}

.breadcrumbs {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    width: min(100%, var(--plan-group-width));
    justify-self: center;
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
    flex-wrap: wrap;
}

.breadcrumbs a:hover {
    color: var(--primary-strong);
}

.breadcrumbs span:last-child {
    color: var(--ink);
}

.country-detail-head {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 18px;
    width: min(100%, var(--plan-group-width));
    justify-self: center;
    position: relative;
    padding: 0;
    border-radius: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.country-detail-heading {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
    text-align: left;
}

.country-detail-flag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 1), rgba(239, 246, 255, 0.98));
    border: 1px solid rgba(191, 219, 254, 0.9);
    box-shadow: 0 10px 22px rgba(37, 99, 235, 0.07);
    font-size: 2rem;
    line-height: 1;
    flex: none;
}

#country-detail-title {
    font-family: var(--display-font);
    font-size: clamp(2rem, 3vw, 2.8rem);
    line-height: 0.96;
    letter-spacing: -0.03em;
    text-transform: none;
}

.country-detail-heading .eyebrow,
.country-detail-heading .section-copy,
.country-detail-summary,
.catalog-header,
.country-duration-nav {
    display: none;
}

.country-page-shell .catalog-section {
    margin-top: -15px;
    overflow: visible;
    padding: 0 4px;
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
}

.country-detail-summary {
    display: none;
}

.country-detail-stat {
    display: grid;
    gap: 6px;
    padding: 18px 20px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(191, 219, 254, 0.9);
}

.country-detail-stat strong {
    font-family: var(--display-font);
    font-size: 1.28rem;
    font-weight: 800;
}

.country-detail-stat span {
    color: var(--muted);
    font-size: 0.92rem;
}

.country-duration-nav {
    display: none;
}

.country-duration-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid var(--line-strong);
    color: var(--ink);
    font-family: var(--mono-font);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
}

.country-duration-link:hover {
    border-color: rgba(37, 99, 235, 0.28);
    transform: translateY(-1px);
}

.country-plan-groups {
    display: grid;
    gap: 22px;
}

.plan-group {
    display: grid;
    gap: 14px;
    padding: 0;
    width: min(100%, var(--plan-group-width));
    max-width: 100%;
    justify-self: center;
    justify-items: stretch;
    background: transparent;
    border: 0;
}

.plan-group--unlimited {
    gap: 18px;
    margin-top: 8px;
    padding-top: 24px;
    border-top: 1px solid rgba(191, 219, 254, 0.72);
}

.plan-group-stack {
    display: grid;
    gap: 18px;
}

.plan-subgroup {
    display: grid;
    gap: 14px;
}

.plan-group-header {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    width: 100%;
    justify-self: stretch;
    padding: 0;
    text-align: left;
}

.plan-group-header h3 {
    margin: 0;
    color: var(--ink);
    font-family: var(--body-font);
    font-size: 1.02rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
    text-align: left;
}

.plan-group-header p {
    display: none;
}

.plan-group--unlimited > .plan-group-header p {
    display: block;
    margin-top: 8px;
    color: var(--muted);
    font-family: var(--body-font);
    font-size: 0.95rem;
    font-weight: 500;
    line-height: 1.55;
    max-width: 54ch;
}

.plan-card-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: stretch;
    width: 100%;
    gap: var(--plan-card-gap);
}

.plan-card {
    --plan-card-inline-padding: 16px;
    --plan-card-top-padding: 21px;
    --plan-card-bottom-padding: 19px;
    position: relative;
    z-index: 0;
    width: var(--plan-card-width);
    display: grid;
    gap: 0;
    padding: var(--plan-card-top-padding) var(--plan-card-inline-padding) 0;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(191, 219, 254, 0.88);
    box-shadow: none;
    overflow: visible;
    transition:
        border-color 200ms var(--ease-standard),
        box-shadow 200ms var(--ease-standard),
        background 200ms var(--ease-standard);
}

.plan-card-surface {
    position: absolute;
    inset: 0;
    z-index: 1;
    padding: 0;
    border: 0;
    border-radius: inherit;
    background: transparent;
    appearance: none;
    cursor: pointer;
}

.plan-card-surface:focus-visible {
    outline: 2px solid rgba(37, 99, 235, 0.24);
    outline-offset: 2px;
}

.plan-card:hover,
.plan-card:focus-within {
    z-index: 4;
    background: rgba(255, 255, 255, 0.98);
    border-color: rgba(37, 99, 235, 0.22);
    box-shadow: 0 10px 20px rgba(37, 99, 235, 0.06);
}

.plan-card-main {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 12px;
    row-gap: 8px;
    padding-bottom: var(--plan-card-bottom-padding);
    pointer-events: none;
}

.plan-card-main-copy {
    display: grid;
    min-width: 0;
}

.plan-card-main-copy > .plan-card-summary-text,
.plan-card-main-copy > .plan-card-summary-text--traffic {
    min-width: 0;
}

.plan-card-summary-text {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--display-font);
    font-size: clamp(1.36rem, 1.36vw, 1.6rem);
    font-weight: 800;
    color: var(--ink);
    line-height: 1;
    letter-spacing: -0.03em;
    text-transform: none;
    white-space: nowrap;
}

.plan-card-summary-text--duration {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-transform: none;
}

.plan-card-summary-text--traffic {
    flex-wrap: nowrap;
}

.plan-card-summary-separator {
    color: #94a3b8;
    font-size: 0.5em;
    font-weight: 600;
}

.plan-card-summary-price {
    color: var(--money);
    font-weight: 600;
    white-space: nowrap;
}

.plan-info-hint {
    position: relative;
    display: inline-flex;
    align-items: center;
    flex: none;
    z-index: 2;
    pointer-events: auto;
}

.plan-info-hint__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    padding: 0;
    border-radius: 999px;
    border: 1px solid rgba(191, 219, 254, 0.96);
    background: rgba(239, 246, 255, 0.98);
    color: rgba(37, 99, 235, 0.88);
    font-size: 0.92rem;
    font-weight: 800;
    cursor: help;
    box-shadow: none;
}

.plan-info-hint__button:hover,
.plan-info-hint__button:focus-visible {
    border-color: rgba(37, 99, 235, 0.3);
    background: rgba(255, 255, 255, 0.98);
    outline: none;
}

.plan-info-hint__popover {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 10px);
    transform: translateX(-50%);
    display: block;
    width: min(320px, calc(100vw - 40px));
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(15, 23, 42, 0.96);
    color: white;
    font-family: var(--body-font);
    font-size: 0.82rem;
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: 0;
    text-transform: none;
    white-space: normal;
    word-break: normal;
    overflow-wrap: anywhere;
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.22);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.18s var(--ease-standard), visibility 0.18s var(--ease-standard), transform 0.18s var(--ease-standard);
    z-index: 24;
}

.plan-info-hint:hover .plan-info-hint__popover,
.plan-info-hint:focus-within .plan-info-hint__popover {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(-2px);
}

.plan-card-subprice {
    width: 100%;
    justify-self: end;
    color: #94a3b8;
    font-family: var(--body-font);
    font-size: clamp(0.96rem, 1vw, 1.04rem);
    font-weight: 700;
    letter-spacing: -0.01em;
    line-height: 1;
    white-space: nowrap;
    text-align: right;
}

.country-detail-empty {
    display: grid;
    gap: 14px;
    place-items: center;
    min-height: 220px;
    padding: 28px;
    border-radius: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    text-align: center;
}

.support-card {
    display: grid;
    gap: 20px;
}

.support-links {
    display: grid;
    width: min(100%, 720px);
    margin-inline: auto;
    grid-template-columns: repeat(auto-fit, minmax(260px, 320px));
    justify-content: center;
    gap: 14px;
}

.support-link {
    display: flex;
    width: min(100%, 320px);
    align-items: start;
    gap: 14px;
    padding: 18px 0;
    justify-self: center;
    transition:
        transform 180ms var(--ease-standard),
        box-shadow 180ms var(--ease-standard),
        border-color 180ms var(--ease-standard);
}

.support-link:hover,
.support-link:focus-within {
    transform: translateY(0);
    border-color: rgba(37, 99, 235, 0.18);
    box-shadow: none;
}

.support-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 42px;
    border-radius: 12px;
    background: var(--primary-soft);
    font-size: 1.1rem;
}

.support-link strong {
    display: block;
    margin-bottom: 4px;
}

.support-link-action {
    display: inline-flex;
    align-items: center;
    margin-top: 6px;
    color: var(--muted);
    font-size: 0.9rem;
    font-weight: 700;
    text-decoration: none;
    transition: color 180ms var(--ease-standard);
}

.support-link-action:hover,
.support-link-action:focus-visible {
    color: var(--primary);
}

.site-footer {
    display: grid;
    gap: 24px;
    width: 100vw;
    margin-top: 56px;
    margin-left: calc(50% - 50vw);
    padding: 36px max(16px, calc((100vw - var(--page-width)) / 2 + 15px)) 44px;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.96) 0%, rgba(255, 255, 255, 0.99) 100%);
    border-top: 1px solid rgba(148, 163, 184, 0.22);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.9),
        0 -18px 36px rgba(15, 23, 42, 0.03);
}

.footer-brand {
    display: grid;
    gap: 10px;
    justify-items: start;
}

.footer-brand p {
    color: var(--muted);
}

.brand--footer {
    gap: 12px;
}

.brand-mark--footer {
    width: 52px;
    height: 52px;
    padding: 5px;
    border-radius: 16px;
    background: rgba(239, 246, 255, 0.9);
}

.footer-tagline-link {
    display: inline-block;
    color: var(--muted);
    text-decoration: none;
    transition: color 180ms var(--ease-standard);
}

.footer-tagline-link:hover,
.footer-tagline-link:focus-visible {
    color: var(--primary);
}

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

.footer-column {
    display: grid;
    gap: 10px;
}

.footer-column h3 {
    font-family: var(--mono-font);
    font-size: 0.82rem;
    letter-spacing: 0.02em;
    text-transform: none;
}

.footer-column a {
    color: var(--muted);
}

.footer-column-text {
    color: var(--muted);
}

.footer-column a:hover {
    color: var(--primary);
}

.footer-legal-wide {
    display: grid;
    gap: 12px;
    padding-top: 20px;
    border-top: 1px solid rgba(148, 163, 184, 0.2);
}

.footer-legal-wide h3 {
    margin: 0;
    font-family: var(--mono-font);
    font-size: 0.82rem;
    letter-spacing: 0.02em;
    text-transform: none;
}

.footer-legal-copy {
    display: grid;
    gap: 12px;
}

.footer-legal {
    margin: 0;
    font-size: 0.94rem;
    line-height: 1.55;
}

.legal-page-shell {
    width: min(calc(100% - 30px), 1120px);
}

.legal-page-shell main {
    gap: 32px;
    margin-top: 20px;
    padding-bottom: 32px;
}

.legal-page-hero {
    display: grid;
    gap: 16px;
}

.legal-page-head {
    display: grid;
    gap: 14px;
    max-width: 860px;
}

.legal-page-title {
    margin: 0;
    font-family: var(--display-font);
    font-size: clamp(2.2rem, 4.2vw, 3.5rem);
    line-height: 0.98;
    letter-spacing: -0.04em;
}

.legal-page-subtitle {
    margin: 0;
    max-width: 780px;
    color: var(--muted);
    font-size: 1.02rem;
    line-height: 1.7;
}

.legal-document {
    display: grid;
    gap: 24px;
    padding: 36px 38px;
    border-radius: 32px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(148, 163, 184, 0.2);
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.05);
    backdrop-filter: blur(10px);
}

.legal-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 12px;
}

.legal-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(239, 246, 255, 0.92);
    border: 1px solid rgba(37, 99, 235, 0.12);
    color: #3b4c68;
    font-size: 0.9rem;
    font-weight: 700;
}

.legal-toc {
    display: grid;
    gap: 12px;
    padding: 18px 20px;
    border-radius: 24px;
    background: rgba(248, 250, 252, 0.9);
    border: 1px solid rgba(148, 163, 184, 0.16);
}

.legal-toc strong {
    font-family: var(--display-font);
    font-size: 1rem;
}

.legal-toc-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 12px;
}

.legal-toc a,
.legal-link {
    color: var(--primary-strong);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

.legal-toc a:hover,
.legal-link:hover {
    color: var(--primary);
}

.legal-content {
    display: grid;
    gap: 26px;
}

.legal-section {
    display: grid;
    gap: 14px;
}

.legal-section h2,
.legal-section h3 {
    margin: 0;
    font-family: var(--display-font);
    letter-spacing: -0.03em;
}

.legal-section h2 {
    font-size: 1.5rem;
}

.legal-section h3 {
    font-size: 1.08rem;
}

.legal-section p {
    margin: 0;
    color: #334155;
    font-size: 1rem;
    line-height: 1.74;
}

.legal-list {
    margin: 0;
    padding-left: 20px;
    color: #334155;
    font-size: 1rem;
    line-height: 1.74;
}

.legal-list li + li {
    margin-top: 8px;
}

.legal-note {
    padding: 16px 18px;
    border-radius: 22px;
    background: rgba(239, 246, 255, 0.78);
    border: 1px solid rgba(37, 99, 235, 0.12);
}

body.modal-open {
    overflow: hidden;
}

.purchase-modal[hidden] {
    display: none;
}

.purchase-modal {
    position: fixed;
    inset: 0;
    z-index: 44;
    display: grid;
    place-items: center;
    padding: 24px;
}

.purchase-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.56);
    backdrop-filter: blur(10px);
}

.purchase-modal__dialog {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 20px;
    width: min(100%, 540px);
    max-height: min(100%, calc(100vh - 32px));
    overflow: auto;
    padding: 28px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.99);
    border: 1px solid rgba(191, 219, 254, 0.82);
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.22);
}

.purchase-modal__close {
    position: absolute;
    top: 16px;
    right: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    padding: 0;
    border: 1px solid rgba(191, 219, 254, 0.92);
    border-radius: 999px;
    background: rgba(239, 246, 255, 0.92);
    color: var(--ink);
    font-size: 1.2rem;
    line-height: 1;
    cursor: pointer;
}

.purchase-modal__close:hover,
.purchase-modal__close:focus-visible {
    border-color: rgba(37, 99, 235, 0.24);
    background: rgba(255, 255, 255, 0.98);
    outline: none;
}

.purchase-modal__header {
    display: grid;
    gap: 8px;
    padding-right: 52px;
}

.purchase-modal__header h2 {
    margin: 0;
    font-family: var(--display-font);
    font-size: clamp(1.6rem, 2.6vw, 2rem);
    line-height: 1;
    letter-spacing: -0.03em;
}

.purchase-modal__plan {
    display: grid;
    gap: 14px;
    padding: 20px;
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(239, 246, 255, 0.84)),
        radial-gradient(circle at top right, rgba(96, 165, 250, 0.12), transparent 42%);
    border: 1px solid rgba(191, 219, 254, 0.9);
}

.purchase-modal__country {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--muted);
    font-size: 0.95rem;
    font-weight: 700;
}

.purchase-modal__flag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 1), rgba(239, 246, 255, 0.98));
    border: 1px solid rgba(191, 219, 254, 0.9);
    box-shadow: 0 8px 18px rgba(37, 99, 235, 0.06);
    font-size: 1.4rem;
    line-height: 1;
}

.purchase-modal__plan-main {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    font-family: var(--display-font);
    font-size: clamp(1.9rem, 3vw, 2.4rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.03em;
    color: var(--ink);
}

.purchase-modal__price {
    font-family: var(--display-font);
    font-size: clamp(1.24rem, 2vw, 1.6rem);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.04em;
    color: var(--money);
}

.purchase-modal__subprice,
.purchase-modal__activation,
.purchase-modal__note,
.purchase-modal__legal {
    margin: 0;
}

.purchase-modal__subprice {
    color: var(--muted);
    font-size: 0.96rem;
    font-weight: 700;
}

.purchase-modal__activation {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--muted);
    font-family: var(--mono-font);
    font-size: 0.82rem;
    font-weight: 700;
}

.purchase-modal__note {
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.82);
    color: var(--ink);
    font-size: 0.92rem;
    line-height: 1.55;
}

.purchase-modal__form {
    display: grid;
    gap: 14px;
}

.purchase-modal__label {
    color: var(--ink);
    font-size: 0.98rem;
    font-weight: 600;
    line-height: 1.5;
}

.purchase-modal__input {
    width: 100%;
    min-height: 56px;
    padding: 0 18px;
    border: 1px solid rgba(148, 163, 184, 0.26);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.98);
    color: var(--ink);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.82),
        0 8px 18px rgba(15, 23, 42, 0.04);
}

.purchase-modal__input:focus-visible {
    outline: none;
    border-color: rgba(37, 99, 235, 0.34);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.82),
        0 12px 24px rgba(37, 99, 235, 0.1);
}

.purchase-modal__submit {
    width: 100%;
}

.purchase-modal__submit:disabled {
    cursor: wait;
    opacity: 0.82;
    transform: none;
}

.purchase-modal__error {
    margin: 0;
    color: #dc2626;
    font-size: 0.9rem;
    line-height: 1.55;
}

.purchase-modal__legal {
    color: var(--muted);
    font-size: 0.84rem;
    line-height: 1.6;
}

.purchase-modal__legal a {
    color: var(--primary);
    text-decoration: underline;
    text-underline-offset: 0.14em;
}

.activation-hero {
    display: grid;
    gap: 18px;
    padding: 12px 0 0;
}

.activation-hero-head {
    display: grid;
    width: min(100%, var(--plan-group-width));
    justify-self: center;
}

.activation-hero-title-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 22px;
}

#activation-country-flag {
    align-self: center;
    transform: translateY(6px);
}

#activation-page-title {
    margin: 0;
    font-size: clamp(2.65rem, 6vw, 5.25rem);
    line-height: 0.94;
    letter-spacing: -0.05em;
    text-transform: none;
}

.activation-hero-subtitle {
    width: min(100%, var(--plan-group-width));
    justify-self: center;
    margin: 0;
    color: var(--muted);
    line-height: 1.7;
}

.activation-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    padding: 0 22px;
    border-radius: 999px;
    font-family: var(--body-font);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    text-transform: none;
    white-space: nowrap;
}

.activation-status-pill.is-ready {
    background: rgba(34, 197, 94, 0.12);
    color: #15803d;
    border: 1px solid rgba(34, 197, 94, 0.2);
}

.activation-status-pill.is-processing {
    background: rgba(59, 130, 246, 0.1);
    color: #1d4ed8;
    border: 1px solid rgba(59, 130, 246, 0.18);
}

.activation-status-pill.is-pending {
    background: rgba(148, 163, 184, 0.12);
    color: #475569;
    border: 1px solid rgba(148, 163, 184, 0.22);
}

.activation-warning,
.activation-save-tip {
    display: grid;
    width: min(100%, var(--plan-group-width));
    justify-self: center;
    padding: 18px 22px;
    border-radius: 24px;
}

.activation-warning {
    gap: 8px;
    background: rgba(255, 247, 237, 0.98);
    border: 1px solid rgba(251, 191, 36, 0.34);
    color: #9a3412;
}

.activation-save-tip {
    gap: 6px;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(191, 219, 254, 0.76);
    color: var(--ink);
    box-shadow: 0 16px 30px rgba(15, 23, 42, 0.04);
}

.activation-notice-stack {
    display: grid;
    gap: 15px;
}

.activation-warning p,
.activation-warning strong,
.activation-save-tip p,
.activation-save-tip strong {
    margin: 0;
}

.activation-save-tip p {
    color: var(--muted);
    line-height: 1.65;
}

.activation-content-shell {
    position: relative;
    display: grid;
    gap: 18px;
    width: min(100%, var(--plan-group-width));
    justify-self: center;
}

.activation-content-blurable {
    transition:
        filter 220ms var(--ease-standard),
        opacity 220ms var(--ease-standard),
        transform 220ms var(--ease-standard);
}

.activation-content-shell.is-locked .activation-content-blurable {
    filter: blur(14px);
    opacity: 0.42;
    transform: scale(0.994);
    pointer-events: none;
    user-select: none;
}

.activation-processing-overlay {
    position: absolute;
    inset: 0;
    z-index: 6;
    display: grid;
    align-content: start;
    justify-items: center;
    gap: 14px;
    padding: 44px 24px 24px;
    text-align: center;
}

.activation-processing-overlay[hidden] {
    display: none;
}

.activation-processing-overlay strong {
    font-size: clamp(1.25rem, 2vw, 1.6rem);
    line-height: 1.15;
}

.activation-processing-overlay p {
    max-width: 44ch;
    margin: 0;
    color: var(--muted);
    line-height: 1.72;
}

.activation-processing-overlay__spinner {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    border: 5px solid rgba(191, 219, 254, 0.72);
    border-top-color: var(--primary);
    box-shadow: 0 18px 34px rgba(37, 99, 235, 0.14);
    animation: activation-spin 900ms linear infinite;
}

.activation-grid,
.activation-details-section {
    display: grid;
    gap: 18px;
    width: 100%;
    justify-self: stretch;
}

.activation-grid {
    grid-template-columns: minmax(0, 1.04fr) minmax(0, 0.96fr);
    align-items: start;
}

.activation-card {
    display: grid;
    gap: 18px;
    padding: 22px 22px 24px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(191, 219, 254, 0.82);
    box-shadow: 0 18px 38px rgba(15, 23, 42, 0.05);
}

.activation-card--primary {
    min-height: 220px;
}

.activation-card-heading {
    gap: 8px;
}

.activation-card-heading h2,
.activation-details-heading h2 {
    margin: 0;
    font-size: 1.22rem;
    letter-spacing: -0.02em;
}

.activation-card-heading p {
    margin: 0;
    max-width: 48ch;
    color: var(--muted);
    line-height: 1.65;
}

.activation-card--collapsible {
    gap: 0;
}

.activation-steps-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    width: 100%;
    padding: 0;
    color: var(--ink);
    text-align: left;
    cursor: pointer;
}

.activation-steps-toggle:focus-visible {
    outline: 2px solid rgba(37, 99, 235, 0.24);
    outline-offset: 4px;
    border-radius: 18px;
}

.activation-steps-toggle__title {
    display: block;
    font-size: 1.22rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.activation-steps-toggle__icon {
    position: relative;
    flex: none;
    width: 16px;
    height: 16px;
    transition: transform 180ms var(--ease-standard);
}

.activation-steps-toggle__icon::before,
.activation-steps-toggle__icon::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 10px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transform-origin: center;
}

.activation-steps-toggle__icon::before {
    left: 0;
    transform: translateY(-50%) rotate(45deg);
}

.activation-steps-toggle__icon::after {
    right: 0;
    transform: translateY(-50%) rotate(-45deg);
}

.activation-steps-toggle[aria-expanded="true"] .activation-steps-toggle__icon {
    transform: rotate(180deg);
}

.activation-steps-panel {
    padding-top: 18px;
}

.activation-ready-panel {
    display: grid;
    gap: 18px;
}

.activation-qr-block {
    display: grid;
    place-items: center;
    min-height: 300px;
    padding: 20px;
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(239, 246, 255, 0.88)),
        radial-gradient(circle at top right, rgba(96, 165, 250, 0.12), transparent 42%);
    border: 1px solid rgba(191, 219, 254, 0.82);
}

.activation-qr-block img {
    display: block;
    width: min(100%, 280px);
    height: auto;
    border-radius: 24px;
}

.activation-access-list {
    display: grid;
    gap: 12px;
}

.activation-access-item {
    display: grid;
    gap: 6px;
    padding-top: 12px;
    border-top: 1px solid rgba(226, 232, 240, 0.84);
}

.activation-access-item:first-child {
    padding-top: 0;
    border-top: 0;
}

.activation-access-item span {
    color: var(--muted);
    font-size: 0.88rem;
    font-weight: 700;
}

.activation-access-item strong,
.activation-access-item a {
    color: var(--ink);
    font-size: 1rem;
    font-weight: 700;
    overflow-wrap: anywhere;
}

.activation-access-item a {
    color: var(--primary);
}

.activation-pending-panel {
    display: grid;
    gap: 16px;
    place-items: center;
    min-height: 280px;
    padding: 24px;
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(239, 246, 255, 0.9)),
        radial-gradient(circle at top right, rgba(96, 165, 250, 0.12), transparent 42%);
    border: 1px solid rgba(191, 219, 254, 0.82);
    text-align: center;
}

.activation-pending-panel p {
    margin: 0;
    max-width: 34ch;
    color: var(--muted);
    line-height: 1.7;
}

.activation-spinner {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    border: 4px solid rgba(191, 219, 254, 0.62);
    border-top-color: var(--primary);
    animation: activation-spin 900ms linear infinite;
}

@keyframes activation-spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes topbar-progress-sheen {
    from {
        background-position: -160px 0, 0 0;
    }

    to {
        background-position: 220px 0, 0 0;
    }
}

.activation-steps-list {
    display: grid;
    gap: 14px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.activation-step-item {
    display: grid;
    gap: 6px;
    padding: 0 0 14px;
    border-bottom: 1px solid rgba(226, 232, 240, 0.9);
}

.activation-step-item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.activation-step-item strong {
    font-size: 1rem;
}

.activation-step-item p {
    margin: 0;
    color: var(--muted);
    line-height: 1.7;
}

.activation-details-heading {
    display: grid;
    gap: 8px;
}

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

.activation-detail-card {
    display: grid;
    gap: 8px;
    padding: 18px;
    border-radius: 22px;
    min-height: 102px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(191, 219, 254, 0.74);
}

.activation-detail-card span {
    color: var(--muted);
    font-size: 0.86rem;
    font-weight: 700;
}

.activation-detail-card strong {
    color: var(--ink);
    font-size: 1rem;
    line-height: 1.45;
}

.activation-detail-card--traffic {
    align-content: start;
}

.activation-detail-card--traffic p {
    margin: 0;
    color: var(--muted);
    font-size: 0.82rem;
    line-height: 1.55;
}

.activation-usage-progress {
    position: relative;
    width: 100%;
    height: 10px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(191, 219, 254, 0.36);
}

.activation-usage-progress__fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #2563eb 0%, #60a5fa 100%);
    box-shadow: 0 8px 16px rgba(37, 99, 235, 0.16);
}

.cookie-banner {
    position: fixed;
    left: 18px;
    right: auto;
    bottom: 18px;
    z-index: 30;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    width: min(calc(100% - 36px), 350px);
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(148, 163, 184, 0.22);
    background: rgba(255, 255, 255, 0.82);
    color: #334155;
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08);
    backdrop-filter: blur(16px);
}

.cookie-banner.is-hidden {
    display: none;
}

.cookie-copy strong {
    display: block;
    margin-bottom: 4px;
    color: #334155;
    font-size: 0.88rem;
    font-weight: 700;
}

.cookie-copy p {
    color: #64748b;
    font-size: 0.8rem;
    line-height: 1.5;
}

.cookie-button {
    flex: none;
    align-self: flex-start;
    min-width: 0;
    padding: 9px 14px;
    border: 1px solid rgba(37, 99, 235, 0.1);
    background: rgba(37, 99, 235, 0.06);
    color: #475569;
    font-size: 0.84rem;
    font-weight: 700;
    box-shadow: none;
}

.cookie-button:hover,
.cookie-button:focus-visible {
    transform: none;
    border-color: rgba(37, 99, 235, 0.16);
    background: rgba(37, 99, 235, 0.1);
    color: #334155;
}

@media (max-width: 1180px) {
    .journey-section {
        grid-template-columns: 1fr;
    }

    .country-detail-head {
        flex-direction: column;
        align-items: stretch;
    }

    .country-detail-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .hero-search-layout {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
    }

    .hero-country-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .countries-page-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .float-card-primary {
        left: 14px;
        bottom: 18px;
    }

    .float-card-secondary {
        right: 14px;
        top: 18px;
    }

    .benefits-grid,
    .review-grid,
    .support-links {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

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

    .activation-grid {
        grid-template-columns: 1fr;
    }

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

@media (max-width: 920px) {
    .topbar {
        grid-template-columns: 1fr;
        justify-items: start;
        border-radius: 0;
    }

    .topbar-progress {
        height: 3px;
    }

    .topbar-nav {
        justify-content: flex-start;
    }

    .hero-stats,
    .steps-grid,
    .benefits-grid,
    .review-grid,
    .support-links,
    .footer-columns {
        grid-template-columns: 1fr;
    }

    .hero-country-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .catalog-header,
    .faq-header {
        flex-direction: column;
        align-items: stretch;
    }

    .country-detail-heading {
        align-items: center;
    }

    .country-directory {
        grid-template-columns: 1fr;
        justify-content: stretch;
    }

    .activation-hero-title-row {
        grid-template-columns: auto minmax(0, 1fr);
        gap: 18px;
    }

    .activation-status-pill {
        grid-column: 1 / -1;
        justify-self: start;
    }
}

@media (max-width: 680px) {
    .page-shell {
        width: min(calc(100% - 16px), var(--page-width));
        padding-top: 0;
    }

    .topbar {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: 12px;
        padding-top: 14px;
        padding-bottom: 14px;
    }

    .brand {
        min-width: 0;
    }

    .brand-mark {
        width: 50px;
        height: 50px;
        padding: 5px;
        border-radius: 16px;
    }

    .brand-copy {
        gap: 2px;
    }

    .brand-text {
        display: grid;
        gap: 2px;
        font-size: 1rem;
        line-height: 1.08;
    }

    .brand-text-divider,
    .brand-tagline,
    .topbar-nav a:not(.topbar-nav__countries) {
        display: none;
    }

    .brand-text-secondary {
        font-family: var(--body-font);
        font-size: 0.82rem;
        font-weight: 700;
        letter-spacing: 0;
        line-height: 1.1;
        color: var(--muted);
    }

    .topbar-nav {
        justify-self: end;
        gap: 0;
        font-size: 0.88rem;
    }

    .topbar-nav__countries {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 36px;
        padding: 0 12px;
        border-radius: 999px;
        border: 1px solid rgba(148, 163, 184, 0.18);
        background: rgba(255, 255, 255, 0.58);
        color: #64748b;
        font-weight: 600;
        box-shadow: none;
    }

    .topbar-nav__countries:hover,
    .topbar-nav__countries:focus-visible {
        color: #475569;
        border-color: rgba(148, 163, 184, 0.24);
        background: rgba(255, 255, 255, 0.72);
    }

    .topbar-progress {
        height: 2px;
    }

    main {
        gap: 56px;
    }

    .country-page-shell main {
        gap: 42px;
    }

    .country-page-shell .page-loading-shell {
        gap: 42px;
    }

    .country-page-shell .catalog-section {
        margin-top: -37px;
    }

    .countries-page-shell main {
        gap: 10px;
    }

    .countries-page-shell .page-loading-shell {
        gap: 10px;
    }

    .legal-page-shell {
        width: min(calc(100% - 16px), 1120px);
    }

    .legal-page-shell main {
        gap: 24px;
        margin-top: 12px;
        padding-bottom: 20px;
    }

    .purchase-modal {
        padding: 12px;
    }

    .purchase-modal__dialog {
        max-height: calc(100vh - 24px);
        padding: 22px 18px 18px;
        border-radius: 24px;
    }

    .purchase-modal__plan {
        padding: 16px;
        border-radius: 20px;
    }

    .hero,
    .seo-copy-section,
    .steps-section,
    .journey-section,
    .benefits-section,
    .reviews-section,
    .faq-section,
    .catalog-section,
    .countries-page-hero,
    .country-detail-hero,
    .activation-warning,
    .activation-save-tip,
    .activation-card,
    .activation-details-section,
    .support-card,
    .site-footer {
        padding: 24px;
        border-radius: 26px;
    }

    .hero {
        width: 100vw;
        margin-left: calc(50% - 50vw);
        padding: 12px 16px 0;
        border-radius: 0;
    }

    .site-footer {
        width: 100vw;
        margin-left: calc(50% - 50vw);
        padding: 28px 16px 34px;
        border-radius: 0;
    }

    .legal-document {
        width: 100%;
        padding: 24px 20px;
        border-radius: 26px;
    }

    .legal-meta {
        gap: 8px;
    }

    .legal-meta span {
        width: 100%;
        justify-content: center;
        text-align: center;
    }

    .legal-page-title {
        font-size: clamp(1.74rem, 8vw, 2.36rem);
    }

    .legal-page-subtitle,
    .legal-section p,
    .legal-list {
        font-size: 0.94rem;
    }

    .seo-copy {
        gap: 12px;
    }

    .seo-copy h2 {
        font-size: 1.2rem;
    }

    .seo-copy p {
        font-size: 0.93rem;
    }

    .legal-toc-links {
        flex-direction: column;
        align-items: flex-start;
    }

    .search-row,
    .hero-actions,
    .cookie-banner {
        flex-direction: column;
        align-items: stretch;
    }

    .topbar-action,
    .primary-button,
    .ghost-button,
    .cookie-button,
    .search-submit-button {
        width: 100%;
    }

    .hero-title {
        font-size: calc(clamp(0.98rem, 4vw, 1.3rem) + 5px);
    }

    .hero-title-line--mobile-break {
        display: block;
        margin-left: 0;
        margin-top: 2px;
    }

    .hero-search-layout {
        width: 100%;
    }

    .hero-search-layout .search-panel--compact {
        flex: none;
        width: 100%;
    }

    .hero-search-layout .search-row--compact {
        flex-direction: row;
        align-items: center;
        min-height: 50px;
        padding: 0 12px;
    }

    .hero-search-layout .search-row--compact::before {
        margin-left: 0;
    }

    .hero-search-layout .search-row--compact input {
        min-height: 50px;
        height: 50px;
        padding: 0 0 0 2px;
    }

    .arrival-inline-hint {
        max-width: none;
        min-height: auto;
    }

    .arrival-inline-hint__popover {
        left: 0;
        right: auto;
        width: min(100%, 340px);
    }

    .countries-page-search .search-row--compact {
        flex-direction: row;
        align-items: center;
        min-height: 47px;
        padding: 0 12px;
    }

    .countries-page-search .search-row--compact::before {
        margin-left: 0;
    }

    .countries-page-search .search-row--compact input {
        min-height: 47px;
        height: 47px;
        padding: 0 0 0 2px;
    }

    .activation-hero-title-row {
        gap: 16px;
    }

    #activation-country-flag {
        transform: translateY(4px);
    }

    #activation-page-title {
        font-size: clamp(2.15rem, 12vw, 3.3rem);
    }

    .activation-processing-overlay {
        padding: 32px 18px 18px;
    }

    .page-loading-overlay {
        padding: 30px 18px 18px;
    }

    .phone-shell {
        padding: 16px;
    }

    .phone-card {
        padding: 18px;
    }

    .float-card {
        position: static;
        max-width: none;
        margin-top: 14px;
    }

    .phone-stats,
    .review-badges {
        grid-template-columns: 1fr;
    }

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

    .package-item-head,
    .plan-group-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .countries-page-shell .country-directory-link--card {
        align-items: center;
        justify-content: space-between;
        flex-direction: row;
        gap: 12px;
    }

    .countries-page-shell .country-directory-price {
        align-items: baseline;
        text-align: right;
    }

    .plan-card-grid {
        display: grid;
        grid-template-columns: 1fr;
    }

    .country-page-shell .country-detail-summary {
        display: none;
    }

    .plan-card {
        --plan-card-inline-padding: 16px;
        --plan-card-top-padding: 19px;
        --plan-card-bottom-padding: 20px;
        width: 100%;
    }

    .plan-group {
        width: 100%;
        justify-self: stretch;
    }

    .country-detail-head,
    .plan-group-header {
        width: 100%;
        justify-self: stretch;
    }

    .plan-card-main {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: start;
        column-gap: 12px;
        row-gap: 4px;
    }

    .country-detail-head {
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        gap: 10px;
    }

    .plan-info-hint__popover {
        left: 0;
        bottom: calc(100% + 8px);
        transform: translateX(0);
        width: min(280px, calc(100vw - 56px));
    }

    .plan-info-hint:hover .plan-info-hint__popover,
    .plan-info-hint:focus-within .plan-info-hint__popover {
        transform: translateY(-2px);
    }

    .plan-card-subprice {
        grid-column: 2;
        font-size: 0.92rem;
    }

    .plan-card-main-copy {
        grid-column: 1;
        align-self: center;
    }

    .country-page-shell .country-detail-heading {
        flex-direction: row;
        align-items: center;
        justify-content: flex-start;
        gap: 14px;
        width: 100%;
        text-align: left;
    }

    .country-detail-heading {
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        width: 100%;
        text-align: left;
    }

    .plan-group-header {
        align-items: flex-start;
    }

    .activation-details-grid {
        grid-template-columns: 1fr;
    }

    .cookie-banner {
        left: 12px;
        right: 12px;
        bottom: 12px;
        width: auto;
        gap: 10px;
        padding: 12px 13px;
        border-radius: 16px;
    }

    .cookie-banner .cookie-button {
        width: auto;
        align-self: flex-start;
    }
}

@media (max-width: 460px) {
    .page-shell {
        padding-top: 0;
    }

    .topbar {
        padding-left: 16px;
        padding-right: 16px;
    }

    .hero {
        padding-left: 16px;
        padding-right: 16px;
    }

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

    .plan-card-summary-text {
        font-size: 1.18rem;
    }

    .plan-card-subprice {
        font-size: 0.86rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .topbar-progress__bar {
        animation: none;
    }
}
