/*
Theme Name: PupiLink
Theme URI: https://pupilink.pl
Author: PupiLink
Description: Lekki motyw landingowy PupiLink - zawieszki NFC dla zwierzat. Strona glowna z animacja, sliderem krok-po-kroku i biegnacym border collie.
Version: 0.3.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: pupilink
*/

:root{
    --cream:#FBF7F0; --cream-2:#F2EADB; --paper:#FFFFFF;
    --ink:#221A15; --ink-soft:#6B5E54;
    --coral:#FF6B4A; --coral-deep:#EF4E2B;
    --grass:#2FB67E; --grass-deep:#1E9466; --grass-soft:#DBF3E7;
    --sky:#BFE3FF; --sun:#FFC94D; --dog:#1A1410;
    --maxw:1100px; --r-lg:30px;
    --shadow:0 22px 48px -26px rgba(34,26,21,.5);
    --meadow-h:122px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:"Plus Jakarta Sans",system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  h1,h2,h3{font-family:"Fredoka",system-ui,sans-serif;font-weight:600;line-height:1.04;letter-spacing:-.01em}
  .wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
  .eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--coral-deep)}
  .eyebrow::before{content:"";width:24px;height:2px;border-radius:2px;background:var(--coral)}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:"Fredoka",sans-serif;font-weight:600;font-size:1.05rem;padding:15px 28px;border-radius:999px;border:0;cursor:pointer;text-decoration:none;transition:transform .2s cubic-bezier(.2,.8,.3,1.25),box-shadow .2s ease}
  .btn-primary{background:var(--coral-deep);color:#fff;box-shadow:0 12px 24px -10px rgba(239,78,43,.7)}
  .btn-primary:hover{transform:translateY(-2px) scale(1.02)}
  .btn-ghost{background:#fff;color:var(--ink);border:1.5px solid rgba(34,26,21,.14)}
  .btn-ghost:hover{transform:translateY(-2px);border-color:var(--ink)}

  header.bar{position:sticky;top:0;z-index:50;background:rgba(251,247,240,.8);backdrop-filter:blur(12px);border-bottom:1px solid rgba(34,26,21,.06)}
  .bar .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
  .logo{display:flex;align-items:center;gap:9px;font-family:"Fredoka";font-weight:700;font-size:1.32rem}
  .logo .dot{width:31px;height:31px;border-radius:10px;background:var(--coral-deep);display:grid;place-items:center}
  .logo .dot svg{width:18px;height:18px}
  .bar .btn{padding:10px 20px;font-size:.95rem}

  /* hero */
  .hero{position:relative;padding:60px 0 36px}
  .hero .wrap{display:grid;gap:30px}
  .hero h1{font-size:clamp(2.5rem,8.4vw,4.4rem);max-width:13ch}
  .hero h1 em{font-style:normal;color:var(--coral-deep)}
  .hero p.lead{font-size:clamp(1.06rem,2.6vw,1.3rem);color:var(--ink-soft);max-width:42ch;margin-top:18px}
  .hero .cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
  .hero .trustline{margin-top:20px;font-size:.9rem;color:var(--ink-soft);display:flex;align-items:center;gap:8px}
  .hero .trustline svg{width:17px;height:17px;color:var(--grass-deep)}
  .stage{position:relative;justify-self:center;width:min(380px,86vw);aspect-ratio:1/1;display:grid;place-items:center}
  .blob{position:absolute;inset:2%;border-radius:46% 54% 52% 48%/52% 46% 54% 48%;background:radial-gradient(circle at 38% 32%,#FFE39A,transparent 60%),radial-gradient(circle at 72% 74%,var(--sky),transparent 58%),radial-gradient(circle at 50% 50%,#fff,transparent 70%);filter:blur(6px)}
  .heroTag{position:relative;z-index:2;width:74%;animation:floaty 4.5s ease-in-out infinite}
  .heroTag .wave{stroke:var(--coral);opacity:0;transform-origin:196px 132px;animation:nfc 2.4s ease-out infinite}
  .heroTag .w2{animation-delay:.4s}.heroTag .w3{animation-delay:.8s}
  @keyframes floaty{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-12px) rotate(2deg)}}
  @keyframes nfc{0%{opacity:0;transform:scale(.5)}30%{opacity:.9}100%{opacity:0;transform:scale(1.15)}}
  @media(min-width:880px){.hero .wrap{grid-template-columns:1.1fr .9fr;align-items:center}.hero{padding:80px 0 52px}}

  section.block{position:relative;z-index:2;padding:60px 0}
  .sec-head{max-width:40ch;margin-bottom:30px}
  .sec-head h2{font-size:clamp(1.9rem,5.6vw,2.8rem);margin-top:12px}
  .sec-head p{color:var(--ink-soft);margin-top:12px;font-size:1.05rem}
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}

  /* ===== SLIDER ===== */
  .demo{background:linear-gradient(180deg,var(--grass-soft),var(--cream) 82%)}
  .demo .wrap{display:grid;gap:34px;align-items:center}
  @media(min-width:900px){.demo .wrap{grid-template-columns:1fr 1fr}}
  .demo-copy .stepno{font-family:"Fredoka";font-weight:700;color:var(--coral-deep);font-size:1rem;letter-spacing:.06em}
  .demo-copy h2{font-size:clamp(1.9rem,5.6vw,2.7rem);margin:8px 0 12px;min-height:2.1em}
  .demo-copy p.cap{color:var(--ink-soft);font-size:1.08rem;max-width:38ch;min-height:3.4em}
  .swap{transition:opacity .25s ease}.swap.out{opacity:0}
  .controls{display:flex;align-items:center;gap:16px;margin-top:26px}
  .arrow{width:48px;height:48px;border-radius:50%;border:1.5px solid rgba(34,26,21,.16);background:#fff;display:grid;place-items:center;cursor:pointer;transition:transform .18s ease,border-color .18s ease}
  .arrow:hover{transform:translateY(-2px);border-color:var(--ink)}
  .arrow svg{width:20px;height:20px;stroke:var(--ink)}
  .dots{display:flex;gap:9px}
  .dot{width:9px;height:9px;border-radius:50%;border:0;background:rgba(34,26,21,.18);cursor:pointer;padding:0;transition:width .25s ease,background .25s ease}
  .dot.active{width:26px;border-radius:6px;background:var(--coral-deep)}

  .deck{justify-self:center}
  .phone{width:288px;max-width:84vw;background:var(--dog);border-radius:42px;padding:13px;box-shadow:0 36px 70px -32px rgba(0,0,0,.6)}
  .notch{width:38%;height:6px;background:#000;border-radius:0 0 8px 8px;margin:0 auto 8px}
  .viewport{position:relative;background:#fff;border-radius:30px;overflow:hidden;touch-action:pan-y}
  .track{display:flex;will-change:transform;transition:transform .5s cubic-bezier(.22,.61,.36,1)}
  .slide{flex:0 0 100%;min-height:452px;display:flex;flex-direction:column}

  /* screen building blocks */
  .scr-head{padding:22px 18px;text-align:center;color:#fff}
  .scr-head.dark{background:var(--dog)}.scr-head.grass{background:var(--grass)}.scr-head.coral{background:var(--coral-deep)}
  .scr-title{font-family:"Fredoka";font-weight:600;font-size:1.24rem}
  .scr-sub{font-size:.84rem;opacity:.9;margin-top:3px}
  .scr-body{padding:18px 16px;display:flex;flex-direction:column;gap:11px;flex:1}
  .avatar{width:78px;height:78px;border-radius:50%;background:var(--cream-2);margin:2px auto 6px;display:grid;place-items:center;border:3px solid #fff;overflow:hidden}
  .avatar svg{width:58px;height:58px}
  .field{border:1.5px solid rgba(34,26,21,.14);border-radius:13px;padding:11px 13px;font-size:.92rem;color:var(--ink-soft)}
  .field b{color:var(--ink);font-weight:700}
  .code{letter-spacing:.34em;font-family:"Fredoka";font-weight:600;font-size:1.5rem;text-align:center;color:var(--ink);background:var(--cream);border-radius:14px;padding:14px;border:2px dashed var(--grass)}
  .chip{display:inline-flex;align-items:center;gap:6px;background:var(--grass-soft);color:var(--grass-deep);font-weight:600;font-size:.82rem;padding:6px 11px;border-radius:999px;margin:2px 4px 2px 0}
  .chip.no{background:#FFE2D7;color:var(--coral-deep)}
  .chips{display:flex;flex-wrap:wrap}
  .fakebtn{margin-top:auto;background:var(--coral-deep);color:#fff;text-align:center;font-family:"Fredoka";font-weight:600;padding:13px;border-radius:14px}
  .nfc-stage{flex:1;display:grid;place-items:center;background:var(--dog)}
  .nfc-stage svg{width:120px;height:120px}
  .ok{width:74px;height:74px;border-radius:50%;background:var(--grass);display:grid;place-items:center;margin:6px auto}
  .ok svg{width:38px;height:38px;stroke:#fff}
  .petcard{background:var(--cream);border-radius:16px;padding:14px;display:flex;gap:12px;align-items:center}
  .petcard .pa{width:48px;height:48px;border-radius:12px;background:#fff;display:grid;place-items:center;flex:none}
  .petcard .pa svg{width:34px;height:34px}
  .ph-btn{display:flex;align-items:center;gap:10px;padding:13px 15px;border-radius:14px;font-weight:700;font-size:.92rem}
  .ph-btn svg{width:18px;height:18px;flex:none}
  .ph-btn.call{background:var(--coral-deep);color:#fff}
  .ph-btn.sms{background:var(--cream-2);color:var(--ink)}
  .ph-btn.loc{background:var(--sky);color:#0b4a78}

  /* product */
  .product .wrap{display:grid;gap:34px;align-items:center}
  @media(min-width:880px){.product .wrap{grid-template-columns:.95fr 1.05fr}}
  .product-art{display:flex;justify-content:center;gap:18px}
  .feature-list{display:grid;gap:15px;margin-top:10px}
  .feature{display:flex;gap:13px;align-items:flex-start}
  .feature .ic{flex:none;width:34px;height:34px;border-radius:11px;background:var(--cream-2);display:grid;place-items:center}
  .feature .ic svg{width:18px;height:18px;color:var(--coral-deep)}
  .feature span{display:block;color:var(--ink-soft);font-size:.97rem}

  .trust .wrap{background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:46px 32px}
  .trust h2{color:#fff;font-size:clamp(1.7rem,5vw,2.4rem)}
  .trust .eyebrow{color:var(--sun)}.trust .eyebrow::before{background:var(--sun)}
  .trust-grid{display:grid;gap:18px;margin-top:26px}
  @media(min-width:680px){.trust-grid{grid-template-columns:repeat(2,1fr)}}
  .tcard{display:flex;gap:13px;align-items:flex-start}
  .tcard .ic{flex:none;width:36px;height:36px;border-radius:11px;background:rgba(255,255,255,.1);display:grid;place-items:center}
  .tcard .ic svg{width:19px;height:19px;color:var(--sun)}
  .tcard span{display:block;color:rgba(255,255,255,.72);font-size:.95rem;margin-top:2px}

  .final{text-align:center;padding:74px 0 calc(70px + var(--meadow-h))}
  .final h2{font-size:clamp(2.1rem,6vw,3rem);max-width:18ch;margin:0 auto 10px}
  .final p{color:var(--ink-soft);max-width:40ch;margin:0 auto 28px}
  footer{background:var(--cream-2);padding:30px 0;font-size:.9rem;color:var(--ink-soft)}
  footer .wrap{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center}

  /* running meadow */
  .meadow{position:fixed;left:0;right:0;bottom:0;height:var(--meadow-h);z-index:40;pointer-events:none;opacity:0;transition:opacity .5s ease}
  .meadow.show{opacity:1}
  .ground{position:absolute;left:0;right:0;bottom:0;height:66px;background:linear-gradient(180deg,var(--grass),var(--grass-deep))}
  .ground::before{content:"";position:absolute;top:-6px;left:0;right:0;height:13px;background:repeating-linear-gradient(95deg,var(--grass) 0 8px,var(--grass-deep) 8px 16px);opacity:.45;border-radius:50%}
  .paws{position:absolute;left:0;right:0;bottom:22px;height:28px}
  .paw{position:absolute;width:10px;height:10px;opacity:0;transition:opacity .35s ease;color:rgba(255,255,255,.5)}
  .home{position:absolute;right:16px;bottom:48px;width:48px;height:48px}
  #dogwrap{position:absolute;bottom:30px;left:0;width:140px;height:96px;will-change:transform}
  #dogshadow{position:absolute;bottom:6px;left:14px;width:104px;height:16px;border-radius:50%;background:rgba(0,0,0,.22);filter:blur(3px)}
  .speed{position:absolute;top:38px;left:-6px;height:38px;width:34px;opacity:.5;animation:streak .25s linear infinite}
  .speed line{stroke:rgba(255,255,255,.7);stroke-width:3;stroke-linecap:round}
  #dog{position:absolute;left:0;bottom:0;width:140px;height:96px}
  .gbody{animation:bound .5s cubic-bezier(.4,0,.5,1) infinite}
  .hipB{transform-box:fill-box;transform-origin:top center;animation:hipBack .5s linear infinite}
  .hipF{transform-box:fill-box;transform-origin:top center;animation:hipFront .5s linear infinite}
  .kneeB{transform-box:fill-box;transform-origin:top center;animation:kneeBack .5s linear infinite}
  .kneeF{transform-box:fill-box;transform-origin:top center;animation:kneeFront .5s linear infinite}
  #legFR2,#legBR2{animation-delay:.06s}
  #tailD{transform-box:fill-box;transform-origin:right center;animation:tailflow .5s ease-in-out infinite}
  #earD{transform-box:fill-box;transform-origin:bottom left;animation:earflap .5s ease-in-out infinite}
  #shadowAnim{animation:shpulse .5s ease-in-out infinite}
  @keyframes bound{0%{transform:translateY(0) rotate(-3deg)}30%{transform:translateY(-9px) rotate(2deg)}55%{transform:translateY(-3px) rotate(3deg)}100%{transform:translateY(0) rotate(-3deg)}}
  @keyframes hipBack{0%{transform:rotate(34deg)}40%{transform:rotate(-40deg)}100%{transform:rotate(34deg)}}
  @keyframes hipFront{0%{transform:rotate(-38deg)}45%{transform:rotate(40deg)}100%{transform:rotate(-38deg)}}
  @keyframes kneeBack{0%{transform:rotate(10deg)}40%{transform:rotate(58deg)}100%{transform:rotate(10deg)}}
  @keyframes kneeFront{0%{transform:rotate(50deg)}45%{transform:rotate(6deg)}100%{transform:rotate(50deg)}}
  @keyframes tailflow{0%,100%{transform:rotate(-12deg)}50%{transform:rotate(14deg)}}
  @keyframes earflap{0%,100%{transform:rotate(-10deg)}50%{transform:rotate(12deg)}}
  @keyframes shpulse{0%,100%{transform:scaleX(1);opacity:.22}30%{transform:scaleX(.7);opacity:.12}}
  @keyframes streak{0%{opacity:.55;transform:translateX(0)}100%{opacity:0;transform:translateX(-10px)}}
  @media(max-width:560px){:root{--meadow-h:98px}#dogwrap{width:112px;height:78px;bottom:28px}#dog{width:112px;height:78px}#dogshadow{width:84px;left:10px}.ground{height:52px}}
  @media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}.heroTag,.gbody,.hipB,.hipF,.kneeB,.kneeF,#tailD,#earD,#shadowAnim,.speed,.heroTag .wave{animation:none}.meadow{opacity:1}.track{transition:none}}
