/* Frontend event signup — wrapper kan innehålla både kort-grid och formulär */

.gko-signup-wrap {
	max-width: 960px;
	margin: 0;
	/* Ärv themats font (Ubuntu via Dynamico) så event-kortets titel ser
	   lika skarp ut som "När/Tid/Plats"-etiketterna nedanför. */
	font-family: inherit;
}
.gko-signup-wrap *, .gko-signup-wrap *::before, .gko-signup-wrap *::after {
	box-sizing: border-box;
}

/* Tillgängligt-dold dropdown — finns för screen readers + state-tracking */
.gko-signup-wrap .gko-screen-reader {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0,0,0,0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

/* ───────────────────────────────────────────────────────────────
 * Kort-grid (browse-vy ovanför formuläret)
 * ───────────────────────────────────────────────────────────── */
.gko-cards-intro {
	margin: 0 0 .85rem;
	font-size: .85rem;
	color: #888;
	letter-spacing: .01em;
}

.gko-event-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25rem;
	margin: 0 0 1.75rem;
}
@media (max-width: 768px) {
	.gko-event-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
	.gko-event-cards { grid-template-columns: 1fr; }
}

.gko-event-card {
	display: flex;
	flex-direction: column;
	background: #0a0a0a;
	border: 1px solid #2a2a2a;
	border-radius: 12px;
	overflow: hidden;
	cursor: pointer;
	transition: border-color .15s, transform .15s, box-shadow .15s;
	color: #fff;
}
.gko-event-card:hover {
	border-color: #555;
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(0, 0, 0, .4);
}
.gko-event-card:active {
	transform: scale(.98);
	transition: transform .1s;
}
.gko-event-card.gko-card-selected {
	border-color: #10b981;
	box-shadow: 0 0 0 2px rgba(16, 185, 129, .25), 0 6px 16px rgba(0, 0, 0, .4);
}
.gko-event-card[aria-disabled="true"] {
	cursor: not-allowed;
	opacity: .55;
}
.gko-event-card[aria-disabled="true"]:hover {
	transform: none;
}

.gko-event-card .gko-card-image {
	width: 100%;
	aspect-ratio: 16 / 9;
	background-color: #1a1a1a;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}
.gko-event-card .gko-card-image-placeholder {
	background-image: linear-gradient(135deg, #1a1a1a 25%, #222 25%, #222 50%, #1a1a1a 50%, #1a1a1a 75%, #222 75%, #222 100%);
	background-size: 20px 20px;
}

.gko-event-card .gko-card-body {
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: .55rem;
	padding: 1rem 1.1rem 1.1rem;
}
.gko-event-card .gko-card-title {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 700;
	color: #fff;
	line-height: 1.25;
	/* Themat (Dynamico) tvingar "Francois One" på alla h1-h6.
	   Tvinga ärvning av brödtext-fonten (Ubuntu) så titel blir skarp. */
	font-family: inherit;
}
.gko-event-card .gko-card-meta {
	font-size: .85rem;
	color: #ddd;
	display: flex;
	flex-direction: column;
	gap: .15rem;
}
.gko-event-card .gko-card-row { line-height: 1.4; }
.gko-event-card .gko-card-label {
	color: #888;
	font-weight: 600;
	margin-right: .15em;
}
.gko-event-card .gko-card-sep { color: #555; }
.gko-event-card .gko-card-desc {
	margin: 0;
	font-size: .82rem;
	color: #ccc;
	line-height: 1.45;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.gko-event-card .gko-card-foot {
	margin-top: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
	padding-top: .25rem;
}
.gko-event-card .gko-card-price {
	font-size: .8rem;
	font-weight: 600;
	color: #ddd;
}
.gko-event-card .gko-card-full-badge {
	font-size: .7rem;
	letter-spacing: .04em;
	color: #fca5a5;
	background: rgba(239, 68, 68, .15);
	border: 1px solid rgba(239, 68, 68, .3);
	border-radius: 4px;
	padding: .2rem .55rem;
}
.gko-event-card .gko-card-cta {
	background: #fff;
	color: #000;
	border: none;
	border-radius: 6px;
	padding: .55rem 1.1rem;
	font-size: .8rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background .15s, transform .1s;
	min-height: 40px; /* touch-target på mobil */
}
.gko-event-card .gko-card-cta:hover { background: #ddd; }
.gko-event-card .gko-card-cta:active { transform: scale(.96); }
.gko-event-card .gko-card-cta.gko-card-cta-waitlist {
	background: #f59e0b;
	color: #1a1a1a;
}
.gko-event-card .gko-card-cta.gko-card-cta-waitlist:hover { background: #fbbf24; }
.gko-event-card .gko-card-cta:disabled {
	background: #333;
	color: #888;
	cursor: not-allowed;
}

@media (max-width: 480px) {
	.gko-event-card .gko-card-foot {
		flex-wrap: wrap;
	}
	.gko-event-card .gko-card-cta {
		flex: 1 1 auto;
		min-width: 110px;
		padding: .7rem 1.1rem;
		font-size: .85rem;
	}
}

/* Valt event-rad i formuläret */
.gko-signup-wrap .gko-selected-event:empty { display: none; }
.gko-signup-wrap .gko-selected-event {
	margin: 0 0 .8rem;
	padding: .55rem .8rem;
	background: rgba(16, 185, 129, .1);
	border: 1px solid rgba(16, 185, 129, .25);
	border-radius: 6px;
	font-size: .85rem;
	color: #d1fae5;
}
.gko-signup-wrap .gko-selected-event .gko-selected-label {
	color: #6ee7b7;
	font-weight: 600;
	letter-spacing: .02em;
	text-transform: uppercase;
	font-size: .7rem;
}

/* Formuläret är dolt tills ett event är valt (kort = primärval) */
.gko-signup-wrap .gko-signup-form:not(.gko-form-active) {
	display: none;
}

.gko-signup-form {
	max-width: 480px;
	/* Vänsterställd så formuläret linjerar med sidans rubrik istället för
	   att centreras horisontellt på sidan. */
	margin: 0;
	padding: 1.5rem 1.75rem 2rem;
	background: #000;
	color: #fff;
	border: 1px solid #2a2a2a;
	border-radius: 12px;
	/* Ärv themats font (Ubuntu) — skarpast på alla skärmar. */
	font-family: inherit;
	box-sizing: border-box;
}
.gko-signup-form *, .gko-signup-form *::before, .gko-signup-form *::after {
	box-sizing: border-box;
}

.gko-signup-form form { display: flex; flex-direction: column; gap: 1.1rem; }
.gko-signup-form .gko-field { display: flex; flex-direction: column; gap: .35rem; }
.gko-signup-form .gko-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

.gko-signup-form label {
	font-size: 1rem;
	letter-spacing: .01em;
	text-transform: none;
	color: #fff;
	font-weight: 700;
}

/* !important + -webkit-text-fill-color + caret-color behövs för att övervinna
   både WordPress-temats globala input-styling OCH Chrome/Edge autofill (som
   annars sätter svart text på vit bakgrund och gör fälten omöjliga att läsa
   på vårt mörka tema). */
.gko-signup-form input,
.gko-signup-form select {
	background: #0d0d0d !important;
	color: #fff !important;
	-webkit-text-fill-color: #fff;
	caret-color: #fff;
	border: 1px solid #2a2a2a;
	border-radius: 6px;
	font-family: inherit;
	font-size: .95rem;
	padding: .65rem .9rem;
	outline: none;
	width: 100%;
	-webkit-appearance: none;
	appearance: none;
	box-shadow: none;
}
.gko-signup-form select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	padding-right: 2.5rem;
}
.gko-signup-form input::placeholder { color: #555 !important; -webkit-text-fill-color: #555; }
.gko-signup-form input:focus,
.gko-signup-form select:focus { border-color: #fff; }
.gko-signup-form input[disabled],
.gko-signup-form select[disabled] { opacity: .5; cursor: not-allowed; }

/* Chrome/Edge autofill-fix: när browsern auto-fyller (t.ex. e-postfält
   med sparat värde) lägger den sin egen ljus-bakgrund och svart text.
   Detta hack återställer vårt mörka tema även för autofyllda fält. */
.gko-signup-form input:-webkit-autofill,
.gko-signup-form input:-webkit-autofill:hover,
.gko-signup-form input:-webkit-autofill:focus,
.gko-signup-form input:-webkit-autofill:active {
	-webkit-text-fill-color: #fff !important;
	-webkit-box-shadow: 0 0 0 1000px #0d0d0d inset !important;
	caret-color: #fff !important;
	transition: background-color 5000s ease-in-out 0s;
}

.gko-signup-form .gko-event-details {
	margin: .8rem 0 0;
}
.gko-signup-form .gko-event-details:empty { display: none; }
.gko-signup-form .gko-event-meta {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: .15rem .8rem;
	margin: 0 0 .6rem;
	padding: .65rem .85rem;
	background: rgba(255, 255, 255, .04);
	border: 1px solid #2a2a2a;
	border-radius: 6px;
}
.gko-signup-form .gko-event-meta dt {
	color: #fff;
	font-size: 1rem;
	letter-spacing: .01em;
	text-transform: none;
	font-weight: 700;
	align-self: center;
}
.gko-signup-form .gko-event-meta dd {
	color: #ddd;
	font-size: .95rem;
	font-weight: 400;
	margin: 0;
	align-self: center;
}
.gko-signup-form .gko-event-desc {
	color: #ccc;
	font-size: .85rem;
	line-height: 1.45;
	white-space: pre-wrap;
	padding: .65rem .85rem;
	background: rgba(255, 255, 255, .03);
	border-left: 2px solid #444;
	border-radius: 4px;
}

/* "Lägg till i kalender"-knapp — laddar ner .ics-fil som öppnas i mobil/desktop-kalender */
.gko-signup-form .gko-event-ics {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	margin: .8rem 0 0;
	padding: .55rem 1rem;
	background: rgba(255, 255, 255, .06);
	border: 1px solid #3a3a3a;
	border-radius: 6px;
	color: #fff;
	font-size: .85rem;
	font-weight: 500;
	text-decoration: none;
	transition: background .15s, border-color .15s;
}
.gko-signup-form .gko-event-ics:hover,
.gko-signup-form .gko-event-ics:focus {
	background: rgba(255, 255, 255, .12);
	border-color: #555;
	color: #fff;
}
.gko-signup-form .gko-event-ics svg {
	flex: 0 0 auto;
	opacity: .85;
}

.gko-signup-form .gko-seat-info {
	font-size: .72rem;
	letter-spacing: .04em;
	color: #aaa;
	margin: .2rem 0 0;
	min-height: 1.1em;
}
.gko-signup-form .gko-seat-info.gko-seat-low { color: #f59e0b; }
.gko-signup-form .gko-seat-info.gko-seat-full { color: #ef4444; font-weight: 600; }
.gko-signup-form .gko-seat-info.gko-seat-waitlist {
	color: #f59e0b;
	font-weight: 600;
	font-size: .78rem;
	line-height: 1.4;
	white-space: normal;
}

.gko-signup-form .gko-price-info {
	font-size: .8rem;
	margin: .5rem 0 0;
	display: flex;
	flex-direction: column;
	gap: .25rem;
}
.gko-signup-form .gko-price-info:empty { display: none; }
.gko-signup-form .gko-price-info.gko-price-free {
	font-style: italic;
	color: #888;
}
.gko-signup-form .gko-price-info .gko-price-tag {
	display: inline-block;
	background: rgba(255, 255, 255, .08);
	color: #fff;
	border: 1px solid #2a2a2a;
	border-radius: 6px;
	padding: .35rem .7rem;
	font-weight: 600;
}
.gko-signup-form .gko-price-info .gko-price-tag.gko-price-nonmember {
	background: rgba(255, 255, 255, .03);
	color: #aaa;
}

.gko-signup-form button {
	width: 100%;
	background: #fff;
	color: #000;
	border: none;
	border-radius: 6px;
	font-family: inherit;
	font-size: .9rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	padding: .95rem;
	cursor: pointer;
	margin-top: .25rem;
	transition: background .15s;
}
.gko-signup-form button:hover { background: #ddd; }
.gko-signup-form button:disabled {
	background: #333;
	color: #888;
	cursor: not-allowed;
}

.gko-signup-form .gko-signup-message {
	margin: .25rem 0 0;
	padding: .6rem .8rem;
	border-radius: 6px;
	font-size: .85rem;
	display: none;
}
.gko-signup-form .gko-signup-message.gko-success {
	display: block;
	background: rgba(16, 185, 129, .15);
	color: #6ee7b7;
	border: 1px solid rgba(16, 185, 129, .3);
}
.gko-signup-form .gko-signup-message.gko-error {
	display: block;
	background: rgba(239, 68, 68, .15);
	color: #fca5a5;
	border: 1px solid rgba(239, 68, 68, .3);
}

/* Kontaktperson-block: namn + mobilnummer på den som ansvarar för anmälan */
.gko-signup-form .gko-contact-block {
	padding: .85rem .9rem 1rem;
	background: rgba(255, 255, 255, .03);
	border: 1px solid #2a2a2a;
	border-radius: 8px;
}
.gko-signup-form .gko-contact-header {
	margin-bottom: .55rem;
}
.gko-signup-form .gko-contact-title {
	font-size: .72rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: #888;
	font-weight: 700;
}
.gko-signup-form .gko-contact-subtitle {
	font-weight: 400;
	text-transform: none;
	letter-spacing: 0;
	color: #777;
	margin-left: .35em;
}
.gko-signup-form .gko-contact-block[hidden] {
	display: none;
}
.gko-signup-form .gko-req {
	color: #f59e0b;
	font-weight: 700;
	margin-left: .15em;
}
.gko-signup-form .gko-contact-hint {
	display: block;
	margin-top: .55rem;
	font-size: .72rem;
	line-height: 1.4;
	color: #888;
}

/* Flera deltagare per anmälan (samma email kan registrera fler ungdomar) */
.gko-signup-form .gko-participants {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.gko-signup-form .gko-participant-row {
	padding: .85rem .9rem 1rem;
	background: rgba(255, 255, 255, .03);
	border: 1px solid #2a2a2a;
	border-radius: 8px;
	transition: border-color .15s, background .15s;
}
.gko-signup-form .gko-participant-row.gko-row-error {
	border-color: rgba(239, 68, 68, .55);
	background: rgba(239, 68, 68, .08);
}
.gko-signup-form .gko-participant-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: .55rem;
}
.gko-signup-form .gko-participant-title {
	font-size: .72rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: #888;
	font-weight: 700;
}
.gko-signup-form button.gko-remove-participant {
	width: auto;
	margin: 0;
	padding: .15rem .55rem;
	background: transparent;
	color: #888;
	border: 1px solid #2a2a2a;
	border-radius: 4px;
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: 0;
	text-transform: none;
	line-height: 1;
}
.gko-signup-form button.gko-remove-participant:hover {
	background: rgba(239, 68, 68, .15);
	color: #fca5a5;
	border-color: rgba(239, 68, 68, .35);
}
.gko-signup-form button.gko-remove-participant[hidden] { display: none; }

.gko-signup-form button.gko-add-participant {
	width: auto;
	align-self: flex-start;
	margin: -.3rem 0 0;
	padding: .55rem 1rem;
	background: transparent;
	color: #ddd;
	border: 1px dashed #3a3a3a;
	border-radius: 6px;
	font-size: .8rem;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: none;
}
.gko-signup-form button.gko-add-participant:hover:not(:disabled) {
	background: rgba(255, 255, 255, .05);
	border-color: #555;
	color: #fff;
}
.gko-signup-form button.gko-add-participant:disabled {
	opacity: .4;
	border-style: dashed;
}

.gko-signup-form .gko-email-help {
	display: block;
	margin-top: .3rem;
	font-size: .72rem;
	color: #888;
	line-height: 1.4;
}

@media (max-width: 480px) {
	.gko-signup-form .gko-row { grid-template-columns: 1fr; }
}
