/* ==========================================================================
   Degerfors Musikkår — ny publik startsida (förslag)
   Formspråk: "Konsertprogrammet" — papper, midnattsblått och mässing.
   Typografi: Fraunces (rubriker) + Schibsted Grotesk (brödtext).
   Ingen jQuery, inga mallberoenden. Skriven för sajtens skarpa CSP.
   ========================================================================== */

:root {
	/* Midnattsblått — kårens mörka blå, fördjupad */
	--marin-950: #081226;
	--marin-900: #0c1a36;
	--marin-800: #112647;
	--marin-700: #16315f;

	/* Mässing — hornens metall */
	--massing-200: #f0deb2;
	--massing-300: #e6cd92;
	--massing-400: #d4af66;
	--massing-500: #bb9140;
	--massing-600: #97712a;
	--massing-700: #7a5a20;

	/* Papper & bläck — konsertprogrammet */
	--papper: #f8f3e8;
	--papper-varm: #efe7d3;
	--papper-ljus: #fffdf6;
	--ink: #221f18;
	--ink-mjuk: #5a5341;
	--linje: rgba(34, 31, 24, 0.14);

	/* Oxblod — accent ur gamla sidans mörkröda */
	--oxblod: #7c2730;

	--font-display: "Fraunces", Georgia, "Times New Roman", serif;
	--font-body: "Schibsted Grotesk", "Segoe UI", system-ui, sans-serif;

	--radie: 14px;
	--skugga-mjuk: 0 1px 2px rgba(8, 18, 38, 0.06), 0 8px 28px rgba(8, 18, 38, 0.08);
	--skugga-djup: 0 2px 6px rgba(8, 18, 38, 0.25), 0 24px 60px rgba(8, 18, 38, 0.35);
	--brus: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

/* ---- Grund ---------------------------------------------------------- */

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

html {
	scroll-behavior: smooth;
	scroll-padding-top: 4rem; /* plats för den klistrade toppraden */
}

body {
	margin: 0;
	font-family: var(--font-body);
	font-size: 1.0625rem;
	line-height: 1.65;
	color: var(--ink);
	background: var(--papper);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; display: block; }

h1, h2, h3 {
	font-family: var(--font-display);
	font-weight: 580;
	line-height: 1.12;
	margin: 0 0 0.5em;
	letter-spacing: -0.01em;
	text-wrap: balance;
}

p { margin: 0 0 1em; }

a { color: var(--massing-700); text-decoration-color: rgba(151, 113, 42, 0.4); text-underline-offset: 0.18em; }
a:hover { color: var(--massing-600); }

::selection { background: var(--massing-300); color: var(--ink); }

:focus-visible {
	outline: 3px solid var(--massing-600);
	outline-offset: 2px;
	border-radius: 2px;
}

.visually-hidden {
	position: absolute; width: 1px; height: 1px;
	margin: -1px; padding: 0; overflow: hidden;
	clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

.hoppa-lank {
	position: absolute; left: 1rem; top: -4rem; z-index: 100;
	background: var(--massing-300); color: var(--ink);
	padding: 0.7em 1.2em; border-radius: 0 0 10px 10px;
	font-weight: 700; text-decoration: none;
	transition: top 0.2s ease;
}
.hoppa-lank:focus { top: 0; }

/* Skip-länkens mål ska kunna ta emot tangentbordsfokus utan jätteram runt main. */
main:focus { outline: none; }

/* ---- Återkommande byggstenar ---------------------------------------- */

.sektion { position: relative; padding: clamp(4rem, 9vw, 7rem) 0; }
.sektion--papper { background: var(--papper); }
.sektion--varm   { background: var(--papper-varm); background-image: var(--brus); }
.sektion--marin  { background: var(--marin-900); background-image: var(--brus); color: var(--papper); }

.sektion-inre {
	max-width: 1140px;
	margin: 0 auto;
	padding: 0 clamp(1.25rem, 5vw, 2.5rem);
}
.sektion-inre.smal { max-width: 900px; }

.sektionshuvud { text-align: center; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.sektionshuvud h2 { font-size: clamp(2rem, 4.5vw, 3rem); }
.sektionshuvud-ingress { max-width: 46ch; margin: 1rem auto 0; color: var(--ink-mjuk); }

/* Liten versalrad med mässingsstreck före rubriker */
.overrad {
	display: inline-flex; align-items: center; gap: 0.65em;
	font-size: 0.78rem; font-weight: 700;
	letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--massing-700); /* mörkare guld → ≥4.5:1 mot ljust papper (WCAG 1.4.3) */
	margin: 0 0 1rem;
}
.overrad-streck { width: 2em; height: 2px; background: var(--massing-500); display: inline-block; }
.overrad--ljus { color: var(--massing-300); }
.overrad--ljus .overrad-streck { background: var(--massing-400); }

/* Programornament: linje med romb i mitten  ——◆—— */
.ornament { position: relative; width: 140px; height: 9px; margin: 1.1rem auto 0; }
.ornament::before {
	content: ""; position: absolute; inset: 4px 0;
	background: linear-gradient(90deg, transparent, var(--massing-500) 18%, var(--massing-500) 82%, transparent);
	height: 1px;
}
.ornament::after {
	content: ""; position: absolute; left: 50%; top: 50%;
	width: 7px; height: 7px; background: var(--massing-500);
	transform: translate(-50%, -50%) rotate(45deg);
}

/* Knappar */
.knapp {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 0.95rem; font-weight: 700;
	letter-spacing: 0.04em;
	padding: 0.85em 1.7em;
	border-radius: 999px;
	border: 1px solid transparent;
	text-decoration: none;
	cursor: pointer;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background-position 0.4s ease, border-color 0.18s ease;
}
.knapp--massing {
	background: linear-gradient(115deg, var(--massing-200) 0%, var(--massing-400) 45%, var(--massing-500) 100%);
	background-size: 160% 100%;
	color: var(--marin-950);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45), 0 2px 10px rgba(8, 18, 38, 0.2);
}
.knapp--massing:hover {
	background-position: 90% 0;
	transform: translateY(-2px);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45), 0 8px 20px rgba(8, 18, 38, 0.28);
	color: var(--marin-950);
}
.knapp--kontur {
	border-color: rgba(230, 205, 146, 0.55);
	color: var(--massing-200);
	background: rgba(230, 205, 146, 0.06);
}
.knapp--kontur:hover { border-color: var(--massing-300); background: rgba(230, 205, 146, 0.14); transform: translateY(-2px); color: var(--massing-200); }
.knapp--liten { padding: 0.5em 1.1em; font-size: 0.85rem; }

/* Flashbesked (ersätter gamla alert()-rutan) */
.flash {
	position: sticky; top: 0; z-index: 60;
	background: var(--massing-300); color: var(--ink);
	border-bottom: 1px solid var(--massing-500);
}
.flash-inre {
	max-width: 1140px; margin: 0 auto;
	padding: 0.7rem clamp(1.25rem, 5vw, 2.5rem);
	display: flex; align-items: center; justify-content: space-between; gap: 1rem;
	font-weight: 600;
}
.flash-stang {
	border: 0; background: none; font-size: 1.4rem; line-height: 1;
	cursor: pointer; color: inherit; padding: 0 0.2em;
}

/* ---- Topprad / navigering ------------------------------------------- */

.topp {
	position: sticky; top: 0; z-index: 50;
	background: rgba(8, 18, 38, 0.92);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-bottom: 1px solid rgba(230, 205, 146, 0.16);
	transition: box-shadow 0.25s ease;
}
.topp--skuggad { box-shadow: 0 6px 24px rgba(8, 18, 38, 0.45); }

.topp-inre {
	max-width: 1240px; margin: 0 auto;
	padding: 0.65rem clamp(1.25rem, 4vw, 2.5rem);
	display: flex; align-items: center; gap: 1.5rem;
}

.topp-logga {
	display: flex; align-items: center; gap: 0.75rem;
	text-decoration: none; color: var(--papper);
	margin-right: auto;
}
.topp-logga img { display: block; } /* loggan har egen guldring – ingen platta bakom */
.topp-namn {
	font-family: var(--font-display);
	font-size: 1.18rem; font-weight: 620; letter-spacing: 0.01em;
	display: flex; flex-direction: column; line-height: 1.05;
}
.topp-namn em { font-style: italic; font-weight: 420; color: var(--massing-300); }

.huvudnav ul {
	list-style: none; margin: 0; padding: 0;
	display: flex; align-items: center; gap: clamp(0.4rem, 1.4vw, 1.4rem);
}
.huvudnav a:not(.knapp) {
	color: rgba(248, 243, 232, 0.85);
	text-decoration: none;
	font-size: 0.95rem; font-weight: 600;
	padding: 0.4em 0.35em;
	border-bottom: 2px solid transparent;
	transition: color 0.15s ease, border-color 0.15s ease;
}
.huvudnav a:not(.knapp):hover { color: var(--massing-300); border-bottom-color: var(--massing-400); }
.huvudnav .knapp--liten { border: 1px solid rgba(230, 205, 146, 0.55); color: var(--massing-200); text-decoration: none; }
.huvudnav .knapp--liten:hover { background: rgba(230, 205, 146, 0.14); }

.nav-knapp { display: none; }

/* ---- Hjälten ---------------------------------------------------------- */

.hero {
	position: relative;
	background:
		radial-gradient(1100px 500px at 85% -10%, rgba(22, 49, 95, 0.85), transparent 60%),
		linear-gradient(168deg, var(--marin-950) 0%, var(--marin-900) 45%, var(--marin-800) 100%);
	color: var(--papper);
	overflow: hidden;
}
.hero::after { /* kornighet över hela hjälten */
	content: ""; position: absolute; inset: 0;
	background-image: var(--brus);
	pointer-events: none;
}

/* Notlinjer: fem tunna linjer i grupp, tonas ut åt höger */
.hero-notlinjer, .fot-notlinjer {
	position: absolute; inset: 0;
	background: repeating-linear-gradient(
		to bottom,
		transparent 0 18px,
		rgba(230, 205, 146, 0.16) 18px 19px,
		transparent 19px 37px,
		rgba(230, 205, 146, 0.16) 37px 38px,
		transparent 38px 56px,
		rgba(230, 205, 146, 0.16) 56px 57px,
		transparent 57px 75px,
		rgba(230, 205, 146, 0.16) 75px 76px,
		transparent 76px 94px,
		rgba(230, 205, 146, 0.16) 94px 95px,
		transparent 95px 220px
	);
	-webkit-mask-image: linear-gradient(100deg, rgba(0,0,0,0.9), transparent 55%);
	mask-image: linear-gradient(100deg, rgba(0,0,0,0.9), transparent 55%);
	pointer-events: none;
}

/* Kårens emblem som svagt sigill i bakgrunden */
.hero-emblem {
	position: absolute; right: -120px; top: 50%;
	width: 560px; height: 560px;
	transform: translateY(-50%);
	background: url("../../images/dmk_logga_400.png") center / contain no-repeat;
	opacity: 0.07;
	filter: grayscale(1) brightness(2.4);
	pointer-events: none;
}

.hero-inre {
	position: relative; z-index: 1;
	max-width: 1140px; margin: 0 auto;
	padding: clamp(4.5rem, 10vw, 8rem) clamp(1.25rem, 5vw, 2.5rem) clamp(4rem, 9vw, 7rem);
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
	gap: clamp(2.5rem, 6vw, 5rem);
	align-items: center;
}

.hero h1 {
	font-size: clamp(2.5rem, 5.6vw, 4.3rem);
	font-weight: 540;
	margin-bottom: 0.45em;
}
.hero h1 em {
	font-style: italic; font-weight: 420;
	color: var(--massing-300);
}

.hero-ingress {
	font-size: clamp(1.05rem, 1.6vw, 1.2rem);
	color: rgba(248, 243, 232, 0.82);
	max-width: 50ch;
	margin-bottom: 2rem;
}

.hero-knappar { display: flex; flex-wrap: wrap; gap: 0.9rem; }

/* Intro-animation: stegvis uppåtton */
@keyframes ton-upp {
	from { opacity: 0; transform: translateY(26px); }
	to   { opacity: 1; transform: none; }
}
.anim   { animation: ton-upp 0.85s cubic-bezier(0.2, 0.7, 0.2, 1) both; }
.anim-1 { animation-delay: 0.05s; }
.anim-2 { animation-delay: 0.16s; }
.anim-3 { animation-delay: 0.28s; }
.anim-4 { animation-delay: 0.4s; }
.anim-5 { animation-delay: 0.52s; }

/* ---- Biljetten: nästa spelning -------------------------------------- */

.hero-sida { display: grid; gap: 1.4rem; justify-items: stretch; }

.biljett {
	position: relative;
	background:
		linear-gradient(180deg, var(--papper-ljus), var(--papper));
	color: var(--ink);
	border-radius: 12px;
	padding: 1.5rem 1.7rem 0;
	box-shadow: var(--skugga-djup);
	transform: rotate(-1.6deg);
	transition: transform 0.3s cubic-bezier(0.2, 0.7, 0.2, 1), box-shadow 0.3s ease;
}
.biljett:hover { transform: rotate(0deg) translateY(-3px); }

.biljett-topp {
	display: flex; align-items: center; justify-content: space-between;
	border-bottom: 1px solid var(--linje);
	padding-bottom: 0.8rem; margin-bottom: 1.1rem;
}
.biljett-etikett {
	font-size: 0.72rem; font-weight: 800;
	letter-spacing: 0.26em; text-transform: uppercase;
	color: var(--oxblod);
}
.biljett-not { color: var(--massing-600); }

.biljett-datum {
	font-family: var(--font-display);
	font-size: clamp(2rem, 3.4vw, 2.7rem);
	font-weight: 600; line-height: 1.05;
	margin: 0 0 0.2em;
}
.biljett-datum--tom { font-size: 1.7rem; }
.biljett-veckodag {
	font-size: 0.95rem; font-weight: 600;
	color: var(--ink-mjuk);
	letter-spacing: 0.02em;
	margin: 0 0 0.9em;
}
.biljett-rubrik {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1.25rem;
	margin: 0 0 0.5em;
}
.biljett-plats {
	display: flex; align-items: center; gap: 0.45em;
	font-size: 0.95rem; color: var(--ink-mjuk);
	margin: 0 0 1em;
}
.biljett-plats svg { color: var(--massing-600); flex: none; }

.biljett-lank { font-weight: 700; font-size: 0.95rem; display: inline-block; margin-bottom: 1.2rem; }

/* Perforering + "streckkod" i biljettens nederkant */
.biljett-streckkod {
	position: relative;
	border-top: 2px dashed rgba(34, 31, 24, 0.25);
	margin: 0 -1.7rem;
	padding: 0.8rem 1.7rem 0.9rem;
	text-align: center;
}
.biljett-streckkod::before, .biljett-streckkod::after {
	content: ""; position: absolute; top: -9px;
	width: 16px; height: 16px; border-radius: 50%;
	background: var(--marin-800); /* "hålslag" i kanten, samma ton som fonden */
	box-shadow: inset 0 1px 2px rgba(8, 18, 38, 0.5);
}
.biljett-streckkod::before { left: -8px; }
.biljett-streckkod::after  { right: -8px; }

.biljett-streckkod span {
	display: block;
	height: 26px;
	background-image:
		repeating-linear-gradient(90deg, var(--ink) 0 2px, transparent 2px 5px),
		repeating-linear-gradient(90deg, var(--ink) 0 1px, transparent 1px 9px);
	opacity: 0.72;
	overflow: hidden;
	color: transparent; /* texten finns för skärmläsare/karaktär, bilden är koden */
}

/* Anslag: nålad lapp under biljetten */
.anslag {
	position: relative;
	background: var(--papper-varm);
	background-image: var(--brus);
	color: var(--ink);
	border-radius: 10px;
	padding: 1.3rem 1.4rem 0.9rem;
	box-shadow: var(--skugga-djup);
	transform: rotate(1.1deg);
	font-size: 0.95rem;
}
.anslag p { margin: 0; }
.anslag strong { font-family: var(--font-display); font-size: 1.08em; }
.anslag-nal {
	position: absolute; top: -7px; left: 50%;
	width: 14px; height: 14px; border-radius: 50%;
	transform: translateX(-50%);
	background: radial-gradient(circle at 35% 30%, var(--massing-200), var(--massing-600) 70%);
	box-shadow: 0 2px 4px rgba(8, 18, 38, 0.45);
}

/* ---- Spelplanen ------------------------------------------------------- */

.program { list-style: none; margin: 0; padding: 0; }

.program-rad {
	display: grid;
	grid-template-columns: 92px 1fr;
	gap: 1.6rem;
	align-items: center;
	padding: 1.3rem 1rem;
	border-bottom: 1px solid var(--linje);
	border-left: 3px solid transparent;
	transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.program-rad:first-child { border-top: 1px solid var(--linje); }
.program-rad:hover {
	background: var(--papper-varm);
	border-left-color: var(--massing-500);
	transform: translateX(4px);
}

.program-datum { text-align: center; }
.program-dag {
	display: block;
	font-family: var(--font-display);
	font-size: 2.4rem; font-weight: 600; line-height: 1;
	color: var(--massing-600);
}
.program-manad {
	display: block;
	font-size: 0.78rem; font-weight: 700;
	letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--ink-mjuk);
	margin-top: 0.3em;
}

.program-meta {
	display: flex; flex-wrap: wrap; align-items: center; gap: 0.5em 1.1em;
	font-size: 0.85rem; font-weight: 600;
	letter-spacing: 0.06em; text-transform: uppercase;
	color: var(--ink-mjuk);
	margin: 0 0 0.25em;
}
.program-plats::before { content: "◆"; font-size: 0.55em; color: var(--massing-500); margin-right: 0.9em; vertical-align: 0.2em; }
.program-chip {
	background: var(--oxblod); color: var(--papper);
	font-size: 0.7rem; font-weight: 800;
	letter-spacing: 0.16em;
	padding: 0.25em 0.8em; border-radius: 999px;
}
.program-rubrik {
	font-size: clamp(1.2rem, 2.4vw, 1.55rem);
	font-weight: 560;
	margin: 0;
}

.tom-text { text-align: center; color: var(--ink-mjuk); max-width: 52ch; margin: 0 auto; }
.sektion-fotnot { text-align: center; color: var(--ink-mjuk); font-size: 0.95rem; margin: 2.2rem 0 0; }

/* ---- Korten: anlita / spela / noter ---------------------------------- */

.kortrad {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
	gap: 1.6rem;
}

.kort {
	position: relative;
	background: var(--papper-ljus);
	border: 1px solid var(--linje);
	border-radius: var(--radie);
	padding: 2rem 1.8rem 1.6rem;
	box-shadow: var(--skugga-mjuk);
	overflow: hidden;
	transition: transform 0.25s cubic-bezier(0.2, 0.7, 0.2, 1), box-shadow 0.25s ease;
}
.kort::before { /* mässingslist som växer fram upptill */
	content: ""; position: absolute; inset: 0 0 auto 0; height: 3px;
	background: linear-gradient(90deg, var(--massing-300), var(--massing-500));
	transform: scaleX(0); transform-origin: left;
	transition: transform 0.35s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.kort:hover { transform: translateY(-5px); box-shadow: 0 4px 8px rgba(8,18,38,0.08), 0 18px 44px rgba(8,18,38,0.14); }
.kort:hover::before { transform: scaleX(1); }

.kort-ikon {
	width: 54px; height: 54px;
	display: grid; place-items: center;
	border-radius: 50%;
	background: var(--massing-200);
	color: var(--massing-700);
	margin-bottom: 1.2rem;
}
.kort h3 { font-size: 1.45rem; margin-bottom: 0.4em; }
.kort p { color: var(--ink-mjuk); font-size: 0.98rem; }
.kort-lank { font-weight: 700; font-size: 0.95rem; text-decoration: none; border-bottom: 2px solid var(--massing-400); padding-bottom: 0.1em; }
.kort-lank:hover { border-bottom-color: var(--massing-600); }

.kort--noter .kort-bild {
	width: 150px;
	border: 5px solid #fff;
	outline: 1px solid var(--linje);
	box-shadow: var(--skugga-mjuk);
	transform: rotate(-2deg);
	margin: 0 0 1.2rem 0.2rem;
}

/* ---- Stödmedlem ------------------------------------------------------- */

.sektion--marin .sektionshuvud h2, .stod-text h2 { color: var(--papper); }

.stod-rad {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(330px, 0.9fr);
	gap: clamp(2.5rem, 6vw, 5rem);
	align-items: start;
}

.stod-text h2 { font-size: clamp(2.1rem, 4.5vw, 3.1rem); }
.stod-text h2 em { font-style: italic; color: var(--massing-300); font-weight: 460; }
.stod-text p { color: rgba(248, 243, 232, 0.85); max-width: 54ch; }
.stod-text strong { color: var(--papper); }

.stod-notis {
	display: flex; gap: 0.9rem; align-items: flex-start;
	border: 1px solid rgba(230, 205, 146, 0.4);
	border-radius: 10px;
	padding: 1rem 1.2rem;
	background: rgba(230, 205, 146, 0.07);
	margin-top: 1.8rem;
	max-width: 54ch;
}
.stod-notis svg { color: var(--massing-300); flex: none; margin-top: 0.15em; }
.stod-notis p { margin: 0; font-size: 0.95rem; color: rgba(248, 243, 232, 0.85); }
.stod-notis strong { color: var(--massing-200); }

.stod-form {
	background: var(--papper-ljus);
	color: var(--ink);
	border-radius: var(--radie);
	padding: 2rem 1.9rem;
	box-shadow: var(--skugga-djup);
}
.stod-form h3 { font-size: 1.5rem; }
.stod-resultat { margin-top: 1.2rem; }

.stod-kvitto {
	background: var(--papper-ljus);
	color: var(--ink);
	border-radius: var(--radie);
	border: 1px solid var(--massing-400);
	padding: 1.6rem 1.7rem;
	box-shadow: var(--skugga-djup);
}
.stod-kvitto h4 { font-family: var(--font-display); font-size: 1.3rem; margin: 0 0 0.5em; }
.stod-kvitto img { margin: 0.8rem auto 0; }
.stod-kvitto .betalrad { font-family: var(--font-display); font-size: 1.15rem; font-weight: 600; }

/* ---- Formulärfält ----------------------------------------------------- */

.falt { margin: 0 0 1.1rem; }
.falt label {
	display: block;
	font-size: 0.78rem; font-weight: 700;
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--ink-mjuk);
	margin-bottom: 0.4em;
}
.falt .valfri { text-transform: none; letter-spacing: 0; font-weight: 500; }

.falt input[type="text"], .falt input[type="email"], .falt input[type="tel"], .falt textarea,
.kontakt-form input[type="text"], .kontakt-form input[type="email"], .kontakt-form textarea {
	width: 100%;
	font: inherit;
	color: var(--ink);
	background: #fff;
	border: 1px solid var(--linje);
	border-radius: 9px;
	padding: 0.65em 0.85em;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.falt input:focus, .falt textarea:focus,
.kontakt-form input:focus, .kontakt-form textarea:focus {
	outline: none;
	border-color: var(--massing-500);
	box-shadow: 0 0 0 3px rgba(212, 175, 102, 0.3);
}

.falt-rad { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.falt-rad .falt { margin-bottom: 1.1rem; }

.falt--kryss { display: flex; gap: 0.7em; align-items: flex-start; }
.falt--kryss input { width: 1.15em; height: 1.15em; margin-top: 0.2em; accent-color: var(--massing-600); flex: none; }
.falt--kryss label {
	text-transform: none; letter-spacing: 0;
	font-size: 0.88rem; font-weight: 500;
	color: var(--ink-mjuk); margin: 0;
}

.falt--hemlig { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.falt-fel {
	background: rgba(124, 39, 48, 0.1);
	color: var(--oxblod);
	border: 1px solid rgba(124, 39, 48, 0.35);
	border-radius: 9px;
	padding: 0.7em 1em;
	font-weight: 600; font-size: 0.95rem;
}

/* ---- Historia --------------------------------------------------------- */

.historia-text { max-width: 68ch; margin: 0 auto; }
.historia-text .anfang::first-letter {
	font-family: var(--font-display);
	float: left;
	font-size: 3.9em; line-height: 0.8;
	font-weight: 600;
	color: var(--massing-600);
	padding: 0.08em 0.12em 0 0;
}

.historia-detaljer { max-width: 68ch; margin: 1.5rem auto 0; }
.historia-detaljer summary {
	list-style: none;
	display: flex; align-items: center; justify-content: center; gap: 0.8em;
	cursor: pointer;
	font-weight: 700; font-size: 0.95rem;
	letter-spacing: 0.08em; text-transform: uppercase;
	color: var(--massing-700);
	border: 1px solid var(--massing-500);
	border-radius: 999px;
	padding: 0.8em 1.6em;
	width: fit-content;
	margin: 0 auto;
	transition: background 0.2s ease, color 0.2s ease;
}
.historia-detaljer summary::-webkit-details-marker { display: none; }
.historia-detaljer summary:hover { background: var(--massing-200); }

.historia-summary-ikon { position: relative; width: 14px; height: 14px; }
.historia-summary-ikon::before, .historia-summary-ikon::after {
	content: ""; position: absolute; background: currentColor;
	transition: transform 0.25s ease;
}
.historia-summary-ikon::before { inset: 6px 0; }
.historia-summary-ikon::after { inset: 0 6px; }
.historia-detaljer[open] .historia-summary-ikon::after { transform: scaleY(0); }
.historia-detaljer[open] summary .historia-summary-text::after { content: " – dölj"; text-transform: none; }

.historia-innehall { padding-top: 2.5rem; }
.historia-innehall p { margin-bottom: 1.2em; }
.historia-innehall h3 {
	font-size: 1.6rem;
	margin: 2em 0 0.8em;
	padding-top: 1.2em;
	border-top: 1px solid var(--linje);
}

.historia-innehall figure { margin: 2.2rem auto; text-align: center; }
.historia-innehall figure img {
	display: inline-block;
	border: 6px solid #fff;
	outline: 1px solid var(--linje);
	box-shadow: var(--skugga-mjuk);
	transform: rotate(-0.8deg);
}
.historia-innehall figure:nth-of-type(even) img { transform: rotate(0.8deg); }
.historia-innehall figcaption {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 0.95rem;
	color: var(--ink-mjuk);
	margin-top: 0.8em;
}

.tabell-fotnot { color: var(--ink-mjuk); font-size: 0.9rem; }
.tabell-rad { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.tabell-rad table { width: 100%; border-collapse: collapse; }
.tabell-rad caption {
	font-family: var(--font-display);
	font-size: 1.2rem; font-weight: 600;
	text-align: left;
	padding-bottom: 0.4em;
	border-bottom: 2px solid var(--massing-500);
	margin-bottom: 0.4em;
}
.tabell-rad td { padding: 0.45em 0.6em 0.45em 0; border-bottom: 1px solid var(--linje); font-size: 0.98rem; }
.tabell-rad td:first-child { white-space: nowrap; color: var(--ink-mjuk); width: 7.5em; }

/* ---- Länkar ----------------------------------------------------------- */

.lank-lista {
	list-style: none; margin: 0; padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.3rem;
}
.lank-kort {
	position: relative;
	background: var(--papper-ljus);
	border: 1px solid var(--linje);
	border-left: 3px solid var(--massing-500);
	border-radius: 10px;
	padding: 1.2rem 1.4rem;
	box-shadow: var(--skugga-mjuk);
}
.lank-rubrik { font-weight: 700; text-decoration: none; }
.lank-anm { color: var(--ink-mjuk); font-size: 0.92rem; margin: 0.4em 0 0; }

/* Osäker-flagga: länkar som väntar på styrelsens granskning. */
.lank-kort--osaker { border-left-color: var(--oxblod); }
.lank-status {
	display: inline-block; margin: 0.5em 0 0.1em;
	font-size: 0.76rem; font-weight: 700; letter-spacing: 0.03em;
	color: var(--oxblod);
	background: rgba(124, 39, 48, 0.1);
	border: 1px solid rgba(124, 39, 48, 0.35);
	border-radius: 999px; padding: 0.2em 0.8em;
}
.lank-bilder { display: flex; gap: 0.7rem; margin-top: 0.9rem; }
.lank-bilder img { width: 90px; border: 3px solid #fff; outline: 1px solid var(--linje); box-shadow: var(--skugga-mjuk); }

.lank-radera { position: absolute; top: 0.6rem; right: 0.6rem; margin: 0; }
.lank-radera-knapp {
	width: 1.7em; height: 1.7em;
	border: 1px solid rgba(124, 39, 48, 0.4);
	border-radius: 50%;
	background: none; color: var(--oxblod);
	font-size: 0.95rem; line-height: 1;
	cursor: pointer;
}
.lank-radera-knapp:hover { background: var(--oxblod); color: var(--papper); }

.lank-form {
	margin-top: 2.5rem;
	background: var(--papper-ljus);
	border: 1px dashed var(--massing-500);
	border-radius: var(--radie);
	padding: 1.8rem;
}
.lank-form h3 { font-size: 1.3rem; }

/* ---- Kontakt ---------------------------------------------------------- */

.kontakt-form { max-width: 640px; margin: 0 auto; }

.kvitto {
	max-width: 560px; margin: 0 auto;
	text-align: center;
	background: var(--papper-ljus);
	border: 1px solid var(--massing-400);
	border-radius: var(--radie);
	padding: 2.5rem 2rem;
	box-shadow: var(--skugga-mjuk);
}
.kvitto svg { color: var(--massing-600); margin: 0 auto 0.8rem; }
.kvitto h3 { font-size: 1.7rem; }
.kvitto p { color: var(--ink-mjuk); margin: 0; }

/* ---- Sidfot ----------------------------------------------------------- */

.fot {
	position: relative;
	background: var(--marin-950);
	background-image: var(--brus);
	color: rgba(248, 243, 232, 0.78);
	overflow: hidden;
}
.fot-notlinjer { opacity: 0.5; }
.fot a { color: rgba(248, 243, 232, 0.85); text-decoration: none; }
.fot a:hover { color: var(--massing-300); }

.fot-inre {
	position: relative;
	max-width: 1140px; margin: 0 auto;
	padding: clamp(3rem, 6vw, 4.5rem) clamp(1.25rem, 5vw, 2.5rem) 2rem;
	display: grid;
	grid-template-columns: 1.2fr 1fr 1fr;
	gap: 2.5rem;
}

.fot-kolumn--namn img { margin-bottom: 1rem; } /* loggans guldring är kanten – ingen platta */
.fot-namn { font-family: var(--font-display); font-size: 1.3rem; font-weight: 620; color: var(--papper); margin-bottom: 0.2em; }
.fot-tagline { font-style: italic; font-family: var(--font-display); color: var(--massing-300); }

.fot-rubrik {
	font-size: 0.75rem; font-weight: 800;
	letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--massing-400);
	margin-bottom: 0.9em;
}
.fot-kolumn ul { list-style: none; margin: 0; padding: 0; }
.fot-kolumn li { margin-bottom: 0.45em; }

.fot-some { display: flex; gap: 0.7rem; }
.fot-some li { margin: 0; }
.fot-some a {
	display: grid; place-items: center;
	width: 42px; height: 42px;
	border: 1px solid rgba(230, 205, 146, 0.4);
	border-radius: 50%;
	color: var(--massing-300);
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}
.fot-some a:hover { background: var(--massing-400); color: var(--marin-950); transform: translateY(-2px); }
.fot-rep { font-size: 0.9rem; margin-top: 1.2rem; }

.fot-botten {
	position: relative;
	border-top: 1px solid rgba(230, 205, 146, 0.16);
	text-align: center;
	padding: 1.2rem;
	font-size: 0.88rem;
}
.fot-botten p { margin: 0; }

/* ---- Uppenbarelser vid skroll ---------------------------------------- */

html.har-js .reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.7s ease, transform 0.7s cubic-bezier(0.2, 0.7, 0.2, 1);
}
html.har-js .reveal.syns { opacity: 1; transform: none; }

/* ---- Rörelsekänslighet ------------------------------------------------ */

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	.anim, html.har-js .reveal { animation: none; transition: none; opacity: 1; transform: none; }
	.biljett { transform: none; }
	*, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ---- Mindre skärmar --------------------------------------------------- */

@media (max-width: 980px) {
	.hero-inre { grid-template-columns: 1fr; }
	.hero-emblem { right: -200px; opacity: 0.05; }
	.hero-sida { max-width: 460px; }
	.stod-rad { grid-template-columns: 1fr; }
	.fot-inre { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 860px) {
	.nav-knapp {
		display: inline-flex; flex-direction: column; justify-content: center; gap: 5px;
		width: 46px; height: 42px;
		padding: 0 11px;
		background: none;
		border: 1px solid rgba(230, 205, 146, 0.4);
		border-radius: 9px;
		cursor: pointer;
	}
	.nav-knapp-rad {
		display: block; height: 2px; width: 100%;
		background: var(--massing-300);
		border-radius: 2px;
		transition: transform 0.25s ease, opacity 0.2s ease;
	}
	.nav-knapp[aria-expanded="true"] .nav-knapp-rad:nth-child(1) { transform: translateY(7px) rotate(45deg); }
	.nav-knapp[aria-expanded="true"] .nav-knapp-rad:nth-child(2) { opacity: 0; }
	.nav-knapp[aria-expanded="true"] .nav-knapp-rad:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

	.huvudnav {
		position: fixed;
		top: 0; left: 0; right: 0;
		padding: 5.2rem 1.5rem 2rem;
		background: var(--marin-950);
		border-bottom: 1px solid rgba(230, 205, 146, 0.25);
		box-shadow: 0 30px 60px rgba(8, 18, 38, 0.5);
		transform: translateY(-105%);
		visibility: hidden; /* stängd meny får inte gå att tabba in i (WCAG 2.4.3) */
		transition: transform 0.3s cubic-bezier(0.2, 0.7, 0.2, 1), visibility 0s linear 0.3s;
		z-index: 40;
	}
	body.nav-oppen .huvudnav { transform: none; visibility: visible; transition: transform 0.3s cubic-bezier(0.2, 0.7, 0.2, 1), visibility 0s; }
	.huvudnav ul { flex-direction: column; align-items: stretch; gap: 0.2rem; }
	.huvudnav a:not(.knapp) { display: block; font-size: 1.15rem; padding: 0.6em 0.2em; border-bottom: 1px solid rgba(230, 205, 146, 0.12); }
	.huvudnav .knapp--liten { margin-top: 1rem; text-align: center; display: block; }
	.topp { z-index: 50; }
	.topp-inre { position: relative; z-index: 50; }
}

@media (max-width: 640px) {
	body { font-size: 1rem; }
	.falt-rad { grid-template-columns: 1fr; gap: 0; }
	.program-rad { grid-template-columns: 64px 1fr; gap: 1rem; padding: 1.1rem 0.6rem; }
	.program-dag { font-size: 1.9rem; }
	.tabell-rad { grid-template-columns: 1fr; }
	.fot-inre { grid-template-columns: 1fr; gap: 2rem; }
	.biljett { transform: rotate(-1deg); }
	.hero-knappar .knapp { width: 100%; text-align: center; }
}
