/*
Theme Name: Glücksmomentverleih
Theme URI: https://gluecksmomentverleih.de
Author: Glücksmomentverleih
Author URI: https://gluecksmomentverleih.de
Description: Maßgeschneidertes WordPress-Theme für Glücksmomentverleih — Fotobox-Verleih im Raum Karlsruhe. Inklusive Admin-Panel, SEO/GEO-Optimierung, Cal.com-Integration und vollständig editierbaren Inhalten.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: gluecksmoment
Tags: one-page, custom-logo, custom-colors, featured-images, theme-options
*/

/* ============================================
   CSS VARIABLES
   ============================================ */
:root{
  --pink:#FF2E93;
  --violet:#7A2EFF;
  --yellow:#FFD23F;
  --mint:#3EE0C8;
  --coral:#FF6B6B;
  --navy:#1A1B41;
  --cream:#FFF6E8;
  --offwhite:#FFFCF5;
  --white:#ffffff;
  --shadow:0 12px 32px rgba(26,27,65,.13);
  --shadow-lg:0 24px 60px rgba(26,27,65,.22);
  --radius:22px;
}

/* ============================================
   RESET & BASE
   ============================================ */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:'DM Sans',sans-serif;
  color:var(--navy);
  background:var(--offwhite);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Caprasimo',cursive;font-weight:400;line-height:1.05;letter-spacing:-.01em}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
section{position:relative}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:1.02rem;
  padding:16px 30px;border-radius:50px;border:3px solid var(--navy);
  cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;
  box-shadow:4px 4px 0 var(--navy);
}
.btn:hover{transform:translate(-2px,-2px) rotate(-1.5deg);box-shadow:7px 7px 0 var(--navy)}
.btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--navy)}
.btn-primary{background:var(--yellow);color:var(--navy)}
.btn-wa{background:var(--mint);color:var(--navy)}
.btn-pink{background:var(--pink);color:var(--white)}
.btn-white{background:var(--white);color:var(--navy)}
.btn-sm{padding:11px 20px;font-size:.92rem;box-shadow:3px 3px 0 var(--navy)}
.btn svg{width:18px;height:18px;flex-shrink:0}

/* ============================================
   HEADER
   ============================================ */
.site-header{
  position:sticky;top:0;z-index:90;
  background:rgba(255,252,245,.92);backdrop-filter:blur(10px);
  border-bottom:3px solid var(--navy);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{font-family:'Caprasimo',cursive;font-size:1.6rem;color:var(--pink)}
.logo .v{color:var(--navy)}
.nav-links{display:flex;gap:28px;font-weight:500;font-size:.97rem}
.nav-links a:hover{color:var(--pink)}
.nav-right{display:flex;align-items:center;gap:14px}
.icon-btn{
  width:44px;height:44px;border-radius:50%;border:2.5px solid var(--navy);
  display:grid;place-items:center;background:var(--white);transition:transform .15s;
}
.icon-btn:hover{transform:translateY(-3px) rotate(8deg)}
.icon-btn.wa{background:var(--mint)}
.icon-btn svg{width:20px;height:20px}
.menu-toggle{display:none;font-size:1.6rem;background:none;border:none;cursor:pointer}

/* ============================================
   HERO
   ============================================ */
.hero{background:linear-gradient(170deg,var(--cream) 0%,#FFE9D6 100%);padding:70px 0 90px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;position:relative;z-index:2}
.confetti-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.confetti-bg span{position:absolute;width:14px;height:14px;border-radius:3px;opacity:.85;animation:confettiFall linear infinite}
@keyframes confettiFall{0%{transform:translateY(-20px) rotate(0deg)}100%{transform:translateY(calc(100vh + 40px)) rotate(360deg)}}
.badge-pill{
  display:inline-flex;align-items:center;gap:8px;background:var(--violet);color:#fff;
  font-weight:700;font-size:.82rem;padding:8px 16px;border-radius:50px;
  border:2.5px solid var(--navy);transform:rotate(-2deg);box-shadow:3px 3px 0 var(--navy);
  text-transform:uppercase;letter-spacing:.05em;
}
.badge-pill svg{width:16px;height:16px;flex-shrink:0}
.hero h1{font-size:4rem;margin:22px 0 0}
.hero h1 .hl{color:var(--pink);position:relative;white-space:nowrap}
.hero h1 .hl svg{position:absolute;left:0;bottom:-12px;width:100%}
.hero p.sub{font-size:1.2rem;margin:26px 0 0;max-width:480px;font-weight:500}
.hero .price-tag{font-family:'Caveat',cursive;font-size:1.7rem;color:var(--violet);font-weight:700;display:inline-block;margin-top:8px;transform:rotate(-3deg)}
.hero-cta{display:flex;gap:16px;margin-top:30px;flex-wrap:wrap}
.trust-bar{
  display:flex;gap:22px;margin-top:30px;flex-wrap:wrap;
  background:var(--white);border:2.5px solid var(--navy);border-radius:16px;
  padding:14px 22px;box-shadow:var(--shadow);max-width:560px;
}
.trust-item{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.9rem}
.trust-item svg{width:22px;height:22px;flex-shrink:0}

/* Polaroid Orbit */
.polaroid-stack{position:relative;height:480px;display:flex;align-items:center;justify-content:center}
.orbit{position:relative;width:420px;height:380px}
.polaroid{
  position:absolute;background:#fff;padding:12px 12px 44px;border:2px solid var(--navy);
  box-shadow:var(--shadow-lg);width:200px;
  left:50%;top:50%;margin-left:-100px;margin-top:-145px;
  animation:orbit 24s linear infinite;
}
.polaroid .pic{height:180px;border-radius:3px;overflow:hidden}
.polaroid .pic img{width:100%;height:100%;object-fit:cover}
.polaroid .cap{font-family:'Caveat',cursive;font-size:1.2rem;font-weight:700;text-align:center;margin-top:8px;color:var(--navy)}
.p1{animation-delay:0s}
.p2{animation-delay:-4s}
.p3{animation-delay:-8s}
.p4{animation-delay:-12s}
.p5{animation-delay:-16s}
.p6{animation-delay:-20s}
@keyframes orbit{
  0%{transform:translateX(0) translateY(50px) scale(1.2) rotate(-3deg);z-index:8}
  8%{transform:translateX(120px) translateY(30px) scale(0.95) rotate(0deg);z-index:7}
  18%{transform:translateX(180px) translateY(-10px) scale(0.7) rotate(3deg);z-index:5}
  30%{transform:translateX(130px) translateY(-50px) scale(0.52) rotate(2deg);z-index:3}
  42%{transform:translateX(35px) translateY(-65px) scale(0.42) rotate(0deg);z-index:1}
  50%{transform:translateX(0) translateY(-70px) scale(0.38) rotate(0deg);z-index:1}
  58%{transform:translateX(-35px) translateY(-65px) scale(0.42) rotate(0deg);z-index:1}
  70%{transform:translateX(-130px) translateY(-50px) scale(0.52) rotate(-2deg);z-index:3}
  82%{transform:translateX(-180px) translateY(-10px) scale(0.7) rotate(-3deg);z-index:5}
  92%{transform:translateX(-120px) translateY(30px) scale(0.95) rotate(0deg);z-index:7}
  100%{transform:translateX(0) translateY(50px) scale(1.2) rotate(-3deg);z-index:8}
}

/* ============================================
   STORY SECTION
   ============================================ */
.story{padding:84px 0;background:var(--offwhite)}
.story-box{
  max-width:860px;margin:0 auto;background:var(--white);
  border:3px solid var(--navy);border-radius:var(--radius);
  padding:44px;box-shadow:var(--shadow);position:relative;
}
.story-headline{
  font-family:'Caprasimo',cursive;font-size:1.55rem;font-weight:400;
  line-height:1.2;margin-bottom:24px;white-space:nowrap;
}
.story-headline .rotate-word{
  display:inline-block;color:var(--pink);
  transition:opacity .5s ease,transform .5s ease;min-width:200px;
}
.story-headline .rotate-word.fade-out{opacity:0;transform:translateY(12px)}
.story-headline .rotate-word.fade-in{opacity:1;transform:translateY(0)}
.story-box p{font-size:1.05rem;font-weight:500}
.story-box p+p{margin-top:14px}

/* ============================================
   STEPS
   ============================================ */
.steps{padding:90px 0;background:var(--cream);perspective:800px}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{
  background:var(--white);border:3px solid var(--navy);border-radius:var(--radius);
  padding:30px 22px;text-align:center;box-shadow:var(--shadow);position:relative;
  transform-origin:top center;transform:rotateX(-90deg);opacity:0;
}
.step.drop-in{animation:boardFall .8s cubic-bezier(.22,.68,.35,1.2) forwards}
.step:nth-child(2).drop-in{animation-delay:.3s}
.step:nth-child(3).drop-in{animation-delay:.6s}
.step:nth-child(4).drop-in{animation-delay:.9s}
.step.drop-in:hover{transform:translateY(-8px) rotate(-1deg)}
@keyframes boardFall{
  0%{transform:rotateX(-90deg);opacity:0}
  40%{transform:rotateX(8deg);opacity:1}
  65%{transform:rotateX(-5deg)}80%{transform:rotateX(2deg)}
  100%{transform:rotateX(0deg);opacity:1}
}
.step .num{
  position:absolute;top:-20px;left:50%;translate:-50% 0;
  width:42px;height:42px;border-radius:50%;color:#fff;
  border:3px solid var(--navy);display:grid;place-items:center;
  font-family:'Caprasimo';font-size:1.2rem;
}
.step:nth-child(1) .num{background:var(--pink)}
.step:nth-child(2) .num{background:var(--violet)}
.step:nth-child(3) .num{background:var(--mint);color:var(--navy)}
.step:nth-child(4) .num{background:var(--yellow);color:var(--navy)}
.step .emoji{margin:10px 0 12px;display:flex;justify-content:center}
.step .emoji svg{width:64px;height:64px}
.step h3{font-size:1.3rem}
.step p{font-size:.94rem;margin-top:6px;font-weight:500}

/* ============================================
   GALLERY
   ============================================ */
.gallery{padding:90px 0;background:var(--violet);color:#fff;overflow:visible}
.gallery .sec-head h2{color:#fff}
.gallery .sec-head .kicker{color:var(--yellow)}
.gallery .sec-head p{color:#EFE7FF}
.gal-wrap{position:relative;min-height:300px;overflow:visible}
.gal-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;transition:filter .4s ease,opacity .4s ease}
.gal-grid .gal-item{width:300px}
.gal-grid.dimmed{filter:blur(12px);opacity:.3;pointer-events:none}
.gal-item{
  background:#fff;padding:10px 10px 34px;border:2px solid var(--navy);
  box-shadow:var(--shadow-lg);cursor:pointer;transition:transform .2s;
}
.gal-item:hover{transform:scale(1.04);z-index:5;position:relative}
.gal-item .pic{aspect-ratio:3/2;border-radius:2px;overflow:hidden}
.gal-item .pic img{width:100%;height:100%;object-fit:cover}
.gal-item .cap{font-family:'Caveat',cursive;font-size:1.15rem;font-weight:700;text-align:center;margin-top:8px;color:var(--navy)}
.gal-item .hint{font-size:.7rem;text-align:center;color:var(--violet);font-weight:600;margin-top:2px;opacity:.7}
.gal-item:nth-child(odd){transform:rotate(-2deg)}
.gal-item:nth-child(even){transform:rotate(2deg)}
.gal-detail{display:none;flex-direction:column;align-items:center;gap:20px;width:100%;position:absolute;top:0;left:0;right:0;z-index:10;padding-bottom:30px}
.gal-detail.active{display:flex}
.gal-detail-head{display:flex;flex-direction:column;align-items:center;width:100%;margin-bottom:12px;gap:12px}
.gal-detail-title{font-family:'Caprasimo',cursive;font-size:1.6rem;color:#fff}
.gal-back{
  background:var(--yellow);color:var(--navy);border:2px solid var(--navy);
  padding:10px 22px;border-radius:50px;font-family:'DM Sans';font-weight:700;
  font-size:.85rem;cursor:pointer;box-shadow:3px 3px 0 var(--navy);transition:transform .15s;
}
.gal-back:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--navy)}
.gal-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;width:100%;justify-items:center;animation:galFadeIn .5s ease}
@keyframes galFadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.gal-sub{background:#fff;padding:8px 8px 30px;border:2px solid var(--navy);box-shadow:var(--shadow-lg)}
.gal-sub:empty,.gal-sub .pic:empty{display:none}
.gal-sub:hover{transform:scale(1.06);z-index:5;position:relative}
.gal-sub .pic{aspect-ratio:3/2;border-radius:2px;overflow:hidden}
.gal-sub .pic img{width:100%;height:100%;object-fit:cover}
.gal-sub .cap{font-family:'Caveat',cursive;font-size:.95rem;font-weight:700;text-align:center;margin-top:5px;color:var(--navy)}
.gal-sub:nth-child(1){transform:rotate(-3deg)}
.gal-sub:nth-child(2){transform:rotate(2deg)}
.gal-sub:nth-child(3){transform:rotate(-1deg)}
.gal-sub:nth-child(4){transform:rotate(3deg)}
.gal-sub:nth-child(5){transform:rotate(-2deg)}
.gal-sub:nth-child(6){transform:rotate(1.5deg)}

/* ============================================
   SERVICES
   ============================================ */
.services{padding:90px 0;background:var(--offwhite)}
.serv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.serv{
  background:var(--white);border:3px solid var(--navy);border-radius:var(--radius);
  padding:28px 22px;box-shadow:var(--shadow);transition:transform .18s;
}
.serv:hover{transform:translateY(-8px) rotate(1deg)}
.serv .ic{
  width:64px;height:64px;border-radius:16px;display:grid;place-items:center;
  border:2.5px solid var(--navy);margin-bottom:16px;
}
.serv .ic svg{width:36px;height:36px}
.serv:nth-child(1) .ic{background:var(--yellow)}
.serv:nth-child(2) .ic{background:var(--mint)}
.serv:nth-child(3) .ic{background:var(--coral)}
.serv:nth-child(4) .ic{background:var(--violet)}
.serv h3{font-size:1.3rem;margin-bottom:6px}
.serv p{font-size:.93rem;font-weight:500}

/* ============================================
   SECTION HEADINGS
   ============================================ */
.sec-head{text-align:center;max-width:680px;margin:0 auto 50px}
.sec-head .kicker{font-family:'Caveat',cursive;font-size:1.6rem;font-weight:700;color:var(--violet);display:block;transform:rotate(-2deg)}
.sec-head h2{font-size:2.9rem;margin-top:4px}
.sec-head p{margin-top:14px;font-size:1.08rem;font-weight:500}

/* ============================================
   PRICING
   ============================================ */
.pricing{padding:90px 0;background:var(--cream)}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:start}
.plan{
  background:var(--white);border:3px solid var(--navy);border-radius:var(--radius);
  padding:34px 28px;box-shadow:var(--shadow);position:relative;
}
.plan.featured{
  background:linear-gradient(180deg,#FFF0F8,#fff);
  border-width:4px;box-shadow:var(--shadow-lg);transform:scale(1.05);z-index:2;
}
.plan .sticker{
  position:absolute;top:-22px;right:-14px;background:var(--yellow);
  border:3px solid var(--navy);border-radius:12px;padding:7px 14px;
  font-family:'Caprasimo';font-size:.9rem;transform:rotate(8deg);
  box-shadow:3px 3px 0 var(--navy);
}
.plan .plan-name{font-family:'Caprasimo';font-size:1.5rem;color:var(--pink)}
.plan.featured .plan-name{color:var(--violet)}
.plan .plan-for{font-size:.9rem;font-weight:500;color:#6b6b80;margin-top:2px;min-height:40px}
.plan .amount{font-family:'Caprasimo';font-size:3.2rem;margin:8px 0 4px}
.plan .amount span{font-size:1.1rem;color:#6b6b80}
.plan .desc{font-size:.9rem;font-weight:500;margin-bottom:6px}
.plan ul{list-style:none;margin:16px 0 24px;display:flex;flex-direction:column;gap:9px}
.plan li{font-size:.92rem;font-weight:500;display:flex;gap:9px;align-items:flex-start}
.plan li .ck{color:var(--mint);-webkit-text-stroke:.6px var(--navy);font-weight:700;flex-shrink:0}
.plan li.off{opacity:.4}
.plan li.off .ck{color:#bbb;-webkit-text-stroke:0}
.plan .btn{width:100%;justify-content:center}
.plan .micro{text-align:center;font-size:.78rem;color:#6b6b80;margin-top:10px;font-weight:500}
.addon-note{
  text-align:center;margin-top:34px;font-weight:500;font-size:.95rem;
  background:var(--white);border:2.5px dashed var(--navy);border-radius:16px;
  padding:16px 24px;max-width:720px;margin-left:auto;margin-right:auto;
}

/* ============================================
   OFFER CARDS + INLINE DETAIL
   ============================================ */
.angebote-wrap{position:relative;overflow:visible}
.angebote-grid{display:flex;flex-wrap:wrap;gap:28px;justify-content:center;transition:filter .4s,opacity .4s}
.angebote-grid .offer-card{width:340px;flex-shrink:0}
.angebote-grid.dimmed{filter:blur(12px);opacity:.25;pointer-events:none}

.offer-card{
  background:var(--white);border:3px solid var(--navy);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);cursor:pointer;
  transition:transform .2s,box-shadow .2s;position:relative;
}
.offer-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.offer-card.featured{border-color:var(--pink)}
.offer-stickers{position:absolute;top:14px;right:14px;display:flex;gap:6px;z-index:3;pointer-events:none}
.offer-sticker{font-weight:800;font-size:.78rem;padding:6px 14px;border-radius:8px;box-shadow:2px 2px 0 rgba(0,0,0,.1)}
.offer-sticker.popular{background:var(--mint);color:var(--navy)}
.offer-sticker.deal{background:var(--coral);color:#fff}
.offer-sticker.neu{background:var(--yellow);color:var(--navy)}
.offer-img{overflow:hidden;background:var(--cream)}
.offer-img img{width:100%;height:200px;object-fit:cover;display:block}
.offer-body{padding:22px}
.offer-title{font-family:'Caprasimo',cursive;font-size:1.35rem;margin-bottom:8px}
.offer-desc{font-size:.9rem;font-weight:500;color:#555;line-height:1.5;margin-bottom:0}
.offer-divider{height:2px;background:var(--cream);margin:16px 0}
.offer-footer{display:flex;align-items:center;justify-content:space-between}
.offer-price{display:flex;align-items:baseline;gap:6px}
.offer-ab{font-size:.8rem;font-weight:500;color:#999}
.offer-amount{font-family:'Caprasimo',cursive;font-size:1.6rem}
.offer-old{font-size:.95rem;font-weight:600;color:#bbb;text-decoration:line-through}
.offer-detail-btn{
  display:flex;align-items:center;gap:4px;background:none;border:none;
  font-family:'DM Sans';font-weight:700;font-size:.92rem;color:var(--navy);
  cursor:pointer;padding:8px 0;transition:color .15s;
}
.offer-detail-btn:hover{color:var(--pink)}

/* Inline Detail Overlay */
.offer-detail{display:none;position:absolute;top:0;left:0;right:0;z-index:10}
.offer-detail.active{display:block}
.offer-detail-inner{
  background:var(--white);border:3px solid var(--navy);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);overflow:hidden;animation:offerSlideIn .4s ease;
}
@keyframes offerSlideIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.offer-detail-grid{display:flex}
.offer-detail-grid.has-image .od-image{width:45%;flex-shrink:0}
.offer-detail-grid.has-image .od-info{width:55%}
.offer-detail-grid:not(.has-image) .od-info{width:100%}
.od-image{overflow:hidden}
.od-image img{width:100%;height:100%;min-height:400px;object-fit:cover;display:block}
.od-info{padding:34px}
.od-info .price-pill{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--mint);color:var(--navy);font-weight:700;font-size:.85rem;
  padding:7px 16px;border-radius:50px;border:2px solid var(--navy);
  box-shadow:2px 2px 0 var(--navy);margin-bottom:14px;
}
.od-info .od-title{font-family:'Caprasimo',cursive;font-size:2.2rem;margin-bottom:8px;line-height:1.1}
.od-short{font-size:.95rem;font-weight:500;color:#555;line-height:1.5;margin-bottom:18px}
.od-feats{display:grid;grid-template-columns:1fr 1fr;gap:8px 20px;margin-bottom:20px}
.od-feats .feat-item{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600}
.od-feats .feat-item.off{opacity:.4}
.od-feats .feat-item.off span{text-decoration:line-through}
.od-price-area{margin-bottom:14px;padding-bottom:14px;border-bottom:2px solid var(--cream)}
.od-old-row{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.od-price-area .old-price{font-size:1.3rem;font-weight:600;color:#bbb;text-decoration:line-through}
.od-price-area .discount-badge{font-size:1rem;font-weight:800;color:var(--navy);background:var(--mint);padding:2px 10px;border-radius:6px;border:1.5px solid var(--navy)}
.od-price-area .current-price{font-family:'Caprasimo',cursive;font-size:2.6rem;color:var(--pink);display:block}
.od-detail-text{font-size:.92rem;font-weight:500;color:#555;line-height:1.6;margin-bottom:18px}
.od-detail-text p{margin-bottom:10px}
.od-cta{display:flex;gap:12px;flex-wrap:wrap}

/* ============================================
   ANGEBOT DETAIL PAGE
   ============================================ */
.angebot-detail{padding:100px 0 80px;background:var(--offwhite)}
.back-link{
  display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:.92rem;
  color:var(--violet);margin-bottom:28px;transition:color .15s;
}
.back-link:hover{color:var(--pink)}
.angebot-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}

/* Image */
.angebot-image-wrap{position:sticky;top:100px}
.angebot-image{
  background:var(--white);border:3px solid var(--navy);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-lg);position:relative;
}
.angebot-image img{width:100%;display:block}
.img-sticker{
  position:absolute;top:20px;left:20px;background:var(--coral);color:#fff;
  font-family:'DM Sans';font-weight:800;font-size:.85rem;
  padding:8px 18px;border-radius:10px;box-shadow:3px 3px 0 rgba(0,0,0,.15);z-index:2;
}
.angebot-image .no-image{
  display:flex;align-items:center;justify-content:center;min-height:450px;background:var(--cream);
}

/* Price Pill */
.price-pill{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--mint);color:var(--navy);font-weight:700;font-size:.9rem;
  padding:8px 18px;border-radius:50px;border:2px solid var(--navy);
  box-shadow:2px 2px 0 var(--navy);margin-bottom:16px;
}

/* Title & Description */
.angebot-info h1{font-size:2.8rem;margin-bottom:10px;line-height:1.05}
.angebot-short{font-size:1.05rem;font-weight:500;line-height:1.6;color:#555;margin-bottom:26px}

/* Features Grid (2 columns) */
.feat-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;
  margin-bottom:28px;padding:22px;
  background:var(--white);border:2px solid var(--cream);border-radius:16px;
}
.feat-item{display:flex;align-items:center;gap:10px;font-size:.95rem;font-weight:600}
.feat-item.off{opacity:.4}
.feat-item.off span{text-decoration:line-through}

/* Price Area */
.price-area{margin-bottom:24px;padding-bottom:24px;border-bottom:2px solid var(--cream)}
.price-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.current-price{font-family:'Caprasimo',cursive;font-size:2.6rem;color:var(--pink)}
.old-price{font-size:1.2rem;font-weight:600;color:#999;text-decoration:line-through}
.discount-badge{
  background:var(--mint);color:var(--navy);font-weight:800;font-size:.82rem;
  padding:5px 14px;border-radius:8px;border:1.5px solid var(--navy);
}
.price-hint{font-size:.88rem;font-weight:500;color:#6b6b80;margin-top:6px;font-style:italic}

/* CTA Buttons */
.angebot-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.angebot-cta .btn-lg{padding:18px 36px;font-size:1.05rem}
.angebot-micro{font-size:.85rem;font-weight:500;color:#6b6b80}

/* Extended Content */
.angebot-content{
  margin-top:50px;background:var(--white);border:3px solid var(--navy);
  border-radius:var(--radius);padding:40px;box-shadow:var(--shadow);
}
.angebot-content h2{font-size:1.6rem;margin:28px 0 12px}
.angebot-content h2:first-child{margin-top:0}
.angebot-content p{margin-bottom:14px;font-size:.97rem;font-weight:500;line-height:1.7}
.angebot-content ul,.angebot-content ol{margin:0 0 14px 24px}
.angebot-content li{margin-bottom:6px;font-size:.95rem;font-weight:500}
.angebot-content img{border-radius:12px;margin:16px 0}

/* Related */
.related-products{margin-top:60px}
.related-products h2{font-family:'Caprasimo',cursive;font-size:1.8rem;margin-bottom:24px;text-align:center}

/* ============================================
   PROMOTIONS
   ============================================ */
.promos{margin-top:44px;display:none}
.promos.visible{display:block}
.promos-head{text-align:center;margin-bottom:24px}
.promos-head h3{font-family:'Caprasimo',cursive;font-size:1.7rem;color:var(--pink)}
.promos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;max-width:900px;margin:0 auto}
.promo-card{
  background:linear-gradient(135deg,#FFF0F5,#FFF8E8);
  border:3px solid var(--navy);border-radius:var(--radius);
  padding:28px 24px;position:relative;overflow:hidden;
  box-shadow:var(--shadow);transition:transform .2s;
}
.promo-card:hover{transform:translateY(-4px)}
.promo-card.hidden-promo{display:none}
.promo-badge{
  position:absolute;top:26px;right:-60px;
  background:var(--pink);color:#fff;font-weight:800;font-size:.7rem;
  padding:7px 80px;transform:rotate(40deg);letter-spacing:.1em;
  text-align:center;white-space:nowrap;box-shadow:0 2px 8px rgba(255,46,147,.3);
  min-width:220px;
}
.promo-card h4{font-family:'Caprasimo',cursive;font-size:1.2rem;margin-bottom:6px}
.promo-card .promo-desc{font-size:.92rem;font-weight:500;color:var(--navy);margin-bottom:6px}
.promo-card .promo-valid{font-size:.78rem;font-weight:600;color:var(--violet);margin-bottom:16px}
.promo-card .promo-price{display:flex;align-items:baseline;gap:10px;margin-bottom:16px}
.promo-card .old-price{font-size:1.1rem;text-decoration:line-through;color:#999;font-weight:600}
.promo-card .new-price{font-family:'Caprasimo',cursive;font-size:1.8rem;color:var(--pink)}

/* ============================================
   TESTIMONIALS
   ============================================ */
.testi{padding:90px 0;background:var(--mint);overflow:hidden}
.testi-wrap{
  --gap:20px;--duration:45s;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
}
.testi-grid{
  display:flex;gap:var(--gap);width:max-content;list-style:none;
  animation:marquee-scroll var(--duration) linear infinite;
  will-change:transform;backface-visibility:hidden;transform:translateZ(0);
}
@keyframes marquee-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(calc(-50% - var(--gap) / 2))}
}
@media(hover:hover){
  .testi-wrap:hover .testi-grid{animation-play-state:paused}
}
.testi-wrap.is-paused .testi-grid{animation-play-state:paused}
@media(prefers-reduced-motion:reduce){
  .testi-grid{animation:none;flex-wrap:wrap;justify-content:center;width:100%}
  .testi-grid>[aria-hidden="true"]{display:none}
}
.tcard{
  flex:0 0 280px;
  background:var(--white);border:2.5px solid var(--navy);border-radius:var(--radius);
  padding:18px;box-shadow:var(--shadow);
}
.tcard:nth-child(odd){transform:rotate(-1deg)}
.tcard:nth-child(even){transform:rotate(1deg)}
.tcard .stars{color:var(--yellow);-webkit-text-stroke:1px var(--navy);font-size:.95rem;letter-spacing:1.5px}
.tcard p{font-size:.85rem;font-weight:500;margin:8px 0 12px;font-style:italic;line-height:1.5}
.tcard .who{display:flex;align-items:center;gap:10px;padding-top:12px;border-top:2px solid var(--cream)}
.tcard .ava{
  width:38px;height:38px;border-radius:50%;border:2px solid var(--navy);
  display:grid;place-items:center;font-family:'Caprasimo';font-size:.95rem;
  flex-shrink:0;background:var(--cream);overflow:hidden;
}
.tcard .ava img{width:100%;height:100%;object-fit:cover}
.tcard .who b{font-size:.85rem}
.tcard .who small{display:block;font-weight:500;color:#6b6b80;font-size:.75rem}

/* ============================================
   BOOKING / CALENDAR
   ============================================ */
.booking-sec{padding:90px 0;background:var(--cream)}
.book-box{
  max-width:720px;margin:0 auto;background:var(--white);
  border:3px solid var(--navy);border-radius:var(--radius);
  padding:40px;box-shadow:var(--shadow-lg);
}
.book-box iframe{width:100%;min-height:500px;border:none;border-radius:var(--radius)}
/* Hide Cal.eu branding bar at bottom of embed */
#cal-embed,#cal-form-embed{position:relative;overflow:hidden}
#cal-embed::after,#cal-form-embed::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:80px;
  background:linear-gradient(to bottom,transparent 0%,var(--white) 40%);
  pointer-events:none;z-index:10;
}

/* ============================================
   FAQ
   ============================================ */
.faq{padding:90px 0;background:var(--offwhite)}
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{
  background:var(--white);border:3px solid var(--navy);border-radius:16px;
  overflow:hidden;box-shadow:var(--shadow);
}
.faq-q{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;
  padding:20px 24px;font-family:'DM Sans';font-weight:700;font-size:1.05rem;
  display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--navy);
}
.faq-q .plus{
  flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--yellow);
  border:2.5px solid var(--navy);display:grid;place-items:center;font-size:1.2rem;
  transition:transform .25s;
}
.faq-item.open .plus{transform:rotate(135deg);background:var(--pink);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a p,.faq-a div{padding:0 24px 22px;font-weight:500;font-size:.97rem}

/* ============================================
   CONTACT
   ============================================ */
.contact{padding:90px 0;background:linear-gradient(170deg,#FFE9D6,var(--cream))}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.form-card{
  background:var(--white);border:3px solid var(--navy);border-radius:var(--radius);
  padding:34px;box-shadow:var(--shadow-lg);
}
.form-card h3{font-size:1.7rem;margin-bottom:6px}
.form-card .lead{font-weight:500;font-size:.95rem;margin-bottom:20px}
/* Style embedded forms to match theme */
.form-card input[type="text"],.form-card input[type="email"],.form-card input[type="tel"],
.form-card input[type="date"],.form-card textarea,.form-card select,
.form-card .wpcf7-form-control,.form-card .n8n-input{
  width:100%;padding:13px 15px;border:2.5px solid var(--navy);border-radius:12px;
  font-family:'DM Sans';font-size:.95rem;background:var(--offwhite);
  margin-bottom:12px;
}
.form-card input:focus,.form-card textarea:focus,.form-card select:focus{
  outline:3px solid var(--yellow);outline-offset:1px;
}
.form-card textarea{resize:vertical;min-height:90px}
.form-card label{display:block;font-weight:700;font-size:.85rem;margin-bottom:5px}
.form-card button[type="submit"],.form-card input[type="submit"],.form-card .wpcf7-submit{
  display:flex;align-items:center;justify-content:center;gap:9px;width:100%;
  font-family:'DM Sans';font-weight:700;font-size:1.02rem;
  padding:16px 30px;border-radius:50px;border:3px solid var(--navy);
  background:var(--pink);color:#fff;cursor:pointer;
  box-shadow:4px 4px 0 var(--navy);transition:transform .15s;
}
.form-card button[type="submit"]:hover,.form-card input[type="submit"]:hover{
  transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--navy);
}
.consent{display:flex;gap:9px;align-items:flex-start;font-size:.8rem;font-weight:500;margin-bottom:16px}
.consent input{margin-top:3px;width:17px;height:17px;flex-shrink:0}
/* n8n Form Embed */
.n8n-form-embed{width:100%;min-height:600px;border:none;border-radius:var(--radius)}
.alt-paths{display:flex;flex-direction:column;gap:14px}
.alt-card{
  background:var(--white);border:3px solid var(--navy);border-radius:18px;
  padding:18px 22px;box-shadow:var(--shadow);display:flex;align-items:center;gap:16px;
  transition:transform .15s;
}
.alt-card:hover{transform:translateX(6px) rotate(-1deg)}
.alt-card .ic{
  width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  border:2.5px solid var(--navy);flex-shrink:0;
}
.alt-card .ic svg{width:26px;height:26px}
.alt-card.wa .ic{background:var(--mint)}
.alt-card.call .ic{background:var(--yellow)}
.alt-card.mail .ic{background:var(--coral)}
.alt-card b{font-size:1.02rem}
.alt-card small{display:block;font-weight:500;color:#6b6b80;font-size:.85rem}
.owner{
  background:var(--violet);color:#fff;border:3px solid var(--navy);border-radius:18px;
  padding:22px;box-shadow:var(--shadow);display:flex;gap:16px;align-items:center;margin-top:14px;
}
.owner .face{width:80px;height:80px;border-radius:50%;border:3px solid var(--navy);flex-shrink:0;overflow:hidden}
.owner .face img{width:100%;height:100%;object-fit:cover}
.owner p{font-size:.9rem;font-weight:500}
.owner .sig{font-family:'Caveat',cursive;font-size:1.4rem;font-weight:700;color:var(--yellow);margin-top:4px}

/* ============================================
   CLOSING CTA
   ============================================ */
.mini-cta{background:var(--pink);color:#fff;padding:70px 0;text-align:center}
.mini-cta h2{font-size:3rem}
.mini-cta p{font-weight:500;font-size:1.1rem;margin:12px 0 28px}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{background:var(--navy);color:#fff;padding:54px 0 110px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px}
.foot-logo{font-family:'Caprasimo';font-size:1.5rem;color:#fff}
.foot-logo .dot{color:var(--yellow)}
.site-footer p{font-size:.9rem;color:#B9B9D0;margin-top:10px;font-weight:500}
.site-footer h4{font-family:'DM Sans';font-weight:700;font-size:.95rem;margin-bottom:12px;text-transform:uppercase;letter-spacing:.06em}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.site-footer ul a{font-size:.88rem;color:#B9B9D0;font-weight:500}
.site-footer ul a:hover{color:var(--yellow)}
.foot-bottom{border-top:1px solid #33345f;margin-top:36px;padding-top:20px;font-size:.82rem;color:#8c8db0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ============================================
   MOBILE BAR
   ============================================ */
.mobile-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:95;
  background:var(--white);border-top:3px solid var(--navy);
  display:none;grid-template-columns:repeat(3,1fr);
  width:100%;max-width:100vw;box-sizing:border-box;
  padding-bottom:env(safe-area-inset-bottom,0);
}
.mobile-bar a{
  padding:13px 6px;text-align:center;font-weight:700;font-size:.82rem;
  display:flex;flex-direction:column;align-items:center;gap:3px;
  border-right:2px solid var(--navy);
}
.mobile-bar a:last-child{border-right:none}
.mobile-bar a .mi{display:flex;justify-content:center}
.mobile-bar a .mi svg{width:22px;height:22px}
.mobile-bar a.call{background:var(--yellow)}
.mobile-bar a.wa{background:var(--mint)}
.mobile-bar a.book{background:var(--pink);color:#fff}

/* ============================================
   LEGAL PAGES
   ============================================ */
.legal-page{padding:100px 0 80px;background:var(--offwhite)}
.legal-page .wrap{max-width:800px}
.legal-page h1{font-size:2.4rem;margin-bottom:30px}
.legal-page h2{font-size:1.5rem;margin:30px 0 12px}
.legal-page h3{font-size:1.2rem;margin:20px 0 8px}
.legal-page p{margin-bottom:14px;font-size:.97rem;font-weight:500}
.legal-page ul,.legal-page ol{margin:0 0 14px 24px}
.legal-page li{margin-bottom:6px;font-size:.95rem;font-weight:500}
.legal-page a{color:var(--pink);text-decoration:underline}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:980px){
  .hero h1{font-size:3rem}
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .polaroid-stack{height:380px;max-width:420px;margin:0 auto}
  .orbit{width:340px;height:320px}
  .polaroid{width:170px;margin-left:-85px;margin-top:-125px;padding:10px 10px 36px}
  .polaroid .pic{height:150px}
  .steps-grid,.serv-grid{grid-template-columns:repeat(2,1fr)}
  .gal-grid .gal-item{width:calc(50% - 10px)}
  .gal-detail-grid{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:1fr;gap:34px}
  .plan.featured{transform:scale(1);order:-1}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .angebote-grid .offer-card{width:calc(50% - 14px)}
  .offer-detail-grid{flex-direction:column!important}
  .offer-detail-grid.has-image .od-image,.offer-detail-grid.has-image .od-info{width:100%!important}
  .od-image img{min-height:250px!important}
  .od-feats{grid-template-columns:1fr!important}
  .angebot-grid{grid-template-columns:1fr;gap:28px}
  .angebot-image-wrap{position:static}
  .feat-grid{grid-template-columns:1fr}
  .plan .plan-for{min-height:auto}
  .tcard{flex:0 0 260px}
  .contact-grid{grid-template-columns:1fr;gap:28px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none;position:absolute;top:74px;left:0;right:0;
    background:var(--white);border-bottom:3px solid var(--navy);
    flex-direction:column;gap:0;padding:0;z-index:89}
  .nav-links.open{display:flex}
  .nav-links a{padding:16px 28px;border-top:1px solid var(--cream);font-size:1rem}
  .nav-links a:hover{background:var(--cream)}
  .menu-toggle{display:block}
  .nav-right .btn{display:none}
  .mobile-bar{display:grid}
  .site-footer{padding-bottom:54px}
  .sec-head h2{font-size:2.3rem}
  .mini-cta h2{font-size:2.2rem}
  .story-box{padding:34px 24px}
  .story-headline{font-size:1.15rem}
}
@media(max-width:560px){
  .hero h1{font-size:2.4rem}
  .steps-grid,.serv-grid{grid-template-columns:1fr 1fr}
  .gal-grid .gal-item{width:calc(50% - 10px)}
  .gal-detail-grid{grid-template-columns:repeat(2,1fr)}
  .trust-bar{gap:14px;padding:12px 16px}
  .hero-cta .btn{flex:1;justify-content:center}
  .wrap{padding:0 16px}
  .foot-grid{grid-template-columns:1fr}
  .product-grid{grid-template-columns:1fr}
  .angebote-grid{gap:20px}
  .angebote-grid .offer-card{width:100%}
  .angebot-cta{flex-direction:column}
  .angebot-cta .btn{width:100%;justify-content:center}
}
