:root {
    --rs-ink: #14213d;
    --rs-ink-2: #263244;
    --rs-muted: #687385;
    --rs-line: #dde5ec;
    --rs-paper: #f4f7f9;
    --rs-card: #ffffff;
    --rs-teal: #d8b45c;
    --rs-teal-2: #9b742a;
    --rs-coral: #ff6b57;
    --rs-gold: #f4b942;
    --rs-blue: #2f6fed;
    --rs-shadow: 0 18px 55px rgba(20, 33, 61, .10);
    --rs-shadow-soft: 0 10px 30px rgba(20, 33, 61, .08);
}

html {
    scroll-behavior: smooth;
}

body {
    color: var(--rs-ink) !important;
    background:
        radial-gradient(circle at 12% -10%, rgba(216, 180, 92, .18), transparent 28%),
        radial-gradient(circle at 92% 4%, rgba(255, 107, 87, .15), transparent 26%),
        linear-gradient(180deg, #fbfcfd 0%, var(--rs-paper) 52%, #eef4f6 100%) !important;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(20, 33, 61, .035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(20, 33, 61, .035) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,.55), transparent 70%);
    z-index: -1;
}

.shell {
    width: min(1220px, calc(100% - 36px)) !important;
}

.topbar {
    position: sticky;
    top: 10px;
    z-index: 10;
    margin-top: 10px;
    padding: 10px 12px !important;
    border: 1px solid rgba(221, 229, 236, .88);
    border-radius: 16px;
    background: rgba(255, 255, 255, .86);
    box-shadow: var(--rs-shadow-soft);
    backdrop-filter: blur(18px);
}

.brand {
    min-width: 0;
    color: var(--rs-ink);
}

.brand-logo,
.brand img {
    width: 54px !important;
    height: 54px !important;
    border-radius: 14px;
    background: white;
    box-shadow: inset 0 0 0 1px rgba(221, 229, 236, .8), 0 10px 22px rgba(20, 33, 61, .10);
    filter: none !important;
}

.brand small,
.sub,
.muted {
    color: var(--rs-muted) !important;
}

.top-actions,
.nav,
.actions {
    gap: 10px !important;
}

.language-switcher {
    position: relative;
    display: inline-flex !important;
    align-items: center;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 12px !important;
    background: transparent !important;
    box-shadow: none !important;
    color: var(--rs-ink);
}

.language-switcher summary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-height: 42px;
    padding: 0 12px;
    border: 1px solid rgba(221, 229, 236, .95);
    border-radius: 12px;
    background: rgba(255, 255, 255, .88);
    box-shadow: 0 10px 20px rgba(20, 33, 61, .08);
    cursor: pointer;
    list-style: none;
    font-size: .8rem;
    font-weight: 900;
    line-height: 1;
    white-space: nowrap;
}

.language-switcher summary::-webkit-details-marker {
    display: none;
}

.language-switcher summary::after {
    content: "";
    width: 7px;
    height: 7px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: translateY(-2px) rotate(45deg);
    opacity: .72;
}

.language-switcher[open] summary {
    border-color: rgba(216, 180, 92, .40);
    box-shadow: 0 0 0 4px rgba(216, 180, 92, .12), 0 14px 26px rgba(20, 33, 61, .12);
}

.language-menu {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    z-index: 50;
    display: grid;
    grid-template-columns: repeat(2, minmax(148px, 1fr));
    gap: 6px;
    width: min(360px, calc(100vw - 28px));
    padding: 10px;
    border: 1px solid rgba(221, 229, 236, .95);
    border-radius: 16px;
    background: rgba(255, 255, 255, .96);
    box-shadow: 0 26px 70px rgba(20, 33, 61, .18);
    backdrop-filter: blur(18px);
}

[dir="rtl"] .language-menu {
    right: auto;
    left: 0;
}

.language-menu a {
    display: grid !important;
    grid-template-columns: 28px 38px minmax(0, 1fr);
    align-items: center;
    gap: 7px;
    min-height: 42px !important;
    padding: 7px 9px !important;
    border: 1px solid transparent !important;
    border-radius: 12px !important;
    color: var(--rs-ink) !important;
    background: transparent !important;
    font-size: .8rem !important;
    font-weight: 900 !important;
    line-height: 1.1;
    box-shadow: none !important;
}

.language-menu a:hover {
    border-color: rgba(216, 180, 92, .22) !important;
    background: rgba(216, 180, 92, .08) !important;
}

.language-menu a.active {
    color: #fff !important;
    border-color: transparent !important;
    background: linear-gradient(135deg, var(--rs-ink), #243b67) !important;
}

.language-menu span,
.language-switcher summary span {
    font-size: 1rem;
}

.language-menu em {
    min-width: 0;
    overflow: hidden;
    color: inherit;
    font-style: normal;
    font-weight: 800;
    text-overflow: ellipsis;
    white-space: nowrap;
    opacity: .76;
}

.primary-btn,
.ghost-btn,
.btn,
.danger-btn,
.qr-btn {
    min-height: 42px !important;
    border-radius: 10px !important;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

.primary-btn,
.btn.primary {
    background: linear-gradient(135deg, var(--rs-ink), #243b67) !important;
    box-shadow: 0 14px 28px rgba(20, 33, 61, .18) !important;
}

.ghost-btn,
.nav a,
.btn,
.danger-btn {
    border-color: rgba(221, 229, 236, .95) !important;
    background: rgba(255, 255, 255, .82) !important;
}

.primary-btn:hover,
.ghost-btn:hover,
.btn:hover,
.danger-btn:hover,
.qr-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 24px rgba(20, 33, 61, .12);
}

.hero {
    grid-template-columns: minmax(0, 1.2fr) minmax(330px, .8fr) !important;
    gap: 20px !important;
    padding: 22px 0 28px !important;
}

.intro {
    min-height: 520px !important;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    border-radius: 18px !important;
    padding: clamp(30px, 5vw, 64px) !important;
    background:
        linear-gradient(90deg, rgba(20, 33, 61, .96), rgba(20, 33, 61, .68) 46%, rgba(20, 33, 61, .28)),
        url("https://images.unsplash.com/photo-1556742049-0cfed4f6a45d?auto=format&fit=crop&w=1600&q=82") center / cover !important;
    box-shadow: var(--rs-shadow);
}

.intro::after {
    content: "";
    position: absolute;
    inset: 16px;
    border: 1px solid rgba(255,255,255,.20);
    border-radius: 14px;
    pointer-events: none;
}

.intro h1 {
    max-width: 780px !important;
    font-size: clamp(2.7rem, 7vw, 6.7rem) !important;
    line-height: .88 !important;
    text-wrap: balance;
}

.intro p {
    max-width: 680px !important;
    color: rgba(255,255,255,.86) !important;
    font-size: clamp(1rem, 1.4vw, 1.16rem) !important;
}

.hero-logo {
    width: min(230px, 62vw) !important;
    margin: -10px 0 18px !important;
}

.stats {
    gap: 10px !important;
}

.stat {
    border-radius: 14px !important;
    border-color: rgba(255,255,255,.22) !important;
}

.panel {
    border-color: rgba(221, 229, 236, .95) !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,.92) !important;
    box-shadow: var(--rs-shadow-soft) !important;
}

.info-panel {
    min-height: 520px;
    align-content: end !important;
    padding: 28px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.84)),
        linear-gradient(135deg, rgba(216,180,92,.14), rgba(47,111,237,.12)) !important;
}

.info-panel h2,
.page-head h1,
h1 {
    color: var(--rs-ink) !important;
    text-wrap: balance;
}

.info-panel p {
    color: var(--rs-muted) !important;
}

.badge {
    border: 1px solid rgba(216, 180, 92, .18);
    color: var(--rs-teal-2) !important;
    background: rgba(216, 180, 92, .10) !important;
}

.filters {
    position: relative;
    top: 0;
    grid-template-columns: minmax(0, 1.5fr) minmax(150px, .45fr) minmax(150px, .42fr) !important;
    padding: 14px !important;
    border-radius: 16px !important;
}

.category-rail {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin: 0 0 18px;
}

.category-rail a {
    display: grid;
    gap: 6px;
    min-height: 92px;
    padding: 16px;
    border: 1px solid rgba(221, 229, 236, .95);
    border-radius: 16px;
    background: rgba(255, 255, 255, .86);
    box-shadow: var(--rs-shadow-soft);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.category-rail a:hover {
    transform: translateY(-2px);
    border-color: rgba(216, 180, 92, .36);
    box-shadow: var(--rs-shadow);
}

.category-rail strong {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--rs-ink);
    font-size: .98rem;
}

.rail-icon {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 9px;
    background: #fff;
    box-shadow: inset 0 0 0 1px rgba(216,226,234,.9);
    color: var(--rs-ink);
}

.category-svg-icon {
    width: 1.1em;
    height: 1.1em;
    display: block;
}

.category-icon-fallback {
    display: inline-grid;
    place-items: center;
    font-size: 1rem;
    font-weight: 900;
}

.category-rail span {
    color: var(--rs-muted);
    font-size: .82rem;
    line-height: 1.35;
}

input,
select,
textarea {
    border-color: var(--rs-line) !important;
    border-radius: 12px !important;
    background: #fff !important;
}

input:focus,
select:focus,
textarea:focus {
    border-color: var(--rs-teal) !important;
    box-shadow: 0 0 0 4px rgba(216, 180, 92, .12) !important;
}

.market-head {
    margin: 26px 0 14px !important;
}

.cards {
    gap: 18px !important;
}

.ad-card {
    border-radius: 16px !important;
    box-shadow: var(--rs-shadow-soft) !important;
    transition: transform .18s ease, box-shadow .18s ease;
}

.ad-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--rs-shadow) !important;
}

.ad-media {
    aspect-ratio: 16 / 11 !important;
}

.ad-media img {
    transition: transform .35s ease;
}

.ad-card:hover .ad-media img {
    transform: scale(1.04);
}

.category-chip {
    border: 1px solid rgba(255,255,255,.20);
    background: rgba(20, 33, 61, .84) !important;
    backdrop-filter: blur(10px);
}

.ad-body {
    padding: 18px !important;
}

.ad-body h3 {
    color: var(--rs-ink);
    font-size: 1.12rem !important;
}

.price {
    color: var(--rs-teal-2) !important;
}

.qr-btn {
    background: linear-gradient(135deg, var(--rs-gold), #ffd972) !important;
}

.modal {
    backdrop-filter: blur(10px);
}

.modal-card {
    border-radius: 18px !important;
}

.modal-side {
    background: #f7fafc !important;
}

/* Admin and client dashboards */
.page-head {
    margin: 28px 0 20px !important;
    align-items: center !important;
}

.page-head h1 {
    font-size: clamp(2rem, 4vw, 3.4rem) !important;
}

.stats {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.panel.stat,
.stat.panel {
    min-height: 126px;
    padding: 22px !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,250,252,.92)),
        linear-gradient(135deg, rgba(216,180,92,.10), rgba(47,111,237,.08)) !important;
}

.panel.stat strong,
.stat.panel strong {
    font-size: clamp(2rem, 4vw, 3.1rem) !important;
    letter-spacing: 0;
}

.panel.pad {
    padding: 22px !important;
}

.panel.pad h2 {
    margin: 0 0 16px;
    font-size: 1.05rem;
}

.charts {
    grid-template-columns: minmax(0, 1.25fr) minmax(280px, .75fr) !important;
}

table {
    border-collapse: separate !important;
    border-spacing: 0 !important;
}

th {
    background: #f7fafc;
    color: #718094 !important;
}

td,
th {
    padding: 15px 16px !important;
}

tbody tr:hover td {
    background: #fbfdfe;
}

.table-wrap {
    border-radius: 14px;
    overflow: hidden;
}

.alert,
.errors {
    border-radius: 14px !important;
}

/* Auth screens */
body:has(.card) .card {
    border-radius: 18px !important;
    box-shadow: var(--rs-shadow) !important;
}

body:has(.card) h1 {
    font-size: clamp(2rem, 5vw, 3rem) !important;
}

body:has(.card)::before {
    opacity: .7;
}

@media (max-width: 980px) {
    .hero,
    .charts {
        grid-template-columns: 1fr !important;
    }

    .info-panel {
        min-height: auto;
    }

    .cards {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

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

@media (max-width: 760px) {
    .shell {
        width: min(100% - 24px, 1220px) !important;
    }

    .topbar {
        position: static;
        border-radius: 14px;
    }

    .top-actions,
    .nav {
        width: 100%;
    }

    .top-actions a,
    .nav a,
    .nav form,
    .nav button {
        flex: 1;
    }

    .intro {
        min-height: 520px !important;
    }

    .filters,
    .cards,
    .category-rail,
    .stats,
    .form-grid {
        grid-template-columns: 1fr !important;
    }

    .language-switcher,
    .language-switcher summary {
        width: 100%;
    }

    .language-menu {
        left: 0;
        right: auto;
        grid-template-columns: 1fr;
        width: 100%;
    }
}

/* Final visual polish */
* {
    -webkit-font-smoothing: antialiased;
    text-rendering: geometricPrecision;
}

::selection {
    color: #fff;
    background: var(--rs-teal);
}

body {
    min-height: 100vh;
}

.topbar::before {
    content: "";
    position: absolute;
    inset: -1px;
    z-index: -1;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(216,180,92,.34), rgba(47,111,237,.18), rgba(255,107,87,.20));
    opacity: .65;
}

.topbar {
    isolation: isolate;
}

.brand span,
.brand > div > div {
    letter-spacing: -.02em;
}

.top-actions a,
.nav a,
.nav button {
    white-space: nowrap;
}

.top-actions .language-menu a,
.nav .language-menu a {
    display: grid !important;
    flex: initial !important;
    border-color: transparent !important;
    background: transparent !important;
}

.top-actions .language-menu a:hover,
.nav .language-menu a:hover {
    border-color: rgba(216, 180, 92, .22) !important;
    background: rgba(216, 180, 92, .08) !important;
}

.top-actions .language-menu a.active,
.nav .language-menu a.active {
    color: #fff !important;
    background: linear-gradient(135deg, var(--rs-ink), #243b67) !important;
}

[dir="rtl"] body,
[dir="rtl"] input,
[dir="rtl"] select,
[dir="rtl"] textarea,
[dir="rtl"] button {
    font-family: Inter, "Segoe UI", Tahoma, Arial, sans-serif;
}

[dir="rtl"] .brand,
[dir="rtl"] .top-actions,
[dir="rtl"] .nav,
[dir="rtl"] .actions,
[dir="rtl"] .meta {
    flex-direction: row-reverse;
}

[dir="rtl"] .intro {
    background:
        linear-gradient(270deg, rgba(20, 33, 61, .96), rgba(20, 33, 61, .68) 46%, rgba(20, 33, 61, .28)),
        url("https://images.unsplash.com/photo-1556742049-0cfed4f6a45d?auto=format&fit=crop&w=1600&q=82") center / cover !important;
}

[dir="rtl"] .category-rail a::after {
    transform-origin: right;
}

[dir="rtl"] th,
[dir="rtl"] td {
    text-align: right !important;
}

.intro::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(135deg, rgba(216,180,92,.22), transparent 32%),
        linear-gradient(315deg, rgba(244,185,66,.18), transparent 30%);
    mix-blend-mode: screen;
    pointer-events: none;
}

.intro > * {
    position: relative;
    z-index: 1;
}

.intro h1,
.auth-copy h1 {
    letter-spacing: -.055em !important;
}

.hero-logo {
    background: rgba(255,255,255,.96);
    border-radius: 22px;
    padding: 10px;
}

.info-panel {
    position: relative;
    overflow: hidden;
}

.info-panel::before {
    content: "";
    position: absolute;
    right: -72px;
    top: -72px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: rgba(216,180,92,.12);
}

.info-panel::after {
    content: "";
    position: absolute;
    left: 28px;
    top: 28px;
    width: 64px;
    height: 5px;
    border-radius: 99px;
    background: linear-gradient(90deg, var(--rs-teal), var(--rs-gold));
}

.info-panel > * {
    position: relative;
    z-index: 1;
}

.category-rail a {
    position: relative;
    overflow: hidden;
}

.category-rail a::after {
    content: "";
    position: absolute;
    left: 16px;
    right: 16px;
    bottom: 0;
    height: 3px;
    border-radius: 999px 999px 0 0;
    background: linear-gradient(90deg, var(--rs-teal), var(--rs-gold));
    transform: scaleX(.25);
    transform-origin: left;
    transition: transform .18s ease;
}

.category-rail a:hover::after {
    transform: scaleX(1);
}

.filters {
    box-shadow: 0 18px 45px rgba(20, 33, 61, .09) !important;
}

.filters input,
.filters select {
    min-height: 50px;
}

.ad-card {
    position: relative;
}

.ad-card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    border-radius: inherit;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.75);
}

.ad-media::after {
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    height: 40%;
    background: linear-gradient(to top, rgba(20,33,61,.36), transparent);
    pointer-events: none;
}

.ad-actions .ghost-btn,
.ad-actions .qr-btn {
    min-height: 44px !important;
}

.meta span {
    color: #718094;
}

.price {
    letter-spacing: -.03em;
}

.modal-card {
    border: 1px solid rgba(255,255,255,.65);
}

.qr-box {
    background:
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,250,252,.96)),
        radial-gradient(circle at 50% 50%, rgba(216,180,92,.10), transparent 55%) !important;
}

.page-head {
    padding: 12px 0;
}

.page-head .actions {
    padding: 6px;
    border: 1px solid rgba(221,229,236,.86);
    border-radius: 14px;
    background: rgba(255,255,255,.72);
}

.panel.stat {
    position: relative;
    overflow: hidden;
}

.panel.stat::after {
    content: "";
    position: absolute;
    right: -30px;
    bottom: -44px;
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: rgba(216,180,92,.10);
}

.panel.stat strong,
.panel.stat span {
    position: relative;
    z-index: 1;
}

.panel.pad canvas {
    max-width: 100%;
}

th:first-child {
    border-top-left-radius: 14px;
}

th:last-child {
    border-top-right-radius: 14px;
}

tbody tr:last-child td:first-child {
    border-bottom-left-radius: 14px;
}

tbody tr:last-child td:last-child {
    border-bottom-right-radius: 14px;
}

.badge {
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.55);
}

.danger-btn {
    background: rgba(255,255,255,.86) !important;
}

@media (prefers-reduced-motion: no-preference) {
    .ad-card,
    .category-rail a,
    .panel,
    .primary-btn,
    .ghost-btn,
    .btn {
        will-change: transform;
    }
}

/* v3 premium finish */
:root {
    --rs-radius-xl: 24px;
    --rs-radius-lg: 18px;
    --rs-focus: 0 0 0 4px rgba(216, 180, 92, .14), 0 12px 28px rgba(20, 33, 61, .10);
}

.auth-page {
    background:
        linear-gradient(90deg, rgba(10, 20, 38, .94), rgba(20, 33, 61, .74) 48%, rgba(20, 33, 61, .45)),
        linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.24)),
        var(--auth-bg, url("https://images.unsplash.com/photo-1556742502-ec7c0e9f34b1?auto=format&fit=crop&w=1800&q=86")) center / cover fixed !important;
}

.auth-register {
    --auth-bg: url("https://images.unsplash.com/photo-1554224155-6726b3ff858f?auto=format&fit=crop&w=1800&q=86");
}

.auth-page::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: linear-gradient(90deg, rgba(0,0,0,.7), transparent 75%);
}

.auth-page .auth-shell,
.auth-page .auth-tools {
    position: relative;
    z-index: 1;
}

.auth-page .auth-shell {
    width: min(1180px, calc(100% - 40px)) !important;
    gap: clamp(24px, 5vw, 58px) !important;
}

.auth-page .brand {
    min-height: 64px;
    padding: 7px 12px 7px 7px;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 999px;
    background: rgba(255,255,255,.10);
    backdrop-filter: blur(14px);
}

[dir="rtl"] .auth-page .brand {
    padding: 7px 7px 7px 12px;
}

.auth-page .brand img {
    width: 50px !important;
    height: 50px !important;
}

.auth-page .auth-copy h1 {
    max-width: 760px !important;
    letter-spacing: -.065em !important;
    text-shadow: 0 20px 50px rgba(0,0,0,.32);
}

.auth-page .auth-copy p {
    max-width: 620px !important;
    font-size: 1.12rem !important;
}

.auth-page .card {
    position: relative;
    overflow: hidden;
    padding: clamp(24px, 4vw, 38px) !important;
    border: 1px solid rgba(255,255,255,.72) !important;
    border-radius: 28px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.97), rgba(250,252,253,.94)),
        linear-gradient(135deg, rgba(216,180,92,.12), rgba(47,111,237,.10)) !important;
    box-shadow: 0 34px 100px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.85) !important;
}

.auth-page .card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
    background: linear-gradient(90deg, var(--rs-teal), var(--rs-gold), var(--rs-blue));
}

.auth-page .card h2 {
    margin-top: 8px !important;
    color: var(--rs-ink);
    font-size: clamp(2rem, 4vw, 2.8rem) !important;
    letter-spacing: -.045em !important;
}

.auth-page .card p {
    margin-bottom: 26px !important;
}

.auth-page label {
    color: #334155 !important;
    letter-spacing: .01em;
}

.auth-page input {
    min-height: 54px !important;
    border: 1px solid #d8e2ea !important;
    border-radius: 14px !important;
    background:
        linear-gradient(180deg, #fff, #fbfdfe) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
}

.auth-page input:focus {
    border-color: var(--rs-teal) !important;
    box-shadow: var(--rs-focus) !important;
}

.auth-page .submit,
.auth-page .secondary {
    min-height: 52px !important;
    border-radius: 14px !important;
}

.auth-page .submit {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--rs-ink), #263f70 58%, #0b766d) !important;
}

.auth-page .submit::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
    transform: translateX(-110%);
    transition: transform .45s ease;
}

.auth-page .submit:hover::after {
    transform: translateX(110%);
}

.auth-page .secondary {
    color: var(--rs-ink);
    background: rgba(255,255,255,.76) !important;
    border-color: #d8e2ea !important;
}

.auth-page .proof,
.auth-page .step {
    border-color: rgba(255,255,255,.22) !important;
    background: rgba(255,255,255,.13) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.16), 0 18px 40px rgba(0,0,0,.12);
}

.auth-page .step b {
    box-shadow: 0 12px 22px rgba(0,0,0,.16);
}

.auth-page .auth-tools .language-switcher {
    border-color: rgba(255,255,255,.30) !important;
    background: rgba(255,255,255,.16) !important;
    box-shadow: 0 14px 30px rgba(0,0,0,.16);
}

.auth-page .error {
    border-radius: 14px !important;
}

.topbar {
    border-radius: 20px !important;
}

.intro,
.info-panel,
.ad-card,
.category-rail a,
.filters,
.panel {
    border-radius: var(--rs-radius-lg) !important;
}

.intro {
    min-height: 560px !important;
}

.intro h1 {
    max-width: 860px !important;
}

.category-rail a {
    min-height: 104px;
    padding: 18px !important;
}

.category-rail strong {
    font-size: 1.04rem !important;
}

.ad-card {
    border-color: rgba(216,226,234,.92) !important;
}

.ad-body h3 {
    font-size: 1.2rem !important;
    letter-spacing: -.02em;
}

.panel.pad,
.panel.stat {
    border-radius: 20px !important;
}

.page-head h1 {
    letter-spacing: -.05em !important;
}

@media (max-width: 760px) {
    .auth-page .auth-shell {
        width: min(100% - 24px, 1180px) !important;
        padding-top: 84px !important;
    }

    .auth-page .card {
        border-radius: 22px !important;
    }

    .auth-page .proofs,
    .auth-page .steps {
        display: none !important;
    }
}

/* Neutral premium hero */
body {
    background:
        linear-gradient(180deg, #f7f8fa 0%, #eef1f4 100%) !important;
}

body::before {
    background-image:
        linear-gradient(rgba(15, 23, 42, .035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15, 23, 42, .035) 1px, transparent 1px);
    opacity: .72;
}

.topbar::before {
    background: linear-gradient(135deg, rgba(15, 23, 42, .14), rgba(255, 255, 255, .68)) !important;
}

.hero {
    grid-template-columns: minmax(0, 1.15fr) minmax(330px, .85fr) !important;
    gap: 18px !important;
}

.intro {
    min-height: 560px !important;
    justify-content: space-between !important;
    color: #111827 !important;
    background:
        linear-gradient(115deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.96) 58%, rgba(241,244,248,.88) 100%),
        url("https://images.unsplash.com/photo-1556742049-0cfed4f6a45d?auto=format&fit=crop&w=1600&q=82") right center / cover !important;
    border: 1px solid rgba(209, 216, 224, .95);
    box-shadow: 0 28px 80px rgba(15, 23, 42, .12) !important;
}

.intro::before {
    display: none !important;
}

.intro::after {
    inset: 18px !important;
    border: 1px solid rgba(17, 24, 39, .08) !important;
    border-radius: calc(var(--rs-radius-lg) - 6px) !important;
}

[dir="rtl"] .intro {
    background:
        linear-gradient(245deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.96) 58%, rgba(241,244,248,.88) 100%),
        url("https://images.unsplash.com/photo-1556742049-0cfed4f6a45d?auto=format&fit=crop&w=1600&q=82") left center / cover !important;
}

[dir="rtl"] .hero-qr-bg {
    right: auto;
    left: clamp(20px, 4vw, 54px);
    transform: rotate(7deg);
}

.intro h1 {
    max-width: 760px !important;
    color: #0f172a !important;
    font-size: clamp(2.45rem, 6.3vw, 6.15rem) !important;
    line-height: .92 !important;
    letter-spacing: 0 !important;
    text-shadow: none !important;
}

.intro p {
    max-width: 610px !important;
    color: #4b5563 !important;
    font-size: clamp(1rem, 1.25vw, 1.13rem) !important;
    line-height: 1.72 !important;
    text-shadow: none !important;
}

.hero-logo {
    width: min(190px, 52vw) !important;
    margin: 0 0 22px !important;
    border: 1px solid rgba(209, 216, 224, .95);
    background: #fff !important;
    box-shadow: 0 16px 36px rgba(15, 23, 42, .10);
}

.hero-qr-bg {
    position: absolute !important;
    right: clamp(20px, 4vw, 54px);
    bottom: clamp(28px, 5vw, 58px);
    z-index: 0 !important;
    display: grid;
    place-items: center;
    width: clamp(210px, 24vw, 330px);
    height: clamp(210px, 24vw, 330px);
    padding: clamp(18px, 2vw, 26px);
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 32px;
    background: rgba(255, 255, 255, .44);
    box-shadow: 0 30px 90px rgba(15, 23, 42, .10);
    opacity: .22;
    pointer-events: none;
    transform: rotate(-7deg);
    filter: grayscale(1);
    overflow: hidden;
}

.hero-qr-bg canvas,
.hero-qr-bg img {
    width: 100% !important;
    height: 100% !important;
    display: block;
}

.intro .stats {
    margin-top: 30px !important;
}

.intro .stat {
    color: #0f172a !important;
    background: rgba(248, 250, 252, .92) !important;
    border-color: rgba(209, 216, 224, .95) !important;
    box-shadow: 0 12px 26px rgba(15, 23, 42, .08);
    backdrop-filter: blur(8px);
}

.intro .stat span {
    color: #64748b !important;
}

.info-panel {
    min-height: 560px !important;
    border-color: rgba(209, 216, 224, .95) !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,248,250,.94)),
        linear-gradient(135deg, rgba(15,23,42,.06), rgba(255,255,255,.64)) !important;
}

.info-panel::before {
    right: -90px;
    top: -90px;
    width: 230px;
    height: 230px;
    background: rgba(15, 23, 42, .06) !important;
}

.info-panel::after {
    width: 74px;
    background: #111827 !important;
}

.info-panel h2 {
    color: #111827 !important;
    letter-spacing: 0 !important;
}

.info-panel p {
    color: #4b5563 !important;
}

@media (max-width: 760px) {
    .intro,
    .info-panel {
        min-height: auto !important;
    }

    .intro {
        padding: 28px !important;
        background: #fff !important;
    }

    .intro .stats {
        display: grid;
        grid-template-columns: 1fr !important;
    }

    .hero-qr-bg {
        right: 18px;
        bottom: 18px;
        width: 190px;
        height: 190px;
        opacity: .13;
    }
}

/* Ultra responsive hero composition */
.hero {
    align-items: stretch !important;
}

.intro {
    display: flex !important;
    flex-direction: column !important;
    min-height: clamp(500px, 62vh, 680px) !important;
    padding: clamp(28px, 4.6vw, 68px) !important;
    overflow: hidden !important;
    isolation: isolate;
}

.intro::after {
    pointer-events: none;
}

.intro h1,
.intro p,
.intro .stats,
.hero-logo {
    max-width: min(760px, 72%) !important;
}

.intro h1 {
    font-size: clamp(2.25rem, 5.8vw, 6.2rem) !important;
    text-wrap: balance;
}

.intro p {
    text-wrap: pretty;
}

.hero-qr-bg {
    width: clamp(220px, 27vw, 390px) !important;
    height: clamp(220px, 27vw, 390px) !important;
    right: clamp(18px, 4.5vw, 72px) !important;
    bottom: clamp(26px, 5vw, 76px) !important;
    opacity: .18 !important;
}

.hero-qr-bg::after {
    content: "";
    position: absolute;
    inset: -18%;
    background: radial-gradient(circle, transparent 42%, rgba(255,255,255,.64) 70%);
    pointer-events: none;
}

.intro .stats {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: clamp(8px, 1vw, 12px) !important;
}

.intro .stat {
    min-width: clamp(112px, 12vw, 150px) !important;
    padding: clamp(12px, 1.4vw, 18px) !important;
}

.info-panel {
    min-height: clamp(500px, 62vh, 680px) !important;
    padding: clamp(24px, 3vw, 38px) !important;
}

.info-panel h2 {
    font-size: clamp(1.65rem, 3.2vw, 2.9rem) !important;
    line-height: 1.02 !important;
    text-wrap: balance;
}

@media (min-width: 1440px) {
    .shell {
        width: min(1320px, calc(100% - 56px)) !important;
    }

    .intro h1,
    .intro p,
    .intro .stats,
    .hero-logo {
        max-width: 820px !important;
    }
}

@media (max-width: 1180px) {
    .hero {
        grid-template-columns: minmax(0, 1fr) minmax(300px, .72fr) !important;
    }

    .intro h1,
    .intro p,
    .intro .stats,
    .hero-logo {
        max-width: min(680px, 78%) !important;
    }

    .hero-qr-bg {
        opacity: .14 !important;
        transform: rotate(-5deg) translateX(8%);
    }
}

@media (max-width: 980px) {
    .hero {
        grid-template-columns: 1fr !important;
    }

    .intro,
    .info-panel {
        min-height: auto !important;
    }

    .intro {
        padding: clamp(28px, 7vw, 54px) !important;
    }

    .intro h1,
    .intro p,
    .intro .stats,
    .hero-logo {
        max-width: min(720px, 100%) !important;
    }

    .hero-qr-bg {
        top: 22px;
        right: 22px !important;
        bottom: auto !important;
        width: clamp(170px, 30vw, 250px) !important;
        height: clamp(170px, 30vw, 250px) !important;
        opacity: .10 !important;
    }
}

@media (max-width: 640px) {
    .shell {
        width: min(100% - 20px, 1220px) !important;
    }

    .top-actions {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
    }

    .top-actions .language-switcher {
        grid-column: 1 / -1;
    }

    .intro {
        padding: 26px 22px !important;
        border-radius: 18px !important;
    }

    .intro::after {
        inset: 12px !important;
        border-radius: 14px !important;
    }

    .intro h1 {
        font-size: clamp(2rem, 12vw, 3.65rem) !important;
        line-height: .96 !important;
    }

    .intro p {
        font-size: .98rem !important;
        line-height: 1.64 !important;
    }

    .hero-logo {
        width: min(150px, 48vw) !important;
    }

    .hero-qr-bg {
        top: auto !important;
        right: -32px !important;
        bottom: -32px !important;
        width: 210px !important;
        height: 210px !important;
        opacity: .08 !important;
        transform: rotate(-8deg);
    }

    .intro .stats {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        width: 100%;
    }

    .intro .stat {
        min-width: 0 !important;
        padding: 12px 10px !important;
    }

    .intro .stat strong {
        font-size: clamp(1.05rem, 6vw, 1.45rem) !important;
    }
}

@media (max-width: 420px) {
    .top-actions {
        grid-template-columns: 1fr !important;
    }

    .intro {
        padding: 24px 18px !important;
    }

    .intro .stats {
        grid-template-columns: 1fr !important;
    }

    .hero-qr-bg {
        width: 180px !important;
        height: 180px !important;
        opacity: .065 !important;
    }
}

/* Admin category builder */
.category-builder {
    margin-bottom: 18px;
}

.icon-picker {
    display: grid;
    gap: 14px;
    padding: 14px;
    border: 1px solid rgba(216,226,234,.95);
    border-radius: 18px;
    background: linear-gradient(180deg, #fff, #f8fafc);
}

.icon-picker-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 58px;
    gap: 12px;
    align-items: end;
}

.icon-preview {
    display: grid;
    place-items: center;
    width: 58px;
    height: 58px;
    border: 1px solid rgba(216,226,234,.95);
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 14px 28px rgba(20,33,61,.09);
    color: var(--rs-ink);
}

.icon-preview .category-svg-icon {
    width: 30px;
    height: 30px;
    stroke-width: 1.65;
}

.icon-groups {
    display: grid;
    gap: 12px;
    max-height: 430px;
    overflow: auto;
    padding-right: 4px;
}

.icon-groups section {
    display: grid;
    gap: 8px;
}

.icon-groups h3 {
    margin: 0;
    color: var(--rs-muted);
    font-size: .78rem;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.icon-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(42px, 1fr));
    gap: 8px;
}

.icon-choice {
    display: grid;
    place-items: center;
    min-height: 42px;
    border: 1px solid rgba(216,226,234,.95);
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 8px 18px rgba(20,33,61,.06);
    color: var(--rs-ink);
    transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.icon-choice .category-svg-icon {
    width: 22px;
    height: 22px;
    stroke-width: 1.75;
}

.icon-choice:hover,
.icon-choice.active {
    transform: translateY(-1px);
    border-color: rgba(216,180,92,.42);
    background: rgba(216,180,92,.08);
    box-shadow: 0 12px 24px rgba(20,33,61,.10);
}

.check-row {
    display: flex !important;
    align-items: center;
    gap: 9px;
    min-height: 44px;
    color: var(--rs-ink);
}

.check-row input {
    width: auto !important;
}

.check-row.compact {
    min-height: 40px;
    font-size: .78rem;
}

.category-admin-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.category-admin-card {
    display: grid;
    gap: 16px;
}

.category-admin-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.category-admin-title {
    display: flex;
    align-items: center;
    gap: 12px;
}

.category-admin-title h2 {
    margin: 0;
    font-size: 1.25rem;
}

.category-icon {
    display: grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border-radius: 14px;
    border: 1px solid rgba(216,226,234,.95);
    background: #fff;
    box-shadow: 0 12px 24px rgba(20,33,61,.08);
    color: var(--rs-ink);
}

.category-icon .category-svg-icon {
    width: 24px;
    height: 24px;
    stroke-width: 1.7;
}

.field-list {
    display: grid;
    gap: 8px;
}

.field-pill {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 12px;
    border: 1px solid rgba(216,226,234,.95);
    border-radius: 14px;
    background: #f8fafc;
}

.field-pill strong,
.field-pill span {
    display: block;
}

.field-pill span {
    margin-top: 3px;
    color: var(--rs-muted);
    font-size: .78rem;
    font-weight: 800;
}

.danger-btn.mini {
    min-height: 32px !important;
    width: 32px;
    padding: 0 !important;
}

.field-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 120px 80px;
    gap: 10px;
}

.field-form textarea {
    grid-column: 1 / -1;
    min-height: 76px;
}

.field-form .btn {
    grid-column: 1 / -1;
}

@media (max-width: 900px) {
    .category-admin-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 560px) {
    .category-admin-head,
    .category-admin-title {
        align-items: flex-start;
        flex-direction: column;
    }

    .field-form {
        grid-template-columns: 1fr;
    }
}

.dynamic-fields {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid rgba(216,180,92,.18);
    border-radius: 16px;
    background:
        linear-gradient(135deg, rgba(216,180,92,.07), rgba(47,111,237,.05)),
        #fff;
}

.dynamic-fields:empty {
    display: none;
}

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

.dynamic-fields-head strong {
    color: var(--rs-ink);
}

.dynamic-fields-head span {
    color: var(--rs-muted);
    font-size: .78rem;
    font-weight: 900;
}

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

.modal-fields {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 14px 0;
}

.modal-fields span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 10px;
    border: 1px solid rgba(216,226,234,.95);
    border-radius: 999px;
    color: var(--rs-ink);
    background: #f8fafc;
    font-size: .82rem;
    font-weight: 850;
}

.dashboard-categories {
    margin-top: 18px;
}

.dashboard-categories-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 14px;
}

.dashboard-categories-head h2 {
    margin: 0 0 6px;
}

.dashboard-category-list {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
}

.dashboard-category-list span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 36px;
    padding: 0 12px;
    border: 1px solid rgba(216,226,234,.95);
    border-radius: 999px;
    background: #f8fafc;
    font-weight: 850;
}

.dashboard-category-list b {
    display: inline-grid;
    place-items: center;
    width: 22px;
    height: 22px;
}

.dashboard-category-list b .category-svg-icon {
    width: 19px;
    height: 19px;
}

@media (max-width: 680px) {
    .dashboard-categories-head {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 680px) {
    .dynamic-fields-grid {
        grid-template-columns: 1fr;
    }
}

/* High-impact premium skin */
:root {
    --rs-deep: #07111f;
    --rs-night: #0d1726;
    --rs-steel: #172438;
    --rs-electric: #d8b45c;
    --rs-flame: #ff6b4a;
    --rs-amber: #ffcb52;
    --rs-ice: #f8fbff;
    --rs-glass: rgba(255,255,255,.78);
    --rs-hard-shadow: 0 34px 90px rgba(7,17,31,.22);
}

body {
    background:
        linear-gradient(180deg, #f7f9fc 0%, #edf2f7 48%, #f8fbff 100%) !important;
}

body::before {
    background-image:
        linear-gradient(rgba(7,17,31,.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(7,17,31,.045) 1px, transparent 1px) !important;
    background-size: 36px 36px !important;
    opacity: .55;
}

.topbar {
    border: 1px solid rgba(255,255,255,.38) !important;
    background:
        linear-gradient(135deg, rgba(255,255,255,.94), rgba(255,255,255,.76)) !important;
    box-shadow: 0 22px 70px rgba(7,17,31,.14) !important;
}

.brand-logo,
.brand img {
    border-radius: 18px !important;
    box-shadow: 0 18px 40px rgba(7,17,31,.18), inset 0 0 0 1px rgba(255,255,255,.9) !important;
}

.primary-btn,
.btn.primary {
    position: relative;
    overflow: hidden;
    border: 0 !important;
    color: #fff !important;
    background:
        linear-gradient(135deg, var(--rs-deep), #172846 54%, #4e3b1d) !important;
    box-shadow: 0 18px 38px rgba(7,17,31,.22) !important;
}

.primary-btn::after,
.btn.primary::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.26) 48%, transparent 64%);
    transform: translateX(-120%);
    transition: transform .55s ease;
}

.primary-btn:hover::after,
.btn.primary:hover::after {
    transform: translateX(120%);
}

.ghost-btn,
.nav a,
.btn,
.danger-btn,
.language-switcher summary {
    border-color: rgba(199,210,224,.92) !important;
    background: rgba(255,255,255,.82) !important;
    box-shadow: 0 12px 28px rgba(7,17,31,.08) !important;
}

.hero {
    gap: 22px !important;
    padding-top: 28px !important;
}

.intro {
    min-height: 640px !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    background:
        linear-gradient(90deg, rgba(7,17,31,.98) 0%, rgba(7,17,31,.88) 42%, rgba(7,17,31,.42) 100%),
        url("https://images.unsplash.com/photo-1556742049-0cfed4f6a45d?auto=format&fit=crop&w=1800&q=88") center / cover !important;
    box-shadow: 0 44px 110px rgba(7,17,31,.34) !important;
}

.intro::before {
    content: "" !important;
    display: block !important;
    position: absolute;
    inset: auto 0 0 0;
    height: 7px;
    background: linear-gradient(90deg, var(--rs-electric), var(--rs-amber), var(--rs-flame));
    opacity: 1;
    pointer-events: none;
}

.intro::after {
    border-color: rgba(255,255,255,.16) !important;
}

.intro h1,
.intro p,
.intro .stats,
.hero-logo {
    max-width: 760px !important;
}

.intro h1 {
    color: #fff !important;
    font-size: 5.6rem !important;
    line-height: .9 !important;
    letter-spacing: 0 !important;
    text-shadow: 0 24px 70px rgba(0,0,0,.38) !important;
}

.intro p {
    color: rgba(255,255,255,.78) !important;
    font-size: 1.15rem !important;
    line-height: 1.72 !important;
}

.hero-logo {
    width: 174px !important;
    border: 1px solid rgba(255,255,255,.28) !important;
    background: rgba(255,255,255,.96) !important;
    box-shadow: 0 28px 70px rgba(0,0,0,.28) !important;
}

.hero-qr-bg {
    width: 380px !important;
    height: 380px !important;
    right: 44px !important;
    bottom: 44px !important;
    border-color: rgba(255,255,255,.16) !important;
    background: rgba(255,255,255,.12) !important;
    opacity: .17 !important;
    filter: invert(1) grayscale(1);
    box-shadow: 0 32px 90px rgba(0,0,0,.18) !important;
}

.intro .stat {
    color: #fff !important;
    border-color: rgba(255,255,255,.18) !important;
    background: rgba(255,255,255,.10) !important;
    box-shadow: 0 18px 44px rgba(0,0,0,.18) !important;
}

.intro .stat span {
    color: rgba(255,255,255,.70) !important;
}

.info-panel {
    min-height: 640px !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    background:
        linear-gradient(155deg, rgba(13,23,38,.98), rgba(23,36,56,.94)),
        linear-gradient(135deg, rgba(216,180,92,.18), rgba(255,107,74,.16)) !important;
    box-shadow: 0 44px 100px rgba(7,17,31,.22) !important;
}

.info-panel::before {
    right: -40px !important;
    top: -40px !important;
    width: 210px !important;
    height: 210px !important;
    border-radius: 44px !important;
    background: linear-gradient(135deg, rgba(216,180,92,.24), rgba(255,203,82,.12)) !important;
    transform: rotate(14deg);
}

.info-panel::after {
    background: linear-gradient(90deg, var(--rs-electric), var(--rs-amber), var(--rs-flame)) !important;
}

.info-panel h2 {
    color: #fff !important;
    font-size: 2.75rem !important;
    line-height: 1 !important;
}

.info-panel p {
    color: rgba(255,255,255,.72) !important;
}

.info-panel .badge {
    color: #041017 !important;
    background: linear-gradient(135deg, var(--rs-electric), #7cf7e3) !important;
    border: 0 !important;
}

.category-rail {
    margin-top: 4px !important;
    gap: 14px !important;
}

.category-rail a {
    min-height: 124px !important;
    border: 1px solid rgba(199,210,224,.85) !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,255,.88)) !important;
    box-shadow: 0 22px 52px rgba(7,17,31,.10) !important;
}

.category-rail a::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(216,180,92,.11), transparent 40%, rgba(255,107,74,.10));
    opacity: 0;
    transition: opacity .2s ease;
}

.category-rail a:hover::before {
    opacity: 1;
}

.rail-icon {
    width: 42px !important;
    height: 42px !important;
    color: #fff !important;
    border: 0 !important;
    background: linear-gradient(135deg, var(--rs-deep), #264162) !important;
    box-shadow: 0 16px 32px rgba(7,17,31,.18) !important;
}

.rail-icon .category-svg-icon {
    width: 22px;
    height: 22px;
}

.filters {
    border: 1px solid rgba(255,255,255,.55) !important;
    background: rgba(255,255,255,.78) !important;
    box-shadow: 0 26px 70px rgba(7,17,31,.12) !important;
    backdrop-filter: blur(18px);
}

input,
select,
textarea {
    border-color: rgba(199,210,224,.95) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}

input:focus,
select:focus,
textarea:focus {
    border-color: rgba(216,180,92,.72) !important;
    box-shadow: 0 0 0 4px rgba(216,180,92,.14), inset 0 1px 0 rgba(255,255,255,.8) !important;
}

.market-head h2,
.page-head h1 {
    color: var(--rs-deep) !important;
    letter-spacing: 0 !important;
}

.ad-card {
    border: 1px solid rgba(199,210,224,.86) !important;
    background: #fff !important;
    box-shadow: 0 30px 76px rgba(7,17,31,.13) !important;
}

.ad-card:hover {
    transform: translateY(-6px) !important;
    box-shadow: 0 42px 96px rgba(7,17,31,.18) !important;
}

.category-chip {
    background: rgba(7,17,31,.88) !important;
    box-shadow: 0 12px 28px rgba(0,0,0,.18);
}

.ad-body h3 {
    color: var(--rs-deep) !important;
    letter-spacing: 0 !important;
}

.price {
    color: #9b742a !important;
}

.qr-btn {
    color: #06101e !important;
    background: linear-gradient(135deg, var(--rs-amber), #ffe18a) !important;
}

.modal-card,
.panel,
.category-admin-card,
.dashboard-categories {
    box-shadow: 0 30px 80px rgba(7,17,31,.12) !important;
}

.icon-picker,
.dynamic-fields {
    border-color: rgba(199,210,224,.88) !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,255,.92)) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.9), 0 18px 44px rgba(7,17,31,.08);
}

.icon-choice,
.category-icon,
.icon-preview {
    border-color: rgba(199,210,224,.9) !important;
    background: linear-gradient(180deg, #fff, #f7faff) !important;
}

.icon-choice:hover,
.icon-choice.active {
    color: #fff !important;
    border-color: transparent !important;
    background: linear-gradient(135deg, var(--rs-deep), #21405f) !important;
}

@media (max-width: 1180px) {
    .intro,
    .info-panel {
        min-height: 570px !important;
    }

    .intro h1 {
        font-size: 4.4rem !important;
    }

    .hero-qr-bg {
        width: 300px !important;
        height: 300px !important;
    }
}

@media (max-width: 980px) {
    .intro,
    .info-panel {
        min-height: auto !important;
    }

    .intro h1 {
        font-size: 4rem !important;
    }

    .hero-qr-bg {
        width: 250px !important;
        height: 250px !important;
        opacity: .10 !important;
    }
}

@media (max-width: 640px) {
    .hero {
        padding-top: 16px !important;
    }

    .intro {
        padding: 28px 22px !important;
    }

    .intro h1 {
        font-size: 3.1rem !important;
        line-height: .96 !important;
    }

    .intro p {
        font-size: 1rem !important;
    }

    .info-panel h2 {
        font-size: 2.1rem !important;
    }

    .category-rail a {
        min-height: 108px !important;
    }
}

@media (max-width: 420px) {
    .intro h1 {
        font-size: 2.35rem !important;
    }

    .hero-logo {
        width: 132px !important;
    }
}

/* No-green luxury finish */
:root {
    --rs-teal: #d8b45c;
    --rs-teal-2: #9b742a;
    --rs-electric: #d8b45c;
    --rs-flame: #ff6b4a;
    --rs-amber: #f4d98b;
    --rs-blue: #8aa4c7;
}

body {
    background:
        radial-gradient(circle at 18% -12%, rgba(216,180,92,.16), transparent 30%),
        radial-gradient(circle at 96% 4%, rgba(138,164,199,.18), transparent 28%),
        linear-gradient(180deg, #f8f7f3 0%, #edf1f6 52%, #fbfaf6 100%) !important;
}

.primary-btn,
.btn.primary {
    background:
        linear-gradient(135deg, #07111f 0%, #1a2a43 52%, #4e3b1d 100%) !important;
}

.primary-btn::after,
.btn.primary::after {
    background: linear-gradient(110deg, transparent 0%, rgba(244,217,139,.34) 48%, transparent 66%) !important;
}

.language-switcher[open] summary,
input:focus,
select:focus,
textarea:focus {
    border-color: rgba(216,180,92,.72) !important;
    box-shadow: 0 0 0 4px rgba(216,180,92,.16), 0 14px 28px rgba(7,17,31,.10) !important;
}

.language-menu a:hover,
.top-actions .language-menu a:hover,
.nav .language-menu a:hover {
    border-color: rgba(216,180,92,.36) !important;
    background: rgba(216,180,92,.12) !important;
}

.language-menu a.active,
.top-actions .language-menu a.active,
.nav .language-menu a.active {
    background: linear-gradient(135deg, #07111f, #2f4263) !important;
}

.intro::before,
.info-panel::after,
.category-rail a::after {
    background: linear-gradient(90deg, #d8b45c, #f4d98b, #8aa4c7) !important;
}

.info-panel {
    background:
        linear-gradient(155deg, rgba(7,17,31,.99), rgba(23,36,56,.96)),
        linear-gradient(135deg, rgba(216,180,92,.18), rgba(138,164,199,.16)) !important;
}

.info-panel::before {
    background: linear-gradient(135deg, rgba(216,180,92,.25), rgba(138,164,199,.16)) !important;
}

.info-panel .badge,
.badge {
    color: #221706 !important;
    border-color: rgba(216,180,92,.30) !important;
    background: linear-gradient(135deg, #f4d98b, #d8b45c) !important;
}

.category-rail a::before {
    background: linear-gradient(135deg, rgba(216,180,92,.14), transparent 42%, rgba(138,164,199,.13)) !important;
}

.rail-icon,
.icon-choice:hover,
.icon-choice.active {
    background: linear-gradient(135deg, #07111f, #2f4263 58%, #6f5224) !important;
}

.price {
    color: #9b742a !important;
}

.qr-btn {
    background: linear-gradient(135deg, #f4d98b, #d8b45c) !important;
}

.dynamic-fields {
    border-color: rgba(216,180,92,.25) !important;
    background:
        linear-gradient(135deg, rgba(216,180,92,.10), rgba(138,164,199,.07)),
        #fff !important;
}

.icon-choice:hover,
.icon-choice.active {
    box-shadow: 0 16px 34px rgba(7,17,31,.18) !important;
}

::selection {
    background: #d8b45c !important;
}

.subscription-strip,
.subscription-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-top: 18px;
    border-color: rgba(216,180,92,.28) !important;
    background:
        linear-gradient(135deg, rgba(244,217,139,.16), rgba(138,164,199,.10)),
        #fff !important;
}

.subscription-strip strong,
.subscription-panel h2 {
    color: #07111f;
}

.subscription-panel h2 {
    margin: 14px 0 10px;
    font-size: clamp(2rem, 5vw, 4rem);
    line-height: .9;
}

.subscription-panel form {
    display: grid;
    min-width: min(260px, 100%);
}

@media (max-width: 760px) {
    .subscription-strip,
    .subscription-panel {
        align-items: flex-start;
        flex-direction: column;
    }
}

/* v18 responsive redesign */
:root {
    --rs-deep: #07111f;
    --rs-slate: #20314b;
    --rs-surface: rgba(255, 255, 255, .92);
    --rs-surface-strong: #ffffff;
    --rs-radius-sm: 12px;
    --rs-radius-md: 18px;
    --rs-radius-lg: 24px;
    --rs-radius-xl: 30px;
    --rs-shadow-xs: 0 10px 24px rgba(7, 17, 31, .06);
    --rs-shadow-md: 0 20px 56px rgba(7, 17, 31, .10);
    --rs-shadow-lg: 0 30px 90px rgba(7, 17, 31, .14);
}

html,
body {
    min-width: 0;
}

img,
svg,
canvas {
    max-width: 100%;
}

body {
    line-height: 1.55;
}

.shell {
    width: min(1240px, calc(100% - clamp(24px, 5vw, 56px))) !important;
}

.topbar {
    gap: clamp(12px, 2vw, 22px) !important;
    min-height: 76px;
    padding: 10px clamp(12px, 2vw, 18px) !important;
    border-radius: 22px !important;
}

.brand {
    gap: 12px !important;
}

.brand > div,
.brand span {
    min-width: 0;
}

.nav,
.top-actions {
    justify-content: flex-end;
}

.nav a,
.nav button,
.top-actions a,
.top-actions button,
.btn,
.primary-btn,
.ghost-btn,
.danger-btn {
    min-height: 44px !important;
    padding-inline: 15px !important;
    border-radius: 14px !important;
    font-weight: 900 !important;
}

.btn,
.ghost-btn,
.nav a,
.danger-btn {
    box-shadow: inset 0 1px 0 rgba(255,255,255,.86);
}

.page-head {
    gap: 18px !important;
    margin: clamp(20px, 4vw, 34px) 0 20px !important;
}

.page-head .actions {
    justify-content: flex-end;
}

.page-head h1,
h1 {
    letter-spacing: -.05em !important;
}

.panel,
.card,
.category-admin-card,
.subscription-panel,
.subscription-strip {
    border-radius: var(--rs-radius-lg) !important;
    border-color: rgba(205, 215, 226, .92) !important;
    background: rgba(255,255,255,.92) !important;
    box-shadow: var(--rs-shadow-md) !important;
}

.panel.pad,
.card {
    padding: clamp(18px, 3vw, 26px) !important;
}

.grid {
    gap: clamp(14px, 2vw, 20px) !important;
}

.stats {
    grid-template-columns: repeat(auto-fit, minmax(min(180px, 100%), 1fr)) !important;
}

.stat {
    position: relative;
    overflow: hidden;
    min-height: 124px;
    display: grid;
    align-content: space-between;
    gap: 12px;
    border-radius: 20px !important;
}

.stat::after {
    content: "";
    position: absolute;
    inset: auto -24px -34px auto;
    width: 92px;
    height: 92px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(216,180,92,.22), transparent 70%);
}

.stat strong {
    font-size: clamp(1.8rem, 4vw, 3rem) !important;
    line-height: 1;
}

.form-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
    gap: 16px !important;
}

.form-grid > label,
.form-grid > .icon-picker,
.form-grid > .dynamic-fields,
.form-grid > .field-form,
.form-grid > .actions {
    grid-column: span 6;
}

.form-grid > .full,
.form-grid > .dynamic-fields,
.form-grid > .icon-picker,
.form-grid > .actions {
    grid-column: 1 / -1;
}

label {
    gap: 9px !important;
    font-size: .78rem !important;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.check-row,
.check {
    letter-spacing: 0 !important;
    text-transform: none !important;
}

input,
select,
textarea {
    min-height: 50px;
    border-radius: 15px !important;
    padding: 13px 15px !important;
}

textarea {
    min-height: 138px;
}

.dynamic-fields {
    padding: clamp(16px, 2.5vw, 22px) !important;
    border-radius: 20px !important;
}

.dynamic-fields-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(240px, 100%), 1fr));
    gap: 14px;
}

.dynamic-fields-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    margin-bottom: 14px;
}

.table-wrap {
    border-radius: 22px !important;
}

table {
    overflow: hidden;
}

th,
td {
    padding: 16px !important;
}

.actions {
    align-items: center;
}

.pagination nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

/* Public home */
.hero {
    align-items: stretch !important;
    gap: clamp(16px, 2vw, 24px) !important;
}

.intro,
.info-panel {
    min-height: clamp(420px, 52vw, 590px) !important;
}

.intro,
.info-panel,
.filters,
.ad-card,
.category-rail a {
    border-radius: var(--rs-radius-lg) !important;
}

.intro {
    padding: clamp(24px, 4vw, 44px) !important;
}

.intro h1 {
    max-width: 760px !important;
    font-size: clamp(2rem, 5.2vw, 5rem) !important;
}

.intro p {
    max-width: 620px !important;
}

.filters {
    gap: 12px !important;
}

.category-rail {
    grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr)) !important;
}

.cards {
    grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr)) !important;
}

.ad-card {
    display: grid;
    grid-template-rows: auto 1fr;
}

.ad-body {
    display: grid;
    align-content: start;
    gap: 10px;
}

.ad-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: auto;
}

/* Public detail */
.detail-card {
    overflow: hidden;
    padding: 0 !important;
}

.detail-layout {
    display: grid;
    grid-template-columns: minmax(320px, .82fr) minmax(0, 1.18fr);
}

.detail-media-wrap {
    min-height: 100%;
    background: #e8eef5;
}

.detail-media-wrap .cover {
    height: 100%;
    min-height: 420px;
    margin: 0;
    border-radius: 0 !important;
}

.detail-main {
    padding: clamp(20px, 3vw, 34px) !important;
}

.detail-main h1 {
    font-size: clamp(1.9rem, 4vw, 3.4rem) !important;
}

.detail-main p {
    font-size: 1.02rem;
}

.field-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(210px, 100%), 1fr)) !important;
}

.field-card {
    border-radius: 16px !important;
    background: linear-gradient(180deg, #fff, #f7f9fc) !important;
}

/* Admin/client structural polish */
.charts {
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr) !important;
}

.dashboard-categories,
.subscription-strip,
.subscription-panel {
    margin-top: 20px !important;
}

.dashboard-categories-head,
.category-admin-head,
.icon-picker-head {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
}

.dashboard-category-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.dashboard-category-list span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(205,215,226,.9);
    background: rgba(255,255,255,.84);
}

.category-admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(360px, 100%), 1fr));
    gap: 18px;
    margin-top: 18px;
}

.icon-groups {
    display: grid;
    gap: 16px;
}

.icon-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(48px, 1fr));
    gap: 10px;
}

.field-list {
    display: grid;
    gap: 10px;
    margin: 18px 0;
}

.field-pill {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid rgba(205,215,226,.9);
    border-radius: 16px;
    background: rgba(248,250,252,.92);
}

.field-pill span {
    display: block;
    color: var(--rs-muted);
    font-size: .82rem;
}

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

.field-form textarea,
.field-form button {
    grid-column: 1 / -1;
}

.subscription-panel {
    min-height: 220px;
}

/* Auth pages */
.client-auth-page .client-auth-shell {
    grid-template-columns: minmax(0, 1fr) minmax(380px, 470px) !important;
}

.admin-auth-page {
    min-height: 100vh;
    margin: 0;
    color: #fff;
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background:
        linear-gradient(120deg, rgba(7,17,31,.96), rgba(20,33,61,.86) 54%, rgba(20,33,61,.48)),
        url("https://images.unsplash.com/photo-1556742031-c6961e8560b0?auto=format&fit=crop&w=1800&q=84") center / cover fixed !important;
}

.admin-auth-page::before {
    content: "";
    position: fixed;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: linear-gradient(90deg, rgba(0,0,0,.72), transparent 78%);
    pointer-events: none;
}

.admin-auth-shell {
    position: relative;
    z-index: 1;
    width: min(1120px, calc(100% - 32px));
    min-height: 100vh;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 430px);
    gap: clamp(22px, 5vw, 64px);
    align-items: center;
}

.admin-auth-copy .brand {
    display: inline-flex;
    min-height: 62px;
    margin-bottom: 30px;
    padding: 6px 13px 6px 6px;
    border: 1px solid rgba(255,255,255,.20);
    border-radius: 999px;
    color: #fff;
    background: rgba(255,255,255,.12);
    backdrop-filter: blur(14px);
}

.admin-auth-copy .brand img {
    width: 50px !important;
    height: 50px !important;
}

.admin-auth-copy .eyebrow {
    display: inline-flex;
    min-height: 30px;
    align-items: center;
    padding: 0 12px;
    margin-bottom: 18px;
    border: 1px solid rgba(255,255,255,.20);
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.admin-auth-copy h1 {
    max-width: 620px;
    margin: 0;
    color: #fff !important;
    font-size: clamp(2.2rem, 5vw, 4.6rem) !important;
    line-height: .94;
}

.admin-auth-copy p {
    max-width: 560px;
    color: rgba(255,255,255,.82);
    font-size: 1.08rem;
}

.admin-auth-card {
    width: 100% !important;
    padding: clamp(22px, 4vw, 32px) !important;
    border-radius: 28px !important;
    background: rgba(255,255,255,.96) !important;
    color: var(--rs-ink);
}

.admin-auth-card h2 {
    margin: 16px 0 8px;
    font-size: clamp(1.8rem, 4vw, 2.35rem);
    letter-spacing: -.04em;
}

.admin-auth-card > p {
    color: var(--rs-muted);
}

.admin-auth-card form {
    display: grid;
    gap: 14px;
}

.admin-auth-card .actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* Mobile tables as cards */
@media (max-width: 820px) {
    .table-wrap[data-mobile-cards] {
        overflow: visible !important;
        border-radius: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
    }

    .table-wrap[data-mobile-cards] table,
    .table-wrap[data-mobile-cards] tbody,
    .table-wrap[data-mobile-cards] tr,
    .table-wrap[data-mobile-cards] td {
        display: block;
        width: 100%;
    }

    .table-wrap[data-mobile-cards] table {
        min-width: 0 !important;
    }

    .table-wrap[data-mobile-cards] thead {
        display: none;
    }

    .table-wrap[data-mobile-cards] tbody {
        display: grid;
        gap: 14px;
    }

    .table-wrap[data-mobile-cards] tr {
        overflow: hidden;
        border: 1px solid rgba(205,215,226,.92);
        border-radius: 20px;
        background: rgba(255,255,255,.96);
        box-shadow: var(--rs-shadow-xs);
    }

    .table-wrap[data-mobile-cards] td {
        display: grid;
        grid-template-columns: minmax(110px, .42fr) minmax(0, 1fr);
        gap: 14px;
        align-items: start;
        padding: 14px 16px !important;
        border-bottom: 1px solid rgba(221,229,236,.82) !important;
    }

    .table-wrap[data-mobile-cards] td:last-child {
        border-bottom: 0 !important;
    }

    .table-wrap[data-mobile-cards] td::before {
        content: attr(data-label);
        color: var(--rs-muted);
        font-size: .72rem;
        font-weight: 900;
        letter-spacing: .06em;
        text-transform: uppercase;
    }

    .table-wrap[data-mobile-cards] td[colspan] {
        display: block;
    }

    .table-wrap[data-mobile-cards] td[colspan]::before {
        display: none;
    }

    .table-wrap[data-mobile-cards] .actions {
        justify-content: flex-start;
    }
}

@media (max-width: 980px) {
    .hero,
    .charts,
    .detail-layout,
    .admin-auth-shell,
    .client-auth-page .client-auth-shell {
        grid-template-columns: 1fr !important;
    }

    .detail-media-wrap .cover {
        min-height: 280px;
        max-height: 420px;
    }

    .intro,
    .info-panel {
        min-height: auto !important;
    }

    .admin-auth-shell {
        padding: 34px 0;
    }
}

@media (max-width: 760px) {
    .shell {
        width: min(100% - 20px, 1240px) !important;
    }

    .topbar,
    .page-head,
    .dashboard-categories-head,
    .category-admin-head,
    .icon-picker-head,
    .top {
        align-items: stretch !important;
        flex-direction: column !important;
    }

    .nav,
    .top-actions,
    .page-head .actions {
        width: 100%;
        justify-content: stretch !important;
    }

    .nav > *,
    .top-actions > *,
    .page-head .actions > * {
        flex: 1 1 100%;
    }

    .nav a,
    .nav form,
    .nav button,
    .top-actions a,
    .top-actions button,
    .page-head .actions a,
    .page-head .actions button {
        width: 100%;
    }

    .form-grid,
    .field-form {
        grid-template-columns: 1fr !important;
    }

    .form-grid > label,
    .form-grid > .icon-picker,
    .form-grid > .dynamic-fields,
    .form-grid > .field-form,
    .form-grid > .actions {
        grid-column: 1 / -1 !important;
    }

    .filters,
    .proofs {
        grid-template-columns: 1fr !important;
    }

    .actions {
        width: 100%;
    }

    .actions > * {
        flex: 1 1 auto;
    }

    .field-pill {
        align-items: flex-start;
        flex-direction: column;
    }

    .admin-auth-card .actions {
        grid-template-columns: 1fr;
    }

    .detail-main {
        padding: 20px !important;
    }
}

@media (max-width: 560px) {
    .intro h1,
    .auth-copy h1,
    .admin-auth-copy h1 {
        font-size: clamp(1.9rem, 9vw, 2.8rem) !important;
    }

    .intro,
    .info-panel,
    .card,
    .panel,
    .auth-card,
    .admin-auth-card {
        border-radius: 20px !important;
    }

    .table-wrap[data-mobile-cards] td {
        grid-template-columns: 1fr;
        gap: 6px;
    }
}

/* v19 mobile language switcher */
@media (max-width: 760px) {
    .language-switcher {
        width: auto !important;
        max-width: 100%;
        flex: 0 0 auto !important;
    }

    .language-switcher summary {
        width: auto !important;
        min-width: 74px;
        justify-content: space-between;
    }

    .top-actions .language-switcher,
    .nav .language-switcher {
        width: 100% !important;
    }

    .top-actions .language-switcher summary,
    .nav .language-switcher summary {
        width: 100% !important;
    }

    .language-menu {
        position: fixed !important;
        top: auto !important;
        right: 12px !important;
        bottom: 12px !important;
        left: 12px !important;
        z-index: 120 !important;
        width: auto !important;
        max-height: min(70vh, 460px);
        overflow-y: auto;
        overscroll-behavior: contain;
        grid-template-columns: 1fr !important;
        padding: 12px !important;
        border-radius: 22px !important;
        box-shadow: 0 28px 90px rgba(7,17,31,.28) !important;
    }

    .language-switcher[open]::before {
        content: "";
        position: fixed;
        inset: 0;
        z-index: 110;
        background: rgba(7,17,31,.34);
        backdrop-filter: blur(4px);
    }

    .language-switcher[open] summary {
        position: relative;
        z-index: 121;
    }

    .language-menu a {
        grid-template-columns: 34px 42px minmax(0, 1fr) !important;
        min-height: 48px !important;
    }

    .auth-tools .language-switcher {
        width: auto !important;
    }

    .auth-tools .language-switcher summary {
        width: auto !important;
    }
}
