/* ============================================================================
   Mysteerikurssi.com — julkisen puolen moderni ulkoasukerros
   ----------------------------------------------------------------------------
   - Sivuston "kromi" (header / valikko / footer) tyylitellään globaalisti.
   - KAIKKI sisältötyylit on aidattu `body.mk-modern`-luokan taakse. Luokka
     lisataan jokaiselle sivulle PAITSI geokätkö-sivupohjille
     (geocachepage.php / testi_sivu.php) — ks. functions.php. Näin
     geokätkösivut säilyttävät tarkalleen nykyisen ulkoasunsa.
   - Tämä tiedosto ladataan evolven inline-customizer-CSS:n JÄLKEEN
     (riippuvuus: evolve-style), joten suurin osa säännöistä voittaa ilman
     raskasta !important-käyttöä. !important on mukana vain siellä, missä
     evolve käyttää sitä itse tai inline-tyyli vaatii ylikirjoituksen.
   ========================================================================== */

:root {
	/* Lämmin "paperi + tiiliruskea" -paletti (ks. layout-prototyyppi, vaihtoehto 3).
	   HUOM: nämä muuttujat vaikuttavat vain modern-kerrokseen — geokätkösivut eivät
	   käytä --mk-accent-värejä eivätkä mk-modern-taustaa, joten ne pysyvät ennallaan. */
	--mk-bg:          #f6f4ee;
	--mk-surface:     #ffffff;
	--mk-ink:         #222222;
	--mk-text:        #3f4754;
	--mk-muted:       #6b7280;
	--mk-border:      #e7e2d6;
	--mk-accent:      #a62b0c;
	--mk-accent-600:  #872207;
	--mk-accent-50:   #f6e7e1;
	--mk-header:      #1b2430;
	--mk-cream:       #f3f0e7;
	--mk-radius:      14px;
	--mk-radius-sm:   10px;
	--mk-shadow:      0 1px 2px rgba(16, 24, 40, .04), 0 4px 16px rgba(16, 24, 40, .06);
	--mk-shadow-lg:   0 14px 34px rgba(16, 24, 40, .13);
	--mk-font:        'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

/* ===========================================================================
   1. SIVUSTON KROMI (globaali — koskee myös geokätkösivuja, sallittu:
      "valikot voivat päivittyä")
   ========================================================================= */

/* --- Ylätunniste: yhtenäinen tumma palkki logolle ja valikolle --- */
.header-v1 .header-pattern,
.header-v1 .menu-header,
.sticky-header {
	background-color: var(--mk-header) !important;
}

.header-v1 .header {
	padding-top: 16px;
	padding-bottom: 16px;
}

.header-logo-container img {
	max-height: 80px;
	width: auto;
}

#tagline {
	color: #9aa6b6 !important;
	font-family: var(--mk-font) !important;
	font-size: 1rem !important;
	font-weight: 400 !important;
	letter-spacing: .01em;
}

/* Tyhjä tumma gradienttikaista headerin alla pois — turha visuaalinen saumat */
.header-block {
	display: none !important;
}

/* --- Valikko --- */
.menu-header {
	border-top: 1px solid rgba(255, 255, 255, .06);
}

.menu-header .navbar-nav .nav-link,
a.nav-link {
	color: #d7dce4 !important;
	font-family: var(--mk-font) !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	padding: .55rem .9rem !important;
	border-radius: 8px;
	transition: color .15s ease, background-color .15s ease;
}

.menu-header .navbar-nav .nav-link:hover,
a.nav-link:hover {
	color: #ffffff !important;
	background-color: rgba(255, 255, 255, .08);
}

.navbar-nav li.menu-item.current-menu-item > a,
.navbar-nav li.menu-item.current-menu-parent > a,
.navbar-nav li.menu-item.current-menu-ancestor > a {
	color: #ffffff !important;
}

/* --- Haku ylätunnisteessa --- */
.header-v1 .header-search .form-control {
	background-color: rgba(255, 255, 255, .08) !important;
	border-color: transparent !important;
	color: #e5e7eb !important;
	border-radius: 8px;
}

.header-v1 .header-search .form-control::placeholder {
	color: #9aa6b6 !important;
}

.menu-header .icon-search,
.menu-header svg {
	color: #9aa6b6;
}

.navbar-toggler {
	color: #ffffff !important;
	border: 1px solid rgba(255, 255, 255, .25) !important;
	border-radius: 8px;
}

.navbar-toggler .icon-menu {
	color: #ffffff;
}

/* Mobiili: pudotusvalikko pysyy tummalla taustalla, vaalea teksti näkyy */
@media (max-width: 767.98px) {
	.menu-header .navbar-collapse,
	.menu-header .navbar-nav,
	.menu-header .navbar-nav li {
		background: transparent !important;
		border-color: rgba(255, 255, 255, .08) !important;
	}
	.menu-header .navbar-nav .nav-link {
		padding: .7rem .25rem !important;
	}
}

/* --- Alatunniste --- */
.home-custom-content {
	background: var(--mk-header) !important;
	padding: 28px 0 !important;
}

.home-custom-content .custom-content-section-title,
.home-custom-content h3 {
	color: #9aa6b6 !important;
	font-size: .9rem !important;
	font-weight: 400 !important;
	text-align: center !important;
	margin: 0 !important;
}

#copyright,
#copyright a {
	color: #9aa6b6 !important;
}

/* Julkisten sivujen alatunniste samaan lämpimään sävyyn kuin ylätunniste/valikko
   (vain .mk-modern → geokätkösivut säilyttävät tumman alatunnisteen ennallaan). */
body.mk-modern .home-custom-content {
	background: var(--mk-cream) !important;
	border-top: 1px solid rgba(0, 0, 0, .08);
}

body.mk-modern .home-custom-content .custom-content-section-title,
body.mk-modern .home-custom-content h3,
body.mk-modern #copyright,
body.mk-modern #copyright a {
	color: #555 !important;
}

/* ===========================================================================
   1b. MODERNI YLÄTUNNISTE (vain julkiset sivut)
   --------------------------------------------------------------------------
   Renderöidään functions.php:ssä `.mk-site-header`-markupina, joka KORVAA
   evolven oletusheaderin ei-geokätkösivuilla (geokätkösivuilla evolven header
   jää koskemattomaksi → yllä oleva osio 1 koskee vain niitä). Lämmin paperikaista,
   pyöreä tunnus + nimi/alaotsikko, päävalikko ja "Aloita kurssi" -CTA.
   ========================================================================= */

.mk-site-header {
	background: var(--mk-cream);
	border-bottom: 1px solid rgba(0, 0, 0, .08);
	padding: 18px 28px;
	font-family: var(--mk-font);
}

.mk-header-inner {
	max-width: 1280px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.mk-brand {
	display: flex;
	align-items: center;
	gap: 18px;
}

.mk-brand-logo-link {
	display: flex;
	flex: none;
}

.mk-brand-logo {
	width: 72px;
	height: 72px;
	object-fit: contain;
	border-radius: 50%;
}

.mk-brand-text {
	display: flex;
	flex-direction: column;
}

/* Otsikko: musta (kuten prototyypissä), ei punainen — ankkurina .mk-modern a
   ylikirjoittaisi värin, joten nostetaan tarkkuutta .mk-site-header-esiäidillä. */
.mk-site-header .mk-brand-title,
.mk-site-header .mk-brand-title:hover {
	color: var(--mk-ink);
	text-decoration: none;
	font-size: 26px;
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -.03em;
}

.mk-brand-subtitle {
	margin-top: 5px;
	font-size: 14px;
	color: #555;
}

/* Päävalikko — wp_nav_menu tulostaa <ul class="mk-menu"> */
.mk-main-nav {
	display: flex;
	align-items: center;
}

.mk-menu {
	display: flex;
	align-items: center;
	gap: 20px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.mk-menu li {
	margin: 0;
}

/* Valikkolinkit mustia (punainen vasta hoverissa/aktiivisena). .mk-site-header-
   esiäiti nostaa tarkkuuden .mk-modern a:n yli. */
.mk-site-header .mk-menu a {
	color: var(--mk-ink);
	text-decoration: none;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.25;
}

.mk-site-header .mk-menu a:hover,
.mk-site-header .mk-menu .current-menu-item > a,
.mk-site-header .mk-menu .current-menu-parent > a,
.mk-site-header .mk-menu .current-menu-ancestor > a {
	color: var(--mk-accent);
}

/* CTA: valkoinen teksti punaisella taustalla (.mk-modern a tekisi tekstistä
   punaisen → punainen punaisella). Nostetaan tarkkuutta esiäidillä. */
.mk-site-header .mk-header-button,
.mk-site-header .mk-header-button:hover {
	color: #fff;
	text-decoration: none;
}

.mk-header-button {
	background: var(--mk-accent);
	padding: 13px 22px;
	border-radius: 7px;
	font-weight: 700;
	white-space: nowrap;
	flex: none;
	transition: background-color .15s ease;
}

.mk-header-button:hover {
	background: var(--mk-accent-600);
}

/* Hampurilaispainike — piilossa työpöydällä, näkyy mobiilissa */
.mk-nav-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid rgba(0, 0, 0, .15);
	border-radius: 8px;
	background: transparent;
	cursor: pointer;
}

.mk-nav-toggle span {
	display: block;
	width: 22px;
	height: 2px;
	margin: 0 auto;
	background: var(--mk-ink);
	transition: transform .2s ease, opacity .2s ease;
}

.mk-nav-toggle.is-active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mk-nav-toggle.is-active span:nth-child(2) { opacity: 0; }
.mk-nav-toggle.is-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 1024px) {
	.mk-header-inner {
		flex-wrap: wrap;
		gap: 16px 24px;
	}
	.mk-nav-toggle {
		display: flex;
		order: 2;
		margin-left: auto;
	}
	.mk-header-button {
		order: 3;
	}
	.mk-main-nav {
		order: 4;
		flex-basis: 100%;
		display: none;
	}
	.mk-main-nav.is-open {
		display: block;
	}
	.mk-menu {
		flex-direction: column;
		align-items: flex-start;
		gap: 4px;
		width: 100%;
	}
	.mk-menu a {
		display: block;
		padding: 10px 0;
		width: 100%;
	}
}

@media (max-width: 520px) {
	.mk-site-header {
		padding: 18px 20px;
	}
	.mk-brand-logo {
		width: 58px;
		height: 58px;
	}
	.mk-brand-title {
		font-size: 26px;
	}
	.mk-brand-subtitle {
		font-size: 14px;
	}
}

/* ===========================================================================
   2. SISÄLTÖ (aidattu .mk-modern — EI koske geokätkösivuja)
   ========================================================================= */

/* --- Perusta & typografia --- */
html body.mk-modern.custom-background {
	background-color: var(--mk-bg) !important;
}

body.mk-modern {
	font-family: var(--mk-font) !important;
	color: var(--mk-text) !important;
	font-weight: 400 !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body.mk-modern .content {
	background: transparent !important;
	padding-top: 2.5rem !important;
	padding-bottom: 3.5rem !important;
}

.mk-modern h1,
.mk-modern h2,
.mk-modern h3,
.mk-modern h4,
.mk-modern h5,
.mk-modern h6 {
	font-family: var(--mk-font) !important;
	color: var(--mk-ink) !important;
	font-weight: 700 !important;
	letter-spacing: -.01em;
}

.mk-modern .post-content {
	font-family: var(--mk-font) !important;
	color: var(--mk-text) !important;
	line-height: 1.7;
}

/* Evolve asettaa monelle elementille `font-family: Roboto` ilman varafonttia;
   koska Robotoa ei ladata, selain putoaa oletus-serifiin. Pakotetaan Inter. */
.mk-modern p,
.mk-modern li,
.mk-modern td,
.mk-modern blockquote,
.mk-modern .card-text,
.mk-modern .widget-content,
.mk-modern .aside,
.mk-modern .aside a,
.mk-modern input,
.mk-modern textarea,
.mk-modern select,
.mk-modern button {
	font-family: var(--mk-font) !important;
}

.mk-modern a {
	/* Hieman tummempi teal leipätekstin linkeille → riittävä kontrasti valkoisella
	   (kirkas --mk-accent jää napeille/ikoneille, joissa teksti on täytön päällä). */
	color: var(--mk-accent-600);
}

.mk-modern a:hover {
	color: var(--mk-accent);
}

/* --- Painikkeet --- */
.mk-modern .btn,
.mk-modern a.btn,
.mk-modern .button,
.mk-modern input[type=submit],
.mk-modern .post-content a.btn {
	background: var(--mk-accent) !important;
	background-image: none !important;
	color: #ffffff !important;
	border: 1px solid var(--mk-accent) !important;
	border-radius: var(--mk-radius-sm) !important;
	padding: .6rem 1.3rem !important;
	font-family: var(--mk-font) !important;
	font-weight: 600 !important;
	box-shadow: 0 1px 2px rgba(166, 43, 12, .25) !important;
	transition: transform .12s ease, background-color .15s ease, box-shadow .15s ease !important;
}

.mk-modern .btn:hover,
.mk-modern a.btn:hover,
.mk-modern .button:hover,
.mk-modern input[type=submit]:hover,
.mk-modern .post-content a.btn:hover {
	background: var(--mk-accent-600) !important;
	border-color: var(--mk-accent-600) !important;
	color: #ffffff !important;
	transform: translateY(-1px);
	box-shadow: 0 7px 18px rgba(166, 43, 12, .32) !important;
}

.mk-modern .btn-sm {
	padding: .45rem .95rem !important;
	font-size: .85rem !important;
}

/* --- Lomakekentät --- */
.mk-modern .content input[type=text],
.mk-modern .content input[type=email],
.mk-modern .content input[type=url],
.mk-modern .content input[type=password],
.mk-modern .content input[type=tel],
.mk-modern .content textarea,
.mk-modern .content select,
.mk-modern .content .form-control {
	background-color: #ffffff !important;
	border: 1px solid var(--mk-border) !important;
	border-radius: var(--mk-radius-sm) !important;
	color: var(--mk-ink) !important;
}

/* --- Murupolku --- */
.mk-modern .breadcrumb {
	background: transparent !important;
	padding-left: 0 !important;
	font-size: .82rem;
}

/* ===========================================================================
   3. ETUSIVUN NOSTOLAATIKOT
   ========================================================================= */

.mk-modern .home-content-boxes {
	/* Alkuperäinen geometry-taustakuva palautettuna, mutta vaalean kerroksen alle
	   himmennettynä, jotta valkoiset kortit erottuvat. Kuvan URL injektoidaan
	   PHP:stä (--mk-hero-bg), jotta se toimii myös tuotannossa. */
	background:
		linear-gradient(180deg, rgba(255, 255, 255, .85) 0%, rgba(246, 247, 249, .92) 100%),
		var(--mk-hero-bg, linear-gradient(180deg, #ffffff, var(--mk-accent-50))) center / cover no-repeat !important;
	padding: 64px 0 !important;
	border-bottom: 1px solid var(--mk-border);
}

.mk-modern .home-content-boxes .content-box .card {
	background: var(--mk-surface) !important;
	border: 1px solid var(--mk-border) !important;
	border-radius: var(--mk-radius) !important;
	box-shadow: var(--mk-shadow) !important;
	padding: 2rem 1.5rem !important;
}

.mk-modern .home-content-boxes .card-img-top {
	margin-bottom: 1.1rem;
}

.mk-modern .home-content-boxes .card-img-top i {
	color: var(--mk-accent) !important;
	font-size: 1.6rem !important;
	width: 64px;
	height: 64px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--mk-accent-50);
	border-radius: 16px;
}

.mk-modern .home-content-boxes .card-title {
	color: var(--mk-ink) !important;
	font-size: 1.3rem !important;
	font-weight: 700 !important;
	margin-bottom: .5rem;
}

.mk-modern .home-content-boxes .card-text {
	color: var(--mk-muted) !important;
	font-size: 1rem !important;
	line-height: 1.6;
}

.mk-modern .home-content-boxes .card-footer {
	background: transparent !important;
	border: 0 !important;
	padding: 1.25rem 0 0 !important;
}

/* ===========================================================================
   4. BLOGI / ARKISTO — artikkelikortit
   ========================================================================= */

.mk-modern .posts.card-deck > .card,
.mk-modern .posts.card-columns > .card {
	background: var(--mk-surface) !important;
	border: 1px solid var(--mk-border) !important;
	border-radius: var(--mk-radius) !important;
	box-shadow: var(--mk-shadow) !important;
	padding: 1.25rem 1.35rem 1.35rem !important;
	margin-bottom: 1.75rem;
}

.mk-modern .posts .card .post-title {
	margin: 0 0 .85rem !important;
	font-size: 1.3rem !important;
	line-height: 1.35 !important;
}

.mk-modern .posts .card .post-title a {
	color: var(--mk-ink) !important;
}

.mk-modern .posts .card .post-title a:hover {
	color: var(--mk-accent) !important;
}

.mk-modern .posts .card .thumbnail-post {
	margin: 0 0 1rem;
	border-radius: var(--mk-radius-sm);
	overflow: hidden;
}

.mk-modern .posts .card .thumbnail-post img {
	display: block;
	width: 100%;
	height: 210px;
	object-fit: cover;
}

.mk-modern .posts .card .post-content {
	color: var(--mk-muted) !important;
	font-size: .98rem;
	line-height: 1.65;
}

.mk-modern .posts .card .post-meta {
	margin: 1rem 0 0 !important;
	padding-top: .85rem;
	border-top: 1px solid var(--mk-border);
	font-size: .8rem;
}

.mk-modern .posts .card .card-body {
	padding: 1rem 0 0 !important;
}

/* ===========================================================================
   5. YKSITTÄINEN SIVU / ARTIKKELI — sisältö valkoisella kortilla
   ========================================================================= */

.mk-modern.page #primary,
.mk-modern.single #primary {
	background: var(--mk-surface);
	border: 1px solid var(--mk-border);
	border-radius: var(--mk-radius);
	box-shadow: var(--mk-shadow);
	padding: 2.25rem 2.5rem;
}

.mk-modern.page #primary .post-title,
.mk-modern.single #primary .post-title {
	margin-top: 0;
	margin-bottom: 1.25rem;
}

.mk-modern.page #primary img,
.mk-modern.single #primary img {
	border-radius: var(--mk-radius-sm);
	height: auto;
}

/* ===========================================================================
   6. SIVUPALKKI / VIMPAINIKKEET
   ========================================================================= */

.mk-modern #secondary .widget {
	background: var(--mk-surface);
	border: 1px solid var(--mk-border);
	border-radius: var(--mk-radius);
	box-shadow: var(--mk-shadow);
	padding: 1.25rem 1.4rem;
	margin-bottom: 1.5rem;
}

.mk-modern #secondary .widget-title {
	color: var(--mk-ink) !important;
	font-size: 1.05rem !important;
	font-weight: 700 !important;
	margin: 0 0 .85rem !important;
	padding-bottom: .6rem;
	border-bottom: 2px solid var(--mk-accent-50);
}

.mk-modern #secondary .widget-content ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mk-modern #secondary .widget_recent_entries li {
	padding: .55rem 0;
	border-bottom: 1px solid var(--mk-border);
}

.mk-modern #secondary .widget_recent_entries li:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.mk-modern #secondary .widget a {
	color: var(--mk-text) !important;
	text-decoration: none;
}

.mk-modern #secondary .widget a:hover {
	color: var(--mk-accent) !important;
}

/* "Ilmoittaudu kursseille" -widget napiksi (ylikirjoittaa inline-tyylin) */
.mk-modern #secondary .widget_custom_html .custom-html-widget a {
	display: block;
	text-align: center;
	background: var(--mk-accent);
	color: #ffffff !important;
	margin-top: 0 !important;
	padding: .9rem 1rem !important;
	border-radius: var(--mk-radius-sm);
	font-size: 1.1rem !important;
	font-weight: 700;
	box-shadow: 0 6px 16px rgba(166, 43, 12, .28);
	transition: background-color .15s ease, transform .12s ease;
}

.mk-modern #secondary .widget_custom_html .custom-html-widget a:hover {
	background: var(--mk-accent-600);
	color: #ffffff !important;
	transform: translateY(-1px);
}
