/* ==========================================================================
   futterlucke.at – Editorial "Feldnotizbuch"-Design
   ========================================================================== */

:root {
  --creme: #faf6ee;
  --creme-dark: #f0e6d2;
  --paper: #fffdf8;
  --ink: #2c2418;
  --ink-soft: #5a4f3f;
  --terracotta: #c9633f;
  --terracotta-dark: #a8492b;
  --tanne: #3c5a44;
  --tanne-dark: #294736;
  --gold: #d8a13a;
  --line: #dccdae;
  --radius-lg: 22px;
  --radius-md: 14px;
  --radius-sm: 8px;
  --shadow: 0 10px 30px -12px rgba(44, 36, 24, 0.25);
  --shadow-sm: 0 4px 14px -6px rgba(44, 36, 24, 0.2);
  --serif: Georgia, 'Iowan Old Style', 'Times New Roman', serif;
  --sans: 'Segoe UI', system-ui, -apple-system, Roboto, sans-serif;
  --maxw: 1180px;
}

* { box-sizing: border-box; min-width: 0; }
html { scroll-behavior: smooth; }
html, body { overflow-x: hidden; max-width: 100%; }
body {
  margin: 0;
  font-family: var(--sans);
  background: var(--creme);
  color: var(--ink);
  line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: var(--terracotta-dark); text-decoration-thickness: 1.5px; }
h1, h2, h3, h4 { font-family: var(--serif); color: var(--ink); line-height: 1.15; margin: 0 0 .5em; overflow-wrap: break-word; }
h1 { font-size: clamp(1.9rem, 7vw, 3.4rem); }
h2 { font-size: clamp(1.5rem, 4vw, 2.4rem); }
h3 { font-size: 1.3rem; }
p { margin: 0 0 1em; overflow-wrap: break-word; }
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; width: 100%; }
.visually-hidden { position:absolute; width:1px;height:1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; }
button, input, select, textarea { font-family: inherit; font-size: 1rem; max-width: 100%; }

/* subtle paper texture */
body::before {
  content: "";
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image: radial-gradient(rgba(44,36,24,0.035) 1px, transparent 1px);
  background-size: 4px 4px;
  opacity: .5;
}

/* ---------- Skip link ---------- */
.skip-link {
  position: absolute; left: -999px; top: 0; background: var(--tanne); color: #fff;
  padding: 10px 16px; z-index: 999; border-radius: 0 0 8px 0;
}
.skip-link:focus { left: 0; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--paper);
  border-bottom: 3px solid var(--ink);
  padding: 10px 0;
}
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.logo-link { display: flex; align-items: center; }
.logo-link img { height: 46px; width: auto; }
.main-nav { display: flex; align-items: center; gap: 4px; }
.main-nav ul { list-style: none; display: flex; gap: 4px; margin: 0; padding: 0; flex-wrap: wrap; }
.main-nav a {
  display: inline-block; padding: 8px 14px; border-radius: 999px;
  color: var(--ink); font-weight: 600; text-decoration: none; font-size: .95rem;
  transition: background .15s, color .15s;
}
.main-nav a:hover, .main-nav a.active { background: var(--tanne); color: #fff; }
.nav-cta {
  background: var(--terracotta) !important; color: #fff !important;
}
.nav-cta:hover { background: var(--terracotta-dark) !important; }
.menu-toggle {
  display: none; align-items: center; justify-content: center;
  background: none; border: 2px solid var(--ink); border-radius: var(--radius-sm);
  width: 44px; height: 44px; padding: 0; cursor: pointer; flex-shrink: 0; position: relative; z-index: 210;
}
.menu-toggle span, .menu-toggle span::before, .menu-toggle span::after {
  display: block; width: 20px; height: 2px; background: var(--ink); position: relative;
  transition: transform .2s ease, opacity .2s ease, top .2s ease;
}
.menu-toggle span::before, .menu-toggle span::after { content: ""; position: absolute; }
.menu-toggle span::before { top: -7px; } .menu-toggle span::after { top: 7px; }
.menu-toggle.open span { background: transparent; }
.menu-toggle.open span::before { top: 0; transform: rotate(45deg); background: var(--ink); }
.menu-toggle.open span::after { top: 0; transform: rotate(-45deg); background: var(--ink); }

.nav-backdrop {
  display: none; position: fixed; inset: 0; background: rgba(44,36,24,.45); z-index: 190;
}
.nav-backdrop.show { display: block; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px; font-weight: 700;
  padding: 12px 22px; border-radius: 999px; border: 2px solid var(--ink); text-decoration: none;
  cursor: pointer; background: var(--paper); color: var(--ink); transition: transform .12s, box-shadow .12s;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.btn-primary { background: var(--terracotta); border-color: var(--terracotta-dark); color: #fff; }
.btn-tanne { background: var(--tanne); border-color: var(--tanne-dark); color: #fff; }
.btn-outline { background: transparent; }
.btn-sm { padding: 8px 16px; font-size: .9rem; }
.btn-block { width: 100%; justify-content: center; }

/* ---------- Badges ---------- */
.badge {
  display: inline-flex; align-items: center; gap: 5px; font-size: .72rem; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase; padding: 4px 10px; border-radius: 999px;
}
.badge-ad { background: var(--gold); color: var(--ink); }
.badge-tanne { background: var(--tanne); color: #fff; }
.badge-terracotta { background: var(--terracotta); color: #fff; }
.badge-outline { background: transparent; border: 1.5px solid currentColor; }

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden; padding: 70px 0 90px;
  background: linear-gradient(180deg, var(--creme-dark), var(--creme));
  border-bottom: 3px solid var(--ink);
}
.hero .wrap { display: grid; grid-template-columns: 1.1fr .9fr; gap: 50px; align-items: center; position: relative; z-index: 1; }
.hero-kicker { display:inline-block; font-weight:700; color: var(--tanne-dark); letter-spacing:.08em; text-transform:uppercase; font-size:.85rem; margin-bottom: 10px;}
.hero-blob {
  position: absolute; right: -80px; top: -80px; width: 420px; height: 420px;
  background: var(--terracotta); opacity: .12; border-radius: 42% 58% 63% 37% / 41% 44% 56% 59%;
}
.hero-art { position: relative; }
.hero-art svg, .hero-art img { width: 100%; }
.search-box {
  display: flex; gap: 8px; margin-top: 26px; background: var(--paper); border: 2px solid var(--ink);
  border-radius: 999px; padding: 6px; max-width: 480px;
}
.search-box input { flex: 1; border: none; background: transparent; padding: 10px 16px; outline: none; }
.search-box button { border-radius: 999px; }

/* ---------- Sections ---------- */
.section { padding: 64px 0; position: relative; z-index: 1; }
.section-alt { background: var(--paper); border-top: 3px solid var(--ink); border-bottom: 3px solid var(--ink); }
.section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 34px; flex-wrap: wrap; }
.section-head p { color: var(--ink-soft); max-width: 60ch; }

/* Asymmetric card grid */
.topic-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px;
}
.topic-grid > a:nth-child(1) { grid-column: span 2; grid-row: span 2; }
.topic-card {
  position: relative; display: block; text-decoration: none; color: var(--ink);
  background: var(--paper); border: 2.5px solid var(--ink); border-radius: var(--radius-lg);
  padding: 26px; min-height: 150px; overflow: hidden; transition: transform .15s, box-shadow .15s;
}
.topic-card:hover { transform: rotate(-.6deg) translateY(-3px); box-shadow: var(--shadow); }
.topic-card .emoji { font-size: 2.4rem; display:block; margin-bottom: 10px; }
.topic-card h3 { margin-bottom: 6px; }
.topic-card p { color: var(--ink-soft); font-size: .95rem; margin: 0; }

/* Article / breed cards */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 24px; }
.card {
  background: var(--paper); border: 2px solid var(--ink); border-radius: var(--radius-md);
  overflow: hidden; display: flex; flex-direction: column; transition: transform .15s, box-shadow .15s;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-sm); }
.card-media { aspect-ratio: 4/3; background: var(--creme-dark); display:flex; align-items:center; justify-content:center; font-size: 3rem; border-bottom: 2px solid var(--ink);}
.card-body { padding: 18px 20px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.card-body h3 { margin: 0; font-size: 1.15rem; }
.card-meta { display: flex; gap: 8px; flex-wrap: wrap; font-size: .78rem; color: var(--ink-soft); }
.card-meta span { background: var(--creme-dark); padding: 3px 9px; border-radius: 999px; }
.card-body .btn { margin-top: auto; align-self: flex-start; }

/* ---------- Filters ---------- */
.filter-bar {
  display: flex; flex-wrap: wrap; gap: 10px; background: var(--paper); border: 2px solid var(--ink);
  border-radius: var(--radius-md); padding: 16px; margin-bottom: 28px;
}
.filter-bar select, .filter-bar input[type="text"] {
  border: 2px solid var(--line); border-radius: var(--radius-sm); padding: 9px 12px; background: var(--creme);
}
.filter-bar label { font-size: .8rem; font-weight: 700; display: block; margin-bottom: 4px; color: var(--ink-soft); }

/* ---------- Comparison table ---------- */
.compare-table-wrap { overflow-x: auto; border: 2.5px solid var(--ink); border-radius: var(--radius-md); background: var(--paper); }
table.compare { width: 100%; border-collapse: collapse; min-width: 720px; }
table.compare th, table.compare td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--line); vertical-align: middle; }
table.compare thead th { background: var(--tanne); color: #fff; font-family: var(--serif); font-size: 1rem; position: sticky; top: 0;}
table.compare tbody tr:hover { background: var(--creme-dark); }
table.compare .prod-name { font-weight: 700; }
.stars { color: var(--gold); letter-spacing: 1px; }
.ad-note { font-size: .7rem; color: var(--ink-soft); padding: 10px 16px; }

/* ---------- Breed detail ---------- */
.breed-hero { display: grid; grid-template-columns: 220px 1fr; gap: 30px; align-items: center; margin-bottom: 30px;}
.breed-hero .emoji-lg { font-size: 6rem; background: var(--creme-dark); border: 3px solid var(--ink); border-radius: 50%; width: 220px; height: 220px; display:flex; align-items:center; justify-content:center; }
.stat-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit,minmax(150px,1fr)); gap: 14px; }
.stat-list li { background: var(--paper); border: 2px solid var(--ink); border-radius: var(--radius-sm); padding: 12px 14px; }
.stat-list strong { display: block; font-family: var(--serif); font-size: 1.1rem; }
.meter { height: 10px; border-radius: 999px; background: var(--creme-dark); overflow: hidden; border: 1.5px solid var(--ink); }
.meter > span { display: block; height: 100%; background: var(--terracotta); }

.two-col { display: grid; grid-template-columns: 2fr 1fr; gap: 40px; align-items: start; }
.sidebar-box { background: var(--paper); border: 2px solid var(--ink); border-radius: var(--radius-md); padding: 20px; margin-bottom: 20px; }
.sidebar-box h4 { margin-bottom: 10px; }

/* ---------- Forms ---------- */
.form-box { background: var(--paper); border: 2.5px solid var(--ink); border-radius: var(--radius-lg); padding: 34px; max-width: 720px; }
.form-row { margin-bottom: 18px; }
.form-row label { display: block; font-weight: 700; margin-bottom: 6px; }
.form-row input, .form-row textarea, .form-row select {
  width: 100%; padding: 11px 14px; border: 2px solid var(--line); border-radius: var(--radius-sm); background: var(--creme);
}
.form-row input:focus, .form-row textarea:focus { outline: 2px solid var(--tanne); border-color: var(--tanne); }
.checkbox-row { display: flex; gap: 10px; align-items: flex-start; }
.checkbox-row input { width: auto; margin-top: 4px; }
.honeypot { position: absolute; left: -9999px; opacity: 0; height:0; }
.alert { padding: 14px 18px; border-radius: var(--radius-sm); margin-bottom: 20px; font-weight: 600; }
.alert-success { background: #e2efe2; border: 2px solid var(--tanne); color: var(--tanne-dark); }
.alert-error { background: #f7e2dc; border: 2px solid var(--terracotta); color: var(--terracotta-dark); }

/* ---------- Footer ---------- */
.site-footer { background: var(--ink); color: var(--creme); padding: 50px 0 24px; margin-top: 40px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 30px; margin-bottom: 30px; }
.site-footer h4 { color: #fff; font-family: var(--sans); font-size: .95rem; text-transform: uppercase; letter-spacing: .05em; }
.site-footer a { color: var(--creme-dark); text-decoration: none; }
.site-footer a:hover { color: #fff; text-decoration: underline; }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.footer-bottom { border-top: 1px solid #4a4030; padding-top: 20px; font-size: .85rem; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; color:#b8ac93;}

/* ---------- Cookie banner ---------- */
.cookie-banner {
  position: fixed; bottom: 16px; left: 16px; right: 16px; max-width: 620px; margin: 0 auto;
  background: var(--paper); border: 2.5px solid var(--ink); border-radius: var(--radius-lg);
  padding: 22px; box-shadow: var(--shadow); z-index: 999; display: none;
}
.cookie-banner.show { display: block; }
.cookie-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
.cookie-options { margin: 14px 0; display: flex; flex-direction: column; gap: 8px; font-size: .9rem; }

/* ---------- Breadcrumb ---------- */
.breadcrumb { font-size: .85rem; color: var(--ink-soft); margin-bottom: 18px; }
.breadcrumb a { color: var(--ink-soft); }

/* ---------- Utilities ---------- */
.text-center { text-align: center; }
.mt-0 { margin-top: 0; } .mb-0 { margin-bottom: 0; }
.tag-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }

@media (max-width: 900px) {
  .hero .wrap { grid-template-columns: 1fr; }
  .hero-art { order: -1; max-width: 300px; margin: 0 auto; }
  .topic-grid { grid-template-columns: 1fr 1fr; }
  .topic-grid > a:nth-child(1) { grid-column: span 2; grid-row: span 1; }
  .two-col { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .breed-hero { grid-template-columns: 140px 1fr; }
  .breed-hero .emoji-lg { width: 140px; height: 140px; font-size: 3.6rem; }
}
@media (max-width: 640px) {
  .wrap { padding: 0 18px; }
  .site-header .wrap { padding: 0 16px; }

  .main-nav {
    position: fixed; top: 0; right: 0; bottom: 0; left: auto;
    width: min(82vw, 340px);
    background: var(--paper);
    flex-direction: column; align-items: stretch;
    padding: 90px 8px 28px;
    display: flex;
    transform: translateX(100%);
    transition: transform .28s ease;
    overflow-y: auto;
    border-left: 3px solid var(--ink);
    box-shadow: -12px 0 30px -10px rgba(44,36,24,.35);
    z-index: 200;
  }
  .main-nav.open { transform: translateX(0); }
  .main-nav ul { flex-direction: column; gap: 0; width: 100%; }
  .main-nav ul li { border-bottom: 1px solid var(--line); }
  .main-nav ul li:last-child { border-bottom: none; margin-top: 10px; }
  .main-nav a {
    display: block; width: 100%; padding: 16px 14px; border-radius: var(--radius-sm);
    font-size: 1.05rem;
  }
  .main-nav a:hover, .main-nav a.active { background: var(--creme-dark); color: var(--ink); }
  .menu-toggle { display: flex; }
  .topic-grid { grid-template-columns: 1fr; }
  .topic-grid > a:nth-child(1) { grid-column: span 1; }
  .footer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 400px) {
  .wrap { padding: 0 14px; }
  .site-header .wrap { padding: 0 12px; }
}
