/* =========================================================
   German Shepherd Place Pro — Main Stylesheet
   Mobile-first, no framework. CSS variables from Customizer.
   ========================================================= */

:root {
	--gspp-charcoal:#1f2a24;
	--gspp-cream:#f7f1e7;
	--gspp-saddle:#6b4423;
	--gspp-forest:#2c4a3a;
	--gspp-tan:#c89b6c;
	--gspp-gold:#d4a949;
	--gspp-blue:#3b6fb6;
	--gspp-amber:#d97706;
	--gspp-white:#ffffff;
	--gspp-ink:#1d2421;
	--gspp-ink-2:#4a5550;
	--gspp-ink-3:#7d8682;
	--gspp-line:#e7dfd0;
	--gspp-surface:#fbf7ef;
	--gspp-success:#1f7a4d;

	--gspp-radius-xs:8px;
	--gspp-radius-sm:12px;
	--gspp-radius:18px;
	--gspp-radius-lg:24px;

	--gspp-shadow-sm:0 1px 2px rgba(31,42,36,.06), 0 2px 8px rgba(31,42,36,.04);
	--gspp-shadow:0 2px 6px rgba(31,42,36,.06), 0 12px 28px rgba(31,42,36,.08);
	--gspp-shadow-lg:0 6px 14px rgba(31,42,36,.08), 0 24px 56px rgba(31,42,36,.14);

	--gspp-sans: 'Inter', 'Manrope', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
	--gspp-serif: 'Fraunces', 'Playfair Display', Georgia, serif;
	--gspp-mono: 'JetBrains Mono', ui-monospace, Menlo, Consolas, monospace;
}

/* ---------- Base ---------- */
*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin:0; color:var(--gspp-ink); background:var(--gspp-cream);
	font-family:var(--gspp-sans); font-size:17px; line-height:1.6;
	-webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
img,svg,video { max-width:100%; height:auto; display:block; }
a { color:var(--gspp-forest); text-underline-offset:3px; }
a:hover { color:var(--gspp-saddle); }
h1,h2,h3,h4,h5 { font-family:var(--gspp-serif); color:var(--gspp-charcoal); letter-spacing:-0.01em; line-height:1.18; margin:0 0 .5em; }
h1 { font-size:clamp(2rem, 4vw + 1rem, 3.4rem); font-weight:600; }
h2 { font-size:clamp(1.5rem, 2vw + 1rem, 2.3rem); font-weight:600; }
h3 { font-size:1.25rem; font-weight:600; }
p { margin:0 0 1em; }
button { font:inherit; cursor:pointer; }
.screen-reader-text { position:absolute !important; clip:rect(1px,1px,1px,1px); width:1px; height:1px; overflow:hidden; }
.gspp-skip:focus { position:fixed; top:8px; left:8px; background:#fff; padding:8px 14px; border-radius:8px; z-index:9999; }

/* ---------- Layout helpers ---------- */
.gspp-container { width:100%; max-width:1200px; margin:0 auto; padding:0 20px; }
.gspp-container--narrow { max-width:820px; }
.gspp-grid { display:grid; gap:18px; }
.gspp-grid--2 { grid-template-columns:1fr; }
.gspp-grid--3 { grid-template-columns:1fr; }
.gspp-grid--4 { grid-template-columns:1fr 1fr; }
@media (min-width: 720px) {
	.gspp-grid--2 { grid-template-columns:1fr 1fr; }
	.gspp-grid--3 { grid-template-columns:1fr 1fr; }
	.gspp-grid--4 { grid-template-columns:1fr 1fr 1fr; }
}
@media (min-width: 1024px) {
	.gspp-grid--3 { grid-template-columns:1fr 1fr 1fr; }
	.gspp-grid--4 { grid-template-columns:repeat(4, 1fr); }
}

/* ---------- Header ---------- */
.gspp-header {
	position:sticky; top:0; z-index:30;
	background:rgba(247,241,231,.92); backdrop-filter:saturate(140%) blur(8px);
	border-bottom:1px solid var(--gspp-line);
}
.gspp-header__inner {
	display:flex; align-items:center; justify-content:space-between; gap:16px;
	padding:14px 20px;
}
.gspp-brand__link { display:inline-flex; align-items:center; gap:10px; text-decoration:none; color:var(--gspp-charcoal); }
.gspp-brand__mark {
	width:38px; height:38px; border-radius:12px;
	background:linear-gradient(135deg, var(--gspp-charcoal), var(--gspp-saddle));
	color:var(--gspp-gold); display:grid; place-items:center;
}
.gspp-brand__name { font-family:var(--gspp-serif); font-weight:600; font-size:1.05rem; }
.gspp-nav { display:none; }
.gspp-nav__list {
	display:flex; gap:22px; list-style:none; padding:0; margin:0;
	flex-wrap:nowrap;
}
.gspp-nav__list li { min-width:0; }
.gspp-nav__list a {
	display:inline-block;
	text-decoration:none; color:var(--gspp-charcoal); font-weight:500;
	white-space:nowrap;
	max-width:18ch;
	overflow:hidden;
	text-overflow:ellipsis;
	vertical-align:middle;
}
.gspp-nav__list a:hover { color:var(--gspp-saddle); }
@media (min-width: 960px) { .gspp-nav { display:block; } }

/* Footer menu defensive — long titles never blow the column width. */
.gspp-footer__menu a { display:inline-block; max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.gspp-header__actions { display:flex; align-items:center; gap:10px; }
.gspp-header__cta {
	display:none; padding:9px 16px; background:var(--gspp-charcoal); color:#fff;
	border-radius:999px; text-decoration:none; font-weight:600; font-size:.92rem;
}
.gspp-header__cta:hover { background:var(--gspp-saddle); color:#fff; }
@media (min-width: 720px) { .gspp-header__cta { display:inline-flex; } }

.gspp-menu-toggle {
	display:inline-flex; flex-direction:column; gap:4px; width:38px; height:38px;
	background:transparent; border:1px solid var(--gspp-line); border-radius:10px; padding:9px;
}
.gspp-menu-toggle span { display:block; height:2px; background:var(--gspp-charcoal); border-radius:2px; }
@media (min-width: 960px) { .gspp-menu-toggle { display:none; } }

.gspp-search-toggle { background:transparent; border:1px solid var(--gspp-line); border-radius:10px; padding:8px; color:var(--gspp-charcoal); }
.gspp-search-bar { border-top:1px solid var(--gspp-line); padding:12px 0; background:#fff; }
.gspp-search { display:flex; gap:8px; max-width:600px; margin:0 auto; }
.gspp-search input[type=search] { flex:1; padding:10px 14px; border:1px solid var(--gspp-line); border-radius:999px; font:inherit; }
.gspp-search__btn { padding:10px 16px; background:var(--gspp-charcoal); color:#fff; border:0; border-radius:999px; font-weight:600; }

/* ---------- Disclaimer pills ---------- */
.gspp-pill {
	display:inline-flex; align-items:center; gap:6px;
	padding:6px 12px; border-radius:999px; font-size:.78rem;
	background:var(--gspp-surface); border:1px solid var(--gspp-line); color:var(--gspp-ink-2);
}
.gspp-pill--vet     { background:#eef5ff; border-color:#d0e0f5; color:#1f3a5a; }
.gspp-pill--trainer { background:#f0f7ee; border-color:#d2e7c8; color:#274d1f; }
.gspp-pill--aff     { background:#fff7eb; border-color:#f5e1bd; color:#6b4423; }

.gspp-disclaimer { border-radius:var(--gspp-radius-sm); padding:12px 14px; font-size:.93rem; line-height:1.5; margin:12px 0; }
.gspp-disclaimer--vet     { background:#eef5ff; color:#1f3a5a; border:1px solid #d0e0f5; }
.gspp-disclaimer--trainer { background:#f0f7ee; color:#274d1f; border:1px solid #d2e7c8; }
.gspp-disclaimer--aff     { background:#fff7eb; color:#6b4423; border:1px solid #f5e1bd; }
.gspp-disclaimer-inline   { font-size:.85rem; color:var(--gspp-ink-3); }

/* ---------- Hero ---------- */
.gspp-hero { position:relative; padding:48px 0 64px; overflow:hidden; }
.gspp-hero__bg {
	position:absolute; inset:0;
	background:
		radial-gradient(80% 60% at 0% 0%, rgba(212,169,73,.22), transparent 60%),
		radial-gradient(70% 60% at 100% 100%, rgba(44,74,58,.22), transparent 60%),
		linear-gradient(135deg, #f7f1e7 0%, #fbf7ef 100%);
}
.gspp-hero__inner { position:relative; display:grid; gap:36px; grid-template-columns:1fr; align-items:center; }
@media (min-width: 960px) { .gspp-hero__inner { grid-template-columns: 1.05fr .95fr; } .gspp-hero { padding:80px 0 96px; } }

.gspp-eyebrow {
	display:inline-block; padding:6px 12px; border-radius:999px;
	background:rgba(31,42,36,.08); color:var(--gspp-charcoal); font-weight:600; font-size:.78rem; letter-spacing:.04em; text-transform:uppercase;
	margin-bottom:14px;
}
.gspp-hero__title { font-family:var(--gspp-serif); }
.gspp-hero__sub { font-size:1.1rem; color:var(--gspp-ink-2); max-width:60ch; }
.gspp-hero__ctas { display:flex; flex-wrap:wrap; gap:12px; margin:24px 0; }
.gspp-hero__pills { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.gspp-hero__chips { display:flex; flex-wrap:wrap; gap:8px; list-style:none; padding:0; margin:20px 0 0; }
.gspp-hero__chips li {
	padding:6px 12px; background:#fff; border:1px solid var(--gspp-line);
	border-radius:999px; font-size:.85rem; color:var(--gspp-ink-2); font-weight:500;
}

.gspp-hero__visual { position:relative; min-height:280px; }
.gspp-hero__photo {
	position:relative; aspect-ratio: 5/4; border-radius:var(--gspp-radius-lg); overflow:hidden;
	background:
		radial-gradient(circle at 30% 30%, rgba(255,255,255,.4), transparent 50%),
		linear-gradient(135deg, var(--gspp-saddle) 0%, var(--gspp-charcoal) 60%, var(--gspp-forest) 100%);
	color:var(--gspp-gold); display:grid; place-items:center; box-shadow:var(--gspp-shadow-lg);
}
.gspp-hero__photo-label {
	position:absolute; bottom:14px; left:16px; right:16px;
	color:#fff; font-family:var(--gspp-serif); font-size:1rem; font-weight:500;
	background:rgba(31,42,36,.55); padding:8px 12px; border-radius:10px; backdrop-filter:blur(4px);
}
.gspp-hero__widget {
	position:absolute; background:#fff; border-radius:var(--gspp-radius-sm); padding:12px 14px;
	box-shadow:var(--gspp-shadow); width:220px;
}
.gspp-hero__widget-head { display:flex; align-items:center; gap:8px; color:var(--gspp-charcoal); font-size:.92rem; margin-bottom:6px; }
.gspp-hero__widget p { margin:0 0 8px; color:var(--gspp-ink-2); font-size:.88rem; line-height:1.3; }
.gspp-hero__widget--train { left:-12px; bottom:30px; }
.gspp-hero__widget--gear  { right:-12px; top:30px; }
.gspp-hero__widget-link { font-size:.85rem; color:var(--gspp-saddle); text-decoration:none; font-weight:600; }
.gspp-progress { height:6px; background:var(--gspp-line); border-radius:999px; overflow:hidden; }
.gspp-progress__bar { height:100%; background:linear-gradient(90deg, var(--gspp-saddle), var(--gspp-gold)); width:0; transition:width .35s ease; }

/* ---------- Buttons ---------- */
.gspp-btn {
	display:inline-flex; align-items:center; gap:8px; padding:13px 22px;
	border-radius:999px; text-decoration:none; font-weight:600; border:0; transition:transform .12s ease, background .15s ease;
}
.gspp-btn:active { transform:translateY(1px); }
.gspp-btn--primary { background:var(--gspp-charcoal); color:#fff; }
.gspp-btn--primary:hover { background:var(--gspp-saddle); color:#fff; }
.gspp-btn--ghost { background:transparent; color:var(--gspp-charcoal); border:1.5px solid var(--gspp-charcoal); }
.gspp-btn--ghost:hover { background:var(--gspp-charcoal); color:#fff; }
.gspp-btn-ghost { background:transparent; border:1px solid var(--gspp-line); color:var(--gspp-charcoal); padding:8px 14px; border-radius:999px; font-weight:600; }
.gspp-btn-ghost:hover { background:#fff; }
.gspp-btn-ghost--sm { padding:6px 10px; font-size:.85rem; }

.gspp-amz-btn {
	display:inline-flex; align-items:center; gap:8px;
	background:linear-gradient(180deg, #ffcf4f, #f9b81e); color:#1f2a24;
	border-radius:999px; padding:11px 18px; font-weight:700; text-decoration:none;
	box-shadow:0 1px 0 #c08e00 inset, 0 1px 6px rgba(31,42,36,.15);
}
.gspp-amz-btn:hover { background:linear-gradient(180deg, #ffd86b, #fcbf32); color:#1f2a24; }
.gspp-amz-btn--sm { padding:8px 14px; font-size:.88rem; }
.gspp-amz-btn--lg { padding:14px 22px; font-size:1.05rem; }
.gspp-amz-btn__arrow { transition:transform .15s ease; }
.gspp-amz-btn:hover .gspp-amz-btn__arrow { transform:translateX(3px); }

/* ---------- Sections ---------- */
.gspp-section { padding:64px 0; }
.gspp-section--alt { background:var(--gspp-surface); }
.gspp-section__head { text-align:center; max-width:720px; margin:0 auto 32px; }
.gspp-section__head h2 { margin-bottom:.4em; }
.gspp-section__head p { color:var(--gspp-ink-2); }
.gspp-section__head .gspp-pill { margin:6px 4px 0; }
.gspp-section__foot { text-align:center; margin-top:18px; }

.gspp-h2 { margin:36px 0 16px; }

/* ---------- Strip (vet/trainer/affiliate row) ---------- */
.gspp-strip { background:linear-gradient(180deg, #fff, #fbf7ef); border-top:1px solid var(--gspp-line); border-bottom:1px solid var(--gspp-line); padding:12px 0; }
.gspp-strip__inner { display:grid; gap:10px; grid-template-columns:1fr; }
@media (min-width: 880px) { .gspp-strip__inner { grid-template-columns:1fr 1fr 1fr; } }
.gspp-strip__item { display:flex; gap:10px; align-items:flex-start; color:var(--gspp-ink-2); font-size:.88rem; }
.gspp-strip__item svg { flex:0 0 auto; color:var(--gspp-saddle); }

/* ---------- Quick start ---------- */
.gspp-quick-grid {
	display:grid; gap:12px; grid-template-columns:repeat(2, 1fr);
}
@media (min-width: 640px) { .gspp-quick-grid { grid-template-columns:repeat(3, 1fr); } }
@media (min-width: 960px) { .gspp-quick-grid { grid-template-columns:repeat(4, 1fr); } }
@media (min-width: 1180px){ .gspp-quick-grid { grid-template-columns:repeat(6, 1fr); } }
.gspp-quick-tile {
	background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius);
	padding:18px 14px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:10px;
	transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.gspp-quick-tile:hover { transform:translateY(-2px); box-shadow:var(--gspp-shadow); border-color:var(--gspp-tan); }
.gspp-quick-tile.is-active { border-color:var(--gspp-charcoal); box-shadow:var(--gspp-shadow); }
.gspp-quick-tile__icon {
	width:44px; height:44px; border-radius:12px;
	background:linear-gradient(135deg, var(--gspp-cream), #fff);
	color:var(--gspp-saddle); display:grid; place-items:center;
}
.gspp-quick-tile strong { font-size:.92rem; color:var(--gspp-charcoal); }

/* ---------- Tool wrapper ---------- */
.gspp-tool {
	background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius-lg);
	padding:22px; box-shadow:var(--gspp-shadow-sm);
}
.gspp-tool__head { display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.gspp-tool__head .gspp-progress { flex:1; }
.gspp-tool__step { font-family:var(--gspp-mono); font-size:.85rem; color:var(--gspp-ink-3); }
.gspp-tool__body { min-height:160px; }
.gspp-tool__foot { display:flex; justify-content:flex-end; margin-top:14px; }
.gspp-tool__result { margin-top:20px; padding:20px; border-radius:var(--gspp-radius); background:linear-gradient(180deg, #fff, var(--gspp-surface)); border:1px solid var(--gspp-line); }
.gspp-tool__result h3 { margin-top:0; }

/* ---------- Quiz ---------- */
.gspp-quiz-q { display:none; }
.gspp-quiz-q.is-active { display:block; animation: gsppFade .25s ease; }
@keyframes gsppFade { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }
.gspp-quiz-q__title { font-family:var(--gspp-serif); margin-bottom:18px; }
.gspp-quiz-q__opts { display:grid; gap:10px; grid-template-columns:1fr; }
@media (min-width: 540px) { .gspp-quiz-q__opts { grid-template-columns:1fr 1fr; } }
.gspp-quiz-opt {
	text-align:left; background:#fff; border:1.5px solid var(--gspp-line); border-radius:14px;
	padding:14px 16px; color:var(--gspp-charcoal); font-weight:500;
	transition:border-color .15s ease, transform .12s ease, background .15s ease;
}
.gspp-quiz-opt:hover { border-color:var(--gspp-saddle); background:var(--gspp-surface); }
.gspp-quiz-opt.is-selected { border-color:var(--gspp-charcoal); background:var(--gspp-charcoal); color:#fff; }
.gspp-quiz-q__nav { margin-top:14px; }
.gspp-quiz-result__title { font-family:var(--gspp-serif); margin-bottom:8px; }

/* ---------- Form grid ---------- */
.gspp-form-grid { display:grid; gap:14px; grid-template-columns:1fr; }
@media (min-width: 700px) { .gspp-form-grid { grid-template-columns:1fr 1fr; } }
@media (min-width: 1000px){ .gspp-form-grid { grid-template-columns:1fr 1fr 1fr; } }
.gspp-form-grid label { display:flex; flex-direction:column; gap:6px; font-size:.88rem; color:var(--gspp-ink-2); font-weight:500; }
.gspp-form-grid input,
.gspp-form-grid select {
	padding:10px 12px; border:1px solid var(--gspp-line); border-radius:10px; font:inherit; background:#fff; color:var(--gspp-charcoal);
}
.gspp-form-grid__actions { grid-column: 1 / -1; display:flex; gap:10px; }

/* ---------- Product box ---------- */
.gspp-prodbox {
	background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius);
	padding:18px; display:flex; flex-direction:column; gap:10px; box-shadow:var(--gspp-shadow-sm);
	transition:transform .15s ease, box-shadow .15s ease;
}
.gspp-prodbox:hover { transform:translateY(-2px); box-shadow:var(--gspp-shadow); }
.gspp-prodbox__head { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.gspp-prodbox__badge { background:var(--gspp-charcoal); color:var(--gspp-gold); padding:4px 10px; border-radius:999px; font-size:.72rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; }
.gspp-prodbox__title { font-family:var(--gspp-serif); font-size:1.1rem; margin:0; }
.gspp-prodbox__best, .gspp-prodbox__sizing { margin:0; font-size:.92rem; color:var(--gspp-ink-2); }
.gspp-prodbox__procon { display:grid; grid-template-columns:1fr 1fr; gap:14px; font-size:.88rem; }
.gspp-pros, .gspp-cons { list-style:none; padding:0; margin:0; }
.gspp-pros li::before { content:"✓"; color:var(--gspp-success); font-weight:700; margin-right:6px; }
.gspp-cons li::before { content:"–"; color:var(--gspp-amber); font-weight:700; margin-right:6px; }
.gspp-prodbox__cta { display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-top:auto; }
.gspp-prodbox__disclosure { font-size:.72rem; color:var(--gspp-ink-3); margin:6px 0 0; }
.gspp-prodbox--hero { padding:24px; }
.gspp-prodbox--sidebar { position:sticky; top:88px; }
.gspp-prodbox--inline { padding:14px; flex-direction:row; align-items:center; }
.gspp-stage {
	font-family:var(--gspp-mono); font-size:.7rem; letter-spacing:.04em; text-transform:uppercase;
	padding:3px 8px; border-radius:999px; background:var(--gspp-surface); color:var(--gspp-ink-2); border:1px solid var(--gspp-line);
}
.gspp-stage--puppy   { background:#eaf3ff; color:#1f3a5a; border-color:#d0e0f5; }
.gspp-stage--adult   { background:#f0f7ee; color:#274d1f; border-color:#d2e7c8; }
.gspp-stage--senior  { background:#fff1e6; color:#7a3d10; border-color:#f5d4b0; }
.gspp-stage--adolescent { background:#fef6e0; color:#705a14; border-color:#efe1ad; }

/* ---------- Compare drawer ---------- */
.gspp-compare-rail {
	display:flex; gap:10px; padding:14px; border:1px dashed var(--gspp-line); border-radius:var(--gspp-radius);
	background:#fff; margin-bottom:18px; min-height:78px; overflow-x:auto;
}
.gspp-compare-rail__empty { color:var(--gspp-ink-3); margin:auto; font-size:.92rem; }
.gspp-compare-rail__item {
	flex:0 0 220px; padding:10px 12px; border:1px solid var(--gspp-line); border-radius:14px; background:var(--gspp-surface);
	display:flex; flex-direction:column; gap:4px;
}
.gspp-compare-rail__remove { align-self:flex-end; background:transparent; border:0; font-size:1rem; color:var(--gspp-ink-3); }
.gspp-compare-table-wrap { overflow-x:auto; }
.gspp-compare-table { width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius); overflow:hidden; }
.gspp-compare-table th, .gspp-compare-table td { padding:12px 14px; text-align:left; border-bottom:1px solid var(--gspp-line); font-size:.92rem; }
.gspp-compare-table th { background:var(--gspp-surface); color:var(--gspp-charcoal); font-weight:600; }
.gspp-compare-table tbody tr:last-child td { border-bottom:0; }

.gspp-compare-drawer {
	position:fixed; right:-380px; top:0; height:100vh; width:360px; background:#fff; border-left:1px solid var(--gspp-line);
	box-shadow:var(--gspp-shadow-lg); z-index:60; transition:right .25s ease; display:flex; flex-direction:column;
}
.gspp-compare-drawer.is-open { right:0; }
.gspp-compare__head { padding:16px 18px; border-bottom:1px solid var(--gspp-line); display:flex; align-items:center; justify-content:space-between; }
.gspp-compare__close { background:transparent; border:0; font-size:1.3rem; }
.gspp-compare__body { padding:14px 18px; overflow:auto; flex:1; display:flex; flex-direction:column; gap:10px; }
.gspp-compare__foot { padding:12px 18px; border-top:1px solid var(--gspp-line); }
.gspp-compare-fab {
	position:fixed; right:16px; bottom:90px; z-index:55;
	background:var(--gspp-charcoal); color:#fff; border:0; padding:12px 16px; border-radius:999px;
	font-weight:700; box-shadow:var(--gspp-shadow); display:inline-flex; gap:8px; align-items:center;
}
.gspp-compare-fab[hidden] { display:none; }

.gspp-care-fab {
	position:fixed; right:16px; bottom:24px; z-index:55;
	background:#fff; color:var(--gspp-saddle); border:1px solid var(--gspp-line); border-radius:999px;
	width:54px; height:54px; display:grid; place-items:center; box-shadow:var(--gspp-shadow);
}

/* ---------- Compare button on cards ---------- */
.gspp-compare-add {
	background:transparent; border:1px solid var(--gspp-line); padding:8px 12px;
	border-radius:999px; font-weight:600; color:var(--gspp-charcoal); font-size:.88rem;
}
.gspp-compare-add.is-added { background:var(--gspp-charcoal); color:#fff; border-color:var(--gspp-charcoal); }

/* ---------- Care DB ---------- */
.gspp-cdb-controls { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:18px; }
.gspp-cdb-search { flex:1; min-width:240px; padding:10px 14px; border:1px solid var(--gspp-line); border-radius:999px; font:inherit; }
.gspp-cdb-filters { display:flex; gap:6px; flex-wrap:wrap; }
.gspp-chip {
	padding:8px 12px; border:1px solid var(--gspp-line); background:#fff; border-radius:999px; font-weight:500; font-size:.88rem;
}
.gspp-chip.is-active { background:var(--gspp-charcoal); color:#fff; border-color:var(--gspp-charcoal); }
.gspp-cdb-grid { display:grid; gap:14px; grid-template-columns:1fr; }
@media (min-width: 720px) { .gspp-cdb-grid { grid-template-columns:1fr 1fr; } }
@media (min-width: 1024px) { .gspp-cdb-grid { grid-template-columns:1fr 1fr 1fr; } }
.gspp-cdb-card { background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius); padding:18px; display:flex; flex-direction:column; gap:10px; }
.gspp-cdb-card header { display:flex; justify-content:space-between; align-items:center; gap:8px; }
.gspp-cdb-card__foot { margin-top:auto; }

/* ---------- Beginner hub ---------- */
.gspp-hub-card {
	background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius);
	padding:20px; text-decoration:none; color:var(--gspp-charcoal);
	display:flex; flex-direction:column; gap:8px; transition:transform .15s ease, box-shadow .15s ease;
}
.gspp-hub-card:hover { transform:translateY(-2px); box-shadow:var(--gspp-shadow); color:var(--gspp-saddle); }
.gspp-hub-card__icon { width:36px; height:36px; border-radius:10px; background:var(--gspp-surface); display:grid; place-items:center; color:var(--gspp-saddle); }
.gspp-hub-card__cta { margin-top:auto; font-weight:600; }

/* ---------- FAQ ---------- */
.gspp-faq { display:flex; flex-direction:column; gap:8px; }
.gspp-faq__item { background:#fff; border:1px solid var(--gspp-line); border-radius:14px; padding:0 16px; }
.gspp-faq__item summary { padding:14px 0; font-weight:600; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; }
.gspp-faq__item summary::after { content:"+"; font-size:1.4rem; color:var(--gspp-ink-3); }
.gspp-faq__item[open] summary::after { content:"−"; }
.gspp-faq__body { padding-bottom:14px; color:var(--gspp-ink-2); }

/* ---------- Newsletter ---------- */
.gspp-newsletter { background:linear-gradient(135deg, var(--gspp-charcoal), var(--gspp-forest)); color:#fff; }
.gspp-newsletter h2 { color:#fff; }
.gspp-newsletter p { color:rgba(255,255,255,.85); }
.gspp-newsletter__inner { display:grid; gap:24px; align-items:center; grid-template-columns:1fr; }
@media (min-width: 800px) { .gspp-newsletter__inner { grid-template-columns:1fr 1fr; } }
.gspp-newsletter__form { display:flex; flex-wrap:wrap; gap:10px; }
.gspp-newsletter__form input { flex:1; min-width:220px; padding:13px 16px; border-radius:999px; border:0; font:inherit; }
.gspp-newsletter__form .gspp-btn { background:var(--gspp-gold); color:var(--gspp-charcoal); }
.gspp-newsletter__note { width:100%; font-size:.78rem; color:rgba(255,255,255,.7); }

/* ---------- Trust ---------- */
.gspp-trust-card { background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius); padding:20px; display:flex; gap:14px; }
.gspp-trust-card__icon { width:38px; height:38px; flex:0 0 auto; border-radius:10px; background:var(--gspp-surface); color:var(--gspp-success); display:grid; place-items:center; }

/* ---------- Footer ---------- */
.gspp-footer { background:var(--gspp-charcoal); color:#dfe6e1; padding:56px 0 24px; }
.gspp-footer__grid { display:grid; gap:32px; grid-template-columns:1fr; }
@media (min-width: 900px) { .gspp-footer__grid { grid-template-columns: 1.2fr 2fr; } }
.gspp-footer__about .gspp-brand__name, .gspp-footer .gspp-brand__name { color:#fff; }
.gspp-footer__desc { color:rgba(255,255,255,.7); font-size:.92rem; }
.gspp-footer__disclaimer, .gspp-footer__disclosure { font-size:.78rem; color:rgba(255,255,255,.6); margin-top:10px; }
.gspp-footer__cols { display:grid; gap:24px; grid-template-columns:1fr 1fr 1fr; }
.gspp-footer__col h4 { color:#fff; font-family:var(--gspp-sans); font-size:.95rem; margin:0 0 10px; }
.gspp-footer__menu { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:6px; }
.gspp-footer__menu a { color:rgba(255,255,255,.78); text-decoration:none; font-size:.92rem; }
.gspp-footer__menu a:hover { color:var(--gspp-gold); }
.gspp-footer__bottom { display:flex; justify-content:space-between; gap:10px; margin-top:32px; padding-top:16px; border-top:1px solid rgba(255,255,255,.1); color:rgba(255,255,255,.55); }

/* ---------- Archive / single ---------- */
.gspp-archive { padding:48px 0; }
.gspp-archive__title { margin-bottom:24px; }
.gspp-post-card { background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius); overflow:hidden; display:flex; flex-direction:column; }
.gspp-post-card__img img { width:100%; aspect-ratio: 16/10; object-fit:cover; }
.gspp-post-card__body { padding:18px; display:flex; flex-direction:column; gap:8px; }
.gspp-post-card__title { font-size:1.05rem; margin:0; }
.gspp-post-card__title a { color:var(--gspp-charcoal); text-decoration:none; }
.gspp-post-card__meta { font-size:.78rem; color:var(--gspp-ink-3); margin:0; }
.gspp-post-card__excerpt { color:var(--gspp-ink-2); margin:0; font-size:.92rem; }
.gspp-pagination { margin-top:32px; display:flex; justify-content:center; }

.gspp-single { padding:48px 0; }
.gspp-single__title { margin-bottom:8px; }
.gspp-single__meta { color:var(--gspp-ink-3); font-size:.88rem; }
.gspp-single__hero { margin:20px 0; border-radius:var(--gspp-radius); overflow:hidden; }
.gspp-prose { font-size:1.08rem; line-height:1.75; color:var(--gspp-ink); }
.gspp-prose h2, .gspp-prose h3 { margin-top:1.6em; }
.gspp-related { margin-top:60px; padding-top:32px; border-top:1px solid var(--gspp-line); }
.gspp-page { padding:48px 0; }

.gspp-crumbs ol { list-style:none; display:flex; flex-wrap:wrap; gap:6px; padding:0; margin:0 0 12px; font-size:.85rem; color:var(--gspp-ink-3); }
.gspp-crumbs li + li::before { content:"›"; margin-right:6px; color:var(--gspp-ink-3); }
.gspp-crumbs a { color:var(--gspp-ink-2); text-decoration:none; }

/* ---------- 404 ---------- */
.gspp-404 { padding:48px 0 80px; }
.gspp-404__hero { display:grid; gap:24px; grid-template-columns:1fr; margin-bottom:36px; }
@media (min-width: 880px) { .gspp-404__hero { grid-template-columns: 1fr 1fr; } }
.gspp-404__text h1 { font-family:var(--gspp-serif); }
.gspp-404__search { margin:36px 0; }
.gspp-cat-tile {
	background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius);
	padding:16px; text-decoration:none; color:var(--gspp-charcoal); display:flex; flex-direction:column; gap:6px;
}
.gspp-cat-tile:hover { border-color:var(--gspp-saddle); box-shadow:var(--gspp-shadow); }

/* ---------- Cards (generic) ---------- */
.gspp-card { background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius); padding:20px; }
.gspp-card--link { text-decoration:none; color:var(--gspp-charcoal); display:flex; flex-direction:column; gap:8px; transition:transform .12s ease; }
.gspp-card--link:hover { transform:translateY(-2px); box-shadow:var(--gspp-shadow); }

/* ---------- Trackers ---------- */
.gspp-grooming__profile { margin-bottom:14px; }
.gspp-grooming__profile label { display:flex; flex-direction:column; gap:6px; max-width:340px; }
.gspp-grooming__profile input { padding:10px 12px; border:1px solid var(--gspp-line); border-radius:10px; font:inherit; }
.gspp-grooming__grid { display:grid; gap:12px; grid-template-columns:1fr; }
@media (min-width: 700px) { .gspp-grooming__grid { grid-template-columns:1fr 1fr; } }
@media (min-width: 1000px) { .gspp-grooming__grid { grid-template-columns:1fr 1fr 1fr 1fr; } }
.gspp-grooming-card { background:#fff; border:1px solid var(--gspp-line); border-radius:14px; padding:14px; display:flex; flex-direction:column; gap:6px; }
.gspp-grooming-card header { display:flex; justify-content:space-between; align-items:flex-start; gap:6px; }
.gspp-muted { color:var(--gspp-ink-3); font-size:.78rem; }
.gspp-grooming-card__actions { display:flex; gap:6px; margin-top:auto; }
.gspp-grooming__actions { display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }

.gspp-health__form { display:grid; gap:10px; grid-template-columns:1fr; margin-bottom:14px; align-items:end; }
@media (min-width: 700px) { .gspp-health__form { grid-template-columns:1fr 1fr 2fr auto; } }
.gspp-health__form label { display:flex; flex-direction:column; gap:6px; font-size:.85rem; color:var(--gspp-ink-2); }
.gspp-health__form input, .gspp-health__form select { padding:10px 12px; border:1px solid var(--gspp-line); border-radius:10px; font:inherit; }
.gspp-health__list { list-style:none; padding:0; margin:0 0 14px; display:flex; flex-direction:column; gap:8px; }
.gspp-health__list li { background:var(--gspp-surface); border:1px solid var(--gspp-line); border-radius:12px; padding:10px 14px; display:flex; justify-content:space-between; gap:10px; flex-wrap:wrap; }
.gspp-health__actions { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:14px; }

.gspp-dogmap__list { list-style:none; padding:0; margin:14px 0; display:flex; flex-direction:column; gap:8px; }
.gspp-dogmap__list li { background:#fff; border:1px solid var(--gspp-line); border-radius:12px; padding:10px 14px; display:flex; justify-content:space-between; gap:10px; flex-wrap:wrap; align-items:center; }

/* ---------- Visualizer ---------- */
.gspp-vis__canvas { margin:18px 0; padding:16px; background:var(--gspp-surface); border-radius:var(--gspp-radius); display:grid; place-items:center; color:var(--gspp-saddle); }
.gspp-vis__svg { width:100%; max-width:480px; height:auto; }
.gspp-vis__zone.is-highlight { stroke:var(--gspp-amber); stroke-width:2.5; }

/* ---------- Training plan ---------- */
.gspp-training-plan__picker { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.gspp-training-plan__picker select { padding:10px 12px; border:1px solid var(--gspp-line); border-radius:10px; font:inherit; }
.gspp-training-days { display:grid; gap:10px; grid-template-columns:1fr; margin-top:14px; }
@media (min-width: 700px) { .gspp-training-days { grid-template-columns:1fr 1fr; } }
.gspp-training-days__day { background:#fff; border:1px solid var(--gspp-line); border-radius:12px; padding:12px 14px; }
.gspp-training-days__day h4 { margin:0 0 6px; font-family:var(--gspp-sans); font-size:.92rem; }
.gspp-training-days__day ul { margin:0; padding-left:20px; color:var(--gspp-ink-2); font-size:.92rem; }

/* ---------- Quick answer ---------- */
.gspp-quick-answer { background:#fff7eb; border:1px solid #f5e1bd; border-left:4px solid var(--gspp-gold); padding:14px 16px; border-radius:12px; margin:18px 0; }
.gspp-quick-answer__q { color:var(--gspp-charcoal); font-family:var(--gspp-serif); display:block; margin-bottom:4px; }

/* ---------- Bundle ---------- */
.gspp-bundle { background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius); padding:18px; }
.gspp-bundle__title { margin:0 0 12px; font-family:var(--gspp-serif); }
.gspp-bundle__list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.gspp-bundle__list li { display:flex; justify-content:space-between; gap:10px; align-items:center; padding:10px 12px; background:var(--gspp-surface); border-radius:10px; }

/* ---------- Procon (block) ---------- */
.gspp-procon { display:grid; gap:14px; grid-template-columns:1fr; margin:18px 0; padding:16px; background:#fff; border:1px solid var(--gspp-line); border-radius:var(--gspp-radius); }
@media (min-width: 600px) { .gspp-procon { grid-template-columns:1fr 1fr; } }

/* ---------- Swipe rail (mobile) ---------- */
@media (max-width: 720px) {
	.gspp-swipe { display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:8px; }
	.gspp-swipe > * { flex:0 0 86%; scroll-snap-align:start; }
}

/* ---------- Quiz result ---------- */
.gspp-quiz-result { animation: gsppFade .25s ease; }
/* Belt-and-suspenders: when JS marks the quiz finished, collapse the body + head
   even if inline style:none wasn't set (e.g. cached older JS). */
.gspp-quiz-tool.is-finished .gspp-tool__body { display:none !important; min-height:0 !important; }
.gspp-quiz-tool.is-finished .gspp-tool__head { display:none !important; }
.gspp-quiz-result__gear { display:grid; gap:10px; grid-template-columns:1fr; margin-top:14px; }
@media (min-width: 700px) { .gspp-quiz-result__gear { grid-template-columns:1fr 1fr; } }
.gspp-quiz-result__gear li { background:#fff; border:1px solid var(--gspp-line); border-radius:12px; padding:10px 14px; display:flex; justify-content:space-between; gap:10px; align-items:center; }

/* ---------- Misc ---------- */
.gspp-sortable { list-style:none; padding:0; margin:0; }
.gspp-sortable__item { background:#fff; border:1px solid var(--gspp-line); border-radius:10px; padding:8px 12px; margin-bottom:6px; display:flex; align-items:center; gap:10px; }

/* ---------- Internal-link block ---------- */
.gspp-internal-links { margin:48px 0 24px; padding:28px; background:var(--gspp-surface); border:1px solid var(--gspp-line); border-radius:var(--gspp-radius); }
.gspp-internal-links h2 { font-family:var(--gspp-serif); margin-top:0; }
.gspp-il-col h3 { font-size:.95rem; margin:0 0 8px; color:var(--gspp-charcoal); font-family:var(--gspp-sans); }
.gspp-il-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:6px; }
.gspp-il-list a { color:var(--gspp-saddle); text-decoration:none; font-weight:600; }
.gspp-il-list a:hover { color:var(--gspp-charcoal); text-decoration:underline; }

.gspp-prose ul, .gspp-prose ol { padding-left:1.3em; }
.gspp-prose table { width:100%; border-collapse:collapse; margin:14px 0; }
.gspp-prose th, .gspp-prose td { padding:10px 12px; border-bottom:1px solid var(--gspp-line); text-align:left; }
.gspp-prose th { background:var(--gspp-surface); font-weight:600; }

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
	* { animation-duration:.001s !important; transition-duration:.001s !important; }
}
