/*
Theme Name: PeddiLaser DE
Theme URI: https://project3.peddinghaus-shop.eu
Description: Deutscher Nachbau der PeddiLaser-Microsite (DSGVO-konform, lokal gehostet, metrische Einheiten). Child-Theme von Twenty Twenty-Five.
Author: miko24
Template: twentytwentyfive
Version: 0.3.0
*/

:root{ --pl-orange:#F47821; --pl-ink:#161616; --pl-dark:#1d1d1d; --pl-stone:#f4f4f4; }

/* ---------- Basis ---------- */
.pl-eyebrow{font-family:Oswald,Inter,sans-serif;text-transform:uppercase;letter-spacing:.14em;font-weight:600;color:var(--pl-orange);font-size:.8rem;display:inline-block;margin:0 0 .8rem}
.wp-block-button__link{border-radius:0!important;font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.04em}
.pl-btn-ghost .wp-block-button__link{background:transparent!important;border:2px solid #fff!important;color:#fff!important}
:where(.wp-block-heading){letter-spacing:-.01em;line-height:1.04}

/* ---------- Hero ---------- */
.pl-hero{position:relative;min-height:84vh;display:flex;align-items:center;background:#0c0c0c;overflow:hidden}
.pl-hero .pl-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.pl-hero .wp-block-cover__background{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,8,8,.88) 0%,rgba(8,8,8,.6) 48%,rgba(8,8,8,.32) 100%),linear-gradient(0deg,rgba(8,8,8,.55) 0%,rgba(8,8,8,0) 40%)!important}
.pl-hero h1{font-size:clamp(2.8rem,6.5vw,5.6rem);font-weight:700;color:#fff;max-width:15ch;text-transform:uppercase;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.pl-hero .pl-sub{font-size:clamp(1.1rem,2vw,1.65rem);color:#fff;font-weight:500;max-width:34ch}

/* ---------- Maschinen-Grid ---------- */
.pl-machines-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.5rem;margin-top:2.5rem}
.pl-mcard{background:#fff;border:1px solid #e6e6e6;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s}
.pl-mcard:hover{box-shadow:0 18px 40px -22px rgba(0,0,0,.35);transform:translateY(-4px)}
.pl-mcard img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:#111}
.pl-mcard .pl-mcard-body{padding:1.2rem 1.3rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.pl-mcard h3{font-size:1.5rem;margin:0;font-weight:700;text-transform:uppercase}
.pl-mcard .pl-mtype{color:var(--pl-orange);font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:600}
.pl-mcard p{margin:.2rem 0 1rem;font-size:.95rem;color:#444;flex:1}
.pl-mcard a.pl-more{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.05em;font-weight:600;color:var(--pl-ink);text-decoration:none;border-bottom:2px solid var(--pl-orange);align-self:flex-start;padding-bottom:2px}
.pl-mcard a.pl-more:hover{color:var(--pl-orange)}

/* ---------- Technik-Split ---------- */
.pl-tech{display:grid;grid-template-columns:1.05fr .95fr;gap:4rem;align-items:center}
.pl-tech.rev .pl-tech-media{order:2}
.pl-tech-media{position:relative}
.pl-tech-media img{width:100%;height:clamp(420px,52vh,620px);object-fit:cover;display:block;box-shadow:0 30px 60px -30px rgba(0,0,0,.45)}
.pl-tech-media::after{content:"";position:absolute;left:-14px;top:-14px;width:70px;height:70px;border-left:4px solid var(--pl-orange);border-top:4px solid var(--pl-orange)}
.pl-tech.rev .pl-tech-media::after{left:auto;right:-14px;border-left:0;border-right:4px solid var(--pl-orange)}
.pl-tech h2{font-size:clamp(2.1rem,3.6vw,3.1rem);font-weight:700;margin:.2rem 0 .8rem}
.pl-tech p{font-size:1.08rem;line-height:1.7;color:#444;max-width:56ch}
@media(max-width:781px){.pl-tech{grid-template-columns:1fr;gap:1.8rem}.pl-tech.rev .pl-tech-media{order:0}}

/* ---------- Stat-Split (Bild) ---------- */
.pl-stat-split{display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:center}
.pl-stat-split h2{font-size:clamp(2.3rem,4.2vw,3.6rem);font-weight:700;max-width:16ch}
.pl-stat-split .pl-stat-media img{width:100%;height:clamp(320px,40vh,460px);object-fit:cover;display:block;box-shadow:0 30px 60px -30px rgba(0,0,0,.4)}
@media(max-width:781px){.pl-stat-split{grid-template-columns:1fr;gap:2rem}}

/* ---------- Testimonials (orange Band, große Foto-Karten) ---------- */
.pl-refs{background:linear-gradient(135deg,#f47821 0%,#d9610f 100%);color:#fff}
.pl-refs h2{color:#fff}
.pl-refs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.2rem;margin-top:2.5rem}
.pl-refcard{position:relative;aspect-ratio:4/5;overflow:hidden;background:#111;box-shadow:0 16px 40px -20px rgba(0,0,0,.5)}
.pl-refcard img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.pl-refcard:hover img{transform:scale(1.06)}
.pl-refcard .pl-refcap{position:absolute;inset:auto 0 0 0;background:linear-gradient(0deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.5) 55%,transparent 100%);padding:1.6rem 1.3rem 1.2rem;color:#fff}
.pl-refcard .pl-ref-name{font-family:Oswald,sans-serif;font-weight:600;text-transform:uppercase;font-size:1.15rem;line-height:1.1}
.pl-refcard .pl-ref-role{font-size:.85rem;color:#f6c8a6;margin-top:.2rem}
.pl-refcard .pl-ref-portrait{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid var(--pl-orange);position:absolute;top:1rem;right:1rem;box-shadow:0 4px 14px rgba(0,0,0,.4)}

/* ---------- Stat / CTA ---------- */
.pl-stat h2{font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:700;max-width:18ch}
.pl-cta{position:relative;text-align:center;overflow:hidden}
.pl-cta-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.pl-cta .wp-block-cover__background{position:absolute;inset:0;z-index:1;background:rgba(15,15,15,.62)!important}
.pl-cta h2{color:#fff;font-size:clamp(2rem,4vw,3.2rem);font-weight:700;max-width:20ch;margin-inline:auto}
.pl-dark{background:var(--pl-dark);color:#fff}
.pl-dark h2{color:#fff}
.pl-dark p{color:#cfcfcf}

/* ---------- Layout ---------- */
.pl-section{padding-block:clamp(3.5rem,7vw,6.5rem);width:100%}
.pl-wrap{max-width:min(1800px,92vw);margin-inline:auto;padding-inline:clamp(20px,4vw,56px)}
.pl-wrap--text{max-width:min(1500px,90vw)}

/* ---------- Apple-Scroll: scrollgetriggerte Bild-/Karten-Reveals (reines CSS) ---------- */
@media (prefers-reduced-motion: no-preference){
  @supports (animation-timeline: view()){
    .pl-tech-media, .pl-stat-media, .pl-mcard, .pl-refcard, .pl-video, .pl-mhero-img, .pl-keyfacts > div{
      animation: pl-reveal linear both;
      animation-timeline: view();
      animation-range: entry 2% cover 24%;
    }
    @keyframes pl-reveal{
      from{opacity:0;transform:translateY(46px) scale(.965)}
      to{opacity:1;transform:none}
    }
  }
}
.pl-home section{width:100%}
.pl-home p{font-size:1.05rem;line-height:1.65}
.pl-lead{font-size:1.15rem;color:#444;max-width:60ch}

/* ---------- Buttons (raw) ---------- */
.pl-btn{display:inline-block;background:var(--pl-orange);color:#fff;font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.04em;font-weight:600;padding:.9rem 1.9rem;text-decoration:none;border:2px solid var(--pl-orange);transition:background .15s,border-color .15s}
.pl-btn:hover{background:#d9650f;border-color:#d9650f;color:#fff}
.pl-btn--ghost{background:transparent;border-color:#fff;color:#fff}
.pl-btn--ghost:hover{background:#fff;color:var(--pl-ink)}
.pl-btnrow{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.7rem}

/* ---------- Maschinenseite (Split-Hero) ---------- */
.pl-mhero{background:#161616;position:relative;overflow:hidden}
.pl-mhero::before{content:"";position:absolute;top:-30%;left:-10%;width:55%;height:160%;background:radial-gradient(circle,rgba(244,120,33,.16) 0%,transparent 65%);z-index:0}
.pl-mhero-split{display:grid;grid-template-columns:1fr 1.15fr;gap:2.5rem;align-items:stretch;position:relative;z-index:1}
.pl-mhero-text{color:#fff;padding-block:clamp(3rem,6vw,5rem);align-self:center}
.pl-mhero-type{color:var(--pl-orange);font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.12em;font-weight:600;font-size:.85rem}
.pl-mhero h1{font-size:clamp(2.4rem,5vw,4.4rem);text-transform:uppercase;color:#fff;margin:.4rem 0 .2rem;line-height:1}
.pl-mhero-img{position:relative;display:flex;align-items:center;justify-content:center;margin:1.5rem 0;min-height:46vh}
.pl-mhero-img::before{content:"";position:absolute;inset:4% 2% 4% 2%;background:radial-gradient(ellipse at 52% 52%,rgba(244,120,33,.20) 0%,rgba(244,120,33,0) 62%);z-index:0}
.pl-mhero-img::after{content:"";position:absolute;left:10%;right:10%;bottom:7%;height:30px;background:radial-gradient(ellipse at 50% 50%,rgba(0,0,0,.6) 0%,transparent 72%);filter:blur(7px);z-index:0}
.pl-mhero-img img{position:relative;z-index:1;width:100%;height:auto;max-height:50vh;object-fit:contain;filter:drop-shadow(0 24px 40px rgba(0,0,0,.45))}
@media(max-width:861px){.pl-mhero-split{grid-template-columns:1fr;gap:0}.pl-mhero-img{min-height:38vh;margin:0 0 1.2rem}}

/* ---------- Mobile-Burger ---------- */
.pl-burger-cb{display:none}
.pl-burger{display:none;font-size:1.7rem;line-height:1;cursor:pointer;color:#1a1a1a;user-select:none;margin-left:auto;padding:.2rem .4rem}
.pl-nav .pl-nav-cta{display:none}
@media(max-width:920px){
  .pl-burger{display:block;margin-left:auto}
  .pl-header-cta{display:none}
  .pl-nav{position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid #e6e6e6;box-shadow:0 18px 30px -16px rgba(0,0,0,.25);flex-direction:column;align-items:stretch;gap:0;margin:0;display:none}
  .pl-burger-cb:checked~.pl-nav{display:flex}
  .pl-nav>a,.pl-drop>.pl-drop-t{padding:.9rem 1.4rem;border-top:1px solid #f0f0f0;font-size:1rem}
  .pl-nav .pl-nav-cta{display:block;background:var(--pl-orange);color:#fff;font-weight:600}
  .pl-drop-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;background:#f7f7f7;min-width:0}
}

/* Spec-Tabelle (metrisch) */
.pl-specs{width:100%;border-collapse:collapse;margin-top:1.5rem;font-size:1.02rem}
.pl-specs tr{border-bottom:1px solid #e4e4e4}
.pl-specs tr:nth-child(odd){background:#fafafa}
.pl-specs td{padding:.85rem 1rem}
.pl-specs td:first-child{font-weight:600;width:46%;font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.02em;font-size:.92rem;color:#333}
.pl-specs td:last-child{color:#111;font-weight:600}
.pl-specgrid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:start}
@media(max-width:861px){.pl-specgrid{grid-template-columns:1fr}}

/* Video + Speedrun */
.pl-video{width:100%;display:block;background:#000;aspect-ratio:16/9}
.pl-speedrun{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:1.4rem}
.pl-stat-box{background:#161616;color:#fff;padding:1.3rem 1.5rem;border-left:4px solid var(--pl-orange)}
.pl-stat-box b{font-family:Oswald,sans-serif;font-size:1.15rem;display:block;text-transform:uppercase;letter-spacing:.02em}
.pl-stat-box span{font-size:.9rem;color:#bbb}
@media(max-width:781px){.pl-speedrun{grid-template-columns:1fr}}

/* Datenblatt-Badge */
.pl-keyfacts{display:flex;gap:2rem;flex-wrap:wrap;margin-top:1.4rem}
.pl-keyfacts div{border-left:3px solid var(--pl-orange);padding-left:.9rem}
.pl-keyfacts b{font-family:Oswald,sans-serif;font-size:1.4rem;display:block;line-height:1}
.pl-keyfacts span{font-size:.82rem;opacity:.85}

/* ---------- Header ---------- */
.pl-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid #ededed;box-shadow:0 2px 12px -8px rgba(0,0,0,.25)}
.pl-header-inner{display:flex;align-items:center;gap:1.5rem;padding-block:.7rem}
.pl-logo img{height:40px;width:auto;display:block}
.pl-nav{display:flex;align-items:center;gap:1.7rem;margin-left:auto}
.pl-nav>a,.pl-drop>.pl-drop-t{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.04em;font-weight:500;font-size:.92rem;color:#1a1a1a;text-decoration:none;cursor:pointer;white-space:nowrap}
.pl-nav>a:hover,.pl-drop:hover>.pl-drop-t{color:var(--pl-orange)}
.pl-drop{position:relative}
.pl-drop-menu{position:absolute;top:100%;left:0;background:#fff;border:1px solid #ededed;box-shadow:0 16px 36px -14px rgba(0,0,0,.3);min-width:220px;padding:.4rem 0;opacity:0;visibility:hidden;transform:translateY(7px);transition:opacity .15s,transform .15s,visibility .15s}
.pl-drop:hover .pl-drop-menu{opacity:1;visibility:visible;transform:translateY(0)}
.pl-drop-menu a{display:block;padding:.55rem 1.2rem;font-family:Oswald,sans-serif;text-transform:uppercase;font-size:.84rem;letter-spacing:.03em;color:#1a1a1a;text-decoration:none}
.pl-drop-menu a:hover{background:#f6f6f6;color:var(--pl-orange)}
.pl-header-cta{padding:.65rem 1.4rem!important;font-size:.84rem}

/* ---------- Footer ---------- */
.pl-footer{background:#141414;color:#cfcfcf}
.pl-footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem;padding-block:4rem 2.5rem}
.pl-footer h4{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.06em;color:#fff;font-size:.95rem;margin:0 0 1.1rem}
.pl-footer a{color:#cfcfcf;text-decoration:none;display:block;padding:.32rem 0;font-size:.95rem}
.pl-footer a:hover{color:var(--pl-orange)}
.pl-foot-logo{font-family:Oswald,sans-serif;font-weight:700;font-size:1.6rem;color:#fff;text-transform:uppercase;display:block;margin-bottom:1rem;letter-spacing:.02em}
.pl-footer-brand p{font-size:.92rem;line-height:1.7;color:#9a9a9a;margin:.4rem 0}
.pl-footer-brand a{display:inline;padding:0}
.pl-footer-bottom{border-top:1px solid #2a2a2a}
.pl-footer-bottom .pl-wrap{padding-block:1.4rem;font-size:.85rem;color:#7d7d7d;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem 1.5rem}
.pl-footer-bottom a{color:#9a9a9a;display:inline;padding:0}
@media(max-width:781px){.pl-footer-grid{grid-template-columns:1fr 1fr}}
