﻿@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url('/fonts/montserrat-cyrillic.woff2') format('woff2');
    unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url('/fonts/montserrat-cyrillic-ext.woff2') format('woff2');
    unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url('/fonts/montserrat-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url('/fonts/montserrat-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root {
    --gold:     #f5c518;
    --gold-dim: #c9a010;
    --red:      #cc2200;
    --bg:       #0a0704;
    --bg2:      #130d06;
    --card:     rgba(0, 0, 0, 0.5);
    --card2:    rgba(0, 0, 0, 0.5);
    --border:   #272727;
    --shadow:   0px 1px 8px rgba(0, 0, 0, 0.75);
    --text:     #f5f0e8;
    --muted:    #c8bfb0;
    --green:    #5cb85c;
    --green-dim: #4a934a;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
    min-height: 100vh;
    background-color: var(--bg);
    color: var(--text);
    font-family: 'Montserrat', sans-serif;
    font-size: 18px;
}

html {
    scrollbar-gutter: stable;
}

.site-bg {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
    background:
        radial-gradient(125% 80% at 50% 118%, rgba(150,55,12,0.42) 0%, rgba(70,28,9,0.2) 32%, transparent 62%),
        linear-gradient(180deg, rgba(12,11,13,0.76) 0%, rgba(10,8,6,0.82) 46%, rgba(10,7,4,0.9) 100%),
        url('https://s1061.s3-cdn-clients.arviol.com/s3rustburg/img/web/css/background_v1.jpg') center top / cover no-repeat fixed;
}

.site-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0.06;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 140 140' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='grain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23grain)'/%3E%3C/svg%3E");
    background-size: 140px 140px;
}

.site-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 46% 100% at 0% 50%,   rgba(0,0,0,0.62) 0%, transparent 64%),
        radial-gradient(ellipse 46% 100% at 100% 50%, rgba(0,0,0,0.62) 0%, transparent 64%),
        linear-gradient(180deg, rgba(0,0,0,0.4) 0%, transparent 32%, rgba(0,0,0,0.5) 100%);
}

.site-bg-embers,
.site-bg-embers2 {
    position: absolute;
    inset: 0;
    background-repeat: repeat;
    will-change: background-position;
}
.site-bg-embers {
    background-image:
        radial-gradient(1.6px 1.6px at 18px 120px,  rgba(245,197,24,0.6),  transparent),
        radial-gradient(1.3px 1.3px at 90px 30px,   rgba(255,150,50,0.5),  transparent),
        radial-gradient(1.8px 1.8px at 150px 180px, rgba(245,197,24,0.55), transparent),
        radial-gradient(1.2px 1.2px at 200px 80px,  rgba(255,120,40,0.45), transparent),
        radial-gradient(1.4px 1.4px at 55px 230px,  rgba(255,170,60,0.5),  transparent),
        radial-gradient(1.1px 1.1px at 175px 260px, rgba(245,197,24,0.45), transparent),
        radial-gradient(1.5px 1.5px at 120px 95px,  rgba(255,135,45,0.4),  transparent);
    background-size: 230px 300px;
    animation: emberRise 26s linear infinite;
}
.site-bg-embers2 {
    background-image:
        radial-gradient(1px 1px at 60px 60px,       rgba(255,170,60,0.45), transparent),
        radial-gradient(2.2px 2.2px at 130px 220px, rgba(245,197,24,0.45), transparent),
        radial-gradient(1.1px 1.1px at 250px 140px, rgba(255,130,40,0.4),  transparent),
        radial-gradient(1.3px 1.3px at 300px 320px, rgba(245,197,24,0.4),  transparent),
        radial-gradient(1.6px 1.6px at 40px 360px,  rgba(255,150,50,0.4),  transparent);
    background-size: 350px 420px;
    opacity: 0.85;
    animation: emberRise 46s linear infinite;
}
@keyframes emberRise {
    from { background-position: 0 0; }
    to   { background-position: 0 -2100px; }
}

.site-bg-glow {
    position: absolute;
    left: 50%;
    bottom: -30%;
    width: 120%;
    height: 70%;
    transform: translateX(-50%);
    background: radial-gradient(ellipse 50% 50% at 50% 100%, rgba(214,90,24,0.28) 0%, rgba(150,50,12,0.12) 35%, transparent 70%);
    animation: forgeBreath 7s ease-in-out infinite;
}
@keyframes forgeBreath {
    0%, 100% { opacity: 0.55; }
    50%      { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
    .site-bg-embers, .site-bg-embers2, .site-bg-glow { animation: none; }
}

@media (max-width: 600px) {
    .site-bg-embers2, .site-bg::before { display: none; }
    .site-bg {
        background:
            radial-gradient(150% 55% at 50% 112%, rgba(165,60,14,0.5) 0%, rgba(80,32,10,0.24) 36%, transparent 68%),
            linear-gradient(180deg, rgba(12,11,13,0.8) 0%, rgba(10,8,6,0.85) 46%, rgba(10,7,4,0.92) 100%),
            url('https://s1061.s3-cdn-clients.arviol.com/s3rustburg/img/web/css/background_v1.jpg') center top / cover no-repeat;
    }
    .site-bg-glow {
        bottom: -8%;
        height: 55%;
        background: radial-gradient(ellipse 92% 48% at 50% 100%, rgba(224,96,26,0.4) 0%, rgba(160,54,14,0.18) 38%, transparent 72%);
    }
}

body > * { position: relative; z-index: 2; }
.topnav-wrap { z-index: 10; }
.site-bg { z-index: 0; }

a { color: var(--gold); text-decoration: none; }
a:hover { color: #fff; }

.site-logo {
    text-align: center;
    padding: 1.5rem 0 0.9rem;
}

.topnav {
    padding: 1.1rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1280px;
    margin: 0 auto;
    background: rgba(0,0,0,0.5);
    border: 1px solid #272727;
    box-shadow: 0px 1px 8px rgba(0,0,0,0.75);
}

.topnav-links { display: flex; gap: 2rem; align-items: center; }

.topnav-links a {
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: color 0.2s;
}
.topnav-links a:hover { color: var(--gold); }

.topnav-dropdown { position: relative; }
.topnav-dropdown > summary {
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    transition: color 0.2s;
}
.topnav-dropdown > summary::-webkit-details-marker { display: none; }
.topnav-dropdown > summary::after {
    content: "\f078";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    font-size: 0.65rem;
    transition: transform 0.2s;
}
.topnav-dropdown > summary:hover,
.topnav-dropdown[open] > summary { color: var(--gold); }
.topnav-dropdown[open] > summary::after { transform: rotate(180deg); }

.topnav-dropdown-menu {
    position: absolute;
    top: calc(100% + 0.6rem);
    left: 0;
    min-width: 160px;
    background: rgba(10,10,10,0.97);
    border: 1px solid #272727;
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.6);
    padding: 0.4rem;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    z-index: 50;
}
.topnav-dropdown-menu a {
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.45rem 0.7rem;
    border-radius: 6px;
    white-space: nowrap;
    transition: color 0.2s, background 0.2s;
}
.topnav-dropdown-menu a:hover { color: var(--gold); background: rgba(255,255,255,0.05); }

.topnav-right {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.topnav-balance { display:inline-flex; align-items:center; gap:0.35rem; background:rgba(212,168,67,0.1); border:1px solid rgba(212,168,67,0.3); color:var(--gold); border-radius:999px; padding:0.25rem 0.75rem; font-size:0.8rem; white-space:nowrap; cursor:pointer; transition:background 0.15s, border-color 0.15s, color 0.15s; }
.topnav-balance:hover { background:rgba(212,168,67,0.2); border-color:rgba(212,168,67,0.6); color:#ffd770; }
.topnav-right a { color: var(--muted); }
.topnav-right a:hover { color: var(--text); }
.topnav-admin { display:inline-flex; align-items:center; gap:0.35rem; background:rgba(204,34,0,0.1); border:1px solid rgba(204,34,0,0.3); color:rgba(240,112,96,0.9); border-radius:999px; padding:0.25rem 0.75rem; font-size:0.8rem; white-space:nowrap; transition:background 0.15s, border-color 0.15s, color 0.15s; }
.topnav-admin:hover { background:rgba(204,34,0,0.2); border-color:rgba(204,34,0,0.55); color:#ff7055; }
.topnav-profile { display:inline-flex; align-items:center; gap:0.35rem; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.13); color:var(--muted); border-radius:999px; padding:0.25rem 0.75rem; font-size:0.8rem; white-space:nowrap; transition:background 0.15s, border-color 0.15s, color 0.15s; }
.topnav-profile:hover { background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.25); color:var(--text); }

.page-wrap {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0.35rem 0 3rem;
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 0.75rem;
    align-items: start;
    z-index: auto;
}

.page-wrap > main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.page-wrap > main > * {
    width: 100%;
}

.sidebar {}

.sidebar-box {
    background: var(--card2);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    border-radius: 3px;
    padding: 1rem;
    margin-bottom: 0.75rem;
    font-size: 1rem;
}

.server-item { margin-bottom: 1rem; }
.server-item:last-child { margin-bottom: 0; }

.server-name {
    color: var(--text);
    font-size: 0.93rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.35rem;
}

.server-connect {
    color: var(--muted);
    font-size: 0.88rem;
    margin-bottom: 0.4rem;
}

.server-bar-wrap {
    background: rgba(255,255,255,0.08);
    border-radius: 1px;
    height: 6px;
    margin-bottom: 0.55rem;
}

.server-bar {
    height: 100%;
    background: var(--gold);
    border-radius: 1px;
    transition: width 0.5s;
    box-shadow: 0 0 8px rgba(245,197,24,0.5), 0 0 2px rgba(245,197,24,0.75);
}

.server-bar-offline {
    background: rgba(255,255,255,0.12);
    box-shadow: none;
}

.server-count {
    color: var(--muted);
    font-size: 0.88rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.server-bar-area { position: relative; }
.server-tip {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 8px);
    transform: translateX(-50%) translateY(6px) scale(0.96);
    transform-origin: bottom center;
    min-width: 150px;
    padding: 0.55rem 0.85rem;
    background: rgba(10,10,10,0.97);
    border: 1px solid #272727;
    border-radius: 8px;
    box-shadow: 0 6px 18px rgba(0,0,0,0.55);
    font-size: 0.78rem;
    line-height: 1.5;
    color: var(--text);
    text-align: center;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s linear 0.18s;
    z-index: 60;
    pointer-events: none;
}
.server-tip-title { color: var(--gold); font-weight: 700; margin-bottom: 0.25rem; }
.server-tip b { color: var(--gold); }
.server-tip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: #272727;
}
.server-bar-area:hover .server-tip,
.server-bar-area:focus-within .server-tip {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0) scale(1);
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s linear 0s;
}

.sidebar-btn {
    display: block;
    width: 100%;
    background: var(--gold);
    color: #000;
    border: none;
    padding: 0.6rem;
    border-radius: 2px;
    font-size: 0.88rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    cursor: pointer;
    text-align: center;
    margin-top: 0.75rem;
    transition: background 0.2s;
    font-family: 'Montserrat', sans-serif;
}
.sidebar-btn:hover { background: #ffd030; color: #000; }

.sidebar-info {
    color: var(--muted);
    font-size: 0.82rem;
    line-height: 1.5;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}
.sinfo-row {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
}
.sinfo-icon {
    color: var(--gold);
    font-size: 0.75rem;
    margin-top: 0.2rem;
    flex-shrink: 0;
    opacity: 0.8;
}
.sinfo-cmd {
    color: var(--gold);
    font-weight: 700;
    font-family: monospace;
    font-size: 0.9rem;
}
.sinfo-note {
    font-size: 0.75rem;
    color: rgba(168,152,128,0.65);
    padding-left: 1.3rem;
}

.cmd-list {
    display: grid;
    grid-template-columns: 13rem 1fr;
    column-gap: 0.75rem;
    row-gap: 0.6rem;
    margin: 0 0 1.25rem;
    font-size: 0.88rem;
}
.cmd-row { display: contents; }
.cmd-row .sinfo-cmd { font-family: inherit; color: var(--green-dim); }
.cmd-row .cmd-desc { color: var(--muted); }

.flash-toast {
    position: fixed;
    bottom: 2rem;
    left: 50%;
    z-index: 9998;
    max-width: 420px;
    background: rgba(12,9,6,0.96);
    border: 1px solid rgba(255,255,255,0.10);
    color: var(--text);
    padding: 0.6rem 1.3rem;
    border-radius: 999px;
    font-size: 0.85rem;
    line-height: 1.4;
    box-shadow: 0 4px 28px rgba(0,0,0,0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 0.55rem;
    cursor: pointer;
    opacity: 0;
    transform: translate(-50%, 14px);
    transition: opacity 0.25s, transform 0.25s;
}
.flash-toast.visible { opacity: 1; transform: translate(-50%, 0); }
.flash-toast.hiding  { opacity: 0; transform: translate(-50%, 14px); }
.flash-toast.toast-success { border-color: rgba(92,184,92,0.4); }
.flash-toast.toast-error   { border-color: rgba(220,60,40,0.4); }
.flash-toast.toast-warning { border-color: rgba(245,197,24,0.4); }
.flash-toast .toast-icon-success { color: var(--green); }
.flash-toast .toast-icon-error   { color: var(--red); }
.flash-toast .toast-icon-warning { color: var(--gold); }

.cat-tabs {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    max-width: 50rem;
    margin: 0 auto 1rem;
}

.cat-tab {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 2.3rem;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.06);
    transition: background 0.15s, color 0.15s, border-color 0.15s;
    background: rgba(0,0,0,0.55);
    color: rgba(255,255,255,0.75);
    padding: 0.5rem 0.9rem;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    cursor: pointer;
    white-space: nowrap;
    font-family: 'Montserrat', sans-serif;
    box-shadow: 0px 1px 8px rgba(0,0,0,0.75);
}
.cat-tab:hover { background: rgba(0,0,0,0.75); color: #fff; border-color: rgba(245,197,24,0.3); }
.cat-tab.active {
    background: linear-gradient(135deg, var(--gold) 0%, var(--gold-dim) 55%, #8a5c08 100%);
    color: #1a1305;
    border-color: var(--gold);
}

.product-grid {
    gap: 0.65rem;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    flex-flow: row wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

html[data-turbo-preview] .prod-card { opacity: 0 !important; animation: none !important; }
@keyframes cardIn {
    from { opacity: 0; translate: 0 14px; }
    to   { opacity: 1; translate: 0 0; }
}
.prod-card {
    animation: cardIn 0.2s ease both;
    animation-delay: calc(min(var(--i, 0), 15) * 20ms);
    width: 12.5em;
    aspect-ratio: 1 / 1;
    position: relative;
    overflow: hidden;
    background: transparent;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    border-radius: 2px;
    cursor: pointer;
    transition: border-color 0.2s, transform 0.15s;
}
.prod-card:hover {
    border-color: rgba(245,197,24,0.45);
    transform: translateY(-2px);
}

.prod-card::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 0;
    background: linear-gradient(
        to bottom,
        rgba(0,0,0,0.55) 0%,
        transparent 40%,
        transparent 55%,
        rgba(0,0,0,0.75) 100%
    );
}

.prod-img {
    position: absolute;
    inset: 10px 0;
    width: 100%;
    height: calc(100% - 20px);
    object-fit: contain;
    z-index: 1;
}

.prod-img-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    color: rgba(255,255,255,0.08);
    z-index: 1;
}

.prod-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 0.6rem;
    background: transparent;
    z-index: 2;
}

.prod-price {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.1rem;
    font-size: 0.82rem;
    font-weight: 700;
}
.prod-price-old {
    color: rgba(255,255,255,0.45);
    text-decoration: line-through;
    font-size: 0.75rem;
}
.prod-price-new { color: rgba(255,255,255,0.8); font-size: 0.9rem; text-shadow: 0 1px 6px rgba(0,0,0,0.9), 0 0 12px rgba(0,0,0,0.7); }

.prod-name {
    font-size: 0.82rem;
    color: #fff;
    line-height: 1.3;
    text-shadow: 0 1px 3px rgba(0,0,0,0.8);
    text-align: center;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.2s, transform 0.2s;
}
.prod-card:hover .prod-name {
    opacity: 1;
    transform: translateY(0);
}
.prod-qty {
    position: absolute;
    bottom: 0.5rem;
    right: 0.55rem;
    font-size: 0.68rem;
    color: rgba(255,255,255,0.5);
    text-align: right;
    text-shadow: 0 1px 3px rgba(0,0,0,0.8);
    opacity: 1;
    transition: opacity 0.2s;
    z-index: 3;
}
.prod-card:hover .prod-qty {
    opacity: 0;
}

.prod-badge {
    position: absolute;
    top: 5%;
    right: -22%;
    width: 65%;
    text-align: center;
    background: rgba(255, 59, 62, 0.75);
    color: #fff;
    font-size: 0.85rem;
    font-weight: 700;
    padding: 0.2em 0;
    transform: rotate(45deg);
    text-shadow: 1px 1px 1px #000;
    white-space: nowrap;
    z-index: 2;
}

.qty-stepper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    margin-top: 1em;
    flex-wrap: wrap;
}

.qty-btn {
    background: rgba(92,184,92,0.07);
    border: 1px solid rgba(92,184,92,0.35);
    color: rgba(92,184,92,0.85);
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 2px;
    font-size: 1.1rem;
    cursor: pointer;
    line-height: 1;
    font-family: inherit;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.qty-btn:hover { background: rgba(92,184,92,0.15); border-color: rgba(92,184,92,0.7); color: var(--green); }

.qty-btn-edge {
    background: rgba(92,184,92,0.07);
    border: 1px solid rgba(92,184,92,0.35);
    color: rgba(92,184,92,0.85);
    height: 2.2rem;
    padding: 0 0.6rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    cursor: pointer;
    letter-spacing: 0.05em;
    font-family: inherit;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.qty-btn-edge:hover { background: rgba(92,184,92,0.15); border-color: rgba(92,184,92,0.7); color: var(--green); }
.qty-btn-chunk { width: auto; padding: 0 0.55rem; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.03em; }
.qty-dec { background: rgba(204,34,0,0.07); border-color: rgba(204,34,0,0.35); color: rgba(240,112,96,0.85); }
.qty-dec:hover { background: rgba(204,34,0,0.15); border-color: rgba(204,34,0,0.7); color: #ff6b4a; }

.priv-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
}

.priv-card {
    background: var(--card2);
    border: 1px solid var(--border);
    border-radius: 3px;
    overflow: hidden;
    transition: border-color 0.2s, transform 0.15s;
    display: flex;
    flex-direction: column;
}
.priv-card:hover { border-color: rgba(245,197,24,0.45); transform: translateY(-2px); }
.priv-card.featured { border-color: var(--gold); box-shadow: 0 0 20px rgba(245,197,24,0.1); }

.priv-card-head {
    padding: 1.25rem 1rem 1rem;
    text-align: center;
    border-bottom: 1px solid var(--border);
}

.priv-tag {
    display: inline-block;
    font-family: 'Russo One', sans-serif;
    font-size: 1.6rem;
    color: var(--gold);
    letter-spacing: 0.05em;
    text-shadow: 0 0 20px rgba(245,197,24,0.4);
    margin-bottom: 0.5rem;
    padding: 0.25rem 0.5rem;
    border: 2px solid rgba(245,197,24,0.3);
}

.priv-price-wrap { margin: 0.5rem 0 0.25rem; }
.priv-price-old { color: var(--muted); text-decoration: line-through; font-size: 0.85rem; }
.priv-price { font-size: 1.6rem; font-weight: 700; color: var(--gold); font-family: 'Russo One', sans-serif; }
.priv-duration { font-size: 0.75rem; color: var(--muted); }

.priv-card-body { padding: 0.85rem 1rem 1rem; flex: 1; display: flex; flex-direction: column; }
.priv-desc { font-size: 0.8rem; color: var(--muted); line-height: 1.6; margin-bottom: 1rem; flex: 1; }

.pdesc-title {
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-align: center;
    margin-bottom: 0.9rem;
}
.pdesc-stats {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    text-align: left;
    background: rgba(var(--accent-rgb, 255,255,255), 0.05);
    border: 1px solid rgba(var(--accent-rgb, 255,255,255), 0.15);
    border-radius: 8px;
    padding: 0.75rem 1rem;
    margin: 0 0 1rem;
    font-size: 0.82rem;
}
.pdesc-stat-row { display: flex; justify-content: space-between; align-items: center; gap: 0.75rem; }
.pdesc-stat-row span:first-child { color: var(--muted); }
.pdesc-stat-row span:last-child { font-weight: 700; white-space: nowrap; }
.pdesc-features {
    list-style: none;
    padding: 0;
    margin: 0 0 1rem;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    font-size: 0.82rem;
    line-height: 1.5;
}
.pdesc-features li { display: flex; gap: 0.55rem; align-items: flex-start; }
.pdesc-features li i { color: var(--green); flex-shrink: 0; margin-top: 0.2rem; font-size: 0.7rem; }
.pdesc-features li span { flex: 1; min-width: 0; }
.pdesc-features.rules-list li i { color: var(--red); }
.pdesc-help {
    font-size: 0.85rem;
    text-align: center;
    margin: 0 0 1rem;
    padding: 0.55rem 1rem;
    border-radius: 8px;
    background: rgba(var(--accent-rgb, 92,184,92), 0.1);
    border: 1px solid rgba(var(--accent-rgb, 92,184,92), 0.3);
}
.pdesc-help b { color: var(--accent, #4caf50); }
.pdesc-note { font-size: 0.76rem; color: var(--rust-muted); line-height: 1.6; text-align: center; }

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    padding: 0.6rem 1.25rem;
    border-radius: 2px;
    font-size: 0.9rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    cursor: pointer;
    border: none;
    transition: all 0.2s;
    font-family: 'Montserrat', sans-serif;
}
.btn-gold { background: var(--gold); color: #000; }
.btn-gold:hover { background: #ffd030; color: #000; }
.btn-buy { background: transparent; border: 1px solid rgba(245,197,24,0.35); color: rgba(245,197,24,0.85); transition: background 0.15s, border-color 0.15s, color 0.15s; }
.btn-buy:hover { background: rgba(245,197,24,0.15); border-color: rgba(245,197,24,0.7); color: var(--gold); }
.btn-outline { background: transparent; border: 1px solid rgba(255,255,255,0.14); color: var(--muted); }
.btn-outline:hover { border-color: var(--gold); color: var(--gold); }
.btn-logout { background: transparent; border: 1px solid rgba(204,34,0,0.35); color: rgba(220,100,80,0.85); transition: background 0.15s, border-color 0.15s, color 0.15s; }
.btn-logout:hover { background: rgba(204,34,0,0.15); border-color: rgba(204,34,0,0.7); color: #ff6b4a; }
.btn-pay { background: transparent; border: 1px solid rgba(92,184,92,0.4); color: rgba(120,200,120,0.9); transition: background 0.15s, border-color 0.15s, color 0.15s; }
.btn-pay:hover { background: rgba(92,184,92,0.15); border-color: rgba(92,184,92,0.75); color: #8fd48f; }
.btn-steam { background: #1b2838; border: 1px solid #2a475e; color: #c6d4df; }
.btn-steam:hover { background: #2a475e; color: #fff; }
.btn-sm { padding: 0.4rem 0.8rem; font-size: 0.82rem; border-radius: 999px; }
.btn-block { width: 100%; }

footer {
    text-align: center;
    padding: 1.75rem;
    font-size: 0.82rem;
    color: rgba(200,191,176,0.92);
    border-top: none;
    line-height: 2;
}
footer a { color: rgba(212,168,67,0.95); text-decoration: none; }
footer a:hover { color: var(--gold); }

.badge {
    display: inline-block;
    padding: 0.2rem 0.55rem;
    border-radius: 2px;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
}
.badge-success  { background: rgba(92,184,92,0.18);  color: #7dce7d; }
.badge-warning  { background: rgba(245,197,24,0.18); color: var(--gold); }
.badge-danger   { background: rgba(204,34,0,0.18);   color: #f07060; }
.badge-info     { background: rgba(41,182,246,0.18); color: #4fc3f7; }
.badge-secondary{ background: rgba(138,122,102,0.18);color: var(--muted); }

@keyframes modalIn {
    from { opacity: 0; transform: translateY(16px) scale(0.97); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

table { width: 100%; border-collapse: collapse; }
th, td { padding: 0.75rem 1rem; text-align: left; border-bottom: 1px solid var(--border); font-size: 0.93rem; }
th { color: var(--muted); font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; }
tr:hover td { background: rgba(255,255,255,0.02); }

.card { background: var(--card2); border: 1px solid var(--border); box-shadow: var(--shadow); border-radius: 3px; overflow: hidden; }
.card-header { padding: 0.85rem 1.1rem; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; font-size: 0.95rem; font-weight: 600; }
.card-body { padding: 1.1rem; }

.form-group { margin-bottom: 1rem; }
.form-label { display: block; margin-bottom: 0.35rem; font-size: 0.85rem; color: var(--muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; }
.form-control { width: 100%; background: #0e0b07; border: 1px solid var(--border); color: var(--text); padding: 0.6rem 0.85rem; border-radius: 2px; font-size: 0.95rem; font-family: 'Montserrat', sans-serif; }
.form-control:focus { outline: none; border-color: rgba(245,197,24,0.45); }
.form-control::placeholder { color: var(--muted); }
select.form-control { color: var(--text); }
select.form-control option { background: #0e0b07; color: var(--text); }
select.form-control option[value=""] { color: var(--muted); }
textarea.form-control { resize: vertical; min-height: 80px; }
input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
input[type=number] { -moz-appearance: textfield; }
.form-check { display: flex; align-items: center; gap: 0.5rem; font-size: 0.93rem; }
.form-check input { accent-color: var(--gold); }

.section-title {
    font-family: 'Russo One', sans-serif;
    font-size: 1.2rem;
    color: var(--gold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.85rem;
    padding-bottom: 0.45rem;
    border-bottom: 1px solid rgba(245,197,24,0.18);
}

.wipe-cal-head {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    margin-bottom: 0.85rem;
}
.wipe-cal-month {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--text);
    letter-spacing: 0.05em;
}
.wipe-cal-year {
    display: inline-block;
    background: rgba(245,197,24,0.15);
    color: var(--gold);
    border-radius: 999px;
    padding: 0.15rem 0.55rem;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.05em;
}
.wipe-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 0.22rem;
    text-align: center;
}
.wipe-cal-dow {
    color: var(--muted);
    font-size: 0.68rem;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.03em;
    padding-bottom: 0.3rem;
}
.wipe-cal-day {
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.78rem;
    color: rgba(255,255,255,0.6);
    border-radius: 4px;
    transition: transform 0.15s;
}
.wipe-cal-day.wipe {
    background: rgba(92,184,92,0.18);
    color: #7dce7d;
    font-weight: 600;
}
.wipe-cal-day.global {
    background: rgba(245,197,24,0.18);
    color: var(--gold);
    font-weight: 700;
}
.wipe-cal-day.today {
    box-shadow: inset 0 0 0 2px var(--red);
    font-weight: 700;
}
.wipe-cal-day.today.wipe,
.wipe-cal-day.today.global {
    box-shadow: inset 0 0 0 2px var(--red);
}
.wipe-cal-legend {
    margin-top: 0.85rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    font-size: 0.7rem;
    color: var(--muted);
}
.wipe-cal-legend > span {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
}
.wipe-cal-marker {
    display: inline-block;
    width: 14px;
    height: 14px;
    border-radius: 3px;
    flex-shrink: 0;
}
.wipe-cal-marker.today {
    background: transparent;
    box-shadow: inset 0 0 0 2px var(--red);
}
.wipe-cal-marker.wipe {
    background: rgba(92,184,92,0.2);
}
.wipe-cal-marker.global {
    background: rgba(245,197,24,0.2);
}
.wipe-cal-time {
    margin-top: 0.6rem;
    font-size: 0.7rem;
    color: var(--muted);
    text-align: center;
    border-top: 1px solid var(--border);
    padding-top: 0.6rem;
}

.site-logo-img {
    max-height: 300px;
    max-width: 100%;
    width: auto;
    height: auto;
    filter: drop-shadow(0 0 20px rgba(245,197,24,0.4));
}

.cabinet-layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 1rem;
    align-items: start;
}

.product-page-grid {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 2rem;
    align-items: start;
}
.product-page-side {
    position: sticky;
    top: 80px;
}

.rb-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0.82);
}
.rb-modal-card {
    width: 100%;
    max-width: 460px;
    margin: 1rem;
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
    overflow-x: hidden;
    box-shadow: 0 8px 40px rgba(0,0,0,0.9), 0 0 0 1px rgba(255,255,255,0.04);
    background: rgba(0,0,0,0.92);
}
.rb-modal-card-sm { max-width: 420px; }

@media (max-width: 900px) {
    .page-wrap { grid-template-columns: 1fr; padding: 0.35rem 0.5rem 3rem; }
    .page-wrap > main { order: 1; }
    .sidebar { order: 2; margin-top: 1rem; }
    .priv-grid { grid-template-columns: 1fr; }
    .site-logo a { font-size: 2.6rem; }
    .site-logo-img { max-height: 200px; }
    .topnav { flex-direction: column; gap: 0.5rem; }
    .cabinet-layout { grid-template-columns: 1fr; }
    .product-page-grid { grid-template-columns: 1fr; gap: 1.25rem; }
    .product-page-side { position: static; }
}

@media (max-width: 600px) {
    html, body { font-size: 16px; }

    .site-logo { padding: 0.75rem 0 0.4rem; }
    .site-logo-img { max-height: 160px; }

    .topnav { padding: 0.6rem 0.85rem; gap: 0.4rem; }
    .topnav-links { gap: 1rem; flex-wrap: wrap; justify-content: center; }
    .topnav-links a, .topnav-dropdown > summary { font-size: 0.72rem; letter-spacing: 0.06em; }
    .topnav-right { gap: 0.4rem; flex-wrap: wrap; justify-content: center; width: 100%; }
    .topnav-balance, .topnav-admin, .topnav-profile {
        font-size: 0.7rem; padding: 0.2rem 0.55rem;
    }

    th, td { padding: 0.45rem 0.5rem; font-size: 0.78rem; }
    th { font-size: 0.68rem; }
    .card > table { display: block; overflow-x: auto; white-space: nowrap; }
    .card > table thead, .card > table tbody { display: table; width: 100%; }

    .card-body { padding: 0.85rem; }
    .card-header { padding: 0.7rem 0.85rem; font-size: 0.85rem; }

    .product-grid { gap: 0.4rem; }
    .prod-card { width: calc(50% - 0.2rem); }

    .rb-modal-card { margin: 0.5rem; max-height: calc(100vh - 1rem); }
    .rb-modal-card .card-body { padding: 1rem; }

    .qty-stepper { gap: 0.45rem; }
    .qty-btn { width: 2rem; height: 2rem; font-size: 1rem; }
    .qty-btn-edge { padding: 0 0.6rem; height: 2rem; font-size: 0.7rem; }
    .qty-btn-chunk { width: auto; padding: 0 0.65rem; font-size: 0.7rem; }

    .cat-tabs { gap: 0.4rem; }
    .cat-tab { padding: 0.4rem 0.7rem; font-size: 0.72rem; min-height: 2.2rem; }

    footer { padding: 1rem 0.5rem; line-height: 1.7; }
    footer p { font-size: 0.74rem; }

    .page-title { font-size: 1.25rem; }

    .cmd-list { grid-template-columns: 1fr; row-gap: 0.9rem; }
    .cmd-row { display: flex; flex-direction: column; gap: 0.15rem; }
}

@media (max-width: 380px) {
    .prod-card { width: 100%; }
    .site-logo-img { max-height: 130px; }

    .qty-stepper { flex-wrap: nowrap; gap: 0.4rem; }
    .qty-btn { width: 1.95rem; height: 1.95rem; font-size: 1rem; flex-shrink: 0; }
    .qty-btn-edge { padding: 0 0.55rem; height: 1.95rem; font-size: 0.66rem; flex-shrink: 0; white-space: nowrap; }
    .qty-btn-chunk { width: auto; padding: 0 0.6rem; font-size: 0.66rem; flex-shrink: 0; white-space: nowrap; }
}

.bans-list { display: flex; flex-direction: column; }
.ban-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.7rem 1rem;
    border-bottom: 1px solid var(--border);
}
.ban-row:last-child { border-bottom: none; }
.ban-avatar { flex-shrink: 0; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; }
.ban-avatar img { width: 36px; height: 36px; border-radius: 3px; display: block; }
.ban-avatar .placeholder { font-size: 1.8rem; color: var(--muted); }
.ban-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 0.2rem; }
.ban-name { color: var(--gold); font-size: 0.9rem; word-break: break-word; }
.ban-reason { color: var(--text); font-size: 0.85rem; word-wrap: break-word; overflow-wrap: anywhere; }
.ban-date { color: var(--muted); font-size: 0.82rem; white-space: nowrap; flex-shrink: 0; }

@media (max-width: 600px) {
    .ban-row { flex-wrap: wrap; gap: 0.55rem 0.75rem; padding: 0.7rem 0.75rem; }
    .ban-info { flex: 1 1 calc(100% - 50px); }
    .ban-date { flex: 1 1 100%; text-align: left; font-size: 0.74rem; padding-left: calc(36px + 0.75rem); margin-top: -0.2rem; }
    .ban-name { font-size: 0.85rem; }
    .ban-reason { font-size: 0.8rem; }
}

.turbo-progress-bar {
    height: 2px;
    background: linear-gradient(90deg, var(--red), var(--gold));
}
