/* Cards/Gitter */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:34px 0}
.card{background:rgba(255,255,255,.88);border:1px solid var(--line);border-radius:8px;padding:20px;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.product{background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 1px 0 rgba(0,0,0,.03);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}
.product:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(46,125,50,.22)}
.product img{width:100%;height:164px;object-fit:contain;object-position:center bottom;background:radial-gradient(circle at 50% 78%,rgba(167,201,87,.18),rgba(255,255,255,0) 54%),linear-gradient(180deg,#fff,#fbfdf8);padding:12px 14px 0;cursor:zoom-in}
.product .meta{padding:13px 14px 14px;border-top:1px solid rgba(20,36,29,.06)}
.product .meta strong{font-size:15px}
.product .meta small{color:var(--muted);font-weight:600}
.page-actions,.about-actions{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 28px}

/* Galerie/Carousel */
.gallery{padding:34px 0}
.carousel{position:relative;overflow:hidden;border-radius:8px;background:#fff;border:1px solid var(--line);max-width:980px;margin:0 auto;box-shadow:var(--shadow)}
.carousel .track{display:flex;scroll-behavior:smooth;transition:transform .28s ease}
.carousel .slide{flex:0 0 100%;min-width:100%;height:clamp(380px,44vw,540px);background:radial-gradient(circle at 50% 72%,rgba(167,201,87,.22),rgba(255,255,255,0) 50%),#fff;position:relative}
.slide img{position:absolute;inset:36px 90px 64px;width:calc(100% - 180px);height:calc(100% - 100px);object-fit:contain;object-position:center}
.ctrl{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.92);border:1px solid var(--line);width:40px;height:40px;border-radius:50%;display:grid;place-items:center;cursor:pointer}
.ctrl:hover{box-shadow:var(--ring)}
.ctrl.prev{left:10px}.ctrl.next{right:10px}
.slide figcaption{
  position:absolute;left:12px;bottom:12px;
  background:rgba(20,36,29,.78);color:#fff;
  padding:7px 11px;border-radius:8px;font-weight:700;font-size:14px
}

/* Fokusbild / persönlicher Ablauf */
.focus-story{
  padding:42px 0 28px;
}

.focus-grid{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:28px;
  align-items:center;
}

.focus-copy{
  max-width:440px;
}

.eyebrow{
  color:var(--g);
  font-size:13px;
  font-weight:800;
  letter-spacing:.08em;
  margin:0 0 8px;
  text-transform:uppercase;
}

.focus-copy h2{
  font-size:clamp(28px,3.4vw,44px);
  line-height:1.06;
  margin:0 0 12px;
}

.focus-copy p:not(.eyebrow){
  color:#314239;
  margin:0 0 18px;
}

.focus-frame{
  position:relative;
  min-height:clamp(330px,38vw,500px);
  border-radius:8px;
  overflow:hidden;
  background:#102018;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.focus-frame::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(20,36,29,.36),rgba(20,36,29,.03) 48%,rgba(20,36,29,.18));
  pointer-events:none;
}

.focus-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  animation:focusDrift 14s ease-in-out infinite alternate;
  transform:scale(1.04);
}

@keyframes focusDrift{
  from{transform:scale(1.04) translate3d(-1.5%,0,0)}
  to{transform:scale(1.12) translate3d(1.5%,-1.5%,0)}
}

/* Lightbox */
.lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.82);
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  z-index:9999;
}
.lightbox.open{display:flex}
.lightbox img{
  max-width:90vw;
  max-height:86vh;
  background:#fff;
  padding:12px;
  border-radius:8px;
}
.lightbox-close{
  position:absolute;
  top:18px;
  right:24px;
  width:44px;
  height:44px;
  border:0;
  border-radius:50%;
  background:#fff;
  color:var(--ink);
  font-size:30px;
  line-height:1;
  cursor:pointer;
}
.lightbox-close:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(255,255,255,.45)}

/* FAQ */
.accordion{border:1px solid rgba(0,0,0,.08);border-radius:12px;background:#fff;overflow:hidden}
.acc-item{border-top:1px solid rgba(0,0,0,.06)}
.acc-item:first-child{border-top:0}
.acc-q{display:flex;justify-content:space-between;gap:10px;padding:14px 16px;cursor:pointer;font-weight:700}
.acc-a{display:none;padding:0 16px 14px;color:var(--muted)}
.acc-item.open .acc-a{display:block}

/* CTA */
.cta{background:linear-gradient(180deg,#fff,rgba(246,249,243,.86));padding:56px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center}

/* --- Produkte: Info-Karten (Hanf / Matte) --- */
.info-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin: 18px 0 26px;
}

.info-card {
  background: rgba(255,255,255,.94);
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 170px 1fr;
  gap: 16px;
  align-items: center;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}

.info-card img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background:linear-gradient(180deg,#fff,#f8fbf4);
  min-height: 150px;
  padding:10px;
}

.info-card .info-text {
  padding: 14px 14px 14px 0;
}

.info-card .info-text strong {
  display: block;
  margin-bottom: 6px;
  font-size:15px;
}
.info-card .info-text small{color:#34443b;font-weight:500;line-height:1.75}

/* Info-Card: zwei Bilder nebeneinander (roh + fertig) */
.info-media.two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 12px;
  align-self: stretch;
}

.info-media.two img {
  width: 100%;
  height: 100%;
  min-height: 170px;
  object-fit: cover;
  border-radius: 8px;
  cursor: zoom-in;
}

@media (max-width: 900px) {
  .info-grid { grid-template-columns: 1fr; }
  .info-card { grid-template-columns: 1fr; }
  .info-card .info-text { padding: 14px; }
}

/* ✅ Seitenzähler Button */
.counter-section {
  padding: 18px 0 4px;
  text-align: center;
}
.counter-btn {
  background: var(--paper);
  border: 2px solid var(--g);
  color: var(--ink);
  padding: 10px 18px;
  font-weight: 700;
  border-radius: 999px;
  cursor: default;
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease;
}
.counter-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,.08);
}

/* Responsive (Komponenten) */
@media (max-width:1024px){
  .grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .features{grid-template-columns:1fr}
  .focus-grid{grid-template-columns:1fr}
  .focus-copy{max-width:680px}
}
@media (max-width:640px){
  .grid{grid-template-columns:1fr}
  .product img{height:220px}
  .carousel .slide{height:360px}
  .slide img{inset:28px 46px 62px;width:calc(100% - 92px);height:calc(100% - 90px)}
  .page-actions,.about-actions{flex-direction:column}
  .page-actions .btn,.about-actions .btn{text-align:center}
  .info-media.two{grid-template-columns:1fr}
  .focus-story{padding:28px 0 18px}
  .focus-frame{min-height:320px}
}
/* Footer Counter in einer Zeile */
.footer-grid {
  align-items: center;
}

.footer-visit {
  display: flex;
  justify-content: flex-end;
}

.counter-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.85);
  border: 2px solid var(--g);
  color: var(--ink);
  border-radius: 999px;
  padding: 6px 12px;      /* kleiner */
  font-weight: 700;
  font-size: 13px;         /* kleiner */
  line-height: 1;
  box-shadow: 0 6px 16px rgba(0,0,0,.10);
  white-space: nowrap;
}

/* Responsive: auf kleineren Screens darf es nach unten umbrechen */
@media (max-width: 820px) {
  .footer-visit {
    justify-content: flex-start;
  }
}
/* --- Footer: Desktop sauber in 1 Zeile (überschreibt base.css) --- */
@media (min-width: 821px) {
  .site-footer .footer-grid{
    display: grid !important;
    grid-template-columns: 1fr auto auto auto !important; /* 4 Spalten */
    gap: 16px !important;
    align-items: center !important;
  }

  .site-footer .footer-grid nav{
    display: flex;
    gap: 16px;
    align-items: center;
    justify-content: flex-end;
  }

  .site-footer .copy{
    align-self: center;
    white-space: nowrap;
  }

  .site-footer .footer-visit{
    align-self: center;            /* <- das verhindert “nach unten versetzt” */
    display: flex;
    justify-content: flex-end;
  }
}
/* --- Footer Mobile: schöner, kompakt, sauber zentriert --- */
@media (max-width: 820px) {
  .site-footer .footer-grid{
    grid-template-columns: 1fr !important;
    text-align: center;
    gap: 8px !important;
  }

  .site-footer .footer-grid > div:first-child{
    margin-top: 4px;
  }

  .site-footer .footer-grid nav{
    justify-content: center;
    gap: 18px;
  }

  .site-footer .copy{
    white-space: normal;
    opacity: .9;
  }

  .site-footer .footer-visit{
    justify-content: center;
    margin-top: 6px;
  }

  .site-footer .counter-pill{
    font-size: 12.5px;
    padding: 7px 12px;
    box-shadow: 0 5px 14px rgba(0,0,0,.10);
  }
}
