/*
Theme Name: Astra Child
Template: astra
Version: 1.0.0
*/

/* ==========================================================================
   CrazySneak — Design tokens (Pearl & Champagne, default theme)
   ========================================================================== */
:root {
	--cs-bg:            #FAF7F2;
	--cs-bg-alt:        #F3EDE2;
	--cs-fg:            #1A1412;
	--cs-card:          #FFFFFF;
	--cs-accent:        #B58B5B;
	--cs-accent-soft:   #EFE4D3;
	--cs-line:          rgba(26, 20, 18, .08);
	--cs-line-soft:     rgba(26, 20, 18, .07);
	--cs-muted:         rgba(26, 20, 18, .65);
	--cs-body:          rgba(26, 20, 18, .78);
	--cs-chip-border:   rgba(26, 20, 18, .14);
	--cs-pattern-line:  rgba(26, 20, 18, .035);

	--cs-font-serif:    'Cormorant Garamond', Georgia, serif;
	--cs-font-sans:     'Inter', system-ui, -apple-system, sans-serif;

	--cs-ease:          cubic-bezier(0.22, 0.61, 0.36, 1);
	--cs-dur-fast:      180ms;
	--cs-dur-base:      220ms;
}

/* ==========================================================================
   FAQ & Help page
   Mobile-first; desktop styles under @media (min-width: 768px).
   ========================================================================== */

/* Eyebrow label ---------------------------------------------------------- */
.csn-eyebrow {
	font-family: var(--cs-font-sans);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cs-accent);
	margin-bottom: 14px;
}

/* Hero ------------------------------------------------------------------- */
.csn-faq-hero {
	position: relative;
	overflow: hidden;
	background: var(--cs-bg);
	padding: 44px 20px 36px;
	text-align: center;
}
.csn-faq-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		135deg,
		var(--cs-pattern-line) 0,
		var(--cs-pattern-line) 1px,
		transparent 1px,
		transparent 14px
	);
	pointer-events: none;
}
.csn-faq-hero__inner {
	position: relative;
	max-width: 720px;
	margin: 0 auto;
}
.csn-faq-hero__title {
	font-family: var(--cs-font-serif);
	font-size: 36px;
	font-weight: 500;
	line-height: 1.05;
	letter-spacing: -0.01em;
	color: var(--cs-fg);
	margin: 0;
}
.csn-faq-hero__title em {
	font-style: italic;
	font-weight: 500;
	color: var(--cs-accent);
}
.csn-faq-hero__sub {
	font-family: var(--cs-font-serif);
	font-style: italic;
	font-size: 16px;
	color: var(--cs-muted);
	max-width: 520px;
	margin: 14px auto 0;
	line-height: 1.45;
}

/* Chip nav (sticky, scroll-spy highlighted) ----------------------------- */
.csn-faq-chipnav {
	position: sticky;
	top: 0;
	z-index: 5;
	background: rgba(250, 247, 242, .94);
	-webkit-backdrop-filter: saturate(140%) blur(8px);
	backdrop-filter: saturate(140%) blur(8px);
	border-bottom: 1px solid rgba(26, 20, 18, .06);
}
.csn-faq-chipnav__inner {
	display: flex;
	gap: 8px;
	overflow-x: auto;
	padding: 12px 20px;
	max-width: 1040px;
	margin: 0 auto;
	scrollbar-width: none;
	-ms-overflow-style: none;
}
.csn-faq-chipnav__inner::-webkit-scrollbar { display: none; }
.csn-chip {
	flex-shrink: 0;
	padding: 9px 14px;
	border-radius: 100px;
	border: 1px solid var(--cs-chip-border);
	background: var(--cs-card);
	color: var(--cs-fg);
	font-family: var(--cs-font-sans);
	font-size: 12.5px;
	font-weight: 600;
	letter-spacing: 0.01em;
	white-space: nowrap;
	text-decoration: none;
	cursor: pointer;
	transition: background var(--cs-dur-fast) var(--cs-ease),
	            color var(--cs-dur-fast) var(--cs-ease),
	            border-color var(--cs-dur-fast) var(--cs-ease);
}
.csn-chip.is-active {
	background: var(--cs-fg);
	color: #fff;
	border-color: var(--cs-fg);
}

/* FAQ groups ------------------------------------------------------------ */
.csn-faq-groups {
	padding: 28px 20px 36px;
	max-width: 880px;
	margin: 0 auto;
	width: 100%;
	box-sizing: border-box;
}
.csn-faq-group { scroll-margin-top: 120px; }
.csn-faq-group + .csn-faq-group { margin-top: 44px; }
.csn-faq-group__header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}
.csn-faq-group__icon {
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: var(--cs-accent-soft);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.csn-faq-group__title {
	font-family: var(--cs-font-serif);
	font-size: 22px;
	font-weight: 500;
	letter-spacing: -0.01em;
	color: var(--cs-fg);
	margin: 0;
	line-height: 1.15;
}

/* Accordion (details/summary) ------------------------------------------- */
.csn-faq-accordion {
	background: var(--cs-card);
	border-radius: 16px;
	border: 1px solid var(--cs-line);
	overflow: hidden;
}
.csn-faq-item {
	border-bottom: 1px solid var(--cs-line-soft);
}
.csn-faq-item:last-child { border-bottom: none; }
.csn-faq-item__q {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	padding: 18px;
	cursor: pointer;
	list-style: none;
}
.csn-faq-item__q::-webkit-details-marker { display: none; }
.csn-faq-item__q-text {
	font-family: var(--cs-font-serif);
	font-size: 18px;
	font-weight: 500;
	line-height: 1.25;
	color: var(--cs-fg);
}
.csn-faq-item__toggle {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: var(--cs-accent-soft);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: background var(--cs-dur-fast) var(--cs-ease);
}
.csn-faq-item[open] .csn-faq-item__toggle { background: var(--cs-accent); }
.csn-faq-item__toggle-minus { display: none; }
.csn-faq-item[open] .csn-faq-item__toggle-plus { display: none; }
.csn-faq-item[open] .csn-faq-item__toggle-minus { display: inline-flex; }
.csn-faq-item__a {
	padding: 0 18px 20px;
	font-family: var(--cs-font-sans);
	font-size: 13.5px;
	line-height: 1.65;
	color: var(--cs-body);
}
.csn-faq-item__a > p:first-child { margin-top: 0; }
.csn-faq-item__a > p:last-child { margin-bottom: 0; }
.csn-faq-item__a a { color: var(--cs-accent); font-weight: 600; text-decoration: none; }
.csn-faq-item__a a:hover { text-decoration: underline; }

/* Group CTAs & footer links --------------------------------------------- */
.csn-faq-group__cta,
.csn-faq-group__link {
	margin: 14px 0 0;
	text-align: left;
}
.csn-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 18px;
	border-radius: 100px;
	font-family: var(--cs-font-sans);
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	border: none;
	cursor: pointer;
	letter-spacing: 0.01em;
	transition: opacity var(--cs-dur-base) var(--cs-ease);
}
.csn-btn--dark { background: var(--cs-fg); color: #fff; }
.csn-btn--dark:hover { opacity: .92; color: #fff; }
.csn-linklike {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: var(--cs-font-sans);
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-accent);
	text-decoration: none;
}
.csn-linklike:hover { text-decoration: underline; color: var(--cs-accent); }

/* Cross-link bar -------------------------------------------------------- */
.csn-crosslinks {
	padding: 36px 20px 40px;
	background: var(--cs-bg);
}
.csn-crosslinks__eyebrow {
	font-family: var(--cs-font-sans);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cs-accent);
	text-align: center;
	margin-bottom: 18px;
}
.csn-crosslinks__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
	max-width: 780px;
	margin: 0 auto;
}
.csn-crosslink {
	background: var(--cs-card);
	border-radius: 16px;
	padding: 18px;
	border: 1px solid var(--cs-line);
	display: flex;
	align-items: center;
	gap: 14px;
	text-decoration: none;
	color: inherit;
	transition: box-shadow var(--cs-dur-base) var(--cs-ease),
	            transform var(--cs-dur-base) var(--cs-ease);
}
.csn-crosslink:hover {
	box-shadow: 0 6px 20px rgba(26, 20, 18, .08);
	transform: translateY(-2px);
}
.csn-crosslink__icon {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	flex-shrink: 0;
	background: var(--cs-accent-soft);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.csn-crosslink__body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
}
.csn-crosslink__title {
	font-family: var(--cs-font-serif);
	font-size: 18px;
	font-weight: 600;
	color: var(--cs-fg);
	line-height: 1.2;
}
.csn-crosslink__teaser {
	font-family: var(--cs-font-sans);
	font-size: 12.5px;
	color: rgba(26, 20, 18, .6);
	line-height: 1.4;
	margin-top: 2px;
}
.csn-crosslink__arrow { flex-shrink: 0; }

/* Still have questions -------------------------------------------------- */
.csn-still {
	padding: 36px 20px 48px;
	background: var(--cs-bg-alt);
}
.csn-still__inner {
	max-width: 640px;
	margin: 0 auto;
	text-align: center;
}
.csn-still__title {
	font-family: var(--cs-font-serif);
	font-size: 28px;
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.01em;
	color: var(--cs-fg);
	margin: 0;
}
.csn-still__title em {
	font-style: italic;
	font-weight: 500;
	color: var(--cs-accent);
}
.csn-still__sub {
	font-family: var(--cs-font-sans);
	font-size: 14px;
	color: var(--cs-muted);
	margin: 14px 0 22px;
	line-height: 1.55;
}
.csn-still__links {
	display: flex;
	gap: 10px;
	justify-content: center;
	flex-wrap: wrap;
}
.csn-pill-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 11px 16px;
	background: var(--cs-card);
	border: 1px solid rgba(26, 20, 18, .09);
	border-radius: 100px;
	font-family: var(--cs-font-sans);
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-fg);
	text-decoration: none;
}
.csn-pill-link:hover { color: var(--cs-fg); text-decoration: none; border-color: rgba(26, 20, 18, .18); }

.csn-icon { flex-shrink: 0; display: inline-block; vertical-align: middle; }

/* ========================================================================
   Desktop (min-width: 768px)
   ======================================================================== */
@media (min-width: 768px) {
	.csn-faq-hero            { padding: 72px 40px 56px; }
	.csn-faq-hero__title     { font-size: 56px; }
	.csn-faq-hero__sub       { font-size: 20px; margin-top: 18px; }

	.csn-faq-chipnav__inner  { padding: 14px 40px; }

	.csn-faq-groups          { padding: 48px 40px; }
	.csn-faq-group__title    { font-size: 28px; }

	.csn-crosslinks          { padding: 48px 40px 56px; }
	.csn-crosslinks__grid    { grid-template-columns: 1fr 1fr; }
	.csn-crosslinks__eyebrow { margin-bottom: 24px; }

	.csn-still               { padding: 56px 40px 72px; }
	.csn-still__title        { font-size: 38px; }
	.csn-still__sub          { font-size: 15px; }
	.csn-still__links        { gap: 12px; }
}
