/*
Theme Name: GdzieNaJoge
Theme URI: https://gdzienajoge.pl
Description: Motyw katalogu szkół jogi i pilates. Dwie przełączalne palety (Noc i złoto / Ziemia i len), sygnatura „Oddech". Integruje plugin gdzienajoge-katalog.
Author: Riomega
Version: 1.0.0
Requires PHP: 8.0
Text Domain: gdzienajoge
*/

/* ============ TOKENY ============ */
:root {
	/* Paleta A — Noc i złoto (domyślna) */
	--brand:      #122A4F;
	--brand-deep: #0C1C38;
	--accent:     #C6A15B;
	--accent-soft:#E4D2A6;
	--bg:         #F6F8FB;
	--surface:    #FFFFFF;
	--ink:        #14213A;
	--muted:      #5A6B85;
	--line:       #E3E8F0;
	--on-brand:   #EAF0FA;

	/* Typografia */
	--display: "Marcellus", Georgia, serif;
	--body:    "Mulish", system-ui, -apple-system, sans-serif;

	/* Szerokości */
	--wide:    1180px;
	--measure: 700px;

	/* Rytm */
	--s1: .5rem; --s2: 1rem; --s3: 1.5rem; --s4: 2.5rem; --s5: 4rem; --s6: 6rem;
	--radius: 4px;
	--shadow: 0 1px 2px rgba(20,33,58,.05), 0 10px 30px -18px rgba(20,33,58,.25);
}

html[data-palette="brown"] {
	--brand:      #5A4632;
	--brand-deep: #3E2F20;
	--accent:     #B5894F;
	--accent-soft:#E2CDA9;
	--bg:         #FBF7F1;
	--surface:    #FFFFFF;
	--ink:        #2E2418;
	--muted:      #7A6A57;
	--line:       #ECE3D6;
	--on-brand:   #F3E9DC;
}

/* ============ BAZA ============ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	background: var(--bg);
	color: var(--ink);
	font-family: var(--body);
	font-size: 1.0625rem;
	line-height: 1.7;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	transition: background-color .4s ease, color .4s ease;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 2px;
}

h1, h2, h3, h4 { font-family: var(--display); font-weight: 400; line-height: 1.15; margin: 0 0 .5em; letter-spacing: .01em; }
h1 { font-size: clamp(2.4rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.7rem, 3vw, 2.3rem); }
h3 { font-size: 1.3rem; }
p { margin: 0 0 1.1em; }

.eyebrow {
	font-family: var(--body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .22em;
	font-size: .72rem;
	color: var(--accent);
	margin: 0 0 1rem;
}

.wrap { width: min(100% - 2.5rem, var(--wide)); margin-inline: auto; }
.measure { max-width: var(--measure); }
.section { padding-block: var(--s6); }
.section--tight { padding-block: var(--s5); }

/* ============ PRZYCISKI ============ */
.btn {
	display: inline-flex; align-items: center; gap: .5rem;
	font-family: var(--body); font-weight: 700; font-size: .9rem;
	letter-spacing: .02em;
	padding: .8rem 1.6rem; border-radius: var(--radius);
	background: var(--accent); color: #1a1304; border: 1px solid var(--accent);
	cursor: pointer; transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -10px rgba(0,0,0,.4); }
.btn--ghost { background: transparent; color: var(--accent); }
.btn--on-brand { background: var(--accent); color: var(--brand-deep); }

/* ============ HEADER ============ */
.site-header {
	background: var(--brand);
	color: var(--on-brand);
	position: sticky; top: 0; z-index: 50;
	border-bottom: 1px solid color-mix(in srgb, var(--on-brand) 14%, transparent);
}
.site-header .wrap { display: flex; align-items: center; gap: 1.5rem; min-height: 72px; }
.brandmark { font-family: var(--display); font-size: 1.45rem; letter-spacing: .02em; color: var(--on-brand); display: flex; align-items: center; gap: .55rem; }
.brandmark .dot { width: 9px; height: 9px; border-radius: 50%; border: 1.5px solid var(--accent); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 30%, transparent); }
.site-nav { display: flex; gap: 1.6rem; margin-left: auto; align-items: center; }
.site-nav a { font-size: .92rem; color: color-mix(in srgb, var(--on-brand) 85%, transparent); position: relative; padding-block: .3rem; }
.site-nav a:hover { color: var(--on-brand); }
.site-nav a::after { content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 1px; background: var(--accent); transition: width .25s ease; }
.site-nav a:hover::after { width: 100%; }

.palette-toggle {
	display: inline-flex; border: 1px solid color-mix(in srgb, var(--on-brand) 28%, transparent);
	border-radius: 999px; overflow: hidden; font-size: .74rem; font-weight: 700; letter-spacing: .08em;
}
.palette-toggle button { background: transparent; color: color-mix(in srgb, var(--on-brand) 70%, transparent); border: 0; padding: .4rem .7rem; cursor: pointer; }
.palette-toggle button[aria-pressed="true"] { background: var(--accent); color: var(--brand-deep); }

/* ============ HERO (sygnatura: oddech) ============ */
.hero { position: relative; background: var(--brand); color: var(--on-brand); overflow: hidden; text-align: center; padding-block: clamp(4rem, 10vw, 8rem); }
.hero__rings { position: absolute; inset: 0; display: grid; place-items: center; pointer-events: none; }
.hero__rings span {
	position: absolute; border-radius: 50%;
	border: 1px solid color-mix(in srgb, var(--accent) 38%, transparent);
	animation: oddech 5.5s ease-in-out infinite;
}
.hero__rings span:nth-child(1) { width: 280px; height: 280px; }
.hero__rings span:nth-child(2) { width: 460px; height: 460px; animation-delay: .5s; opacity: .7; }
.hero__rings span:nth-child(3) { width: 660px; height: 660px; animation-delay: 1s; opacity: .45; }
@keyframes oddech {
	0%, 100% { transform: scale(.92); opacity: .35; }
	50%      { transform: scale(1.06); opacity: .8; }
}
.hero__inner { position: relative; z-index: 1; max-width: 720px; margin-inline: auto; }
.hero h1 { color: var(--on-brand); margin-bottom: .3em; }
.hero__lead { color: color-mix(in srgb, var(--on-brand) 80%, transparent); font-size: 1.15rem; margin-bottom: 2rem; }

/* ============ WYSZUKIWARKA ============ */
.search-card {
	display: flex; flex-wrap: wrap; gap: .6rem; background: var(--surface); color: var(--ink);
	padding: .7rem; border-radius: var(--radius); box-shadow: var(--shadow); max-width: 620px; margin-inline: auto;
}
.search-card select, .search-card input[type="search"] {
	flex: 1 1 180px; border: 1px solid var(--line); border-radius: var(--radius); padding: .7rem .8rem;
	font-family: var(--body); font-size: .95rem; color: var(--ink); background: var(--surface);
}
.search-card .btn { flex: 0 0 auto; }
.city-chips { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; margin-top: 1.6rem; }
.city-chips a {
	font-size: .85rem; color: color-mix(in srgb, var(--on-brand) 82%, transparent);
	border: 1px solid color-mix(in srgb, var(--on-brand) 26%, transparent); border-radius: 999px; padding: .35rem .9rem;
	transition: border-color .2s ease, color .2s ease;
}
.city-chips a:hover { border-color: var(--accent); color: var(--on-brand); }

/* ============ SEKCJE / NAGŁÓWKI ============ */
.sec-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; margin-bottom: var(--s4); }
.sec-head .more { font-size: .85rem; color: var(--accent); white-space: nowrap; }
.rule-gold { height: 1px; background: linear-gradient(90deg, var(--accent), transparent); border: 0; margin: 0; }

/* ============ KARTY SZKÓŁ ============ */
.grid { display: grid; gap: 1.6rem; grid-template-columns: repeat(3, 1fr); }
.card {
	background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden;
	display: flex; flex-direction: column; transition: transform .2s ease, box-shadow .25s ease, border-color .2s ease;
}
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: color-mix(in srgb, var(--accent) 40%, var(--line)); }
.card__media { aspect-ratio: 3/2; background: color-mix(in srgb, var(--brand) 8%, var(--surface)); position: relative; }
.card__media img { width: 100%; height: 100%; object-fit: cover; }
.card__badge { position: absolute; top: .7rem; left: .7rem; background: color-mix(in srgb, var(--brand) 88%, transparent); color: var(--on-brand); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; padding: .25rem .6rem; border-radius: 3px; }
.card__body { padding: 1.1rem 1.2rem 1.3rem; display: flex; flex-direction: column; gap: .35rem; flex: 1; }
.card__city { font-size: .74rem; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); }
.card__title { font-family: var(--display); font-size: 1.25rem; line-height: 1.2; }
.card__meta { font-size: .85rem; color: var(--muted); margin-top: auto; }

/* ============ CHIP-y STYLÓW ============ */
.tags { display: flex; flex-wrap: wrap; gap: .55rem; }
.tag {
	font-size: .82rem; color: var(--ink); background: var(--surface);
	border: 1px solid var(--line); border-radius: 999px; padding: .4rem 1rem; transition: border-color .2s, color .2s;
}
.tag:hover { border-color: var(--accent); color: var(--accent); }

/* ============ STRONA SZKOŁY ============ */
.szkola-head { background: var(--brand); color: var(--on-brand); padding-block: var(--s5); }
.szkola-head h1 { color: var(--on-brand); margin-bottom: .25em; }
.szkola-head .loc { font-size: .8rem; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
.gnj-verified { display: inline-block; vertical-align: middle; font-family: var(--body); font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--brand-deep); background: var(--accent); padding: .3rem .7rem; border-radius: 999px; margin-left: .6rem; }
.szkola-head .tags .tag { background: color-mix(in srgb, var(--on-brand) 8%, transparent); border-color: color-mix(in srgb, var(--on-brand) 22%, transparent); color: var(--on-brand); }
.szkola-grid { display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: 3rem; align-items: start; }
.szkola-main > * + * { margin-top: var(--s4); }
.prose { max-width: var(--measure); }
.prose p { color: color-mix(in srgb, var(--ink) 92%, var(--muted)); }

.block-title { font-family: var(--display); font-size: 1.45rem; margin-bottom: 1rem; padding-bottom: .5rem; border-bottom: 1px solid var(--line); }

/* grafik */
.grafik { width: 100%; border-collapse: collapse; font-size: .92rem; }
.grafik th { text-align: left; font-weight: 700; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); padding: .5rem .6rem; border-bottom: 1px solid var(--line); }
.grafik td { padding: .65rem .6rem; border-bottom: 1px solid var(--line); }
.grafik td:first-child { color: var(--accent); font-weight: 600; white-space: nowrap; }

/* instruktorzy */
.instruktorzy { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: 1rem; }
.instruktor { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 1rem; }
.instruktor .imie { font-family: var(--display); font-size: 1.1rem; }
.instruktor .spec { font-size: .8rem; color: var(--muted); }

/* sidebar */
.szkola-aside { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 1.4rem; }
.panel { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem; }
.panel h3 { font-size: 1.05rem; margin-bottom: .8rem; }
.hours { list-style: none; margin: 0; padding: 0; font-size: .9rem; }
.hours li { display: flex; justify-content: space-between; padding: .35rem 0; border-bottom: 1px dashed var(--line); }
.hours li:last-child { border-bottom: 0; }
.contact-row { display: flex; gap: .6rem; font-size: .92rem; padding: .3rem 0; }
.contact-row a { color: var(--accent); }

/* claim banner (z pluginu) */
.gnj-claim-banner { background: color-mix(in srgb, var(--accent) 16%, var(--surface)); border: 1px solid var(--accent); border-radius: var(--radius); padding: .9rem 1.1rem; margin-bottom: 1.4rem; font-size: .92rem; }
.gnj-claim-banner button { margin-left: .5rem; }

/* ============ BLOG ============ */
.post-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.post-card .post-body { padding: 1.2rem 1.3rem 1.4rem; }
.post-card h3 { font-size: 1.2rem; }
.post-card .date { font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.entry { }
.entry .prose h2 { margin-top: 1.6em; }

/* CTA właściciel */
.cta-owner { background: var(--brand-deep); color: var(--on-brand); border-radius: var(--radius); padding: var(--s4); display: flex; flex-wrap: wrap; align-items: center; gap: 1.5rem; justify-content: space-between; }
.cta-owner h2 { color: var(--on-brand); margin: 0; }
.cta-owner p { color: color-mix(in srgb, var(--on-brand) 75%, transparent); margin: .4rem 0 0; }

/* ============ FOOTER ============ */
.site-footer { background: var(--brand-deep); color: color-mix(in srgb, var(--on-brand) 75%, transparent); padding-block: var(--s5) var(--s3); margin-top: var(--s6); }
.site-footer .cols { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; }
.site-footer a { color: color-mix(in srgb, var(--on-brand) 75%, transparent); }
.site-footer a:hover { color: var(--accent); }
.site-footer h4 { color: var(--on-brand); font-size: 1rem; }
.site-footer .legal { margin-top: var(--s4); padding-top: 1.2rem; border-top: 1px solid color-mix(in srgb, var(--on-brand) 14%, transparent); font-size: .8rem; display: flex; justify-content: space-between; flex-wrap: wrap; gap: .6rem; }

/* ============ FORMULARZE PLUGINU (panel) ============ */
.gnj-form { max-width: var(--measure); }
.gnj-form label { display: block; font-size: .9rem; font-weight: 600; }
.gnj-form input[type=text], .gnj-form input[type=email], .gnj-form input[type=password], .gnj-form textarea, .gnj-form select {
	width: 100%; border: 1px solid var(--line); border-radius: var(--radius); padding: .6rem .7rem; font-family: var(--body); font-size: .95rem; margin-top: .25rem; background: var(--surface); color: var(--ink);
}
.gnj-form fieldset { border: 1px solid var(--line); border-radius: var(--radius); padding: 1rem 1.2rem; margin: 1.2rem 0; }
.gnj-form legend { font-family: var(--display); padding: 0 .5rem; }
.gnj-form button { all: unset; } .gnj-form button[type=submit] { display: inline-flex; }
.gnj-form button[type=submit] { font-family: var(--body); font-weight: 700; padding: .8rem 1.6rem; border-radius: var(--radius); background: var(--accent); color: var(--brand-deep); cursor: pointer; }
.gnj-ok { background: color-mix(in srgb, #2e7d32 14%, var(--surface)); border: 1px solid #2e7d32; padding: .8rem 1rem; border-radius: var(--radius); margin-bottom: 1.2rem; }
.gnj-err { background: color-mix(in srgb, #c62828 12%, var(--surface)); border: 1px solid #c62828; padding: .8rem 1rem; border-radius: var(--radius); margin-bottom: 1.2rem; }
.gnj-lista { list-style: none; padding: 0; } .gnj-lista li { padding: .8rem 0; border-bottom: 1px solid var(--line); }

/* ============ RESPONSYWNOŚĆ ============ */
@media (max-width: 900px) {
	.grid { grid-template-columns: repeat(2, 1fr); }
	.szkola-grid { grid-template-columns: 1fr; }
	.szkola-aside { position: static; }
	.site-footer .cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
	.grid { grid-template-columns: 1fr; }
	.site-nav { display: none; }
	.site-footer .cols { grid-template-columns: 1fr; }
	.cta-owner { flex-direction: column; align-items: flex-start; }
}

/* ============ DOSTĘPNOŚĆ / RUCH ============ */
@media (prefers-reduced-motion: reduce) {
	* { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
	.hero__rings span { opacity: .5; }
}
