/* NE Design System — modules/organizations.css — Phase 2 (#65) */
/* Organization pages — loaded conditionally */

/* === My Federations (archive personal section) === */
.ne-org-my-feds {
	margin-bottom: var(--ne-space-6);
}

.ne-org-my-feds__header {
	display: flex;
	align-items: center;
	gap: var(--ne-space-3);
	margin-bottom: var(--ne-space-4);
}

.ne-org-my-feds__icon {
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--ne-accent-glow);
	border: 1px solid var(--ne-accent-soft);
	border-radius: var(--ne-radius-sm);
	color: var(--ne-accent);
	font-size: 0.85rem;
}

.ne-org-my-feds__title {
	font-family: var(--ne-font-display);
	font-size: 1rem;
	font-weight: 700;
	color: var(--ne-text);
	margin: 0;
	line-height: 1.2;
	letter-spacing: 0.04em;
}

.ne-org-my-feds__sub {
	font-family: var(--ne-font-mono);
	font-size: 0.65rem;
	color: var(--ne-text-subtle);
	margin: 0;
	letter-spacing: 0.3px;
}

.ne-org-my-card {
	display: flex;
	align-items: center;
	gap: var(--ne-space-3);
	padding: var(--ne-space-3) var(--ne-space-4);
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-md);
	text-decoration: none;
	transition: border-color var(--ne-duration) var(--ne-ease),
	            background var(--ne-duration) var(--ne-ease);
}

a.ne-org-my-card:hover {
	border-color: var(--ne-accent-soft);
	background: var(--ne-elevated);
}

.ne-org-my-card__avatar {
	width: 36px;
	height: 36px;
	border-radius: var(--ne-radius-sm);
	overflow: hidden;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--ne-elevated);
	color: var(--ne-text-subtle);
	font-size: 0.8rem;
}

.ne-org-my-card__avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ne-org-my-card__info {
	flex: 1;
	min-width: 0;
}

.ne-org-my-card__name {
	display: block;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--ne-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	line-height: 1.3;
}

a.ne-org-my-card:hover .ne-org-my-card__name {
	color: var(--ne-accent);
}

.ne-org-my-card__role {
	font-size: 0.65rem;
	color: var(--ne-text-subtle);
}

.ne-org-my-card__role i {
	font-size: 0.55rem;
	margin-right: 2px;
	color: var(--ne-accent);
}

.ne-org-my-card__status {
	flex-shrink: 0;
	font-family: var(--ne-font-mono);
	font-size: 0.6rem;
	font-weight: 500;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	padding: 3px 8px;
	border-radius: var(--ne-radius-pill);
}

.ne-org-my-card__status--active {
	background: rgba(29, 187, 96, 0.12);
	color: var(--ne-green-alt);
}

.ne-org-my-card__status--pending {
	background: rgba(255, 193, 7, 0.12);
	color: #ffc107;
}

.ne-org-my-card__status--rejected {
	background: rgba(255, 79, 79, 0.12);
	color: var(--ne-red);
}

.ne-org-my-card--rejected {
	opacity: 0.45;
	pointer-events: none;
}

.ne-org-my-feds--rejected {
	margin-bottom: var(--ne-space-6);
}

.ne-org-header {
	display: flex;
	align-items: center;
	gap: var(--ne-space-5);
	padding: var(--ne-space-6) 0;
}

.ne-org-logo {
	width: 80px;
	height: 80px;
	border-radius: var(--ne-radius-lg);
	object-fit: cover;
	border: 1px solid var(--ne-border);
}

.ne-org-name {
	font-family: var(--ne-font-display);
	font-size: 1.8rem;
	letter-spacing: -1px;
}

.ne-org-meta {
	font-family: var(--ne-font-mono);
	font-size: 0.7rem;
	color: var(--ne-text-subtle);
	text-transform: uppercase;
	letter-spacing: 0.8px;
}

/* === Member grid === */
.ne-member-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: var(--ne-card-gap);
}

.ne-member {
	display: flex;
	align-items: center;
	gap: var(--ne-space-3);
	padding: var(--ne-space-3);
	background: var(--ne-elevated);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-md);
}

.ne-member__avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 2px solid var(--ne-accent-soft);
	object-fit: cover;
}

.ne-member__name {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--ne-text);
	text-decoration: none;
}

.ne-member__name:hover {
	color: var(--ne-accent);
}

.ne-member__role {
	font-family: var(--ne-font-mono);
	font-size: 0.688rem;
	color: var(--ne-text-subtle);
}

/* === Archive intro === */
.ne-org-archive-intro {
	margin-bottom: var(--ne-space-6);
	padding: var(--ne-space-7) var(--ne-space-6);
	background:
		radial-gradient(ellipse at 10% 50%, rgba(var(--ne-accent-rgb, 99, 102, 241), 0.06) 0%, transparent 50%),
		var(--ne-elevated);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-lg);
	position: relative;
	overflow: hidden;
}

.ne-org-archive-intro::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--ne-accent), transparent);
	opacity: 0.4;
}

.ne-org-archive-intro__eyebrow {
	display: inline-block;
	font-family: var(--ne-font-mono);
	font-size: 0.688rem;
	font-weight: 600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--ne-accent);
	margin-bottom: var(--ne-space-3);
}

.ne-org-archive-intro__title {
	font-family: var(--ne-font-display);
	font-style: italic;
	font-size: 1.8rem;
	color: var(--ne-text);
	margin: 0 0 var(--ne-space-4);
	line-height: 1.2;
}

.ne-org-archive-intro__title em {
	color: var(--ne-accent);
}

.ne-org-archive-intro__desc {
	font-size: 0.875rem;
	color: var(--ne-text-subtle);
	line-height: 1.8;
	margin: 0;
	max-width: 680px;
}

@media (max-width: 750px) {
	.ne-org-archive-intro {
		padding: var(--ne-space-6) var(--ne-space-5);
	}

	.ne-org-archive-intro__title {
		font-size: 1.4rem;
	}
}

/* === Organization cards (archive) === */
.ne-org-card {
	display: flex;
	flex-direction: column;
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-lg);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform var(--ne-duration) var(--ne-ease),
	            border-color var(--ne-duration) var(--ne-ease),
	            box-shadow var(--ne-duration) var(--ne-ease);
}

.ne-org-card:hover {
	transform: translateY(-2px);
	border-color: var(--ne-border-s);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
}

.ne-org-card__image {
	position: relative;
	height: 180px;
	overflow: hidden;
}

.ne-org-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--ne-duration) var(--ne-ease);
}

.ne-org-card:hover .ne-org-card__image img {
	transform: scale(1.05);
}

.ne-org-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, transparent 20%, rgba(0, 0, 0, 0.75));
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: var(--ne-space-4);
}

.ne-org-card__name {
	font-family: var(--ne-font-body);
	font-weight: 600;
	font-size: 1.15rem;
	color: #fff;
	text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
}

.ne-org-card__siglas {
	font-family: var(--ne-font-mono);
	font-size: 0.75rem;
	color: var(--ne-accent);
	margin-top: var(--ne-space-1);
}

.ne-org-card__placeholder {
	width: 100%;
	height: 100%;
	background: var(--ne-elevated);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	color: var(--ne-text-muted);
}

.ne-org-card__body {
	padding: var(--ne-space-4);
	flex: 1;
	display: flex;
	flex-direction: column;
}

.ne-org-card__desc {
	font-size: 0.825rem;
	line-height: 1.5;
	color: var(--ne-text-subtle);
	margin: 0 0 var(--ne-space-3);
}

.ne-org-card__stats {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ne-space-2);
	margin-top: auto;
}

.ne-text-sm {
	font-size: 0.85rem;
	line-height: 1.5;
}

/* ============================================
   Single Organization Page
   ============================================ */

/* Hero variant */
.ne-hero--org-single {
	min-height: 280px;
	background-size: cover;
	background-position: center;
}

.ne-org-single__logo {
	width: 80px;
	height: 80px;
	border-radius: var(--ne-radius-lg);
	object-fit: cover;
	border: 2px solid rgba(255, 255, 255, 0.15);
	margin-bottom: var(--ne-space-4);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
}

/* Layout — content left (1fr), sidebar right (340px) */
.ne-org-single {
	grid-template-columns: 1fr 340px;
	align-items: start;
}

.ne-org-single__label {
	font-family: var(--ne-font-mono);
	font-size: 0.65rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--ne-text-muted);
	white-space: nowrap;
	margin-bottom: var(--ne-space-3);
}

.ne-org-single__desc {
	font-family: var(--ne-font-body);
	font-size: 0.875rem;
	line-height: 1.7;
	color: var(--ne-text-subtle);
	margin-bottom: var(--ne-space-5);
	padding-bottom: var(--ne-space-4);
	border-bottom: 1px solid var(--ne-border);
}

.ne-org-single__desc p {
	margin: 0 0 var(--ne-space-3);
}

.ne-org-single__desc p:last-child {
	margin-bottom: 0;
}

/* === Organization event cards === */
.ne-org-event {
	border-radius: var(--ne-radius-lg);
	overflow: hidden;
}

.ne-org-event__image {
	position: relative;
	height: 180px;
	overflow: hidden;
}

.ne-org-event__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--ne-duration) var(--ne-ease);
}

.ne-org-event:hover .ne-org-event__image img {
	transform: scale(1.05);
}

.ne-org-event__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, transparent 20%, rgba(0, 0, 0, 0.75));
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	gap: var(--ne-space-2);
	padding: var(--ne-space-4);
}

.ne-org-event__name {
	font-family: var(--ne-font-body);
	font-weight: 600;
	font-size: 0.95rem;
	color: #fff;
	line-height: 1.3;
	text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
}

/* === Member actions sidebar === */
.ne-org-actions .ne-org-single__label {
	margin-bottom: var(--ne-space-4);
}

/* ============================================
   Event Wizard — Full-width layout
   ============================================ */

.ne-org-wizard-card {
	padding: var(--ne-space-7);
}

.ne-org-wizard-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--ne-space-5);
	padding-bottom: var(--ne-space-4);
	border-bottom: 1px solid var(--ne-border);
}

.ne-org-wizard-title {
	font-family: var(--ne-font-body);
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--ne-text);
	margin: 0;
}

/* ============================================
   New Organization Page
   ============================================ */

/* === Form intro === */
.ne-org-form-intro {
	text-align: center;
	margin-bottom: var(--ne-space-6);
}

.ne-org-form-intro__text {
	font-size: 0.875rem;
	color: var(--ne-text-subtle);
	line-height: 1.6;
	margin: 0 0 var(--ne-space-4);
}

.ne-org-form-intro__perks {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--ne-space-2);
}

.ne-pill--subtle {
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	color: var(--ne-text-muted);
	font-family: var(--ne-font-mono);
	font-size: 0.65rem;
	font-weight: 500;
	letter-spacing: 0.3px;
	padding: var(--ne-space-1) var(--ne-space-3);
	border-radius: var(--ne-radius-pill);
}

/* === Success screen === */
.ne-org-success {
	display: flex;
	justify-content: center;
	padding: var(--ne-space-6) 0;
}

.ne-org-success__card {
	text-align: center;
	padding: var(--ne-space-8) var(--ne-space-6);
	max-width: 480px;
	width: 100%;
}

.ne-org-success__badge {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	font-size: 1.8rem;
	color: var(--ne-accent);
	margin-bottom: var(--ne-space-5);
}

.ne-org-success__badge-ring {
	position: absolute;
	inset: 0;
	border: 2px solid var(--ne-accent-soft);
	border-radius: 50%;
	opacity: 0.4;
}

.ne-org-success__title {
	font-family: var(--ne-font-display);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--ne-text);
	margin: 0 0 var(--ne-space-3);
	letter-spacing: -0.01em;
}

.ne-org-success__divider {
	width: 40px;
	height: 2px;
	background: var(--ne-accent);
	margin: 0 auto var(--ne-space-5);
	border-radius: 1px;
}

.ne-org-success__text {
	font-size: 0.875rem;
	color: var(--ne-text-muted);
	line-height: 1.7;
	margin: 0 0 var(--ne-space-5);
}

.ne-org-success__detail {
	display: inline-flex;
	align-items: center;
	gap: var(--ne-space-2);
	padding: var(--ne-space-2) var(--ne-space-4);
	background: rgba(19, 22, 48, 0.5);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-pill);
	font-size: 0.75rem;
	color: var(--ne-text-subtle);
	margin-bottom: var(--ne-space-6);
}

.ne-org-success__detail i {
	color: var(--ne-accent);
	font-size: 0.7rem;
}

.ne-org-success__cta {
	width: 100%;
}

/* === Form overrides (legacy shortcode) === */
.organization-form {
	padding: var(--ne-space-6);
}

.organization-form .ctt-input,
.organization-form .ctt-forms input[type="text"],
.organization-form .ctt-forms input[type="url"],
.organization-form .ctt-forms textarea,
.organization-form .ctt-forms select {
	background: rgba(19, 22, 48, 0.6);
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-md);
	color: var(--ne-text);
	padding: var(--ne-space-3) var(--ne-space-4);
	font-family: var(--ne-font-body);
	font-size: 0.875rem;
	width: 100%;
	transition: border-color var(--ne-duration) var(--ne-ease),
	            box-shadow var(--ne-duration) var(--ne-ease);
}

.organization-form .ctt-input:focus,
.organization-form .ctt-forms input:focus,
.organization-form .ctt-forms textarea:focus,
.organization-form .ctt-forms select:focus {
	border-color: var(--ne-accent);
	box-shadow: 0 0 0 3px var(--ne-accent-glow);
	outline: none;
	background: rgba(19, 22, 48, 0.8);
}

.organization-form .ctt-forms textarea {
	min-height: 120px;
	resize: vertical;
}

.organization-form .ctt-forms input[type="file"] {
	padding: var(--ne-space-3);
	cursor: pointer;
}

.organization-form .ctt-form-line {
	margin-bottom: var(--ne-space-5);
}

/* Two-column form row */
.organization-form .ne-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--ne-space-4);
	margin-bottom: var(--ne-space-5);
}

.organization-form .ne-form-row .ctt-form-line {
	margin-bottom: 0;
}

/* Required field indicator */
.organization-form .ctt-form-line:has([required]) > label::after,
.organization-form .ctt-form-line:has([required]) > .form-label-ico::after {
	content: " *";
	color: var(--ne-red);
}

.organization-form .form-label-ico,
.organization-form label {
	font-family: var(--ne-font-body);
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--ne-text);
	margin-bottom: var(--ne-space-2);
	display: block;
}

/* Character counter */
.organization-form .ne-char-count {
	font-family: var(--ne-font-mono);
	font-size: 0.7rem;
	color: var(--ne-text-subtle);
	text-align: right;
	margin-top: var(--ne-space-1);
}

.organization-form .ctt-text {
	font-size: 0.75rem !important;
	color: var(--ne-text-subtle) !important;
	margin-top: var(--ne-space-2) !important;
	line-height: 1.4;
}

.organization-form .ctt-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--ne-space-2);
	width: 100%;
	padding: var(--ne-space-3) var(--ne-space-5);
	font-family: var(--ne-font-body);
	font-size: 1rem;
	font-weight: 600;
	color: #fff;
	background: var(--ne-accent);
	border: 1px solid transparent;
	border-radius: var(--ne-radius-md);
	cursor: pointer;
	transition: transform var(--ne-duration) var(--ne-ease),
	            box-shadow var(--ne-duration) var(--ne-ease);
}

.organization-form .ctt-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 0 32px var(--ne-accent-glow);
}

/* Select2 — selection box */
.organization-form .select2-container--default .select2-selection--multiple {
	background: rgba(19, 22, 48, 0.6);
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-md);
	min-height: 44px;
	padding: var(--ne-space-1) var(--ne-space-2);
}

.organization-form .select2-container--default .select2-selection--multiple:focus-within {
	border-color: var(--ne-accent);
	box-shadow: 0 0 0 3px var(--ne-accent-glow);
	background: rgba(19, 22, 48, 0.8);
}

/* Select2 — chips */
.organization-form .select2-container--default .select2-selection--multiple .select2-selection__choice {
	background: var(--ne-accent-glow);
	border: 1px solid var(--ne-accent-soft);
	border-radius: var(--ne-radius-sm);
	color: var(--ne-text);
	font-size: 0.8rem;
	padding: 2px 8px;
	margin: 3px 4px 3px 0;
}

.organization-form .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
	color: var(--ne-text-muted);
	margin-right: 4px;
	font-size: 1rem;
	font-weight: 400;
}

.organization-form .select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
	color: var(--ne-red);
}

/* Select2 — search input */
.organization-form .select2-container--default .select2-search--inline .select2-search__field {
	color: var(--ne-text);
	font-family: var(--ne-font-body);
	font-size: 0.875rem;
}

.organization-form .select2-container--default .select2-search--inline .select2-search__field::placeholder {
	color: var(--ne-text-subtle);
}

/* Select2 — dropdown (rendered on body) */
.select2-container--default .select2-dropdown {
	background: var(--ne-surface);
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-md);
	overflow: hidden;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
	background: rgba(19, 22, 48, 0.6);
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-sm);
	color: var(--ne-text);
	padding: var(--ne-space-2) var(--ne-space-3);
	font-family: var(--ne-font-body);
	font-size: 0.875rem;
}

.select2-container--default .select2-search--dropdown .select2-search__field:focus {
	border-color: var(--ne-accent);
	outline: none;
}

.select2-container--default .select2-results__option {
	color: var(--ne-text);
	padding: var(--ne-space-2) var(--ne-space-3);
	font-family: var(--ne-font-body);
	font-size: 0.85rem;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
	background: var(--ne-accent-glow);
	color: var(--ne-text);
}

.select2-container--default .select2-results__option[aria-selected="true"] {
	background: rgba(19, 22, 48, 0.8);
	color: var(--ne-text-muted);
}

.select2-container--default .select2-results__message {
	color: var(--ne-text-subtle);
	font-size: 0.8rem;
	font-style: italic;
}

/* === Social grid & input groups === */
.organization-form .ne-social-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--ne-space-3);
	margin-bottom: var(--ne-space-5);
}

.organization-form .ne-social-grid .ctt-form-line {
	margin-bottom: 0;
}

.organization-form .ne-input-prefix-wrap {
	display: flex;
	align-items: stretch;
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-md);
	background: rgba(19, 22, 48, 0.6);
	overflow: hidden;
	transition: border-color var(--ne-duration) var(--ne-ease),
	            box-shadow var(--ne-duration) var(--ne-ease);
}

.organization-form .ne-input-prefix-wrap:focus-within {
	border-color: var(--ne-accent);
	box-shadow: 0 0 0 3px var(--ne-accent-glow);
	background: rgba(19, 22, 48, 0.8);
}

.organization-form .ne-input-prefix {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	min-width: 120px;
	padding: 0 var(--ne-space-2) 0 var(--ne-space-3);
	font-family: var(--ne-font-mono);
	font-size: 0.75rem;
	color: var(--ne-text-subtle);
	white-space: nowrap;
	user-select: none;
	border-right: 1px solid var(--ne-border-s);
	background: rgba(19, 22, 48, 0.3);
}

.organization-form .ne-input-group .ctt-input {
	border: none !important;
	background: transparent !important;
	box-shadow: none !important;
	outline: none !important;
	flex: 1;
	min-width: 0;
}

.organization-form .ne-input-group .form-label-ico i {
	width: 1.2em;
	text-align: center;
	margin-right: var(--ne-space-1);
}

/* === Upload dropzone === */
.ne-upload__input {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	opacity: 0 !important;
	overflow: hidden !important;
	pointer-events: none;
}

.ne-upload-zone {
	position: relative;
	border: 2px dashed var(--ne-border-s);
	border-radius: var(--ne-radius-lg);
	background: rgba(19, 22, 48, 0.4);
	cursor: pointer;
	transition: border-color var(--ne-duration) var(--ne-ease),
	            background var(--ne-duration) var(--ne-ease);
}

.ne-upload-zone:hover,
.ne-upload-zone.is-dragover {
	border-color: var(--ne-accent);
	background: var(--ne-accent-glow);
}

.ne-upload-zone__empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ne-space-2);
	padding: var(--ne-space-6) var(--ne-space-4);
}

.ne-upload-zone__icon {
	font-size: 1.8rem;
	color: var(--ne-text-subtle);
	transition: color var(--ne-duration) var(--ne-ease);
}

.ne-upload-zone:hover .ne-upload-zone__icon {
	color: var(--ne-accent);
}

.ne-upload-zone__label {
	font-size: 0.85rem;
	color: var(--ne-text-muted);
	text-align: center;
}

.ne-upload-zone__label strong {
	color: var(--ne-accent);
}

.ne-upload-zone__hint {
	font-family: var(--ne-font-mono);
	font-size: 0.65rem;
	color: var(--ne-text-subtle);
	letter-spacing: 0.3px;
}

.ne-upload-zone__preview {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--ne-space-4);
}

.ne-upload-zone__img {
	max-width: 160px;
	max-height: 160px;
	border-radius: var(--ne-radius-md);
	object-fit: contain;
}

.ne-upload-zone__remove {
	position: absolute;
	top: var(--ne-space-2);
	right: var(--ne-space-2);
	width: 28px !important;
	height: 28px !important;
	min-width: 28px;
	max-width: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	background: var(--ne-red);
	color: #fff;
	border: none;
	border-radius: 50%;
	font-size: 0.7rem;
	cursor: pointer;
	opacity: 0;
	transition: opacity var(--ne-duration) var(--ne-ease);
}

.ne-upload-zone:hover .ne-upload-zone__remove {
	opacity: 1;
}

.ne-upload-zone.has-file {
	border-style: solid;
	border-color: var(--ne-green-alt);
	background: rgba(29, 187, 96, 0.05);
}

/* === Form wizard stepper === */
.ne-wizard-stepper {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	margin-bottom: var(--ne-space-6);
	padding-bottom: var(--ne-space-5);
	border-bottom: 1px solid var(--ne-border);
}

.ne-wizard-step {
	display: flex;
	align-items: center;
	gap: var(--ne-space-2);
	padding: var(--ne-space-2) var(--ne-space-3);
	border-radius: var(--ne-radius-md);
	cursor: default;
	transition: background var(--ne-duration) var(--ne-ease);
}

.ne-wizard-step.is-done {
	cursor: pointer;
}

.ne-wizard-step.is-done:hover {
	background: var(--ne-elevated);
}

.ne-wizard-step__num {
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	font-family: var(--ne-font-mono);
	font-size: 0.75rem;
	font-weight: 700;
	background: var(--ne-elevated);
	color: var(--ne-text-subtle);
	border: 2px solid var(--ne-border);
	transition: all var(--ne-duration) var(--ne-ease);
}

.ne-wizard-step.is-active .ne-wizard-step__num {
	background: var(--ne-accent);
	color: #fff;
	border-color: var(--ne-accent);
	box-shadow: 0 0 16px rgba(139, 127, 232, 0.4);
}

.ne-wizard-step.is-active {
	background: var(--ne-accent-glow);
	border-radius: var(--ne-radius-pill);
}

.ne-wizard-step.is-done .ne-wizard-step__num {
	background: var(--ne-green-alt);
	color: #fff;
	border-color: var(--ne-green-alt);
}

.ne-wizard-step__label {
	font-family: var(--ne-font-mono);
	font-size: 0.688rem;
	font-weight: 500;
	color: var(--ne-text-subtle);
	letter-spacing: 0.3px;
}

.ne-wizard-step.is-active .ne-wizard-step__label {
	color: #fff;
	font-weight: 600;
}

.ne-wizard-step.is-done .ne-wizard-step__label {
	color: var(--ne-text-muted);
}

.ne-wizard-step__line {
	flex: 0 0 32px;
	height: 2px;
	background: var(--ne-border);
	margin: 0 var(--ne-space-1);
}

/* Wizard nav */
.ne-wizard-nav {
	display: flex;
	justify-content: space-between;
	gap: var(--ne-space-3);
	margin-top: var(--ne-space-5);
	padding-top: var(--ne-space-5);
	border-top: 1px solid var(--ne-border);
}

.ne-wizard-nav .ne-btn {
	flex: 1;
}

/* Wizard validation error flash */
.ne-wizard-error {
	animation: ne-shake 0.4s ease;
}

.ne-wizard-error .ctt-input,
.ne-wizard-error .select2-selection--multiple {
	border-color: var(--ne-red) !important;
	box-shadow: 0 0 0 3px rgba(255, 79, 79, 0.15) !important;
}

@keyframes ne-shake {
	0%, 100% { transform: translateX(0); }
	20% { transform: translateX(-6px); }
	40% { transform: translateX(6px); }
	60% { transform: translateX(-4px); }
	80% { transform: translateX(4px); }
}

/* Wizard responsive */
@media (max-width: 480px) {
	.ne-wizard-step__label {
		display: none;
	}

	.ne-wizard-step__line {
		flex: 0 0 20px;
	}
}

/* === Status messages === */
.ne-org-message {
	padding: var(--ne-space-4);
	border-radius: var(--ne-radius-md);
	font-size: 0.875rem;
	font-weight: 500;
	margin-bottom: var(--ne-space-5);
}

.ne-org-message--success {
	background: rgba(61, 214, 140, 0.1);
	border: 1px solid rgba(61, 214, 140, 0.3);
	color: var(--ne-green);
}

.ne-org-message--warning {
	background: rgba(255, 184, 0, 0.1);
	border: 1px solid rgba(255, 184, 0, 0.3);
	color: var(--ne-yellow);
}

.ne-org-message--error {
	background: rgba(255, 79, 79, 0.1);
	border: 1px solid rgba(255, 79, 79, 0.3);
	color: var(--ne-red);
}

/* === Invitation cards (archive, #111) === */
.ne-org-invitations {
	margin-bottom: var(--ne-space-6);
}

.ne-invite-card {
	display: flex;
	flex-direction: column;
	gap: var(--ne-space-3);
	padding: var(--ne-space-4);
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-left: 3px solid #ffc107;
	border-radius: var(--ne-radius-md);
	transition: opacity 0.3s ease, transform 0.3s ease, max-height 0.4s ease;
}

.ne-invite-card__header {
	display: flex;
	align-items: center;
	gap: var(--ne-space-3);
}

.ne-invite-card__from {
	display: block;
	font-size: 0.65rem;
	color: var(--ne-text-subtle);
	margin-top: 2px;
}

.ne-invite-card__role {
	font-family: var(--ne-font-mono);
	font-size: 0.7rem;
	color: var(--ne-text-muted);
	letter-spacing: 0.3px;
	padding: var(--ne-space-2) var(--ne-space-3);
	background: var(--ne-elevated);
	border-radius: var(--ne-radius-sm);
}

.ne-invite-card__role i {
	color: var(--ne-accent);
	margin-right: var(--ne-space-1);
	font-size: 0.6rem;
}

.ne-invite-card__actions {
	display: flex;
	gap: var(--ne-space-2);
}

.ne-invite-card__actions .ne-btn {
	flex: 1;
	justify-content: center;
}

.ne-invite-card__message {
	font-size: 0.75rem;
	font-weight: 500;
	padding: var(--ne-space-2) var(--ne-space-3);
	border-radius: var(--ne-radius-sm);
	text-align: center;
}

.ne-invite-card__message--success {
	background: rgba(29, 187, 96, 0.12);
	color: var(--ne-green-alt);
}

.ne-invite-card__message--rejected {
	background: rgba(255, 193, 7, 0.12);
	color: #ffc107;
}

.ne-invite-card__message--error {
	background: rgba(255, 79, 79, 0.1);
	color: var(--ne-red);
}

/* === CTA banner (archive bottom) === */
.ne-org-cta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--ne-space-7);
	padding: var(--ne-space-8, 3.5rem) var(--ne-space-7);
	background:
		radial-gradient(ellipse at 20% 50%, rgba(var(--ne-accent-rgb, 99, 102, 241), 0.08) 0%, transparent 50%),
		radial-gradient(ellipse at 80% 50%, var(--ne-accent-glow) 0%, transparent 50%),
		var(--ne-elevated);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-lg);
	position: relative;
	overflow: hidden;
}

.ne-org-cta::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--ne-accent), transparent);
	opacity: 0.6;
}

.ne-org-cta__text {
	flex: 1;
}

.ne-org-cta__eyebrow {
	display: inline-block;
	font-family: var(--ne-font-mono);
	font-size: 0.688rem;
	font-weight: 600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--ne-accent);
	margin-bottom: var(--ne-space-3);
}

.ne-org-cta__title {
	font-family: var(--ne-font-display);
	font-style: italic;
	font-size: 2.4rem;
	color: var(--ne-text);
	margin: 0 0 var(--ne-space-4);
	line-height: 1.15;
}

.ne-org-cta__title em {
	color: var(--ne-accent);
}

.ne-org-cta__desc {
	font-size: 0.925rem;
	color: var(--ne-text-subtle);
	line-height: 1.7;
	margin: 0;
	max-width: 560px;
}

.ne-org-cta__action {
	flex-shrink: 0;
}

/* Features grid below CTA */
.ne-org-fed-features {
	margin-top: var(--ne-space-6);
}

/* === Responsive === */
@media (max-width: 750px) {
	.ne-org-single {
		grid-template-columns: 1fr;
	}

	.ne-org-events-grid {
		grid-template-columns: 1fr 1fr;
	}

	.ne-org-cta {
		flex-direction: column;
		text-align: center;
		padding: var(--ne-space-7) var(--ne-space-5);
	}

	.ne-org-cta__title {
		font-size: 1.8rem;
	}

	.ne-org-cta__desc {
		max-width: none;
		font-size: 0.875rem;
	}

	.organization-form {
		padding: var(--ne-space-4);
	}

	.organization-form .ne-form-row,
	.organization-form .ne-social-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 480px) {
	.ne-org-events-grid {
		grid-template-columns: 1fr;
	}
}
