/**
 * セキュアアップローダー共通CSS
 */

/* ========================================
   基本設定
======================================== */

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    font-size: 16px;
}

body {
    margin: 0;
}

button,
input,
select,
textarea {
    font: inherit;
}

/* ========================================
   ページ全体
======================================== */

.uploader-body {
    min-width: 320px;
    min-height: 100vh;
    padding: 24px;
    background: #f3f5f7;
    color: #222;
    font-family:
        -apple-system,
        BlinkMacSystemFont,
        "Segoe UI",
        "Yu Gothic",
        "Meiryo",
        sans-serif;
    line-height: 1.6;
}

/* ========================================
   コンテナ
======================================== */

.uploader-container {
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
}

.uploader-container-login {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - 48px);
}

/* ========================================
   カード
======================================== */

.uploader-card {
    width: 100%;
    padding: 32px;
    background: #fff;
    border: 1px solid #dfe3e8;
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.uploader-container-login .uploader-card {
    max-width: 420px;
}

/* ========================================
   見出し・説明
======================================== */

.uploader-title {
    margin: 0 0 24px;
    font-size: 24px;
    line-height: 1.4;
    text-align: center;
}

.uploader-description {
    margin: 0 0 24px;
    color: #555;
    text-align: center;
}

.uploader-notice {
    margin: 20px 0 0;
    color: #666;
    font-size: 13px;
    text-align: center;
}

/* ========================================
   フォーム
======================================== */

.uploader-form {
    width: 100%;
}

.uploader-form-group {
    margin-bottom: 20px;
}

.uploader-label {
    display: block;
    margin-bottom: 8px;
    font-weight: 700;
}

.uploader-input {
    display: block;
    width: 100%;
    min-height: 46px;
    padding: 10px 12px;
    border: 1px solid #b8bec5;
    border-radius: 6px;
    background: #fff;
    color: #222;
    font-size: 16px;
}

.uploader-input:hover {
    border-color: #7e8791;
}

.uploader-input:focus {
    border-color: #246bfd;
    outline: 2px solid #246bfd;
    outline-offset: 1px;
}

/* ========================================
   ボタン
======================================== */

.uploader-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 10px 18px;
    border: 0;
    border-radius: 6px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
    transition:
        background-color 0.2s ease,
        opacity 0.2s ease;
}

.uploader-button:focus-visible {
    outline: 3px solid rgba(36, 107, 253, 0.35);
    outline-offset: 2px;
}

.uploader-button-primary {
    width: 100%;
    background: #246bfd;
    color: #fff;
}

.uploader-button-primary:hover {
    background: #1858d8;
}

.uploader-button-danger {
    background: #c62828;
    color: #fff;
}

.uploader-button-danger:hover {
    background: #a91f1f;
}

.uploader-button-secondary {
    background: #e7ebef;
    color: #222;
}

.uploader-button-secondary:hover {
    background: #d8dde3;
}

/* ========================================
   メッセージ
======================================== */

.uploader-message {
    margin-bottom: 20px;
    padding: 12px 14px;
    border: 1px solid transparent;
    border-radius: 6px;
    line-height: 1.6;
}

.uploader-message-error {
    border-color: #d93025;
    background: #fff4f4;
    color: #b3261e;
}

.uploader-message-success {
    border-color: #198754;
    background: #f1fff7;
    color: #146c43;
}

.uploader-message-warning {
    border-color: #cc8b00;
    background: #fff9e8;
    color: #7a5200;
}

/* ========================================
   スマートフォン対応
======================================== */

@media (max-width: 600px) {
    .uploader-body {
        padding: 16px;
    }

    .uploader-container-login {
        min-height: calc(100vh - 32px);
    }

    .uploader-card {
        padding: 24px 20px;
    }

    .uploader-title {
        font-size: 21px;
    }
}

/* ========================================
   共通補助要素
======================================== */

.uploader-help {
    margin: 8px 0 0;
    color: #666;
    font-size: 13px;
}
/* ========================================
   アップロード画面
======================================== */

.uploader-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 24px;
}

.uploader-page-title {
    margin: 0;
    font-size: 28px;
    line-height: 1.4;
}

.uploader-page-description {
    margin: 6px 0 0;
    color: #666;
}

.uploader-header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.uploader-inline-form {
    display: inline;
    margin: 0;
}

.uploader-section-title {
    margin: 0 0 24px;
    font-size: 21px;
    line-height: 1.4;
}

.uploader-file-input {
    display: block;
    width: 100%;
    min-height: 48px;
    padding: 10px;
    border: 1px solid #b8bec5;
    border-radius: 6px;
    background: #fff;
    color: #222;
    cursor: pointer;
}

.uploader-file-input:hover {
    border-color: #7e8791;
}

.uploader-file-input:focus {
    border-color: #246bfd;
    outline: 2px solid #246bfd;
    outline-offset: 1px;
}

.uploader-file-input::file-selector-button {
    margin-right: 12px;
    padding: 8px 14px;
    border: 0;
    border-radius: 5px;
    background: #e7ebef;
    color: #222;
    font-weight: 700;
    cursor: pointer;
}

.uploader-file-input::file-selector-button:hover {
    background: #d8dde3;
}

.uploader-upload-information {
    margin-bottom: 20px;
    padding: 16px;
    border: 1px solid #dfe3e8;
    border-radius: 6px;
    background: #f8f9fa;
}

.uploader-information-list {
    margin: 0;
}

.uploader-information-list > div {
    display: grid;
    grid-template-columns: 190px minmax(0, 1fr);
    gap: 16px;
    padding: 8px 0;
    border-bottom: 1px solid #e2e6ea;
}

.uploader-information-list > div:first-child {
    padding-top: 0;
}

.uploader-information-list > div:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.uploader-information-list dt {
    font-weight: 700;
}

.uploader-information-list dd {
    margin: 0;
    overflow-wrap: anywhere;
}

.uploader-warning-text {
    margin: 0 0 20px;
    color: #7a5200;
    font-size: 14px;
    font-weight: 700;
}

@media (max-width: 700px) {
    .uploader-header {
        align-items: stretch;
        flex-direction: column;
    }

    .uploader-header-actions {
        width: 100%;
    }

    .uploader-header-actions .uploader-button,
    .uploader-header-actions .uploader-inline-form {
        flex: 1;
    }

    .uploader-header-actions .uploader-inline-form .uploader-button {
        width: 100%;
    }

    .uploader-information-list > div {
        grid-template-columns: 1fr;
        gap: 2px;
    }
}

@media (max-width: 480px) {
    .uploader-header-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .uploader-page-title {
        font-size: 24px;
    }
}
/* ========================================
   ファイル一覧
======================================== */

.uploader-list-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 24px;
}

.uploader-list-heading .uploader-section-title {
    margin-bottom: 0;
}

.uploader-file-count {
    margin: 0;
    padding: 4px 10px;
    border-radius: 999px;
    background: #e7ebef;
    color: #444;
    font-size: 14px;
    font-weight: 700;
}

.uploader-table-wrapper {
    width: 100%;
    overflow-x: auto;
}

.uploader-table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
}

.uploader-table th,
.uploader-table td {
    padding: 14px 12px;
    border-bottom: 1px solid #dfe3e8;
    text-align: left;
    vertical-align: middle;
}

.uploader-table th {
    background: #f5f7f9;
    color: #444;
    font-size: 14px;
    white-space: nowrap;
}

.uploader-table tbody tr:hover {
    background: #fafbfc;
}

.uploader-file-name {
    display: block;
    max-width: 360px;
    overflow-wrap: anywhere;
    font-weight: 700;
}

.uploader-file-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

.uploader-button-small {
    min-height: 36px;
    padding: 6px 12px;
    font-size: 14px;
}

.uploader-button-auto {
    width: auto;
}

.uploader-empty {
    padding: 40px 20px;
    border: 1px dashed #c6ccd2;
    border-radius: 8px;
    background: #fafbfc;
    text-align: center;
}

.uploader-empty p {
    margin: 0 0 20px;
    color: #666;
}

@media (max-width: 760px) {
    .uploader-table,
    .uploader-table thead,
    .uploader-table tbody,
    .uploader-table tr,
    .uploader-table th,
    .uploader-table td {
        display: block;
        width: 100%;
    }

    .uploader-table thead {
        position: absolute;
        width: 1px;
        height: 1px;
        overflow: hidden;
        clip: rect(0 0 0 0);
        white-space: nowrap;
    }

    .uploader-table tr {
        margin-bottom: 16px;
        overflow: hidden;
        border: 1px solid #dfe3e8;
        border-radius: 8px;
        background: #fff;
    }

    .uploader-table td {
        display: grid;
        grid-template-columns: 130px minmax(0, 1fr);
        gap: 12px;
        padding: 12px;
        border-bottom: 1px solid #e7ebef;
    }

    .uploader-table td:last-child {
        border-bottom: 0;
    }

    .uploader-table td::before {
        content: attr(data-label);
        color: #555;
        font-size: 13px;
        font-weight: 700;
    }

    .uploader-file-name {
        max-width: none;
    }

    .uploader-file-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .uploader-file-actions .uploader-button,
    .uploader-file-actions .uploader-inline-form,
    .uploader-file-actions .uploader-inline-form .uploader-button {
        width: 100%;
    }
}

@media (max-width: 480px) {
    .uploader-table td {
        grid-template-columns: 1fr;
        gap: 4px;
    }
}

/* ========================================
   公開フォーム共通要素
======================================== */

.uploader-textarea {
    display: block;
    width: 100%;
    min-height: 130px;
    padding: 10px 12px;
    resize: vertical;
    border: 1px solid #b8bec5;
    border-radius: 6px;
    background: #fff;
    color: #222;
    font-size: 16px;
    line-height: 1.6;
}

.uploader-textarea:hover {
    border-color: #7e8791;
}

.uploader-textarea:focus {
    border-color: #246bfd;
    outline: 2px solid #246bfd;
    outline-offset: 1px;
}

.public-uploader-required-note {
    margin: 0;
    color: #666;
    font-size: 13px;
    text-align: right;
}

.public-uploader-required,
.public-uploader-required-note span {
    color: #c62828;
    font-weight: 700;
}

.public-uploader-optional {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 7px;
    border-radius: 4px;
    background: #e7ebef;
    color: #555;
    font-size: 12px;
    font-weight: 700;
    vertical-align: 1px;
}

.public-uploader-agreement {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 22px;
    font-weight: 700;
    cursor: pointer;
}

.public-uploader-agreement input {
    width: 18px;
    height: 18px;
    margin: 3px 0 0;
    flex-shrink: 0;
}

/* ボット検出用項目。通常の利用者には表示しません。 */
.public-uploader-honeypot {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}
/* ========================================
   告知依頼管理画面
======================================== */

.public-submission-counts {
    display: flex;
    align-items: center;
    gap: 8px;
}

.public-submission-unread-count {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 999px;
    background: #fff1f0;
    color: #b3261e;
    font-size: 14px;
    font-weight: 700;
}

.public-submission-list {
    display: grid;
    gap: 20px;
}

.public-submission-card {
    overflow: hidden;
    border: 1px solid #dfe3e8;
    border-radius: 10px;
    background: #fff;
}

.public-submission-status-unread {
    border-left: 5px solid #d93025;
}

.public-submission-status-confirmed {
    border-left: 5px solid #246bfd;
}

.public-submission-status-completed {
    border-left: 5px solid #198754;
}

.public-submission-summary {
    padding: 18px 20px;
    border-bottom: 1px solid #e7ebef;
    background: #f8f9fa;
}

.public-submission-status-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 8px;
    color: #666;
    font-size: 13px;
}

.public-submission-status {
    display: inline-block;
    padding: 3px 9px;
    border-radius: 999px;
    font-weight: 700;
}

.public-submission-status-label-unread {
    background: #fff1f0;
    color: #b3261e;
}

.public-submission-status-label-confirmed {
    background: #eef4ff;
    color: #1858d8;
}

.public-submission-status-label-completed {
    background: #f1fff7;
    color: #146c43;
}

.public-submission-subject {
    margin: 0 0 6px;
    font-size: 20px;
    line-height: 1.5;
}

.public-submission-sender {
    margin: 0;
    color: #555;
}

.public-submission-detail {
    padding: 20px;
}

.public-submission-data {
    margin: 0 0 24px;
}

.public-submission-data > div {
    display: grid;
    grid-template-columns: 130px minmax(0, 1fr);
    gap: 16px;
    padding: 9px 0;
    border-bottom: 1px solid #e7ebef;
}

.public-submission-data dt {
    font-weight: 700;
}

.public-submission-data dd {
    margin: 0;
    overflow-wrap: anywhere;
}

.public-submission-content,
.public-submission-attachment {
    margin-bottom: 24px;
}

.public-submission-content h4,
.public-submission-attachment h4 {
    margin: 0 0 10px;
    font-size: 16px;
}

.public-submission-content-text {
    padding: 16px;
    border: 1px solid #dfe3e8;
    border-radius: 7px;
    background: #fafbfc;
    line-height: 1.8;
    overflow-wrap: anywhere;
}

.public-submission-attachment p {
    margin: 0 0 12px;
}

.public-submission-controls {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    padding-top: 20px;
    border-top: 1px solid #e7ebef;
}

.public-submission-status-form {
    display: flex;
    align-items: flex-end;
    gap: 10px;
}

.public-submission-status-form label {
    display: grid;
    gap: 6px;
    font-size: 14px;
    font-weight: 700;
}

.uploader-select {
    min-height: 40px;
    padding: 8px 32px 8px 10px;
    border: 1px solid #b8bec5;
    border-radius: 6px;
    background: #fff;
    color: #222;
}

.uploader-select:focus {
    border-color: #246bfd;
    outline: 2px solid #246bfd;
    outline-offset: 1px;
}

.public-submission-delete-form {
    margin: 0;
}

@media (max-width: 700px) {
    .public-submission-status-row {
        align-items: flex-start;
        flex-direction: column;
        gap: 6px;
    }

    .public-submission-data > div {
        grid-template-columns: 1fr;
        gap: 3px;
    }

    .public-submission-controls {
        align-items: stretch;
        flex-direction: column;
    }

    .public-submission-status-form {
        align-items: stretch;
        flex-direction: column;
    }

    .public-submission-status-form
    .uploader-button,
    .public-submission-delete-form,
    .public-submission-delete-form
    .uploader-button {
        width: 100%;
    }
}
/* ========================================
   京都大学外科交流センター
   公開告知依頼フォーム
======================================== */

.public-uploader-body {
    --center-primary: #153f5f;
    --center-primary-dark: #0c2d47;
    --center-primary-light: #eaf2f7;
    --center-accent: #a67c35;
    --center-border: #d7e0e6;
    --center-text: #263640;
    --center-muted: #667782;
    --center-background: #f4f7f9;

    padding: 0 20px 48px;
    background:
        linear-gradient(
            180deg,
            var(--center-primary) 0,
            var(--center-primary) 220px,
            var(--center-background) 220px,
            var(--center-background) 100%
        );
    color: var(--center-text);
}

.public-uploader-container {
    max-width: 820px;
}

.center-public-header {
    padding: 34px 0 30px;
    color: #fff;
    text-align: center;
}

.center-public-brand {
    margin-bottom: 32px;
}

.center-public-brand-en {
    margin: 0 0 5px;
    font-family:
        Georgia,
        "Times New Roman",
        serif;
    font-size: 11px;
    letter-spacing: 0.2em;
    opacity: 0.82;
}

.center-public-brand-name {
    margin: 0;
    font-family:
        "Yu Mincho",
        "Hiragino Mincho ProN",
        serif;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.center-public-title-area {
    position: relative;
}

.center-public-title-label {
    display: inline-block;
    margin-bottom: 8px;
    color: #d9e7ef;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.18em;
}

.center-public-title {
    margin: 0;
    font-family:
        "Yu Mincho",
        "Hiragino Mincho ProN",
        serif;
    font-size: 34px;
    font-weight: 700;
    letter-spacing: 0.08em;
    line-height: 1.4;
}

.center-public-title::after {
    display: block;
    width: 48px;
    height: 2px;
    margin: 16px auto;
    background: var(--center-accent);
    content: "";
}

.center-public-lead {
    display: inline-block;
    max-width: 680px;
    margin: 0 auto;
    padding: 10px 18px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 4px;
    background: rgba(12, 45, 71, 0.35);
    color: #ffffff;
    font-size: 15px;
    line-height: 1.8;
    text-align: center;
}

.center-public-guidance {
    margin: 0 0 24px;
    padding: 24px 28px;
    border: 1px solid var(--center-border);
    border-left: 4px solid var(--center-accent);
    border-radius: 4px;
    background: #fff;
    box-shadow: 0 4px 14px rgba(13, 48, 71, 0.05);
}

.center-public-guidance-title {
    margin: 0 0 12px;
    color: var(--center-primary);
    font-family:
        "Yu Mincho",
        "Hiragino Mincho ProN",
        serif;
    font-size: 19px;
}

.center-public-guidance p {
    margin: 0;
    color: #465965;
    font-size: 14px;
    line-height: 1.9;
}

.center-public-guidance p + p {
    margin-top: 8px;
}

.center-public-form-card {
    padding: 38px 42px;
    border-color: var(--center-border);
    border-radius: 6px;
    box-shadow: 0 10px 32px rgba(13, 48, 71, 0.08);
}

.center-public-form-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 30px;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--center-border);
}

.center-public-form-heading
.uploader-section-title {
    margin: 0;
    color: var(--center-primary);
    font-family:
        "Yu Mincho",
        "Hiragino Mincho ProN",
        serif;
    font-size: 22px;
}

.center-public-form-number {
    margin: 0 0 5px;
    color: var(--center-accent);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.16em;
}

.center-public-form-heading
.public-uploader-required-note {
    margin: 0;
    flex-shrink: 0;
    color: var(--center-muted);
}

.center-public-label {
    color: #263b48;
    font-size: 15px;
}

.center-public-label-note {
    color: var(--center-muted);
    font-size: 13px;
    font-weight: 400;
}

.public-uploader-required {
    color: #a62929;
}

.public-uploader-optional {
    background: #e8edf0;
    color: #53656f;
}

.public-uploader-body .uploader-form-group {
    margin-bottom: 27px;
}

.public-uploader-body .uploader-input,
.public-uploader-body .uploader-textarea,
.public-uploader-body .uploader-file-input {
    border-color: #b7c4cc;
    border-radius: 4px;
    background: #fcfdfd;
}

.public-uploader-body .uploader-input {
    min-height: 49px;
}

.public-uploader-body .uploader-input:focus,
.public-uploader-body .uploader-textarea:focus,
.public-uploader-body .uploader-file-input:focus {
    border-color: var(--center-primary);
    outline-color: rgba(21, 63, 95, 0.25);
}

.public-uploader-body
.uploader-input::placeholder,
.public-uploader-body
.uploader-textarea::placeholder {
    color: #9aa6ad;
}

.public-uploader-body .uploader-help {
    color: var(--center-muted);
}

.center-public-file-area {
    padding: 16px;
    border: 1px dashed #acbbc4;
    border-radius: 4px;
    background: #f8fafb;
}

.center-public-file-area
.uploader-file-input {
    background: #fff;
}

.center-public-file-limit {
    margin: 6px 0 0;
    color: var(--center-primary);
    font-size: 13px;
    font-weight: 700;
}

.center-public-confirmation {
    margin: 32px 0 23px;
    padding: 22px 24px;
    border: 1px solid #d8d1bd;
    border-radius: 4px;
    background: #fcfaf5;
}

.center-public-confirmation h3 {
    margin: 0 0 12px;
    color: #624d25;
    font-size: 15px;
}

.center-public-confirmation ul {
    margin: 0;
    padding-left: 21px;
    color: #564f40;
    font-size: 13px;
    line-height: 1.8;
}

.center-public-confirmation li + li {
    margin-top: 5px;
}

.center-public-agreement {
    margin-bottom: 28px;
    padding: 15px 17px;
    border: 1px solid var(--center-border);
    border-radius: 4px;
    background: #f8fafb;
    color: #344a57;
    font-size: 14px;
}

.center-public-agreement input {
    accent-color: var(--center-primary);
}

.center-public-submit-area {
    text-align: center;
}

.center-public-submit-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: min(100%, 420px);
    min-height: 56px;
    padding: 13px 28px;
    border: 1px solid var(--center-primary);
    border-radius: 3px;
    background: var(--center-primary);
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.05em;
    cursor: pointer;
    transition:
        background-color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
}

.center-public-submit-button::after {
    margin-left: 14px;
    content: "›";
    font-size: 24px;
    font-weight: 400;
    line-height: 1;
}

.center-public-submit-button:hover {
    border-color: var(--center-primary-dark);
    background: var(--center-primary-dark);
    transform: translateY(-1px);
}

.center-public-submit-button:focus-visible {
    outline: 3px solid rgba(21, 63, 95, 0.3);
    outline-offset: 3px;
}

.center-public-submit-area p {
    margin: 12px 0 0;
    color: var(--center-muted);
    font-size: 12px;
}

.center-public-footer {
    padding: 28px 0 0;
    color: #71818a;
    font-size: 11px;
    letter-spacing: 0.04em;
    text-align: center;
}

.center-public-footer p {
    margin: 0;
}

.center-public-footer-name {
    margin-bottom: 3px !important;
    color: #4f626d;
    font-family:
        "Yu Mincho",
        "Hiragino Mincho ProN",
        serif;
    font-size: 14px;
    font-weight: 700;
}

.center-public-result {
    margin-top: 20px;
    padding: 52px 40px;
    border: 1px solid var(--center-border);
    border-radius: 6px;
    background: #fff;
    box-shadow: 0 10px 32px rgba(13, 48, 71, 0.08);
    text-align: center;
}

.center-public-result-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    margin: 0 auto 20px;
    border: 2px solid #3b7857;
    border-radius: 50%;
    color: #3b7857;
    font-size: 27px;
    font-weight: 700;
}

.center-public-result h2 {
    margin: 0 0 18px;
    color: var(--center-primary);
    font-family:
        "Yu Mincho",
        "Hiragino Mincho ProN",
        serif;
    font-size: 25px;
}

.center-public-result p {
    margin: 0;
    line-height: 1.9;
}

.center-public-result-note {
    max-width: 560px;
    margin: 20px auto 28px !important;
    padding: 14px;
    border-radius: 4px;
    background: #f4f7f9;
    color: var(--center-muted);
    font-size: 13px;
}

.center-public-secondary-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 45px;
    padding: 9px 22px;
    border: 1px solid var(--center-primary);
    border-radius: 3px;
    background: #fff;
    color: var(--center-primary);
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
}

.center-public-secondary-button:hover {
    background: var(--center-primary-light);
}

@media (max-width: 700px) {
    .public-uploader-body {
        padding-right: 14px;
        padding-bottom: 30px;
        padding-left: 14px;
        background:
            linear-gradient(
                180deg,
                var(--center-primary) 0,
                var(--center-primary) 235px,
                var(--center-background) 235px,
                var(--center-background) 100%
            );
    }

    .center-public-header {
        padding-top: 25px;
    }

    .center-public-brand {
        margin-bottom: 26px;
    }

    .center-public-brand-name {
        font-size: 19px;
    }

    .center-public-title {
        font-size: 28px;
    }

    .center-public-lead {
        font-size: 14px;
    }

    .center-public-guidance {
        padding: 20px;
    }

    .center-public-form-card {
        padding: 27px 20px;
    }

    .center-public-form-heading {
        align-items: flex-start;
        flex-direction: column;
        gap: 8px;
    }

    .center-public-form-heading
    .public-uploader-required-note {
        text-align: left;
    }

    .center-public-confirmation {
        padding: 19px;
    }

    .center-public-result {
        padding: 40px 22px;
    }
}
