/*
Theme Name: PIRALO
Theme URI: https://www.piralo.si/
Author: PIRALO D.O.O.
Author URI: https://www.piralo.si/
Description: Modern, animated, fully responsive WordPress theme for PIRALO D.O.O.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: piralo
Tags: business, technology, modern, responsive, animations, red
*/

/* ================================================================
   PIRALO — DESIGN SYSTEM v2
   Bold. Data-driven. Red-forward. Diagonal geometry.
   ================================================================ */

:root {
  --red:       #c62828;
  --red-hi:    #ef5350;
  --red-deep:  #8e1b1b;
  --red-glow:  rgba(198,40,40,.18);
  --ink:       #0c0c0f;
  --ink-2:     #141418;
  --ink-3:     #1c1c22;
  --ink-4:     #27272e;
  --white:     #ffffff;
  --snow:      #f8f8fb;
  --smoke:     #f0f0f4;
  --muted:     #8a8a96;
  --line:      rgba(255,255,255,.07);
  --line-l:    rgba(0,0,0,.08);

  --ff-head: "Archivo", "Arial Narrow", sans-serif;
  --ff-body: "Sora", system-ui, sans-serif;

  --max:  1320px;
  --pad:  clamp(1.2rem, 4vw, 4rem);
  --r:    18px;
  --r-sm: 10px;

  --ease:     cubic-bezier(.16,.84,.44,1);
  --spring:   cubic-bezier(.22,1,.36,1);
  --snap:     cubic-bezier(.77,0,.18,1);
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--ff-body);background:var(--ink);color:var(--white);line-height:1.65;font-size:17px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
h1,h2,h3,h4{font-family:var(--ff-head);font-weight:900;line-height:1.0;letter-spacing:-.025em;text-transform:uppercase}
.container{max-width:var(--max);margin:0 auto;padding-inline:var(--pad)}

/* ================================================================
   TOP TICKER BAR
   ================================================================ */
.ticker-bar{
  background:var(--red);
  padding:.55rem 0;
  text-align:center;
  font-family:var(--ff-head);
  font-size:.72rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:rgba(255,255,255,.88);
  position:relative;
  z-index:1001;
}

/* ================================================================
   HEADER
   ================================================================ */
.site-header{
  position:sticky;top:0;
  z-index:1000;
  background:rgba(12,12,15,.92);
  backdrop-filter:blur(18px) saturate(1.6);
  border-bottom:1px solid var(--line);
  transition:background .3s var(--ease),box-shadow .3s;
}
.site-header.at-top{background:transparent;border-bottom-color:transparent}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding-block:.9rem}

/* Brand / logo */
.brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.brand img{height:46px;width:auto;filter:invert(1);mix-blend-mode:screen}
.brand-text{font-family:var(--ff-head);font-size:1.5rem;font-weight:900;letter-spacing:-.03em;color:var(--white);text-transform:uppercase}
.brand-text em{color:var(--red-hi);font-style:normal}

/* Nav links */
.nav-main{display:flex;align-items:center;gap:2.4rem}
.nav-main>ul{display:flex;align-items:center;gap:1.8rem}
.nav-main a{
  font-family:var(--ff-head);font-weight:700;font-size:.82rem;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.78);
  position:relative;padding:.35rem 0;
  transition:color .25s;
}
.nav-main a:hover,.nav-main .current-menu-item>a{color:var(--white)}
.nav-main a::before{
  content:"";position:absolute;left:0;bottom:-2px;
  width:100%;height:2px;background:var(--red-hi);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--spring);
}
.nav-main a:hover::before,.nav-main .current-menu-item>a::before{transform:scaleX(1)}

/* Dropdown */
.nav-main .menu-item-has-children{position:relative}
.nav-main .sub-menu{
  position:absolute;top:calc(100% + 16px);left:-1rem;
  background:var(--ink-2);
  border:1px solid rgba(198,40,40,.2);
  border-top:2px solid var(--red);
  border-radius:0 0 var(--r-sm) var(--r-sm);
  padding:.5rem;min-width:220px;
  display:grid;gap:.1rem;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:all .3s var(--spring);
  box-shadow:0 24px 48px -12px rgba(0,0,0,.8);
}
.nav-main .menu-item-has-children:hover .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-main .sub-menu a{display:block;padding:.7rem 1rem;border-radius:6px;font-size:.8rem;color:rgba(255,255,255,.7)}
.nav-main .sub-menu a::before{display:none}
.nav-main .sub-menu a:hover{background:var(--ink-3);color:var(--red-hi)}

/* CTA button in nav */
.nav-cta{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:4px 16px;background:var(--red);color:var(--white);
  font-family:var(--ff-head);font-weight:800;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  border-radius:100px;
  transition:background .25s,transform .25s,box-shadow .25s;
  white-space:nowrap;
}
.nav-cta:hover{background:var(--red-hi);transform:translateY(-2px);box-shadow:0 12px 30px rgba(198,40,40,.45)}
.nav-cta svg{width:14px;height:14px;transition:transform .3s var(--spring)}
.nav-cta:hover svg{transform:translateX(4px)}

/* Scroll lock when mobile nav is open (works on iOS Safari) */
html.nav-open{overflow:hidden;position:fixed;width:100%}

/* Mobile burger */
.nav-toggle{display:none;flex-direction:column;gap:5px;width:28px;z-index:1100;padding:4px 0}
.nav-toggle span{height:2px;width:100%;background:var(--white);border-radius:2px;transition:.4s var(--ease)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ================================================================
   HERO — SPLIT LAYOUT
   ================================================================ */
.hero{
  position:relative;
  min-height:calc(100vh - 90px);
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  overflow:hidden;
}

/* Diagonal divider between the two halves */
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(105deg,var(--ink) 52%,transparent 52%);
  pointer-events:none;
  z-index:1;
}

/* Left half — dark */
.hero__left{
  position:relative;z-index:2;
  padding:6rem var(--pad) 6rem calc((100vw - var(--max)) / 2 + var(--pad));
  max-width:calc(var(--max) / 2 + (100vw - var(--max)) / 2);
}
@media(min-width:1321px){.hero__left{padding-left:calc((100vw - 1320px)/2 + 4rem)}}

/* Right half — red with polygon shapes */
.hero__right{
  position:absolute;right:0;top:0;bottom:0;
  width:52%;
  background:linear-gradient(135deg,var(--red-deep) 0%,var(--red) 50%,#d73232 100%);
  overflow:hidden;
}
.hero__right-img{
  position:absolute;inset:0;
  opacity:.22;
  mix-blend-mode:luminosity;
}
.hero__right-img img{width:100%;height:100%;object-fit:cover}

/* Polygon overlay shapes on right */
.hero__right::before{
  content:"";position:absolute;
  width:300px;height:300px;
  top:-60px;right:-60px;
  background:rgba(255,255,255,.06);
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  animation:hexSpin 18s linear infinite;
}
.hero__right::after{
  content:"";position:absolute;
  width:180px;height:180px;
  bottom:80px;left:40px;
  background:rgba(0,0,0,.12);
  clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);
  animation:hexSpin 12s linear infinite reverse;
}
@keyframes hexSpin{to{transform:rotate(360deg)}}

/* Data badge in hero right */
.hero__badge{
  position:absolute;z-index:3;
  bottom:2.5rem;right:2.5rem;
  background:rgba(0,0,0,.4);
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--r);
  padding:1.4rem 1.8rem;
  font-family:var(--ff-head);
}
.hero__badge .big{display:block;font-size:3rem;font-weight:900;line-height:1;color:var(--white)}
.hero__badge .sm{font-size:.72rem;letter-spacing:.2em;color:rgba(255,255,255,.65);text-transform:uppercase;margin-top:.3rem}

/* Hero content */
.hero__tag{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--ff-head);font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--red-hi);margin-bottom:1.6rem;
}
.hero__tag::before{content:"";width:28px;height:2px;background:var(--red-hi)}
.hero h1{
  font-size:clamp(2.8rem,5.5vw,5.6rem);
  margin-bottom:1.6rem;
  line-height:.96;
}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line span{display:block;transform:translateY(110%)}
.hero h1 .hl{
  -webkit-text-stroke:2px var(--red-hi);
  color:transparent;
}
.hero p.lead{font-size:clamp(1rem,1.6vw,1.2rem);color:rgba(255,255,255,.65);max-width:520px;margin-bottom:2.6rem;line-height:1.8}
.hero__btns{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:3.5rem}

/* Pill button (primary) */
.btn{
  display:inline-flex;align-items:center;gap:.65rem;
  padding:1rem 2rem;
  background:var(--red);color:var(--white);
  font-family:var(--ff-head);font-weight:800;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;
  border-radius:100px;
  border:2px solid transparent;
  transition:all .3s var(--spring);
  white-space:nowrap;
}
.btn:hover{background:var(--red-hi);transform:translateY(-3px);box-shadow:0 16px 36px rgba(198,40,40,.45)}
.btn--ghost{background:transparent;border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.85)}
.btn--ghost:hover{border-color:var(--red-hi);color:var(--white);background:rgba(198,40,40,.1);box-shadow:none;transform:translateY(-2px)}
.btn--dark{background:var(--ink-2);border-color:var(--line);color:var(--white)}
.btn--dark:hover{background:var(--ink-3);border-color:rgba(198,40,40,.4)}
.btn .arr{transition:transform .3s var(--spring)}
.btn:hover .arr{transform:translateX(5px)}

/* Mini stats under hero buttons */
.hero__ministats{display:flex;gap:2.5rem;flex-wrap:wrap}
.hero__ministats .ms{border-left:2px solid var(--red);padding-left:.9rem}
.hero__ministats .ms .n{font-family:var(--ff-head);font-size:1.9rem;font-weight:900;color:var(--white);line-height:1}
.hero__ministats .ms .l{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}

/* Hero animation */
.hero.in h1 .line span{transform:translateY(0);transition:transform 1s var(--spring)}
.hero h1 .line:nth-child(2) span{transition-delay:.1s}
.hero h1 .line:nth-child(3) span{transition-delay:.2s}

/* ================================================================
   SECTION SHELL
   ================================================================ */
.section{padding:clamp(4rem,10vw,8rem) 0;position:relative}
.section--white{background:var(--white);color:var(--ink)}
.section--snow{background:var(--snow);color:var(--ink)}
.section--red{background:var(--red);color:var(--white)}
.section--dark{background:var(--ink-2)}

/* Diagonal top edge */
.section--angle-top{
  padding-top:calc(clamp(4rem,10vw,8rem) + 3vw);
  clip-path:polygon(0 3vw,100% 0,100% 100%,0 100%);
  margin-top:-3vw;
}
.section--angle-bottom{
  padding-bottom:calc(clamp(4rem,10vw,8rem) + 3vw);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 3vw),0 100%);
}

/* Section header */
.sh{margin-bottom:3.5rem}
.sh .eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--ff-head);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--red-hi);font-weight:700;margin-bottom:.8rem;
}
.sh .eyebrow::before{content:"";width:26px;height:2px;background:var(--red-hi);flex-shrink:0}
.section--white .sh .eyebrow,.section--snow .sh .eyebrow{color:var(--red-deep)}
.section--white .sh .eyebrow::before,.section--snow .sh .eyebrow::before{background:var(--red-deep)}
.section--red .sh .eyebrow{color:rgba(255,255,255,.75)}
.section--red .sh .eyebrow::before{background:rgba(255,255,255,.75)}
.sh h2{font-size:clamp(2rem,4.5vw,3.6rem);line-height:.95;margin-bottom:1rem}
.section--white .sh h2,.section--snow .sh h2{color:var(--ink)}
.sh p{color:var(--muted);font-size:1.05rem;max-width:680px;line-height:1.75}
.section--white .sh p,.section--snow .sh p{color:#555562}
.section--red .sh p{color:rgba(255,255,255,.75)}

/* ================================================================
   MARQUEE (partners)
   ================================================================ */
.marquee-wrap{
  padding:2rem 0;
  border-block:1px solid var(--line-l);
  background:var(--snow);
  overflow:hidden;
}
.marquee__track{display:flex;gap:4rem;width:max-content;animation:marqueeX 32s linear infinite}
.marquee__track span{
  font-family:var(--ff-head);font-weight:800;font-size:1.5rem;
  letter-spacing:.05em;text-transform:uppercase;
  color:rgba(12,12,15,.2);white-space:nowrap;
}
.marquee-wrap:hover .marquee__track{animation-play-state:paused}
@keyframes marqueeX{to{transform:translateX(-50%)}}

/* ================================================================
   CATEGORY / PRODUCT CARDS — new overlay style
   ================================================================ */
.cat-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.2rem;
}
.cat-card{
  position:relative;border-radius:var(--r);overflow:hidden;
  aspect-ratio:3/4;
  background:var(--ink-3);
  cursor:pointer;
  transition:transform .5s var(--spring),box-shadow .5s;
}
.cat-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 32px 64px -16px rgba(0,0,0,.6)}
.cat-card__img{
  position:absolute;inset:0;
  transition:transform 1.2s var(--ease);
}
.cat-card__img img{width:100%;height:100%;object-fit:cover;filter:brightness(.7)}
.cat-card:hover .cat-card__img{transform:scale(1.08)}
/* Bottom gradient overlay */
.cat-card::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(12,12,15,.95) 0%,rgba(12,12,15,.35) 50%,transparent 100%);
  transition:opacity .4s;
}
.cat-card:hover::before{opacity:.9}
/* Red top accent on hover */
.cat-card::after{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--red),var(--red-hi));
  z-index:3;transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--spring);
}
.cat-card:hover::after{transform:scaleX(1)}
.cat-card__body{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  padding:1.8rem 1.6rem;
  transform:translateY(8px);transition:transform .4s var(--spring);
}
.cat-card:hover .cat-card__body{transform:translateY(0)}
.cat-card__tag{
  display:inline-block;
  font-family:var(--ff-head);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--red-hi);margin-bottom:.5rem;
}
.cat-card__body h3{font-size:1.5rem;color:var(--white);margin-bottom:.5rem}
.cat-card__body p{font-size:.9rem;color:rgba(255,255,255,.6);margin-bottom:1.1rem;
  max-height:0;overflow:hidden;transition:max-height .4s var(--spring),opacity .4s;opacity:0}
.cat-card:hover .cat-card__body p{max-height:4rem;opacity:1}
.cat-card__link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--ff-head);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--red-hi);font-weight:800;
}
.cat-card__link svg{transition:transform .3s var(--spring)}
.cat-card:hover .cat-card__link svg{transform:translateX(6px)}

/* ================================================================
   FEATURE / USP CARDS (inside category page)
   ================================================================ */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}
.feat-card{
  background:var(--white);border:1px solid var(--line-l);
  border-radius:var(--r);padding:2.2rem 1.8rem;
  transition:transform .4s var(--spring),box-shadow .4s;
  position:relative;overflow:hidden;
}
.feat-card::before{
  content:"";position:absolute;left:0;top:0;width:4px;height:0;
  background:var(--red);transition:height .5s var(--spring);
}
.feat-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px -16px rgba(198,40,40,.18)}
.feat-card:hover::before{height:100%}
.feat-card .ico{
  width:54px;height:54px;border-radius:12px;
  background:rgba(198,40,40,.08);color:var(--red-deep);
  display:grid;place-items:center;margin-bottom:1.4rem;
  border:1px solid rgba(198,40,40,.15);
}
.feat-card .ico svg{width:26px;height:26px}
.feat-card h3{font-size:1.25rem;color:var(--ink);margin-bottom:.6rem}
.feat-card p{font-size:.95rem;color:#565666;line-height:1.7}

/* ================================================================
   PRODUCT CARDS (individual items inside category)
   ================================================================ */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}
.prod-card{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;
  transition:transform .4s var(--spring),border-color .4s,box-shadow .4s;
}
.prod-card:hover{transform:translateY(-7px);border-color:rgba(239,83,80,.35);box-shadow:0 24px 56px -20px rgba(198,40,40,.35)}
.prod-card__img{aspect-ratio:1/1;overflow:hidden;background:var(--ink-3)}
.prod-card__img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.prod-card:hover .prod-card__img img{transform:scale(1.08)}
.prod-card__body{padding:1.5rem}
.prod-card__body h3{font-size:1.15rem;margin-bottom:.45rem}
.prod-card__body p{font-size:.9rem;color:var(--muted);margin-bottom:1rem;min-height:2.4em}
.prod-card__link{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:var(--ff-head);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--red-hi);font-weight:800;
}
.prod-card__link svg{transition:transform .3s var(--spring)}
.prod-card:hover .prod-card__link svg{transform:translateX(5px)}

/* ================================================================
   ABOUT SPLIT
   ================================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split--rev{direction:rtl}
.split--rev>*{direction:ltr}
.split__img{
  position:relative;border-radius:var(--r);overflow:hidden;
  aspect-ratio:3/4;
}
.split__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.split:hover .split__img img{transform:scale(1.04)}
.split__img-badge{
  position:absolute;left:1.4rem;bottom:1.4rem;
  background:var(--red);color:var(--white);
  font-family:var(--ff-head);font-weight:900;
  padding:1rem 1.4rem;border-radius:12px;line-height:1;
  box-shadow:0 8px 24px rgba(198,40,40,.45);
}
.split__img-badge b{display:block;font-size:2.2rem}
.split__img-badge span{font-size:.68rem;letter-spacing:.16em;opacity:.8}
.split__text h2{font-size:clamp(2rem,4vw,3.2rem);margin:1rem 0 1.2rem}
.section--white .split__text h2,.section--snow .split__text h2{color:var(--ink)}
.split__text p{color:var(--muted);line-height:1.8;margin-bottom:1rem}
.section--white .split__text p,.section--snow .split__text p{color:#555562}

/* Check list */
.check-list{display:grid;gap:.75rem;margin:1.6rem 0 2.2rem}
.check-list li{display:flex;align-items:flex-start;gap:.9rem;font-size:.98rem}
.check-list .chk{
  flex:none;width:24px;height:24px;border-radius:50%;
  background:var(--red);color:var(--white);
  display:grid;place-items:center;
  box-shadow:0 4px 12px rgba(198,40,40,.35);
  margin-top:.1rem;
}
.check-list .chk svg{width:12px;height:12px}

/* ================================================================
   STATS GRID (replaces the band)
   ================================================================ */
.stats-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:1px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r);overflow:hidden;
}
.section--white .stats-grid,.section--snow .stats-grid{
  background:var(--line-l);
  border-color:var(--line-l);
}
.stat-box{
  padding:2.5rem 2rem;
  background:rgba(255,255,255,.04);
  transition:background .3s;
}
.section--white .stat-box,.section--snow .stat-box{background:var(--white)}
.stat-box:hover{background:rgba(198,40,40,.08)}
.stat-box .num{
  font-family:var(--ff-head);font-size:clamp(2.8rem,5vw,4.2rem);
  font-weight:900;line-height:1;color:var(--red-hi);
}
.section--white .stat-box .num,.section--snow .stat-box .num{color:var(--red)}
.stat-box .lbl{font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:.5rem}
.section--white .stat-box .lbl,.section--snow .stat-box .lbl{color:#888896}

/* ================================================================
   VALUE CARDS (about page)
   ================================================================ */
.value-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}
.value-card{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--r);padding:2.2rem 1.8rem;
  transition:transform .4s var(--spring),border-color .4s;
}
.value-card:hover{transform:translateY(-6px);border-color:rgba(239,83,80,.3)}
.value-card .n,.value-card .num-big{font-family:var(--ff-head);font-size:3rem;font-weight:900;color:var(--red-hi);line-height:1;margin-bottom:.6rem}
.value-card h3{font-size:1.2rem;margin-bottom:.6rem}
.value-card p{color:var(--muted);font-size:.94rem;line-height:1.7}

/* ================================================================
   SERVICES GRID (about page — "What We Offer")
   ================================================================ */
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem;margin-top:3rem}
.svc{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--r);padding:1.8rem 1.6rem;
  transition:transform .4s var(--spring),border-color .3s;
}
.svc:hover{transform:translateY(-5px);border-color:rgba(198,40,40,.3)}
.svc__ico{
  width:48px;height:48px;border-radius:10px;
  background:rgba(198,40,40,.08);color:var(--red);
  display:grid;place-items:center;
  border:1px solid rgba(198,40,40,.15);
  margin-bottom:1.1rem;
  flex-shrink:0;
}
.svc__ico svg{width:22px;height:22px;display:block}
.svc h3{font-size:1.1rem;margin-bottom:.45rem}
.svc p{color:var(--muted);font-size:.92rem;line-height:1.7;margin-bottom:.9rem}
.svc__link{
  display:inline-flex;align-items:center;gap:.4rem;
  color:var(--red-hi);font-size:.8rem;font-weight:700;
  font-family:var(--ff-head);letter-spacing:.06em;text-transform:uppercase;
}
.svc__link svg{width:13px;height:13px;transition:transform .3s var(--spring)}
.svc__link:hover svg{transform:translateX(4px)}

/* ================================================================
   STATS BAND (about page)
   ================================================================ */
.band{background:var(--red);padding:3.5rem 0}
.band .container{display:flex;flex-wrap:wrap;justify-content:center;gap:2.5rem 4rem;text-align:center}
.band .num{font-family:var(--ff-head);font-size:2.8rem;font-weight:900;color:var(--white);line-height:1}
.band .lbl{color:rgba(255,255,255,.78);font-size:.8rem;margin-top:.3rem;letter-spacing:.09em;text-transform:uppercase}

/* Section head alias */
.section__head{max-width:680px}

/* ================================================================
   CATEGORIES OVERVIEW PAGE (.products / .prod)
   ================================================================ */
.products{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.8rem}
.prod{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;
  transition:transform .4s var(--spring),box-shadow .4s;
}
.prod:hover{transform:translateY(-6px);box-shadow:0 24px 50px -16px rgba(0,0,0,.5)}
.prod__img{aspect-ratio:16/9;overflow:hidden}
.prod__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.prod:hover .prod__img img{transform:scale(1.06)}
.prod__body{padding:1.5rem 1.6rem}
.prod__body h3{font-size:1.2rem;margin-bottom:.5rem}
.prod__body p{color:var(--muted);font-size:.93rem;line-height:1.7;margin-bottom:1rem}

/* ================================================================
   CTA BLOCK — new red full-bleed style
   ================================================================ */
.cta-block{
  position:relative;border-radius:24px;overflow:hidden;
  background:var(--red);
  padding:clamp(3rem,8vw,6rem) clamp(2rem,5vw,5rem);
  text-align:center;
}
.cta-block::before{
  content:"";position:absolute;
  width:500px;height:500px;
  top:-200px;right:-100px;
  background:rgba(255,255,255,.07);
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  animation:hexSpin 20s linear infinite;
}
.cta-block::after{
  content:"";position:absolute;
  width:300px;height:300px;
  bottom:-120px;left:5%;
  background:rgba(0,0,0,.1);
  clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);
  animation:hexSpin 14s linear infinite reverse;
}
.cta-block__in{position:relative;z-index:1}
.cta-block h2{font-size:clamp(2rem,5vw,3.8rem);color:var(--white);margin-bottom:1rem}
.cta-block p{color:rgba(255,255,255,.75);max-width:560px;margin:0 auto 2.2rem;font-size:1.05rem}
.btn--white{background:var(--white);color:var(--red);border-color:var(--white)}
.btn--white:hover{background:var(--snow);transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.3);color:var(--red)}

/* ================================================================
   PAGE HERO (inner pages)
   ================================================================ */
.page-hero{position:relative;padding:9rem 0 5rem;overflow:hidden;min-height:40vh;display:flex;align-items:flex-end}
.page-hero__bg{position:absolute;inset:0}
.page-hero__bg img{width:100%;height:100%;object-fit:cover;opacity:.25;filter:grayscale(.3)}
.page-hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to right,rgba(12,12,15,.92) 40%,rgba(12,12,15,.6) 100%)}
.page-hero__bg::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(198,40,40,.2),transparent 60%)}
.page-hero__in{position:relative;z-index:2;max-width:800px}
.page-hero h1{font-size:clamp(2.5rem,6vw,5rem);margin:1rem 0 .8rem}
.page-hero p{color:rgba(255,255,255,.65);font-size:1.1rem;max-width:580px;line-height:1.75}
.crumbs{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.crumbs a{color:var(--red-hi);transition:opacity .25s}
.crumbs a:hover{opacity:.75}

/* ================================================================
   CONTACT
   ================================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-cards{display:grid;gap:.9rem}
.cc{
  display:flex;align-items:flex-start;gap:1.1rem;
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:1.5rem;
  transition:transform .35s var(--spring),border-color .35s;
}
.cc:hover{transform:translateX(7px);border-color:rgba(239,83,80,.35)}
.cc__ic{
  flex:none;width:46px;height:46px;border-radius:10px;
  background:var(--red);color:var(--white);
  display:grid;place-items:center;
  box-shadow:0 6px 16px rgba(198,40,40,.35);
}
.cc h4{font-size:.72rem;letter-spacing:.18em;color:var(--muted);margin-bottom:.3rem}
.cc p,.cc a{font-family:var(--ff-head);font-weight:700;font-size:1rem}
.cc a:hover{color:var(--red-hi)}
.form-box{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--r);padding:clamp(1.6rem,4vw,2.8rem);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.73rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.field input,.field textarea{
  width:100%;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  color:var(--white);padding:.9rem 1rem;border-radius:8px;
  font-family:var(--ff-body);font-size:.97rem;
  transition:border-color .25s,background .25s;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.3)}
.field input:focus,.field textarea:focus{
  outline:none;border-color:var(--red-hi);
  background:rgba(198,40,40,.06);
}
.field textarea{resize:vertical;min-height:130px}
.form-success{
  background:rgba(198,40,40,.1);border:1px solid rgba(239,83,80,.4);
  padding:1.1rem 1.3rem;border-radius:8px;margin-bottom:1.4rem;
  color:var(--red-hi);font-weight:600;
}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{
  background:var(--ink-2);border-top:1px solid var(--line);
  padding:clamp(3.5rem,7vw,5.5rem) 0 2rem;
}
.footer-top{
  display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;
  padding-bottom:3rem;border-bottom:1px solid var(--line);
  margin-bottom:2rem;
}
.footer-brand p{color:var(--muted);font-size:.95rem;line-height:1.75;margin-top:1.2rem;max-width:300px}
.footer-brand img{height:52px;filter:invert(1);mix-blend-mode:screen}
.footer-brand .brand-text{font-size:1.6rem}
.foot-col h5{
  font-family:var(--ff-head);font-size:.72rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--red-hi);margin-bottom:1.4rem;
}
.foot-col a{display:block;color:var(--muted);padding:.38rem 0;font-size:.94rem;transition:color .25s,padding-left .25s}
.foot-col a:hover{color:var(--white);padding-left:5px}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;color:var(--muted);font-size:.85rem}
.footer-bottom a:hover{color:var(--red-hi)}
.footer-wm{
  text-align:center;font-family:var(--ff-head);font-weight:900;
  font-size:clamp(4rem,18vw,15rem);
  color:rgba(198,40,40,.04);
  line-height:1;letter-spacing:-.04em;user-select:none;
  margin-top:1.5rem;text-transform:uppercase;
}

/* ================================================================
   SCROLL REVEAL
   ================================================================ */
[data-reveal]{opacity:0;transform:translateY(36px);transition:opacity .9s var(--spring),transform .9s var(--spring)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.12s}
[data-reveal][data-delay="2"]{transition-delay:.24s}
[data-reveal][data-delay="3"]{transition-delay:.36s}
[data-reveal][data-delay="4"]{transition-delay:.48s}

/* Back to top */
.to-top{
  position:fixed;right:1.5rem;bottom:1.5rem;z-index:900;
  width:48px;height:48px;border-radius:12px;
  background:var(--red);color:var(--white);
  display:grid;place-items:center;
  opacity:0;pointer-events:none;transform:translateY(16px);
  transition:all .35s var(--spring);
  box-shadow:0 8px 24px rgba(198,40,40,.4);
}
.to-top.show{opacity:1;pointer-events:auto;transform:none}
.to-top:hover{background:var(--red-hi);transform:translateY(-3px)}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .split__img{aspect-ratio:16/9}
  .contact-grid{grid-template-columns:1fr}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero::after{display:none}
  .hero__right{position:relative;width:100%;height:50vw;min-height:280px;order:-1}
  .hero__left{padding:3rem var(--pad)}
  .hero__badge{bottom:1.5rem;right:1.5rem}
}
@media(max-width:860px){
  .nav-toggle{display:flex}
  /* Remove backdrop-filter so fixed nav can cover the full viewport */
  .site-header{backdrop-filter:none;-webkit-backdrop-filter:none}
  .nav-main{
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:#0c0c0f;
    flex-direction:column;justify-content:center;align-items:center;
    transform:translateX(100%);transition:transform .45s var(--spring);
    z-index:2000;gap:2rem;
    overflow-y:auto;
  }
  .nav-main.open{transform:none}
  .nav-toggle{z-index:2100}
  .nav-main>ul{flex-direction:column;gap:1.4rem;text-align:center}
  .nav-main a{font-size:1.3rem}
  .nav-main .sub-menu{
    position:static;opacity:1;visibility:visible;transform:none;
    background:none;border:0;box-shadow:none;padding:.4rem 0;text-align:center;
  }
  .footer-top{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr 1fr}
  .hero__ministats{gap:1.5rem}
  /* Fix horizontal overflow */
  .hero{overflow:hidden}
}
@media(max-width:768px){
  .hero{display:flex;flex-direction:column}
  .hero__left{width:100%;max-width:100%;flex:0 0 100%}
  .hero__right{width:100%;max-width:100%}
}
@media(max-width:520px){
  body{font-size:16px;overflow-x:hidden}
  .btn{width:100%;justify-content:center;text-align:center}
  .hero__btns{width:100%;flex-direction:column}
  .cat-grid{grid-template-columns:1fr}
  .hero__left h1{font-size:clamp(2.4rem,12vw,4.5rem)}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition-duration:.01ms!important}
  [data-reveal]{opacity:1;transform:none}
}
