@font-face {
font-family: "Inter";
src: url("/assets/fonts/inter-latin.woff2") format("woff2");
font-weight: 100 900;
font-style: normal;
font-display: optional;
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC,
U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
font-family: "Inter";
src: url("/assets/fonts/inter-latin-ext.woff2") format("woff2");
font-weight: 100 900;
font-style: normal;
font-display: optional;
unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F,
U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

*,
*::before,
*::after {
box-sizing: border-box;
}

* {
margin: 0;
}

html {
-webkit-text-size-adjust: 100%;
font-synthesis: none;
}

body {
min-height: 100vh;
line-height: 1.65;
-webkit-font-smoothing: antialiased;
}

img,
picture,
video,
canvas,
svg {
display: block;
max-width: 100%;
}

input,
button,
textarea,
select {
font: inherit;
}

a {
color: inherit;
}

:root {

--color-paper-50: #fdfbf7;
--color-paper-100: #f5f0e8;
--color-paper-200: #e8dfd0;

--color-ink-900: #1c1b19;
--color-ink-700: #3d3a36;

--color-sage-600: #557559;
--color-sage-500: #6b8f71;
--color-sage-200: #c5d4c7;
--color-sage-50: #f1f5f2;

--color-cta-yellow: #ffd814;
--color-cta-yellow-hover: #f7ca00;
--color-cta-border: #fcd200;

--color-whatsapp: #25d366;

--color-amber-soft: #faf3e6;
--color-amber-border: #e8d4a8;
--color-vehicles: #d4943c;
--color-animals: #8b7cb6;
--color-nature: #5da88f;
--color-activity: #c4785a;

--color-text: var(--color-ink-900);
--color-text-muted: #5e5854;
--color-bg: #ffffff;
--color-bg-surface: var(--color-paper-100);
--color-border: var(--color-paper-200);
--color-ring: rgba(85, 117, 89, 0.35);
--color-link: var(--color-sage-600);
--color-link-hover: #3f5a43;
--color-brand: var(--color-sage-600);
--color-brand-light: var(--color-sage-50);
--color-brand-dark: #3f5a43;

--container-prose-max: 36rem;
--container-wide-max: 64rem;
--container-shop-max: 90rem;
--page-gutter-x: 1.25rem;
--color-header-text: var(--color-ink-900);
--color-footer-bg: var(--color-paper-100);
--color-footer-text: var(--color-ink-700);

--color-orange: var(--color-sage-500);
--font-display: "Inter", "Segoe UI", system-ui, -apple-system, Roboto, Arial, sans-serif;
--font-body: "Inter", "Segoe UI", system-ui, -apple-system, Roboto, Arial, sans-serif;
--shadow-sm: 0 1px 2px rgba(28, 27, 25, 0.05);
--shadow-card-hover: 0 4px 14px rgba(28, 27, 25, 0.07);
--radius-card: 16px;
--radius-pill: 999px;
--radius-btn: 14px;
--radius-input: 14px;
--radius-hero: 20px;
--radius-logo: 12px;
--section-pad-y: 32px;
--section-pad-x: var(--page-gutter-x);
}

@media (min-width: 768px) {
:root {
--section-pad-y: 48px;
--page-gutter-x: 1.5rem;
--section-pad-x: var(--page-gutter-x);
}
}

body {
font-family: "Inter", "Arial", sans-serif;
font-size-adjust: 1;
size-adjust: 100%;
font-size: 15px;
color: var(--color-text);
background: var(--color-paper-50);
}

* {
font-family: inherit;
}

@media (min-width: 768px) {
body {
font-size: 16px;
}
}

h1,
h2,
h3 {
font-family: var(--font-display);
line-height: 1.35;
font-weight: 600;
color: var(--color-ink-900);
letter-spacing: -0.02em;
}

h1 {
font-size: 1.85rem;
font-weight: 700;
}

h2 {
font-size: 1.45rem;
}

h3 {
font-size: 1.1rem;
}

@media (min-width: 768px) {
h1 {
font-size: 2.5rem;
}

h2 {
font-size: 1.85rem;
}
}

a {
color: var(--color-link);
text-decoration-thickness: 1px;
text-underline-offset: 3px;
}

a:hover {
color: var(--color-link-hover);
}

:focus-visible {
outline: 2px solid var(--color-sage-600);
outline-offset: 2px;
}

button:focus-visible,
.btn:focus-visible {
outline: 2px solid var(--color-sage-600);
outline-offset: 2px;
}

.container {
width: 100%;
max-width: var(--container-prose-max);
margin-left: auto;
margin-right: auto;
padding-left: 0;
padding-right: 0;
}

.container--wide {
max-width: var(--container-wide-max);
}

.container--shop {
max-width: min(var(--container-shop-max), 100%);
}

.section {
padding-top: var(--section-pad-y);
padding-bottom: var(--section-pad-y);
padding-left: max(var(--page-gutter-x), env(safe-area-inset-left, 0px));
padding-right: max(var(--page-gutter-x), env(safe-area-inset-right, 0px));
}

.section--surface {
background: var(--color-bg-surface);
}

.text-label {
font-family: var(--font-body);
font-size: 11px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.14em;
color: var(--color-sage-600);
}

.visually-hidden {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}

.site-header {
position: sticky;
top: 0;
z-index: 50;
background: rgba(255, 255, 255, 0.7);
-webkit-backdrop-filter: blur(10px);
backdrop-filter: blur(10px);
border-bottom: 1px solid var(--color-paper-200);
box-shadow: none;
}

.site-header__inner {
max-width: var(--container-wide-max);
width: 100%;
margin: 0 auto;
padding: 10px max(var(--page-gutter-x), env(safe-area-inset-left, 0px)) 10px
max(var(--page-gutter-x), env(safe-area-inset-right, 0px));
display: flex;
align-items: center;
justify-content: space-between;
gap: 16px;
}

.site-logo {
display: inline-flex;
align-items: center;
gap: 10px;
font-family: var(--font-display);
font-size: 18px;
font-weight: 700;
color: var(--color-header-text);
text-decoration: none;
white-space: nowrap;
letter-spacing: -0.02em;
}

.site-logo:hover {
color: var(--color-sage-600);
}

.site-logo__mark {
height: 36px;
width: auto;
flex-shrink: 0;
display: block;
border-radius: var(--radius-logo);
object-fit: contain;
}

.site-logo__mark--footer {
width: 40px;
height: 38px;
max-width: 40px;
max-height: 38px;
flex-shrink: 0;
}

.site-logo__text span {
color: var(--color-sage-600);
}

.site-nav {
display: none;
align-items: center;
gap: 24px;
}

@media (min-width: 768px) {
.site-nav {
display: flex;
}
}

.site-nav a {
font-size: 14px;
font-weight: 500;
color: var(--color-ink-700);
text-decoration: none;
}

.site-nav a:hover {
color: var(--color-sage-600);
text-decoration: underline;
text-underline-offset: 3px;
}

.btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
border: none;
cursor: pointer;
font-family: var(--font-body);
text-decoration: none;
transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.btn--primary {
background: var(--color-cta-yellow);
color: var(--color-ink-900);
border: 1px solid var(--color-cta-border);
border-radius: var(--radius-btn);
padding: 10px 22px;
font-size: 13px;
font-weight: 600;
box-shadow: none;
}

.btn--primary:hover {
background: var(--color-cta-yellow-hover);
color: var(--color-ink-900);
}

.btn--outline {
background: transparent;
color: var(--color-sage-600);
border: 1px solid var(--color-sage-200);
border-radius: var(--radius-btn);
padding: 10px 22px;
font-size: 13px;
font-weight: 600;
}

.btn--outline:hover {
background: var(--color-sage-50);
color: var(--color-sage-600);
border-color: var(--color-sage-500);
}

.btn--outline-muted {
color: var(--color-link);
border: 1px solid var(--color-paper-200);
border-radius: var(--radius-btn);
padding: 10px 22px;
font-size: 13px;
font-weight: 600;
background: rgba(255, 255, 255, 0.85);
}

.btn--outline-muted:hover {
background: var(--color-paper-50);
color: var(--color-link-hover);
border-color: var(--color-sage-200);
}

#product-freepage-cta {
background: #eaf7ff;
border-color: #b9e1ff;
color: #1b5f8a;
}

#product-freepage-cta:hover {
background: #dff2ff;
border-color: #95d2ff;
color: #144d72;
}

#product-review-cta {
background: #f3ecff;
border-color: #d8c4ff;
color: #5b3f94;
}

#product-review-cta:hover {
background: #ebe1ff;
border-color: #c6abff;
color: #4d3384;
}

#product-hardcover-cta {
background: #ffeede;
border-color: #ffd1a6;
color: #8a4e1e;
}

#product-hardcover-cta:hover {
background: #ffe3cc;
border-color: #ffbf85;
color: #744119;
}

.btn.is-disabled,
.btn[aria-disabled="true"] {
pointer-events: none;
opacity: 0.55;
cursor: not-allowed;
}

.btn--sm {
padding: 8px 16px;
font-size: 13px;
}

.btn--outline-muted.btn--sm {
padding: 8px 16px;
}

.header-actions {
display: flex;
align-items: center;
gap: 12px;
}

.header-actions .btn--primary {
display: none;
}

@media (min-width: 768px) {
.header-actions .btn--primary {
display: inline-flex;
}
}

.nav-toggle {
display: flex;
flex-direction: column;
justify-content: center;
gap: 5px;
width: 40px;
height: 40px;
padding: 8px;
background: transparent;
border: none;
cursor: pointer;
border-radius: var(--radius-btn);
}

@media (min-width: 768px) {
.nav-toggle {
display: none;
}
}

.nav-toggle span {
display: block;
height: 2px;
width: 100%;
background: var(--color-ink-700);
border-radius: 1px;
transition: transform 0.2s ease, opacity 0.2s ease;
}

.site-nav--mobile {
display: none;
flex-direction: column;
gap: 0;
padding: 0 max(var(--page-gutter-x), env(safe-area-inset-left, 0px)) 16px
max(var(--page-gutter-x), env(safe-area-inset-right, 0px));
max-width: var(--container-wide-max);
width: 100%;
margin: 0 auto;
border-bottom: 1px solid var(--color-paper-200);
background: rgba(255, 255, 255, 0.75);
-webkit-backdrop-filter: blur(8px);
backdrop-filter: blur(8px);
}

.site-nav--mobile.is-open {
display: flex;
}

.site-nav--mobile a {
padding: 12px 0;
font-size: 15px;
font-weight: 500;
color: var(--color-ink-700);
text-decoration: none;
border-top: 1px solid var(--color-paper-200);
}

.site-nav--mobile a:hover {
color: var(--color-sage-600);
}

.site-nav--mobile .btn--primary {
margin-top: 12px;
justify-content: center;
color: var(--color-ink-900);
}

@media (min-width: 768px) {
.site-nav--mobile {
display: none !important;
}
}

.site-footer {
background: var(--color-footer-bg);
color: var(--color-footer-text);
padding: 48px max(var(--page-gutter-x), env(safe-area-inset-right, 0px)) 32px
max(var(--page-gutter-x), env(safe-area-inset-left, 0px));
margin-top: auto;
border-top: 1px solid var(--color-paper-200);
}

.site-footer a {
color: var(--color-sage-600);
text-decoration: none;
}

.site-footer a:hover {
color: var(--color-link-hover);
text-decoration: underline;
text-underline-offset: 3px;
}

.site-footer__grid {
max-width: var(--container-wide-max);
width: 100%;
margin: 0 auto;
display: grid;
gap: 32px;
}

@media (min-width: 768px) {
.site-footer__grid {
grid-template-columns: 1.2fr repeat(4, 1fr);
gap: 24px;
}
}

.site-footer__brand .site-logo {
color: var(--color-ink-900);
margin-bottom: 8px;
display: inline-block;
}

.site-footer__brand .site-logo__text span {
color: var(--color-sage-600);
}

.site-footer__tagline {
font-size: 14px;
opacity: 0.9;
line-height: 1.6;
color: var(--color-ink-700);
}

.site-footer__socials {
display: flex;
align-items: center;
gap: 10px;
margin-top: 12px;
}

.social-link {
display: inline-flex;
align-items: center;
justify-content: center;
width: 34px;
height: 34px;
border-radius: 999px;
border: 1px solid var(--color-paper-200);
color: var(--color-sage-600);
background: rgba(255, 255, 255, 0.9);
text-decoration: none;
}

.social-link:hover {
background: var(--color-sage-50);
border-color: var(--color-sage-200);
color: var(--color-link-hover);
}

.site-footer__col h3 {
font-family: var(--font-body);
font-size: 11px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.14em;
margin-bottom: 12px;
color: var(--color-sage-600);
}

.site-footer__col ul {
list-style: none;
padding: 0;
}

.site-footer__col li {
margin-bottom: 8px;
}

.site-footer__col a {
font-size: 14px;
}

.site-footer__bottom {
max-width: var(--container-wide-max);
width: 100%;
margin: 40px auto 0;
padding-top: 24px;
border-top: 1px solid var(--color-paper-200);
font-size: 13px;
color: var(--color-text-muted);
}

.site-footer__bottom a {
font-size: 13px;
font-weight: 500;
}

.card-grid {
display: grid;
gap: 16px;
grid-template-columns: 1fr;
}

@media (min-width: 600px) {
.card-grid--2 {
grid-template-columns: repeat(2, 1fr);
}

.card-grid--3 {
grid-template-columns: repeat(2, 1fr);
}
}

@media (min-width: 900px) {
.card-grid--3 {
grid-template-columns: repeat(3, 1fr);
}
}

.card-grid--5 {
grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 520px) {
.card-grid--5 {
grid-template-columns: repeat(3, 1fr);
}
}

@media (min-width: 768px) {
.card-grid--5 {
grid-template-columns: repeat(4, 1fr);
}
}

@media (min-width: 1100px) {
.card-grid--5 {
grid-template-columns: repeat(5, 1fr);
}
}

.card-grid--catalog {
grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 1100px) {
.card-grid--catalog {
grid-template-columns: repeat(5, 1fr);
}
}

@media (min-width: 1100px) {
.card-grid--5 .product-card__title {
font-size: 13px;
}
}

.card-grid--4 {
grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 768px) {
.card-grid--4 {
grid-template-columns: repeat(4, 1fr);
}
}

.product-card {
border: 1px solid var(--color-paper-200);
border-radius: var(--radius-card);
background: rgba(255, 255, 255, 0.92);
overflow: hidden;
transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
box-shadow: var(--shadow-sm);
}

.product-card:hover {
box-shadow: var(--shadow-card-hover);
transform: translateY(-1px);
border-color: color-mix(in srgb, var(--color-sage-200) 70%, transparent);
}

@supports not (color: color-mix(in srgb, white, black)) {
.product-card:hover {
border-color: var(--color-sage-200);
}
}

.product-card__link {
text-decoration: none;
color: inherit;
display: block;
}

.product-card__media {
display: flex;
align-items: center;
justify-content: center;
background: var(--color-paper-100);
padding: 0;
min-height: 11rem;
overflow: hidden;
}

@media (min-width: 768px) {
.product-card__media {
min-height: 12.5rem;
}
}

.product-card__image {
aspect-ratio: 400 / 533;
width: 100%;
height: auto;
max-height: 15rem;
object-fit: contain;
object-position: center;
background: transparent;
border-radius: var(--radius-btn);
transition: transform 0.2s ease;
}

.product-card:hover .product-card__image {
transform: scale(1.04);
}

.product-card__badges {
display: inline-flex;
flex-wrap: wrap;
gap: 6px;
align-items: center;
}

.badge-book-number {
display: inline-block;
background: rgba(246, 153, 49, 0.14);
color: #8a4f1d;
font-size: 11px;
padding: 3px 10px;
border-radius: var(--radius-pill);
font-weight: 600;
}
@media (min-width: 768px) {
.product-card__image {
max-height: 17rem;
}
}

.product-rating {
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 4px 8px;
margin-bottom: 8px;
font-size: 12px;
line-height: 1.2;
color: var(--color-ink-700);
}

.product-rating--hero {
font-size: 13px;
margin-bottom: 12px;
}

.product-rating__stars-wrap {
position: relative;
display: inline-block;
font-size: 14px;
line-height: 1;
letter-spacing: 2px;
color: #dcd4c8;
}

.product-rating--hero .product-rating__stars-wrap {
font-size: 15px;
}

.product-rating__stars-fg {
position: absolute;
left: 0;
top: 0;
overflow: hidden;
white-space: nowrap;
color: #f69931;
pointer-events: none;
}

.product-rating__score {
font-weight: 600;
color: var(--color-ink-900);
}

.product-rating__count {
color: var(--color-text-muted);
font-weight: 400;
}

.product-card__body {
padding: 14px 16px 16px;
}

.product-card__title {
font-family: var(--font-body);
font-size: 15px;
font-weight: 600;
line-height: 1.35;
margin-bottom: 8px;
color: var(--color-ink-900);
}

.badge-age {
display: inline-block;
background: var(--color-sage-50);
color: var(--color-sage-600);
font-size: 11px;
padding: 3px 10px;
border-radius: var(--radius-pill);
font-weight: 500;
}

.collection-card {
border: 1px solid var(--color-paper-200);
border-radius: var(--radius-card);
background: rgba(255, 255, 255, 0.95);
overflow: hidden;
padding: 24px;
text-decoration: none;
color: inherit;
display: block;
transition: box-shadow 0.2s ease, border-color 0.2s ease;
box-shadow: var(--shadow-sm);
}

.collection-card:hover {
box-shadow: var(--shadow-card-hover);
border-color: var(--color-sage-200);
}

.collection-card--drawing {
border-top: 4px solid var(--color-sage-500);
}

.collection-card--activity {
border-top: 4px solid var(--color-activity);
}

.collection-card h2 {
margin-bottom: 12px;
}

.collection-card p {
font-size: 14px;
color: var(--color-text-muted);
margin-bottom: 8px;
}

.collection-card--coupon {
background: var(--color-amber-soft);
border: 1px dashed var(--color-amber-border);
}

.filter-pills {
display: flex;
flex-wrap: wrap;
gap: 8px;
margin-bottom: 24px;
}

.filter-pill {
border: 1px solid var(--color-paper-200);
background: rgba(255, 255, 255, 0.9);
color: var(--color-ink-700);
font-size: 13px;
font-weight: 500;
padding: 8px 14px;
border-radius: var(--radius-pill);
cursor: pointer;
font-family: var(--font-body);
}

.filter-pill:hover {
border-color: var(--color-sage-200);
background: var(--color-sage-50);
color: var(--color-sage-600);
}

.filter-pill.is-active {
background: var(--color-sage-600);
border-color: var(--color-sage-600);
color: #fff;
}

.filter-pill.is-active:hover {
background: #4a664d;
border-color: #4a664d;
color: #fff;
}

.theme-dot {
display: inline-block;
width: 8px;
height: 8px;
border-radius: 50%;
margin-right: 6px;
vertical-align: middle;
}

.theme-dot--vehicles {
background: var(--color-vehicles);
}

.theme-dot--animals {
background: var(--color-animals);
}

.theme-dot--nature {
background: var(--color-nature);
}

.theme-dot--flowers {
background: #e879a8;
}

.theme-dot--fantasy {
background: #a78bfa;
}

.theme-dot--transport {
background: #38bdf8;
}

.age-card {
border: 1px solid var(--color-paper-200);
border-radius: var(--radius-card);
padding: 24px;
background: rgba(255, 255, 255, 0.92);
text-decoration: none;
color: inherit;
display: block;
transition: transform 0.2s ease, box-shadow 0.2s ease;
box-shadow: var(--shadow-sm);
}

.age-card:hover {
transform: translateY(-1px);
box-shadow: var(--shadow-card-hover);
}

.age-card h3 {
margin-bottom: 8px;
}

.age-card p {
font-size: 14px;
color: var(--color-text-muted);
}

.breadcrumb {
font-size: 13px;
color: var(--color-text-muted);
margin-bottom: 24px;
}

.breadcrumb a {
color: var(--color-sage-600);
text-decoration: none;
}

.breadcrumb a:hover {
text-decoration: underline;
text-underline-offset: 3px;
color: var(--color-link-hover);
}

.breadcrumb span {
margin: 0 6px;
opacity: 0.5;
}

.badges-row {
display: flex;
flex-wrap: wrap;
gap: 8px;
margin-bottom: 16px;
}

.badge-collection {
font-size: 11px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.12em;
padding: 4px 10px;
border-radius: var(--radius-pill);
background: var(--color-sage-50);
color: var(--color-sage-600);
}

.badge-collection--activity {
background: rgba(196, 120, 90, 0.12);
color: #9a5a42;
}

#product-number {
margin: 0;
display: inline-flex;
align-items: center;
padding: 4px 10px;
border-radius: var(--radius-pill);
font-size: 11px;
font-weight: 600;
letter-spacing: 0.08em;
text-transform: uppercase;
background: rgba(246, 153, 49, 0.14);
color: #8a4f1d;
}

.callout-success {
background: var(--color-sage-50);
border: 1px solid var(--color-sage-200);
border-radius: var(--radius-card);
padding: 12px 16px;
color: var(--color-sage-600);
font-size: 14px;
}

.btn--whatsapp {
background: var(--color-whatsapp);
color: #fff;
border-radius: var(--radius-btn);
font-weight: 600;
}

.btn--whatsapp:hover {
filter: brightness(1.05);
color: #fff;
}

.page {
display: flex;
flex-direction: column;
min-height: 100vh;
}

.page-main {
flex: 1;
}

.hero {
padding-top: var(--section-pad-y);
padding-bottom: var(--section-pad-y);
padding-left: max(var(--page-gutter-x), env(safe-area-inset-left, 0px));
padding-right: max(var(--page-gutter-x), env(safe-area-inset-right, 0px));
background: linear-gradient(165deg, var(--color-paper-100) 0%, #fff 58%);
border-radius: 0 0 var(--radius-hero) var(--radius-hero);
}

.hero__inner {
max-width: var(--container-wide-max);
width: 100%;
margin: 0 auto;
}

@media (min-width: 768px) {
.hero__grid {
display: block;
}
}

.hero__preview h1 {
margin-bottom: 16px;
max-width: 16ch;
}

.hero__preview p {
font-size: 1.05rem;
color: var(--color-text-muted);
max-width: 28rem;
margin-bottom: 24px;
line-height: 1.65;
}

.hero__ctas {
display: flex;
flex-wrap: wrap;
gap: 12px;
margin-bottom: 32px;
}

@media (min-width: 768px) {
.hero__ctas {
margin-bottom: 0;
}
}

.hero__preview {
margin-top: 0;
}

@media (min-width: 768px) {
.hero__preview {
margin-top: 0;
}
}

.section-head {
max-width: var(--container-wide-max);
width: 100%;
margin: 0 auto var(--section-pad-x);
padding: 0;
}

.section-head h2 {
margin-bottom: 8px;
}

.section-head h1 {
margin-bottom: 8px;
}

.section-head p {
color: var(--color-text-muted);
font-size: 15px;
max-width: 50ch;
}

.section-head--wide p {
max-width: none;
}

.seo-block {
max-width: var(--container-prose-max);
width: 100%;
margin: 0 auto;
}

.seo-block--wide {
max-width: var(--container-wide-max);
}

.home-catalog-more {
margin-top: 18px;
display: flex;
justify-content: center;
}

.seo-block h2 {
margin: 22px 0 12px;
}

.seo-block h2:first-child {
margin-top: 0;
}

.seo-block h2 + p,
.seo-block h2 + ul,
.seo-block h2 + .faq-list,
.seo-block h2 + #product-faq,
.seo-block h2 + div {
margin-top: 0;
}

#product-faq {
margin: 18px 0 22px;
}

.seo-block p {
margin-bottom: 16px;
color: var(--color-text-muted);
font-size: 15px;
}

.seo-block ul {
margin: 0 0 16px;
padding-left: 20px;
color: var(--color-text-muted);
font-size: 15px;
}

.seo-block li {
margin: 0 0 8px;
line-height: 1.65;
}

.seo-block li:last-child {
margin-bottom: 0;
}

.seo-block details {
border: 1px solid var(--color-paper-200);
background: rgba(255, 255, 255, 0.8);
border-radius: 12px;
padding: 10px 12px;
margin: 0 0 10px;
}

.seo-block details:last-child {
margin-bottom: 0;
}

.seo-block summary {
cursor: pointer;
font-weight: 600;
color: var(--color-ink-900);
}

.seo-block details p {
margin-top: 10px;
}

.seo-block p:last-child {
margin-bottom: 0;
}

.shop-toolbar {
display: flex;
flex-wrap: wrap;
gap: 12px;
align-items: center;
justify-content: space-between;
margin-bottom: 24px;
max-width: min(var(--container-shop-max), 100%);
width: 100%;
margin-left: auto;
margin-right: auto;
padding: 0;
}

.shop-toolbar p {
font-size: 14px;
color: var(--color-text-muted);
}

.shop-toolbar select,
.shop-toolbar__select {
padding: 8px 14px;
border-radius: var(--radius-input);
border: 1px solid var(--color-paper-200);
font-family: var(--font-body);
font-size: 14px;
color: var(--color-ink-900);
background: rgba(255, 255, 255, 0.95);
min-width: 10rem;
}

.shop-toolbar select:focus-visible,
.shop-toolbar__select:focus-visible {
outline: 2px solid var(--color-sage-600);
outline-offset: 2px;
border-color: var(--color-sage-600);
}

.product-hero {
padding-top: var(--section-pad-y);
padding-bottom: var(--section-pad-y);
padding-left: max(var(--page-gutter-x), env(safe-area-inset-left, 0px));
padding-right: max(var(--page-gutter-x), env(safe-area-inset-right, 0px));
}

.product-hero__inner {
max-width: var(--container-wide-max);
width: 100%;
margin: 0 auto;
}

@media (min-width: 768px) {
.product-hero__grid {
display: grid;
grid-template-columns: minmax(220px, 340px) 1fr;
gap: 40px;
align-items: start;
}
}

.product-hero__cover {
display: flex;
align-items: center;
justify-content: center;
border-radius: var(--radius-hero);
overflow: hidden;
border: 1px solid var(--color-paper-200);
background: var(--color-paper-100);
margin-bottom: 24px;
box-shadow: none;
min-height: 420px;
}

@media (min-width: 768px) {
.product-hero__cover {
margin-bottom: 0;
}
}

.product-hero__cover img {
width: auto;
max-width: 100%;
max-height: 540px;
height: auto;
object-fit: contain;
object-position: center;
background: var(--color-paper-50);
}

.product-hero__details h1 {
margin-bottom: 12px;
font-size: 28px;
}

#product-subtitle {
font-size: 1.1rem;
margin-bottom: 10px;
color: var(--color-ink-700);
}

@media (min-width: 768px) {
.product-hero__details h1 {
font-size: 36px;
}
}

.product-hero__details .lead {
font-size: 16px;
color: var(--color-text-muted);
margin-bottom: 20px;
line-height: 1.65;
}

.product-ctas {
display: flex;
flex-wrap: wrap;
gap: 10px;
}

#product-related-grid {
grid-template-columns: repeat(3, 1fr);
}

@media (min-width: 1100px) {
#product-related-grid {
grid-template-columns: repeat(5, 1fr);
}
}

.spec-list {
list-style: none;
padding: 0;
margin: 0 0 24px;
font-size: 14px;
color: var(--color-text-muted);
}

.spec-list li {
padding: 6px 0;
border-bottom: 0.5px solid var(--color-border);
}

.spec-list strong {
color: var(--color-text);
font-weight: 600;
margin-right: 8px;
}

.preview-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 12px;
max-width: var(--container-wide-max);
width: 100%;
margin: 0 auto;
padding: 0;
}

.preview-grid__cell {
aspect-ratio: 1;
background: repeating-linear-gradient(
-45deg,
var(--color-paper-100),
var(--color-paper-100) 8px,
var(--color-paper-200) 8px,
var(--color-paper-200) 16px
);
border-radius: var(--radius-btn);
border: 1px dashed var(--color-paper-200);
}

.error-page {
text-align: center;
padding-top: 64px;
padding-bottom: 64px;
padding-left: max(var(--page-gutter-x), env(safe-area-inset-left, 0px));
padding-right: max(var(--page-gutter-x), env(safe-area-inset-right, 0px));
}

.error-page h1 {
font-size: 72px;
color: var(--color-sage-600);
line-height: 1;
margin-bottom: 16px;
}

.error-page p {
color: var(--color-text-muted);
margin-bottom: 24px;
}

.collection-hero {
padding: 0;
max-width: var(--container-prose-max);
width: 100%;
margin-left: auto;
margin-right: auto;
margin-bottom: var(--section-pad-x);
}

.collection-hero h1 {
margin-bottom: 12px;
}

.collection-hero .lead {
font-size: 17px;
color: var(--color-text-muted);
}

.prose {
max-width: var(--container-prose-max);
width: 100%;
margin: 0 auto;
padding: 0;
}

.prose h2 {
margin-top: 32px;
margin-bottom: 12px;
}

.prose p {
margin-bottom: 16px;
color: var(--color-text-muted);
font-size: 15px;
}

.prose ul {
margin: 0 0 16px 1.2rem;
color: var(--color-text-muted);
font-size: 15px;
}

.age-grid {
display: grid;
gap: 16px;
max-width: var(--container-wide-max);
width: 100%;
margin: 0 auto;
padding: 0;
}

@media (min-width: 768px) {
.age-grid {
grid-template-columns: repeat(3, 1fr);
}
}

#ages-3-8,
#ages-4-12,
#ages-5-10 {
scroll-margin-top: 88px;
}

.collections-index-grid {
display: grid;
gap: 24px;
max-width: var(--container-wide-max);
width: 100%;
margin: 0 auto;
}

@media (min-width: 768px) {
.collections-index-grid {
grid-template-columns: repeat(2, 1fr);
}
}

.free-pages-list {
display: grid;
gap: 8px;
grid-template-columns: 1fr;
}

@media (min-width: 640px) {
.free-pages-list {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}

@media (min-width: 1024px) {
.free-pages-list {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
}

.free-page-card {
border: 1px solid var(--color-paper-200);
border-radius: var(--radius-card);
background: rgba(255, 255, 255, 0.95);
padding: 6px 8px;
display: flex;
flex-direction: row;
align-items: stretch;
gap: 8px;
min-height: 5.25rem;
}

.free-page-card__media {
flex: 0 0 92px;
width: 92px;
border: none;
border-radius: 6px;
background: transparent;
display: flex;
align-items: center;
justify-content: center;
overflow: hidden;
}

@media (min-width: 640px) {
.free-page-card__media {
flex-basis: 108px;
width: 108px;
}
}

@media (min-width: 1024px) {
.free-page-card__media {
flex-basis: 120px;
width: 120px;
}
}

.free-page-card__cover {
width: 100%;
height: auto;
max-height: 6.5rem;
object-fit: contain;
vertical-align: middle;
}

@media (min-width: 640px) {
.free-page-card__cover {
max-height: 7.25rem;
}
}

.free-page-card__body {
flex: 1;
min-width: 0;
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 4px;
}

.free-page-card__meta {
display: flex;
flex-wrap: wrap;
gap: 4px;
align-items: center;
}

.free-page-badge {
display: inline-flex;
align-items: center;
padding: 2px 7px;
border-radius: 999px;
font-size: 9px;
font-weight: 600;
letter-spacing: 0.06em;
text-transform: uppercase;
}

.free-page-badge--series {
background: #e9f6ee;
color: #356a48;
}

.free-page-badge--id {
background: #fff0db;
color: #81511f;
}

.free-page-card__title {
margin: 0;
font-size: 0.875rem;
font-weight: 600;
line-height: 1.25;
color: var(--color-ink-900);
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
overflow: hidden;
}

.free-page-card__blurb {
margin: 0;
font-size: 12px;
line-height: 1.35;
color: var(--color-text-muted);
}

.free-page-card__actions {
margin-top: auto;
width: 100%;
}

.free-page-card__actions .btn {
width: 100%;
justify-content: center;
}

.unlock-modal {
position: fixed;
inset: 0;
background: rgba(16, 20, 24, 0.48);
display: flex;
align-items: center;
justify-content: center;
padding: 16px;
z-index: 120;
}

.unlock-modal[hidden] {
display: none;
}

.unlock-modal__card {
position: relative;
width: min(560px, 100%);
border-radius: var(--radius-card);
background: #fff;
border: 1px solid var(--color-paper-200);
padding: 14px;
}

.unlock-modal__card h2 {
margin-bottom: 6px;
}

.unlock-modal__actions {
display: flex;
flex-wrap: wrap;
gap: 8px;
margin-top: 10px;
}

.unlock-modal__share-row {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 10px;
margin-top: 10px;
}

.unlock-modal__card p {
margin: 6px 0 0;
}

.unlock-modal__close {
position: absolute;
top: 10px;
right: 10px;
width: 32px;
height: 32px;
border: none;
border-radius: 999px;
background: #f3f4f6;
color: #374151;
font-size: 22px;
line-height: 1;
cursor: pointer;
}

.share-icon-btn {
width: 100%;
min-height: 64px;
border: 1px solid var(--color-paper-200);
border-radius: 14px;
background: rgba(255, 255, 255, 0.95);
color: #111827;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
cursor: pointer;
gap: 6px;
padding: 8px 10px;
}

.share-icon-btn:hover {
background: #f8fafc;
border-color: #cbd5e1;
}

.share-icon-btn__img {
display: block;
}

.share-icon-btn__label {
font-size: 12px;
font-weight: 600;
color: #374151;
line-height: 1.1;
}
