/* ========================================================================
   Реставрация фотографии — /lab UI
   Стиль совмещён с adg.dovodai.ru landing: бренд-красный #8B2635,
   Lora (display) + Manrope (body), карточки rounded-2xl shadow-paper.
   4 услуги (восстановить / улучшить / раскрасить / оживить) видны сразу.
   ======================================================================== */

:root {
    --paper:           #FAF6F0;
    --paper-grad:      linear-gradient(180deg, #FAF6F0 0%, #F5EDDE 100%);
    --card:            #FFFFFF;
    --card-warm:       #FBF7F0;
    --ink:             #2D1F14;
    --ink-strong:      #1A1A1A;
    --muted:           #6E5849;
    --muted-light:     #9C8B7B;
    --border:          #E6D9C2;
    --border-light:    #E8E2D6;

    --primary:         #8B2635;
    --primary-dark:    #6B1D29;
    --accent-soft:     #F5EDDE;
    --accent-gold:    #C8A862;
    --warn-bg:         #FDF4E3;
    --warn-ink:        #7A5A1F;
    --err-bg:          #FCEAEA;
    --err-ink:         #8B2635;

    --radius-sm:       8px;
    --radius:          14px;
    --radius-lg:       20px;
    --radius-xl:       24px;
    --radius-pill:     999px;

    --shadow-sm:       0 1px 2px rgba(31,26,23,.06);
    --shadow:          0 4px 16px rgba(31,26,23,.08);
    --shadow-lift:     0 8px 28px rgba(31,26,23,.14);
    --shadow-cta:      0 4px 12px rgba(139,38,53,.22);

    --tap-min:         48px;
    --font-display:    'Lora', Georgia, serif;
    --font-body:       'Manrope', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}

/* === Reset === */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img, svg, video { max-width: 100%; height: auto; display: block; }

body.pl-body {
    background: var(--paper);
    color: var(--ink);
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
    display: flex; flex-direction: column;
}
.pl-main { flex: 1 0 auto; }

/* === Container === */
.pl-container { max-width: 980px; margin: 0 auto; padding: 0 16px; }
@media (min-width: 720px) { .pl-container { padding: 0 24px; } }

/* === Header === */
.pl-header {
    background: rgba(250, 246, 240, .92);
    -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--border-light);
    position: sticky; top: 0; z-index: 50;
}
.pl-header__inner {
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 0;
}
.pl-logo {
    display: inline-flex; align-items: center; gap: 10px;
    color: var(--ink-strong); text-decoration: none;
    font-family: var(--font-display);
    font-weight: 600; font-size: 18px;
}
.pl-logo__mark {
    width: 34px; height: 34px; border-radius: 10px;
    background: var(--primary); color: #fff;
    display: grid; place-items: center;
    font-weight: 700; font-size: 16px;
    box-shadow: var(--shadow-sm);
}
.pl-header__nav { display: flex; gap: 18px; align-items: center; }
.pl-link {
    color: var(--muted); text-decoration: none;
    font-size: 14px; transition: color .15s;
}
.pl-link:hover { color: var(--ink); }
.pl-link--muted { color: var(--muted); }
@media (max-width: 540px) {
    .pl-header__nav a { font-size: 13px; }
    .pl-logo { font-size: 16px; }
}

.pl-credit-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 0 0 12px;
    font-size: 13px;
}
.pl-credit-strip[hidden] { display: none; }
.pl-credit-strip__body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    min-width: 0;
}
.pl-credit-strip__email {
    color: var(--muted);
    max-width: 260px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pl-credit-pill {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 5px 10px;
    border-radius: var(--radius-pill);
    font-weight: 700;
    border: 1px solid transparent;
    font-variant-numeric: tabular-nums;
}
.pl-credit-pill--photo {
    color: #125E54;
    background: #E8F7F3;
    border-color: #BDE5DD;
}
.pl-credit-pill--video {
    color: #59328C;
    background: #F1EAFE;
    border-color: #D8C8FA;
}
.pl-credit-strip__link {
    flex: 0 0 auto;
    color: var(--primary);
    font-weight: 700;
    text-decoration: none;
    min-height: 30px;
    display: inline-flex;
    align-items: center;
}
@media (max-width: 540px) {
    .pl-credit-strip {
        align-items: flex-start;
        flex-direction: column;
        gap: 6px;
    }
    .pl-credit-strip__email { max-width: 100%; }
}

/* === Hero === */
.pl-hero {
    padding: 40px 0 32px;
    background: var(--paper-grad);
    text-align: center;
}
.pl-hero__title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 30px;
    line-height: 1.15;
    color: var(--ink-strong);
    letter-spacing: -.01em;
    margin: 0 0 14px;
}
@media (min-width: 720px) {
    .pl-hero { padding: 60px 0 44px; }
    .pl-hero__title { font-size: 42px; }
}
.pl-hero__sub {
    font-size: 17px; color: var(--muted);
    max-width: 620px; margin: 0 auto;
}

/* === 4 услуги — info cards (визуальный обзор для intuition) === */
.pl-services {
    display: grid; gap: 12px;
    grid-template-columns: 1fr 1fr;
    max-width: 720px; margin: 24px auto 0;
}
@media (min-width: 720px) {
    .pl-services { grid-template-columns: repeat(4, 1fr); gap: 14px; }
}
.pl-service-tile {
    background: var(--card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius);
    padding: 16px 14px;
    text-align: center;
    box-shadow: var(--shadow-sm);
}
.pl-service-tile__icon {
    font-size: 28px;
    margin-bottom: 6px;
    display: block; line-height: 1;
}
.pl-service-tile__name {
    font-weight: 600; color: var(--ink-strong);
    font-size: 14px; line-height: 1.25;
    margin-bottom: 4px;
}
.pl-service-tile__price {
    font-size: 13px; color: var(--primary);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.pl-package-panel {
    max-width: 760px;
    margin: 22px auto 0;
    padding: 18px;
    border: 1px solid rgba(139,38,53,.18);
    border-radius: var(--radius-xl);
    background: rgba(255,255,255,.74);
    box-shadow: var(--shadow-sm);
    text-align: left;
}
.pl-package-panel__head {
    display: grid;
    gap: 4px;
    margin-bottom: 14px;
}
.pl-package-panel__head strong {
    color: var(--ink-strong);
    font-size: 17px;
}
.pl-package-panel__head span {
    color: var(--muted);
    font-size: 14px;
}
.pl-package-strip {
    display: grid;
    gap: 10px;
    grid-template-columns: 1fr;
    margin: 0;
}
@media (min-width: 720px) {
    .pl-package-strip { grid-template-columns: repeat(3, 1fr); }
}
.pl-package-mini {
    position: relative;
    display: grid;
    gap: 4px;
    text-align: left;
    color: var(--ink);
    text-decoration: none;
    background: var(--card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius);
    padding: 14px 14px 12px;
    box-shadow: var(--shadow-sm);
    min-height: 132px;
}
.pl-package-mini:hover {
    border-color: var(--primary);
    box-shadow: var(--shadow);
}
.pl-package-mini strong {
    color: var(--ink-strong);
    font-size: 15px;
}
.pl-package-mini span {
    color: var(--muted);
    font-size: 13px;
}
.pl-package-mini b {
    color: var(--primary);
    font-size: 18px;
    font-variant-numeric: tabular-nums;
}
.pl-package-mini__badge {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 2px 8px;
    border-radius: var(--radius-pill);
    background: #FDF4E3;
    color: #7A5A1F;
    font-size: 11px !important;
    font-weight: 800;
}

.pl-packages-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}
@media (min-width: 820px) {
    .pl-packages-grid { grid-template-columns: repeat(3, 1fr); }
}
.pl-package-card {
    background: var(--card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-xl);
    padding: 22px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.pl-package-card h2 {
    font-family: var(--font-display);
    font-size: 22px;
    line-height: 1.2;
    color: var(--ink-strong);
    margin: 0;
}
.pl-package-card p {
    color: var(--muted);
    margin: 0;
}
.pl-package-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 10px;
    color: var(--muted);
    font-size: 14px;
}
.pl-package-card li {
    padding-top: 10px;
    border-top: 1px solid var(--border-light);
}
.pl-package-card__footer {
    margin-top: auto;
    display: grid;
    gap: 12px;
}
.pl-package-card__footer strong {
    color: var(--primary);
    font-size: 28px;
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

/* === Form / sections === */
.pl-form { padding: 28px 16px 56px; max-width: 720px; margin: 0 auto; }
@media (min-width: 720px) { .pl-form { padding: 36px 24px 72px; } }

.pl-section {
    background: var(--card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-xl);
    padding: 24px;
    margin-bottom: 18px;
    box-shadow: var(--shadow-sm);
}
.pl-section__title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 20px;
    color: var(--ink-strong);
    margin: 0 0 4px;
    display: flex; align-items: baseline; gap: 8px;
}
.pl-section__title__step {
    font-size: 14px;
    background: var(--primary); color: #fff;
    width: 28px; height: 28px; border-radius: 50%;
    display: inline-grid; place-items: center;
    flex: 0 0 28px;
    font-weight: 700;
    font-family: var(--font-body);
}
.pl-section__hint {
    font-size: 14px; color: var(--muted);
    margin: 0 0 16px;
}

/* === File drop / picker === */
.pl-file {
    display: flex; flex-direction: column; gap: 10px;
    border: 2px dashed var(--border);
    border-radius: var(--radius-lg);
    padding: 24px 20px;
    background: var(--card-warm);
    transition: border-color .15s, background .15s;
    text-align: center;
    cursor: pointer;
}
.pl-file:has(input:focus-visible) { border-color: var(--primary); }
.pl-file:hover { border-color: var(--primary); background: #FCEFE9; }
.pl-file__big {
    font-size: 28px; display: block; margin-bottom: 4px;
}
.pl-file__primary {
    font-weight: 600; color: var(--ink-strong); font-size: 16px;
    margin: 0;
}
.pl-file__hint {
    font-size: 13px; color: var(--muted-light);
    margin: 0;
}
.pl-file input[type="file"] {
    font-family: inherit; font-size: 14px;
    color: var(--ink); cursor: pointer;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 8px 12px;
    margin-top: 4px;
}

/* === Constructor: радио-карточки === */
.opt-group {
    display: grid; gap: 12px; grid-template-columns: 1fr;
    border: 0; padding: 0; margin: 0;
}
@media (min-width: 540px) {
    .opt-group--main { grid-template-columns: 1fr 1fr; }
}
.opt-group legend, .pl-sr-only {
    position: absolute; width: 1px; height: 1px; padding: 0;
    margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
}

.opt-card {
    position: relative;
    display: flex; flex-direction: column; gap: 6px;
    background: var(--card);
    border: 2px solid var(--border-light);
    border-radius: var(--radius-lg);
    padding: 18px 18px 16px;
    cursor: pointer;
    transition: border-color .15s, box-shadow .15s, transform .15s, background .15s;
    min-height: var(--tap-min);
}
.opt-card:hover {
    border-color: var(--primary);
    transform: translateY(-1px);
    box-shadow: var(--shadow);
}
.opt-card:has(input:checked) {
    border-color: var(--primary);
    background: var(--card-warm);
    box-shadow: 0 0 0 3px rgba(139,38,53,.10), var(--shadow);
}
.opt-card:focus-within {
    outline: 3px solid rgba(139,38,53,.30);
    outline-offset: 2px;
}
.opt-card input[type="radio"],
.opt-card input[type="checkbox"] {
    position: absolute; opacity: 0; pointer-events: none;
    width: 1px; height: 1px;
}
.opt-card__icon {
    font-size: 22px; line-height: 1;
    margin-bottom: 4px;
}
.opt-card__title {
    font-weight: 600;
    font-size: 16px;
    color: var(--ink-strong);
    line-height: 1.3;
}
.opt-card__desc {
    color: var(--muted);
    font-size: 14px;
    line-height: 1.4;
    margin: 2px 0 0;
}
.opt-card__price {
    font-weight: 700;
    color: var(--primary);
    font-size: 18px;
    font-variant-numeric: tabular-nums;
    margin-top: auto;
    padding-top: 8px;
}

/* === Sub-options (colorize / animate quality) === */
.opt-sub, .opt-quality {
    max-height: 0; overflow: hidden;
    opacity: 0; margin: 0;
    transition: max-height .3s ease, opacity .25s ease, margin .25s ease;
}
.opt-group--main:has(input[value="restore"]:checked) ~ .opt-sub--colorize {
    max-height: 220px; opacity: 1; margin: 16px 0 0;
}
.opt-addon:has(#animate-toggle:checked) .opt-quality {
    max-height: 400px; opacity: 1; margin-top: 14px;
}
@supports not selector(:has(*)) {
    .opt-sub, .opt-quality { max-height: 500px; opacity: 1; margin: 12px 0; }
}

/* Toggle row (colorize / animate) */
.opt-toggle {
    display: flex; align-items: flex-start; gap: 12px;
    background: var(--accent-soft);
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 16px;
    cursor: pointer;
    transition: border-color .15s, background .15s;
}
.opt-toggle:has(input:checked) {
    border-color: var(--primary);
    background: #FCEFE9;
}
.opt-toggle input { margin-top: 3px; accent-color: var(--primary); width: 18px; height: 18px; }
.opt-toggle__body { display: flex; flex-direction: column; gap: 2px; }
.opt-toggle__title { font-weight: 600; color: var(--ink-strong); font-size: 15px; }
.opt-toggle__desc { font-size: 13px; color: var(--muted); line-height: 1.4; }
.opt-toggle__price {
    margin-left: auto;
    color: var(--primary);
    font-weight: 700;
    white-space: nowrap;
    font-size: 14px;
}

/* Animate quality 2x card grid */
.opt-quality__grid {
    display: grid; gap: 10px;
    grid-template-columns: 1fr 1fr;
}
.opt-quality__card {
    position: relative;
    background: var(--card); border: 2px solid var(--border-light);
    border-radius: var(--radius);
    padding: 14px; cursor: pointer; transition: all .15s;
    display: flex; flex-direction: column; gap: 4px;
}
.opt-quality__card:hover { border-color: var(--primary); }
.opt-quality__card:has(input:checked) {
    border-color: var(--primary);
    background: var(--card-warm);
    box-shadow: 0 0 0 2px rgba(139,38,53,.10);
}
.opt-quality__card[data-hd-available="false"] { opacity: .55; cursor: not-allowed; }
.opt-quality__card input { position: absolute; opacity: 0; }
.opt-quality__title { font-weight: 600; color: var(--ink-strong); font-size: 14px; }
.opt-quality__hint { font-size: 12px; color: var(--muted); }
.opt-quality__price {
    font-weight: 700; color: var(--primary);
    font-size: 14px; margin-top: 2px;
}

/* === Input / email === */
.pl-input {
    display: block; width: 100%;
    background: var(--card);
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 16px;
    font-family: inherit; font-size: 16px;
    color: var(--ink-strong);
    transition: border-color .15s, box-shadow .15s;
    -webkit-appearance: none;
}
.pl-input:focus {
    outline: 0;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(139,38,53,.12);
}
.pl-input::placeholder { color: var(--muted-light); }

.pl-label {
    display: block;
    font-weight: 600;
    color: var(--ink-strong);
    margin-bottom: 6px;
    font-size: 14px;
}
.pl-email-verified {
    margin-top: 12px;
    padding: 12px 14px;
    border-radius: var(--radius);
    background: #E8F7F3;
    border: 1px solid #BDE5DD;
    color: #125E54;
    font-size: 14px;
}
.pl-email-verified[hidden],
#email-code-panel[hidden] {
    display: none;
}
.pl-email-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 10px;
}
.pl-email-actions .pl-btn {
    width: 100%;
}
.pl-email-actions .pl-btn--primary,
.pl-email-actions .pl-btn--secondary {
    min-height: 52px;
    padding: 14px 18px;
}
@media (min-width: 560px) {
    .pl-email-actions {
        grid-template-columns: 1fr 1fr;
    }
}

/* === Consent checkboxes === */
.pl-consent {
    display: flex; flex-direction: column; gap: 10px;
    background: var(--accent-soft);
    border-radius: var(--radius);
    padding: 14px 16px;
    margin-top: 12px;
}
.pl-consent__row {
    display: flex; align-items: flex-start; gap: 10px;
    font-size: 14px;
    line-height: 1.45;
    color: var(--ink);
    cursor: pointer;
}
.pl-consent__row input {
    margin-top: 3px;
    accent-color: var(--primary);
    width: 18px; height: 18px;
}
.pl-consent a { color: var(--primary); }

/* === Sticky total + CTA === */
.pl-total {
    background: var(--card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-xl);
    padding: 18px 22px;
    margin: 22px 0;
    display: flex; flex-direction: column; gap: 6px;
    box-shadow: var(--shadow-sm);
}
.pl-total__row {
    display: flex; justify-content: space-between; align-items: baseline;
    font-size: 17px;
}
.pl-total__label { color: var(--ink); font-weight: 500; }
.pl-total__amount {
    color: var(--primary);
    font-weight: 700;
    font-size: 26px;
    font-variant-numeric: tabular-nums;
}
.pl-total__eta { color: var(--muted); font-size: 14px; }
.pl-total__breakdown { color: var(--muted-light); font-size: 13px; }

/* === Primary CTA button === */
.pl-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 8px;
    border: 0; border-radius: var(--radius);
    font-family: inherit; font-weight: 600;
    cursor: pointer;
    transition: all .15s;
    text-decoration: none;
    -webkit-tap-highlight-color: transparent;
}
.pl-btn--primary {
    background: var(--primary); color: #fff;
    padding: 18px 28px;
    font-size: 17px;
    box-shadow: var(--shadow-cta);
    width: 100%;
}
.pl-btn--primary:hover {
    background: var(--primary-dark);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(139,38,53,.28);
    color: #fff;
}
.pl-btn--primary:active { transform: translateY(0); }
.pl-btn--secondary {
    background: var(--card);
    color: var(--ink-strong);
    border: 1.5px solid var(--border);
    padding: 16px 24px;
    font-size: 16px;
}
.pl-btn--secondary:hover { border-color: var(--ink); }

/* iOS Safari-safe busy state (NO btn.disabled — bfcache problem) */
form.is-busy .pl-btn { opacity: .65; pointer-events: none; cursor: progress; }
form.is-busy .pl-btn::after { content: '…'; margin-left: 6px; }

/* === Flash messages === */
.pl-flash {
    border-radius: var(--radius);
    padding: 14px 16px;
    margin-bottom: 14px;
    font-size: 14px;
    line-height: 1.5;
}
.pl-flash--warn { background: var(--warn-bg); color: var(--warn-ink); border: 1px solid #E8C77A; }
.pl-flash--error { background: var(--err-bg); color: var(--err-ink); border: 1px solid #E8A0A0; }
.pl-flash ul { margin: 6px 0 0; padding-left: 20px; }

/* === Footer === */
.pl-footer {
    background: var(--card);
    border-top: 1px solid var(--border-light);
    padding: 32px 0 22px;
    margin-top: 40px;
    color: var(--muted);
    font-size: 14px;
}
.pl-footer__grid {
    display: grid; gap: 24px; grid-template-columns: 1fr;
}
@media (min-width: 720px) {
    .pl-footer__grid { grid-template-columns: 1.6fr 1fr 1.4fr; }
}
.pl-footer__title {
    font-family: var(--font-display);
    color: var(--ink-strong);
    font-size: 16px;
    font-weight: 600;
    margin: 0 0 8px;
}
.pl-footer__muted { color: var(--muted); font-size: 13px; margin: 0 0 4px; line-height: 1.5; }
.pl-footer__list { list-style: none; padding: 0; margin: 0; }
.pl-footer__list li { margin-bottom: 6px; }
.pl-footer__legal {
    text-align: center;
    border-top: 1px solid var(--border-light);
    margin-top: 24px; padding-top: 14px;
    font-size: 12px; color: var(--muted-light);
}

/* === Order / status / checkout views === */
.pl-page-title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 28px;
    line-height: 1.2;
    color: var(--ink-strong);
    margin: 28px 0 6px;
}
.pl-page-sub { color: var(--muted); font-size: 15px; margin: 0 0 18px; }
.pl-result-img {
    width: 100%;
    border-radius: var(--radius-lg);
    background: var(--card);
    border: 1px solid var(--border-light);
    box-shadow: var(--shadow);
}

/* === Legal pages typography === */
.pl-legal {
    background: var(--card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-xl);
    padding: 32px;
    margin: 28px auto;
    max-width: 760px;
    box-shadow: var(--shadow-sm);
}
.pl-legal h1 {
    font-family: var(--font-display);
    font-size: 28px;
    font-weight: 600;
    color: var(--ink-strong);
    margin: 0 0 22px;
    line-height: 1.2;
}
.pl-legal h2 {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 600;
    color: var(--ink-strong);
    margin: 28px 0 12px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border-light);
}
.pl-legal h3 { font-weight: 600; font-size: 16px; color: var(--ink-strong); margin: 16px 0 6px; }
.pl-legal p { margin: 0 0 12px; color: var(--ink); line-height: 1.65; }
.pl-legal ul, .pl-legal ol { margin: 0 0 12px; padding-left: 22px; color: var(--ink); line-height: 1.65; }
.pl-legal li { margin-bottom: 6px; }
.pl-legal strong { color: var(--ink-strong); }
.pl-legal a { color: var(--primary); }
.pl-legal .legal-requisites,
.pl-legal .rkn-block {
    background: var(--accent-soft);
    border-left: 4px solid var(--primary);
    border-radius: var(--radius-sm);
    padding: 14px 18px;
    margin: 14px 0;
    font-size: 14px;
}

/* === A11y === */
.sr-only {
    position: absolute; width: 1px; height: 1px; padding: 0;
    margin: -1px; overflow: hidden; clip: rect(0 0 0 0);
    white-space: nowrap; border: 0;
}
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        transition: none !important;
        animation: none !important;
    }
}

/* ========================================================================
   LEGACY ALIASES + ORDER/CHECKOUT VIEW SUPPORT
   ======================================================================== */

/* .pl-card is an alias for .pl-section */
.pl-card {
    background: var(--card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-xl);
    padding: 24px;
    margin-bottom: 18px;
    box-shadow: var(--shadow-sm);
}
.pl-card__title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 20px;
    color: var(--ink-strong);
    margin: 0 0 12px;
}

/* === Order page === */
.pl-order { padding: 28px 16px 56px; max-width: 720px; margin: 0 auto; }
@media (min-width: 720px) { .pl-order { padding: 36px 24px 72px; } }
.pl-order__header { text-align: center; margin-bottom: 24px; }
.pl-order__title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 28px;
    color: var(--ink-strong);
    margin: 0 0 6px;
}
.pl-order__token { color: var(--muted); font-size: 13px; margin: 0; }
.pl-order__token code {
    background: var(--accent-soft);
    padding: 2px 8px;
    border-radius: var(--radius-sm);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 12px;
}

/* === Progress / spinner === */
.pl-progress { text-align: center; padding: 24px 16px; }
.pl-progress__step {
    font-weight: 600;
    color: var(--ink-strong);
    margin: 12px 0 4px;
    font-size: 16px;
}
.pl-progress__eta { color: var(--muted); font-size: 14px; margin: 0 0 12px; }
.pl-progress__eta strong { color: var(--ink-strong); }

.pl-spinner {
    display: inline-block; width: 38px; height: 38px;
    border: 3px solid var(--border);
    border-top-color: var(--primary);
    border-radius: 50%;
    animation: pl-spin .9s linear infinite;
}
@keyframes pl-spin { to { transform: rotate(360deg); } }

.pl-progressbar {
    width: 100%; height: 6px;
    background: var(--border-light);
    border-radius: var(--radius-pill);
    overflow: hidden;
    margin: 8px 0;
}
.pl-progressbar__fill {
    height: 100%;
    background: var(--primary);
    border-radius: var(--radius-pill);
    transition: width .4s ease;
}

/* === Result / preview === */
.pl-result__wm-note {
    background: var(--warn-bg);
    color: var(--warn-ink);
    border-left: 3px solid var(--accent-gold);
    padding: 10px 14px;
    border-radius: var(--radius-sm);
    font-size: 13px;
    margin: 12px 0;
}
.pl-result__failed-title {
    color: var(--err-ink);
    font-weight: 600;
    font-size: 16px;
    margin: 12px 0 4px;
}
.pl-result__failed-text {
    color: var(--muted);
    font-size: 14px;
    margin: 0 0 12px;
}

.pl-result img, .pl-result video {
    width: 100%;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-light);
    box-shadow: var(--shadow);
    background: var(--card);
}

/* === Visually hidden === */
.pl-visually-hidden, .opt-toggle__label {
    /* in case still referenced */
}

/* === Header social icons === */
.pl-header__socials { display: inline-flex; align-items: center; gap: 6px; }
.pl-social {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--card-warm);
    border: 1px solid var(--border-light);
    transition: transform .15s, border-color .15s;
    padding: 5px;
}
.pl-social:hover { transform: scale(1.1); border-color: var(--primary); }
.pl-social img { display: block; max-width: 100%; height: auto; object-fit: contain; }
@media (max-width: 480px) {
    .pl-header__socials { gap: 4px; }
    .pl-social { width: 28px; height: 28px; padding: 4px; }
    .pl-header__nav a[href^="mailto"] { font-size: 11px; }
}

/* Удалить сейчас — link-style в стиле бренда (фикс синей кнопки в браузере) */
.pl-link--danger {
    background: none;
    border: 0;
    padding: 0;
    margin: 0;
    font: inherit;
    color: var(--muted);
    text-decoration: underline;
    text-underline-offset: 2px;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
}
.pl-link--danger:hover,
.pl-link--danger:focus { color: var(--ink); }
.pl-inline-form { display: inline; }
