/* ---------------------------------------------------------------------------
   Conference Q&A — theme based on paluba.media
   (warm off-white canvas, charcoal text, cyan accent, system sans-serif)
--------------------------------------------------------------------------- */
:root {
    --bg: #f7f7f5;
    --surface: #ffffff;
    --surface-alt: #f1f1ef;
    --text: #313131;
    --text-muted: #575758;
    --accent: #0bb4e1;
    --accent-dark: #0a93b8;
    --success: #00d084;
    --success-dark: #019e65;
    --danger: #e5484d;
    --danger-dark: #c4383c;
    --border: #dddddd;
    --border-light: #ebebeb;
    --radius: 10px;
    --shadow: 0 1px 2px rgba(49, 49, 49, .06), 0 6px 20px rgba(49, 49, 49, .05);
    --font: Roboto, sans-serif;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
    font-family: var(--font);
    background: var(--bg);
    color: var(--text);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--accent-dark); text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3 { color: var(--text); font-weight: 700; line-height: 1.25; margin: 0 0 .5em; }
h1 { font-size: 1.7rem; }
h2 { font-size: 1.3rem; }
h3 { font-size: 1.05rem; }

p { margin: 0 0 1rem; }
.muted { color: var(--text-muted); }
.small { font-size: .85rem; }

/* ----------------------------- Layout ---------------------------------- */
.site-header {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 10;
}
.site-header .inner {
    max-width: 1080px;
    margin: 0 auto;
    padding: .85rem 1.25rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}
.brand {
    display: inline-flex;
    align-items: center;
}
.brand img { height: 26px; width: auto; display: block; }
.site-header nav { margin-left: auto; display: flex; gap: 1.1rem; align-items: center; }
.site-header nav a { color: var(--text-muted); font-weight: 600; font-size: .92rem; }
.site-header nav a:hover { color: var(--text); text-decoration: none; }

main { max-width: 1080px; margin: 0 auto; padding: 1.75rem 1.25rem 4rem; }
main.narrow { max-width: 680px; }

.page-head { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1.5rem; }
.page-head .grow { flex: 1; }

/* ----------------------------- Cards ----------------------------------- */
.card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.4rem;
    margin-bottom: 1.1rem;
}
.card.tight { padding: 1rem 1.2rem; }

/* ------------------------------ Tags ----------------------------------- */
.tag {
    display: inline-block;
    text-transform: uppercase;
    font-size: .7rem;
    font-weight: 700;
    padding: .22em .6em;
    border-radius: 999px;
    background: var(--surface-alt);
    color: var(--text-muted);
    border: 1px solid var(--border);
}
.tag.accent { background: rgba(11,180,225,.12); color: var(--accent-dark); border-color: rgba(11,180,225,.3); }
.tag.success { background: rgba(0,208,132,.13); color: var(--success-dark); border-color: rgba(0,208,132,.3); }
.tag.warn { background: #fff4e0; color: #a96a00; border-color: #f3d9a8; }
.tag.muted { background: var(--surface-alt); }

/* ----------------------------- Buttons --------------------------------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .45rem;
    font-family: inherit; font-size: .95rem; font-weight: 600;
    padding: .6rem 1.1rem;
    border-radius: 8px;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
    cursor: pointer;
    transition: background .12s, border-color .12s, color .12s, transform .04s;
    text-decoration: none;
}
.btn:hover { background: var(--surface-alt); text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn.primary:hover { background: var(--accent-dark); border-color: var(--accent-dark); }
.btn.success { background: var(--success); border-color: var(--success); color: #fff; }
.btn.success:hover { background: var(--success-dark); border-color: var(--success-dark); }
.btn.danger { background: var(--surface); border-color: var(--danger); color: var(--danger-dark); }
.btn.danger:hover { background: var(--danger); color: #fff; }
.btn.ghost { background: transparent; border-color: transparent; color: var(--text-muted); }
.btn.ghost:hover { background: var(--surface-alt); }
.btn.sm { padding: .4rem .7rem; font-size: .85rem; }
.btn.lg { padding: .8rem 1.5rem; font-size: 1.05rem; }
.btn.block { width: 100%; }

.btn-row { display: flex; gap: .6rem; flex-wrap: wrap; align-items: center; }

/* Keyboard focus ring matching the cyan one on form fields (links/buttons would
   otherwise only get the platform default). */
.btn:focus-visible, .event-nav__item:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(11, 180, 225, .35);
}

/* ------------------------------ Forms ---------------------------------- */
form .row { margin-bottom: 1.15rem; }
label { display: block; font-weight: 600; margin-bottom: .35rem; font-size: .92rem; }
.form-help, .help-text { color: var(--text-muted); font-size: .82rem; margin-top: .3rem; }

input[type=text], input[type=email], input[type=password], input[type=search], textarea, select {
    width: 100%;
    font-family: inherit;
    font-size: 1rem;
    color: var(--text);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: .6rem .7rem;
}
/* Comfortable ~44px touch height for single-line controls on mobile. */
input[type=text], input[type=email], input[type=password], input[type=search], select { min-height: 44px; }
textarea { resize: vertical; }
input:focus, textarea:focus, select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(11,180,225,.18);
}

.choice-list { display: flex; flex-direction: column; gap: .45rem; }
.choice-list label { font-weight: 400; display: flex; align-items: center; gap: .5rem; margin: 0; cursor: pointer; }
.choice-list input { width: auto; }

/* Top-align the box against a multi-line label (e.g. the consent text wraps on
   phones) and pad the label so the whole row is a comfortable ~44px tap target. */
.checkbox-inline { display: flex; align-items: flex-start; gap: .5rem; }
.checkbox-inline label { margin: 0; font-weight: 400; padding: .15rem 0; }
.checkbox-inline input { width: auto; }

/* Custom checkbox: cyan rounded box, fills with a white check when on, red on error */
input[type=checkbox] {
    appearance: none;
    -webkit-appearance: none;
    width: 24px;
    height: 24px;
    margin: 0;
    flex-shrink: 0;
    border: 2px solid var(--accent);
    border-radius: 6px;
    background-color: #fff;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 74%;
    cursor: pointer;
    transition: background-color .12s, border-color .12s;
}
input[type=checkbox]:checked {
    background-color: var(--accent);
    border-color: var(--accent);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12.5l4.5 4.5L19 7'/%3E%3C/svg%3E");
}
input[type=checkbox]:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(11, 180, 225, .25);
}
input[type=checkbox]:user-invalid {
    border-color: var(--danger);
}
label:has(input[type=checkbox]:user-invalid) {
    color: var(--danger);
}

ul.form-errors, .form-errors {
    list-style: none; margin: .35rem 0 0; padding: 0;
    color: var(--danger-dark); font-size: .85rem;
}

.honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* Collapsible "edit answer" in moderation */
.edit-answer { margin: .5rem 0 0; }
.edit-answer > summary { display: inline-block; cursor: pointer; font-size: .85rem; font-weight: 600; color: var(--accent-dark); list-style: none; }
.edit-answer > summary::-webkit-details-marker { display: none; }
.edit-answer[open] > summary { margin-bottom: .4rem; }
.edit-answer label { font-size: .8rem; }

/* ------------------------------ Tables --------------------------------- */
table.data { width: 100%; border-collapse: collapse; background: var(--surface); }
table.data th, table.data td { text-align: left; padding: .8rem .9rem; border-bottom: 1px solid var(--border); }
table.data th { font-size: .78rem; text-transform: uppercase; color: var(--text-muted); }
table.data tr:last-child td { border-bottom: none; }

/* ----------------------------- Flashes --------------------------------- */
.flash { padding: .8rem 1rem; border-radius: 8px; margin-bottom: 1rem; border: 1px solid; font-weight: 500; }
.flash.success { background: rgba(0,208,132,.1); border-color: rgba(0,208,132,.35); color: var(--success-dark); }
.flash.error { background: rgba(229,72,77,.08); border-color: rgba(229,72,77,.35); color: var(--danger-dark); }

/* --------------------------- Field builder ----------------------------- */
.field-rows { display: flex; flex-direction: column; gap: 1rem; }
.field-row {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface-alt);
    padding: 1.1rem;
    position: relative;
}
.field-row .grid {
    display: grid;
    grid-template-columns: 2fr 1.4fr;
    gap: .9rem;
}
.field-row .remove-field {
    position: absolute; top: .7rem; right: .7rem;
}
/* Questionnaire rows: ↑ / ↓ / удалить in one toolbar (programme rows keep .remove-field). */
.field-row .row-tools {
    position: absolute; top: .7rem; right: .7rem;
    display: flex; gap: .35rem;
}
.is-hidden { display: none !important; }
.empty-hint { color: var(--text-muted); font-style: italic; padding: .5rem 0; }

/* Programme builder (admin) — reuses .field-row, adds the photo block. */
.program-row .photo-field { margin-top: .6rem; }

/* Upload widget (logo, cover, speaker photo, programme PDF): preview + Загрузить /
   Изменить / Удалить, driven by upload_controller.js. */
.visually-hidden {
    position: absolute !important;
    width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.upload-field + .upload-field { margin-top: 1.4rem; }
.upload-field__label { font-weight: 600; font-size: .92rem; margin-bottom: .5rem; }
.upload { display: flex; gap: 1.1rem; align-items: center; }
.upload__preview {
    flex: 0 0 auto;
    width: 88px; height: 88px;
    border-radius: 12px;
    background: var(--surface-alt);
    border: 1px solid var(--border);
    overflow: hidden;
    display: flex; align-items: center; justify-content: center;
}
.upload__thumb { width: 100%; height: 100%; object-fit: cover; display: block; }
.upload__placeholder { display: inline-flex; color: var(--text-muted); }
.upload__placeholder svg { width: 40px; height: 40px; opacity: .5; }
.upload__body { flex: 1; min-width: 0; }
.upload__hint { margin: 0 0 .45rem; }
.upload__name { font-weight: 500; margin: 0 0 .45rem; overflow-wrap: anywhere; }
.upload__actions { display: flex; gap: 1.4rem; align-items: center; flex-wrap: wrap; }
.upload__btn {
    display: inline-flex; align-items: center; gap: .45rem;
    background: none; border: 0; padding: 0; cursor: pointer;
    font-family: inherit; font-size: 1.05rem; font-weight: 700;
    color: var(--accent);
    transition: color .12s;
}
.upload__btn svg { width: 1.15em; height: 1.15em; }
.upload__btn:hover { color: var(--accent-dark); }
.upload__btn.muted { color: var(--text-muted); font-weight: 600; }
.upload__btn.muted:hover { color: var(--danger-dark); }
.upload__btn:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(11, 180, 225, .35); border-radius: 6px; }

/* --------------------- Conference branding header ---------------------- */
.event-head { margin-bottom: 1.5rem; }
.event-cover {
    margin-bottom: 1rem;
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border-light);
}
.event-cover img { display: block; width: 100%; height: auto; max-height: 280px; object-fit: cover; }
.event-head__main { display: flex; align-items: center; gap: 1rem; }
.event-head__main .grow { flex: 1; min-width: 0; }
.event-head__main h1 { margin: 0 0 .25rem; }
/* Приветственное слово (описание события под заголовком). */
.event-head__main p { font-size: 1.15rem; }
.event-logo { flex: 0 0 auto; height: 52px; width: auto; max-width: 160px; object-fit: contain; }

/* In-page section tabs between questions and programme (paluba-style). */
.event-nav {
    display: flex;
    gap: .25rem;
    border-bottom: 1px solid var(--border);
    margin-bottom: 1.5rem;
}
.event-nav__item {
    padding: .7rem 1.1rem;
    font-weight: 600;
    color: var(--text-muted);
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color .12s, border-color .12s;
}
.event-nav__item:hover { color: var(--text); text-decoration: none; }
.event-nav__item.is-active { color: var(--accent-dark); border-bottom-color: var(--accent); }

@media (max-width: 640px) {
    .event-nav { gap: 0; }
    .event-nav__item { flex: 1; text-align: center; padding: .9rem .5rem; }
}

/* --------------------- Programme (public page) ------------------------- */
.program-tools { display: flex; gap: .6rem; align-items: center; flex-wrap: wrap; margin-bottom: 1rem; }
.search-box { position: relative; flex: 1; min-width: 200px; }
.search-box__icon {
    position: absolute;
    left: .85rem; top: 50%;
    transform: translateY(-50%);
    width: 18px; height: 18px;
    color: var(--text-muted);
    pointer-events: none;
}
.search-box input[type=search] { appearance: none; -webkit-appearance: none; padding-left: 2.5rem; border-radius: 999px; }
.search-box input[type=search]::-webkit-search-cancel-button { cursor: pointer; }
.program-favonly { white-space: nowrap; }
.program-favonly.is-active { color: var(--accent-dark); border-color: var(--accent); background: rgba(11, 180, 225, .1); }

.program-list { display: flex; flex-direction: column; gap: .9rem; }
.program-entry {
    position: relative;
    display: flex;
    gap: 1rem;
    background: var(--surface);
    border: 1px solid var(--border-light);
    border-radius: var(--radius);
    padding: 1rem 1.2rem;
}
/* Reserve room for the favourite ★ only when the interactive controls are present. */
[data-controller="program"] .program-entry { padding-right: 2.8rem; }
.program-fav {
    position: absolute;
    top: .6rem;
    right: .6rem;
    padding: .25rem;
    background: none;
    border: 0;
    line-height: 0;
    cursor: pointer;
    color: var(--border);
    transition: color .12s;
}
.program-fav svg { width: 22px; height: 22px; fill: none; }
.program-fav:hover { color: var(--text-muted); }
.program-fav.is-fav { color: var(--accent); }
.program-fav.is-fav svg { fill: var(--accent); }
.program-fav:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(11, 180, 225, .35); border-radius: 6px; }
.program-time {
    flex: 0 0 auto;
    min-width: 64px;
    font-weight: 700;
    color: var(--accent-dark);
    font-variant-numeric: tabular-nums;
}
.program-body { flex: 1; min-width: 0; }
.program-topic { font-weight: 600; font-size: 1.05rem; margin: 0 0 .35rem; }
.speaker { display: flex; gap: .8rem; align-items: flex-start; margin-top: .4rem; }
.speaker-photo {
    flex: 0 0 auto;
    width: 56px; height: 56px;
    object-fit: cover;
    border-radius: 50%;
    border: 1px solid var(--border);
}
.speaker-meta { min-width: 0; }
.speaker-name { font-weight: 500; font-size: 1.05rem; margin: 0; }
.speaker-role { font-size: .9rem; color: #999999; }
.speaker-bio { font-size: .9rem; margin-top: .25rem; white-space: pre-wrap; }

/* Break long unbreakable tokens (pasted URLs/handles) in admin/guest-supplied
   content so they can't force horizontal scroll on a phone — same intent as
   the .q-value rule on the wall. */
.event-head h1, .event-head p, .program-topic, .speaker-name, .speaker-role, .speaker-bio {
    overflow-wrap: anywhere;
}

@media (max-width: 480px) {
    .program-entry { flex-direction: column; gap: .4rem; }
    /* Stack the logo above the title so the heading gets full width on phones. */
    .event-head__main { flex-direction: column; align-items: flex-start; }
    .small, .form-help, .help-text { font-size: .9rem; }
}

/* ----------------------------- Info page ------------------------------- */
.info-list { display: flex; flex-direction: column; gap: 1rem; }
.info-card {
    background: var(--surface);
    border: 1px solid var(--border-light);
    border-radius: var(--radius);
    padding: 1rem 1.2rem;
}
.info-card__label { font-size: .72rem; text-transform: uppercase; letter-spacing: .03em; color: var(--text-muted); margin-bottom: .35rem; }
.info-card__value { font-size: 1.05rem; overflow-wrap: anywhere; }
.info-card__text { font-size: 1rem; white-space: pre-wrap; }
.info-card__link { display: inline-block; margin-top: .5rem; font-weight: 600; }
.info-wifi { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; margin-top: .5rem; }
.info-wifi__caption { flex: 0 0 auto; min-width: 48px; }
.info-wifi__value { font-weight: 600; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; overflow-wrap: anywhere; }
.info-wifi .btn { margin-left: auto; }

/* ------------------------------- Wall ---------------------------------- */
.wall-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1rem; }
.question-card {
    background: var(--surface);
    border: 1px solid var(--border-light);
    border-radius: var(--radius);
    padding: 1.1rem 1.2rem;
    animation: pop-in .35s ease;
}
.question-card .qa { margin-bottom: .7rem; }
.question-card .qa:last-child { margin-bottom: 0; }
.question-card .q-label { font-size: .72rem; text-transform: uppercase; color: var(--text-muted); margin-bottom: .15rem; }
.question-card .q-value { font-size: 1rem; color: var(--text); white-space: pre-wrap; word-break: break-word; }
.question-card .question-meta { display: flex; align-items: center; gap: .6rem; margin-top: .8rem; }
.answered-mark { color: var(--success-dark); font-size: .85rem; font-weight: 700; }
.question-card.answered .q-value { color: var(--text-muted); }
.vote-btn {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface);
    color: var(--text-muted);
    font: inherit;
    font-size: .9rem;
    padding: .3rem .8rem;
    cursor: pointer;
}
.vote-btn:hover { border-color: var(--accent); color: var(--accent-dark); }
.vote-btn.rejected { border-color: var(--danger); color: var(--danger-dark); animation: vote-shake .3s ease; }
@keyframes vote-shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-3px); }
    75% { transform: translateX(3px); }
}
.question-card.voted .vote-btn {
    background: rgba(11,180,225,.12);
    border-color: rgba(11,180,225,.4);
    color: var(--accent-dark);
}

/* --------------------- Projector mode (the wall) ----------------------- */
/* Larger type + high contrast for displaying the wall on a projector. */
.projector { background: #ffffff; }
.projector main { max-width: none; padding: 1.5rem 2.5rem 3rem; }
.projector .page-head { margin-bottom: 1.75rem; }
.projector .page-head h1 { font-size: 3rem; line-height: 1.1; color: #000; }
.projector .wall-grid { grid-template-columns: repeat(auto-fill, minmax(440px, 1fr)); gap: 1.5rem; }
.projector .question-card {
    border: 2px solid #000;
    border-radius: 12px;
    padding: 1.5rem 1.75rem;
}
.projector .question-card .q-label { font-size: 1.15rem; font-weight: 700; color: #000; }
.projector .question-card .q-value { font-size: 1.95rem; line-height: 1.3; font-weight: 600; color: #000; }
.projector .question-card .qa { margin-bottom: 1rem; }
.projector .empty-hint { font-size: 1.7rem; color: #000; text-align: center; padding: 2rem 0; }
/* Projector is display-only: the vote count stays visible (black on white),
   clicks are dead, and the per-browser "voted" tint is suppressed — it is
   meaningless on a shared screen and would break the contrast rule. */
.projector .question-card .vote-btn,
.projector .question-card.voted .vote-btn { pointer-events: none; font-size: 1.3rem; font-weight: 700; color: #000; border: 2px solid #000; background: #fff; }
.projector .answered-mark { font-size: 1.3rem; color: #000; }
/* Answered cards recede via a light-grey fill, NOT opacity — text and border
   stay pure black to keep the across-the-room contrast rule intact. */
.projector .question-card.answered { background: #ececec; }
.projector .question-card.answered .q-value { color: #000; }

@keyframes pop-in {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

.live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--success); display: inline-block; margin-right: .4rem; animation: pulse 1.6s infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

/* ------------------------------ QR page -------------------------------- */
.qr-box { text-align: center; }
.qr-box img { width: 320px; max-width: 100%; height: auto; border: 1px solid var(--border); border-radius: var(--radius); background: #fff; padding: 12px; }
.url-pill { display: inline-block; background: var(--surface-alt); border: 1px solid var(--border); border-radius: 999px; padding: .4rem .9rem; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .85rem; word-break: break-all; }

/* ------------------------------ Auth ----------------------------------- */
.auth-wrap { min-height: 80vh; display: flex; align-items: center; justify-content: center; }
.auth-card { width: 100%; max-width: 380px; }

@media (max-width: 640px) {
    .field-row .grid { grid-template-columns: 1fr; }
    .page-head { flex-direction: column; }
    h1 { font-size: 1.45rem; }
}

@media print {
    .site-header, .btn, .no-print { display: none !important; }
    body { background: #fff; }
}

/* --------------------- Login (paluba.media layout) --------------------- */
.pl-login-page { background: #054770; }
.pl-login-page main { max-width: none; margin: 0; padding: 0; }

.pl-login {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    color: #fff;
    padding: 60px 20px 40px;
}
.pl-login__logo { width: 190px; max-width: 60%; text-align: center; }
.pl-login__logo img { display: block; width: 100%; height: auto; }

.pl-login__card {
    background: #fff;
    border-radius: 16px;
    padding: 40px;
    margin: 30px 0;
    width: 100%;
    max-width: 490px;
    color: #093350;
}
.pl-login__card h1 {
    font-family: 'Roboto Condensed', Roboto, sans-serif;
    font-weight: 700;
    font-size: 34px;
    line-height: 40px;
    text-align: center;
    color: #093350;
    margin: 0 0 30px;
}
.pl-login__error {
    background: rgba(209, 27, 27, .08);
    border: 1px solid rgba(209, 27, 27, .35);
    color: #c4383c;
    border-radius: 8px;
    padding: .7rem .9rem;
    margin-bottom: 20px;
    font-size: 14px;
}

.pl-field { display: flex; flex-direction: column; margin-bottom: 25px; }
.pl-field label { font-weight: 500; font-size: 14px; line-height: 20px; margin-bottom: 5px; color: #093350; }
.pl-login-page .pl-input {
    padding: 14px 20px;
    width: 100%;
    border: 1px solid #D3D3D3;
    border-radius: 10px;
    font-size: 16px;
    line-height: 24px;
    color: #093350;
    background: #fff;
    font-family: inherit;
}
.pl-login-page .pl-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(11, 180, 225, .15); }

.pl-remember { margin-bottom: 25px; }
.pl-remember label {
    display: flex;
    align-items: center;
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    margin: 0;
    color: #093350;
    cursor: pointer;
}
.pl-remember input { margin: 0 8px 0 0; }

.pl-submit { margin-bottom: 0; }
.pl-button {
    width: 100%;
    height: 54px;
    background: var(--accent);
    border: none;
    border-radius: 10px;
    color: #F7F7F5;
    font-weight: 700;
    font-size: 14px;
    line-height: normal;
    text-transform: uppercase;
    letter-spacing: 0.75px;
    cursor: pointer;
    font-family: inherit;
}
.pl-button:hover { background: #1A5177; }

.pl-login__foot { color: rgba(255, 255, 255, .7); font-size: 14px; line-height: 20px; text-align: center; }

@media (max-width: 540px) {
    .pl-login__card { padding: 28px 20px; }
    .pl-login__card h1 { font-size: 28px; line-height: 34px; }
    .pl-login__brand { font-size: 1.5rem; }
}
