        .lib {
            --lib-ink: #0f172a;
            --lib-muted: #64748b;
            --lib-subtle: #94a3b8;
            --lib-line: #e5e7eb;
            --lib-bg: #f8fafc;
            --lib-hover: #f1f5f9;
            --lib-success: #059669;
            --lib-success-bg: #ecfdf5;
            --lib-warn: #b45309;
            --lib-warn-bg: #fffbeb;
            --lib-r-sm: 8px;
            --lib-r-md: 12px;
            --lib-r-lg: 16px;
            --pts-accent: #f59e0b;
            --pts-accent-bg: #fffbeb;
        }
        .lib-container { width: 90%; max-width: 960px; margin: 0 auto; padding: 32px 0 64px; }
        .lib-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin: 16px 0 24px; flex-wrap: wrap; }
        .lib-head-left { display: inline-flex; align-items: center; gap: 12px; flex-wrap: wrap; }
        .lib-title { font-size: 28px; font-weight: 700; color: var(--lib-ink); letter-spacing: -0.02em; line-height: 1.2; display: inline-flex; align-items: center; gap: 10px; }
        .lib-title i { color: var(--pts-accent); font-size: 24px; }
        .lib-cta { height: 42px; padding: 0 20px; background: var(--color-primary); color: #fff; border: none; border-radius: var(--lib-r-md); font-size: 14px; font-weight: 600; cursor: pointer; transition: background 0.15s; }
        .lib-cta:hover { background: var(--color-primary--hover); }
        /* size-override базового .btn .btn-outline-primary — компактнее под header */
        .pts-help-btn { padding: 7px 14px; font-size: 13px; gap: 6px; border-radius: var(--lib-r-sm); }
        .pts-help-btn i { font-size: 13px; }
        @media (max-width: 600px) {
            .pts-help-btn span { display: none; }
            .pts-help-btn { padding: 7px 10px; }
        }
        /* Модалка «Как это работает» — dark theme контента */
        .pts-rules-modal .pts-rules-grid { gap: 14px; margin: 0 0 24px; }
        .pts-rules-modal .pts-rule {
            background: #232323;
            border: 1px solid #3c3c3c;
            padding: 22px 20px;
            border-radius: 18px;
            transition: border-color .2s;
        }
        .pts-rules-modal .pts-rule:hover { border-color: #4a4a4a; }
        .pts-rules-modal .pts-rule-icon {
            width: 52px; height: 52px;
            border-radius: 14px;
            font-size: 22px;
            margin-bottom: 16px;
        }
        /* Тёплые приглушённые акценты иконок — не белят на тёмном фоне */
        .pts-rules-modal .pts-rule-icon.indigo { background: rgba(99,102,241,0.15); color: #a5b4fc; }
        .pts-rules-modal .pts-rule-icon.green  { background: rgba(34,197,94,0.15);  color: #86efac; }
        .pts-rules-modal .pts-rule-icon.amber  { background: rgba(245,158,11,0.15); color: #fbbf24; }
        .pts-rules-modal .pts-rule h4 { color: #fff; font-size: 16px; margin: 0 0 6px; }
        .pts-rules-modal .pts-rule p  { color: #a8b3c1; font-size: 13.5px; line-height: 1.55; margin: 0; }

        .pts-rules-modal .pts-faq-title { color: #fff; font-weight: 700; margin: 22px 0 12px; }
        /* Единый скруглённый блок FAQ — items без отдельных border'ов, только разделители */
        .pts-rules-modal .pts-faq {
            background: #232323;
            border: 1px solid #3c3c3c;
            border-radius: 18px;
            overflow: hidden;
        }
        .pts-rules-modal .pts-faq-item {
            background: transparent;
            border: 0;
            border-bottom: 1px solid #3c3c3c;
        }
        .pts-rules-modal .pts-faq-item:last-child { border-bottom: 0; }
        .pts-rules-modal .pts-faq-trigger { color: #fff; }
        .pts-rules-modal .pts-faq-trigger:hover { background: #2c2c2c; }
        .pts-rules-modal .pts-faq-trigger i { color: #8e8e8e; }
        .pts-rules-modal .pts-faq-q { color: #fff; }
        .pts-rules-modal .pts-faq-a { color: #a8b3c1; }

        /* Hero */
        .pts-hero { display: grid; grid-template-columns: 1fr minmax(220px, 280px); gap: 16px; margin-bottom: 16px; }
        .pts-hero-info { background: #fff; border: 1px solid var(--lib-line); border-radius: var(--lib-r-lg); padding: 24px; }
        .pts-status { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; background: var(--lib-success-bg); color: var(--lib-success); border-radius: 999px; font-size: 12px; font-weight: 600; margin-bottom: 14px; }
        .pts-status::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--lib-success); box-shadow: 0 0 0 3px rgba(5,150,105,0.18); }
        .pts-hero-text { color: var(--lib-muted); font-size: 14px; line-height: 1.55; font-weight: 500; }

        .pts-balance { background: var(--lib-ink); color: #fff; border-radius: var(--lib-r-lg); padding: 24px; display: flex; flex-direction: column; justify-content: center; gap: 6px; text-align: center; }
        .pts-balance-label { font-size: 12px; font-weight: 500; color: rgba(255,255,255,0.55); }
        .pts-balance-val { font-size: 40px; font-weight: 700; color: var(--pts-accent); line-height: 1; letter-spacing: -0.02em; }
        .pts-balance-val small { font-size: 14px; font-weight: 600; color: rgba(255,255,255,0.65); margin-left: 4px; }
        .pts-topup-btn { margin-top: 14px; align-self: stretch; display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-weight: 600; }
        .pts-topup-btn i { font-size: 12px; }

        /* Topup-flow `.is-topup`-правила переехали в global style.css
           (2026-05-09) — нужны на любой странице где открывается topup,
           не только на /points.php. */

        /* Mini stats */
        .pts-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-bottom: 16px; }
        .pts-stat { background: #fff; border: 1px solid var(--lib-line); border-radius: var(--lib-r-lg); padding: 14px 16px; display: flex; align-items: center; gap: 12px; }
        .pts-stat-icon { width: 36px; height: 36px; border-radius: var(--lib-r-sm); background: var(--pts-accent-bg); color: var(--pts-accent); display: inline-flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
        .pts-stat-val { font-size: 14px; font-weight: 700; color: var(--lib-ink); line-height: 1.2; }
        .pts-stat-lab { font-size: 12px; font-weight: 500; color: var(--lib-muted); margin-top: 2px; }

        /* Progress */
        .pts-progress { background: #fff; border: 1px solid var(--lib-line); border-radius: var(--lib-r-lg); padding: 16px 18px; margin-bottom: 16px; }
        .pts-progress-head { display: flex; justify-content: space-between; align-items: center; font-size: 13px; font-weight: 600; color: var(--lib-ink); }
        .pts-progress-head i { color: var(--pts-accent); margin-right: 4px; }
        .pts-progress-bar-wrap { height: 8px; background: var(--lib-bg); border-radius: 999px; overflow: hidden; margin: 10px 0; }
        .pts-progress-bar { height: 100%; background: var(--pts-accent); border-radius: 999px; transition: width 0.6s ease; }
        .pts-progress-meta { display: flex; justify-content: space-between; font-size: 12px; font-weight: 500; color: var(--lib-muted); }
        .pts-progress-meta b { color: var(--lib-ink); font-weight: 600; }

        /* Tabs */
        .pts-tabs { display: inline-flex; gap: 4px; background: var(--lib-bg); padding: 4px; border-radius: var(--lib-r-md); margin-bottom: 20px; }
        .pts-tab-btn { padding: 8px 16px; border: none; background: none; font-weight: 600; font-size: 13px; border-radius: var(--lib-r-sm); cursor: pointer; transition: background 0.15s, color 0.15s; color: var(--lib-muted); }
        .pts-tab-btn:hover { color: var(--lib-ink); }
        .pts-tab-btn.active { background: #fff; color: var(--lib-ink); box-shadow: 0 1px 2px rgba(0,0,0,0.06); }

        /* History list */
        .pts-list { background: #fff; border: 1px solid var(--lib-line); border-radius: var(--lib-r-lg); overflow: hidden; }
        .pts-row { display: flex; align-items: center; gap: 14px; padding: 14px 18px; border-bottom: 1px solid var(--lib-line); transition: background 0.15s; }
        .pts-row:last-child { border-bottom: none; }
        .pts-row:hover { background: var(--lib-bg); }
        .pts-row-icon { width: 36px; height: 36px; border-radius: var(--lib-r-md); display: inline-flex; align-items: center; justify-content: center; font-size: 13px; flex-shrink: 0; }
        .pts-row-icon.plus { background: var(--lib-success-bg); color: var(--lib-success); }
        .pts-row-icon.minus { background: var(--pts-accent-bg); color: var(--pts-accent); }
        .pts-row-info { flex: 1; min-width: 0; }
        .pts-row-title { font-size: 14px; font-weight: 600; color: var(--lib-ink); line-height: 1.3; }
        .pts-row-date { font-size: 12px; color: var(--lib-subtle); font-weight: 500; margin-top: 2px; }
        .pts-row-amount { font-size: 14px; font-weight: 700; white-space: nowrap; letter-spacing: -0.01em; color: var(--lib-ink); }
        .pts-row-amount.plus { color: var(--lib-success); }

        /* Earn list */
        .pts-row-icon.done { background: var(--lib-success-bg); color: var(--lib-success); }
        .pts-row-icon.auto { background: #eef2ff; color: #4f46e5; }
        .pts-row.is-done .pts-row-title { color: var(--lib-muted); }
        .pts-badge { display: inline-flex; align-items: center; gap: 6px; padding: 5px 11px; border-radius: 999px; font-size: 12px; font-weight: 600; white-space: nowrap; }
        .pts-badge i { font-size: 11px; }
        .pts-badge.done { background: var(--lib-success-bg); color: var(--lib-success); }
        .pts-badge.auto { background: #eef2ff; color: #4f46e5; }

        /* Rules grid */
        .pts-rules-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 24px; }
        .pts-rule { background: #fff; border: 1px solid var(--lib-line); border-radius: var(--lib-r-lg); padding: 20px; }
        .pts-rule-icon { width: 40px; height: 40px; border-radius: var(--lib-r-sm); display: inline-flex; align-items: center; justify-content: center; font-size: 16px; margin-bottom: 12px; }
        .pts-rule-icon.indigo { background: #eef2ff; color: #4f46e5; }
        .pts-rule-icon.green  { background: var(--lib-success-bg); color: var(--lib-success); }
        .pts-rule-icon.amber  { background: var(--pts-accent-bg); color: var(--pts-accent); }
        .pts-rule h4 { font-weight: 600; font-size: 15px; color: var(--lib-ink); margin-bottom: 6px; }
        .pts-rule p { font-size: 13px; color: var(--lib-muted); line-height: 1.5; }

        /* FAQ */
        .pts-faq-title { font-size: 18px; font-weight: 700; color: var(--lib-ink); margin-bottom: 12px; letter-spacing: -0.01em; }
        .pts-faq { background: #fff; border: 1px solid var(--lib-line); border-radius: var(--lib-r-lg); overflow: hidden; }
        .pts-faq-item { border-bottom: 1px solid var(--lib-line); }
        .pts-faq-item:last-child { border-bottom: none; }
        .pts-faq-trigger { width: 100%; background: none; border: none; padding: 16px 20px; display: flex; align-items: center; justify-content: space-between; cursor: pointer; text-align: left; gap: 16px; transition: background 0.15s; }
        .pts-faq-trigger:hover { background: var(--lib-bg); }
        .pts-faq-q { font-size: 14px; font-weight: 600; color: var(--lib-ink); }
        .pts-faq-trigger i { color: var(--lib-subtle); font-size: 12px; transition: transform 0.2s; }
        .pts-faq-item.active .pts-faq-trigger i { transform: rotate(180deg); }
        .pts-faq-body { overflow: hidden; max-height: 0; transition: max-height 0.3s ease; }
        .pts-faq-item.active .pts-faq-body { max-height: 400px; }
        .pts-faq-a { font-size: 14px; color: var(--lib-muted); line-height: 1.55; padding: 0 20px 16px; margin: 0; }

        /* Empty state — old style */
        .lib-empty { padding: 100px 20px; text-align: center; background: #fff; border-radius: 30px; border: 1px solid #f2f2f2; }
        .lib-empty i { font-size: 60px; color: #f1f5f9; margin-bottom: 25px; display: block; }
        .lib-empty h2 { font-weight: 800; margin-bottom: 10px; font-size: 22px; }
        .lib-empty p { color: #888; margin-bottom: 30px; font-size: 15px; }
        .lib-empty-btn { display: inline-block; padding: 15px 40px; background: var(--color-primary); color: #fff; border-radius: 15px; font-weight: 800; text-decoration: none; transition: background 0.2s; }
        .lib-empty-btn:hover { background: var(--color-primary--hover); color: #fff; }

        /* Pagination */
        .lib-pagination { display: flex; justify-content: center; gap: 6px; margin-top: 24px; flex-wrap: wrap; }
        .lib-page { min-width: 38px; height: 38px; padding: 0 10px; display: inline-flex; align-items: center; justify-content: center; background: #fff; border: 1px solid var(--lib-line); border-radius: var(--lib-r-md); color: var(--lib-ink); font-size: 13px; font-weight: 600; text-decoration: none; transition: background 0.15s, border-color 0.15s; }
        .lib-page:hover { background: var(--lib-hover); border-color: #cbd5e1; }
        .lib-page.active { background: var(--lib-ink); border-color: var(--lib-ink); color: #fff; }

        @media (max-width: 768px) {
            .pts-hero { grid-template-columns: 1fr; }
            .pts-rules-grid { grid-template-columns: 1fr; }
        }
        @media (max-width: 640px) {
            .lib-container { width: 100%; padding: 20px 16px 48px; }
            .lib-head { margin: 8px 0 16px; }
            .lib-title { font-size: 22px; }
            .pts-hero-info, .pts-balance, .pts-rule { padding: 18px; }
            .pts-balance-val { font-size: 32px; }
            .pts-row { padding: 12px 14px; gap: 12px; }
        }
        /* На мобиле rules-карточки компактнее, чтобы FAQ не уезжал за viewport */
        @media (max-width: 640px) {
            .pts-rules-modal .pts-rules-grid { gap: 10px; margin-bottom: 18px; }
            .pts-rules-modal .pts-rule { padding: 16px; border-radius: 14px; }
            .pts-rules-modal .pts-rule-icon { width: 44px; height: 44px; font-size: 18px; margin-bottom: 12px; border-radius: 12px; }
            .pts-rules-modal .pts-rule h4 { font-size: 15px; }
            .pts-rules-modal .pts-rule p { font-size: 13px; }
            .pts-rules-modal .pts-faq-title { margin: 16px 0 10px; font-size: 16px; }
            .pts-rules-modal .pts-faq-trigger { padding: 14px 16px; }
            .pts-rules-modal .pts-faq-q { font-size: 13px; }
            .pts-rules-modal .pts-faq-a { padding: 0 16px 14px; font-size: 13px; }
        }
        /* Модалка «Как это работает» на мобиле — bottom-sheet + явный скролл
           (базовый .modal с transform: translate(-50%, -50%) + min-height ломал scroll
           на iOS Safari внутри высокого FAQ-контента) */
        @media (max-width: 767px) {
            .modal.pts-rules-modal {
                /* Отменяем flex column из .modal-vio-new — иначе flex-shrink пожирает FAQ */
                display: block !important;
                top: auto;
                bottom: 0;
                left: 0;
                right: 0;
                transform: none;
                width: 100%;
                max-width: 100%;
                max-height: 90vh;
                max-height: 90dvh;
                min-height: 0 !important;
                border-radius: 20px 20px 0 0 !important;
                border-bottom: 0 !important;
                border-left: 0 !important;
                border-right: 0 !important;
                padding: 16px 16px calc(16px + env(safe-area-inset-bottom, 0px)) !important;
                overflow-y: auto;
                -webkit-overflow-scrolling: touch;
                overscroll-behavior: contain;
            }
        }
