:root {
            --so-primary: #00687a;
            --so-accent: #48b4cd;
            --so-ink: #1d2a31;
            --so-muted: #5c696e;
        }
body {
    background: #ffffff;
}

.container {
            max-width: 80rem;
            margin: 0 auto;
        }
        .section {
            padding: 5.5rem 1.5rem 0;
        }
        .label {
            font-size: 0.72rem;
            font-weight: 700;
            letter-spacing: 0.22em;
            text-transform: uppercase;
            color: var(--so-primary);
        }
        .form-card {
            padding: 2rem;
            border-radius: 1.6rem;
            background: #ffffff;
            box-shadow: 0 24px 56px rgba(17, 39, 44, 0.08);
        }
        .form-card {
            background: linear-gradient(180deg, #eef8fa 0%, #ffffff 100%);
            box-shadow:
                inset 0 0 0 1px rgba(0, 104, 122, 0.08),
                0 24px 56px rgba(17, 39, 44, 0.08);
        }
.form-lead {
            max-width: 48rem;
        }
.form-status {
            margin-top: 1.5rem;
            padding: 1rem 1.1rem;
            border-radius: 1rem;
            font-size: 0.95rem;
            line-height: 1.8;
        }
        .form-status-title {
            font-size: 1rem;
            font-weight: 700;
            letter-spacing: 0.04em;
        }
        .form-status-copy {
            margin-top: 0.35rem;
        }
        .form-status.is-success {
            background: #ecfbf4;
            color: #0f5d36;
            box-shadow: inset 0 0 0 1px rgba(15, 93, 54, 0.12);
        }
        .form-status.is-error {
            background: #fff3f2;
            color: #8a2c27;
            box-shadow: inset 0 0 0 1px rgba(138, 44, 39, 0.12);
        }
        .form-status-list {
            margin-top: 0.65rem;
            padding-left: 1.15rem;
            list-style: disc;
        }
        .recruit-conditions-entry {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            gap: 0.8rem 1rem;
            margin-top: 1.6rem;
        }
        .recruit-conditions-entry p {
            color: #63747a;
            font-size: 0.9rem;
            line-height: 1.7;
        }
        .recruit-conditions-open {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 0.45rem;
            min-height: 2.8rem;
            padding: 0.75rem 1.15rem;
            border: none;
            border-radius: 9999px;
            background: linear-gradient(135deg, #00687a, #48b4cd);
            color: #effcff;
            font-size: 0.86rem;
            font-weight: 800;
            letter-spacing: 0.06em;
            box-shadow: 0 14px 28px rgba(0, 104, 122, 0.18);
        }
        .recruit-conditions-open .material-symbols-outlined {
            font-size: 1.05rem;
        }
        .form-hidden {
            position: absolute;
            left: -9999px;
            width: 1px;
            height: 1px;
            overflow: hidden;
        }
        .form-anchor {
            scroll-margin-top: 8rem;
        }
        .recruit-form {
            display: grid;
            gap: 1rem;
        }
        .recruit-form-grid {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 1rem;
        }
.form-field {
            display: grid;
            gap: 0.5rem;
        }
        .form-field label,
        .form-check label {
            font-size: 0.84rem;
            font-weight: 700;
            color: #1f343a;
        }
        .form-label {
            display: inline-flex;
            align-items: center;
            gap: 0.55rem;
            flex-wrap: wrap;
        }
        .required-badge {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-height: 1.35rem;
            padding: 0 0.45rem;
            border-radius: 9999px;
            background: #fff1ef;
            color: #b33a33;
            font-size: 0.68rem;
            font-weight: 700;
            letter-spacing: 0.08em;
        }
        .form-field input,
        .form-field select,
        .form-field textarea {
            width: 100%;
            border: 1px solid rgba(0, 104, 122, 0.12);
            border-radius: 1rem;
            background: #fbfeff;
            padding: 0.95rem 1rem;
            font-size: 0.98rem;
            color: #1d2a31;
            outline: none;
            transition: border-color 0.2s ease, box-shadow 0.2s ease;
        }
        .form-field input:focus,
        .form-field select:focus,
        .form-field textarea:focus {
            border-color: rgba(0, 104, 122, 0.36);
            box-shadow: 0 0 0 3px rgba(72, 180, 205, 0.12);
        }
        .form-field textarea {
            min-height: 10rem;
            resize: vertical;
        }
        .form-field input[type="file"] {
            padding: 0.8rem 0.95rem;
            background: #f8fcfd;
            line-height: 1.5;
        }
        .form-field input[type="file"]::file-selector-button {
            margin-right: 0.9rem;
            padding: 0.65rem 0.95rem;
            border: none;
            border-radius: 9999px;
            background: rgba(0, 104, 122, 0.1);
            color: var(--so-primary);
            font-size: 0.82rem;
            font-weight: 700;
            cursor: pointer;
        }
        .form-field-note {
            margin-top: -0.05rem;
            font-size: 0.8rem;
            line-height: 1.7;
            color: #6a787d;
        }
        .form-field.is-full {
            grid-column: 1 / -1;
        }
        .form-field.is-invalid input,
        .form-field.is-invalid select,
        .form-field.is-invalid textarea {
            border-color: rgba(179, 58, 51, 0.75);
            box-shadow: 0 0 0 3px rgba(179, 58, 51, 0.08);
            background: #fffaf9;
        }
        .form-check {
            display: grid;
            grid-template-columns: auto minmax(0, 1fr);
            gap: 0.8rem;
            width: 100%;
        }
        .form-check input {
            margin-top: 0.18rem;
        }
        .form-check label {
            display: block;
            font-size: 0.92rem;
            line-height: 1.8;
            color: #4a5a60;
            word-break: normal;
        }
        .form-check.is-invalid {
            padding: 0.8rem 0.9rem;
            border-radius: 1rem;
            background: #fff7f6;
            box-shadow: inset 0 0 0 1px rgba(179, 58, 51, 0.18);
        }
        .field-error {
            display: block;
            min-height: 1.45rem;
            margin-top: 0.1rem;
            font-size: 0.8rem;
            line-height: 1.7;
            color: #b33a33;
            visibility: hidden;
        }
        .field-error.is-visible {
            visibility: visible;
        }
        .form-submit {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 0.6rem;
            min-height: 3.4rem;
            padding: 0.95rem 1.5rem;
            border: none;
            border-radius: 9999px;
            background: linear-gradient(135deg, #00687a, #48b4cd);
            color: #effcff;
            font-size: 0.92rem;
            font-weight: 700;
            letter-spacing: 0.12em;
        }
        .form-submit.is-loading {
            opacity: 0.7;
            pointer-events: none;
        }
        .form-note {
            font-size: 0.82rem;
            line-height: 1.8;
            color: #637278;
        }
        .submit-mask {
            position: fixed;
            inset: 0;
            display: none;
            align-items: center;
            justify-content: center;
            padding: 1.5rem;
            background: rgba(10, 21, 26, 0.46);
            backdrop-filter: blur(6px);
            -webkit-backdrop-filter: blur(6px);
            z-index: 120;
        }
        .submit-mask.is-visible {
            display: flex;
        }
        .submit-mask-panel {
            min-width: min(100%, 22rem);
            padding: 1.4rem 1.5rem;
            border-radius: 1.3rem;
            background: rgba(255, 255, 255, 0.96);
            box-shadow: 0 24px 56px rgba(16, 39, 42, 0.18);
            text-align: center;
        }
        .submit-mask-title {
            font-size: 1rem;
            font-weight: 700;
            color: #12323a;
            letter-spacing: 0.04em;
        }
        .submit-mask-copy {
            margin-top: 0.45rem;
            font-size: 0.9rem;
            line-height: 1.8;
            color: #5a6a70;
        }
        .confirm-modal {
            position: fixed;
            inset: 0;
            display: none;
            align-items: center;
            justify-content: center;
            padding: 1.5rem;
            background: rgba(10, 21, 26, 0.34);
            backdrop-filter: blur(6px);
            -webkit-backdrop-filter: blur(6px);
            z-index: 119;
        }
        .confirm-modal.is-visible {
            display: flex;
        }
        .confirm-modal-panel {
            width: min(100%, 28rem);
            padding: 1.55rem 1.55rem 1.4rem;
            border-radius: 1.4rem;
            background: rgba(255, 255, 255, 0.98);
            box-shadow: 0 28px 64px rgba(16, 39, 42, 0.18);
        }
        .confirm-modal-kicker {
            font-size: 0.72rem;
            font-weight: 700;
            letter-spacing: 0.18em;
            color: #00687a;
        }
        .confirm-modal-title {
            margin-top: 0.55rem;
            font-size: 1.3rem;
            font-weight: 800;
            letter-spacing: -0.03em;
            color: #163038;
        }
        .confirm-modal-copy {
            margin-top: 0.7rem;
            font-size: 0.94rem;
            line-height: 1.85;
            color: #58686d;
        }
        .confirm-modal-actions {
            display: flex;
            justify-content: flex-end;
            gap: 0.8rem;
            margin-top: 1.25rem;
        }
        .confirm-modal-button {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-height: 2.9rem;
            padding: 0.8rem 1.2rem;
            border-radius: 9999px;
            font-size: 0.86rem;
            font-weight: 700;
            letter-spacing: 0.08em;
        }
        .confirm-modal-button.is-secondary {
            border: 1px solid rgba(0, 104, 122, 0.14);
            background: #ffffff;
            color: #4e5e64;
        }
        .confirm-modal-button.is-primary {
            border: none;
            background: linear-gradient(135deg, #00687a, #48b4cd);
            color: #effcff;
        }
        .recruit-conditions-modal {
            position: fixed;
            inset: 0;
            display: none;
            place-items: center;
            padding: 1rem 1.5rem 1.5rem;
            background: rgba(10, 21, 26, 0.42);
            backdrop-filter: blur(7px);
            -webkit-backdrop-filter: blur(7px);
            z-index: 120;
        }
        .recruit-conditions-modal.is-visible {
            display: grid;
        }
        .recruit-conditions-panel {
            position: relative;
            width: min(100%, 46rem);
            max-height: calc(100svh - 2.5rem);
            overflow: visible;
            padding: clamp(1.15rem, 2.4vw, 1.7rem);
            border-radius: 1.35rem;
            background:
                radial-gradient(circle at top right, rgba(124, 227, 253, 0.22), transparent 28%),
                linear-gradient(180deg, #ffffff, #f8fdff);
            box-shadow: 0 30px 76px rgba(16, 39, 42, 0.24);
        }
        .recruit-conditions-close {
            position: absolute;
            top: 1rem;
            right: 1rem;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 2.4rem;
            height: 2.4rem;
            border: 1px solid rgba(0, 104, 122, 0.12);
            border-radius: 9999px;
            background: rgba(255, 255, 255, 0.88);
            color: #26454d;
        }
        .recruit-conditions-close .material-symbols-outlined {
            font-size: 1.1rem;
        }
        .recruit-conditions-kicker {
            color: #00687a;
            font-size: 0.72rem;
            font-weight: 800;
            letter-spacing: 0.18em;
            text-transform: uppercase;
        }
        .recruit-conditions-panel h3 {
            margin-top: 0.42rem;
            color: #163038;
            font-size: clamp(1.45rem, 2.6vw, 2rem);
            font-weight: 900;
            letter-spacing: -0.04em;
        }
        .recruit-conditions-lead {
            max-width: 37rem;
            margin-top: 0.5rem;
            color: #5a6a70;
            font-size: 0.9rem;
            line-height: 1.65;
        }
        .recruit-conditions-list {
            display: grid;
            gap: 0;
            margin-top: 1rem;
            border-top: 1px solid rgba(0, 104, 122, 0.12);
        }
        .recruit-conditions-list div {
            display: grid;
            grid-template-columns: minmax(8rem, 0.32fr) minmax(0, 1fr);
            gap: 1rem;
            padding: 0.68rem 0;
            border-bottom: 1px solid rgba(0, 104, 122, 0.12);
        }
        .recruit-conditions-list dt {
            color: #00687a;
            font-size: 0.86rem;
            font-weight: 900;
            letter-spacing: 0.08em;
        }
        .recruit-conditions-list dd {
            color: #30474e;
            font-size: 0.9rem;
            line-height: 1.55;
        }
        .recruit-conditions-actions {
            display: flex;
            flex-wrap: wrap;
            justify-content: flex-end;
            gap: 0.8rem;
            margin-top: 1rem;
        }
        .recruit-conditions-actions button,
        .recruit-conditions-actions a {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-height: 2.8rem;
            padding: 0.75rem 1.2rem;
            border-radius: 9999px;
            font-size: 0.86rem;
            font-weight: 800;
            letter-spacing: 0.06em;
        }
        .recruit-conditions-actions button {
            border: 1px solid rgba(0, 104, 122, 0.14);
            background: #ffffff;
            color: #4e5e64;
        }
        .recruit-conditions-actions a {
            background: #00687a;
            color: #effcff;
        }
        .success-modal {
            position: fixed;
            inset: 0;
            display: none;
            align-items: center;
            justify-content: center;
            padding: 1.5rem;
            background: rgba(10, 21, 26, 0.38);
            backdrop-filter: blur(7px);
            -webkit-backdrop-filter: blur(7px);
            z-index: 121;
        }
        .success-modal.is-visible {
            display: flex;
        }
        .success-modal-panel {
            width: min(100%, 30rem);
            padding: 1.7rem 1.7rem 1.45rem;
            border-radius: 1.5rem;
            background:
                radial-gradient(circle at top right, rgba(124, 227, 253, 0.22), transparent 22%),
                linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 253, 255, 0.98));
            box-shadow: 0 30px 70px rgba(16, 39, 42, 0.22);
        }
        .success-modal-mark {
            display: inline-flex;
            align-items: center;
            gap: 0.55rem;
            font-size: 0.76rem;
            font-weight: 800;
            letter-spacing: 0.18em;
            color: #0f6b48;
        }
        .success-modal-mark::before {
            content: "";
            width: 0.72rem;
            height: 0.72rem;
            border-radius: 9999px;
            background: linear-gradient(135deg, #1ca66d, #4fd8a0);
            box-shadow: 0 0 0 0.32rem rgba(28, 166, 109, 0.12);
        }
        .success-modal-title {
            margin-top: 0.7rem;
            font-size: 1.45rem;
            font-weight: 800;
            letter-spacing: -0.035em;
            color: #163038;
        }
        .success-modal-copy {
            margin-top: 0.8rem;
            font-size: 0.96rem;
            line-height: 1.9;
            color: #55656b;
        }
        .success-modal-actions {
            display: flex;
            justify-content: flex-end;
            margin-top: 1.35rem;
        }
        .success-modal-button {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-height: 2.95rem;
            padding: 0.82rem 1.3rem;
            border: none;
            border-radius: 9999px;
            background: linear-gradient(135deg, #0e7d58, #4bc49a);
            color: #effcff;
            font-size: 0.86rem;
            font-weight: 700;
            letter-spacing: 0.08em;
        }
        .footer {
            border-top: 1px solid rgba(0, 104, 122, 0.08);
        }
        @media (max-width: 1023px) {
            .recruit-form-grid {
                grid-template-columns: 1fr;
            }
        }
        @media (max-width: 640px) {
            .recruit-conditions-modal {
                padding: 0.75rem;
            }
            .recruit-conditions-panel {
                max-height: calc(100svh - 1.5rem);
                padding: 1rem;
                border-radius: 1rem;
            }
            .recruit-conditions-close {
                top: 0.75rem;
                right: 0.75rem;
            }
            .recruit-conditions-list div {
                grid-template-columns: 1fr;
                gap: 0.2rem;
                padding: 0.5rem 0;
            }
            .recruit-conditions-list dt,
            .recruit-conditions-list dd {
                font-size: 0.82rem;
                line-height: 1.45;
            }
            .recruit-conditions-lead {
                font-size: 0.82rem;
                line-height: 1.5;
            }
            .recruit-conditions-actions {
                justify-content: stretch;
                margin-top: 0.75rem;
            }
            .recruit-conditions-actions button,
            .recruit-conditions-actions a {
                width: 100%;
            }
        }


