/* =====================================================================
   FURKANS GAMING DEALS — Core Stylesheet
   Premium dark gaming theme · neon blue / purple / orange
   Self-hosted fonts (GDPR) · mobile-first · reduced-motion aware
   ===================================================================== */

/* ---------- Self-hosted fonts ---------- */
@font-face{font-family:'Chakra Petch';font-style:normal;font-weight:500;font-display:swap;
  src:url('../fonts/chakra-petch-latin-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Chakra Petch';font-style:normal;font-weight:500;font-display:swap;
  src:url('../fonts/chakra-petch-latin-ext-500-normal.woff2') format('woff2');unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Chakra Petch';font-style:normal;font-weight:600;font-display:swap;
  src:url('../fonts/chakra-petch-latin-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Chakra Petch';font-style:normal;font-weight:600;font-display:swap;
  src:url('../fonts/chakra-petch-latin-ext-600-normal.woff2') format('woff2');unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Chakra Petch';font-style:normal;font-weight:700;font-display:swap;
  src:url('../fonts/chakra-petch-latin-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Chakra Petch';font-style:normal;font-weight:700;font-display:swap;
  src:url('../fonts/chakra-petch-latin-ext-700-normal.woff2') format('woff2');unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}

@font-face{font-family:'Sora';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/sora-latin-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Sora';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/sora-latin-ext-400-normal.woff2') format('woff2');unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Sora';font-style:normal;font-weight:500;font-display:swap;
  src:url('../fonts/sora-latin-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Sora';font-style:normal;font-weight:500;font-display:swap;
  src:url('../fonts/sora-latin-ext-500-normal.woff2') format('woff2');unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Sora';font-style:normal;font-weight:600;font-display:swap;
  src:url('../fonts/sora-latin-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Sora';font-style:normal;font-weight:600;font-display:swap;
  src:url('../fonts/sora-latin-ext-600-normal.woff2') format('woff2');unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Sora';font-style:normal;font-weight:700;font-display:swap;
  src:url('../fonts/sora-latin-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Sora';font-style:normal;font-weight:700;font-display:swap;
  src:url('../fonts/sora-latin-ext-700-normal.woff2') format('woff2');unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}

/* ---------- Animatable angle for neon borders ---------- */
@property --bd-angle{syntax:'<angle>';inherits:false;initial-value:0deg;}

/* ---------- Design tokens ---------- */
:root{
  --bg:#07080E;
  --bg-2:#0B0D16;
  --surface:#101320;
  --surface-2:#161A29;
  --surface-3:#1C2133;
  --line:rgba(255,255,255,.07);
  --line-2:rgba(255,255,255,.13);

  --blue:#2E8BFF;
  --blue-bright:#49A7FF;
  --cyan:#36D0FF;
  --purple:#8B5CF6;
  --purple-bright:#A974FF;
  --pink:#FF2E9A;
  --orange:#FF9A1E;
  --orange-deep:#FF6A00;

  --text:#EEF1FB;
  --text-soft:#B7BFD6;
  --muted:#828BA8;

  --grad-brand:linear-gradient(100deg,var(--blue) 0%,var(--purple) 52%,var(--pink) 100%);
  --grad-warm:linear-gradient(100deg,var(--orange) 0%,var(--orange-deep) 100%);
  --grad-cool:linear-gradient(120deg,var(--cyan) 0%,var(--blue) 60%,var(--purple) 100%);

  --font-display:'Chakra Petch',system-ui,sans-serif;
  --font-body:'Sora',system-ui,-apple-system,'Segoe UI',sans-serif;

  --radius-sm:12px;
  --radius:18px;
  --radius-lg:26px;
  --maxw:1240px;
  --gutter:clamp(1.1rem,4vw,2.4rem);

  --ease-out:cubic-bezier(.23,1,.32,1);
  --ease-in-out:cubic-bezier(.77,0,.175,1);
  --ease-drawer:cubic-bezier(.32,.72,0,1);

  --header-h:74px;
  --shadow-card:0 18px 40px -22px rgba(0,0,0,.85);
  --glow-blue:0 0 32px -6px rgba(46,139,255,.55);
  --glow-pink:0 0 32px -6px rgba(255,46,154,.5);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box;}
*{margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
  font-size:1rem;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  min-height:100vh;
}
img,svg,video{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button,input,textarea,select{font:inherit;color:inherit;}
ul{list-style:none;}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:6px;}

/* Ambient page backdrop — deep space with faint neon haze */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(900px 600px at 12% -5%,rgba(46,139,255,.16),transparent 60%),
    radial-gradient(820px 620px at 100% 8%,rgba(255,46,154,.12),transparent 58%),
    radial-gradient(700px 700px at 50% 120%,rgba(139,92,246,.14),transparent 60%),
    var(--bg);
}
/* subtle grid texture */
body::after{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 30%,transparent 80%);
          mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 30%,transparent 80%);
}

/* ---------- Typography ---------- */
h1,h2,h3,h4,.display{font-family:var(--font-display);font-weight:700;line-height:1.04;letter-spacing:-.01em;}
.eyebrow{
  font-family:var(--font-display);font-weight:600;font-size:.78rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--cyan);display:inline-flex;align-items:center;gap:.6ch;
}
.eyebrow::before{content:"";width:26px;height:2px;border-radius:2px;background:var(--grad-cool);box-shadow:var(--glow-blue);}
h2.section-title{font-size:clamp(1.95rem,4.4vw,3.1rem);letter-spacing:-.02em;}
.lead{font-size:clamp(1.02rem,1.6vw,1.18rem);color:var(--text-soft);max-width:60ch;}
.text-grad{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;}
.text-warm{background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;color:transparent;}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
.section{padding-block:clamp(4rem,9vw,7rem);position:relative;}
.section--tight{padding-block:clamp(2.6rem,6vw,4rem);}
.center{text-align:center;}
.section-head{max-width:64ch;margin-inline:auto;margin-bottom:clamp(2.2rem,5vw,3.4rem);}
.section-head.center{display:flex;flex-direction:column;align-items:center;gap:1rem;}
.divider-glow{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--line-2),transparent);}

/* ---------- Buttons ---------- */
.btn{
  --bw:0;
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--font-display);font-weight:600;font-size:1rem;letter-spacing:.01em;
  padding:.92em 1.5em;border-radius:999px;cursor:pointer;border:0;
  position:relative;isolation:isolate;white-space:nowrap;
  transition:transform .14s var(--ease-out),box-shadow .25s var(--ease-out),filter .2s var(--ease-out);
}
.btn svg{width:1.15em;height:1.15em;flex:none;}
.btn:active{transform:translateY(1px) scale(.985);}

.btn-primary{color:#fff;background:var(--grad-brand);box-shadow:0 10px 30px -10px rgba(46,139,255,.6),0 4px 14px -8px rgba(255,46,154,.5);}
.btn-primary::after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--grad-brand);filter:blur(16px);opacity:.5;z-index:-1;transition:opacity .25s var(--ease-out);}
.btn-warm{color:#1a0e00;background:var(--grad-warm);box-shadow:0 10px 30px -10px rgba(255,154,30,.65);}
.btn-warm::after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--grad-warm);filter:blur(16px);opacity:.45;z-index:-1;transition:opacity .25s var(--ease-out);}
.btn-whatsapp{color:#03210f;background:linear-gradient(100deg,#3ddc84,#25d366);box-shadow:0 10px 30px -10px rgba(37,211,102,.6);}
.btn-ghost{color:var(--text);background:rgba(255,255,255,.04);border:1px solid var(--line-2);backdrop-filter:blur(6px);}
.btn-ghost:hover{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.07);}
.btn-sm{padding:.62em 1.05em;font-size:.9rem;}
.btn-lg{padding:1.05em 1.9em;font-size:1.08rem;}
.btn-block{width:100%;}

@media (hover:hover) and (pointer:fine){
  .btn-primary:hover,.btn-warm:hover,.btn-whatsapp:hover{transform:translateY(-2px);filter:brightness(1.06);}
  .btn-primary:hover::after,.btn-warm:hover::after{opacity:.8;}
}

/* ---------- Header / Nav ---------- */
/* ---------- Promo bar ---------- */
.promo-bar{
  position:relative;z-index:90;
  display:flex;align-items:center;justify-content:center;gap:.6rem;
  padding:.6rem 1.2rem;text-align:center;
  font-family:var(--font-display);font-weight:500;font-size:.85rem;letter-spacing:.01em;
  color:#06122a;
  background:linear-gradient(100deg,var(--cyan),var(--blue) 42%,var(--purple));
  background-size:200% 100%;animation:promo-shift 9s linear infinite;
}
.promo-bar .promo-text{line-height:1.3;}
@media (prefers-reduced-motion:reduce){.promo-bar{animation:none;}}
@keyframes promo-shift{to{background-position:200% 0;}}
@media(max-width:560px){.promo-bar{font-size:.78rem;padding:.5rem .9rem;}}

.site-header{
  position:sticky;top:0;z-index:80;
  height:var(--header-h);display:flex;align-items:center;
  background:rgba(8,9,16,.55);
  backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  border-bottom:1px solid transparent;
  transition:background .3s var(--ease-out),border-color .3s var(--ease-out);
}
.site-header.scrolled{background:rgba(8,9,16,.82);border-bottom-color:var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;font-size:1.06rem;}
.brand img{width:42px;height:42px;border-radius:11px;}
.brand b{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;}
.brand span{color:var(--text-soft);font-weight:600;}

.nav-links{display:flex;align-items:center;gap:.35rem;}
.nav-links a{
  font-family:var(--font-display);font-weight:500;font-size:.94rem;color:var(--text-soft);
  padding:.5rem .85rem;border-radius:10px;position:relative;
  transition:color .2s var(--ease-out),background .2s var(--ease-out);
}
.nav-links a::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.34rem;height:2px;border-radius:2px;background:var(--grad-cool);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease-out);opacity:0;}
.nav-links a:hover{color:var(--text);}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{transform:scaleX(1);opacity:1;}
.nav-links a[aria-current="page"]{color:var(--text);}
.nav-cta{display:flex;align-items:center;gap:.6rem;}

.nav-toggle{display:none;width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.05);border:1px solid var(--line-2);cursor:pointer;align-items:center;justify-content:center;}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:20px;height:2px;border-radius:2px;background:var(--text);transition:transform .3s var(--ease-out),opacity .2s var(--ease-out);}
.nav-toggle span{position:relative;}
.nav-toggle span::before{position:absolute;top:-6px;}
.nav-toggle span::after{position:absolute;top:6px;}
body.nav-open .nav-toggle span{background:transparent;}
body.nav-open .nav-toggle span::before{transform:translateY(6px) rotate(45deg);}
body.nav-open .nav-toggle span::after{transform:translateY(-6px) rotate(-45deg);}

/* ---------- Hero ---------- */
.hero{position:relative;padding-top:clamp(2.5rem,7vw,4.5rem);padding-bottom:clamp(3rem,8vw,5.5rem);overflow:clip;}
.hero-glow{position:absolute;inset:0;z-index:-1;pointer-events:none;}
.hero-glow::before,.hero-glow::after{content:"";position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;}
.hero-glow::before{width:520px;height:520px;left:-8%;top:-6%;background:radial-gradient(circle,rgba(46,139,255,.5),transparent 70%);animation:drift1 14s var(--ease-in-out) infinite alternate;}
.hero-glow::after{width:560px;height:560px;right:-10%;top:10%;background:radial-gradient(circle,rgba(255,46,154,.4),transparent 70%);animation:drift2 16s var(--ease-in-out) infinite alternate;}

.hero-inner{display:grid;gap:clamp(2rem,5vw,3.5rem);align-items:center;}
.hero-logo-wrap{position:relative;display:flex;justify-content:center;margin-inline:auto;width:min(440px,82vw);}
.hero-logo-wrap .halo{position:absolute;inset:-8% -8%;background:radial-gradient(circle at 50% 45%,rgba(139,92,246,.45),rgba(46,139,255,.25) 38%,transparent 66%);filter:blur(34px);z-index:-1;animation:pulse-halo 6s var(--ease-in-out) infinite;}
.hero-logo-wrap img{width:100%;border-radius:30px;filter:drop-shadow(0 24px 60px rgba(0,0,0,.6));}

.hero-copy{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.4rem;}
.hero h1{font-size:clamp(2.35rem,6.4vw,4.4rem);letter-spacing:-.025em;}
.hero h1 .line{display:block;}
.hero .lead{font-size:clamp(1.05rem,1.9vw,1.28rem);}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.4rem 2rem;justify-content:center;margin-top:.4rem;color:var(--muted);font-size:.92rem;}
.hero-trust b{color:var(--text);font-family:var(--font-display);}
.hero-trust .dot{display:inline-flex;align-items:center;gap:.5ch;}
.hero-trust .dot::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--grad-cool);box-shadow:0 0 10px var(--blue);}

@media(min-width:920px){
  .hero-inner{grid-template-columns:1.05fr 1fr;}
  .hero-copy{text-align:left;align-items:flex-start;}
  .hero-actions,.hero-trust{justify-content:flex-start;}
  .hero-logo-wrap{order:2;}
}

/* Floating PlayStation glyphs (signature motif) */
.ps-field{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden;}
.ps-glyph{position:absolute;font-family:var(--font-display);font-weight:600;opacity:.16;filter:drop-shadow(0 0 8px currentColor);will-change:transform;}
.ps-glyph.g1{top:14%;left:7%;font-size:2.2rem;color:var(--blue);animation:float-y 9s ease-in-out infinite;}
.ps-glyph.g2{top:24%;right:9%;font-size:1.7rem;color:var(--pink);animation:float-y 11s ease-in-out infinite 1s;}
.ps-glyph.g3{bottom:18%;left:13%;font-size:1.9rem;color:var(--orange);animation:float-y 10s ease-in-out infinite .6s;}
.ps-glyph.g4{bottom:26%;right:12%;font-size:2.4rem;color:var(--purple);animation:float-y 12s ease-in-out infinite 1.4s;}

/* ---------- Pills / chips / badges ---------- */
.chip{display:inline-flex;align-items:center;gap:.5ch;padding:.34em .8em;border-radius:999px;font-size:.78rem;font-weight:600;font-family:var(--font-display);letter-spacing:.02em;border:1px solid var(--line-2);background:rgba(255,255,255,.04);color:var(--text-soft);}
.badge-deal{position:absolute;top:.85rem;left:.85rem;z-index:3;padding:.3em .7em;border-radius:8px;font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;color:#1a0e00;background:var(--grad-warm);box-shadow:0 6px 16px -6px rgba(255,154,30,.7);}
.badge-cat{position:absolute;top:.85rem;right:.85rem;z-index:3;padding:.3em .65em;border-radius:8px;font-size:.7rem;font-weight:600;letter-spacing:.03em;backdrop-filter:blur(8px);background:rgba(8,9,16,.6);border:1px solid var(--line-2);color:var(--text-soft);}

/* ---------- Cards ---------- */
.grid{display:grid;gap:clamp(1rem,2.4vw,1.6rem);}
.grid-products{grid-template-columns:repeat(auto-fill,minmax(min(100%,250px),1fr));}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(min(100%,230px),1fr));}

.card{
  position:relative;background:linear-gradient(180deg,var(--surface-2),var(--surface));
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-card);
  transition:transform .3s var(--ease-out),border-color .3s var(--ease-out),box-shadow .3s var(--ease-out);
}
/* rotating neon border (signature) */
.card-neon::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;z-index:4;pointer-events:none;
  background:conic-gradient(from var(--bd-angle),transparent 0%,var(--blue) 14%,var(--cyan) 24%,var(--purple) 42%,var(--pink) 58%,transparent 72%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;
  opacity:0;transition:opacity .3s var(--ease-out);
}
@media (hover:hover) and (pointer:fine){
  .card-neon:hover{transform:translateY(-6px);border-color:transparent;box-shadow:0 28px 50px -26px rgba(0,0,0,.9),0 0 30px -10px rgba(139,92,246,.4);}
  .card-neon:hover::before{opacity:1;animation:spin-border 3.4s linear infinite;}
}
.card-neon.is-featured::before{opacity:.85;animation:spin-border 5s linear infinite;}

.product-media{position:relative;aspect-ratio:4/3;overflow:hidden;background:radial-gradient(circle at 50% 40%,var(--surface-3),var(--bg-2));}
.product-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out);}
.product-media .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);}
.product-media .placeholder svg{width:46px;height:46px;opacity:.5;}
@media (hover:hover) and (pointer:fine){.card:hover .product-media img{transform:scale(1.06);}}

.product-body{padding:1.05rem 1.1rem 1.2rem;display:flex;flex-direction:column;gap:.55rem;}
.product-title{font-family:var(--font-display);font-weight:600;font-size:1.06rem;line-height:1.2;letter-spacing:-.01em;}
.product-desc{font-size:.88rem;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em;}
.product-foot{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-top:.3rem;}
.price{font-family:var(--font-display);font-weight:700;font-size:1.4rem;letter-spacing:-.01em;color:var(--text);display:inline-flex;align-items:baseline;gap:.3ch;}
.price .cur{font-size:.85em;color:var(--orange);}
.price-old{font-size:.92rem;color:var(--muted);text-decoration:line-through;margin-left:.4ch;font-family:var(--font-body);}
.stock{font-size:.74rem;font-weight:600;padding:.26em .6em;border-radius:7px;font-family:var(--font-display);letter-spacing:.02em;}
.stock.in{color:#7df0b0;background:rgba(37,211,102,.12);border:1px solid rgba(37,211,102,.3);}
.stock.out{color:#ffa3a3;background:rgba(255,77,77,.1);border:1px solid rgba(255,77,77,.28);}

/* ---------- Feature / why-us cards ---------- */
.feature{position:relative;padding:1.7rem 1.5rem;border-radius:var(--radius);background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);overflow:hidden;transition:transform .3s var(--ease-out),border-color .3s var(--ease-out);}
.feature::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 100% 0%,rgba(46,139,255,.12),transparent 55%);opacity:0;transition:opacity .3s var(--ease-out);pointer-events:none;}
@media (hover:hover) and (pointer:fine){.feature:hover{transform:translateY(-4px);border-color:var(--line-2);} .feature:hover::after{opacity:1;}}
.feature-icon{width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;background:rgba(46,139,255,.1);border:1px solid var(--line-2);color:var(--cyan);}
.feature-icon svg{width:26px;height:26px;}
.feature.i-purple .feature-icon{background:rgba(139,92,246,.12);color:var(--purple-bright);}
.feature.i-orange .feature-icon{background:rgba(255,154,30,.12);color:var(--orange);}
.feature.i-pink .feature-icon{background:rgba(255,46,154,.12);color:var(--pink);}
.feature h3{font-size:1.18rem;margin-bottom:.5rem;}
.feature p{color:var(--text-soft);font-size:.94rem;}

/* ---------- Categories strip ---------- */
.cat-tabs{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;}
.cat-tab{
  font-family:var(--font-display);font-weight:500;font-size:.92rem;
  padding:.6em 1.15em;border-radius:999px;cursor:pointer;
  background:rgba(255,255,255,.04);border:1px solid var(--line-2);color:var(--text-soft);
  display:inline-flex;align-items:center;gap:.55ch;
  transition:color .2s var(--ease-out),border-color .2s var(--ease-out),background .2s var(--ease-out),transform .14s var(--ease-out);
}
.cat-tab .ps{font-weight:700;}
.cat-tab:hover{color:var(--text);border-color:rgba(255,255,255,.3);}
.cat-tab:active{transform:scale(.97);}
.cat-tab.active{color:#fff;border-color:transparent;background:var(--grad-brand);box-shadow:0 8px 22px -10px rgba(139,92,246,.7);}
.cat-tab .count{font-size:.72em;opacity:.7;}

/* ---------- Search / toolbar ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;margin-bottom:2rem;}
.search{position:relative;flex:1 1 260px;max-width:420px;}
.search svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted);pointer-events:none;}
.search input{width:100%;padding:.85rem 1rem .85rem 2.7rem;border-radius:999px;background:var(--surface);border:1px solid var(--line-2);transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out);}
.search input::placeholder{color:var(--muted);}
.search input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(46,139,255,.18);}
.select-wrap{position:relative;}
.select-wrap select{appearance:none;padding:.85rem 2.6rem .85rem 1.1rem;border-radius:999px;background:var(--surface);border:1px solid var(--line-2);cursor:pointer;font-family:var(--font-display);font-size:.92rem;}
.select-wrap::after{content:"";position:absolute;right:1.1rem;top:50%;width:8px;height:8px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:translateY(-65%) rotate(45deg);pointer-events:none;}
.result-count{color:var(--muted);font-size:.9rem;}
.result-count b{color:var(--text);font-family:var(--font-display);}

.empty-state{text-align:center;padding:4rem 1rem;color:var(--muted);grid-column:1/-1;}
.empty-state .ps-big{font-family:var(--font-display);font-size:2.6rem;letter-spacing:.3em;opacity:.4;margin-bottom:1rem;}
.empty-state h3{color:var(--text-soft);margin-bottom:.4rem;}

/* ---------- Termine (flea market dates) ---------- */
.termin-list{display:grid;gap:1rem;}
.termin{
  position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:1.2rem;align-items:center;
  padding:1.25rem 1.4rem;border-radius:var(--radius);background:linear-gradient(180deg,var(--surface-2),var(--surface));
  border:1px solid var(--line);overflow:hidden;
  transition:transform .3s var(--ease-out),border-color .3s var(--ease-out);
}
.termin::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--grad-cool);}
@media (hover:hover) and (pointer:fine){.termin:hover{transform:translateX(4px);border-color:var(--line-2);}}
.termin.is-next{border-color:rgba(46,139,255,.4);box-shadow:0 0 30px -14px rgba(46,139,255,.6);}
.termin-date{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:74px;padding:.6rem .4rem;border-radius:14px;background:rgba(46,139,255,.08);border:1px solid var(--line-2);}
.termin-date .d{font-family:var(--font-display);font-weight:700;font-size:1.7rem;line-height:1;}
.termin-date .m{font-family:var(--font-display);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);margin-top:.2rem;}
.termin-info h3{font-size:1.15rem;margin-bottom:.25rem;}
.termin-info .meta{display:flex;flex-wrap:wrap;gap:.4rem 1rem;color:var(--muted);font-size:.88rem;}
.termin-info .meta span{display:inline-flex;align-items:center;gap:.45ch;}
.termin-info .meta svg{width:14px;height:14px;color:var(--blue-bright);}
.termin-next-tag{position:absolute;top:0;right:0;font-family:var(--font-display);font-weight:600;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;padding:.3em .7em;border-bottom-left-radius:12px;color:#031;background:linear-gradient(100deg,#3ddc84,#25d366);}
@media(max-width:600px){
  .termin{grid-template-columns:auto 1fr;gap:.9rem;}
  .termin-cta-col{grid-column:1/-1;}
}

/* ---------- Map ---------- */
.map-shell{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-2);box-shadow:var(--shadow-card);min-height:380px;}
#map{width:100%;height:clamp(380px,52vh,560px);background:var(--bg-2);}
.leaflet-container{background:#0a0c14 !important;font-family:var(--font-body) !important;}
.leaflet-popup-content-wrapper{background:var(--surface-2) !important;color:var(--text) !important;border:1px solid var(--line-2);border-radius:14px !important;box-shadow:var(--shadow-card) !important;}
.leaflet-popup-tip{background:var(--surface-2) !important;}
.leaflet-popup-content{margin:.85rem 1rem !important;font-size:.9rem;}
.leaflet-popup-content b{font-family:var(--font-display);}
.leaflet-control-zoom a{background:var(--surface-2) !important;color:var(--text) !important;border-color:var(--line-2) !important;}
.leaflet-control-attribution{background:rgba(8,9,16,.7) !important;color:var(--muted) !important;}
.leaflet-control-attribution a{color:var(--blue-bright) !important;}
.map-pin-fallback{display:flex;flex-direction:column;gap:.4rem;align-items:center;justify-content:center;height:100%;color:var(--muted);text-align:center;padding:2rem;}

/* ---------- Forms ---------- */
.form{display:grid;gap:1.1rem;}
.field{display:flex;flex-direction:column;gap:.45rem;}
.field label{font-family:var(--font-display);font-weight:500;font-size:.88rem;color:var(--text-soft);}
.field label .req{color:var(--pink);}
.field input,.field textarea{
  width:100%;padding:.85rem 1rem;border-radius:13px;background:var(--surface);
  border:1px solid var(--line-2);transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out);
}
.field textarea{resize:vertical;min-height:130px;}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(46,139,255,.16);}
.field-row{display:grid;gap:1.1rem;}
@media(min-width:560px){.field-row{grid-template-columns:1fr 1fr;}}
.form-note{font-size:.82rem;color:var(--muted);}
.form-note a{color:var(--blue-bright);text-decoration:underline;text-underline-offset:2px;}
.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.86rem;color:var(--text-soft);}
.consent input{margin-top:.25rem;width:18px;height:18px;accent-color:var(--blue);flex:none;}
.form-status{font-size:.92rem;padding:.85rem 1rem;border-radius:12px;display:none;}
.form-status.ok{display:block;color:#9af0c0;background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.3);}
.form-status.err{display:block;color:#ffb0b0;background:rgba(255,77,77,.1);border:1px solid rgba(255,77,77,.3);}

/* ---------- Contact / split layouts ---------- */
.split{display:grid;gap:clamp(2rem,5vw,3.5rem);align-items:start;}
@media(min-width:880px){.split{grid-template-columns:1.1fr .9fr;}}
.contact-card{padding:1.5rem;border-radius:var(--radius);background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);}
.contact-row{display:flex;gap:1rem;align-items:center;padding:.95rem 0;border-bottom:1px solid var(--line);}
.contact-row:last-child{border-bottom:0;}
.contact-row .ic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:rgba(46,139,255,.1);border:1px solid var(--line-2);color:var(--cyan);flex:none;}
.contact-row .ic svg{width:22px;height:22px;}
.contact-row .label{font-size:.78rem;color:var(--muted);font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;}
.contact-row .val{font-weight:600;color:var(--text);font-size:1.02rem;word-break:break-word;}
.contact-row .val:hover{color:var(--blue-bright);}

/* ---------- About ---------- */
.about-hero{display:grid;gap:clamp(2rem,5vw,3.5rem);align-items:center;}
@media(min-width:880px){.about-hero{grid-template-columns:1fr 1fr;}}
.about-figure{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line-2);aspect-ratio:4/3;background:radial-gradient(circle at 50% 35%,var(--surface-3),var(--bg-2));display:flex;align-items:center;justify-content:center;}
.about-figure img{width:78%;filter:drop-shadow(0 20px 50px rgba(0,0,0,.5));}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.6rem;}
.stat{padding:1.1rem 1rem;border-radius:var(--radius);background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);text-align:center;}
.stat .num{font-family:var(--font-display);font-weight:700;font-size:1.85rem;line-height:1;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;}
.stat .lab{font-size:.78rem;color:var(--muted);margin-top:.4rem;}

/* ---------- CTA band ---------- */
.cta-band{position:relative;border-radius:var(--radius-lg);overflow:hidden;padding:clamp(2.4rem,6vw,4rem);text-align:center;background:linear-gradient(135deg,rgba(46,139,255,.16),rgba(139,92,246,.14) 45%,rgba(255,46,154,.14));border:1px solid var(--line-2);}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% -20%,rgba(139,92,246,.4),transparent 60%);pointer-events:none;}
.cta-band h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:.8rem;position:relative;}
.cta-band p{max-width:52ch;margin:0 auto 1.7rem;color:var(--text-soft);position:relative;}
.cta-band .hero-actions{position:relative;}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line);margin-top:2rem;background:linear-gradient(180deg,transparent,rgba(8,9,16,.6));padding-block:clamp(2.6rem,5vw,3.6rem);}
.footer-grid{display:grid;gap:2rem;grid-template-columns:1fr;}
@media(min-width:760px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr;}}
.footer-brand .brand{margin-bottom:.9rem;}
.footer-brand p{color:var(--muted);font-size:.9rem;max-width:38ch;}
.footer-col h4{font-family:var(--font-display);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-soft);margin-bottom:1rem;}
.footer-col a{display:block;color:var(--muted);font-size:.92rem;padding:.3rem 0;transition:color .2s var(--ease-out);}
.footer-col a:hover{color:var(--text);}
.footer-social{display:flex;gap:.7rem;margin-top:1rem;}
.footer-social a{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04);border:1px solid var(--line-2);color:var(--text-soft);transition:color .2s var(--ease-out),border-color .2s var(--ease-out),transform .14s var(--ease-out);}
.footer-social a:hover{color:var(--text);border-color:rgba(255,255,255,.3);transform:translateY(-2px);}
.footer-social svg{width:20px;height:20px;}
.footer-bottom{display:flex;flex-wrap:wrap;gap:.8rem 1.4rem;align-items:center;justify-content:space-between;margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid var(--line);color:var(--muted);font-size:.84rem;}
.footer-bottom nav{display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;}
.footer-bottom nav a:hover{color:var(--text);}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;right:clamp(1rem,3vw,1.6rem);bottom:clamp(1rem,3vw,1.6rem);z-index:70;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3ddc84,#25d366);box-shadow:0 14px 34px -10px rgba(37,211,102,.7);color:#fff;transition:transform .2s var(--ease-out),box-shadow .25s var(--ease-out);}
.wa-float svg{width:30px;height:30px;}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid rgba(37,211,102,.6);animation:wa-ring 2.4s var(--ease-out) infinite;}
@media (hover:hover) and (pointer:fine){.wa-float:hover{transform:scale(1.08);}}

/* ---------- Breadcrumb / page header ---------- */
.page-head{padding-top:clamp(2.4rem,6vw,3.6rem);padding-bottom:clamp(1.4rem,3vw,2rem);text-align:center;position:relative;}
.page-head h1{font-size:clamp(2.1rem,5.4vw,3.5rem);letter-spacing:-.02em;}
.page-head p{margin-top:.9rem;}
.crumb{display:flex;gap:.5ch;justify-content:center;color:var(--muted);font-size:.82rem;margin-bottom:1rem;font-family:var(--font-display);}
.crumb a:hover{color:var(--text-soft);}

/* ---------- Legal pages ---------- */
.legal{max-width:780px;margin-inline:auto;}
.legal h2{font-size:1.4rem;margin:2rem 0 .8rem;}
.legal h3{font-size:1.1rem;margin:1.4rem 0 .5rem;color:var(--text-soft);}
.legal p,.legal li{color:var(--text-soft);font-size:.95rem;margin-bottom:.7rem;}
.legal ul{list-style:disc;padding-left:1.4rem;margin-bottom:1rem;}
.legal a{color:var(--blue-bright);text-decoration:underline;text-underline-offset:2px;word-break:break-word;}
.legal strong{color:var(--text);}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out);}
.reveal.in{opacity:1;transform:none;}
.reveal-stagger>*{opacity:0;transform:translateY(18px);}
.reveal-stagger.in>*{animation:stagger-in .6s var(--ease-out) forwards;}
.reveal-stagger.in>*:nth-child(1){animation-delay:.02s;}
.reveal-stagger.in>*:nth-child(2){animation-delay:.07s;}
.reveal-stagger.in>*:nth-child(3){animation-delay:.12s;}
.reveal-stagger.in>*:nth-child(4){animation-delay:.17s;}
.reveal-stagger.in>*:nth-child(5){animation-delay:.22s;}
.reveal-stagger.in>*:nth-child(6){animation-delay:.27s;}
.reveal-stagger.in>*:nth-child(7){animation-delay:.32s;}
.reveal-stagger.in>*:nth-child(8){animation-delay:.37s;}

/* ---------- Keyframes ---------- */
@keyframes spin-border{to{--bd-angle:360deg;}}
@keyframes drift1{from{transform:translate(0,0);}to{transform:translate(40px,30px);}}
@keyframes drift2{from{transform:translate(0,0);}to{transform:translate(-50px,40px);}}
@keyframes pulse-halo{0%,100%{opacity:.7;transform:scale(1);}50%{opacity:1;transform:scale(1.05);}}
@keyframes float-y{0%,100%{transform:translateY(0) rotate(0);}50%{transform:translateY(-16px) rotate(6deg);}}
@keyframes wa-ring{0%{transform:scale(1);opacity:.8;}100%{transform:scale(1.6);opacity:0;}}
@keyframes stagger-in{to{opacity:1;transform:none;}}
@keyframes fade-up{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

/* Power-on hero entrance */
.boot .hero-logo-wrap img{animation:boot-logo 1s var(--ease-out) both;}
.boot .hero-copy>*{animation:fade-up .7s var(--ease-out) both;}
.boot .hero-copy>*:nth-child(1){animation-delay:.1s;}
.boot .hero-copy>*:nth-child(2){animation-delay:.2s;}
.boot .hero-copy>*:nth-child(3){animation-delay:.3s;}
.boot .hero-copy>*:nth-child(4){animation-delay:.4s;}
.boot .hero-copy>*:nth-child(5){animation-delay:.5s;}
@keyframes boot-logo{0%{opacity:0;transform:scale(.92);filter:brightness(.4) blur(6px);}55%{filter:brightness(1.25) blur(0);}100%{opacity:1;transform:scale(1);filter:brightness(1);}}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.08s !important;}
  .reveal{opacity:1 !important;transform:none !important;}
  .reveal-stagger>*{opacity:1 !important;transform:none !important;}
  .hero-glow::before,.hero-glow::after,.ps-glyph,.wa-float::after,.hero-logo-wrap .halo{animation:none !important;}
  .card-neon:hover::before,.card-neon.is-featured::before{animation:none !important;opacity:.7;}
}

/* ---------- Mobile nav drawer ---------- */
@media(min-width:881px){.nav-links .btn{margin-left:.55rem;}}

@media(max-width:880px){
  .nav-toggle{display:flex;}
  .nav-cta .btn-ghost{display:none;}
  .nav-links{
    position:fixed;inset:var(--header-h) 0 auto 0;flex-direction:column;align-items:stretch;gap:.2rem;
    padding:1rem var(--gutter) 1.6rem;background:rgba(8,9,16,.97);backdrop-filter:blur(20px);
    border-bottom:1px solid var(--line);
    transform:translateY(-12px);opacity:0;pointer-events:none;visibility:hidden;
    transition:transform .3s var(--ease-drawer),opacity .25s var(--ease-out),visibility 0s linear .3s;
  }
  body.nav-open .nav-links{transform:none;opacity:1;pointer-events:auto;visibility:visible;transition:transform .35s var(--ease-drawer),opacity .25s var(--ease-out);}
  .nav-links a{padding:.85rem 1rem;font-size:1.05rem;border-radius:12px;}
  .nav-links a::after{display:none;}
  .nav-links a:hover,.nav-links a[aria-current="page"]{background:rgba(255,255,255,.05);}
  .nav-links .btn{margin-top:.6rem;}
}

/* small screens density */
@media(max-width:420px){
  :root{--header-h:66px;}
  .price{font-size:1.25rem;}
  .stat-row{grid-template-columns:1fr 1fr;}
}

/* print-ish / selection */
::selection{background:rgba(46,139,255,.35);color:#fff;}

/* ── 404 / Fehlerseite ───────────────────────────── */
.error-page{max-width:640px;margin-inline:auto;text-align:center;padding:48px 0 24px;}
.error-code{font-family:var(--font-display,"Chakra Petch",sans-serif);font-size:clamp(72px,18vw,160px);line-height:.9;font-weight:700;
  background:linear-gradient(135deg,var(--blue,#2b8fff),var(--pink,#FF2E9A) 60%,var(--orange,#ff9f1c));
  -webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 28px rgba(43,143,255,.35));}
.error-page h1{margin:.2em 0 .4em;}
.error-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:28px;}
