/**
 * Talent Portal Styles
 *
 * @package Angry_Elf
 */

/* -----------------------------------------------------------------------
   Alerts
   ----------------------------------------------------------------------- */

.talent-alert {
	padding: 1rem 1.25rem;
	border-radius: 6px;
	margin-bottom: 1.5rem;
	font-size: 0.95rem;
	line-height: 1.5;
}

.talent-alert--success {
	background: rgba(34, 197, 94, 0.12);
	border: 1px solid rgba(34, 197, 94, 0.4);
	color: #22c55e;
}

.talent-alert--error {
	background: rgba(239, 68, 68, 0.12);
	border: 1px solid rgba(239, 68, 68, 0.4);
	color: #f87171;
}

.talent-alert__link {
	margin-left: 0.5rem;
	text-decoration: underline;
	color: inherit;
}

/* -----------------------------------------------------------------------
   Tab toggle
   ----------------------------------------------------------------------- */

.talent-tabs {
	display: flex;
	gap: 0;
	border-bottom: 2px solid rgba(255, 255, 255, 0.08);
	margin-bottom: 2rem;
}

.talent-tab {
	background: transparent;
	border: none;
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.95rem;
	font-family: inherit;
	padding: 0.75rem 1.5rem;
	cursor: pointer;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: color 0.2s, border-color 0.2s;
}

.talent-tab:hover {
	color: rgba(255, 255, 255, 0.8);
}

.talent-tab--active {
	color: var(--color-accent, #E07820);
	border-bottom-color: var(--color-accent, #E07820);
}

/* -----------------------------------------------------------------------
   Form wrapper
   ----------------------------------------------------------------------- */

.talent-form-wrap {
	max-width: 860px;
}

.talent-form-wrap--narrow {
	max-width: 440px;
}

/* -----------------------------------------------------------------------
   Two-column form grid
   ----------------------------------------------------------------------- */

.talent-form-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.25rem;
}

@media (max-width: 640px) {
	.talent-form-grid {
		grid-template-columns: 1fr;
	}
}

.talent-field {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
}

.talent-field--full {
	grid-column: 1 / -1;
}

.talent-field label {
	font-size: 0.875rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.8);
}

.talent-field .required {
	color: var(--color-orange, #ff9b1b);
}

.talent-field__hint {
	font-size: 0.8rem;
	color: rgba(255, 255, 255, 0.4);
	margin-top: 0.125rem;
}

.talent-form input[type="text"],
.talent-form input[type="email"],
.talent-form input[type="tel"],
.talent-form input[type="url"],
.talent-form input[type="password"],
.talent-form select,
.talent-form textarea {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 6px;
	color: #fff;
	font-family: inherit;
	font-size: 0.95rem;
	padding: 0.6rem 0.875rem;
	transition: border-color 0.2s, background 0.2s;
	width: 100%;
}

.talent-form input:focus,
.talent-form select:focus,
.talent-form textarea:focus {
	border-color: var(--color-accent, #E07820);
	background: rgba(255, 255, 255, 0.09);
	outline: none;
}

.talent-form input.is-invalid,
.talent-form select.is-invalid,
.talent-form textarea.is-invalid {
	border-color: #f87171;
}

.talent-form select option {
	background: #1a1f3c;
	color: #fff;
}

.talent-form textarea {
	resize: vertical;
	min-height: 100px;
}

/* -----------------------------------------------------------------------
   Role radio buttons
   ----------------------------------------------------------------------- */

.talent-role-fieldset {
	border: none;
	padding: 0;
	margin: 0;
}

.talent-role-fieldset legend {
	font-size: 0.875rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.8);
	margin-bottom: 0.75rem;
}

.talent-role-options {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.talent-role-option {
	cursor: pointer;
}

.talent-role-option input[type="radio"] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.talent-role-option__label {
	display: inline-block;
	padding: 0.5rem 1.25rem;
	border: 2px solid rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	font-size: 0.9rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.6);
	transition: border-color 0.2s, color 0.2s, background 0.2s;
}

.talent-role-option input[type="radio"]:checked + .talent-role-option__label {
	border-color: var(--color-accent, #E07820);
	background: rgba(224, 120, 32, 0.18);
	color: #fff;
}

.talent-role-option:hover .talent-role-option__label {
	border-color: rgba(255, 255, 255, 0.4);
	color: #fff;
}

/* -----------------------------------------------------------------------
   Conditional field panels
   ----------------------------------------------------------------------- */

.actor-fields,
.crew-fields {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding-top: 1.25rem;
	margin-top: 0.25rem;
}

/* -----------------------------------------------------------------------
   File drop zones
   ----------------------------------------------------------------------- */

.talent-dropzone {
	position: relative;
	border: 2px dashed rgba(255, 255, 255, 0.2);
	border-radius: 8px;
	padding: 2rem 1rem;
	text-align: center;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s;
}

.talent-dropzone:hover,
.talent-dropzone.is-over {
	border-color: var(--color-accent, #E07820);
	background: rgba(224, 120, 32, 0.06);
}

.talent-dropzone__input {
	position: absolute;
	inset: 0;
	width: 100% !important;
	height: 100%;
	opacity: 0;
	cursor: pointer;
}

.talent-dropzone__prompt .dashicons {
	font-size: 2rem;
	width: 2rem;
	height: 2rem;
	color: rgba(255, 255, 255, 0.35);
	display: block;
	margin: 0 auto 0.5rem;
}

.talent-dropzone__prompt p {
	margin: 0;
	color: rgba(255, 255, 255, 0.55);
	font-size: 0.9rem;
}

.talent-dropzone__hint {
	font-size: 0.78rem !important;
	color: rgba(255, 255, 255, 0.3) !important;
	margin-top: 0.25rem !important;
}

/* Headshot preview */
.talent-dropzone__preview {
	margin-bottom: 0.75rem;
}

.talent-dropzone__preview img {
	width: 100px;
	height: 100px;
	object-fit: cover;
	border-radius: 50%;
	border: 3px solid var(--color-accent, #E07820);
	display: block;
	margin: 0 auto;
}

/* -----------------------------------------------------------------------
   Form actions
   ----------------------------------------------------------------------- */

.talent-form-actions {
	display: flex;
	gap: 1rem;
	align-items: center;
	margin-top: 2rem;
	flex-wrap: wrap;
}

.talent-form-legal {
	margin-top: 1rem;
	font-size: 0.8rem;
	color: rgba(255, 255, 255, 0.35);
}

.talent-form-forgot {
	margin-top: 0.75rem;
	font-size: 0.875rem;
}

.talent-form-forgot a {
	color: rgba(255, 255, 255, 0.5);
	text-decoration: underline;
}

.talent-form-forgot a:hover {
	color: rgba(255, 255, 255, 0.8);
}

/* -----------------------------------------------------------------------
   WP Login form override (State 1 login tab)
   ----------------------------------------------------------------------- */

#loginform {
	background: transparent !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
}

#loginform label {
	font-size: 0.875rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.8);
	display: block;
	margin-bottom: 0.375rem;
}

#loginform input[type="text"],
#loginform input[type="password"] {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 6px;
	color: #fff;
	font-family: inherit;
	font-size: 0.95rem;
	padding: 0.6rem 0.875rem;
	width: 100%;
	box-sizing: border-box;
	margin-bottom: 1rem;
}

#loginform input[type="text"]:focus,
#loginform input[type="password"]:focus {
	border-color: var(--color-accent, #E07820);
	outline: none;
}

#loginform input[type="checkbox"] {
	margin-right: 0.375rem;
}

#loginform .forgetmenot label {
	font-weight: 400;
	display: inline;
}

#loginform input[type="submit"] {
	background: var(--color-accent, #E07820);
	color: #fff;
	border: none;
	border-radius: 6px;
	font-family: inherit;
	font-size: 1rem;
	font-weight: 600;
	padding: 0.7rem 2rem;
	cursor: pointer;
	transition: background 0.2s;
	width: 100%;
	margin-top: 0.5rem;
}

#loginform input[type="submit"]:hover {
	background: #2a3ed6;
}

/* -----------------------------------------------------------------------
   Profile card (State 2 view mode)
   ----------------------------------------------------------------------- */

.talent-profile-card {
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: 2.5rem;
	align-items: start;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 12px;
	padding: 2rem;
}

@media (max-width: 640px) {
	.talent-profile-card {
		grid-template-columns: 1fr;
		text-align: center;
	}
}

.talent-headshot-img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	border-radius: 10px;
	display: block;
}

.talent-headshot-placeholder {
	width: 100%;
	aspect-ratio: 1;
	background: rgba(255, 255, 255, 0.06);
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.talent-headshot-placeholder .dashicons {
	font-size: 4rem;
	width: 4rem;
	height: 4rem;
	color: rgba(255, 255, 255, 0.2);
}

.talent-profile-card__info h2 {
	margin: 0 0 0.5rem;
	font-size: 1.5rem;
}

/* Role badge */
.talent-role-badge {
	display: inline-block;
	background: rgba(224, 120, 32, 0.15);
	border: 1px solid rgba(224, 120, 32, 0.45);
	color: var(--color-accent, #E07820);
	border-radius: 999px;
	padding: 0.2rem 0.75rem;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.talent-role-badge--large {
	font-size: 0.875rem;
	padding: 0.3rem 1rem;
}

/* Detail list */
.talent-detail-list {
	margin: 1.25rem 0;
	display: grid;
	grid-template-columns: 130px 1fr;
	gap: 0.5rem 1rem;
	align-items: start;
}

@media (max-width: 640px) {
	.talent-detail-list {
		grid-template-columns: 1fr;
		text-align: left;
	}
}

.talent-detail-list dt {
	font-size: 0.8rem;
	font-weight: 700;
	color: rgba(255, 255, 255, 0.45);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding-top: 2px;
}

.talent-detail-list dd {
	font-size: 0.95rem;
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
}

/* Links section */
.talent-links {
	display: flex;
	gap: 0.625rem;
	flex-wrap: wrap;
	margin-bottom: 1.5rem;
}

/* Profile actions */
.talent-profile-actions {
	display: flex;
	gap: 0.75rem;
	align-items: center;
	flex-wrap: wrap;
}

/* Current headshot small preview in edit mode */
.talent-current-headshot {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
	font-size: 0.85rem;
	color: rgba(255, 255, 255, 0.5);
}

/* -----------------------------------------------------------------------
   Admin notice (State 3)
   ----------------------------------------------------------------------- */

.talent-admin-notice {
	text-align: center;
	padding: 3rem 1rem;
}

.talent-admin-notice p {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.7);
	margin-bottom: 1.5rem;
}

/* -----------------------------------------------------------------------
   Button overrides / extensions (use existing .btn classes)
   ----------------------------------------------------------------------- */

.btn--sm {
	font-size: 0.85rem;
	padding: 0.4rem 1rem;
}

.btn--lg {
	font-size: 1.05rem;
	padding: 0.8rem 2.5rem;
}

/* -----------------------------------------------------------------------
   Script Submission — Release Agreement
   ----------------------------------------------------------------------- */

.script-release-wrap {
	border: 1px solid rgba(255, 155, 27, 0.3);
	border-radius: 10px;
	padding: 1.75rem 2rem;
	background: rgba(255, 155, 27, 0.04);
	max-width: 860px;
}

.script-release-heading {
	font-size: 1.25rem;
	margin: 0 0 0.5rem;
	color: var(--color-orange, #ff9b1b);
}

.script-release-intro {
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.6);
	margin: 0 0 1.25rem;
}

.script-release-text {
	background: rgba(0, 0, 0, 0.25);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 6px;
	padding: 1.25rem 1.5rem;
	max-height: 360px;
	overflow-y: auto;
	font-size: 0.875rem;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.75);
	scroll-behavior: smooth;
}

.script-release-text p {
	margin: 0 0 1rem;
}

.script-release-text p:last-child {
	margin-bottom: 0;
}

.script-release-disclaimer {
	font-size: 0.82rem !important;
	color: rgba(255, 255, 255, 0.45) !important;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding-top: 0.75rem;
	margin-top: 0.5rem;
}

/* Agreement checkbox label */
.script-agree-label {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	cursor: pointer;
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.8);
	font-weight: 400;
}

.script-agree-label input[type="checkbox"] {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	margin-top: 2px;
	accent-color: var(--color-accent, #E07820);
	cursor: pointer;
}

.script-agree-link {
	color: var(--color-accent, #E07820);
	text-decoration: underline;
}

/* Submit button disabled state */
#script-submit-btn:disabled {
	opacity: 0.45;
	cursor: not-allowed;
}

/* =======================================================================
   .portal-* ALIASES  (actor-portal + crew-portal templates use these)
   Maps portal-* class names onto the same styles as talent-* classes
   ======================================================================= */

/* Alerts */
.portal-alert { padding: 0.875rem 1.25rem; border-radius: 8px; font-size: 0.9rem; margin-bottom: 1.5rem; display: flex; align-items: flex-start; gap: 0.625rem; }
.portal-alert--success { background: rgba(34, 197, 94, 0.12); border: 1px solid rgba(34, 197, 94, 0.3); color: #4ade80; }
.portal-alert--error   { background: rgba(239, 68, 68, 0.1);  border: 1px solid rgba(239, 68, 68, 0.3);  color: #f87171; }
.portal-alert__link    { color: inherit; font-weight: 600; text-decoration: underline; }

/* Tab toggle */
.portal-tabs       { display: flex; gap: 0; border-bottom: 2px solid rgba(255,255,255,0.08); margin-bottom: 2rem; }
.portal-tab        { background: none; border: none; padding: 0.75rem 1.5rem; font-size: 0.95rem; font-weight: 600; color: rgba(255,255,255,0.5); cursor: pointer; position: relative; transition: color 0.2s; }
.portal-tab:hover  { color: rgba(255,255,255,0.8); }
.portal-tab--active{ color: var(--color-accent, #E07820); }
.portal-tab--active::after { content: ''; position: absolute; bottom: -2px; left: 0; right: 0; height: 2px; background: var(--color-accent, #E07820); }

/* Form layout */
.portal-form-wrap         { max-width: 800px; }
.portal-form-wrap--narrow { max-width: 480px; }
.portal-form-grid         { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem 1.5rem; }
@media (max-width: 600px) { .portal-form-grid { grid-template-columns: 1fr; } }

/* Field */
.portal-field        { display: flex; flex-direction: column; gap: 0.375rem; }
.portal-field--full  { grid-column: 1 / -1; }
.portal-field label  { font-size: 0.875rem; font-weight: 600; color: rgba(255,255,255,0.75); text-transform: uppercase; letter-spacing: 0.04em; }
.portal-field .required { color: var(--color-accent, #E07820); margin-left: 2px; }
.portal-field__hint  { font-size: 0.78rem; color: rgba(255,255,255,0.4); margin-top: 0.2rem; }

/* Form inputs */
.portal-form input[type="text"],
.portal-form input[type="email"],
.portal-form input[type="tel"],
.portal-form input[type="url"],
.portal-form input[type="password"],
.portal-form select,
.portal-form textarea {
	width: 100%; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12);
	border-radius: 6px; padding: 0.65rem 0.875rem; color: #fff; font-size: 0.95rem;
	font-family: inherit; transition: border-color 0.2s, background 0.2s; box-sizing: border-box;
}
.portal-form input:focus,
.portal-form select:focus,
.portal-form textarea:focus { outline: none; border-color: var(--color-accent, #E07820); background: rgba(255,255,255,0.07); }
.portal-form input.is-invalid,
.portal-form select.is-invalid,
.portal-form textarea.is-invalid { border-color: #f87171; }
.portal-form select option { background: #101525; }
.portal-form textarea        { resize: vertical; min-height: 100px; }

/* Dropzone */
.portal-dropzone            { border: 2px dashed rgba(255,255,255,0.2); border-radius: 10px; padding: 2rem; text-align: center; cursor: pointer; transition: border-color 0.2s, background 0.2s; position: relative; }
.portal-dropzone:hover,
.portal-dropzone.is-over    { border-color: var(--color-accent, #E07820); background: rgba(224,120,32,0.06); }
.portal-dropzone__input     { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%; }
.portal-dropzone__prompt .dashicons { font-size: 2.5rem; color: rgba(255,255,255,0.3); }
.portal-dropzone__prompt p  { font-size: 0.9rem; color: rgba(255,255,255,0.5); margin: 0.5rem 0 0; }
.portal-dropzone__hint      { font-size: 0.78rem; color: rgba(255,255,255,0.35); margin-top: 0.375rem; display: block; }
.portal-dropzone__preview   { margin-top: 1rem; }
.portal-dropzone__preview img { max-width: 140px; max-height: 140px; border-radius: 8px; object-fit: cover; }

/* Form actions + legal */
.portal-form-actions  { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; padding-top: 0.75rem; border-top: 1px solid rgba(255,255,255,0.06); margin-top: 0.5rem; }
.portal-form-legal    { font-size: 0.78rem; color: rgba(255,255,255,0.35); margin-top: 0.75rem; line-height: 1.5; }
.portal-form-forgot   { font-size: 0.85rem; color: rgba(255,255,255,0.45); }
.portal-form-forgot a { color: var(--color-accent, #E07820); text-decoration: none; }
.portal-form-forgot a:hover { text-decoration: underline; }

/* Hero eyebrow */
.portal-hero-eyebrow {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-accent, #E07820);
	background: rgba(224,120,32,0.1);
	border: 1px solid rgba(224,120,32,0.25);
	border-radius: 999px;
	padding: 0.25rem 0.875rem;
	margin-bottom: 1rem;
}

/* Profile card */
.portal-profile-card {
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: 2rem;
	background: rgba(255,255,255,0.03);
	border: 1px solid rgba(14,124,135,0.12);
	border-radius: 14px;
	padding: 2rem;
	margin-bottom: 2rem;
}
@media (max-width: 680px) { .portal-profile-card { grid-template-columns: 1fr; } }

.portal-headshot-img {
	width: 100%; max-width: 200px; height: 200px; object-fit: cover;
	border-radius: 10px; display: block;
}
.portal-headshot-placeholder {
	width: 200px; height: 200px; border-radius: 10px;
	background: rgba(255,255,255,0.06); border: 2px dashed rgba(255,255,255,0.15);
	display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.5rem;
}
.portal-headshot-placeholder .dashicons { font-size: 3rem; color: rgba(255,255,255,0.2); }

.portal-profile-card__info h2 { font-size: 1.6rem; margin: 0 0 0.4rem; color: #fff; }

.portal-role-badge {
	display: inline-block;
	background: rgba(224,120,32,0.15);
	border: 1px solid rgba(224,120,32,0.45);
	color: var(--color-accent, #E07820);
	border-radius: 999px;
	padding: 0.2rem 0.75rem;
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: 1rem;
}
.portal-role-badge--large { font-size: 0.85rem; padding: 0.3rem 1rem; }

.portal-detail-list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem 1.5rem;
	margin: 1rem 0;
}
@media (max-width: 480px) { .portal-detail-list { grid-template-columns: 1fr; text-align: left; } }
.portal-detail-list dt { font-size: 0.8rem; font-weight: 700; color: rgba(255,255,255,0.45); text-transform: uppercase; letter-spacing: 0.06em; padding-top: 2px; }
.portal-detail-list dd { font-size: 0.95rem; color: rgba(255,255,255,0.85); margin: 0; }

.portal-links { display: flex; gap: 0.625rem; flex-wrap: wrap; margin-bottom: 1.5rem; }

.portal-profile-actions { display: flex; gap: 0.75rem; align-items: center; flex-wrap: wrap; }

.portal-current-headshot {
	display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.75rem;
	font-size: 0.85rem; color: rgba(255,255,255,0.5);
}

.portal-admin-notice { text-align: center; padding: 3rem 1rem; }
.portal-admin-notice p { font-size: 1.1rem; color: rgba(255,255,255,0.7); margin-bottom: 1.5rem; }

/* =======================================================================
   Crew Skills / Role Checkboxes
   ======================================================================= */

.crew-skills-section {
	grid-column: 1 / -1;
	border: 1px solid rgba(224,120,32,0.15);
	border-radius: 12px;
	padding: 1.75rem;
	background: rgba(255,255,255,0.02);
}

.crew-skills-section h3 {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-accent, #E07820);
	margin: 0 0 0.375rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.crew-skills-section .crew-skills-intro {
	font-size: 0.85rem;
	color: rgba(255,255,255,0.45);
	margin: 0 0 1.5rem;
}

.crew-dept-groups {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.crew-dept-group {}

.crew-dept-group__label {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: rgba(255,255,255,0.4);
	border-bottom: 1px solid rgba(255,255,255,0.06);
	padding-bottom: 0.4rem;
	margin-bottom: 0.75rem;
}

.crew-skills-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.crew-skill-check {
	display: none; /* Hide default checkbox */
}

.crew-skill-check + label {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.3rem 0.75rem;
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 999px;
	font-size: 0.82rem;
	color: rgba(255,255,255,0.55);
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
	user-select: none;
}

.crew-skill-check + label:hover {
	border-color: rgba(224,120,32,0.4);
	color: rgba(255,255,255,0.85);
}

.crew-skill-check:checked + label {
	border-color: var(--color-accent, #E07820);
	background: rgba(224,120,32,0.15);
	color: var(--color-accent, #E07820);
	font-weight: 600;
}

.crew-skills-selected-count {
	font-size: 0.82rem;
	color: rgba(255,255,255,0.4);
	margin-top: 1rem;
}

.crew-skills-selected-count strong {
	color: var(--color-accent, #E07820);
}

/* Profile view: skills tag cloud */
.portal-skills-cloud {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.5rem;
}

.portal-skill-tag {
	display: inline-block;
	padding: 0.25rem 0.7rem;
	background: rgba(224,120,32,0.1);
	border: 1px solid rgba(224,120,32,0.25);
	border-radius: 999px;
	font-size: 0.78rem;
	color: rgba(255,255,255,0.7);
}
