/*
Theme Name: TestudoTracker
Author: Eduardo Bermejo
Description: Tema oficial de TestudoTracker — App para tortugas de tierra. Fiel al diseño de la aplicación React.
Version: 4.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: testudo
Tags: blog, one-column, custom-logo, custom-menu, featured-images, translation-ready
*/

/* ═══════════════════════════════════════════════════════
   DESIGN TOKENS — Material Design 3 (from React app)
   ═══════════════════════════════════════════════════════ */
:root {
  /* Primary */
  --primary: #256a13;
  --primary-container: #3f832b;
  --on-primary: #ffffff;
  --primary-fixed: #aaf68e;
  --on-primary-fixed: #032100;
  --primary-fixed-dim: #8fd975;

  /* Secondary */
  --secondary: #2e48e0;
  --secondary-container: #4c64fa;
  --on-secondary: #ffffff;
  --secondary-fixed: #dee0ff;
  --on-secondary-fixed: #000e5e;

  /* Tertiary */
  --tertiary: #006b20;
  --tertiary-container: #288535;
  --on-tertiary: #ffffff;
  --on-tertiary-container: #f7fff1;
  --tertiary-fixed: #99f899;
  --on-tertiary-fixed: #002105;

  /* Surfaces */
  --background: #fbf9f8;
  --on-background: #1b1c1c;
  --surface: #fbf9f8;
  --on-surface: #1b1c1c;
  --on-surface-variant: #41493c;
  --surface-container-lowest: #ffffff;
  --surface-container-low: #f5f3f3;
  --surface-container: #f0eded;
  --surface-container-high: #eae8e7;
  --surface-container-highest: #e4e2e2;

  /* Outline */
  --outline: #717a6a;
  --outline-variant: #c0c9b8;

  /* Error */
  --error: #ba1a1a;
  --error-container: #ffdad6;
  --on-error: #ffffff;
  --on-error-container: #93000a;

  /* Typography */
  --font-sans: "Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;
  --font-headline: "Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;

  /* Radius */
  --r-sm: 0.75rem;
  --r-md: 1rem;
  --r-lg: 1.5rem;
  --r-xl: 2rem;
  --r-2xl: 2.5rem;
  --r-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(27,28,28,0.04);
  --shadow-md: 0 8px 30px rgba(27,28,28,0.04);
  --shadow-lg: 0 12px 32px rgba(27,28,28,0.06);
  --shadow-xl: 0 20px 40px rgba(27,28,28,0.1);
}

/* ═══════════════════════════════════════════════════════
   RESET & BASE
   ═══════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: 5rem;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  background: var(--background);
  color: var(--on-background);
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--primary); text-decoration: none; transition: color 0.2s; }
a:hover { color: var(--primary-container); }
a:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; border-radius: 4px; }
button, input, select, textarea { font: inherit; color: inherit; }
button { cursor: pointer; border: 0; background: transparent; }
::selection { background: rgba(37,106,19,0.2); color: var(--primary); }

/* Accessibility */
.sr-only { position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0; }
.skip-link:focus { position:fixed;top:1rem;left:1rem;z-index:9999;padding:0.5rem 1rem;background:var(--primary);color:var(--on-primary);font-weight:700;border-radius:var(--r-sm);clip:auto;width:auto;height:auto; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:0.01ms!important; transition-duration:0.01ms!important; scroll-behavior:auto!important; }
}

/* ═══════════════════════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════════════════════ */
.site { display:flex; flex-direction:column; min-height:100vh; }
.site-main { flex:1; }
.max-container { max-width:1400px; margin:0 auto; padding-left:1.5rem; padding-right:1.5rem; }
@media (min-width:768px) { .max-container { padding-left:3rem; padding-right:3rem; } }

/* ═══════════════════════════════════════════════════════
   NAVBAR — sticky glass effect
   ═══════════════════════════════════════════════════════ */
.site-navbar {
  position: sticky; top:0; z-index:50;
  background: rgba(251,249,248,0.8);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--shadow-md);
  transition: background 0.2s;
}
.navbar-inner {
  display:flex; justify-content:space-between; align-items:center;
  height:5rem; max-width:1400px; margin:0 auto;
  padding:0 1.5rem;
}
@media (min-width:768px) { .navbar-inner { padding:0 3rem; } }

.navbar-brand { display:flex; align-items:center; gap:0.75rem; }
.navbar-brand img { height:2.5rem; width:auto; object-fit:contain; }
.navbar-brand-text {
  font-size:1.5rem; font-weight:700; letter-spacing:-0.05em;
  color:var(--primary); font-family:var(--font-headline);
}
@media (max-width:639px) { .navbar-brand-text { display:none; } }

/* Desktop nav */
.navbar-links { display:none; align-items:center; gap:2rem; }
@media (min-width:768px) { .navbar-links { display:flex; } }
.navbar-links a {
  font-weight:600; color:var(--on-surface-variant); transition:color 0.2s;
}
.navbar-links a:hover, .navbar-links a.active {
  color:var(--primary);
}
.navbar-links a.active { border-bottom:2px solid var(--primary); padding-bottom:0.25rem; }

/* Nav CTA */
.nav-cta {
  display:inline-flex; align-items:center; gap:0.5rem;
  background:var(--primary); color:var(--on-primary);
  padding:0.625rem 1.5rem; border-radius:var(--r-full);
  font-weight:700; font-size:0.875rem;
  box-shadow:0 4px 12px rgba(37,106,19,0.3);
  transition:all 0.2s;
}
.nav-cta:hover { background:var(--primary-container); color:var(--on-primary); transform:translateY(-1px); }
.nav-cta:active { transform:scale(0.95); }
.nav-cta svg { width:20px; height:20px; }

/* Mobile actions */
.navbar-mobile-actions { display:flex; align-items:center; gap:0.5rem; }
@media (min-width:768px) { .navbar-mobile-actions { display:none; } }
.nav-cta-mobile {
  display:flex; align-items:center; gap:0.5rem;
  background:var(--primary); color:var(--on-primary);
  padding:0.5rem 1rem; border-radius:var(--r-full);
  font-weight:700; font-size:0.875rem;
  box-shadow:0 4px 12px rgba(37,106,19,0.3);
}
.nav-cta-mobile svg { width:18px; height:18px; }

.menu-toggle {
  display:flex; align-items:center; justify-content:center;
  width:44px; height:44px; color:var(--on-surface-variant);
}
@media (min-width:768px) { .menu-toggle { display:none; } }

/* Mobile menu */
.mobile-menu {
  display:none; position:absolute; top:5rem; left:0; width:100%;
  background:var(--surface); border-top:1px solid rgba(192,201,184,0.2);
  padding:1rem 1.5rem; box-shadow:var(--shadow-xl); z-index:40;
}
.mobile-menu.is-open { display:flex; flex-direction:column; gap:1rem; }
.mobile-menu a {
  font-weight:600; padding:0.5rem 0; color:var(--on-surface-variant);
}
.mobile-menu a.active { color:var(--primary); }
.mobile-menu .nav-cta {
  margin-top:1rem; width:100%; justify-content:center; padding:0.75rem;
}

/* Desktop nav CTA container */
.navbar-desktop-cta { display:none; align-items:center; gap:1rem; }
@media (min-width:768px) { .navbar-desktop-cta { display:flex; } }

/* ═══════════════════════════════════════════════════════
   HERO SECTION (Home)
   ═══════════════════════════════════════════════════════ */
.hero-section {
  position:relative; overflow:hidden;
  padding:3rem 0 6rem;
}
@media (min-width:768px) { .hero-section { padding:5rem 0 8rem; } }

.hero-blob {
  position:absolute; top:0; right:0; z-index:-1;
  width:66%; height:100%; opacity:0.1; pointer-events:none;
}
.hero-blob-1, .hero-blob-2 {
  position:absolute; border-radius:60% 40% 30% 70% / 60% 30% 70% 40%;
  filter:blur(60px);
}
.hero-blob-1 { background:var(--primary); width:600px; height:600px; top:-5rem; right:-5rem; }
.hero-blob-2 { background:var(--primary-container); width:400px; height:400px; top:10rem; right:10rem; }

.hero-grid {
  display:grid; grid-template-columns:1fr; gap:4rem; align-items:center;
  max-width:1400px; margin:0 auto; padding:0 1.5rem;
}
@media (min-width:768px) { .hero-grid { padding:0 3rem; } }
@media (min-width:1024px) { .hero-grid { grid-template-columns:1fr 1fr; } }

.hero-badge {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding:0.25rem 0.75rem; border-radius:var(--r-full);
  background:var(--primary-fixed); color:var(--on-primary-fixed);
  font-weight:700; font-size:0.75rem;
  text-transform:uppercase; letter-spacing:0.1em;
  margin-bottom:1.5rem;
}
.hero-badge-dot {
  position:relative; width:0.5rem; height:0.5rem;
}
.hero-badge-dot::before {
  content:''; position:absolute; inset:0;
  border-radius:50%; background:#22c55e;
  animation:ping 1.5s cubic-bezier(0,0,0.2,1) infinite;
}
.hero-badge-dot::after {
  content:''; position:absolute; inset:0;
  border-radius:50%; background:#22c55e;
}
@keyframes ping { 75%,100% { transform:scale(2); opacity:0; } }

.hero-title {
  font-size:clamp(2.5rem,7vw,4.5rem); font-weight:800;
  font-family:var(--font-headline); line-height:1.1;
  color:var(--on-surface); letter-spacing:-0.03em;
  margin:0 0 1.5rem;
}

.hero-subtitle {
  font-size:clamp(1rem,2.5vw,1.25rem); color:var(--on-surface-variant);
  max-width:32rem; line-height:1.7; margin:0 0 2.5rem;
}

.hero-actions { display:flex; flex-direction:column; gap:1.5rem; align-items:flex-start; }
@media (min-width:640px) { .hero-actions { flex-direction:row; align-items:center; } }

.hero-playstore { height:4rem; cursor:pointer; transition:transform 0.3s; filter:drop-shadow(0 4px 12px rgba(0,0,0,0.15)); }
.hero-playstore:hover { transform:scale(1.05); }

.hero-rating {
  display:flex; align-items:center; gap:0.75rem;
  padding:0.75rem 1.25rem; border-radius:var(--r-lg);
  background:var(--surface-container-lowest);
  box-shadow:var(--shadow-sm); border:1px solid rgba(192,201,184,0.3);
}
.hero-rating-avatars { display:flex; }
.hero-rating-avatars img {
  width:2rem; height:2rem; border-radius:50%; border:2px solid white;
  margin-left:-0.5rem; object-fit:cover; background:var(--surface-container-high);
}
.hero-rating-avatars img:first-child { margin-left:0; }
.hero-rating-stars { color:#eab308; display:flex; gap:1px; margin-bottom:2px; }
.hero-rating-text { font-weight:700; font-size:0.75rem; color:var(--on-surface); }

/* Hero video */
.hero-video-col { display:none; }
@media (min-width:1024px) { .hero-video-col { display:block; } }
.hero-video-mobile { display:block; margin-bottom:2.5rem; }
@media (min-width:1024px) { .hero-video-mobile { display:none; } }

.hero-video-wrap {
  position:relative; width:100%; max-width:44rem;
  border-radius:var(--r-xl);
  overflow:hidden; box-shadow:var(--shadow-xl);
  border:8px solid white; background:var(--surface-container-high);
  margin:0 auto;
}
.hero-video-wrap video { width:100%; display:block; object-fit:cover; }
.hero-video-glow {
  position:absolute; inset:0; background:rgba(37,106,19,0.1);
  border-radius:50%; filter:blur(60px); transform:scale(0.75);
  animation:pulse-glow 3s ease-in-out infinite; z-index:-1;
}
@keyframes pulse-glow { 0%,100% { opacity:0.5; } 50% { opacity:1; } }

/* ═══════════════════════════════════════════════════════
   SECTION: Advantages Bento
   ═══════════════════════════════════════════════════════ */
.advantages-section {
  padding:6rem 0; background:var(--surface-container-low);
  border-top:1px solid rgba(192,201,184,0.1);
  border-bottom:1px solid rgba(192,201,184,0.1);
}
.section-eyebrow {
  display:block; text-align:center; color:var(--primary);
  font-weight:700; text-transform:uppercase; letter-spacing:0.15em;
  font-size:0.875rem; margin-bottom:1rem;
}
.section-heading {
  text-align:center; font-size:clamp(1.75rem,4vw,3rem);
  font-weight:700; font-family:var(--font-headline); margin:0 0 1rem;
}
.section-subheading {
  text-align:center; color:var(--on-surface-variant);
  max-width:40rem; margin:0 auto 3rem; font-size:1.05rem;
}

.bento-grid {
  display:grid; grid-template-columns:1fr; gap:2rem;
}
@media (min-width:640px) { .bento-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px) { .bento-grid { grid-template-columns:repeat(4,1fr); } }

.bento-card {
  background:var(--surface-container-lowest); padding:2rem;
  border-radius:var(--r-xl); border:1px solid rgba(192,201,184,0.2);
  box-shadow:var(--shadow-sm); transition:box-shadow 0.3s;
}
.bento-card:hover { box-shadow:var(--shadow-lg); }
.bento-card svg { color:var(--primary); margin-bottom:1rem; width:36px; height:36px; }
.bento-card h3 { font-size:1.25rem; font-weight:700; font-family:var(--font-headline); margin:0 0 0.75rem; }
.bento-card p { font-size:0.875rem; color:var(--on-surface-variant); line-height:1.7; margin:0; }

/* ═══════════════════════════════════════════════════════
   SECTION: How It Works (green bg)
   ═══════════════════════════════════════════════════════ */
.how-section {
  padding:5rem 0; background:var(--primary); color:var(--on-primary);
  position:relative; overflow:hidden;
}
.how-grid {
  display:grid; grid-template-columns:1fr; gap:2rem;
}
@media (min-width:768px) { .how-grid { grid-template-columns:repeat(3,1fr); } }
.how-step {
  background:rgba(255,255,255,0.1); border-radius:var(--r-xl);
  padding:2rem; text-align:center; backdrop-filter:blur(8px);
}
.how-step-num {
  width:3rem; height:3rem; border-radius:50%;
  background:var(--primary-fixed); color:var(--on-primary-fixed);
  font-weight:800; font-size:1.25rem;
  display:inline-flex; align-items:center; justify-content:center;
  margin-bottom:1rem;
}
.how-step h3 { font-size:1.15rem; font-weight:700; margin:0 0 0.5rem; }
.how-step p { font-size:0.875rem; opacity:0.85; line-height:1.6; margin:0; }

/* ═══════════════════════════════════════════════════════
   SECTION: Species Carousel (Home)
   ═══════════════════════════════════════════════════════ */
.species-carousel-section { padding:6rem 0; }
.species-carousel {
  display:flex; overflow-x:auto; gap:2rem;
  padding-bottom:3rem; scroll-snap-type:x mandatory;
  scrollbar-width:none; -ms-overflow-style:none;
}
.species-carousel::-webkit-scrollbar { display:none; }

.species-card-link {
  flex:none; width:20rem; scroll-snap-align:start;
  text-decoration:none; color:inherit;
}
@media (min-width:768px) { .species-card-link { width:25rem; } }

.species-card {
  background:var(--surface-container-lowest); border-radius:var(--r-2xl);
  padding:1rem; border:1px solid rgba(192,201,184,0.2);
  box-shadow:var(--shadow-sm); transition:all 0.5s;
  display:flex; flex-direction:column; height:100%;
}
.species-card:hover { box-shadow:var(--shadow-xl); }

.species-card-img {
  aspect-ratio:1/1; border-radius:60% 40% 30% 70% / 60% 30% 70% 40%;
  overflow:hidden; margin-bottom:1.5rem;
}
.species-card-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform 0.7s;
}
.species-card:hover .species-card-img img { transform:scale(1.1); }

.species-card-body { padding:0 1rem 1rem; flex:1; display:flex; flex-direction:column; }
.species-card-body h3 {
  font-size:1.5rem; font-weight:700; color:var(--primary);
  font-family:var(--font-headline); margin:0 0 0.5rem;
}
.species-card-body p {
  font-size:0.875rem; color:var(--on-surface-variant); line-height:1.6;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
  margin:0;
}
.species-card-tag {
  margin-top:auto; padding-top:1.5rem;
  display:flex; align-items:center; gap:0.5rem;
  color:var(--primary); font-size:0.75rem; font-weight:700;
  text-transform:uppercase; letter-spacing:0.08em;
}
.species-card-tag svg { width:16px; height:16px; }

/* ═══════════════════════════════════════════════════════
   SECTION: Products (Amazon)
   ═══════════════════════════════════════════════════════ */
.products-section { padding:6rem 0; }
.products-grid {
  display:grid; grid-template-columns:1fr; gap:2rem;
}
@media (min-width:640px) { .products-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px) { .products-grid { grid-template-columns:repeat(3,1fr); } }

.product-card {
  background:var(--surface-container-lowest); border-radius:var(--r-xl);
  overflow:hidden; border:1px solid rgba(192,201,184,0.2);
  box-shadow:var(--shadow-sm); transition:all 0.3s;
  display:flex; flex-direction:column;
}
.product-card:hover { box-shadow:var(--shadow-xl); }
.product-card-img { height:12rem; overflow:hidden; background:var(--surface-container); }
.product-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s; }
.product-card:hover .product-card-img img { transform:scale(1.05); }
.product-card-body { padding:1.5rem; flex:1; display:flex; flex-direction:column; }
.product-card-body h3 { font-size:1.25rem; font-weight:700; font-family:var(--font-headline); margin:0 0 0.5rem; }
.product-card-body p { font-size:0.875rem; color:var(--on-surface-variant); flex:1; margin:0 0 1rem; }
.product-card-footer {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:1rem; border-top:1px solid rgba(192,201,184,0.1); margin-top:auto;
}
.product-price { font-weight:700; font-size:1.15rem; }
.product-buy {
  display:inline-flex; align-items:center; gap:0.5rem;
  background:#FF9900; color:#000; padding:0.5rem 1rem;
  border-radius:var(--r-full); font-weight:700; font-size:0.875rem;
  transition:background 0.2s;
}
.product-buy:hover { background:#e68a00; color:#000; }
.product-buy svg { width:16px; height:16px; }

/* ═══════════════════════════════════════════════════════
   SECTION: Stats
   ═══════════════════════════════════════════════════════ */
.stats-section {
  padding:5rem 0; background:var(--surface-container-highest);
  border-top:1px solid rgba(192,201,184,0.1);
  border-bottom:1px solid rgba(192,201,184,0.1);
}
.stats-grid {
  display:grid; grid-template-columns:1fr; gap:3rem; text-align:center;
}
@media (min-width:768px) { .stats-grid { grid-template-columns:repeat(3,1fr); } }
.stats-number {
  font-size:3.75rem; font-weight:900; color:var(--primary);
  letter-spacing:-0.05em; margin-bottom:0.75rem; line-height:1;
}
.stats-label {
  color:var(--on-surface-variant); font-weight:500; font-size:1.1rem;
  text-transform:uppercase; letter-spacing:0.1em;
}

/* ═══════════════════════════════════════════════════════
   SECTION: FAQ
   ═══════════════════════════════════════════════════════ */
.faq-section { padding:6rem 0; }
.faq-list { max-width:48rem; margin:0 auto; display:flex; flex-direction:column; gap:1.5rem; }
.faq-item {
  background:var(--surface-container-lowest); border-radius:var(--r-lg);
  border:1px solid rgba(192,201,184,0.2); overflow:hidden;
}
.faq-item summary {
  display:flex; justify-content:space-between; align-items:center;
  padding:1.5rem; cursor:pointer; font-weight:700; font-size:1.1rem;
  list-style:none; user-select:none;
}
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary svg { transition:transform 0.3s; color:var(--on-surface-variant); flex-shrink:0; margin-left:1rem; }
.faq-item[open] summary svg { transform:rotate(180deg); }
.faq-item .faq-answer { padding:0 1.5rem 1.5rem; color:var(--on-surface-variant); line-height:1.7; }

/* ═══════════════════════════════════════════════════════
   SPECIES LIST PAGE
   ═══════════════════════════════════════════════════════ */
.species-list-page { max-width:72rem; margin:0 auto; padding:1rem 1.5rem 3rem; }
.species-list-header { text-align:center; margin-bottom:2rem; }
.species-list-header h1 {
  font-size:clamp(2.5rem,5vw,3.75rem); font-weight:800;
  letter-spacing:-0.05em; font-family:var(--font-headline); margin:0 0 1rem;
}
.species-list-header h1 .text-primary { color:var(--primary); }
.species-list-header p {
  font-size:1.25rem; color:var(--on-surface-variant); max-width:40rem; margin:0 auto;
}
.species-list-grid {
  display:grid; grid-template-columns:1fr; gap:2rem;
}
@media (min-width:640px) { .species-list-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px) { .species-list-grid { grid-template-columns:repeat(3,1fr); } }

.species-list-card {
  background:var(--surface-container-low); border-radius:var(--r-2xl);
  padding:1rem; border:1px solid rgba(192,201,184,0.2);
  box-shadow:var(--shadow-sm); transition:all 0.3s; display:flex; flex-direction:column;
}
.species-list-card:hover { box-shadow:var(--shadow-xl); }
.species-list-card-img {
  aspect-ratio:4/3; border-radius:var(--r-xl); overflow:hidden; position:relative; margin-bottom:1.5rem;
}
.species-list-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s; }
.species-list-card:hover .species-list-card-img img { transform:scale(1.05); }
.species-list-card-tag {
  position:absolute; top:1rem; left:1rem;
  background:rgba(255,255,255,0.9); backdrop-filter:blur(4px);
  padding:0.25rem 0.75rem; border-radius:var(--r-full);
  font-size:0.75rem; font-weight:700; color:var(--primary);
  text-transform:uppercase; letter-spacing:0.05em;
}
.species-list-card-body { padding:0 0.5rem; flex:1; display:flex; flex-direction:column; }
.species-list-card-body h3 { font-size:1.5rem; font-weight:700; font-family:var(--font-headline); margin:0 0 0.25rem; }
.species-list-card-body .sci-name { color:var(--primary); font-weight:500; font-style:italic; margin-bottom:1rem; }
.species-list-card-body p { font-size:0.875rem; color:var(--on-surface-variant); line-height:1.7; flex:1; margin:0 0 1.5rem; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.species-list-card-cta { display:flex; align-items:center; color:var(--primary); font-weight:700; font-size:0.875rem; transition:transform 0.2s; }
.species-list-card:hover .species-list-card-cta { transform:translateX(0.5rem); }
.species-list-card-cta svg { width:16px; height:16px; margin-left:0.5rem; }

/* ═══════════════════════════════════════════════════════
   SPECIES DETAIL PAGE
   ═══════════════════════════════════════════════════════ */
.species-detail { max-width:72rem; margin:0 auto; padding:1rem 1.5rem 3rem; }
@media (min-width:768px) { .species-detail { padding:1rem 3rem 3rem; } }

.species-detail-back {
  display:inline-flex; align-items:center; gap:0.5rem;
  color:var(--on-surface-variant); font-weight:500;
  margin-bottom:2rem; transition:color 0.2s;
}
.species-detail-back:hover { color:var(--primary); }
.species-detail-back svg { width:20px; height:20px; }

/* Hero */
.species-detail-hero {
  display:grid; grid-template-columns:1fr; gap:3rem; margin-bottom:4rem;
}
@media (min-width:1024px) { .species-detail-hero { grid-template-columns:1fr 1fr; } }
.species-detail-hero-img {
  aspect-ratio:4/3; border-radius:var(--r-2xl); overflow:hidden;
  background:var(--surface-container-low);
}
.species-detail-hero-img img { width:100%; height:100%; object-fit:cover; }
.species-detail-hero-info { display:flex; flex-direction:column; justify-content:center; }
.species-detail-badges { display:flex; flex-wrap:wrap; gap:0.5rem; margin-bottom:1rem; }
.badge-pill {
  font-size:0.75rem; font-weight:700; padding:0.25rem 0.75rem;
  border-radius:var(--r-full); display:inline-flex; align-items:center; gap:0.375rem;
}
.badge-primary { background:var(--primary); color:var(--on-primary); }
.badge-secondary { background:var(--secondary-fixed); color:var(--on-secondary-fixed); }
.badge-tertiary { background:var(--tertiary-fixed); color:var(--on-tertiary-fixed); }
.badge-outline { background:transparent; border:1px solid var(--outline-variant); color:var(--on-surface-variant); }

.species-detail-hero-info h1 {
  font-size:clamp(2.5rem,5vw,4rem); font-weight:800;
  font-family:var(--font-headline); letter-spacing:-0.03em;
  margin:0 0 0.5rem; line-height:1.1;
}
.species-detail-hero-info .sci-name {
  font-size:1.25rem; color:var(--primary); font-style:italic;
  font-weight:500; margin:0 0 1.5rem;
}
.species-detail-hero-info .desc {
  font-size:1.05rem; color:var(--on-surface-variant); line-height:1.8; margin:0;
}

/* Stats bento */
.species-stats-bento {
  display:grid; grid-template-columns:1fr; gap:1rem; margin-bottom:4rem;
}
@media (min-width:768px) { .species-stats-bento { grid-template-columns:repeat(3,1fr); } }

.stat-card {
  padding:2rem; border-radius:var(--r-lg);
}
.stat-card-light { background:var(--surface-container-low); }
.stat-card-primary { background:var(--primary); color:var(--on-primary); }
.stat-card svg { margin-bottom:1rem; }
.stat-card h3 { font-size:1.1rem; font-weight:700; margin:0 0 0.25rem; font-family:var(--font-headline); }
.stat-card .stat-value { font-size:2.5rem; font-weight:800; margin-bottom:1rem; }
.stat-card .stat-label { font-size:0.6875rem; text-transform:uppercase; letter-spacing:0.1em; font-weight:700; opacity:0.7; }

.stat-card-primary .stat-desc { color:var(--primary-fixed); font-size:0.875rem; line-height:1.6; margin-bottom:1.5rem; }

/* Temperature row */
.temp-row {
  grid-column: 1 / -1;
  background:var(--surface-container-lowest); padding:2rem;
  border-radius:var(--r-lg); box-shadow:var(--shadow-sm);
  border:1px solid rgba(192,201,184,0.1);
  display:grid; grid-template-columns:1fr; gap:2rem;
}
@media (min-width:768px) { .temp-row { grid-template-columns:repeat(3,1fr); } }
.temp-item { display:flex; flex-direction:column; }
.temp-item .temp-label { font-weight:700; font-size:0.8rem; text-transform:uppercase; letter-spacing:0.1em; margin-bottom:1rem; }
.temp-item .temp-value { font-size:2.5rem; font-weight:800; }
.temp-item .temp-desc { font-size:0.875rem; color:var(--on-surface-variant); margin-top:0.5rem; }
.temp-label-primary { color:var(--primary); }
.temp-label-muted { color:var(--on-surface-variant); }
.temp-label-secondary { color:var(--secondary); }

/* Husbandry */
.husbandry-section {
  display:grid; grid-template-columns:1fr; gap:4rem; align-items:start; margin-bottom:6rem;
}
@media (min-width:1024px) { .husbandry-section { grid-template-columns:1fr 1fr; } }
.husbandry-section h2 { font-size:2.5rem; font-weight:700; letter-spacing:-0.02em; margin:0 0 1.5rem; font-family:var(--font-headline); }
.husbandry-section > div:first-child p { font-size:1.1rem; color:var(--on-surface-variant); line-height:1.8; margin:0 0 2.5rem; }

.husbandry-tips { display:flex; flex-direction:column; gap:2rem; }
.husbandry-tip { display:flex; gap:1.5rem; }
.husbandry-tip-icon {
  width:3rem; height:3rem; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.tip-icon-primary { background:var(--primary-fixed); color:var(--primary); }
.tip-icon-tertiary { background:var(--tertiary-fixed); color:var(--tertiary); }
.tip-icon-secondary { background:var(--secondary-fixed); color:var(--secondary); }
.husbandry-tip h3 { font-weight:700; font-size:1.1rem; margin:0 0 0.25rem; }
.husbandry-tip p { font-size:0.875rem; color:var(--on-surface-variant); line-height:1.6; margin:0; }

/* Image grid */
.species-images-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:1rem;
}
.species-images-grid .grid-img {
  border-radius:var(--r-lg); overflow:hidden; aspect-ratio:1/1; background:var(--surface-container-low);
}
.species-images-grid .grid-img:nth-child(2) { margin-top:2rem; }
.species-images-grid .grid-img:nth-child(3) { margin-top:-2rem; }
.species-images-grid img { width:100%; height:100%; object-fit:cover; }

/* Species navigation */
.species-nav-row {
  border-top:1px solid rgba(192,201,184,0.2);
  padding-top:3rem; margin-top:3rem;
  display:flex; flex-direction:column; gap:1.5rem;
  align-items:center; justify-content:space-between;
}
@media (min-width:768px) { .species-nav-row { flex-direction:row; } }

.species-nav-btn {
  display:flex; align-items:center; gap:1rem; padding:1rem;
  border-radius:var(--r-lg); transition:background 0.2s;
  text-decoration:none; color:inherit;
}
.species-nav-btn:hover { background:var(--surface-container-low); }
.species-nav-btn-icon {
  width:3rem; height:3rem; border-radius:50%;
  background:var(--surface-container); display:flex;
  align-items:center; justify-content:center;
  transition:all 0.2s; color:var(--on-surface-variant);
}
.species-nav-btn:hover .species-nav-btn-icon { background:var(--primary); color:white; }
.species-nav-btn-text .nav-label { font-size:0.875rem; color:var(--on-surface-variant); margin-bottom:0.25rem; }
.species-nav-btn-text .nav-name { font-weight:700; font-size:1.1rem; }

/* CTA banner */
.species-cta-banner {
  background:var(--primary); border-radius:var(--r-xl); padding:3rem;
  position:relative; overflow:hidden; text-align:center; margin-top:6rem;
}
@media (min-width:768px) { .species-cta-banner { text-align:left; } }
.species-cta-banner::before, .species-cta-banner::after {
  content:''; position:absolute; border-radius:50%;
  background:rgba(63,131,43,0.4); filter:blur(60px);
}
.species-cta-banner::before { width:16rem; height:16rem; top:-50%; right:-10%; }
.species-cta-banner::after { width:12rem; height:12rem; bottom:-50%; left:-10%; }
.species-cta-inner {
  position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:center; gap:3rem;
}
@media (min-width:768px) { .species-cta-inner { flex-direction:row; } }
.species-cta-inner h2 {
  font-size:clamp(1.5rem,3vw,3rem); font-weight:800;
  color:var(--on-primary); letter-spacing:-0.02em;
  font-family:var(--font-headline); margin:0 0 1rem; flex:1;
}
.species-cta-inner p { color:var(--primary-fixed); font-size:1.1rem; max-width:36rem; margin:0; }
.species-cta-btn {
  display:inline-flex; align-items:center; gap:0.75rem;
  background:var(--primary-fixed); color:var(--on-primary-fixed);
  font-weight:700; padding:1.25rem 2.5rem; border-radius:var(--r-sm);
  box-shadow:var(--shadow-xl); transition:all 0.2s; white-space:nowrap; flex-shrink:0;
}
.species-cta-btn:hover { background:white; color:var(--on-primary-fixed); }
.species-cta-btn:active { transform:scale(0.95); }
.species-cta-btn svg { width:24px; height:24px; }

/* ═══════════════════════════════════════════════════════
   BLOG PAGE
   ═══════════════════════════════════════════════════════ */
.blog-page { max-width:1400px; margin:0 auto; padding:3rem 1.5rem; }
@media (min-width:768px) { .blog-page { padding:3rem 3rem; } }

.blog-header {
  display:flex; align-items:flex-start; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  margin-bottom:2rem;
}
.blog-header h1 {
  font-size:clamp(2rem,4vw,3.75rem); font-weight:800;
  font-family:var(--font-headline); letter-spacing:-0.05em; margin:0;
}
.blog-filters { display:none; gap:1rem; }
@media (min-width:768px) { .blog-filters { display:flex; } }
.blog-filter-pill {
  padding:0.5rem 1rem; border-radius:var(--r-full);
  border:1px solid rgba(192,201,184,0.3); font-size:0.875rem;
  font-weight:700; transition:background 0.2s; color:var(--on-surface-variant);
}
.blog-filter-pill:hover { background:var(--surface-container-low); }

/* Blog hero article */
.blog-hero-article {
  position:relative; border-radius:var(--r-2xl); overflow:hidden;
  aspect-ratio:16/9; margin-bottom:4rem; cursor:pointer;
}
@media (min-width:768px) { .blog-hero-article { aspect-ratio:21/9; } }
.blog-hero-article img {
  width:100%; height:100%; object-fit:cover;
  transition:transform 1s;
}
.blog-hero-article:hover img { transform:scale(1.05); }
.blog-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.8), rgba(0,0,0,0.2), transparent);
}
.blog-hero-content {
  position:absolute; bottom:0; left:0; padding:2rem;
  width:100%;
}
@media (min-width:768px) { .blog-hero-content { padding:4rem; width:66%; } }
.blog-hero-tags { display:flex; gap:0.75rem; margin-bottom:1rem; }
.blog-hero-tags span {
  font-size:0.6875rem; font-weight:700; text-transform:uppercase;
  letter-spacing:0.1em; padding:0.25rem 0.75rem; border-radius:var(--r-full);
}
.blog-hero-content h2 {
  font-size:clamp(1.5rem,3vw,3rem); font-weight:700; color:white;
  font-family:var(--font-headline); line-height:1.2; margin:0 0 1rem;
}
.blog-hero-content p { color:rgba(255,255,255,0.8); font-size:1.1rem; margin:0 0 1.5rem; display:none; }
@media (min-width:768px) { .blog-hero-content p { display:block; } }
.blog-hero-meta { display:flex; align-items:center; gap:1rem; color:rgba(255,255,255,0.6); font-size:0.875rem; font-weight:500; }
.blog-hero-meta svg { width:16px; height:16px; }

/* Blog grid */
.blog-grid { display:grid; grid-template-columns:1fr; gap:3rem; }
@media (min-width:1024px) { .blog-grid { grid-template-columns:2fr 1fr; } }

.blog-posts { display:flex; flex-direction:column; gap:3rem; }
.blog-post-card {
  display:flex; flex-direction:column; gap:2rem; cursor:pointer;
}
@media (min-width:768px) { .blog-post-card { flex-direction:row; } }
.blog-post-card-img {
  width:100%; aspect-ratio:4/3; border-radius:var(--r-xl); overflow:hidden; background:var(--surface-container-low);
}
@media (min-width:768px) { .blog-post-card-img { width:40%; } }
.blog-post-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s; }
.blog-post-card:hover .blog-post-card-img img { transform:scale(1.05); }
.blog-post-card-body { flex:1; }
.blog-post-card-meta {
  display:flex; align-items:center; gap:0.75rem; font-size:0.75rem;
  font-weight:700; text-transform:uppercase; letter-spacing:0.1em;
  color:var(--primary); margin-bottom:1rem;
}
.blog-post-card-meta svg { width:14px; height:14px; }
.blog-post-card-body h3 {
  font-size:clamp(1.25rem,2vw,1.75rem); font-weight:700;
  font-family:var(--font-headline); margin:0 0 1rem; line-height:1.3;
  transition:color 0.2s;
}
.blog-post-card:hover .blog-post-card-body h3 { color:var(--primary); }
.blog-post-card-body p { color:var(--on-surface-variant); line-height:1.7; margin:0 0 1.5rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.blog-post-card-cta {
  display:inline-flex; align-items:center; gap:0.5rem;
  font-weight:700; color:var(--primary); transition:gap 0.2s;
}
.blog-post-card:hover .blog-post-card-cta { gap:0.75rem; }
.blog-post-card-cta svg { width:18px; height:18px; }

/* Blog sidebar */
.blog-sidebar { display:flex; flex-direction:column; gap:3rem; }
.blog-sidebar-card {
  background:var(--surface-container-low); padding:2rem;
  border-radius:var(--r-xl); border:1px solid rgba(192,201,184,0.2);
}
.blog-sidebar-card h3 {
  font-size:1.25rem; font-weight:700; font-family:var(--font-headline);
  margin:0 0 1.5rem; display:flex; align-items:center; gap:0.5rem;
}
.blog-sidebar-card h3 svg { color:var(--primary); width:20px; height:20px; }
.blog-sidebar-card p { font-size:0.875rem; color:var(--on-surface-variant); line-height:1.6; margin:0 0 1.5rem; }

.blog-sidebar-input {
  width:100%; padding:0.75rem 1rem; border-radius:var(--r-sm);
  border:1px solid rgba(192,201,184,0.3); background:var(--surface-container-lowest);
  margin-bottom:0.75rem; font-size:0.9375rem;
}
.blog-sidebar-input:focus { outline:none; box-shadow:0 0 0 2px rgba(37,106,19,0.3); }
.blog-sidebar-btn {
  width:100%; background:var(--primary); color:var(--on-primary);
  font-weight:700; padding:0.75rem; border-radius:var(--r-sm); transition:background 0.2s;
}
.blog-sidebar-btn:hover { background:var(--primary-container); }

.blog-tags { display:flex; flex-wrap:wrap; gap:0.5rem; }
.blog-tag-pill {
  padding:0.5rem 1rem; background:var(--surface-container-lowest);
  border:1px solid rgba(192,201,184,0.3); border-radius:var(--r-full);
  font-size:0.875rem; font-weight:500; color:var(--on-surface-variant);
  transition:all 0.2s;
}
.blog-tag-pill:hover { border-color:var(--primary); color:var(--primary); }

/* ═══════════════════════════════════════════════════════
   FEEDING PAGE
   ═══════════════════════════════════════════════════════ */
.feeding-page { max-width:64rem; margin:0 auto; padding:3rem 1.5rem; }

.feeding-header { text-align:center; margin-bottom:4rem; }
.feeding-header .guide-badge {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding:0.375rem 1rem; border-radius:var(--r-full);
  background:var(--primary-fixed); color:var(--on-primary-fixed);
  font-weight:700; font-size:0.75rem; text-transform:uppercase;
  letter-spacing:0.1em; margin-bottom:1.5rem;
}
.feeding-header .guide-badge svg { width:14px; height:14px; }
.feeding-header h1 {
  font-size:clamp(2.5rem,5vw,4.5rem); font-weight:800;
  font-family:var(--font-headline); letter-spacing:-0.03em;
  margin:0 0 1.5rem; line-height:1.1;
}
.feeding-header p { font-size:1.25rem; color:var(--on-surface-variant); max-width:36rem; margin:0 auto; line-height:1.7; }

/* Seasonal calendar */
.season-grid {
  display:grid; grid-template-columns:1fr; gap:1rem; margin-bottom:5rem;
}
@media (min-width:640px) { .season-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px) { .season-grid { grid-template-columns:repeat(4,1fr); } }
.season-card { padding:1.5rem; border-radius:var(--r-xl); }
.season-card h3 { font-size:1.25rem; font-weight:700; font-family:var(--font-headline); margin:0 0 0.75rem; }
.season-card p { font-size:0.875rem; opacity:0.9; line-height:1.6; margin:0; }
.season-spring { background:var(--primary-fixed); color:var(--on-primary-fixed); }
.season-summer { background:var(--surface-container-highest); color:var(--on-surface); }
.season-autumn { background:var(--tertiary-fixed); color:var(--on-tertiary-fixed); }
.season-winter { background:var(--secondary-fixed); color:var(--on-secondary-fixed); }

/* Calcium section */
.calcium-section {
  background:var(--surface-container-low); padding:2rem;
  border-radius:var(--r-2xl); border:1px solid rgba(192,201,184,0.2);
  margin-bottom:5rem; position:relative; overflow:hidden;
}
@media (min-width:768px) { .calcium-section { padding:3rem; } }
.calcium-grid {
  display:grid; grid-template-columns:1fr; gap:3rem; align-items:center; position:relative; z-index:1;
}
@media (min-width:768px) { .calcium-grid { grid-template-columns:1fr 1fr; } }
.calcium-section h2 { font-size:1.75rem; font-weight:700; font-family:var(--font-headline); margin:0 0 1.5rem; }
.calcium-section > .calcium-grid > div:first-child > p { color:var(--on-surface-variant); line-height:1.7; margin:0 0 1.5rem; }

.calcium-tips { display:flex; flex-direction:column; gap:1rem; }
.calcium-tip { display:flex; gap:0.75rem; align-items:flex-start; }
.calcium-tip svg { flex-shrink:0; margin-top:2px; }
.calcium-tip span { font-size:0.875rem; color:var(--on-surface-variant); }
.calcium-tip strong { color:var(--on-surface); }

.calcium-ratio-box {
  background:var(--surface-container-lowest); padding:1.5rem; border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm); border:1px solid rgba(192,201,184,0.1);
}
.calcium-ratio-box h3 { font-weight:700; font-size:0.8rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--primary); margin:0 0 1rem; }
.calcium-ratio-box p { font-size:0.875rem; color:var(--on-surface-variant); margin:0 0 1rem; }
.calcium-bar { height:0.375rem; background:var(--surface-container-highest); border-radius:var(--r-full); overflow:hidden; display:flex; }
.calcium-bar-ca { width:66%; background:var(--primary); height:100%; }
.calcium-bar-p { width:34%; background:var(--error); height:100%; }
.calcium-bar-labels { display:flex; justify-content:space-between; margin-top:0.5rem; font-size:0.75rem; font-weight:700; }

/* Safe foods table */
.foods-table-wrap { margin-bottom:5rem; }
.foods-table-wrap h2 { font-size:1.5rem; font-weight:700; font-family:var(--font-headline); margin:0 0 0.5rem; }
.foods-table-wrap > p { color:var(--on-surface-variant); margin:0 0 2rem; }
.foods-table {
  width:100%; border-collapse:collapse; background:var(--surface-container-lowest);
  border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm);
  border:1px solid rgba(192,201,184,0.2);
}
.foods-table thead { background:var(--surface-container-low); }
.foods-table th {
  padding:1rem; text-align:left; font-weight:700; font-size:0.8rem;
  text-transform:uppercase; letter-spacing:0.1em; color:var(--on-surface-variant);
  border-bottom:1px solid rgba(192,201,184,0.2);
}
.foods-table td { padding:1rem; font-size:0.875rem; border-bottom:1px solid rgba(192,201,184,0.1); }
.foods-table tr:hover { background:var(--surface-container-lowest); }
.foods-table .food-name { font-weight:700; color:var(--primary); }
.foods-table .food-sci { font-style:italic; color:var(--on-surface-variant); }
.freq-badge {
  display:inline-block; padding:0.125rem 0.5rem; border-radius:4px;
  font-size:0.75rem; font-weight:700;
}
.freq-daily { background:var(--primary-fixed); color:var(--on-primary-fixed); }
.freq-moderate { background:var(--surface-container-highest); color:var(--on-surface-variant); }

/* Red list */
.red-list-section {
  background:var(--error-container); color:var(--on-error-container);
  padding:2rem; border-radius:var(--r-2xl);
}
@media (min-width:768px) { .red-list-section { padding:3rem; } }
.red-list-header { display:flex; align-items:center; gap:1rem; margin-bottom:1.5rem; }
.red-list-icon {
  width:3rem; height:3rem; border-radius:50%;
  background:var(--error); color:white;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.red-list-icon svg { width:24px; height:24px; }
.red-list-header h2 { font-size:1.5rem; font-weight:700; font-family:var(--font-headline); margin:0; }
.red-list-section > p { margin:0 0 2rem; line-height:1.7; }
.red-list-grid {
  display:grid; grid-template-columns:1fr; gap:1rem;
}
@media (min-width:640px) { .red-list-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:768px) { .red-list-grid { grid-template-columns:repeat(3,1fr); } }
.red-list-item {
  display:flex; gap:0.75rem; align-items:flex-start;
  background:rgba(255,255,255,0.4); padding:1rem; border-radius:var(--r-sm);
}
.red-list-item svg { color:var(--error); flex-shrink:0; margin-top:2px; width:18px; height:18px; }
.red-list-item span { font-size:0.875rem; font-weight:500; }

/* ═══════════════════════════════════════════════════════
   LEGAL / COOKIES / ACCESSIBILITY PAGES
   ═══════════════════════════════════════════════════════ */
.legal-page {
  max-width:48rem; margin:0 auto; padding:4rem 1.5rem;
}
.legal-page h1 {
  font-size:clamp(2rem,4vw,3rem); font-weight:800;
  font-family:var(--font-headline); margin:0 0 2rem;
}
.legal-page h2 {
  font-size:1.5rem; font-weight:700; color:var(--on-surface);
  margin:2.5rem 0 1rem;
}
.legal-page p { color:var(--on-surface-variant); line-height:1.8; margin:0 0 1.5rem; }
.legal-page ul { padding-left:1.5rem; margin:0 0 1.5rem; }
.legal-page li { color:var(--on-surface-variant); line-height:1.8; margin-bottom:0.75rem; }
.legal-page a { color:var(--primary); text-decoration:underline; text-underline-offset:3px; }
.legal-back {
  display:inline-flex; align-items:center; gap:0.5rem;
  color:var(--on-surface-variant); font-weight:500; margin-bottom:2rem;
  transition:color 0.2s;
}
.legal-back:hover { color:var(--primary); }
.legal-back svg { width:20px; height:20px; }

/* ═══════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════ */
.site-footer {
  background:var(--surface-container-low); width:100%;
  padding:4rem 0; border-top:1px solid rgba(192,201,184,0.1);
}
.footer-grid {
  display:grid; grid-template-columns:1fr; gap:3rem;
  max-width:1400px; margin:0 auto; padding:0 1.5rem;
}
@media (min-width:768px) { .footer-grid { grid-template-columns:1fr 2fr 1fr; padding:0 3rem; } }

.footer-brand { display:flex; flex-direction:column; gap:1.5rem; }
.footer-brand-row { display:flex; align-items:center; gap:0.75rem; }
.footer-brand-row img { height:3rem; width:auto; }
.footer-brand-row span { font-size:1.25rem; font-weight:700; color:var(--primary); font-family:var(--font-headline); letter-spacing:-0.02em; }
.footer-brand p { font-size:0.875rem; color:var(--on-surface-variant); line-height:1.6; max-width:18rem; margin:0; }

.footer-links-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:2rem; }
.footer-links-grid h4 { font-size:0.875rem; font-weight:700; color:var(--on-surface); margin:0 0 0.75rem; }
.footer-links-grid a {
  display:block; font-size:0.875rem; color:var(--on-surface-variant);
  padding:0.25rem 0; transition:color 0.2s;
}
.footer-links-grid a:hover { color:var(--primary); }

.footer-support { display:flex; flex-direction:column; gap:1.5rem; align-items:flex-start; }
@media (min-width:768px) { .footer-support { align-items:flex-end; } }
.footer-support h4 { font-size:0.875rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; margin:0; }
.footer-support-btn {
  background:rgba(37,106,19,0.1); color:var(--primary); font-weight:700;
  padding:0.75rem 1.5rem; border-radius:var(--r-sm); font-size:0.875rem;
  transition:all 0.2s;
}
.footer-support-btn:hover { background:var(--primary); color:var(--on-primary); }
.footer-copyright { font-size:0.75rem; color:var(--on-surface-variant); text-transform:uppercase; letter-spacing:0.1em; margin-top:1rem; }

.footer-bottom {
  max-width:1400px; margin:0 auto; padding:2rem 1.5rem 0;
  border-top:1px solid rgba(192,201,184,0.1); margin-top:3rem;
}
@media (min-width:768px) { .footer-bottom { padding:2rem 3rem 0; } }
.footer-bottom p { font-size:0.75rem; color:var(--on-surface-variant); text-align:center; margin:0; }
@media (min-width:768px) { .footer-bottom p { text-align:left; } }

/* ═══════════════════════════════════════════════════════
   WP OVERRIDES & BLOG POST STYLES
   ═══════════════════════════════════════════════════════ */
.entry-content { font-size:1.0625rem; line-height:1.8; color:var(--on-surface-variant); }
.entry-content h2 { font-size:1.5rem; font-weight:700; color:var(--on-surface); margin:2.5rem 0 1rem; }
.entry-content h3 { font-size:1.2rem; font-weight:700; color:var(--on-surface); margin:2rem 0 0.75rem; }
.entry-content p { margin:0 0 1.5rem; }
.entry-content img { border-radius:var(--r-md); margin:2rem 0; }
.entry-content blockquote { border-left:3px solid var(--primary); padding:1rem 1.5rem; margin:2rem 0; background:var(--surface-container-low); border-radius:0 var(--r-sm) var(--r-sm) 0; font-style:italic; }
.entry-content a { color:var(--primary); text-decoration:underline; text-underline-offset:2px; }
.entry-content ul, .entry-content ol { padding-left:1.5rem; margin:0 0 1.5rem; }
.entry-content li { margin-bottom:0.5rem; }

/* Single post */
.single-post-page { max-width:48rem; margin:0 auto; padding:2rem 1.5rem 4rem; }
.single-post-hero { aspect-ratio:16/9; border-radius:var(--r-2xl); overflow:hidden; margin-bottom:2rem; }
.single-post-hero img { width:100%; height:100%; object-fit:cover; }
.single-post-header { margin-bottom:3rem; }
.single-post-cats { display:flex; gap:0.5rem; margin-bottom:1rem; }
.single-post-title { font-size:clamp(1.75rem,4vw,2.75rem); font-weight:800; font-family:var(--font-headline); letter-spacing:-0.03em; margin:0 0 1rem; line-height:1.2; }
.single-post-meta { display:flex; align-items:center; gap:0.75rem; font-size:0.875rem; color:var(--on-surface-variant); font-weight:500; }
.single-post-meta .sep { opacity:0.4; }

/* Pagination */
.wp-pagination { margin-top:3rem; text-align:center; }
.wp-pagination .nav-links { display:flex; align-items:center; justify-content:center; gap:0.5rem; }
.wp-pagination .page-numbers {
  display:inline-flex; align-items:center; justify-content:center;
  width:2.25rem; height:2.25rem; border-radius:var(--r-sm);
  font-weight:700; font-size:0.875rem; color:var(--on-surface-variant);
  border:1px solid rgba(192,201,184,0.3); background:var(--surface-container-lowest);
  transition:all 0.2s;
}
.wp-pagination .page-numbers:hover { background:var(--surface-container-low); color:var(--on-surface); }
.wp-pagination .page-numbers.current { background:var(--primary); color:var(--on-primary); border-color:var(--primary); }

/* Elementor */
.testudo-elementor-active .site-main { overflow:visible; }
.testudo-elementor-active .elementor-section.elementor-section-stretched { width:100%!important; left:0!important; }

/* Print */
@media print {
  .site-navbar, .site-footer, .mobile-menu { display:none!important; }
  .site-main { padding:0!important; }
  a { color:inherit; text-decoration:underline; }
}

/* Amazon product images — ensure proper display */
.product-card-img {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  padding: 1rem;
}
.product-card-img img {
  width: auto;
  max-width: 100%;
  height: 10rem;
  object-fit: contain;
  mix-blend-mode: multiply;
}

/* ═══════════════════════════════════════════════════════
   NAVBAR: Species Dropdown (CLICK-based)
   ═══════════════════════════════════════════════════════ */
.nav-dropdown {
  position: relative;
}
.nav-dropdown-trigger {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-weight: 600;
  color: var(--on-surface-variant);
  transition: color 0.2s;
  padding: 0;
  background: none;
  border: none;
  font-size: inherit;
  cursor: pointer;
}
.nav-dropdown-trigger:hover,
.nav-dropdown-trigger.active {
  color: var(--primary);
}
.nav-dropdown-trigger svg {
  transition: transform 0.2s;
}
.nav-dropdown-menu.is-open ~ .nav-dropdown-trigger svg,
.nav-dropdown-trigger[aria-expanded="true"] svg {
  transform: rotate(180deg);
}

.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 0.75rem);
  left: 50%;
  transform: translateX(-50%);
  width: 280px;
  max-height: 420px;
  overflow-y: auto;
  background: var(--surface-container-lowest);
  border: 1px solid rgba(192,201,184,0.2);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xl);
  padding: 0.5rem;
  z-index: 60;
  flex-direction: column;
  scrollbar-width: thin;
  scrollbar-color: var(--outline-variant) transparent;
}
.nav-dropdown-menu::-webkit-scrollbar { width: 4px; }
.nav-dropdown-menu::-webkit-scrollbar-thumb { background: var(--outline-variant); border-radius: 4px; }

.nav-dropdown-menu.is-open {
  display: flex;
}

.nav-dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.5rem 0.625rem;
  border-radius: var(--r-sm);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--on-surface-variant);
  transition: all 0.15s;
  text-decoration: none;
  white-space: nowrap;
}
.nav-dropdown-item:hover {
  background: var(--surface-container-low);
  color: var(--primary);
}
.nav-dropdown-item img {
  width: 24px;
  height: 24px;
  border-radius: 4px;
  object-fit: cover;
  flex-shrink: 0;
}
.nav-dropdown-all {
  font-weight: 700;
  font-size: 0.8125rem;
  color: var(--primary);
  border-bottom: 1px solid rgba(192,201,184,0.15);
  margin-bottom: 0.25rem;
  padding-bottom: 0.625rem;
}

/* ─── Mobile species sub-menu ─── */
.mobile-species-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.5rem 0;
  font-weight: 700;
  color: var(--on-surface-variant);
  background: none;
  border: none;
  font-size: inherit;
  cursor: pointer;
}
.mobile-species-toggle.active { color: var(--primary); }
.mobile-species-toggle svg { transition: transform 0.2s; }
.mobile-species-toggle.active svg { transform: rotate(180deg); }

.mobile-species-sub {
  flex-direction: column;
  padding-left: 1rem;
  gap: 0.25rem;
}
.mobile-species-sub a {
  font-size: 0.875rem;
  padding: 0.375rem 0.75rem;
  color: var(--on-surface-variant);
  border-radius: var(--r-sm);
  transition: background 0.15s;
}
.mobile-species-sub a:hover { background: var(--surface-container-low); color: var(--primary); }

/* ─── Species carousel scroll buttons (desktop) ─── */
.carousel-wrap {
  position: relative;
}
.carousel-btn {
  display: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: var(--surface-container-lowest);
  box-shadow: var(--shadow-lg);
  border: 1px solid rgba(192,201,184,0.2);
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--on-surface);
  transition: all 0.2s;
}
.carousel-btn:hover {
  background: var(--primary);
  color: white;
  box-shadow: var(--shadow-xl);
}
.carousel-btn-prev { left: -0.5rem; }
.carousel-btn-next { right: -0.5rem; }
@media (min-width: 768px) {
  .carousel-btn { display: flex; }
}

