/* ============================================================
 * flauron.org — shared site styles
 * Dark/gold theme matching flauron.com.
 * ============================================================ */
:root {
	--bg-deep:    #0f1416;
	--bg-card:    #161c20;
	--bg-soft:    #1d2428;
	--gold:       #c8a650;
	--gold-light: #e2c275;
	--gold-soft:  #dfc683;
	--border:     #2a3033;
	--text:       #d8d4c2;
	--text-dim:   #8d8a78;
	--text-muted: #5d5a4e;
	--success:    #2d6a4f;
	--success-bg: #40916c;
	--danger:     #b03b3b;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
	background: var(--bg-deep);
	color: var(--text);
	font-family: 'Open Sans', -apple-system, Segoe UI, Roboto, sans-serif;
	line-height: 1.6;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

a { color: var(--gold); text-decoration: none; transition: color .15s; }
a:hover { color: var(--gold-light); }

h1, h2, h3, h4 {
	font-family: 'Cinzel', 'Open Sans', serif;
	color: var(--gold);
	letter-spacing: 1px;
	margin-bottom: .8rem;
	font-weight: 600;
}
h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; margin-top: 2rem; }
h3 { font-size: 1.15rem; margin-top: 1.5rem; }

p { margin-bottom: 1rem; }

ul, ol { margin: .5rem 0 1rem 1.5rem; }
li { margin-bottom: .35rem; }

strong { color: var(--gold-light); }
em { color: var(--text-dim); font-style: italic; }

hr {
	border: 0;
	border-top: 1px solid var(--border);
	margin: 1.5rem 0;
}

code {
	font-family: ui-monospace, Menlo, monospace;
	background: rgba(200, 166, 80, .1);
	padding: 1px 6px;
	border-radius: 3px;
	color: var(--gold-light);
	font-size: .9em;
}

/* ── Layout ────────────────────────────────────────────────── */
.site-header {
	background: rgba(0, 0, 0, .35);
	border-bottom: 1px solid var(--border);
	padding: 1rem 0;
}
.site-header .inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 1.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	flex-wrap: wrap;
}
.brand {
	font-family: 'Cinzel', serif;
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--gold);
	letter-spacing: 2px;
	text-transform: uppercase;
}
.brand:hover { color: var(--gold-light); }

.nav {
	display: flex;
	gap: 1.2rem;
	flex-wrap: wrap;
	align-items: center;
}
.nav a {
	color: var(--text-dim);
	font-size: .85rem;
	text-transform: uppercase;
	letter-spacing: .8px;
	font-weight: 600;
	padding: .35rem 0;
}
.nav a:hover { color: var(--gold-light); }

main.site-main {
	max-width: 1100px;
	width: 100%;
	margin: 0 auto;
	padding: 2.5rem 1.5rem;
	flex: 1;
}

.site-footer {
	background: rgba(0, 0, 0, .5);
	border-top: 1px solid var(--border);
	padding: 2rem 0 1.2rem;
	margin-top: 3rem;
	color: var(--text-muted);
	font-size: .82rem;
}
.site-footer .inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 1.5rem;
}
.site-footer .links {
	display: flex;
	gap: 1.5rem;
	flex-wrap: wrap;
	margin-bottom: 1rem;
}
.site-footer .links a {
	color: var(--text-muted);
	font-size: .82rem;
}
.site-footer .links a:hover { color: var(--gold-light); }
.site-footer .copyright {
	border-top: 1px solid var(--border);
	padding-top: 1rem;
	color: var(--text-muted);
}
.site-footer .legal-info {
	font-size: .75rem;
	color: var(--text-muted);
	margin-top: .5rem;
	line-height: 1.5;
}

/* ── Cards & content blocks ────────────────────────────────── */
.card {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 2rem;
	margin-bottom: 1.5rem;
}

.page-title {
	text-align: center;
	margin-bottom: 1.5rem;
}
.page-title h1 { margin: 0 0 .5rem; }
.page-title .ornament {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .8rem;
	margin: .8rem auto 0;
	max-width: 380px;
}
.page-title .orn-line {
	flex: 1;
	height: 1px;
	background: linear-gradient(to right, transparent, rgba(200, 166, 80, .4), transparent);
}
.page-title .orn-icon { color: var(--gold); font-size: 1.1rem; }

/* ── Buttons / CTA ─────────────────────────────────────────── */
.btn {
	display: inline-block;
	padding: .9rem 2rem;
	border: none;
	border-radius: 6px;
	font-family: 'Cinzel', serif;
	font-size: .95rem;
	font-weight: 700;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	cursor: pointer;
	transition: .25s all;
	text-align: center;
}
.btn-primary {
	background: linear-gradient(130deg, var(--success), var(--success-bg) 50%, var(--success));
	background-size: 200% 100%;
	color: #f0fff4;
	border: 1px solid #52b788;
}
.btn-primary:hover {
	background-position: 100% 0;
	color: #fff;
	box-shadow: 0 4px 24px rgba(64, 145, 108, .35);
}
.btn-secondary {
	background: transparent;
	color: var(--gold);
	border: 1px solid var(--gold);
}
.btn-secondary:hover {
	background: rgba(200, 166, 80, .1);
	color: var(--gold-light);
}
.btn-block { display: block; width: 100%; }

/* ── Home page hero ────────────────────────────────────────── */
.hero {
	text-align: center;
	padding: 3rem 1rem 2rem;
}
.hero h1 {
	font-size: 2.6rem;
	margin-bottom: 1rem;
}
.hero p.lead {
	font-size: 1.05rem;
	color: var(--text-dim);
	max-width: 640px;
	margin: 0 auto 2rem;
}
.hero .cta-group {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

/* ── Features grid (home) ──────────────────────────────────── */
.features {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1rem;
	margin: 2rem 0;
}
.feature {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 6px;
	padding: 1.3rem;
	text-align: center;
}
.feature .icon {
	font-size: 1.8rem;
	color: var(--gold);
	margin-bottom: .6rem;
}
.feature h3 {
	font-size: 1rem;
	margin: 0 0 .4rem;
}
.feature p {
	color: var(--text-dim);
	font-size: .85rem;
	margin: 0;
}

/* ── Legal pages typography ────────────────────────────────── */
.legal-content {
	max-width: 800px;
	margin: 0 auto;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 2.5rem;
}
.legal-content h1 {
	text-align: center;
	margin-bottom: 2rem;
}
.legal-content h2 {
	color: var(--gold);
	font-size: 1.25rem;
	margin-top: 2rem;
	padding-bottom: .4rem;
	border-bottom: 1px solid var(--border);
}
.legal-content h3 {
	font-size: 1.05rem;
	margin-top: 1.3rem;
	color: var(--gold-light);
}
.legal-content p, .legal-content li {
	font-size: .95rem;
	color: var(--text);
}
.legal-content .intro {
	color: var(--text-dim);
	font-style: italic;
	padding: 1rem 0;
	border-bottom: 1px solid var(--border);
	margin-bottom: 1.5rem;
}
.legal-content hr {
	margin: 1.5rem 0;
	border-top: 1px solid rgba(200, 166, 80, .15);
}

/* ── Payment confirmation page ─────────────────────────────── */
.payment-card {
	max-width: 520px;
	margin: 0 auto;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 2rem;
}
.payment-row {
	display: flex;
	justify-content: space-between;
	padding: .7rem 0;
	border-bottom: 1px dashed rgba(200, 166, 80, .15);
}
.payment-row:last-child { border-bottom: 0; }
.payment-row .label {
	color: var(--text-muted);
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: .8px;
}
.payment-row .value {
	color: var(--text);
	font-weight: 600;
}
.payment-row .value.amount {
	color: var(--gold-light);
	font-size: 1.2rem;
}
.payment-notice {
	background: rgba(200, 166, 80, .07);
	border: 1px solid rgba(200, 166, 80, .2);
	border-radius: 6px;
	padding: 1rem;
	margin: 1.2rem 0;
	font-size: .85rem;
	color: var(--text-dim);
}
.payment-error {
	background: rgba(176, 59, 59, .1);
	border: 1px solid rgba(176, 59, 59, .35);
	border-radius: 6px;
	padding: 1rem;
	color: #d97a7a;
	font-size: .9rem;
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 640px) {
	.site-header .inner { flex-direction: column; gap: .8rem; }
	.nav { gap: .8rem; justify-content: center; }
	.hero h1 { font-size: 1.9rem; }
	main.site-main { padding: 1.5rem 1rem; }
	.legal-content { padding: 1.5rem; }
}
