/* =====================================================
   JUPINI — gemeinsames Stylesheet (alle Templates)
   Palette: Deep Navy · Ocean Blue · Forest Green
   ===================================================== */
html,body{overflow-x:hidden;max-width:100%}
:root{
  --blue-950:#0c1a35;--blue-900:#1e3a5f;--blue-800:#1e40af;--blue-700:#1d4ed8;
  --blue-600:#2563eb;--blue-500:#3b82f6;--blue-400:#60a5fa;--blue-100:#dbeafe;--blue-50:#eff6ff;
  --green-700:#15803d;--green-600:#16a34a;--green-500:#22c55e;--green-100:#dcfce7;--green-50:#f0fdf4;
  --teal-600:#0891b2;--teal-500:#06b6d4;--teal-400:#22d3ee;
  --violet-600:#7c3aed;--violet-700:#6d28d9;
  --amber-600:#d97706;--amber-500:#f59e0b;--amber-100:#fef3c7;--amber-50:#fffbeb;
  --navy:#0f172a;--slate-800:#1e293b;--slate-700:#334155;--slate-600:#475569;
  --slate-400:#94a3b8;--slate-300:#cbd5e1;--slate-200:#e2e8f0;--slate-100:#f1f5f9;--slate-50:#f8fafc;
  --white:#fff;--star:#f59e0b;
  --font-serif:'Playfair Display',Georgia,serif;--font-sans:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 20px rgba(0,0,0,.1);
  --shadow-lg:0 16px 48px rgba(0,0,0,.14);--shadow-xl:0 28px 70px rgba(0,0,0,.2);
  --shadow-blue:0 4px 24px rgba(37,99,235,.3);--shadow-blue-lg:0 8px 40px rgba(37,99,235,.42);
  --radius-sm:8px;--radius-md:14px;--radius-lg:24px;
}

/* ---- Base (nur innerhalb .jupini-page, um Astra nicht zu stören) ---- */
.jupini-page *,.jupini-page *::before,.jupini-page *::after{box-sizing:border-box}
.jupini-page{font-family:var(--font-sans);color:var(--slate-800);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
.jupini-page img{max-width:100%;display:block;object-fit:cover}
.jupini-page ul{list-style:none;margin:0;padding:0}
.jupini-page a{text-decoration:none;color:inherit}
.jupini-page h1,.jupini-page h2,.jupini-page h3{margin:0}
.jp-container{max-width:1200px;margin:0 auto;padding:0 28px}
.jp-container-wide{max-width:1240px;margin:0 auto;padding:0 28px}
.jp-text-center{text-align:center}

/* ---- Reveal ---- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}.reveal-d4{transition-delay:.4s}.reveal-d5{transition-delay:.5s}

/* ---- Buttons ---- */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--blue-600),var(--blue-700));color:#fff;padding:14px 30px;border-radius:50px;font-size:.92rem;font-weight:700;letter-spacing:.02em;border:none;cursor:pointer;box-shadow:var(--shadow-blue);transition:all .22s;position:relative;overflow:hidden;font-family:var(--font-sans)}
.btn-primary::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);transition:left .5s}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-blue-lg);color:#fff}
.btn-primary:hover::before{left:100%}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.88);padding:14px 30px;border-radius:50px;font-size:.92rem;font-weight:600;border:1.5px solid rgba(255,255,255,.3);transition:all .22s;cursor:pointer}
.btn-ghost:hover{border-color:rgba(255,255,255,.85);color:#fff;background:rgba(255,255,255,.08)}
.btn-white{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--blue-700);padding:15px 34px;border-radius:50px;font-size:.92rem;font-weight:800;transition:all .22s;box-shadow:var(--shadow-lg);cursor:pointer}
.btn-white:hover{transform:translateY(-2px)}
.btn-light{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--blue-700);padding:13px 26px;border-radius:50px;font-size:.9rem;font-weight:700;transition:all .22s;box-shadow:var(--shadow-md);cursor:pointer}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}

/* ---- Section helpers ---- */
.sec{padding:80px 0}
.sec-pill{display:flex;justify-content:center;margin-bottom:12px}
.sec-pill span,.section-label{color:var(--blue-600);font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;background:var(--blue-50);border:1px solid var(--blue-100);padding:4px 14px;border-radius:50px;display:inline-block}
.section-label{background:none;border:none;padding:0;display:block;text-align:center;margin-bottom:12px;letter-spacing:.14em;font-size:.75rem}
.sec-title,.section-title{font-family:var(--font-serif);text-align:center;font-size:clamp(1.7rem,2.8vw,2.4rem);font-weight:800;color:var(--navy);letter-spacing:-.02em;margin-bottom:48px;line-height:1.2}
.section-title em,.sec-title em{font-style:italic;color:var(--blue-600)}
.sec-sub{text-align:center;color:var(--slate-600);font-size:1rem;max-width:560px;margin:0 auto 48px;line-height:1.6}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:16px}
.sec-link,.sec-view-all{color:var(--blue-600);font-size:.85rem;font-weight:700;display:flex;align-items:center;gap:6px;border-bottom:1.5px solid var(--blue-100);padding-bottom:2px;transition:gap .2s,border-color .2s}
.sec-link:hover,.sec-view-all:hover{gap:10px;border-color:var(--blue-600)}

/* ---- Announcement Marquee ---- */
.ann-bar{background:var(--navy);color:rgba(255,255,255,.75);font-size:.78rem;font-weight:500;height:36px;overflow:hidden;overflow-x:clip;width:100%;position:relative}
.ann-track{display:flex;align-items:center;height:100%;animation:marquee 30s linear infinite;white-space:nowrap}
.ann-item{padding:0 38px;display:flex;align-items:center;gap:8px}
.ann-item em{color:var(--teal-400);font-style:normal;font-weight:700}
.ann-sep{color:rgba(255,255,255,.18)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ---- NAV ---- */
.site-nav{position:sticky;top:0;z-index:200;background:rgba(15,23,42,0);backdrop-filter:blur(0);transition:background .4s,backdrop-filter .4s,box-shadow .4s,border-color .4s;height:70px;border-bottom:1px solid transparent}
.site-nav.solid{background:rgba(15,23,42,.96);backdrop-filter:blur(18px) saturate(160%);box-shadow:0 2px 24px rgba(0,0,0,.3);border-color:rgba(255,255,255,.05)}
.site-nav.nav-solid-default{background:rgba(15,23,42,.96);backdrop-filter:blur(18px) saturate(160%);box-shadow:0 2px 24px rgba(0,0,0,.18);border-color:rgba(255,255,255,.05)}
.nav-inner{max-width:1240px;margin:0 auto;padding:0 28px;height:100%;display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
.nav-left,.nav-right{display:flex;align-items:center;gap:26px}
.nav-right{justify-content:flex-end}
.nav-link{color:rgba(255,255,255,.72);font-size:.82rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;transition:color .18s;position:relative;display:flex;align-items:center;gap:6px;cursor:pointer}
.nav-link.active{color:#fff}
.nav-link::after{content:'';position:absolute;bottom:-6px;left:0;right:0;height:1.5px;background:var(--teal-400);transform:scaleX(0);transition:transform .25s}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}
.nav-link:hover{color:#fff}
.nav-logo{text-align:center}.nav-logo img{height:42px;width:auto;margin:0 auto}
.nav-icons{display:flex;align-items:center;gap:18px}
.nav-icon{color:rgba(255,255,255,.78);font-size:1.05rem;cursor:pointer;transition:color .18s;position:relative}
.nav-icon:hover{color:#fff}
.cart-badge{position:absolute;top:-7px;right:-9px;background:var(--blue-500);color:#fff;font-size:.6rem;font-weight:800;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}
@keyframes onlinePulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.55)}70%{box-shadow:0 0 0 6px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}

/* ---- HERO (Home) ---- */
.hero{height:90vh;min-height:580px;position:relative;overflow:hidden;margin-top:-70px;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 28%;animation:heroZoom 12s ease forwards}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(10,18,40,.78) 0%,rgba(10,18,40,.4) 52%,rgba(10,18,40,.12) 100%)}
.hero-content{position:relative;z-index:1;max-width:1240px;margin:0 auto;padding:70px 28px 0;width:100%}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--teal-400);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;border:1px solid rgba(34,211,238,.35);padding:5px 14px;border-radius:50px;margin-bottom:20px;background:rgba(34,211,238,.08);animation:fadeUp .8s ease .3s both}
.hero-headline{font-family:var(--font-serif);font-size:clamp(2.6rem,5.2vw,4.8rem);font-weight:900;color:#fff;line-height:1.08;letter-spacing:-.02em;margin-bottom:20px;max-width:700px;animation:fadeUp .8s ease .5s both}
.hero-headline em{font-style:italic;color:var(--teal-400)}
.hero-sub{color:rgba(255,255,255,.72);font-size:1.08rem;line-height:1.6;max-width:500px;margin-bottom:36px;animation:fadeUp .8s ease .7s both}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;animation:fadeUp .8s ease .9s both}
.hero-trust{position:absolute;bottom:34px;left:0;right:0}
.hero-trust-inner{max-width:1240px;margin:0 auto;padding:0 28px;display:flex;gap:28px;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.65);font-size:.78rem;font-weight:500}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ---- Intent Cards ---- */
.intents{padding:72px 0 84px;background:var(--white);position:relative;margin-top:-60px;z-index:5}
.intents-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.intent-card{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);background:#fff;transition:transform .3s,box-shadow .3s;cursor:pointer;min-height:340px;display:flex;flex-direction:column}
.intent-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}
.intent-img{position:relative;height:190px;overflow:hidden}
.intent-img img{width:100%;height:100%;transition:transform .5s}
.intent-card:hover .intent-img img{transform:scale(1.08)}
.intent-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,18,40,.55),transparent 60%)}
.intent-icon{position:absolute;top:16px;left:16px;width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:var(--shadow-md)}
.intent-badge{position:absolute;top:18px;right:16px;display:flex;align-items:center;gap:6px;background:rgba(15,23,42,.78);backdrop-filter:blur(6px);color:#fff;font-size:.7rem;font-weight:700;padding:5px 11px;border-radius:50px}
.intent-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--green-500);animation:onlinePulse 2s infinite}
.intent-body{padding:24px;flex:1;display:flex;flex-direction:column}
.intent-title{font-family:var(--font-serif);font-size:1.4rem;font-weight:800;color:var(--navy);margin-bottom:8px}
.intent-text{font-size:.9rem;color:var(--slate-600);line-height:1.6;margin-bottom:18px;flex:1}
.intent-link{display:inline-flex;align-items:center;gap:6px;color:var(--blue-600);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;transition:gap .2s}
.intent-card:hover .intent-link{gap:10px}
.intent-card.accent-teal .intent-link{color:var(--teal-600)}
.intent-card.accent-green .intent-link{color:var(--green-600)}

/* ---- Categories grid ---- */
.categories{padding:84px 0;background:var(--slate-50)}
.cat-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:14px;height:440px}
.cat-card{position:relative;border-radius:16px;overflow:hidden;cursor:pointer}
.cat-card img{width:100%;height:100%;transition:transform .5s}
.cat-card:hover img{transform:scale(1.06)}
.cat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,18,40,.72) 0%,rgba(10,18,40,.05) 55%);transition:background .3s}
.cat-card:hover .cat-overlay{background:linear-gradient(to top,rgba(10,18,40,.8) 0%,rgba(10,18,40,.1) 55%)}
.cat-label{position:absolute;bottom:0;left:0;right:0;padding:20px}
.cat-label h3{font-family:var(--font-serif);font-size:1.5rem;font-weight:800;color:#fff;line-height:1.15;margin-bottom:6px}
.cat-label-sm h3{font-size:1.15rem}
.cat-link{display:inline-flex;align-items:center;gap:5px;color:var(--teal-400);font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;transition:gap .2s}
.cat-card:hover .cat-link{gap:9px}

/* ---- Tierarzt/Ratgeber teaser + Chat ---- */
.tierarzt{padding:96px 0;background:linear-gradient(165deg,var(--blue-50) 0%,#fff 60%);position:relative;overflow:hidden}
.tierarzt::before{content:'';position:absolute;top:-160px;right:-160px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.08) 0%,transparent 70%);pointer-events:none}
.tierarzt-inner{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:center;position:relative;z-index:1}
.ta-eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--blue-600);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;background:var(--blue-50);border:1px solid var(--blue-100);padding:5px 14px;border-radius:50px;margin-bottom:18px}
.ta-title{font-family:var(--font-serif);font-size:clamp(1.9rem,3.2vw,2.7rem);font-weight:900;color:var(--navy);line-height:1.15;letter-spacing:-.02em;margin-bottom:18px}
.ta-title em{font-style:italic;color:var(--blue-600)}
.ta-text{color:var(--slate-600);font-size:1rem;line-height:1.7;margin-bottom:26px}
.ta-steps{display:flex;flex-direction:column;gap:14px;margin-bottom:30px}
.ta-step{display:flex;align-items:flex-start;gap:14px}
.ta-step-num{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--blue-600),var(--blue-700));color:#fff;font-size:.82rem;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-blue)}
.ta-step-text strong{display:block;font-size:.92rem;font-weight:700;color:var(--navy);margin-bottom:2px}
.ta-step-text span{font-size:.84rem;color:var(--slate-600)}
.ta-vets{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#fff;border:1px solid var(--slate-200);border-radius:16px;box-shadow:var(--shadow-sm);margin-bottom:26px}
.ta-vets-info{flex:1}
.ta-vets-online{display:flex;align-items:center;gap:7px;font-size:.85rem;font-weight:700;color:var(--navy)}
.ta-vets-online .dot{width:8px;height:8px;border-radius:50%;background:var(--green-500);animation:onlinePulse 2s infinite}
.ta-vets-sub{font-size:.78rem;color:var(--slate-400);margin-top:2px}
.ta-chat{background:#fff;border-radius:24px;box-shadow:var(--shadow-xl);padding:24px;border:1px solid var(--slate-100);position:relative}
.ta-chat-header{display:flex;align-items:center;gap:10px;padding-bottom:16px;border-bottom:1px solid var(--slate-100);margin-bottom:18px}
.ta-chat-logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--blue-600),var(--teal-600));display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.ta-chat-title{font-weight:800;font-size:.92rem;color:var(--navy)}
.ta-chat-status{font-size:.74rem;color:var(--green-600);font-weight:600;display:flex;align-items:center;gap:5px}
.ta-chat-status .dot{width:6px;height:6px;border-radius:50%;background:var(--green-500)}
.bubble{max-width:85%;padding:13px 16px;border-radius:16px;font-size:.88rem;line-height:1.55;margin-bottom:14px}
.bubble-user{background:var(--slate-100);color:var(--slate-800);margin-left:auto;border-bottom-right-radius:5px}
.bubble-ai{background:linear-gradient(135deg,var(--blue-50),var(--green-50));color:var(--slate-800);border:1px solid var(--blue-100);border-bottom-left-radius:5px}
.bubble-tag{display:inline-flex;align-items:center;gap:5px;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:3px 9px;border-radius:50px;margin-bottom:8px}
.bubble-tag.ai{background:var(--blue-600);color:#fff}
.bubble-verified{display:flex;align-items:center;gap:7px;margin-top:10px;padding-top:10px;border-top:1px dashed var(--slate-200);font-size:.76rem;color:var(--amber-600);font-weight:600}
.ta-chat-input{display:flex;gap:8px;margin-top:18px;padding-top:16px;border-top:1px solid var(--slate-100)}
.ta-chat-input input{flex:1;border:1.5px solid var(--slate-200);border-radius:50px;padding:11px 18px;font-size:.85rem;font-family:var(--font-sans);outline:none;color:var(--slate-800)}
.ta-chat-input input:focus{border-color:var(--blue-500)}
.ta-chat-send{background:linear-gradient(135deg,var(--blue-600),var(--blue-700));color:#fff;border:none;width:42px;height:42px;border-radius:50%;font-size:1rem;cursor:pointer;box-shadow:var(--shadow-blue);transition:transform .2s;flex-shrink:0}
.ta-chat-send:hover{transform:scale(1.08)}

/* ---- Trust bar ---- */
.trust-bar{background:linear-gradient(135deg,var(--navy),var(--blue-900));padding:54px 0;position:relative;overflow:hidden}
.trust-bar::after{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.15) 0%,transparent 70%)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;z-index:1}
.trust-item{text-align:center;padding:18px 16px}
.trust-num{font-family:var(--font-serif);font-size:2.7rem;font-weight:900;line-height:1;margin-bottom:8px;background:linear-gradient(135deg,#fff,var(--teal-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.trust-desc{font-size:.82rem;color:rgba(255,255,255,.55);font-weight:500;line-height:1.4}
@media(min-width:768px){.trust-item+.trust-item{border-left:1px solid rgba(255,255,255,.08)}}

/* ---- Features cards ---- */
.lp-features,.feat-sec{padding:88px 0;background:var(--white)}
.feat-sec{background:var(--slate-50)}
.lp-features-grid,.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.feat-grid{grid-template-columns:repeat(4,1fr);gap:22px}
.lp-feature-card,.feat-card{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-md);padding:32px;position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s}
.feat-card{padding:28px;text-align:center}
.lp-feature-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-500),var(--teal-600));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.lp-feature-card:hover,.feat-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--blue-100)}
.lp-feature-card:hover::before{transform:scaleX(1)}
.lp-feature-icon-box,.feat-icon{width:52px;height:52px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--blue-50),var(--green-50));border:1px solid var(--blue-100);display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:16px;transition:transform .25s}
.feat-icon{width:56px;height:56px;border-radius:14px;margin:0 auto 14px}
.lp-feature-card:hover .lp-feature-icon-box{transform:scale(1.1) rotate(-3deg)}
.lp-feature-card h3,.feat-card h3{font-size:1rem;font-weight:800;color:var(--navy);margin-bottom:8px}
.lp-feature-card p,.feat-card p{font-size:.88rem;color:var(--slate-600);line-height:1.65}

/* ---- Product cards grid (bestseller/related/shop) ---- */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.product-card,.pcard,.pc-card{border-radius:16px;overflow:hidden;background:#fff;border:1px solid var(--slate-200);transition:transform .28s,box-shadow .28s,border-color .28s;cursor:pointer}
.product-card:hover,.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--blue-100)}
.product-img-wrap,.pcard-img,.pc-img{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--slate-50)}
.product-img-wrap img,.pcard-img img,.pc-img img{width:100%;height:100%;transition:transform .4s}
.product-card:hover .product-img-wrap img,.pcard:hover .pcard-img img{transform:scale(1.07)}
.product-badge,.pcard-badge,.pc-badge,.card-badge{position:absolute;top:12px;left:12px;z-index:1;background:linear-gradient(135deg,var(--blue-600),var(--blue-700));color:#fff;font-size:.68rem;font-weight:800;letter-spacing:.04em;padding:4px 10px;border-radius:50px}
.product-badge.new,.pc-badge.new,.card-badge.new,.pcard-badge.new{background:linear-gradient(135deg,var(--green-600),var(--green-700))}
.product-badge.sale,.card-badge.sale{background:linear-gradient(135deg,var(--violet-600),var(--violet-700))}
.quick-add{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(135deg,var(--blue-600),var(--blue-700));color:#fff;text-align:center;padding:12px;font-size:.82rem;font-weight:700;letter-spacing:.04em;transform:translateY(100%);transition:transform .28s}
.product-card:hover .quick-add,.card:hover .quick-add{transform:translateY(0)}
.product-info,.pcard-info,.pc-info{padding:16px}
.product-cat,.pcard-cat,.pc-cat{font-size:.72rem;color:var(--slate-400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px;font-weight:600}
.product-name,.pcard-name,.pc-name{font-weight:700;font-size:.92rem;color:var(--navy);margin-bottom:8px;line-height:1.35}
.product-stars,.pc-stars{color:var(--star);font-size:.75rem;margin-bottom:10px}
.product-stars span,.pc-stars span{color:var(--slate-400);font-size:.72rem;margin-left:4px}
.product-price,.pcard-price,.pc-price{display:flex;align-items:center;gap:7px}
.product-price .new,.pcard-price .new,.pc-price .new,.price-new{font-size:1.08rem;font-weight:800;color:var(--blue-700)}
.product-price .old,.pcard-price .old,.pc-price .old,.price-old{font-size:.82rem;color:var(--slate-400);text-decoration:line-through}

/* ---- Brand story ---- */
.brand-story{padding:96px 0;background:linear-gradient(160deg,var(--navy) 0%,var(--blue-900) 100%);position:relative;overflow:hidden}
.brand-story::before{content:'';position:absolute;top:-200px;left:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(34,211,238,.1) 0%,transparent 70%)}
.brand-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.brand-img{border-radius:20px;overflow:hidden;height:460px;box-shadow:0 24px 60px rgba(0,0,0,.4)}
.brand-img img{width:100%;height:100%}
.brand-tag{display:inline-block;color:var(--teal-400);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;margin-bottom:16px}
.brand-title{font-family:var(--font-serif);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:900;color:#fff;line-height:1.15;letter-spacing:-.02em;margin-bottom:20px}
.brand-title em{font-style:italic;color:var(--teal-400)}
.brand-text{color:rgba(255,255,255,.65);font-size:1rem;line-height:1.75;margin-bottom:32px}
.brand-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:34px}
.brand-stat{text-align:center;padding:16px 12px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:rgba(255,255,255,.04)}
.brand-stat-num{font-family:var(--font-serif);font-size:1.8rem;font-weight:900;color:#fff;margin-bottom:4px}
.brand-stat-label{font-size:.72rem;color:rgba(255,255,255,.45);font-weight:500}

/* ---- Newsletter ---- */
.newsletter{background:var(--blue-50);border-top:1px solid var(--blue-100);border-bottom:1px solid var(--blue-100);padding:64px 0}
.nl-inner{text-align:center;max-width:580px;margin:0 auto}
.nl-tag{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--blue-100);color:var(--blue-600);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:5px 14px;border-radius:50px;margin-bottom:16px}
.nl-title{font-family:var(--font-serif);font-size:2rem;font-weight:800;color:var(--navy);margin-bottom:10px}
.nl-sub{color:var(--slate-600);font-size:.94rem;margin-bottom:28px;line-height:1.6}
.nl-form{display:flex;gap:10px;max-width:460px;margin:0 auto}
.nl-input{flex:1;padding:14px 20px;border:2px solid var(--slate-200);border-radius:50px;font-size:.88rem;font-family:var(--font-sans);background:#fff;color:var(--slate-800);outline:none;transition:border-color .18s}
.nl-input:focus{border-color:var(--blue-500)}
.nl-btn{background:linear-gradient(135deg,var(--blue-600),var(--blue-700));color:#fff;padding:14px 28px;border-radius:50px;border:none;font-size:.88rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-blue);transition:all .2s;font-family:var(--font-sans);white-space:nowrap}
.nl-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-blue-lg)}

/* ---- Footer ---- */
.jupini-footer{background:#0f172a!important;padding:64px 0 32px!important;display:block!important}
.footer-inner{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:48px;margin-bottom:52px}
.footer-brand img{height:42px;width:auto;filter:brightness(0) invert(1);opacity:1;margin-bottom:16px;display:block}
.footer-brand p{color:rgba(255,255,255,.75);font-size:.85rem;line-height:1.7;max-width:280px;margin-bottom:20px}
.footer-social{display:none}
.social-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);font-size:.78rem;font-weight:600;transition:all .2s;cursor:pointer}
.social-btn:hover{border-color:var(--blue-400);color:#fff;background:rgba(255,255,255,.06)}
.footer-col h4{color:rgba(255,255,255,.9);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{color:rgba(255,255,255,.72);font-size:.83rem;transition:color .18s}
.footer-col ul li a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:28px;text-align:center}
.footer-copy{color:rgba(255,255,255,.5);font-size:.75rem;display:inline-block}
.footer-legal{display:flex;gap:24px}
.footer-legal a{color:rgba(255,255,255,.65);font-size:.75rem}
.footer-legal a:hover{color:#fff}

/* ---- Smile Widget ---- */
.smile-widget{position:fixed;bottom:24px;left:24px;z-index:300}
.smile-toggle{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--blue-600),var(--teal-600));box-shadow:var(--shadow-blue-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;cursor:pointer;border:3px solid #fff;transition:transform .25s;position:relative}
.smile-toggle:hover{transform:scale(1.08) rotate(-6deg)}
.smile-toggle .pulse{position:absolute;top:-2px;right:-2px;width:16px;height:16px;border-radius:50%;background:var(--green-500);border:2px solid #fff;animation:onlinePulse 2s infinite}
.smile-panel{position:absolute;bottom:70px;left:0;width:270px;max-width:calc(100vw - 48px);background:#fff;border-radius:20px;box-shadow:var(--shadow-xl);overflow:hidden;opacity:0;transform:translateY(20px) scale(.95);pointer-events:none;transition:all .3s}
.smile-widget.open .smile-panel{opacity:1;transform:none;pointer-events:auto}
.smile-vid{position:relative;height:180px;overflow:hidden;cursor:pointer}
.smile-vid img{width:100%;height:100%}
.smile-vid-overlay{position:absolute;inset:0;background:rgba(10,18,40,.2);display:flex;align-items:center;justify-content:center}
.smile-vid-play{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--blue-700);padding-left:3px}
.smile-head{position:absolute;top:12px;left:12px;right:12px;display:flex;align-items:center;justify-content:space-between}
.smile-head-tag{background:rgba(15,23,42,.78);backdrop-filter:blur(6px);color:#fff;font-size:.68rem;font-weight:700;padding:5px 11px;border-radius:50px}
.smile-close{width:26px;height:26px;border-radius:50%;background:rgba(15,23,42,.78);color:#fff;border:none;cursor:pointer;font-size:.85rem}
.smile-body{padding:14px}
.smile-body h4{font-size:.88rem;font-weight:800;color:var(--navy);margin-bottom:4px}
.smile-body p{font-size:.76rem;color:var(--slate-600);margin-bottom:10px}
.smile-actions{display:flex;gap:8px}
.smile-like{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;background:var(--blue-50);color:var(--blue-700);border:1px solid var(--blue-100);border-radius:50px;padding:8px;font-size:.78rem;font-weight:700;cursor:pointer}
.smile-sound{width:38px;border-radius:50px;background:var(--slate-100);border:1px solid var(--slate-200);cursor:pointer}

/* ---- Breadcrumb ---- */
.breadcrumb{padding:16px 0;background:var(--slate-50);border-bottom:1px solid var(--slate-100)}
.breadcrumb-inner{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--slate-400);flex-wrap:wrap}
.breadcrumb-inner a{color:var(--slate-600)}.breadcrumb-inner a:hover{color:var(--blue-600)}
.breadcrumb-sep{color:var(--slate-300)}
.breadcrumb-current{color:var(--navy);font-weight:600}

/* =====================================================
   SINGLE PRODUCT PAGE (jp-sp-*)
   ===================================================== */
.jp-sp-cont{max-width:1200px;margin:0 auto;padding:0 28px}
.jp-sp-pill{display:flex;justify-content:center;margin-bottom:12px}
.jp-sp-pill span{color:var(--blue-600);font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;background:var(--blue-50);border:1px solid var(--blue-100);padding:4px 14px;border-radius:50px}
.jp-sp-h2{font-family:var(--font-serif);text-align:center;font-size:clamp(1.7rem,2.8vw,2.4rem);font-weight:800;color:var(--navy);letter-spacing:-.02em;margin-bottom:48px;line-height:1.2}
.jp-link{color:var(--blue-600);font-weight:600}

/* Breadcrumb */
.jp-sp-bc{background:var(--slate-50);border-bottom:1px solid var(--slate-100);padding:14px 0}
.jp-sp-bc a{color:var(--slate-600);font-size:.8rem;transition:color .18s;text-decoration:none}
.jp-sp-bc a:hover{color:var(--blue-600)}
.jp-sp-sep{color:var(--slate-300);font-size:.8rem;margin:0 4px}
.jp-sp-cur{color:var(--navy);font-size:.8rem;font-weight:600}

/* Hero layout */
.jp-sp-product{display:block!important}
.jp-sp-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;padding:48px 0 72px}

/* Gallery */
.jp-sp-gal{position:sticky;top:80px}
.jp-sp-gal-main{position:relative;border-radius:20px;overflow:hidden;background:var(--slate-50);box-shadow:var(--shadow-lg);aspect-ratio:1/1}
.jp-sp-gal-main img{width:100%;height:100%;object-fit:cover;transition:opacity .3s}
.jp-sp-badges{position:absolute;top:16px;left:16px;display:flex;gap:8px;z-index:2}
.jp-sp-badge{font-size:.72rem;font-weight:800;letter-spacing:.04em;padding:5px 12px;border-radius:50px;color:#fff}
.jp-sp-badge-blu{background:linear-gradient(135deg,var(--blue-600),var(--blue-700))}
.jp-sp-badge-grn{background:linear-gradient(135deg,var(--green-600),var(--green-700))}
.jp-sp-wish{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);border:none;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:transform .2s;z-index:2}
.jp-sp-wish:hover{transform:scale(1.1)}
.jp-sp-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:12px}
.jp-sp-thumb{aspect-ratio:1/1;border-radius:12px;overflow:hidden;cursor:pointer;border:2.5px solid transparent;background:var(--slate-100);transition:border-color .18s,transform .18s}
.jp-sp-thumb img{width:100%;height:100%;object-fit:cover}
.jp-sp-thumb:hover{transform:scale(1.05)}
.jp-sp-thumb.active{border-color:var(--blue-600);box-shadow:0 0 0 3px rgba(37,99,235,.18)}

/* Buybox */
.jp-sp-cat{font-size:.76rem;color:var(--blue-600);text-transform:uppercase;letter-spacing:.12em;font-weight:700;margin-bottom:10px}
.jp-sp-title{font-family:var(--font-serif)!important;font-size:2.3rem!important;font-weight:800!important;color:var(--navy)!important;line-height:1.15;letter-spacing:-.02em;margin-bottom:14px!important}
.jp-sp-rating{display:flex;align-items:center;gap:10px;margin-bottom:20px}
.jp-sp-stars{color:var(--star,#f59e0b);font-size:1rem;letter-spacing:1px}
.jp-sp-rnum{font-size:.85rem;color:var(--slate-600)}
.jp-sp-rlink{font-size:.82rem;color:var(--blue-600);font-weight:600;border-bottom:1px solid var(--blue-100);text-decoration:none}
.jp-sp-price-row{display:flex;align-items:baseline;gap:12px;margin-bottom:6px;flex-wrap:wrap}
.jp-sp-price{font-size:2.2rem;font-weight:900;letter-spacing:-.02em;background:linear-gradient(135deg,var(--blue-700),var(--blue-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.jp-sp-price-plain .woocommerce-Price-amount{font-size:2.2rem;font-weight:900;color:var(--blue-700)}
.jp-sp-price-old{font-size:1.2rem;color:var(--slate-400);text-decoration:line-through}
.jp-sp-save{background:var(--green-50);color:var(--green-700);font-size:.78rem;font-weight:800;padding:4px 10px;border-radius:50px;border:1px solid var(--green-100)}
.jp-sp-tax{font-size:.78rem;color:var(--slate-400);margin-bottom:24px}
.jp-sp-tax a{color:var(--blue-600)}
.jp-sp-desc{font-size:.96rem;color:var(--slate-600);line-height:1.7;margin-bottom:26px;padding-bottom:26px;border-bottom:1px solid var(--slate-100)}

/* ATC */
.jp-sp-atc-outer{display:flex;gap:12px;margin:0 0 14px;align-items:stretch}
.jp-sp-qty-ui{display:flex;align-items:center;border:2px solid var(--slate-200);border-radius:12px;overflow:hidden;background:#fff;flex-shrink:0}
.jp-sp-qbtn{width:44px;height:54px;border:none;background:var(--slate-50);font-size:1.2rem;color:var(--slate-800);cursor:pointer;transition:background .15s;font-weight:600}
.jp-sp-qbtn:hover{background:var(--blue-50);color:var(--blue-700)}
#jp-qdisplay{width:48px;height:54px;display:flex;align-items:center;justify-content:center;border-left:2px solid var(--slate-200);border-right:2px solid var(--slate-200);font-size:1rem;font-weight:700;color:var(--navy)}
.jp-sp-atc-form{flex:1;min-width:0}
.jp-sp-atc-form form.cart{display:flex!important;margin:0!important;width:100%!important}
.jp-sp-atc-form form.cart .quantity{display:none!important}
.jp-sp-atc-form form.cart button,.jp-sp-atc-form .single_add_to_cart_button{
  flex:1!important;width:100%!important;min-height:54px!important;
  background:linear-gradient(135deg,var(--blue-600),var(--blue-700))!important;
  color:#fff!important;border:none!important;border-radius:12px!important;
  font-size:1rem!important;font-weight:800!important;cursor:pointer;
  box-shadow:var(--shadow-blue)!important;transition:all .22s!important;
  font-family:var(--font-sans)!important;letter-spacing:.01em;text-transform:none!important
}
.jp-sp-atc-form form.cart button:hover{transform:translateY(-2px)!important;box-shadow:var(--shadow-blue-lg)!important}
.jp-sp-stock{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--green-700);font-weight:600;margin-bottom:22px}
.jp-sp-sdot{width:8px;height:8px;border-radius:50%;background:var(--green-500);animation:onlinePulse 2s infinite;flex-shrink:0}

/* Trust strip */
.jp-sp-trust{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}
.jp-sp-titem{display:flex;align-items:center;gap:9px;font-size:.82rem;color:var(--slate-600);font-weight:500;padding:10px 14px;border:1px solid var(--slate-200);border-radius:12px;transition:border-color .18s,background .18s}
.jp-sp-titem:hover{border-color:var(--blue-100);background:var(--blue-50)}
.jp-sp-titem span{font-size:1.15rem}

/* Accordion */
.jp-sp-acc{border-top:1px solid var(--slate-100);margin-top:8px}
.jp-acc-item{border-bottom:1px solid var(--slate-100)}
.jp-acc-q{width:100%;text-align:left;background:none;border:none;padding:18px 0;font-size:.92rem;font-weight:700;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-sans)}
.jp-acc-q:hover{color:var(--blue-600)}
.jp-acc-ico{width:26px;height:26px;border-radius:50%;background:var(--blue-50);border:1.5px solid var(--blue-100);display:flex;align-items:center;justify-content:center;color:var(--blue-600);font-weight:700;font-size:.85rem;transition:all .25s;flex-shrink:0}
.jp-acc-item.open .jp-acc-ico{background:var(--blue-600);color:#fff;transform:rotate(45deg)}
.jp-acc-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;font-size:.88rem;color:var(--slate-600);line-height:1.7}
.jp-acc-item.open .jp-acc-a{max-height:600px;padding-bottom:18px}
.jp-acc-tbl{width:100%;border-collapse:collapse}
.jp-acc-tbl tr{border-bottom:1px solid var(--slate-100)}
.jp-acc-tbl td{padding:10px 0;font-size:.88rem}
.jp-acc-tbl td:first-child{color:var(--slate-500);font-weight:500;width:42%}
.jp-acc-tbl td:last-child{color:var(--navy);font-weight:600}

/* Features section */
.jp-sp-feat-sec{background:var(--slate-50);padding:80px 0}
.jp-sp-feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.jp-sp-feat-card{background:#fff;border:1px solid var(--slate-200);border-radius:16px;padding:28px;text-align:center;transition:transform .25s,box-shadow .25s,border-color .25s}
.jp-sp-feat-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--blue-100)}
.jp-sp-feat-ico{width:56px;height:56px;margin:0 auto 14px;border-radius:14px;background:linear-gradient(135deg,var(--blue-50),var(--green-50));border:1px solid var(--blue-100);display:flex;align-items:center;justify-content:center;font-size:1.6rem}
.jp-sp-feat-card h3{font-size:1rem;font-weight:800;color:var(--navy);margin-bottom:8px}
.jp-sp-feat-card p{font-size:.85rem;color:var(--slate-600);line-height:1.6}

/* KI CTA */
.jp-sp-ki{background:linear-gradient(135deg,var(--navy),var(--blue-900));padding:60px 0}
.jp-sp-ki-inner{display:flex;align-items:center;justify-content:space-between;gap:40px}
.jp-sp-ki-l{display:flex;align-items:center;gap:24px}
.jp-sp-ki-ico{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--blue-600),var(--teal-600));display:flex;align-items:center;justify-content:center;font-size:1.9rem;flex-shrink:0}
.jp-sp-ki-l h3{font-family:var(--font-serif);font-size:1.6rem;font-weight:800;color:#fff;margin-bottom:6px}
.jp-sp-ki-l p{color:rgba(255,255,255,.6);font-size:.9rem;max-width:440px;line-height:1.6}
.jp-sp-online{color:var(--green-500);font-weight:700}
.jp-sp-ki-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--blue-700);padding:14px 28px;border-radius:50px;font-size:.9rem;font-weight:700;white-space:nowrap;transition:all .22s;box-shadow:var(--shadow-md);text-decoration:none}
.jp-sp-ki-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);color:var(--blue-700)}

/* Reviews */
.jp-sp-rev{background:var(--slate-50);padding:80px 0}
.jp-sp-rev-sum{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center;max-width:760px;margin:0 auto 48px;background:#fff;border:1px solid var(--slate-200);border-radius:20px;padding:32px 40px}
.jp-sp-rscore{text-align:center}
.jp-sp-rscore-n{font-family:var(--font-serif);font-size:3.4rem;font-weight:900;color:var(--navy);line-height:1}
.jp-sp-rscore-s{color:var(--star,#f59e0b);font-size:1rem;margin:6px 0}
.jp-sp-rscore-c{font-size:.8rem;color:var(--slate-500)}
.jp-sp-rbars{display:flex;flex-direction:column;gap:7px}
.jp-sp-rbar-row{display:flex;align-items:center;gap:12px;font-size:.78rem;color:var(--slate-500)}
.jp-sp-rbar-t{flex:1;height:7px;background:var(--slate-100);border-radius:50px;overflow:hidden}
.jp-sp-rbar-f{height:100%;background:linear-gradient(90deg,var(--blue-500),var(--teal-600));border-radius:50px}
.jp-sp-rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:40px}
.jp-sp-rev-card{background:#fff;border:1px solid var(--slate-200);border-radius:16px;padding:24px}
.jp-sp-rev-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.jp-sp-rev-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--blue-500),var(--teal-600));display:flex;align-items:center;justify-content:center;color:#fff;font-size:.82rem;font-weight:800;flex-shrink:0}
.jp-sp-rev-name{font-size:.86rem;font-weight:700;color:var(--navy)}
.jp-sp-rev-verif{font-size:.72rem;color:var(--green-600);font-weight:600}
.jp-sp-rev-s{color:var(--star,#f59e0b);font-size:.85rem;margin-bottom:8px}
.jp-sp-rev-t{font-size:.86rem;color:var(--slate-600);line-height:1.65}
.jp-sp-no-rev{text-align:center;color:var(--slate-500);padding:24px}
.jp-sp-rev-form{margin-top:24px}

/* Related */
.jp-sp-related{background:#fff;padding:80px 0}
.jp-sp-rel-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;list-style:none;padding:0;margin:0}
.jp-sp-rel-card a{display:block;border-radius:16px;overflow:hidden;background:#fff;border:1px solid var(--slate-200);transition:transform .28s,box-shadow .28s,border-color .28s;text-decoration:none}
.jp-sp-rel-card a:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--blue-100)}
.jp-sp-rel-img{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--slate-50)}
.jp-sp-rel-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.jp-sp-rel-card a:hover .jp-sp-rel-img img{transform:scale(1.07)}
.jp-sp-rel-badge{position:absolute;top:12px;left:12px;background:linear-gradient(135deg,var(--green-600),var(--green-700));color:#fff;font-size:.66rem;font-weight:800;padding:4px 10px;border-radius:50px}
.jp-sp-rel-info{padding:16px}
.jp-sp-rel-cat{font-size:.7rem;color:var(--slate-400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px;font-weight:600}
.jp-sp-rel-name{font-weight:700;font-size:.9rem;color:var(--navy);margin-bottom:8px;line-height:1.35}
.jp-sp-rel-price .woocommerce-Price-amount{font-size:1rem;font-weight:800;color:var(--blue-700)}

/* Hide old WC extra content in new template */
.jp-sp-product .jp-ps-extras,.jp-sp-product .jp-trust,.jp-sp-product .jp-usp{display:none}
.jp-sp-product .woocommerce-tabs{display:none!important}
.jp-sp-product .related.products{display:none!important}
.jp-sp-product .up-sells{display:none!important}

/* SP responsive */
@media(max-width:1024px){
  .jp-sp-inner{grid-template-columns:1fr;gap:36px;padding:32px 0 56px}
  .jp-sp-gal{position:static}
  .jp-sp-feat-grid{grid-template-columns:repeat(2,1fr)}
  .jp-sp-rev-grid{grid-template-columns:1fr}
  .jp-sp-rel-grid{grid-template-columns:repeat(2,1fr)}
  .jp-sp-ki-inner{flex-direction:column;text-align:center}
  .jp-sp-ki-l{flex-direction:column}
}
@media(max-width:768px){
  .jp-sp-title{font-size:1.8rem!important}
  .jp-sp-feat-grid{grid-template-columns:1fr}
  .jp-sp-rev-sum{grid-template-columns:1fr;gap:24px;text-align:center;padding:24px}
  .jp-sp-rel-grid{grid-template-columns:1fr 1fr}
  .jp-sp-trust{grid-template-columns:1fr}
  .jp-sp-h2{margin-bottom:28px}
}

/* ---- Responsive (gemeinsam) ---- */
@media(max-width:1024px){
  .intents-grid{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr 1fr;height:auto;grid-template-rows:260px 200px 200px}
  .cat-card:first-child{grid-column:span 2}
  .tierarzt-inner,.brand-inner{grid-template-columns:1fr;gap:40px}
  .products-grid,.feat-grid{grid-template-columns:repeat(2,1fr)}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-left,.nav-right{display:none}
  .hero-headline{font-size:2.3rem}
  .products-grid,.feat-grid{grid-template-columns:1fr 1fr}
  .nl-form{flex-direction:column}
  .footer-inner{grid-template-columns:1fr}
  .intents{margin-top:0}
  .comm-inner{grid-template-columns:1fr!important;gap:24px!important}
  .tdt-card{min-height:260px!important}
}

/* ---- Cookie Banner ---- */
.cookie-bar{position:fixed;bottom:28px;right:28px;z-index:9999;width:380px;max-width:calc(100vw - 56px);background:var(--navy);border-radius:20px;box-shadow:0 24px 64px rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.08);opacity:0;transform:translateY(20px);pointer-events:none;transition:opacity .35s ease,transform .35s ease}
.cookie-bar.cookie-visible{opacity:1;transform:translateY(0);pointer-events:auto}
.cookie-inner{padding:22px 22px 18px}
.cookie-icon{font-size:1.8rem;margin-bottom:10px;display:block}
.cookie-text strong{display:block;color:#fff;font-size:.92rem;font-weight:800;margin-bottom:6px}
.cookie-text p{color:rgba(255,255,255,.65);font-size:.78rem;line-height:1.6;margin:0}
.cookie-text a{color:var(--teal-400);text-decoration:underline;text-underline-offset:3px}
.cookie-text a:hover{color:var(--teal-500)}
.cookie-actions{display:flex;gap:10px;margin-top:16px}
.cookie-btn-accept{flex:1;background:linear-gradient(135deg,var(--blue-600),var(--blue-700));color:#fff;border:none;border-radius:50px;padding:11px 18px;font-size:.82rem;font-weight:700;cursor:pointer;font-family:var(--font-sans);box-shadow:var(--shadow-blue);transition:transform .2s,box-shadow .2s}
.cookie-btn-accept:hover{transform:translateY(-1px);box-shadow:var(--shadow-blue-lg)}
.cookie-btn-decline{flex:1;background:transparent;color:rgba(255,255,255,.65);border:1.5px solid rgba(255,255,255,.18);border-radius:50px;padding:11px 18px;font-size:.82rem;font-weight:600;cursor:pointer;font-family:var(--font-sans);transition:border-color .2s,color .2s}
.cookie-btn-decline:hover{border-color:rgba(255,255,255,.5);color:#fff}
@media(max-width:480px){
  .cookie-bar{bottom:0;right:0;width:100%;max-width:100%;border-radius:20px 20px 0 0}
}
