/* ==========================================================================
   Strony prawne (template-legal.php) — 1:1 wg mockup/regulamin.html
   Pełna szerokość przez .fws-wrap (standard --maxw + --pad). Tokeny z tokens.css.
   ========================================================================== */

/* Wyłamanie z kontenera Astra → treść w .fws-wrap (jak kontakt/o-nas) */
.page-template-template-legal #content > .ast-container,
.page-template-template-legal #primary,
.page-template-template-legal #primary > .ast-article-single,
.page-template-template-legal .entry-content,
.page-template-template-legal article.page {
	max-width: 100% !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	display: block !important;
}
.page-template-template-legal .entry-header,
.page-template-template-legal .ast-single-entry-banner,
.page-template-template-legal .entry-title,
.page-template-template-legal .page-title { display: none !important; }

.fws-legal-page { font-family: var(--body); color: var(--ink); }

/* Breadcrumb */
.fws-legal-page .crumb { font-family: var(--mono); font-size: 12px; color: #7c7f84; padding: 24px 0 0; }
.fws-legal-page .crumb a { text-decoration: none; color: #7c7f84; }
.fws-legal-page .crumb a:hover { color: var(--signal); }
.fws-legal-page .crumb span { color: #bdb8ad; margin: 0 7px; }
.fws-legal-page .crumb .cur { color: var(--ink); }

/* Layout: sidebar + treść */
.fws-legal-page .legal {
	display: grid;
	grid-template-columns: 240px minmax(0, 1fr);
	gap: 44px;
	padding-block: 32px 80px;
	align-items: start;
}

/* Sidebar nawigacji prawnej */
.fws-legal-page .legal-nav {
	position: sticky;
	top: 90px;
	border: 1px solid #e2ddd3;
	border-radius: var(--r);
	background: var(--paper);
	overflow: hidden;
}
.fws-legal-page .legal-nav a {
	display: block;
	padding: 13px 16px;
	font-size: 14px;
	color: #4a4d52;
	border-bottom: 1px solid #ece7dd;
	text-decoration: none;
}
.fws-legal-page .legal-nav a:last-child { border-bottom: none; }
.fws-legal-page .legal-nav a:hover { background: var(--bone); }
.fws-legal-page .legal-nav a.on { font-weight: 600; color: var(--ink); box-shadow: inset 3px 0 0 var(--signal); }

/* Treść */
.fws-legal-page .legal-main { min-width: 0; }
.fws-legal-page .legal-main h1 {
	font-family: var(--display);
	font-weight: 800;
	font-size: clamp(26px, 3.2vw, 38px);
	letter-spacing: -.015em;
	margin: 0 0 6px;
}
.fws-legal-page .legal-main h2 {
	font-family: var(--display);
	font-weight: 700;
	font-size: 19px;
	margin: 34px 0 10px;
}
.fws-legal-page .legal-main h2:first-of-type { margin-top: 24px; }
.fws-legal-page .legal-main p { font-size: 15px; color: #3f4348; margin-bottom: 12px; max-width: 70ch; }
.fws-legal-page .legal-main .ph { color: #9a9388; font-style: italic; }
.fws-legal-page .updated { font-family: var(--mono); font-size: 12px; color: #9a9388; margin-bottom: 20px; }

/* Notka ostrzegawcza (placeholder/Vorlage) */
.fws-legal-page .note {
	display: flex;
	gap: 12px;
	border: 1px solid #e0c4a8;
	background: #faf3ea;
	border-radius: var(--r);
	padding: 16px 18px;
	margin: 18px 0;
	font-size: 14px;
	color: #6b5435;
}
.fws-legal-page .note svg { width: 20px; height: 20px; flex: none; color: var(--signal); margin-top: 1px; }

/* Tabela Impressum */
.fws-legal-page .impressum-table {
	border: 1px solid #e2ddd3;
	border-radius: var(--r);
	overflow: hidden;
	max-width: 560px;
	margin-top: 8px;
}
.fws-legal-page .impressum-table .ir {
	display: grid;
	grid-template-columns: 160px 1fr;
	border-bottom: 1px solid #ece7dd;
}
.fws-legal-page .impressum-table .ir:last-child { border-bottom: none; }
.fws-legal-page .impressum-table .ik { padding: 11px 16px; background: var(--bone); font-size: 13px; color: #6b6f74; }
.fws-legal-page .impressum-table .iv { padding: 11px 16px; font-family: var(--mono); font-size: 13.5px; }
.fws-legal-page .impressum-table .iv.ph { color: #9a9388; font-style: italic; }

/* Responsywność */
@media (max-width: 860px) {
	.fws-legal-page .legal { grid-template-columns: 1fr; gap: 24px; }
	.fws-legal-page .legal-nav { position: static; }
}
