/* Страницы «Сотрудничество» (партнерам). Все стили заскоуплены под .partner-page, чтобы не задевать сайт. */

.partner-page {
    --pp-brand: #008EF1;
    --pp-brand-d: #0077cc;
    --pp-brand-soft: #e8f4fe;
    --pp-ink: #0b0a12;
    --pp-body: #5e5e5f;
    --pp-muted: #5f636b;
    --pp-success: #0cbc87;
    --pp-danger: #d6293e;
    --pp-orange: #fd7e14;
    --pp-info: #17a2b8;
    --pp-soft: #f5f7fb;
    --pp-line: #e8ecf2;
    --pp-shadow: 0 0 40px rgba(29, 58, 83, .10);
    --pp-shadow-lg: 0 1.5rem 3rem rgba(29, 58, 83, .18);
    --pp-r: 1rem;
    --pp-r-lg: 1.5rem;

    font-family: "DM Sans", sans-serif;
    color: var(--pp-body);
}

.partner-page * { box-sizing: border-box; }
.partner-page h1, .partner-page h2, .partner-page h3, .partner-page h4, .partner-page h5, .partner-page h6 {
    font-family: "Poppins", sans-serif;
    font-weight: 700;
    color: var(--pp-ink);
    line-height: 1.22;
}

.partner-page .pp-lead { font-size: 1.12rem; color: var(--pp-muted); }
.partner-page .pp-ico { width: 1em; height: 1em; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; flex: none; }

.partner-page .pp-eyebrow { display: inline-flex; align-items: center; gap: .5rem; background: var(--pp-brand-soft); color: var(--pp-brand-d); font-weight: 600; font-size: .9rem; border-radius: 50rem; padding: .45rem 1rem; }
.partner-page .pp-hero h1 { font-size: clamp(1.9rem, 3.6vw, 2.7rem); }
.partner-page .pp-trust-pill { display: inline-flex; align-items: center; gap: .5rem; background: #fff; border: 1px solid var(--pp-line); border-radius: 50rem; padding: .45rem .95rem; font-weight: 600; color: var(--pp-ink); font-size: .88rem; }

/* выгоды */
.partner-page .pp-feat { display: flex; gap: 1rem; align-items: flex-start; padding: 1.1rem 0; border-bottom: 1px solid var(--pp-line); }
.partner-page .pp-feat:last-child { border-bottom: none; }
.partner-page .pp-feat .pp-fic { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; font-size: 1.45rem; flex: none; }
.partner-page .pp-bg-1 { background: #e8f4fe; color: var(--pp-brand); }
.partner-page .pp-bg-2 { background: #e6f8f1; color: var(--pp-success); }
.partner-page .pp-bg-3 { background: #fff4e0; color: var(--pp-orange); }
.partner-page .pp-bg-6 { background: #e9f6f8; color: var(--pp-info); }

/* шаги */
.partner-page .pp-step { display: flex; gap: 1rem; align-items: flex-start; margin-bottom: 1.2rem; }
.partner-page .pp-step .pp-n { width: 38px; height: 38px; border-radius: 50%; background: var(--pp-brand); color: #fff; font-family: "Poppins", sans-serif; font-weight: 700; display: grid; place-items: center; flex: none; }

/* менеджер */
.partner-page .pp-manager { background: var(--pp-soft); border-radius: var(--pp-r-lg); padding: 1.4rem; display: flex; gap: 1rem; align-items: center; }
.partner-page .pp-avatar { width: 58px; height: 58px; border-radius: 50%; background: linear-gradient(135deg, #008EF1, #36b3ff); color: #fff; font-family: "Poppins", sans-serif; font-weight: 700; font-size: 1.25rem; display: grid; place-items: center; flex: none; }

/* липкая форма */
/* top:80px — чтобы форма не пряталась под прилипающую при скролле шапку (header-sticky-on, ~64px) */
.partner-page .pp-sticky { position: sticky; top: 80px; align-self: flex-start; }
.partner-page .pp-form-card { background: #fff; border-radius: var(--pp-r-lg); box-shadow: var(--pp-shadow-lg); overflow: hidden; border: 1px solid var(--pp-line); }
.partner-page .pp-form-head { background: linear-gradient(135deg, #008EF1, #0a73d0); color: #fff; padding: 1.4rem 1.6rem; }
.partner-page .pp-form-head h4 { color: #fff; margin: 0; }
.partner-page .pp-form-head .pp-sub { color: #dcefff; font-size: .9rem; margin-top: .2rem; }
.partner-page .pp-form-body { padding: 1.5rem 1.6rem; }
.partner-page .pp-form-foot { background: var(--pp-soft); padding: .9rem 1.6rem; display: flex; align-items: center; gap: .6rem; font-size: .82rem; color: var(--pp-muted); border-top: 1px solid var(--pp-line); }
.partner-page .form-label { font-weight: 600; color: var(--pp-ink); font-size: .88rem; margin-bottom: .3rem; }
.partner-page .pp-req { color: var(--pp-danger); }
.partner-page .form-control, .partner-page .form-select { border: 1.5px solid var(--pp-line); border-radius: .6rem; padding: .65rem .85rem; color: var(--pp-ink); font-size: .95rem; }
.partner-page .form-control:focus, .partner-page .form-select:focus { border-color: var(--pp-brand); box-shadow: 0 0 0 .2rem rgba(0, 142, 241, .12); }
.partner-page .form-control.is-invalid, .partner-page .form-select.is-invalid { border-color: var(--pp-danger); }
.partner-page .pp-field-error { color: var(--pp-danger); font-size: .78rem; margin-top: .25rem; display: none; }

.partner-page .btn-pp { background: var(--pp-brand); border: none; color: #fff; font-weight: 600; border-radius: .7rem; padding: .85rem 1.6rem; transition: .18s; }
.partner-page .btn-pp:hover { background: var(--pp-brand-d); color: #fff; }
.partner-page .btn-pp-ghost { background: #fff; border: 1.5px solid var(--pp-line); color: var(--pp-ink); font-weight: 600; border-radius: .7rem; padding: .8rem 1.5rem; }

/* город: автокомплит «поиск при вводе» + чипы выбранных */
.partner-page .city-ac { position: relative; }
.partner-page .city-ac-input { position: relative; }
.partner-page .city-ac-input input { padding-right: 2.2rem; }
.partner-page .city-ac-clear { position: absolute; right: .45rem; top: 50%; transform: translateY(-50%); border: none; background: transparent; color: var(--pp-muted); font-size: 1.3rem; line-height: 1; padding: 0 .35rem; cursor: pointer; border-radius: .4rem; }
.partner-page .city-ac-clear:hover { color: var(--pp-ink); background: var(--pp-soft); }
.partner-page .city-ac-dd { position: absolute; left: 0; right: 0; top: calc(100% + 5px); z-index: 1200; background: #fff; border: 1px solid var(--pp-line); border-radius: .8rem; box-shadow: var(--pp-shadow-lg); max-height: 252px; overflow-y: auto; padding: .35rem; }
.partner-page .city-ac-group { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--pp-muted); padding: .5rem .65rem .25rem; }
.partner-page .city-ac-item { display: flex; align-items: center; gap: .55rem; padding: .55rem .65rem; border-radius: .55rem; cursor: pointer; font-size: .95rem; color: var(--pp-ink); }
.partner-page .city-ac-item .pp-ico { font-size: 1.05rem; color: var(--pp-brand); flex: none; }
.partner-page .city-ac-item:hover, .partner-page .city-ac-item.active { background: var(--pp-brand-soft); }
.partner-page .city-ac-item strong { color: var(--pp-brand-d); font-weight: 700; }
.partner-page .city-ac-add { color: var(--pp-brand-d); font-weight: 600; }
.partner-page .city-ac-add .pp-ico { color: var(--pp-success); }
.partner-page .city-chips { display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: .55rem; }
.partner-page .city-chips:empty { display: none; }
.partner-page .city-chip { display: inline-flex; align-items: center; gap: .4rem; background: var(--pp-brand-soft); color: var(--pp-brand-d); border: 1px solid rgba(0, 142, 241, .25); border-radius: 50rem; padding: .35rem .35rem .35rem .8rem; font-size: .85rem; font-weight: 600; }
.partner-page .city-chip button { border: none; background: transparent; color: var(--pp-brand-d); font-size: 1.15rem; line-height: 1; padding: 0; width: 1.3rem; height: 1.3rem; display: grid; place-items: center; border-radius: 50%; cursor: pointer; }
.partner-page .city-chip button:hover { background: rgba(0, 142, 241, .18); }

/* согласие 152-ФЗ */
.partner-page .pp-consent { display: flex; gap: .65rem; align-items: flex-start; cursor: pointer; font-size: .85rem; color: var(--pp-body); margin: 0; }
.partner-page .pp-consent input { margin-top: .15rem; width: 1.1rem; height: 1.1rem; flex: none; accent-color: var(--pp-brand); cursor: pointer; }
.partner-page .pp-consent input.is-invalid { outline: 2px solid var(--pp-danger); outline-offset: 2px; border-radius: .2rem; }
.partner-page .pp-consent a { color: var(--pp-brand); }

/* прогрессивное раскрытие необязательных полей */
.partner-page .more-fields { border: 1px dashed var(--pp-line); border-radius: .7rem; padding: .1rem .9rem; }
.partner-page .more-fields summary { font-weight: 600; color: var(--pp-brand-d); cursor: pointer; list-style: none; display: flex; align-items: center; gap: .45rem; padding: .7rem 0; font-size: .92rem; }
.partner-page .more-fields summary::-webkit-details-marker { display: none; }
.partner-page .more-fields summary .pp-ico { color: var(--pp-brand); font-size: 1.05rem; transition: transform .2s; }
.partner-page .more-fields[open] summary .pp-ico { transform: rotate(45deg); }
.partner-page .more-fields[open] { padding-bottom: .9rem; }
.partner-page .more-fields:not([open]) .more-fields-body { display: none; }

/* успех */
.partner-page .pp-success { padding: 2.2rem 1.6rem 2rem; text-align: center; }
.partner-page .pp-success .pp-ok { width: 64px; height: 64px; border-radius: 50%; background: rgba(12, 188, 135, .12); color: #0a8f66; display: grid; place-items: center; margin: 0 auto 1rem; }

/* FAQ */
.partner-page .pp-faq details { background: #fff; border: 1px solid var(--pp-line); border-radius: var(--pp-r); padding: .9rem 1.1rem; margin-bottom: .6rem; }
.partner-page .pp-faq summary { font-family: "Poppins", sans-serif; font-weight: 600; color: var(--pp-ink); cursor: pointer; list-style: none; display: flex; justify-content: space-between; gap: 1rem; font-size: .98rem; }
.partner-page .pp-faq summary::-webkit-details-marker { display: none; }
.partner-page .pp-faq details[open] summary .pp-ico { transform: rotate(45deg); }
.partner-page .pp-faq summary .pp-ico { transition: .2s; color: var(--pp-brand); }

.partner-page .pp-block { padding: 2.6rem 0; }

@media (max-width: 991px) {
    .partner-page .pp-sticky { position: static; }
    .partner-page .city-chip button { width: 1.6rem; height: 1.6rem; }
    .partner-page .city-ac-item { padding: .7rem .65rem; }
}
@media (prefers-reduced-motion: reduce) {
    .partner-page * { transition-duration: .01ms !important; animation-duration: .01ms !important; }
}

/* хлебные крошки (как на остальном сайте) — partner.css грузится только на этих страницах */
.breadcrumb a { color: inherit; }
.breadcrumb .breadcrumb-item + .breadcrumb-item::before { color: rgba(0, 0, 0, .35); }

/* адаптив под телефон */
@media (max-width: 575px) {
    .partner-page .pp-block { padding: 1.5rem 0; }
    .partner-page .pp-block .row { --bs-gutter-y: 1.25rem; }
    .partner-page .pp-form-head { padding: 1.1rem 1.15rem; }
    .partner-page .pp-form-body { padding: 1.15rem; }
    .partner-page .pp-form-foot { padding: .8rem 1.15rem; }
    .partner-page .pp-hero h1 { font-size: 1.6rem; }
    .partner-page .pp-lead { font-size: 1rem; }
    .partner-page .pp-manager { padding: 1.1rem; gap: .8rem; }
    .partner-page .pp-avatar { width: 48px; height: 48px; font-size: 1.05rem; }
    .partner-page .pp-feat { padding: .9rem 0; }
    .partner-page .pp-feat .pp-fic { width: 40px; height: 40px; font-size: 1.2rem; }
}
