/* ШТАБ ИТ — Adaptive Service. Самодостаточные стили сервиса (поверх main.css). */

/* --------------------------------------------------------------------------
 * Tailwind-утилиты, которых нет в собранном css/tailwind.css.
 * Проект собирает Tailwind заранее (purge), поэтому неиспользованные на других
 * страницах классы отсутствуют. Здесь добиваем только те, что нужны этой странице.
 * ------------------------------------------------------------------------ */
.flex-wrap { flex-wrap: wrap; }
.gap-2 { gap: 0.5rem; }
.p-4 { padding: 1rem; }
.pt-5 { padding-top: 1.25rem; }
.pb-10 { padding-bottom: 2.5rem; }
.pb-20 { padding-bottom: 5rem; }
.py-14 { padding-top: 3.5rem; padding-bottom: 3.5rem; }
.mt-3 { margin-top: 0.75rem; }
.mt-5 { margin-top: 1.25rem; }
.mt-6 { margin-top: 1.5rem; }
.mt-7 { margin-top: 1.75rem; }
.mt-10 { margin-top: 2.5rem; }
.mb-4 { margin-bottom: 1rem; }
.max-w-2xl { max-width: 42rem; }
.leading-tight { line-height: 1.25; }
.min-w-0 { min-width: 0; }
.flex-shrink-0 { flex-shrink: 0; }
.whitespace-nowrap { white-space: nowrap; }
.self-start { align-self: flex-start; }
.text-gold-accent { color: #FFD700; }
.border-gold-accent { border-color: #FFD700; }
.hover\:text-gold-accent:hover { color: #FFD700; }
.group:hover .group-hover\:text-gold-accent { color: #FFD700; }

@media (min-width: 640px) {
    .sm\:p-6 { padding: 1.5rem; }
    .sm\:p-7 { padding: 1.75rem; }
}
@media (min-width: 768px) {
    .md\:p-7 { padding: 1.75rem; }
    .md\:p-8 { padding: 2rem; }
    .md\:pb-14 { padding-bottom: 3.5rem; }
    .md\:pb-28 { padding-bottom: 7rem; }
    .md\:mt-9 { margin-top: 2.25rem; }
    .md\:mt-14 { margin-top: 3.5rem; }
    .md\:items-center { align-items: center; }
    .md\:justify-between { justify-content: space-between; }
    .md\:self-auto { align-self: auto; }
}

:root {
    --as-gold: #FFD700;
    --as-bg: #000;
    --as-surface: #0a0a0a;
    --as-surface-2: #111;
    --as-line: rgba(255, 255, 255, 0.10);
    --as-line-soft: rgba(255, 255, 255, 0.06);
    --as-muted: #8a8f98;
    --as-error: #ff5a5a;
    --as-warn: #ffb020;
    --as-info: #4aa8ff;
    --as-ok: #34d399;
}

.as-page {
    background:
        radial-gradient(circle at 85% -10%, rgba(255, 215, 0, 0.06), transparent 45%),
        radial-gradient(circle at 0% 100%, rgba(74, 168, 255, 0.05), transparent 40%),
        var(--as-bg);
    min-height: 100svh;
}

/* ----------------------------- Hero / шапка сервиса ----------------------------- */

.as-hero {
    border-bottom: 1px solid var(--as-line);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent);
}

.as-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0.9rem;
    border: 1px solid rgba(255, 215, 0, 0.35);
    border-radius: 999px;
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--as-gold);
    background: rgba(255, 215, 0, 0.05);
}

.as-badge::before {
    content: '';
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: var(--as-gold);
    box-shadow: 0 0 10px var(--as-gold);
}

.as-h1 {
    font-weight: 900;
    text-transform: uppercase;
    line-height: 0.95;
    letter-spacing: -0.01em;
    font-size: clamp(2.4rem, 7vw, 5.5rem);
}

/* ----------------------------- Панель запроса ----------------------------- */

.as-panel {
    background: var(--as-surface);
    border: 1px solid var(--as-line);
    border-radius: 1.25rem;
}

.as-form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

@media (min-width: 720px) {
    .as-form {
        flex-direction: row;
    }
}

.as-input-wrap {
    position: relative;
    flex: 1;
    min-width: 0;
}

.as-input-wrap > svg {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--as-muted);
    pointer-events: none;
}

.as-input {
    width: 100%;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--as-line);
    border-radius: 0.85rem;
    color: #fff;
    font-size: 1rem;
    padding: 1rem 1rem 1rem 2.85rem;
    outline: none;
    transition: border-color 0.2s ease, background-color 0.2s ease;
}

.as-input::placeholder { color: #5b626c; }

.as-input:focus {
    border-color: rgba(255, 215, 0, 0.6);
    background: rgba(255, 255, 255, 0.06);
}

.as-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border: 1px solid transparent;
    border-radius: 0.85rem;
    padding: 1rem 2rem;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.as-btn--primary {
    background: var(--as-gold);
    color: #000;
}

.as-btn--primary:hover { background: #ffe34d; transform: translateY(-1px); }

.as-btn--ghost {
    background: transparent;
    border-color: var(--as-line);
    color: #fff;
    letter-spacing: 0.08em;
    padding: 0.55rem 1rem;
    font-size: 11px;
}

.as-btn--ghost:hover { border-color: var(--as-gold); color: var(--as-gold); }

.as-btn[disabled] { opacity: 0.75; cursor: progress; transform: none; }

.as-btn.is-loading { cursor: progress; }
.as-btn.is-loading::before {
    content: '';
    width: 14px;
    height: 14px;
    border: 2px solid rgba(0, 0, 0, 0.25);
    border-top-color: #000;
    border-radius: 999px;
    margin-right: 0.55rem;
    animation: as-spin 0.7s linear infinite;
}

/* ----------------------------- Тулбар управления ----------------------------- */

.as-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem 1.25rem;
}

.as-toolbar__group {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.as-toolbar__label {
    font-size: 10px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--as-muted);
}

.as-seg {
    display: inline-flex;
    border: 1px solid var(--as-line);
    border-radius: 0.65rem;
    overflow: hidden;
}

.as-seg button {
    background: transparent;
    color: var(--as-muted);
    border: 0;
    padding: 0.45rem 0.85rem;
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.as-seg button + button { border-left: 1px solid var(--as-line); }
.as-seg button[aria-pressed="true"] { background: var(--as-gold); color: #000; font-weight: 700; }

.as-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 11px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--as-muted);
    cursor: pointer;
    user-select: none;
}

.as-toggle input { accent-color: var(--as-gold); width: 1rem; height: 1rem; }

.as-range {
    -webkit-appearance: none;
    appearance: none;
    width: 130px;
    height: 4px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.15);
    outline: none;
    cursor: pointer;
}

.as-range::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border-radius: 999px;
    background: var(--as-gold);
    box-shadow: 0 0 0 4px rgba(255, 215, 0, 0.15);
}

.as-range::-moz-range-thumb {
    width: 16px;
    height: 16px;
    border: 0;
    border-radius: 999px;
    background: var(--as-gold);
}

.as-scale-value {
    font-variant-numeric: tabular-nums;
    color: #fff;
    font-size: 12px;
    min-width: 3ch;
}

/* ----------------------------- Чипы устройств ----------------------------- */

.as-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.as-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.85rem;
    border: 1px solid var(--as-line);
    border-radius: 0.7rem;
    background: rgba(255, 255, 255, 0.02);
    color: #c9ccd1;
    font-size: 12px;
    cursor: pointer;
    transition: border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.as-chip:hover { border-color: rgba(255, 215, 0, 0.4); color: #fff; }

.as-chip[aria-pressed="true"] {
    border-color: var(--as-gold);
    background: rgba(255, 215, 0, 0.08);
    color: #fff;
}

.as-chip__check {
    width: 15px;
    height: 15px;
    border-radius: 4px;
    border: 1px solid var(--as-line);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    color: #000;
    background: transparent;
}

.as-chip[aria-pressed="true"] .as-chip__check { background: var(--as-gold); border-color: var(--as-gold); }
.as-chip__os { font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--as-muted); }
.as-chip__year { font-size: 10px; color: #6f757e; font-variant-numeric: tabular-nums; }
.as-chip__dim { color: var(--as-muted); font-variant-numeric: tabular-nums; }

/* ----------------------------- Отчёт об ошибках ----------------------------- */

.as-report { display: none; }
.as-report.is-visible { display: block; }

.as-report__top {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: 1fr;
}

@media (min-width: 860px) {
    .as-report__top { grid-template-columns: auto 1fr; align-items: center; }
}

.as-score {
    display: flex;
    align-items: center;
    gap: 1.1rem;
}

.as-score__ring {
    --val: 0;
    --col: var(--as-ok);
    width: 96px;
    height: 96px;
    border-radius: 999px;
    flex-shrink: 0;
    display: grid;
    place-items: center;
    background:
        radial-gradient(closest-side, var(--as-surface) 73%, transparent 74%),
        conic-gradient(var(--col) calc(var(--val) * 1%), rgba(255, 255, 255, 0.08) 0);
}

.as-score__num { font-size: 1.9rem; font-weight: 900; line-height: 1; }
.as-score__cap { font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--as-muted); margin-top: 2px; }

.as-stat {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.as-stat__item { display: flex; flex-direction: column; gap: 2px; }
.as-stat__n { font-size: 1.5rem; font-weight: 800; font-variant-numeric: tabular-nums; }
.as-stat__l { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--as-muted); }
.as-stat__n.is-error { color: var(--as-error); }
.as-stat__n.is-warn { color: var(--as-warn); }
.as-stat__n.is-ok { color: var(--as-ok); }

.as-meta-line {
    font-size: 12px;
    color: var(--as-muted);
    word-break: break-all;
}
.as-meta-line b { color: #cfd2d7; font-weight: 600; }

.as-checks { display: grid; gap: 0.6rem; margin-top: 1.25rem; }

.as-check {
    border: 1px solid var(--as-line);
    border-left-width: 3px;
    border-radius: 0.7rem;
    background: rgba(255, 255, 255, 0.015);
    padding: 0.85rem 1rem;
}

.as-check--error { border-left-color: var(--as-error); }
.as-check--warning { border-left-color: var(--as-warn); }
.as-check--info { border-left-color: var(--as-info); }
.as-check--pass { border-left-color: var(--as-ok); }

.as-check__head { display: flex; align-items: flex-start; gap: 0.65rem; }

.as-check__icon {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    border-radius: 5px;
    display: grid;
    place-items: center;
    font-size: 12px;
    font-weight: 700;
    margin-top: 1px;
}
.as-check--error .as-check__icon { background: rgba(255, 90, 90, 0.15); color: var(--as-error); }
.as-check--warning .as-check__icon { background: rgba(255, 176, 32, 0.15); color: var(--as-warn); }
.as-check--info .as-check__icon { background: rgba(74, 168, 255, 0.15); color: var(--as-info); }
.as-check--pass .as-check__icon { background: rgba(52, 211, 153, 0.15); color: var(--as-ok); }

.as-check__title { font-weight: 700; font-size: 0.95rem; }
.as-check__detail { color: #b4b8bf; font-size: 0.86rem; line-height: 1.5; margin-top: 0.3rem; }

.as-check__fix {
    margin-top: 0.5rem;
    font-size: 0.82rem;
    color: #d9dce1;
    background: rgba(255, 215, 0, 0.06);
    border: 1px solid rgba(255, 215, 0, 0.18);
    border-radius: 0.5rem;
    padding: 0.5rem 0.7rem;
}
.as-check__fix b { color: var(--as-gold); }

.as-check__items {
    margin-top: 0.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.as-check__items code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.78rem;
    color: #ffcf6b;
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid var(--as-line-soft);
    border-radius: 0.35rem;
    padding: 0.25rem 0.5rem;
    word-break: break-all;
}

/* ----------------------------- Превью устройств ----------------------------- */

.as-previews {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem 1.6rem;
    align-items: flex-start;
    justify-content: center;
}

@media (min-width: 1024px) {
    .as-previews { justify-content: flex-start; }
}

.as-device { display: flex; flex-direction: column; align-items: center; gap: 0.6rem; }

.as-device__head {
    display: flex;
    align-items: baseline;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.4rem 0.5rem;
    max-width: 100%;
}

.as-device__name { font-weight: 700; font-size: 0.9rem; white-space: nowrap; }

.as-device__os {
    font-size: 9px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 0.1rem 0.4rem;
    border-radius: 999px;
    border: 1px solid var(--as-line);
    color: var(--as-muted);
}
.as-device__os.is-ios { color: #e8e8ed; }
.as-device__os.is-android { color: #a4c639; border-color: rgba(164, 198, 57, 0.4); }
.as-device__os.is-desktop { color: #7fb4ff; border-color: rgba(74, 168, 255, 0.4); }
.as-device__os.is-mac { color: #e8e8ed; border-color: rgba(255, 255, 255, 0.25); }

.as-device__dim { font-size: 11px; color: var(--as-muted); font-variant-numeric: tabular-nums; }
.as-device__year {
    font-size: 11px;
    color: #6f757e;
    font-variant-numeric: tabular-nums;
}

.as-device__reload {
    border: 1px solid var(--as-line);
    background: transparent;
    color: var(--as-muted);
    border-radius: 6px;
    width: 22px;
    height: 22px;
    display: inline-grid;
    place-items: center;
    cursor: pointer;
    font-size: 13px;
    line-height: 1;
    transition: color 0.2s ease, border-color 0.2s ease;
}
.as-device__reload:hover { color: var(--as-gold); border-color: var(--as-gold); }

/* Кнопка «Консоль разработчика» в шапке устройства */
.as-device__devtools {
    position: relative;
    border: 1px solid var(--as-line);
    background: transparent;
    color: var(--as-muted);
    border-radius: 6px;
    height: 22px;
    padding: 0 6px;
    display: inline-grid;
    place-items: center;
    cursor: pointer;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 11px;
    line-height: 1;
    transition: color 0.2s ease, border-color 0.2s ease;
}
.as-device__devtools:hover { color: var(--as-gold); border-color: var(--as-gold); }
.as-device__devtools.has-errors { color: #ff8585; border-color: rgba(255, 90, 90, 0.5); }
.as-device__devbadge {
    position: absolute;
    top: -7px;
    right: -7px;
    min-width: 15px;
    height: 15px;
    padding: 0 3px;
    border-radius: 999px;
    background: #ff4d4d;
    color: #fff;
    font-family: system-ui, -apple-system, sans-serif;
    font-size: 9px;
    font-weight: 700;
    line-height: 15px;
    text-align: center;
}

/* ----------------------------- Консоль разработчика (модал) ----------------------------- */
body.as-dt-open { overflow: hidden; }

.as-dt {
    position: fixed;
    inset: 0;
    z-index: 120;
    display: flex;
    align-items: center;
    justify-content: center;
}
.as-dt[hidden] { display: none; }

.as-dt__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.72);
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
}

.as-dt__panel {
    position: relative;
    width: min(940px, 94vw);
    height: min(660px, 86vh);
    display: flex;
    flex-direction: column;
    background: #0a0b0e;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 14px;
    box-shadow: 0 30px 80px -20px rgba(0, 0, 0, 0.9);
    overflow: hidden;
}

.as-dt__head {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.7rem 0.9rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    flex-wrap: wrap;
}
.as-dt__title { font-weight: 700; font-size: 13px; letter-spacing: 0.03em; }
.as-dt__spacer { flex: 1 1 auto; }

.as-dt__tabs { display: flex; gap: 0.3rem; }
.as-dt__tab {
    font-size: 12px;
    padding: 0.35rem 0.7rem;
    border-radius: 0.5rem;
    border: 1px solid transparent;
    background: transparent;
    color: var(--as-muted);
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
}
.as-dt__tab:hover { color: #fff; }
.as-dt__tab.is-active { color: #000; background: var(--as-gold); font-weight: 700; }

.as-dt__btn {
    font-size: 12px;
    padding: 0.35rem 0.6rem;
    border-radius: 0.5rem;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: transparent;
    color: var(--as-muted);
    cursor: pointer;
    transition: color 0.2s ease, border-color 0.2s ease;
}
.as-dt__btn:hover { color: #fff; border-color: rgba(255, 255, 255, 0.35); }
.as-dt__close { font-size: 13px; line-height: 1; }

.as-dt__body { flex: 1 1 auto; overflow: hidden; background: #070809; display: flex; min-height: 0; }
.as-dt__list {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 12px;
    line-height: 1.5;
}
.as-dt__list[hidden] { display: none; }

/* Вкладка «Сеть»: закреплённый фильтр + скроллируемый список */
.as-dt__pane { flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column; }
.as-dt__pane[hidden] { display: none; }
.as-dt__filter {
    display: flex;
    gap: 0.4rem;
    padding: 0.5rem 0.9rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    background: #0a0b0e;
    flex: 0 0 auto;
}
.as-dt__chip {
    font-size: 11px;
    padding: 0.25rem 0.65rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: transparent;
    color: var(--as-muted);
    cursor: pointer;
    font-variant-numeric: tabular-nums;
    transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}
.as-dt__chip:hover { color: #fff; }
.as-dt__chip.is-active { background: var(--as-gold); color: #000; border-color: var(--as-gold); font-weight: 700; }
.as-dt__chip.has-errors { border-color: rgba(255, 90, 90, 0.5); color: #ff8585; }
.as-dt__chip.has-errors.is-active { background: #ff4d4d; color: #fff; border-color: #ff4d4d; }
.as-dt__empty { padding: 1.2rem 0.9rem; color: #5b6472; font-size: 12px; }

.as-dt-row {
    display: flex;
    gap: 0.6rem;
    padding: 0.3rem 0.9rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    align-items: baseline;
    white-space: pre-wrap;
    word-break: break-word;
}
.as-dt-row__time { color: #5b6472; flex: 0 0 auto; font-size: 11px; font-variant-numeric: tabular-nums; }
.as-dt-row__level { flex: 0 0 auto; text-transform: uppercase; font-size: 10px; letter-spacing: 0.05em; opacity: 0.65; }
.as-dt-row__text { flex: 1 1 auto; color: #c9d1d9; }
.as-dt-row--error { background: rgba(255, 70, 70, 0.08); }
.as-dt-row--error .as-dt-row__text { color: #ff9a9a; }
.as-dt-row--warn .as-dt-row__text { color: #ffd479; }
.as-dt-row--info .as-dt-row__text { color: #9ad1ff; }
.as-dt-row--debug .as-dt-row__text { color: #9aa4b2; }

.as-dt-net {
    display: grid;
    grid-template-columns: 46px 64px minmax(0, 1fr) auto;
    gap: 0.6rem;
    align-items: baseline;
}
.as-dt-net__status { color: #7ee787; font-variant-numeric: tabular-nums; }
.as-dt-net.is-bad { background: rgba(255, 70, 70, 0.07); }
.as-dt-net.is-bad .as-dt-net__status { color: #ff7b7b; }
.as-dt-net__method { color: #79c0ff; font-size: 11px; text-transform: uppercase; }
.as-dt-net__url { color: #c9d1d9; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.as-dt-net__meta { color: #5b6472; font-size: 11px; white-space: nowrap; font-variant-numeric: tabular-nums; }
.as-dt-net__err { grid-column: 3 / -1; color: #ff7b7b; font-size: 11px; }

@media (max-width: 640px) {
    .as-dt__panel { width: 100vw; height: 100dvh; border-radius: 0; }
    .as-dt-net { grid-template-columns: 44px minmax(0, 1fr); }
    .as-dt-net__method, .as-dt-net__meta { display: none; }
}

/* Сцена резервирует масштабированное место, телефон масштабируется внутри.
   --chrome-w/--chrome-h — размер «рамки» устройства (телефон или ноутбук). */
.as-stage {
    --chrome-w: 24px;
    --chrome-h: 28px;
    position: relative;
    width: calc((var(--w) + var(--chrome-w)) * var(--scale));
    height: calc((var(--h) + var(--chrome-h)) * var(--scale));
}

.as-stage.is-desktop {
    --chrome-w: 20px;
    --chrome-h: 42px;
}

.as-phone {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(var(--w) + var(--chrome-w));
    height: calc(var(--h) + var(--chrome-h));
    transform: scale(var(--scale));
    transform-origin: top left;
    background: linear-gradient(160deg, #2a2c31, #0c0d0f 60%);
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 44px;
    padding: 14px 12px;
    box-shadow:
        0 30px 60px -25px rgba(0, 0, 0, 0.9),
        inset 0 0 0 2px rgba(0, 0, 0, 0.6);
}

/* Рамка ноутбука/браузера для компьютерных разрешений */
.as-laptop {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(var(--w) + var(--chrome-w));
    height: calc(var(--h) + var(--chrome-h));
    transform: scale(var(--scale));
    transform-origin: top left;
    background: #1b1d22;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 12px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 30px 60px -25px rgba(0, 0, 0, 0.9);
}

.as-laptop__bar {
    flex: 0 0 32px;
    height: 32px;
    background: #26282e;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 12px;
}

.as-laptop__dots { display: flex; gap: 7px; flex-shrink: 0; }
.as-laptop__dot { width: 11px; height: 11px; border-radius: 999px; }

.as-laptop__url {
    flex: 1;
    min-width: 0;
    font-size: 12px;
    color: #8a8f98;
    background: rgba(0, 0, 0, 0.25);
    border-radius: 6px;
    padding: 3px 10px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.as-laptop__screen-wrap {
    flex: 1;
    padding: 0 10px 10px;
}
.as-laptop .as-screen { border-radius: 0 0 4px 4px; }

.as-phone.is-android { border-radius: 30px; padding: 12px 10px; }

.as-screen {
    position: relative;
    box-sizing: border-box;
    width: var(--w);
    height: var(--h);
    border-radius: 30px;
    overflow: hidden;
    /* Белый фон как в реальном браузере: прозрачные участки страницы (без своего
       фона) должны быть белыми, а не чёрными. Состояние загрузки закрывает
       спиннер-оверлей, поэтому белый «не мелькает». */
    background: #fff;
}
.as-phone.is-android .as-screen { border-radius: 18px; }

/* Верхняя «строка состояния»: сдвигаем контент сайта вниз, чтобы челка/остров/
   отверстие камеры не перекрывали шапку — как safe-area на реальных телефонах. */
.as-phone.notch-island .as-screen { padding-top: 44px; }
.as-phone.notch-punch .as-screen { padding-top: 18px; }

.as-screen iframe {
    width: var(--w);
    height: var(--h);
    border: 0;
    display: block;
    background: #fff;
}

/* Динамический остров (iOS) / камера-вырез (Android) */
.as-notch {
    position: absolute;
    top: 9px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    pointer-events: none;
}
.as-phone.is-ios .as-notch {
    width: 95px;
    height: 26px;
    background: #000;
    border-radius: 999px;
    top: 20px;
}
.as-phone.is-android .as-notch {
    width: 11px;
    height: 11px;
    background: #000;
    border-radius: 999px;
    top: 16px;
}

.as-screen__overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    background: #0c0d10;
    color: var(--as-muted);
    font-size: 13px;
    text-align: center;
    padding: 1.5rem;
    transition: opacity 0.3s ease;
}
.as-screen__overlay.is-hidden { opacity: 0; pointer-events: none; }

.as-spinner {
    width: 26px;
    height: 26px;
    border: 3px solid rgba(255, 255, 255, 0.15);
    border-top-color: var(--as-gold);
    border-radius: 999px;
    animation: as-spin 0.8s linear infinite;
}
@keyframes as-spin { to { transform: rotate(360deg); } }

/* --- Состояние ошибки кадра: конкретная причина + кнопка «Повторить» --- */
.as-screen__error { display: none; flex-direction: column; align-items: center; gap: 0.4rem; }
.as-screen__overlay.is-error { background: #14090b; }
.as-screen__overlay.is-error .as-spinner,
.as-screen__overlay.is-error .as-screen__ovtext { display: none; }
.as-screen__overlay.is-error .as-screen__error { display: flex; }

.as-screen__error-icon {
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(255, 90, 90, 0.15);
    border: 1px solid rgba(255, 90, 90, 0.5);
    color: #ff8585;
    font-weight: 800;
    font-size: 16px;
    line-height: 1;
}
.as-screen__error-title { color: #ffc9c9; font-weight: 700; font-size: 13px; }
.as-screen__error-msg {
    color: var(--as-muted);
    font-size: 12px;
    line-height: 1.4;
    max-width: 90%;
    word-break: break-word;
}
.as-screen__error-meta { color: #6b7280; font-size: 10px; letter-spacing: 0.06em; }
.as-screen__error-retry {
    margin-top: 0.4rem;
    font-size: 11px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--as-gold);
    border: 1px solid rgba(255, 215, 0, 0.4);
    border-radius: 0.5rem;
    padding: 0.4rem 0.8rem;
    cursor: pointer;
    background: transparent;
    transition: background-color 0.2s ease, color 0.2s ease;
}
.as-screen__error-retry:hover { background: var(--as-gold); color: #000; }

.as-device.no-scroll .as-screen iframe { overflow: hidden; }

/* ----------------------------- Пустые состояния ----------------------------- */

.as-empty {
    border: 1px dashed var(--as-line);
    border-radius: 1.25rem;
    padding: 3rem 1.5rem;
    text-align: center;
    color: var(--as-muted);
}
.as-empty svg { margin: 0 auto 1rem; opacity: 0.5; }

/* Прячем бейдж reCAPTCHA полностью (по просьбе — без текста-уведомления). */
.grecaptcha-badge {
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    display: none !important;
}

/* Лоадер анализа (область аудита, пока идёт проверка) */
.as-loading {
    display: none;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem 1.75rem;
}
.as-loading.is-visible { display: flex; }
.as-loading__text {
    color: #c9ccd1;
    font-size: 0.95rem;
}

.as-error-banner {
    display: none;
    border: 1px solid rgba(255, 90, 90, 0.4);
    background: rgba(255, 90, 90, 0.08);
    color: #ffc9c9;
    border-radius: 0.85rem;
    padding: 0.9rem 1.1rem;
    font-size: 0.9rem;
}
.as-error-banner.is-visible { display: block; }

.as-section-title {
    font-size: 11px;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--as-muted);
    margin-bottom: 1rem;
}

/* Адаптивный тулбар: на мобильных переносим управление в аккуратную колонку */
@media (max-width: 600px) {
    .as-toolbar { gap: 0.85rem; }
    .as-toolbar__group { width: 100%; justify-content: space-between; }
}

/* ----- Движок: бейдж платформы, Core Web Vitals, полоса категорий ----- */
.as-badge--bitrix {
    display: inline-block;
    padding: 1px 8px;
    border-radius: 6px;
    background: #1a6fb5;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
}
.as-extras { margin: 0 0 16px; }
.as-cwv { margin: 0 0 14px; }
.as-cwv h3 { font-size: 14px; margin: 0 0 8px; }
.as-cwv__loading { color: var(--as-muted); font-size: 13px; margin: 0; }
.as-cwv__cell {
    display: inline-block;
    min-width: 88px;
    margin: 0 8px 8px 0;
    padding: 8px 10px;
    border-radius: 10px;
    text-align: center;
    background: #f3f4f6;
    color: #1a1d24;
}
.as-cwv__cell span { display: block; font-size: 11px; color: #5b6470; }
.as-cwv__cell b { font-size: 16px; color: #1a1d24; font-weight: 700; }
.as-cwv__cell--good { background: #e6f6e6; }
.as-cwv__cell--needs-improvement { background: #fff5e0; }
.as-cwv__cell--poor { background: #fde8e8; }
.as-cwv__progress {
    height: 8px;
    max-width: 440px;
    margin: 2px 0 8px;
    background: rgba(255, 255, 255, 0.12);
    border-radius: 6px;
    overflow: hidden;
}
.as-cwv__progress-fill {
    height: 100%;
    width: 3%;
    border-radius: 6px;
    background: linear-gradient(90deg, var(--as-warn), var(--as-ok));
    transition: width 0.35s ease;
}
.as-cwv__hint { color: var(--as-muted); font-size: 13px; margin: 0; }

.as-cats { display: flex; flex-wrap: wrap; gap: 6px; }
.as-cat {
    display: inline-flex;
    align-items: baseline;
    gap: 5px;
    font-size: 12px;
    padding: 4px 9px;
    border-radius: 8px;
    background: #f3f4f6;
    color: #444;
}
.as-cat b { font-weight: 700; }
.as-cat__rate { font-style: normal; font-size: 11px; opacity: 0.95; }
.as-cat--best  { background: #e3f6e3; } .as-cat--best  b, .as-cat--best  .as-cat__rate { color: #1f8a3b; }
.as-cat--good  { background: #ecf7ec; } .as-cat--good  b, .as-cat--good  .as-cat__rate { color: #2f9e44; }
.as-cat--ok    { background: #eaf1fb; } .as-cat--ok    b, .as-cat--ok    .as-cat__rate { color: #2b6cb0; }
.as-cat--bad   { background: #fff3e0; } .as-cat--bad   b, .as-cat--bad   .as-cat__rate { color: #c77700; }
.as-cat--worst { background: #fdeaea; } .as-cat--worst b, .as-cat--worst .as-cat__rate { color: #d9352c; }
.as-cat--none  { background: #f3f4f6; } .as-cat--none  .as-cat__rate { color: #888; }
