/* Page-specific styles (about, kontakt, referenzen, single referenz, single service, knowledge) */

/* ---------- About ---------- */
.ab-hero { padding: 10rem 0 5rem; position: relative; overflow: hidden; }
.ab-hero h1 { font-family: var(--bs-font-heading); font-weight: 900; font-size: clamp(3rem, 9vw, 8rem); line-height: 0.9; letter-spacing: -.03em; margin: 0; }

.values-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; padding: 5rem 0; }
@media (min-width: 768px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .values-grid { grid-template-columns: repeat(4, 1fr); } }
.value-card { padding: 2rem; border: 1px solid var(--bs-border-subtle); border-radius: 1rem; background: var(--bs-bg-subtle); transition: border-color .3s; }
.value-card:hover { border-color: var(--bs-accent); }
.value-card .num { font-family: 'Courier New', monospace; color: var(--bs-accent); font-size: .75rem; letter-spacing: .3em; }
.value-card h3 { font-family: var(--bs-font-heading); font-weight: 900; font-size: 1.5rem; color: #fff; margin: 1rem 0 .75rem; letter-spacing: -.01em; }
.value-card p { color: var(--bs-text-muted); line-height: 1.65; margin: 0; font-size: .95rem; }

.founder { display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: center; padding: 1rem 0 2rem; }
@media (min-width: 880px) { .founder { grid-template-columns: 22rem 1fr; gap: 4rem; } }
.founder-portrait { position: relative; border-radius: 1rem; overflow: hidden; border: 1px solid var(--bs-border-subtle); background: var(--bs-bg-subtle); aspect-ratio: 4 / 5; }
.founder-portrait img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: .7; }
.founder-badge { position: absolute; left: 1rem; bottom: 1rem; padding: .35rem .9rem; background: var(--bs-accent); color: #000; font-family: var(--bs-font-heading); font-weight: 900; letter-spacing: .1em; border-radius: .4rem; font-size: .9rem; }
.founder-body h3 { font-family: var(--bs-font-heading); font-weight: 900; font-size: clamp(2rem, 4vw, 2.75rem); color: #fff; margin: 0; letter-spacing: -.02em; }
.founder-role { color: var(--bs-accent); font-family: var(--bs-font-heading); font-weight: 900; letter-spacing: .2em; text-transform: uppercase; font-size: .9rem; margin-top: .5rem; }
.founder-quals { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1.25rem 0 1.75rem; }
.founder-quals span { font-family: 'Courier New', monospace; font-size: .75rem; letter-spacing: .05em; color: var(--bs-text-secondary); border: 1px solid var(--bs-border-subtle); border-radius: 2rem; padding: .4rem .9rem; }
.founder-body p { color: var(--bs-text-muted); line-height: 1.75; font-size: 1.0625rem; margin: 0 0 1.25rem; max-width: 44rem; }
.founder-contact { margin-top: 1.75rem; }

/* ---------- Kontakt — CF7 styling alignment ---------- */
.k-form .wpcf7 p { margin: 0 0 1.5rem; }
.k-form .wpcf7-form-control-wrap { display: block; }
.k-form input[type="text"],
.k-form input[type="email"],
.k-form input[type="tel"],
.k-form input[type="url"],
.k-form input[type="number"],
.k-form select,
.k-form textarea {
  width: 100%; background: var(--bs-bg-base); border: 1px solid var(--bs-border-subtle);
  border-radius: .5rem; padding: .875rem 1rem; color: #fff;
  font-family: inherit; font-size: 1rem; transition: border-color .2s;
}
.k-form input:focus,
.k-form select:focus,
.k-form textarea:focus { outline: none; border-color: var(--bs-accent); }
.k-form textarea { min-height: 9rem; resize: vertical; }
.k-form .wpcf7-submit,
.k-form input[type="submit"] {
  display: inline-flex; align-items: center; gap: .75rem;
  padding: 1rem 2rem;
  font-family: var(--bs-font-heading); font-weight: 900;
  font-size: 1rem; letter-spacing: .1em;
  border-radius: .5rem;
  background: var(--bs-accent); color: #000; border: none; cursor: pointer;
  width: 100%; justify-content: center;
  transition: background .2s;
}
.k-form .wpcf7-submit:hover,
.k-form input[type="submit"]:hover { background: var(--bs-accent-hover); }
.k-form .wpcf7-not-valid-tip { color: #ff6b6b; font-size: .8rem; margin-top: .25rem; display: block; }
.k-form .wpcf7-response-output {
  margin: 1.5rem 0 0; padding: 1rem 1.25rem; border-radius: .5rem;
  background: var(--bs-bg-base); border-left: 3px solid var(--bs-accent);
  color: var(--bs-text-secondary);
}
.k-hero { padding: 9rem 0 4rem; position: relative; overflow: hidden; }
.k-grid { display: grid; gap: 4rem; grid-template-columns: 1fr; padding: 3rem 0 7rem; }
@media (min-width: 1024px) { .k-grid { grid-template-columns: 5fr 4fr; } }
.k-form { background: var(--bs-bg-subtle); border: 1px solid var(--bs-border-subtle); border-radius: 1rem; padding: 2.5rem; }
.k-form .row { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .k-form .row { grid-template-columns: 1fr 1fr; } }
.k-form label { display: block; font-family: var(--bs-font-heading); font-weight: 900; font-size: .75rem; letter-spacing: .2em; text-transform: uppercase; color: var(--bs-accent); margin-bottom: .5rem; }
.k-form input, .k-form select, .k-form textarea {
  width: 100%; background: var(--bs-bg-base); border: 1px solid var(--bs-border-subtle);
  border-radius: .5rem; padding: .875rem 1rem; color: #fff;
  font-family: inherit; font-size: 1rem; transition: border-color .2s;
}
.k-form input:focus, .k-form select:focus, .k-form textarea:focus { outline: none; border-color: var(--bs-accent); }
.k-form textarea { min-height: 9rem; resize: vertical; }
.k-form .field { margin-bottom: 1.5rem; }
.info-card { padding: 2rem; background: var(--bs-bg-subtle); border: 1px solid var(--bs-border-subtle); border-radius: 1rem; }
.info-card h4 { font-family: var(--bs-font-heading); font-weight: 900; font-size: .875rem; letter-spacing: .25em; color: var(--bs-accent); text-transform: uppercase; margin: 0 0 1rem; }
.info-card p { color: var(--bs-text-secondary); line-height: 1.7; margin: 0 0 .5rem; font-size: .95rem; }
.info-card a { color: #fff; font-weight: 700; }
.info-card a:hover { color: var(--bs-accent); }

/* ---------- Referenzen archive ---------- */
.r-hero { padding: 9rem 0 4rem; position: relative; overflow: hidden; }
.r-filter { display: flex; gap: .5rem; flex-wrap: wrap; padding: 2rem 0; }
.r-chip { padding: .5rem 1.25rem; border: 1px solid var(--bs-border-subtle); border-radius: 999px; background: var(--bs-bg-base); font-family: var(--bs-font-heading); font-weight: 900; font-size: .75rem; letter-spacing: .15em; color: var(--bs-text-muted); text-transform: uppercase; cursor: pointer; transition: all .2s; text-decoration:none; }
.r-chip.active, .r-chip:hover { background: var(--bs-accent); color: #000; border-color: var(--bs-accent); }
.r-grid { display: grid; gap: 1.5rem; grid-template-columns: 1fr; padding: 0 0 6rem; }
@media (min-width: 768px) { .r-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .r-grid { grid-template-columns: repeat(3, 1fr); } }
.r-card { display: flex; flex-direction: column; background: var(--bs-bg-base); border: 1px solid var(--bs-bg-surface); border-radius: .75rem; overflow: hidden; transition: border-color .3s, background .3s; }
.r-card:hover { border-color: rgba(255,107,0,.4); background: #111; }
.r-img { height: 14rem; background: var(--bs-bg-subtle); position: relative; overflow: hidden; }
.r-img img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: .55; }
.r-img .cat { position: absolute; top: 1rem; left: 1rem; padding: .25rem .75rem; background: var(--bs-accent); color: #000; font-family: var(--bs-font-heading); font-weight: 900; font-size: .75rem; letter-spacing: .1em; border-radius: .375rem; }
.r-body { padding: 1.5rem; }
.r-client { color: var(--bs-text-muted); font-family: var(--bs-font-heading); font-weight: 900; font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: .5rem; }
.r-title { font-family: var(--bs-font-heading); font-weight: 900; color: #fff; font-size: 1.125rem; line-height: 1.2; margin-bottom: .75rem; transition: color .3s; }
.r-card:hover .r-title { color: var(--bs-accent); }
.r-result { color: var(--bs-accent); font-weight: 700; font-size: .875rem; }

/* ---------- Single Referenz (case study) ---------- */
.d-hero { padding: 9rem 0 3rem; }
.d-img { height: 28rem; background: var(--bs-bg-subtle); display: block; overflow: hidden; border-radius: 1rem; margin-bottom: 3rem; position: relative; }
.d-img img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: .55; }
.d-grid { display: grid; gap: 3rem; grid-template-columns: 1fr; padding: 3rem 0; }
@media (min-width: 1024px) { .d-grid { grid-template-columns: 2fr 1fr; } }
.d-section { margin-bottom: 3rem; }
.d-section h2 { font-family: var(--bs-font-heading); font-weight: 900; font-size: 1.75rem; color: #fff; margin: 0 0 1rem; letter-spacing: -.01em; }
.d-section p { color: var(--bs-text-secondary); line-height: 1.75; margin: 0 0 1rem; }
.d-meta { background: var(--bs-bg-subtle); border: 1px solid var(--bs-border-subtle); border-radius: 1rem; padding: 2rem; position: sticky; top: 6rem; }
.d-meta .row { padding: .75rem 0; border-bottom: 1px solid var(--bs-border-subtle); }
.d-meta .row:last-child { border-bottom: none; }
.d-meta .row .k { color: var(--bs-text-muted); font-family: var(--bs-font-heading); font-weight: 900; font-size: .75rem; letter-spacing: .2em; text-transform: uppercase; margin-bottom: .25rem; }
.d-meta .row .v { color: #fff; font-weight: 700; }
.results-list { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .results-list { grid-template-columns: repeat(2, 1fr); } }
.result-card { padding: 1.5rem; background: var(--bs-bg-base); border: 1px solid var(--bs-border-subtle); border-radius: .75rem; }
.result-card .v { font-family: var(--bs-font-heading); font-weight: 900; font-size: 2rem; color: var(--bs-accent); }
.result-card .l { color: var(--bs-text-secondary); font-size: .9rem; margin-top: .25rem; }
.testimonial { background: var(--bs-accent); padding: 3rem; border-radius: 1rem; color: #000; margin: 3rem 0; position: relative; }
.testimonial .quote { font-family: var(--bs-font-heading); font-weight: 900; font-size: 1.5rem; line-height: 1.3; margin: 0 0 1.5rem; letter-spacing: -.01em; }
.testimonial .author { font-weight: 900; }

/* ---------- Single Service ---------- */
.svc-hero { position: relative; padding: 10rem 0 6rem; overflow: hidden; background: var(--bs-bg-base); }
.svc-hero::after {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .04; z-index: 0;
  background-image:
    linear-gradient(#fff 1px, transparent 1px),
    linear-gradient(90deg, #fff 1px, transparent 1px);
  background-size: 80px 30px, 80px 30px;
  background-position: 0 0, 40px 15px;
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, transparent 80%);
          mask-image: linear-gradient(to bottom, #000 0%, transparent 80%);
}
.svc-hero .bg-text { font-size: 22vw; top: 50%; left: 50%; transform: translate(-50%, -50%); opacity: 0.02; }
.svc-hero-grid { display: grid; gap: 3rem; grid-template-columns: 1fr; align-items: end; position: relative; z-index: 1; }
@media (min-width: 1024px) { .svc-hero-grid { grid-template-columns: 3fr 2fr; } }
.svc-hero h1 { font-family: var(--bs-font-heading); font-weight: 900; font-size: clamp(3rem, 8vw, 7rem); line-height: 0.95; letter-spacing: -0.03em; margin: 0; }
.svc-hero .icon-tile { width: 5rem; height: 5rem; border: 1px solid var(--bs-border-subtle); background: var(--bs-bg-subtle); border-radius: 1rem; display: flex; align-items: center; justify-content: center; color: var(--bs-accent); margin-bottom: 1.5rem; }
.svc-hero .icon-tile svg { width: 40px; height: 40px; }
.features-grid { display: grid; gap: 1.25rem; grid-template-columns: 1fr; padding: 5rem 0; }
@media (min-width: 768px) { .features-grid { grid-template-columns: repeat(2, 1fr); } }
.feature-card { padding: 2.5rem; border: 1px solid var(--bs-border-subtle); border-radius: 1rem; background: var(--bs-bg-subtle); transition: border-color .3s, background .3s; }
.feature-card:hover { border-color: var(--bs-accent); background: #111; }
.feature-card .num { font-family: var(--bs-font-heading); color: var(--bs-accent); font-size: 1rem; letter-spacing: .25em; }
.feature-card h3 { font-family: var(--bs-font-heading); font-weight: 900; font-size: 1.75rem; color: #fff; margin: 1rem 0; letter-spacing: -0.01em; }
.feature-card p { color: var(--bs-text-muted); line-height: 1.7; margin: 0; }

.stats-row { display: grid; grid-template-columns: 1fr; gap: 1rem; padding: 4rem 0; }
@media (min-width: 768px) { .stats-row { grid-template-columns: repeat(3, 1fr); } }
.big-stat { padding: 3rem 2rem; border: 1px solid var(--bs-border-subtle); border-radius: 1rem; background: var(--bs-bg-base); text-align: center; }
.big-stat .v { font-family: var(--bs-font-heading); font-size: clamp(3rem, 5vw, 4.5rem); color: var(--bs-accent); line-height: 1; }
.big-stat .l { color: var(--bs-text-muted); font-family: var(--bs-font-heading); font-weight: 900; font-size: .875rem; letter-spacing: .25em; text-transform: uppercase; margin-top: 1rem; }

.svc-cta { background: var(--bs-accent); border-radius: 1.25rem; padding: 4rem 2rem; margin: 4rem 0 7rem; text-align: center; position: relative; overflow: hidden; }
.svc-cta h2 { font-family: var(--bs-font-heading); font-weight: 900; font-size: clamp(2.5rem, 5vw, 4rem); color: #000; line-height: 1; margin: 0 0 1rem; letter-spacing: -.02em; }
.svc-cta p { color: rgba(0,0,0,.7); font-weight: 700; margin: 0 0 2rem; }

.pricing-section { padding: 5rem 0 7rem; background: var(--bs-bg-base); }
.pricing-head { text-align: center; margin-bottom: 3.5rem; }
.pricing-grid { display: grid; gap: 1.5rem; grid-template-columns: 1fr; align-items: stretch; max-width: 76rem; margin: 0 auto; }
@media (min-width: 768px) { .pricing-grid { grid-template-columns: repeat(3, 1fr); } }
.price-card { position: relative; display: flex; flex-direction: column; background: var(--bs-bg-subtle); border: 1px solid var(--bs-border-subtle); border-radius: 1rem; padding: 2.25rem 2rem 2.5rem; transition: border-color .3s, transform .3s; }
.price-card:hover { border-color: var(--bs-accent); transform: translateY(-4px); }
.price-card.featured { background: #111; border: 2px solid var(--bs-accent); box-shadow: 0 24px 60px rgba(255, 107, 0, .15); }
.price-card .ribbon { position: absolute; top: -.85rem; left: 50%; transform: translateX(-50%); background: var(--bs-accent); color: #000; font-family: var(--bs-font-heading); font-weight: 900; font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; padding: .35rem .85rem; border-radius: 999px; }
.price-card h3 { font-family: var(--bs-font-heading); font-weight: 900; font-size: 1.5rem; color: #fff; letter-spacing: -.01em; margin: 0 0 .25rem; }
.price-card .desc { color: var(--bs-text-muted); font-size: .9rem; margin: 0 0 1.5rem; line-height: 1.55; }
.price-card .price { font-family: var(--bs-font-heading); font-weight: 900; font-size: 2.25rem; color: var(--bs-accent); line-height: 1; letter-spacing: -.02em; margin-bottom: .35rem; }
.price-card .price-note { color: var(--bs-text-muted); font-size: .75rem; font-weight: 700; letter-spacing: .08em; margin-bottom: 1.75rem; text-transform: uppercase; }
.price-card ul { list-style: none; padding: 0; margin: 0 0 2rem; display: flex; flex-direction: column; gap: .75rem; flex: 1; }
.price-card ul li { display: flex; align-items: flex-start; gap: .75rem; color: var(--bs-text-secondary); font-size: .9rem; line-height: 1.5; }
.price-card ul li::before { content: ""; flex-shrink: 0; margin-top: .45rem; width: 8px; height: 8px; background: var(--bs-accent); transform: rotate(45deg); }
.price-card .price-cta { display: inline-flex; align-items: center; justify-content: center; gap: .75rem; padding: 1rem 1.25rem; font-family: var(--bs-font-heading); font-weight: 900; font-size: .9rem; letter-spacing: .15em; border-radius: .625rem; background: var(--bs-bg-base); border: 1px solid var(--bs-border-subtle); color: #fff; transition: all .25s; text-decoration:none; }
.price-card .price-cta:hover { background: var(--bs-accent); border-color: var(--bs-accent); color: #000; }
.price-card.featured .price-cta { background: var(--bs-accent); border-color: var(--bs-accent); color: #000; }
.price-card.featured .price-cta:hover { background: var(--bs-accent-hover); }
.pricing-note { text-align: center; margin-top: 2.5rem; color: var(--bs-text-muted); font-size: .85rem; font-weight: 700; }
.pricing-note .star { color: var(--bs-accent); margin-right: .35rem; }

/* ---------- BigKnowledge ---------- */
.b-hero { padding: 9rem 0 4rem; position: relative; overflow: hidden; }
.b-feature {
  display: grid; gap: 2rem; grid-template-columns: 1fr;
  background: var(--bs-bg-subtle); border: 1px solid var(--bs-border-subtle); border-radius: 1rem;
  padding: 2.5rem; margin-bottom: 3rem; align-items: center;
  transition: border-color .3s;
  text-decoration: none;
}
.b-feature:hover { border-color: var(--bs-accent); }
@media (min-width: 768px) { .b-feature { grid-template-columns: 1fr 1.2fr; gap: 3rem; } }
.b-feature-img { height: 16rem; background: var(--bs-bg-subtle); border-radius: .75rem; overflow: hidden; position: relative; }
.b-feature-img img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: .55; }
.b-feature .meta { color: var(--bs-accent); font-family: var(--bs-font-heading); font-weight: 900; font-size: .75rem; letter-spacing: .25em; }
.b-feature h2 { font-family: var(--bs-font-heading); font-weight: 900; font-size: 2rem; color: #fff; margin: .75rem 0; letter-spacing: -.01em; line-height: 1.1; }
.b-feature p { color: var(--bs-text-muted); line-height: 1.65; }

.b-grid { display: grid; gap: 1.5rem; grid-template-columns: 1fr; padding-bottom: 6rem; }
@media (min-width: 768px) { .b-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .b-grid { grid-template-columns: repeat(3, 1fr); } }
.b-card { background: var(--bs-bg-base); border: 1px solid var(--bs-border-subtle); border-radius: 1rem; overflow: hidden; transition: border-color .3s; text-decoration: none; display:block; }
.b-card:hover { border-color: var(--bs-accent); }
.b-card-img { height: 12rem; background: var(--bs-bg-subtle); position: relative; overflow: hidden; }
.b-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: .55; }
.b-card-img .tag { position: absolute; top: 1rem; left: 1rem; padding: .25rem .75rem; background: var(--bs-accent); color: #000; font-family: var(--bs-font-heading); font-weight: 900; font-size: .65rem; letter-spacing: .15em; border-radius: .375rem; }
.b-card-body { padding: 1.5rem; }
.b-card-meta { color: var(--bs-text-muted); font-family: var(--bs-font-heading); font-weight: 900; font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; margin-bottom: .5rem; }
.b-card-title { font-family: var(--bs-font-heading); font-weight: 900; color: #fff; font-size: 1.125rem; line-height: 1.2; margin-bottom: .75rem; transition: color .3s; }
.b-card:hover .b-card-title { color: var(--bs-accent); }

/* Kategorie-Filter (Blog) */
.b-filter { display: flex; flex-wrap: wrap; gap: .6rem; margin: 2.5rem 0 1.5rem; }
.b-chip {
  font-family: var(--bs-font-heading); font-weight: 900;
  font-size: .7rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--bs-text-muted); background: var(--bs-bg-subtle);
  border: 1px solid var(--bs-border-subtle); border-radius: 2rem;
  padding: .55rem 1.1rem; cursor: pointer; transition: all .2s; text-decoration: none;
}
.b-chip:hover { color: var(--bs-text-secondary); border-color: var(--bs-text-muted); }
.b-chip.active { background: var(--bs-accent); border-color: var(--bs-accent); color: #000; }

/* Search form / pagination */
.screen-reader-text { position: absolute; clip: rect(1px,1px,1px,1px); overflow: hidden; height: 1px; width: 1px; word-wrap: normal; }
.pagination, .nav-links { display:flex; gap:.5rem; flex-wrap:wrap; justify-content:center; }
.pagination .page-numbers, .nav-links .page-numbers { padding:.5rem 1rem; border:1px solid var(--bs-border-subtle); border-radius:.5rem; color: var(--bs-text-muted); font-weight:700; font-family:var(--bs-font-heading); }
.pagination .page-numbers.current { background: var(--bs-accent); color:#000; border-color:var(--bs-accent); }

/* WP-Prose: long-form pages and posts */
.bs-prose h1, .bs-prose h2, .bs-prose h3 { font-family: var(--bs-font-heading); color:#fff; letter-spacing:-.01em; }
.bs-prose h2 { font-size: 1.875rem; margin: 2.5rem 0 1rem; }
.bs-prose h3 { font-size: 1.375rem; margin: 2rem 0 .75rem; }
.bs-prose p, .bs-prose ul, .bs-prose ol { color: var(--bs-text-secondary); line-height: 1.75; margin: 0 0 1.25rem; }
.bs-prose a { color: var(--bs-accent); text-decoration: underline; }
.bs-prose blockquote { border-left: 3px solid var(--bs-accent); padding-left: 1.25rem; color: var(--bs-text-secondary); font-style: italic; margin: 1.5rem 0; }
.bs-prose code { background: var(--bs-bg-subtle); padding: .15rem .4rem; border-radius: .25rem; font-family: 'Courier New', monospace; font-size: .9em; color: var(--bs-accent); }
.bs-prose pre { background: var(--bs-bg-subtle); padding: 1.25rem; border-radius: .5rem; overflow-x: auto; border: 1px solid var(--bs-border-subtle); }
.bs-prose img { border-radius: .5rem; }

/* ── SEO-Content-Block (Service-Seiten) ── */
.seo-block { padding: 5.5rem 0; background: var(--bs-bg-base); border-top: 1px solid var(--bs-border-subtle); }
.seo-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: center; }
@media (min-width: 900px) { .seo-grid { grid-template-columns: 1fr 1fr; gap: 4.5rem; } .seo-grid.flip .seo-illu { order: 2; } }
.seo-illu {
  background: radial-gradient(120% 120% at 30% 20%, rgba(255,107,0,0.06), transparent 60%), var(--bs-bg-subtle);
  border: 1px solid var(--bs-border-subtle); border-radius: 1.25rem; padding: 1.75rem;
}
.seo-illu img { width: 100%; height: auto; display: block; }
.seo-text h2 {
  font-family: var(--bs-font-heading); font-weight: 900;
  font-size: clamp(1.75rem, 3.4vw, 2.6rem); color: #fff; line-height: 1.04;
  letter-spacing: -.02em; margin: 0 0 1.25rem;
}
.seo-text h2 .accent { color: var(--bs-accent); }
.seo-text p { color: var(--bs-text-muted); line-height: 1.8; font-size: 1.0625rem; margin: 0 0 1.1rem; max-width: 44rem; }
.seo-text .btn { margin-top: 1rem; }

/* ── FAQ-Section (Service-Seiten) ── */
.faq-block { padding: 5.5rem 0; background: var(--bs-bg-subtle); border-top: 1px solid var(--bs-border-subtle); }
.faq-block .faq-list { max-width: 52rem; margin: 2.5rem auto 0; display: flex; flex-direction: column; gap: .85rem; }
.faq-block .faq-item { border: 1px solid var(--bs-border-subtle); border-radius: .9rem; background: var(--bs-bg-base); overflow: hidden; transition: border-color .2s, box-shadow .2s; }
.faq-block .faq-item[open] { border-color: var(--bs-accent); box-shadow: 0 10px 30px -18px rgba(255,107,0,.6); }
.faq-block .faq-item summary {
  list-style: none; cursor: pointer; padding: 1.2rem 1.5rem;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  font-family: var(--bs-font-heading); font-weight: 900; font-size: 1.05rem; color: #fff;
}
.faq-block .faq-item summary::-webkit-details-marker { display: none; }
.faq-block .faq-item summary::after { content: "+"; flex: 0 0 auto; font-size: 1.6rem; line-height: 1; color: var(--bs-accent); transition: transform .25s; }
.faq-block .faq-item[open] summary::after { transform: rotate(45deg); }
.faq-block .faq-item .faq-a { padding: 0 1.5rem 1.4rem; color: var(--bs-text-muted); line-height: 1.75; font-size: 1rem; }

/* ── Produkte (CPT) ── */
.produkt-grid { display: grid; grid-template-columns: 1fr; gap: 1.75rem; margin-top: 1rem; }
@media (min-width: 640px) { .produkt-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .produkt-grid { grid-template-columns: repeat(3, 1fr); } }
.produkt-card { display: flex; flex-direction: column; background: var(--bs-bg-subtle); border: 1px solid var(--bs-border-subtle); border-radius: 1.1rem; overflow: hidden; transition: border-color .25s, transform .25s, box-shadow .25s; }
.produkt-card:hover { border-color: var(--bs-accent); transform: translateY(-4px); box-shadow: 0 18px 40px -24px rgba(255,107,0,.6); }
.produkt-card-top { position: relative; aspect-ratio: 16 / 10; background: radial-gradient(120% 120% at 30% 10%, rgba(255,107,0,0.08), transparent 60%), var(--bs-bg-base); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.produkt-card-top .produkt-illu, .produkt-card-top img { width: 78%; height: 78%; object-fit: contain; display: block; }
.produkt-badge { position: absolute; top: 1rem; left: 1rem; z-index: 2; padding: .3rem .8rem; background: var(--bs-accent); color: #000; font-family: var(--bs-font-heading); font-weight: 900; font-size: .68rem; letter-spacing: .12em; border-radius: .4rem; }
.produkt-card-body { padding: 1.5rem; display: flex; flex-direction: column; flex: 1; }
.produkt-card-body h3 { font-family: var(--bs-font-heading); font-weight: 900; font-size: 1.5rem; color: #fff; margin: 0 0 .5rem; letter-spacing: -.01em; }
.produkt-tagline { color: var(--bs-text-muted); line-height: 1.6; font-size: .95rem; margin: 0 0 1.25rem; }
.produkt-card-foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.produkt-price { color: var(--bs-text-secondary); font-family: var(--bs-font-heading); font-weight: 900; font-size: .9rem; }
.produkt-more { color: var(--bs-accent); font-family: var(--bs-font-heading); font-weight: 900; font-size: .72rem; letter-spacing: .12em; }

/* ── Blog-Funnel-CTA (am Artikelende) ── */
.article-cta { margin: 3.5rem 0; background: linear-gradient(160deg, rgba(255,107,0,.12), var(--bs-bg-subtle)); border: 1px solid var(--bs-accent); border-radius: 1.25rem; padding: 2.25rem; }
.article-cta-tag { font-family: var(--bs-font-graffiti); color: var(--bs-accent); font-size: 1.15rem; transform: rotate(var(--bs-graffiti-angle)); display: inline-block; margin-bottom: .5rem; }
.article-cta h3 { font-family: var(--bs-font-heading); font-weight: 900; font-size: clamp(1.5rem,3vw,2rem); color: #fff; line-height: 1.05; letter-spacing: -.02em; margin: 0 0 .75rem; }
.article-cta p { color: var(--bs-text-secondary); line-height: 1.6; margin: 0 0 1.5rem; }
.article-cta-row { display: flex; gap: .85rem; flex-wrap: wrap; }

/* ── Gratis-Guide (Lead-Magnet Danke-Seite) ── */
#guide-main .g-wrap { max-width: 52rem; margin: 0 auto; padding: 4rem 1.5rem 6rem; }
.g-thanks { text-align: center; border-bottom: 2px solid var(--bs-accent); padding-bottom: 2.5rem; margin-bottom: 2.5rem; }
.g-check-badge { width: 3.5rem; height: 3.5rem; margin: 0 auto 1.25rem; border-radius: 50%; background: var(--bs-accent); color: #000; font-size: 2rem; font-weight: 900; display: flex; align-items: center; justify-content: center; }
.g-kicker { font-family: var(--bs-font-graffiti); color: var(--bs-accent); font-size: 1.3rem; display: inline-block; }
.g-h1 { font-family: var(--bs-font-heading); font-weight: 900; font-size: clamp(2.25rem, 6vw, 3.5rem); line-height: .98; letter-spacing: -.02em; color: #fff; margin: .75rem 0 1rem; }
.g-h1 .accent { color: var(--bs-accent); }
.g-intro { color: var(--bs-text-secondary); font-size: 1.0625rem; line-height: 1.7; max-width: 40rem; margin: 0 auto 1.75rem; }
.g-block { margin: 2.5rem 0; }
.g-block h2 { font-family: var(--bs-font-heading); font-weight: 900; font-size: 1.5rem; color: #fff; letter-spacing: -.01em; margin: 0 0 1rem; display: flex; align-items: baseline; gap: .75rem; }
.g-block h2 .n { color: var(--bs-accent); font-size: 1rem; font-family: 'Courier New', monospace; }
.g-check { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .7rem; }
.g-check li { position: relative; padding-left: 2rem; color: var(--bs-text-secondary); line-height: 1.5; }
.g-check li::before { content: ""; position: absolute; left: 0; top: .15em; width: 1.3rem; height: 1.3rem; border: 2px solid var(--bs-accent); border-radius: .3rem; }
.g-cta { margin-top: 3.5rem; background: linear-gradient(150deg, var(--bs-accent), var(--bs-accent-dark)); border-radius: 1.25rem; padding: 2.5rem; text-align: center; }
.g-cta h3 { font-family: var(--bs-font-heading); font-weight: 900; font-size: clamp(1.75rem,4vw,2.5rem); color: #000; line-height: 1; margin: 0 0 .75rem; }
.g-cta p { color: rgba(0,0,0,.8); font-weight: 700; margin: 0 0 1.5rem; }
@media print { body { background: #fff; } bs-nav, bs-footer, .g-thanks .btn { display: none !important; } .g-h1, .g-block h2, .g-check li { color: #000; } .g-intro, .g-check li { color: #222; } }

/* Kleine Kategorie-Tags / Badges auf Karten – Graffiti-Schrift (wie die Über-Überschriften) */
.b-card-img .tag, .r-img .cat, .r-card .cat, .produkt-badge, .b-feature .meta,
.b-chip, .r-chip {
  font-family: var(--bs-font-graffiti) !important; font-weight: 400 !important; letter-spacing: .03em !important;
}
