/*
Theme Name: Cyllium
Theme URI: https://cyllium.eu
Author: Cyllium
Author URI: https://cyllium.eu
Description: Custom WordPress theme for Cyllium — Cybersecurity, Audit & IT company group. Dark theme with Space Grotesk font and purple brand colors.
Version: 1.9.3
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cyllium
Tags: dark, one-column, custom-menu, featured-images
*/

/* ═══════════════════════════════════════════════
   CYLLIUM.EU — SHARED STYLES
   Brand: #5e2a52 / #bf5d9f, Space Grotesk
   ═══════════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --p1:#5e2a52;--p2:#bf5d9f;--p3:#d98ec5;--p4:#e8b8da;
  --g1:rgba(191,93,159,.35);
  --d1:#0e0a12;--d2:#150f1c;--d3:#1c1526;--d4:#241d30;--d5:#2e2540;
  --s1:rgba(255,255,255,.04);--s2:rgba(255,255,255,.07);--s3:rgba(255,255,255,.11);
  --b1:rgba(255,255,255,.06);--b2:rgba(255,255,255,.1);
  --tw:#fff;--t80:rgba(255,255,255,.82);--t60:rgba(255,255,255,.58);
  --t40:rgba(255,255,255,.52);--t25:rgba(255,255,255,.35);
  --f:'Space Grotesk',sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);--dur:.35s;
  --gold:#d4a843;--gold-light:#e8c76a;--gold-dark:#c9952c;
}
html{scroll-behavior:smooth;scroll-padding-top:140px}
body{font-family:var(--f);font-size:16px;line-height:1.65;color:var(--t80);background:var(--d1);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.ctr{max-width:1280px;margin:0 auto;padding:0 32px}

/* GEO */
.geo{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;display:none!important}
.geo svg{position:absolute;width:100%;height:100%}
.fr{position:absolute;will-change:transform,opacity}
.fr svg{fill:none;stroke:var(--p2);stroke-linecap:round;stroke-linejoin:round}
@keyframes dft{0%{transform:translate(0,0) rotate(0)}25%{transform:translate(18px,-22px) rotate(6deg)}50%{transform:translate(-12px,-44px) rotate(-3deg)}75%{transform:translate(14px,-28px) rotate(9deg)}100%{transform:translate(0,0) rotate(0)}}
@keyframes brth{0%,100%{transform:scale(1) rotate(0);opacity:var(--o,.05)}50%{transform:scale(1.1) rotate(5deg);opacity:calc(var(--o,.05)*1.8)}}
@keyframes gst{0%,100%{opacity:0;transform:translateY(6px) scale(.96)}12%{opacity:var(--o,.05);transform:translateY(0) scale(1)}88%{opacity:var(--o,.05);transform:translateY(-3px) scale(1.01)}}
.fr1{left:4%;top:10%;width:80px;--o:.05;animation:dft 24s linear infinite}
.fr2{right:10%;top:6%;width:45px;--o:.07;animation:brth 16s ease-in-out infinite}
.fr3{left:52%;top:22%;width:130px;--o:.025;animation:brth 20s ease-in-out infinite;animation-delay:-5s}
.fr4{right:28%;top:42%;width:32px;--o:.09;animation:dft 28s linear infinite;animation-delay:-10s}
.fr5{left:18%;top:48%;width:65px;--o:.04;animation:gst 14s ease-in-out infinite;animation-delay:-3s}
.fr6{right:6%;top:52%;width:50px;--o:.06;animation:brth 12s ease-in-out infinite;animation-delay:-7s}
.fr7{left:38%;top:68%;width:90px;--o:.03;animation:dft 26s linear infinite;animation-delay:-14s}
.fr8{right:20%;top:72%;width:38px;--o:.08;animation:gst 18s ease-in-out infinite;animation-delay:-4s}
.fr9{left:8%;top:82%;width:70px;--o:.04;animation:brth 22s ease-in-out infinite;animation-delay:-9s}
.fr10{left:65%;top:85%;width:100px;--o:.03;animation:dft 30s linear infinite;animation-delay:-18s}
.pg{position:relative;z-index:1}

/* Hexa-DNA canvas background — unified across all pages */
#cyl-hexa-bg{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0;pointer-events:none}
.elementor,.elementor-location-header,.elementor-location-footer,header,main,footer,.site-header,.site-footer{position:relative;z-index:1}
/* ALL pages: Elementor sections transparent so canvas shows through */
.elementor-section{background-color:transparent!important;background-image:none!important;position:relative!important;overflow:hidden!important}
.elementor-section::before{content:'';position:absolute;inset:0;background:rgba(14,10,18,.06);z-index:0;pointer-events:none}
.elementor-section>.elementor-container{position:relative;z-index:1}
.elementor-section .elementor-widget-wrap,.elementor-section .elementor-column-wrap{position:relative;z-index:1}
/* UX: Compact Elementor sections — tighter spacing, wider content */
.elementor-section>.elementor-container{max-width:1280px!important}
.elementor-section .elementor-section>.elementor-container{max-width:100%!important}
/* Header logo — ensure no clipping */
.elementor-widget-image img,.elementor-widget-theme-site-logo img{object-fit:contain!important;max-height:45px}
.elementor-location-footer .elementor-widget-image img{max-height:140px!important;height:140px!important;width:auto!important}

/* HEADER */
.hd{position:fixed;top:0;left:0;right:0;z-index:100;transition:all var(--dur) var(--ease)}
.hd-wrap{display:flex;align-items:center;justify-content:space-between;height:72px;transition:height var(--dur) var(--ease)}
.hd.sc{background:rgba(14,10,18,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--b1)}
.hd.sc .hd-wrap{height:58px}
.hd .logo img{height:34px;transition:height var(--dur) var(--ease)}
.hd.sc .logo img{height:28px}
.nv{display:flex;gap:2px;align-items:center}
.nv a,.nv-d>a{padding:7px 13px;font-size:13.5px;font-weight:500;color:var(--t40);border-radius:6px;transition:all var(--dur) var(--ease)}
.nv a:hover,.nv-d:hover>a{color:var(--tw);background:var(--s2)}
.nv-d{position:relative}
.nv-d>a::after{content:'';border:3px solid transparent;border-top:3px solid currentColor;margin-left:4px;opacity:.4}
.dm{position:absolute;top:calc(100% + 8px);left:-8px;min-width:200px;background:var(--d3);border:1px solid var(--b2);border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.5);padding:6px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s var(--ease)}
.nv-d:hover .dm{opacity:1;visibility:visible;transform:translateY(0)}
.dm a{display:block;padding:8px 14px;font-size:13px;font-weight:500;border-radius:6px;color:var(--t40)}
.dm a:hover{background:var(--s2);color:var(--tw)}
.hd-r{display:flex;align-items:center;gap:10px}
.lng{font-size:12px;font-weight:600;color:var(--t25);cursor:pointer}
.lng .on{color:var(--p2)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--f);font-weight:600;border:0;cursor:pointer;transition:all var(--dur) var(--ease);white-space:nowrap}
.btn-s{font-size:13px;padding:9px 20px;border-radius:8px}
.btn-m{font-size:14.5px;padding:13px 28px;border-radius:10px}
.btn-l{font-size:15px;padding:16px 36px;border-radius:12px}
.btn-g{background:linear-gradient(135deg,var(--p2),var(--p1));color:var(--tw);box-shadow:0 4px 20px var(--g1)}
.btn-g:hover{box-shadow:0 8px 40px rgba(191,93,159,.5);transform:translateY(-2px)}
.btn-o{background:transparent;color:var(--t60);box-shadow:inset 0 0 0 1px var(--b2)}
.btn-o:hover{color:var(--tw);background:var(--s2);box-shadow:inset 0 0 0 1px rgba(191,93,159,.3);transform:translateY(-2px)}
.mbt{display:none;background:none;border:none;cursor:pointer;padding:8px}
.mbt span{display:block;width:20px;height:2px;background:var(--t60);margin:4px 0}

/* HERO */
.hero{position:relative;min-height:85vh;display:flex;align-items:center;overflow:hidden;
  background:linear-gradient(170deg,var(--d1) 0%,var(--d2) 30%,var(--d4) 60%,var(--p1) 100%)}
.hero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 65% 55% at 65% 35%,rgba(191,93,159,.12) 0%,transparent 60%),
  radial-gradient(ellipse 45% 50% at 12% 75%,rgba(94,42,82,.1) 0%,transparent 50%)}
/* hero hex pattern removed — canvas handles background */

.hero-c{position:relative;z-index:2;max-width:640px;padding:110px 0 64px}
.htag{display:inline-flex;align-items:center;gap:10px;background:var(--s2);border:1px solid var(--b2);border-radius:100px;padding:5px 16px 5px 5px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--p3);margin-bottom:36px;opacity:0;animation:up .7s .1s forwards}
.htag-dot{width:8px;height:8px;border-radius:50%;background:var(--p2);box-shadow:0 0 14px var(--g1);animation:pls 2s ease-in-out infinite}
@keyframes pls{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.hero h1{font-size:clamp(3rem,6vw,4.5rem);font-weight:700;color:var(--tw);line-height:1.06;letter-spacing:-2px;margin-bottom:28px;opacity:0;animation:up .7s .25s forwards}
.hero h1 .hl{background:linear-gradient(135deg,var(--p3),var(--p2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-p{font-size:18px;font-weight:300;color:var(--t40);line-height:1.8;max-width:460px;margin-bottom:44px;opacity:0;animation:up .7s .4s forwards}
.hero-a{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:up .7s .55s forwards}
@keyframes up{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* Hero right — abstract geometry */
.hero-art{position:absolute;right:-2%;top:50%;transform:translateY(-50%);width:500px;height:500px;opacity:0;animation:fin 1.4s .3s forwards}
@keyframes fin{from{opacity:0}to{opacity:1}}
.ha-ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:50%;animation:rng 6s ease-in-out infinite}
.ha-r1{width:180px;height:180px;border:1px solid rgba(191,93,159,.12)}
.ha-r2{width:300px;height:300px;border:1px solid rgba(191,93,159,.07);animation-delay:1s}
.ha-r3{width:420px;height:420px;border:1px dashed rgba(191,93,159,.04);animation-delay:2s}
@keyframes rng{0%,100%{opacity:.5;transform:translate(-50%,-50%) scale(1) rotate(0)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.03) rotate(8deg)}}
.ha-sh{position:absolute;animation:hsh ease-in-out infinite}
.ha-sh svg{fill:none;stroke:var(--p2);stroke-linecap:round}
.hs1{width:70px;right:15%;top:15%;animation-duration:10s}.hs1 svg{stroke-opacity:.2;stroke-width:.7}
.hs2{width:40px;left:25%;top:30%;animation-duration:13s;animation-delay:-3s}.hs2 svg{stroke-opacity:.3;stroke-width:1}
.hs3{width:55px;right:30%;bottom:25%;animation-duration:11s;animation-delay:-5s}.hs3 svg{stroke-opacity:.15;stroke-width:.6}
.hs4{width:90px;left:15%;bottom:20%;animation-duration:14s;animation-delay:-7s}.hs4 svg{stroke-opacity:.08;stroke-width:.5}
.hs5{width:30px;right:45%;top:40%;animation-duration:8s;animation-delay:-2s}.hs5 svg{stroke-opacity:.35;stroke-width:1.2}
.ha-core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:80px;height:92px;
  background:linear-gradient(150deg,var(--p2),var(--p1));
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  box-shadow:0 0 80px var(--g1);display:flex;align-items:center;justify-content:center}
.ha-core svg{width:36px;height:36px;fill:var(--tw)}
@keyframes hsh{0%,100%{transform:translateY(0) rotate(0)}33%{transform:translateY(-8px) rotate(5deg)}66%{transform:translateY(4px) rotate(-3deg)}}

/* SECTIONS */
.s{position:relative;overflow:hidden;z-index:1}
.s-pad{padding:72px 0}
.bg-flow-1{background:linear-gradient(180deg,var(--p1) 0%,var(--d3) 15%,var(--d2) 100%)}
.bg-flow-2{background:linear-gradient(180deg,var(--d2) 0%,var(--d3) 50%,var(--d2) 100%)}
.bg-flow-3{background:var(--d2)}
.bg-flow-4{background:linear-gradient(180deg,var(--d2) 0%,var(--d4) 50%,var(--d3) 100%)}
.bg-flow-5{background:linear-gradient(180deg,var(--d3) 0%,var(--d2) 100%)}
.bg-accent{background:linear-gradient(160deg,var(--d4) 0%,var(--p1) 50%,var(--d3) 100%)}
.bg-cta{background:linear-gradient(150deg,var(--p1) 0%,var(--d4) 60%,var(--d3) 100%)}

.sl{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--p2);margin-bottom:16px}
.sl::before{content:'';width:20px;height:1.5px;background:var(--p2)}
.st{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:700;color:var(--tw);letter-spacing:-.5px;margin-bottom:16px;line-height:1.15}
.ss{font-size:16px;font-weight:300;color:var(--t40);max-width:520px;line-height:1.75}
.sh{margin-bottom:40px}
.sh-c{text-align:center}
.sh-c .ss{margin:0 auto}

/* REVEAL */
.rv{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
.rv.vis{opacity:1;transform:translateY(0)}
.single-content.rv,.blog-hero-inner.rv{opacity:1!important;transform:none!important}
.r1{transition-delay:.08s}.r2{transition-delay:.16s}.r3{transition-delay:.24s}

/* STRIP */
.strip{padding:20px 0;border-top:1px solid var(--b1);border-bottom:1px solid var(--b1)}
.strip-i{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.strip-i,.strip-i *,.strip-n,.strip-n *{font-family:var(--f)!important;font-style:normal!important}
.strip-l{font-size:10px;font-weight:700;color:var(--t25);text-transform:uppercase;letter-spacing:2.5px}
.strip-n{display:flex;align-items:center;gap:24px}
.strip-nm{font-weight:600;font-size:14px;color:var(--t40);transition:color var(--dur) var(--ease);font-family:var(--f)!important;font-style:normal!important}
.strip-nm:hover{color:var(--p2)}
.strip-dt{width:3px;height:3px;border-radius:50%;background:var(--t25)}

/* TEAM AVATARS — center on face */
img.tm-avatar,.tm-card img{object-position:center 20%!important;object-fit:cover!important;aspect-ratio:1!important;border-radius:50%!important;width:100px;height:100px}

/* CARDS */
.grd{display:grid;gap:20px}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.cd{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:32px 28px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all var(--dur) var(--ease)}
.cd:hover{background:var(--s2);border-color:rgba(191,93,159,.15);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.cd-i{width:44px;height:44px;background:rgba(191,93,159,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:all var(--dur) var(--ease)}
.cd:hover .cd-i{background:var(--p1);box-shadow:0 0 20px rgba(191,93,159,.2)}
.cd-i svg{width:20px;height:20px;fill:var(--p2);transition:fill var(--dur) var(--ease)}
.cd:hover .cd-i svg{fill:var(--tw)}
.cd h4{font-size:16px;font-weight:600;color:var(--tw);margin-bottom:8px}
.cd p{font-size:14px;color:var(--t40);line-height:1.65}

/* PILLARS */
.pil{background:var(--s1);border:1px solid var(--b1);border-radius:20px;padding:40px 34px;position:relative;overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all var(--dur) var(--ease);display:flex;flex-direction:column;cursor:pointer;text-decoration:none;color:inherit;height:100%}
.pil::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--p2),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.pil:hover::after{transform:scaleX(1)}
.pil:hover{background:var(--s2);border-color:rgba(191,93,159,.12);box-shadow:0 16px 56px rgba(0,0,0,.35);transform:translateY(-4px)}
.pi{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;background:rgba(191,93,159,.08)}
.pi svg{width:24px;height:24px;fill:var(--p2)}
.pil:nth-child(2) .pi{background:rgba(94,42,82,.12)}.pil:nth-child(2) .pi svg{fill:var(--p3)}
.pil:nth-child(3) .pi{background:var(--s3)}.pil:nth-child(3) .pi svg{fill:var(--t60)}
.pil h3{font-size:22px;font-weight:700;color:var(--tw);margin-bottom:10px}
.pil>p{font-size:14.5px;color:var(--t40);line-height:1.7;margin-bottom:22px}
.pil ul{list-style:none;margin-bottom:24px}
.pil li{font-size:13.5px;padding:5px 0 5px 18px;position:relative;color:var(--t60)}
.pil li::before{content:'';position:absolute;left:0;top:12px;width:5px;height:5px;border-radius:50%;background:var(--p2)}
.pil:nth-child(2) li::before{background:var(--p3)}
.pil:nth-child(3) li::before{background:var(--t40)}
.pil-lnk{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--p2);transition:gap var(--dur) var(--ease);margin-top:auto}
.pil-lnk:hover{gap:12px}
.pil-lnk svg{width:14px;height:14px;fill:currentColor}

/* ROADMAP */
.rm{display:flex;align-items:flex-start;justify-content:center;margin-top:60px}
.rm-s{display:flex;flex-direction:column;align-items:center;width:180px;text-align:center;position:relative}
.rm-s:not(:last-child)::after{content:'';position:absolute;top:20px;left:calc(50% + 24px);right:-50%;height:1px;background:linear-gradient(90deg,var(--p2),var(--b1))}
.rm-n{width:40px;height:40px;border-radius:50%;background:var(--s2);border:1px solid var(--b2);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--p2);margin-bottom:14px;position:relative;z-index:2;transition:all var(--dur) var(--ease)}
.rm-s:hover .rm-n{background:var(--p1);border-color:var(--p2);color:var(--tw);box-shadow:0 0 24px rgba(191,93,159,.25)}
.rm-t{font-size:13px;font-weight:600;color:var(--t80);margin-bottom:4px}
.rm-d{font-size:12px;color:var(--t40);line-height:1.5}

/* COUNTERS */
.nums{padding:80px 0;position:relative}
.nums::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 80% at 50% 50%,rgba(191,93,159,.06) 0%,transparent 70%)}
.nums-g{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.nm{text-align:center}
.nm-v{font-size:clamp(2.4rem,4.5vw,3.4rem);font-weight:700;color:var(--tw);line-height:1}
.nm-v .sf{color:var(--p2)}
.nm-l{font-size:11px;font-weight:600;color:var(--t25);text-transform:uppercase;letter-spacing:2px;margin-top:10px}

/* CERTS */
.certs{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.cert{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.35;transition:all var(--dur) var(--ease);cursor:default}
.cert:hover{opacity:1}
.cb{width:60px;height:60px;border:1px solid var(--b2);border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--s1);font-size:10.5px;font-weight:700;text-align:center;line-height:1.3;color:var(--t80);transition:all var(--dur) var(--ease)}
.cert:hover .cb{border-color:var(--p2);box-shadow:0 0 20px rgba(191,93,159,.12)}
.cn{font-size:10.5px;font-weight:600;color:var(--t40)}

/* CLIENTS */
.logos{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--b1);border:1px solid var(--b1);border-radius:14px;overflow:hidden;margin-bottom:56px}
.lc{background:var(--d2);display:flex;align-items:center;justify-content:center;padding:22px;min-height:76px;transition:background var(--dur) var(--ease)}
.lc:hover{background:var(--d3)}
.lc span{font-size:10.5px;font-weight:700;color:var(--t25);letter-spacing:2px;text-transform:uppercase;transition:color var(--dur) var(--ease)}
.lc:hover span{color:var(--p2)}
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.qt{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:32px;position:relative;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.qt::before{content:'\201C';font-size:52px;font-weight:700;color:var(--p2);opacity:.12;position:absolute;top:10px;left:22px;line-height:1}
.qt p{font-size:15px;font-style:italic;color:var(--t60);line-height:1.7;margin-bottom:16px;position:relative}
.qt-w{display:flex;align-items:center;gap:10px}
.qt-a{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--p2),var(--p1));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--tw)}
.qt-n{font-weight:600;font-size:13.5px;color:var(--tw)}
.qt-r{font-size:11.5px;color:var(--t40)}

/* CTA */
.cta{padding:100px 0;text-align:center;position:relative}
.cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(191,93,159,.08) 0%,transparent 65%)}
.cta h2{font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--tw);margin-bottom:14px;position:relative}
.cta p{color:var(--t40);font-size:17px;max-width:440px;margin:0 auto 36px;position:relative}

/* FOOTER */
.ft{border-top:1px solid var(--b1);color:var(--t40);padding:72px 0 32px}
.ft-g{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:48px}
.ft h4{font-size:10.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--t60);margin-bottom:18px}
.ft-a p{font-size:13.5px;line-height:1.7;margin-bottom:16px}
.ft-sc{display:flex;gap:8px}
.ft-sc a{width:34px;height:34px;border:1px solid var(--b1);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all var(--dur) var(--ease)}
.ft-sc a:hover{background:var(--p1);border-color:var(--p2)}
.ft-sc svg{width:14px;height:14px;fill:var(--t40)}
.ft-sc a:hover svg{fill:var(--tw)}
.ft-lk{list-style:none}
.ft-lk li{margin-bottom:8px}
.ft-lk a{font-size:13px;color:var(--t40);transition:color var(--dur) var(--ease)}
.ft-lk a:hover{color:var(--p2)}
.ft-ci{display:flex;gap:10px;margin-bottom:10px;font-size:13px}
.ft-ci svg{width:14px;height:14px;fill:var(--p2);flex-shrink:0;margin-top:3px}
.ft-bt{border-top:1px solid var(--b1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--t25)}
.ft-bl{display:flex;gap:18px}
.ft-bl a{color:var(--t25);transition:color var(--dur) var(--ease)}
.ft-bl a:hover{color:var(--p2)}

/* ═══ PAGE HERO (subpages) ═══ */
.page-hero{
  padding:120px 0 40px;
  background:linear-gradient(170deg,var(--d1) 0%,var(--d3) 50%,var(--p1) 100%);
  position:relative;overflow:hidden;
}
.page-hero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 50% at 70% 40%,rgba(191,93,159,.1) 0%,transparent 60%)}
/* page-hero hex pattern removed — canvas handles background */
.ph-content{position:relative;z-index:1;max-width:640px}
.ph-breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--t40);margin-bottom:20px}
.ph-breadcrumb a{color:var(--t40);transition:color var(--dur) var(--ease)}
.ph-breadcrumb a:hover{color:var(--p2)}
.ph-sep{color:var(--t25)}
.ph-current{color:var(--p2)}
.page-hero h1{font-size:clamp(2.2rem,4.5vw,3.2rem);font-weight:700;color:var(--tw);line-height:1.12;letter-spacing:-1px;margin-bottom:16px}
.ph-desc{font-size:17px;font-weight:300;color:var(--t40);line-height:1.75;max-width:520px}

/* ═══ SERVICE PAGE ITEMS ═══ */
.svc-intro{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:center}
.svc-intro-text h2{font-size:clamp(1.5rem,3vw,2rem);font-weight:700;color:var(--tw);margin-bottom:16px;line-height:1.2}
.svc-intro-text p{font-size:15px;color:var(--t40);line-height:1.75}
.svc-intro-stats{display:flex;gap:40px}
.svc-stat{text-align:center}
.svc-stat-num{font-size:clamp(2rem,4vw,2.8rem);font-weight:700;color:var(--tw)}
.svc-stat-num .sf{color:var(--p2)}
.svc-stat-lbl{font-size:12px;font-weight:500;color:var(--t40);text-transform:uppercase;letter-spacing:1px;margin-top:6px}

.svc-list{display:flex;flex-direction:column;gap:0}
.svc-item{display:flex;gap:28px;padding:32px 0;border-bottom:1px solid var(--b1);transition:all var(--dur) var(--ease)}
.svc-item:first-child{border-top:1px solid var(--b1)}
.svc-item:hover{padding-left:12px}
.svc-item-num{font-size:13px;font-weight:700;color:var(--p2);min-width:32px;padding-top:4px}
.svc-item-body h3{font-size:18px;font-weight:600;color:var(--tw);margin-bottom:8px}
.svc-item-body p{font-size:14px;color:var(--t40);line-height:1.7;margin-bottom:12px}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px}
.svc-tags span{font-size:11px;font-weight:600;color:var(--p2);background:rgba(191,93,159,.08);padding:4px 10px;border-radius:100px;border:1px solid rgba(191,93,159,.12)}

/* ═══ BLOG LISTING ═══ */
/* Blog hero — compact, filters inline, transparent for canvas bg */
.blog-hero{padding:72px 0 0;background:transparent;position:relative;overflow:visible;z-index:auto}
.blog-hero::before{content:'';position:absolute;inset:0;background:rgba(14,10,18,.06);z-index:0;pointer-events:none}
.blog-hero-inner{position:relative;z-index:1;text-align:left}
.bg-transparent{background:transparent!important;position:relative!important;z-index:1!important;overflow:visible!important}
.blog-hero+.s .s-pad{padding-top:16px}
.bg-transparent::before{content:'';position:absolute;inset:0;background:rgba(14,10,18,.06);z-index:-1;pointer-events:none}
.blog-hero h1{font-size:clamp(1.8rem,3.5vw,2.4rem);font-weight:700;color:var(--tw);line-height:1.15;letter-spacing:-0.5px;margin-bottom:12px;text-align:left}
.blog-filters{display:flex;align-items:center;justify-content:flex-start;gap:8px;flex-wrap:wrap}
/* Featured post card — horizontal */
.blog-featured{display:grid;grid-template-columns:1fr 1fr;background:var(--s1);border:1px solid var(--b1);border-radius:20px;overflow:hidden;position:relative;transition:all var(--dur) var(--ease);margin-bottom:24px}
.blog-featured::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--p2),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.blog-featured:hover::after{transform:scaleX(1)}
.blog-featured:hover{border-color:rgba(191,93,159,.15);box-shadow:0 16px 56px rgba(0,0,0,.35)}
.blog-featured .bf-img{position:relative;overflow:hidden;min-height:260px;background:linear-gradient(135deg,var(--d3),var(--d4));display:flex;align-items:center;justify-content:center}
.blog-featured.no-thumb{grid-template-columns:1fr}.blog-featured.no-thumb .bf-img{display:none}
.blog-featured .bf-img img{width:100%;height:100%;object-fit:cover}
.blog-featured .bf-body{padding:32px;display:flex;flex-direction:column;justify-content:center}
.blog-featured .bf-tag{display:inline-block;width:fit-content;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--tw);background:var(--p1);padding:4px 12px;border-radius:100px;margin-bottom:14px}
.blog-featured .bf-body h2{font-size:22px;font-weight:700;color:var(--tw);line-height:1.3;margin-bottom:12px;transition:color var(--dur) var(--ease)}
.blog-featured:hover .bf-body h2{color:var(--p3)}
.blog-featured .bf-body p{font-size:14.5px;color:var(--t40);line-height:1.7;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-featured .bf-meta{font-size:12px;color:var(--t25);display:flex;gap:12px;margin-bottom:16px}
/* Grid cards — compact */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.blog-card{background:var(--s1);border:1px solid var(--b1);border-radius:16px;overflow:hidden;position:relative;transition:all var(--dur) var(--ease)}
.blog-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--p2),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.blog-card:hover::after{transform:scaleX(1)}
.blog-card:hover{border-color:rgba(191,93,159,.15);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.3),0 0 24px rgba(191,93,159,.06)}
.blog-img{height:160px;background:linear-gradient(135deg,var(--d3),var(--d4));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.blog-img img{width:100%;height:100%;object-fit:cover}
.blog-img-tag{position:absolute;top:12px;left:12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--tw);background:var(--p1);padding:4px 10px;border-radius:100px}
.blog-body{padding:20px}
.blog-meta{font-size:12px;color:var(--t25);margin-bottom:8px;display:flex;gap:12px}
.blog-card h3{font-size:16px;font-weight:600;color:var(--tw);margin-bottom:6px;line-height:1.35;transition:color var(--dur) var(--ease)}
.blog-card:hover h3{color:var(--p3)}
.blog-card .blog-body p{font-size:13.5px;color:var(--t40);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-more{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--p2);margin-top:12px;transition:gap var(--dur) var(--ease)}
.blog-more:hover{gap:12px}
/* Blog empty state */
.blog-empty{text-align:center;padding:64px 0}
.blog-empty-icon{width:64px;height:64px;margin:0 auto 20px;background:rgba(191,93,159,.08);border-radius:16px;display:flex;align-items:center;justify-content:center}
.blog-empty-icon svg{width:28px;height:28px;fill:var(--p2)}
/* Single post hero — category badge */
.post-cat-tag{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--tw);background:var(--p1);padding:4px 12px;border-radius:100px;margin-bottom:14px}
.single-featured{max-width:900px;margin:0 auto 32px;border-radius:16px;overflow:hidden}
.single-featured img{width:100%;display:block}

/* ═══ CONTACT FORM ═══ */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px}
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--t60);margin-bottom:6px;text-transform:uppercase;letter-spacing:1px}
.form-input,.form-textarea{width:100%;background:var(--s1);border:1px solid var(--b2);border-radius:10px;padding:14px 18px;font-family:var(--f);font-size:14px;color:var(--tw);transition:all var(--dur) var(--ease);outline:none}
.form-input:focus,.form-textarea:focus{border-color:var(--p2);box-shadow:0 0 0 3px rgba(191,93,159,.1)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--t25)}
.form-textarea{min-height:140px;resize:vertical}
.contact-info{padding:32px;background:var(--s1);border:1px solid var(--b1);border-radius:16px}
.contact-info h3{font-size:20px;font-weight:700;color:var(--tw);margin-bottom:24px}
.ci-item{display:flex;gap:14px;margin-bottom:20px}
.ci-item svg{width:18px;height:18px;fill:var(--p2);flex-shrink:0;margin-top:2px}
.ci-item-label{font-size:12px;font-weight:600;color:var(--t40);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.ci-item-val{font-size:15px;color:var(--t80)}

/* ═══ NEWSLETTER ═══ */
.nl-hero{text-align:center;max-width:560px;margin:0 auto}
.nl-form{display:flex;gap:12px;margin-top:32px}
.nl-form .form-input{flex:1}
.nl-features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:64px}
.nl-feat{text-align:center}
.nl-feat-ico{width:48px;height:48px;margin:0 auto 16px;background:rgba(191,93,159,.08);border-radius:12px;display:flex;align-items:center;justify-content:center}
.nl-feat-ico svg{width:22px;height:22px;fill:var(--p2)}
.nl-feat h4{font-size:15px;font-weight:600;color:var(--tw);margin-bottom:6px}
.nl-feat p{font-size:13px;color:var(--t40);line-height:1.6}

/* ═══ TEAM PAGE ═══ */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.team-card{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:28px;text-align:center;transition:all var(--dur) var(--ease);backdrop-filter:blur(8px)}
.team-card:hover{background:var(--s2);border-color:rgba(191,93,159,.15);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.team-avatar{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--d4),var(--d5));margin:0 auto 18px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--p3);border:2px solid var(--b2);transition:border-color var(--dur) var(--ease)}
.team-card:hover .team-avatar{border-color:var(--p2)}
.team-name{font-size:16px;font-weight:600;color:var(--tw);margin-bottom:4px}
.team-role{font-size:13px;color:var(--p2);font-weight:500;margin-bottom:12px}
.team-certs{display:flex;flex-wrap:wrap;justify-content:center;gap:4px}
.team-cert{font-size:10px;font-weight:700;color:var(--t40);background:var(--s2);padding:3px 8px;border-radius:100px;border:1px solid var(--b1)}

/* ═══ SINGLE POST ═══ */
.single-content{max-width:720px;margin:0 auto}
.single-content h2{font-size:clamp(1.4rem,3vw,1.8rem);font-weight:700;color:var(--tw);margin:32px 0 16px;line-height:1.3}
.single-content h3{font-size:clamp(1.2rem,2.5vw,1.5rem);font-weight:600;color:var(--tw);margin:28px 0 12px;line-height:1.3}
.single-content p{font-size:16px;color:var(--t60);line-height:1.8;margin-bottom:20px}
.single-content ul,.single-content ol{margin:0 0 20px 20px;color:var(--t60)}
.single-content li{margin-bottom:8px;line-height:1.7}
.single-content blockquote{border-left:3px solid var(--p2);padding:16px 24px;margin:24px 0;background:var(--s1);border-radius:0 10px 10px 0}
.single-content blockquote p{color:var(--t80);font-style:italic;margin-bottom:0}
.single-content img{border-radius:12px;margin:24px 0}
.single-content a{color:var(--p2);transition:color var(--dur) var(--ease)}
.single-content a:hover{color:var(--p3)}
.post-meta{display:flex;gap:16px;font-size:13px;color:var(--t40);margin-bottom:32px}
.post-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:40px;padding-top:24px;border-top:1px solid var(--b1)}
.post-tags a{font-size:12px;font-weight:600;color:var(--p2);background:rgba(191,93,159,.08);padding:5px 12px;border-radius:100px;border:1px solid rgba(191,93,159,.12);transition:all var(--dur) var(--ease)}
.post-tags a:hover{background:var(--p1);color:var(--tw)}

/* ═══ WP NAV MENU — DROPDOWN ═══ */
.nv .menu{display:flex;gap:2px;align-items:center;list-style:none;margin:0;padding:0}
.nv .menu li{position:relative}
.nv .menu li a{padding:7px 13px;font-size:13.5px;font-weight:500;color:var(--t40);border-radius:6px;transition:all var(--dur) var(--ease);display:block}
.nv .menu li a:hover,.nv .menu li:hover>a{color:var(--tw);background:var(--s2)}
.nv .menu li.menu-item-has-children>a::after{content:'';display:inline-block;border:3px solid transparent;border-top:3px solid currentColor;margin-left:4px;opacity:.4;vertical-align:middle}
/* Hover bridge — fills gap between parent li and sub-menu so hover doesn't break */
.nv .menu li.menu-item-has-children::after{content:'';position:absolute;top:100%;left:0;right:0;height:12px}
/* Sub-menu dropdown */
.nv .menu .sub-menu{position:absolute;top:calc(100% + 8px);left:-8px;min-width:200px;background:rgba(14,10,18,.95);border:1px solid rgba(212,168,67,.3);border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 20px rgba(212,168,67,.06);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:6px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s var(--ease);list-style:none;margin:0;z-index:99999}
.nv .menu li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nv .menu .sub-menu li a{display:block;padding:8px 14px;font-size:13px;font-weight:500;border-radius:6px;color:var(--t40)}
.nv .menu .sub-menu li a:hover{background:var(--s2);color:var(--tw)}

/* WP Footer widget area */
.ft-lk .menu{list-style:none;margin:0;padding:0}
.ft-lk .menu li{margin-bottom:8px}
.ft-lk .menu li a{font-size:13px;color:var(--t40);transition:color var(--dur) var(--ease)}
.ft-lk .menu li a:hover{color:var(--p2)}

/* ═══ SERVICE PAGE — NUMBERED GRID ═══ */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.svc-card{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:32px 28px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all var(--dur) var(--ease);position:relative;overflow:hidden;display:flex;flex-direction:column;height:100%}
.svc-card>a:last-child,.svc-card>.pil-lnk{margin-top:auto}
.svc-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--p2),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-card:hover{background:var(--s2);border-color:rgba(191,93,159,.15);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.svc-num{font-size:32px;font-weight:700;color:rgba(191,93,159,.15);line-height:1;margin-bottom:14px;font-variant-numeric:tabular-nums}
.svc-card:hover .svc-num{color:rgba(191,93,159,.3)}
.svc-card-icon{width:44px;height:44px;background:rgba(191,93,159,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;transition:all var(--dur) var(--ease)}
.svc-card:hover .svc-card-icon{background:var(--p1);box-shadow:0 0 20px rgba(191,93,159,.2)}
.svc-card-icon svg{width:20px;height:20px;fill:var(--p2);transition:fill var(--dur) var(--ease)}
.svc-card:hover .svc-card-icon svg{fill:var(--tw)}
.svc-card h4{font-size:17px;font-weight:600;color:var(--tw);margin-bottom:8px}
.svc-card p{font-size:14px;color:var(--t40);line-height:1.65}

/* ═══ CYL-CARD — universal glass card (used in service pages) ═══ */
.cyl-card{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:32px 28px;display:flex;flex-direction:column;height:100%;transition:all var(--dur) var(--ease);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.cyl-card:hover{border-color:rgba(191,93,159,.15);transform:translateY(-2px)}
.cyl-card h4,.cyl-card h3{font-size:17px;font-weight:600;color:var(--tw);margin-bottom:8px}
.cyl-card p{font-size:14px;color:var(--t40);line-height:1.65}

/* ═══ SERVICE PAGE — COMPARISON ═══ */
.svc-compare{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:40px}
.svc-compare-card{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:36px 32px;text-align:center;backdrop-filter:blur(8px)}
.svc-compare-card.highlight{border-color:rgba(191,93,159,.25);background:var(--s2);box-shadow:0 0 40px rgba(191,93,159,.08)}
.svc-compare-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--t40);margin-bottom:12px}
.svc-compare-price{font-size:clamp(2rem,4vw,2.8rem);font-weight:700;color:var(--tw);line-height:1;margin-bottom:6px}
.svc-compare-price .sf{color:var(--p2)}
.svc-compare-note{font-size:13px;color:var(--t40);margin-bottom:20px}
.svc-compare-list{list-style:none;text-align:left}
.svc-compare-list li{font-size:13.5px;padding:8px 0 8px 22px;position:relative;color:var(--t60);border-bottom:1px solid var(--b1)}
.svc-compare-list li:last-child{border-bottom:none}
.svc-compare-list li::before{content:'';position:absolute;left:0;top:14px;width:6px;height:6px;border-radius:50%;background:var(--t25)}
.svc-compare-card.highlight .svc-compare-list li::before{background:var(--p2)}
.svc-compare-vs{display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--p2);margin:24px 0}

/* ═══ SERVICE PAGE — TIER PRICING ═══ */
.svc-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.svc-tier{background:var(--s1);border:1px solid var(--b1);border-radius:20px;padding:40px 32px;text-align:center;position:relative;overflow:hidden;backdrop-filter:blur(8px);transition:all var(--dur) var(--ease)}
.svc-tier::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--p2),transparent);opacity:0;transition:opacity .5s var(--ease)}
.svc-tier:hover::before{opacity:1}
.svc-tier.featured{border-color:rgba(191,93,159,.25);background:var(--s2)}
.svc-tier.featured::before{opacity:1}
.svc-tier:hover{transform:translateY(-4px);box-shadow:0 16px 56px rgba(0,0,0,.35)}
.svc-tier-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--tw);background:linear-gradient(135deg,var(--p2),var(--p1));padding:4px 14px;border-radius:100px;margin-bottom:16px}
.svc-tier-name{font-size:22px;font-weight:700;color:var(--tw);margin-bottom:8px}
.svc-tier-price{font-size:clamp(2rem,3.5vw,2.6rem);font-weight:700;color:var(--tw);line-height:1;margin-bottom:4px}
.svc-tier-price .sf{color:var(--p2)}
.svc-tier-period{font-size:13px;color:var(--t40);margin-bottom:24px}
.svc-tier-divider{width:100%;height:1px;background:var(--b1);margin:0 0 24px}
.svc-tier-list{list-style:none;text-align:left;margin-bottom:32px}
.svc-tier-list li{font-size:13.5px;padding:7px 0 7px 24px;position:relative;color:var(--t60)}
.svc-tier-list li::before{content:'';position:absolute;left:0;top:13px;width:8px;height:8px;border-radius:50%;border:2px solid var(--p2);background:transparent}
.svc-tier.featured .svc-tier-list li::before{background:var(--p2)}

/* ═══ SERVICE PAGE — INCLUDED LIST ═══ */
.svc-included{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:40px}
.svc-inc-item{display:flex;gap:14px;padding:18px 20px;background:var(--s1);border:1px solid var(--b1);border-radius:12px;transition:all var(--dur) var(--ease)}
.svc-inc-item:hover{background:var(--s2);border-color:rgba(191,93,159,.12)}
.svc-inc-item svg{width:20px;height:20px;fill:var(--p2);flex-shrink:0;margin-top:2px}
.svc-inc-item span{font-size:14px;color:var(--t80);line-height:1.5}

/* ═══ SERVICE PAGE — PROBLEM STATS ═══ */
.problem-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.problem-stat{text-align:center;padding:24px 16px;background:var(--s1);border:1px solid var(--b1);border-radius:12px}
.problem-stat-num{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:var(--p2);line-height:1;margin-bottom:6px}
.problem-stat-lbl{font-size:12px;font-weight:500;color:var(--t40);text-transform:uppercase;letter-spacing:1px}

/* ═══ SERVICE PAGE — WHY US CARDS ═══ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.why-card{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:32px 28px;text-align:center;backdrop-filter:blur(8px);transition:all var(--dur) var(--ease)}
.why-card:hover{background:var(--s2);border-color:rgba(191,93,159,.15);transform:translateY(-3px)}
.why-card svg{width:36px;height:36px;fill:var(--p2);margin-bottom:16px}
.why-card h4{font-size:16px;font-weight:600;color:var(--tw);margin-bottom:8px}
.why-card p{font-size:14px;color:var(--t40);line-height:1.65}

/* ═══ CERT DETAIL PAGE ═══ */
.cert-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.cert-card{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:32px 28px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all var(--dur) var(--ease);position:relative;overflow:hidden}
.cert-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--p2),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.cert-card:hover::after{transform:scaleX(1)}
.cert-card:hover{background:var(--s2);border-color:rgba(191,93,159,.15);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.cert-card-head{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.cert-card-head .cb{width:64px;height:64px;flex-shrink:0;font-size:11px;border-radius:14px}
.cert-card-head h3{font-size:16px;font-weight:600;color:var(--tw);line-height:1.3}
.cert-card-issuer{font-size:12px;font-weight:600;color:var(--p2);text-transform:uppercase;letter-spacing:1px}
.cert-card p{font-size:14px;color:var(--t40);line-height:1.7;margin-bottom:16px}
.cert-card-tags{display:flex;flex-wrap:wrap;gap:6px}
.cert-card-tags span{font-size:11px;font-weight:600;color:var(--p2);background:rgba(191,93,159,.08);padding:4px 10px;border-radius:100px;border:1px solid rgba(191,93,159,.12)}

/* ═══ CAREER PAGE ═══ */
.career-benefits{display:flex;flex-direction:column;gap:20px}
.career-benefit{display:flex;gap:24px;padding:32px 28px;background:var(--s1);border:1px solid var(--b1);border-radius:16px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all var(--dur) var(--ease)}
.career-benefit:hover{background:var(--s2);border-color:rgba(191,93,159,.15);transform:translateX(6px)}
.career-benefit-icon{width:52px;height:52px;flex-shrink:0;background:rgba(191,93,159,.08);border-radius:14px;display:flex;align-items:center;justify-content:center;transition:all var(--dur) var(--ease)}
.career-benefit:hover .career-benefit-icon{background:var(--p1);box-shadow:0 0 20px rgba(191,93,159,.2)}
.career-benefit-icon svg{width:24px;height:24px;stroke:var(--p2);fill:none;transition:stroke var(--dur) var(--ease)}
.career-benefit:hover .career-benefit-icon svg{stroke:var(--tw)}
.career-benefit h3{font-size:18px;font-weight:600;color:var(--tw);margin-bottom:8px}
.career-benefit p{font-size:14px;color:var(--t40);line-height:1.7}

.career-positions{display:flex;flex-direction:column;gap:0}
.career-position{padding:32px 0;border-bottom:1px solid var(--b1);transition:all var(--dur) var(--ease)}
.career-position:first-child{border-top:1px solid var(--b1)}
.career-position:hover{padding-left:12px}
.career-pos-header{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:12px}
.career-pos-header h3{font-size:18px;font-weight:600;color:var(--tw);margin-bottom:4px}
.career-pos-meta{display:flex;gap:16px;font-size:13px;color:var(--t40)}
.career-position p{font-size:14px;color:var(--t40);line-height:1.7;margin-bottom:12px}

.career-contact{text-align:center}
.career-contact-inner{max-width:560px;margin:0 auto;padding:48px 40px;background:var(--s1);border:1px solid var(--b1);border-radius:20px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.career-contact-icon{width:60px;height:60px;margin:0 auto 20px;background:rgba(191,93,159,.08);border-radius:16px;display:flex;align-items:center;justify-content:center}
.career-contact-icon svg{width:28px;height:28px;stroke:var(--p2);fill:none}
.career-contact-inner h3{font-size:22px;font-weight:700;color:var(--tw);margin-bottom:12px}
.career-contact-inner p{font-size:15px;color:var(--t40);line-height:1.7}

/* ═══ WP PAGINATION ═══ */
.nav-links{display:flex;align-items:center;justify-content:center;gap:6px}
.nav-links .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;font-size:14px;font-weight:600;color:var(--t40);background:var(--s1);border:1px solid var(--b1);border-radius:10px;transition:all var(--dur) var(--ease)}
.nav-links .page-numbers:hover{color:var(--tw);background:var(--s2);border-color:rgba(191,93,159,.15)}
.nav-links .page-numbers.current{color:var(--tw);background:var(--p1);border-color:var(--p2);box-shadow:0 0 20px rgba(191,93,159,.2)}
.nav-links .page-numbers.dots{border:none;background:none}

/* ═══ COMPANY CARDS (About page) ═══ */
.company-card{position:relative;overflow:hidden}
.company-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--p2),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.company-card:hover::after{transform:scaleX(1)}
.company-id{font-size:12px;font-weight:600;color:var(--p2);margin-bottom:12px;letter-spacing:.5px}
.company-focus{margin-top:16px}

/* ═══ TEAM CARDS FULL (Team page) ═══ */
.team-card-full{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:32px 28px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all var(--dur) var(--ease);position:relative;overflow:hidden}
.team-card-full::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--p2),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.team-card-full:hover::after{transform:scaleX(1)}
.team-card-full:hover{background:var(--s2);border-color:rgba(191,93,159,.15);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
/* Náš tím — hide certification sections (bezpečnostné + technologické) */
.elementor-element-22c3df5,.elementor-element-ef13131,.elementor-element-27d79af{display:none!important}
/* Ecosystem pillar cards — CTA aligned to bottom */
.cyl-eco-card{display:flex!important;flex-direction:column!important;height:100%!important}
.cyl-eco-link{margin-top:auto!important}
/* Circular photos — ALWAYS square aspect ratio to prevent oval stretching */
.team-card-full img[style*="border-radius"],.team-card img[style*="border-radius"],.cyl-testimonial img{aspect-ratio:1;object-fit:cover}
.tcf-header{display:flex;align-items:center;gap:16px;margin-bottom:18px}
.tcf-header .team-avatar{margin:0;flex-shrink:0}
.tcf-info{min-width:0}
.tcf-bio{font-size:14px;color:var(--t40);line-height:1.7;margin-bottom:18px}
.tcf-certs{display:flex;flex-wrap:wrap;gap:6px}

/* ═══ MAP PLACEHOLDER ═══ */
.map-placeholder{margin-top:20px;border-radius:12px;border:1px solid var(--b1);height:200px;background:var(--s2);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all var(--dur) var(--ease)}
.map-placeholder:hover{border-color:rgba(191,93,159,.12);background:var(--s3)}

/* ═══ CONTACT FORM ENHANCEMENTS ═══ */
.contact-form select.form-input{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23bf5d9f' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center;padding-right:44px;cursor:pointer}
.contact-form select.form-input option{background:var(--d3);color:var(--tw)}
.contact-form .btn{margin-top:8px}

/* ═══ PDF LEAD MAGNET ═══ */
.pdf-lead{display:flex;gap:32px;align-items:center;background:var(--s1);border:1px solid rgba(212,168,67,.2);border-radius:20px;padding:40px 36px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.pdf-lead-icon{flex-shrink:0;width:72px;height:72px;display:flex;align-items:center;justify-content:center;background:rgba(212,168,67,.06);border:1px solid rgba(212,168,67,.15);border-radius:16px}
.pdf-lead-content{flex:1}
@media(max-width:768px){.pdf-lead{flex-direction:column;text-align:center;padding:32px 24px;gap:20px}.pdf-lead-icon{margin:0 auto}.pdf-lead .el-label{text-align:center!important;display:block!important}}

/* ═══ HOMEPAGE BLOG GRID ═══ */
.hp-blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.hp-blog-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;cursor:pointer}
.hp-blog-card:hover{border-color:rgba(191,93,159,.2);box-shadow:0 12px 40px rgba(0,0,0,.3),0 0 20px rgba(191,93,159,.06);transform:translateY(-3px)}
.hp-blog-tag{display:inline-block;width:fit-content;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--p2);background:rgba(191,93,159,.08);padding:4px 10px;border-radius:100px;border:1px solid rgba(191,93,159,.12);margin-bottom:14px}
.hp-blog-card h4{font-size:17px;font-weight:600;color:var(--tw);margin-bottom:10px;line-height:1.35;transition:color var(--dur) var(--ease)}
.hp-blog-card:hover h4{color:var(--p3)}
.hp-blog-excerpt{font-size:14px;color:var(--t40);line-height:1.65;margin-bottom:auto;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.hp-blog-meta{display:flex;gap:14px;font-size:12px;color:var(--t25);margin-top:18px;padding-top:14px;border-top:1px solid var(--b1)}
.hp-blog-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--p2);margin-top:12px;transition:gap var(--dur) var(--ease)}
.hp-blog-card:hover .hp-blog-link{gap:12px}

/* ═══ NEWSLETTER ROW (Homepage) ═══ */
.nl-row{display:flex;align-items:center;justify-content:space-between;gap:40px;margin-top:56px;padding:40px 44px;background:var(--s1);border:1px solid var(--b1);border-radius:20px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.nl-row-text h3{font-size:20px;font-weight:700;color:var(--tw);margin-bottom:4px}
.nl-row-text p{font-size:14px;color:var(--t40);line-height:1.6}
.nl-row-form{display:flex;gap:12px;flex-shrink:0}
.nl-row-form .form-input{min-width:260px}

/* ═══ SECTION GRADIENT SEPARATORS ═══ */
/* Removed harsh purple lines — flowing gradients handle transitions now */

/* ═══ SECTION HEADER GLOW ON HOVER ═══ */
.st{transition:text-shadow .5s var(--ease)}
.sh:hover .st{text-shadow:0 0 30px rgba(191,93,159,.2),0 0 60px rgba(191,93,159,.08)}

/* ═══ CARD PURPLE GLOW ON HOVER ═══ */
.cd:hover{box-shadow:0 12px 40px rgba(0,0,0,.3),0 0 24px rgba(191,93,159,.08)}

/* ═══ PILLAR GLOW BORDER ON HOVER ═══ */
.pil{transition:all var(--dur) var(--ease),box-shadow .5s var(--ease)}
.pil:hover{box-shadow:0 16px 56px rgba(0,0,0,.35),0 0 30px rgba(191,93,159,.1),inset 0 0 30px rgba(191,93,159,.03)}
.pil:hover::after{transform:scaleX(1);box-shadow:0 0 12px rgba(191,93,159,.3)}

/* ═══ BUTTON HOVER ENHANCEMENT ═══ */
.btn{transition:all var(--dur) var(--ease),transform .2s var(--ease),box-shadow .3s var(--ease)}
.btn-g:hover{box-shadow:0 8px 40px rgba(191,93,159,.5),0 0 20px rgba(191,93,159,.15);transform:translateY(-2px) scale(1.02)}
.btn-o:hover{transform:translateY(-2px) scale(1.02);box-shadow:inset 0 0 0 1px rgba(191,93,159,.3),0 0 16px rgba(191,93,159,.06)}

/* ═══ HAMBURGER MENU ANIMATION ═══ */
.mbt{position:relative;width:36px;height:36px;display:none;background:none;border:1px solid var(--b2);border-radius:8px;cursor:pointer;padding:0;transition:all var(--dur) var(--ease)}
.mbt:hover{border-color:rgba(191,93,159,.3);background:var(--s2)}
.mbt span{display:block;width:18px;height:2px;background:var(--t60);position:absolute;left:50%;transform:translateX(-50%);transition:all .3s var(--ease);border-radius:2px}
.mbt span:nth-child(1){top:10px}
.mbt span:nth-child(2){top:17px}
.mbt span:nth-child(3){top:24px}
.mbt.active span:nth-child(1){top:17px;transform:translateX(-50%) rotate(45deg);background:var(--p2)}
.mbt.active span:nth-child(2){opacity:0;transform:translateX(-50%) scaleX(0)}
.mbt.active span:nth-child(3){top:17px;transform:translateX(-50%) rotate(-45deg);background:var(--p2)}

/* ═══ ELEMENTOR IMAGE CAROUSEL ═══ */
/* Override ALL background on carousel containers/sections/widgets */
.e-con:has(.elementor-widget-image-carousel),
.elementor-element:has(.elementor-widget-image-carousel),
.elementor-widget-image-carousel,
.elementor-widget-image-carousel .elementor-widget-container,
.elementor-widget-image-carousel .elementor-image-carousel,
.elementor-section:has(.elementor-widget-image-carousel),
.elementor-section:has(.elementor-widget-image-carousel) > .elementor-container,
.elementor-section:has(.elementor-widget-image-carousel) > .elementor-container > .elementor-column,
.elementor-section:has(.elementor-widget-image-carousel) > .elementor-container > .elementor-column > .elementor-widget-wrap{
  background:transparent!important;background-color:transparent!important;background-image:none!important}
.elementor-widget-image-carousel .swiper-wrapper{align-items:center}
.elementor-widget-image-carousel .swiper-slide{display:flex;align-items:center;justify-content:center;padding:16px 20px}
.elementor-widget-image-carousel .swiper-slide img{max-height:70px!important;height:70px!important;width:auto!important;object-fit:contain!important;filter:brightness(.9);transition:filter .3s var(--ease)}
.elementor-widget-image-carousel .swiper-slide img:hover{filter:brightness(1.1)}
.elementor-widget-image-carousel .elementor-swiper-button{color:rgba(191,93,159,.5)!important;font-size:18px!important;transition:color .3s var(--ease)}
.elementor-widget-image-carousel .elementor-swiper-button:hover{color:#bf5d9f!important}
.elementor-widget-image-carousel .swiper-pagination-bullet{background:rgba(191,93,159,.3)!important;opacity:1!important;width:8px;height:8px;transition:all .3s var(--ease)}
.elementor-widget-image-carousel .swiper-pagination-bullet-active{background:#bf5d9f!important;transform:scale(1.2)}

/* ═══ V MÉDIÁCH — compact tile grid ═══ */
.media-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.media-tile{display:flex;flex-direction:column;gap:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:20px 18px;text-decoration:none;color:inherit;transition:all .25s ease;cursor:pointer}
.media-tile:hover{border-color:rgba(191,93,159,.3);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.3)}
.media-tile h3{font-size:14px;font-weight:600;color:var(--tw);line-height:1.35;margin:0}
.media-tile-meta{font-size:11px;color:var(--t40);margin-top:auto}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){.media-grid{grid-template-columns:repeat(3,1fr)}.g3,.blog-grid,.hp-blog-grid{grid-template-columns:1fr}.blog-featured{grid-template-columns:1fr}.blog-featured .bf-img{min-height:200px}.nl-row{flex-direction:column;text-align:center;gap:24px}.nl-row-form{width:100%;justify-content:center}.nl-row-form .form-input{min-width:0;flex:1}.nums-g{grid-template-columns:repeat(2,1fr)}.ft-g{grid-template-columns:repeat(2,1fr)}.logos{grid-template-columns:repeat(3,1fr)}.rm{flex-wrap:wrap;gap:12px}.rm-s:not(:last-child)::after{display:none}.hero-art{display:none}.svc-intro{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr}.nl-features{grid-template-columns:1fr}.team-grid{grid-template-columns:repeat(2,1fr)}.svc-grid{grid-template-columns:repeat(2,1fr)}.svc-tiers{grid-template-columns:1fr}.svc-compare{grid-template-columns:1fr}.svc-included{grid-template-columns:1fr}.why-grid{grid-template-columns:1fr}.problem-stats{grid-template-columns:1fr}.cert-detail-grid{grid-template-columns:1fr}}
@media(max-width:768px){.nv{display:none}.mbt{display:flex;align-items:center;justify-content:center}.hero-c{padding:120px 0 80px}.blog-hero{padding:70px 0 0}.blog-hero h1{font-size:24px}.blog-featured .bf-img{min-height:160px}.blog-featured .bf-body{padding:20px}.blog-featured .bf-body h2{font-size:18px}.blog-img{height:120px}.s-pad{padding:72px 0}.blog-hero+.s .s-pad{padding-top:8px!important}.nums{padding:56px 0}.quotes,.g2{grid-template-columns:1fr}.logos{grid-template-columns:repeat(2,1fr)}.ft-g{grid-template-columns:1fr;gap:28px}.ft-bt{flex-direction:column;gap:12px;text-align:center}.hero-a{flex-direction:column;align-items:flex-start}.strip-i{flex-direction:column;gap:12px}.rm{flex-direction:column;align-items:center}.nl-form{flex-direction:column}.nl-row-form{flex-direction:column}.nl-row-form .form-input{min-width:0}.svc-item{flex-direction:column;gap:12px}.svc-intro-stats{flex-direction:column;gap:24px}.team-grid{grid-template-columns:1fr}.career-benefit{flex-direction:column;gap:16px}.career-pos-header{flex-direction:column;align-items:flex-start;gap:12px}.tcf-header{flex-direction:column;text-align:center}.tcf-certs{justify-content:center}}

/* ═══ LANGUAGE SWITCHER ═══ */
.lng{display:flex;align-items:center;gap:4px}
.lng a,.lng span{font-size:12px;font-weight:600;color:var(--t25);transition:color var(--dur) var(--ease);text-decoration:none}
.lng a:hover,.lng span.on,.lng .current-lang{color:var(--p2)}
/* Polylang outputs <ul> list */
.lng ul{display:flex;align-items:center;gap:0;list-style:none;margin:0;padding:0}
.lng ul li{display:flex;align-items:center}
.lng ul li:not(:last-child)::after{content:'/';color:var(--t25);margin:0 4px;font-size:12px}
.lng ul li a{font-size:12px;font-weight:600;color:var(--t25);text-decoration:none;transition:color var(--dur) var(--ease)}
.lng ul li.current-lang a{color:var(--p2)}
.lng ul li a:hover{color:var(--p2)}

/* ═══ WORDPRESS NAV MENU (duplicate removed — see above) ═══ */
/* Active page highlight */
.nv .menu li.current-menu-item>a,.nv .menu li.current-menu-ancestor>a,.nv .menu li.current-page-ancestor>a{color:var(--p2)}

/* ═══ WORDPRESS OVERRIDES ═══ */
body,html{background:var(--d1)!important;color:var(--t80)!important}
.ft{background:var(--d1);position:relative;z-index:2}
#wpadminbar~.pg{margin-top:0}
body.admin-bar .hd{top:32px}
@media(max-width:782px){body.admin-bar .hd{top:46px}}
a{color:inherit}
.s,.hero,.strip,.ft,.cta{position:relative;z-index:1}

/* ═══ ELEMENTOR PAGE OVERRIDES ═══ */
/* Header — fixed at top, above all content */
.elementor-location-header{position:fixed!important;top:0;left:0;right:0;z-index:99999!important;
  backdrop-filter:blur(20px)!important;-webkit-backdrop-filter:blur(20px)!important;
  box-shadow:0 1px 0 rgba(255,255,255,.06)!important;
  background:rgba(14,10,18,.85)!important}
/* Header inner — single horizontal row */
.elementor-location-header .e-con-inner{flex-direction:row!important;align-items:center!important;gap:16px!important;padding:8px 0!important}
/* Logo vertical alignment — match nav item baseline */
.elementor-location-header .elementor-widget-image{display:flex!important;align-items:center!important}
.elementor-location-header .elementor-widget-image img{height:36px!important;width:auto!important}
/* Mobile dropdown nav hidden by default — only target the NAV container, NOT desktop UL.sub-menu */
.elementor-location-header > .elementor > .e-con > .e-con-inner nav.elementor-nav-menu--dropdown{display:none!important}
.elementor-location-header nav.elementor-nav-menu--dropdown.elementor-nav-menu--dropdown--opened{display:block!important}
/* Desktop sub-menu dropdowns — show on hover */
.elementor-nav-menu--main li.menu-item-has-children:hover>.sub-menu{display:block!important;visibility:visible!important;opacity:1!important}
body.admin-bar .elementor-location-header{top:32px!important}
@media(max-width:782px){body.admin-bar .elementor-location-header{top:46px!important}}
/* Legacy cyl-header class (if set in Elementor section) */
.cyl-header{
  backdrop-filter:blur(20px)!important;
  -webkit-backdrop-filter:blur(20px)!important;
  box-shadow:0 1px 0 rgba(255,255,255,.06)!important;
}
/* Elementor pages: offset content below fixed header */
.elementor-location-header + .elementor{padding-top:80px!important}
/* PHP fallback pages: offset below fixed header */
.hd + .page-hero,.hd + .hero,.hd + .blog-hero,.hd + .s{padding-top:80px!important}
.elementor-default .elementor,
.elementor-template-full-width .elementor{
  position:relative;z-index:1;
}
/* Remove Elementor default section gaps */
.elementor-element > .e-con{margin-bottom:0!important}
/* Elementor label badge styling */
.el-label,.elementor-widget-text-editor .el-label{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  color:var(--p2);margin-bottom:16px;
}
.el-label::before{content:'';width:20px;height:1.5px;background:var(--p2)}
/* Glass card styles for Elementor HTML widgets */
.el-card{
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
  border-radius:16px;padding:32px 28px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:all var(--dur) var(--ease);
}
.el-card:hover{
  background:rgba(255,255,255,.06);border-color:rgba(191,93,159,.15);
  transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.3);
}
/* CTA section gradient glow */
.el-cta-section{position:relative}
.el-cta-section::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(191,93,159,.08) 0%,transparent 65%);pointer-events:none}
/* Elementor heading colors */
.elementor-widget-heading .elementor-heading-title{line-height:1.15!important}
/* Smooth section transitions — hide harsh divider lines */
.e-con + .e-con{border-top:none!important}
.elementor-widget-divider .elementor-divider-separator{opacity:.12!important}
.elementor-widget-divider{margin-top:0!important;margin-bottom:0!important}
/* Elementor nav-menu — compact with working dropdowns */
.elementor-nav-menu--main .elementor-item{padding:6px 12px!important;font-size:13.5px!important}
.elementor-nav-menu--main .sub-menu{z-index:99999!important;background:rgba(14,10,18,.95)!important;backdrop-filter:blur(20px)!important;-webkit-backdrop-filter:blur(20px)!important;border:1px solid rgba(212,168,67,.3)!important;border-radius:10px!important;box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 20px rgba(212,168,67,.06)!important;padding:6px!important;min-width:220px!important;white-space:nowrap!important}
.elementor-nav-menu--main .sub-menu li{list-style:none!important}
.elementor-nav-menu--main .sub-menu a{font-size:13.5px!important;color:rgba(255,255,255,.6)!important;padding:9px 16px!important;border-radius:6px!important;display:block!important;transition:all .25s ease!important;white-space:nowrap!important}
.elementor-nav-menu--main .sub-menu a:hover,.elementor-nav-menu--main .sub-menu a:focus{background:rgba(255,255,255,.06)!important;color:#fff!important}
.elementor-nav-menu--dropdown .elementor-item{padding:8px 14px!important}
/* Fix Elementor container max-width */
.e-con.e-con-boxed > .e-con-inner{max-width:1160px}
/* Reduce Elementor widget spacing */
.elementor-widget:not(:last-child){margin-bottom:16px!important}
/* Contact Form 7 dark theme */
.wpcf7 input,.wpcf7 textarea,.wpcf7 select{
  width:100%;background:rgba(255,255,255,.04)!important;
  border:1px solid rgba(255,255,255,.1)!important;
  border-radius:10px!important;padding:14px 18px!important;
  font-family:var(--f)!important;font-size:14px!important;
  color:#fff!important;outline:none!important;
  transition:all var(--dur) var(--ease)!important;
}
.wpcf7 input:focus,.wpcf7 textarea:focus{
  border-color:var(--p2)!important;
  box-shadow:0 0 0 3px rgba(191,93,159,.1)!important;
}
.wpcf7 input[type="submit"]{
  background:linear-gradient(135deg,var(--p2),var(--p1))!important;
  border:none!important;cursor:pointer!important;
  font-weight:600!important;letter-spacing:.5px!important;
  box-shadow:0 4px 20px rgba(191,93,159,.35)!important;
  transition:all var(--dur) var(--ease)!important;
}
.wpcf7 input[type="submit"]:hover{
  box-shadow:0 8px 40px rgba(191,93,159,.5)!important;
  transform:translateY(-2px)!important;
}
.wpcf7 label{font-size:12px;font-weight:600;color:rgba(255,255,255,.58);
  text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:6px}
.wpcf7 textarea{min-height:140px;resize:vertical}
.wpcf7 .wpcf7-not-valid-tip{color:var(--p3);font-size:12px}
.wpcf7-response-output{border-color:var(--p2)!important;color:var(--t60)!important;
  border-radius:10px!important;font-size:14px!important}
/* Premium/Gold accent for Strategické riadenie */
.el-premium-card{border-color:var(--gold) !important;background:linear-gradient(135deg,rgba(212,168,67,.06),rgba(201,149,44,.02)) !important}
.el-premium-card:hover{border-color:var(--gold-light) !important;background:linear-gradient(135deg,rgba(212,168,67,.12),rgba(201,149,44,.04)) !important}
.el-premium-badge{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:#0e0a12;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;border-radius:20px}
.el-gold-text{color:var(--gold) !important}
.el-gold-border{border-color:var(--gold) !important}

/* Hierarchy diagram styles */
.el-hierarchy{max-width:700px;margin:0 auto;font-family:var(--f)}
.el-hierarchy .h-top{background:linear-gradient(135deg,rgba(212,168,67,.12),rgba(201,149,44,.04));border:1px solid var(--gold);border-radius:12px 12px 0 0;padding:20px 24px;text-align:center}
.el-hierarchy .h-mid{background:rgba(191,93,159,.08);border:1px solid rgba(191,93,159,.3);border-top:none;padding:16px 24px;text-align:center}
.el-hierarchy .h-bot{display:flex;border:1px solid rgba(255,255,255,.1);border-top:none;border-radius:0 0 12px 12px;overflow:hidden}
.el-hierarchy .h-bot > div{flex:1;padding:16px;text-align:center;border-right:1px solid rgba(255,255,255,.06)}
.el-hierarchy .h-bot > div:last-child{border-right:none}
.el-hierarchy .h-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px}
.el-hierarchy .h-name{font-weight:600;font-size:15px;color:#fff}
.el-hierarchy .h-sub{font-size:12px;color:var(--t60)}

/* Cyllinder Program highlight */
.el-cyllinder{border:2px solid var(--p2) !important;background:linear-gradient(135deg,rgba(191,93,159,.08),rgba(94,42,82,.04)) !important;border-radius:20px !important;padding:40px !important}

/* Tier cards */
.el-tier-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:32px;transition:all .35s var(--ease)}
.el-tier-card:hover{border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.05)}
.el-tier-card.el-tier-featured{border-color:var(--p2);position:relative}
.el-tier-card .el-tier-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--p2);color:#fff;padding:4px 16px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}
.el-tier-card .el-check{color:#4ade80;margin-right:8px}
.el-tier-card .el-dash{color:var(--t25);margin-right:8px}

/* ═══════════════════════════════════════════════
   GLOBAL LAYOUT RULES v1.3
   Compact spacing, consistent alignment, max-width
   ═══════════════════════════════════════════════ */

/* Max-width & centering */
.elementor-section .elementor-container{max-width:1140px!important;margin:0 auto!important}

/* Section padding — compact */
.elementor-section{padding:36px 0!important}
.elementor-section:first-child{padding:56px 0 32px!important}
.elementor-section:last-child{padding:40px 0!important}

/* Widget spacing — tighter */
.elementor-widget{margin-bottom:12px!important}
.elementor-widget:last-child{margin-bottom:0!important}

/* Headings spacing */
.elementor-heading-title{margin-bottom:12px!important}
h1.elementor-heading-title{margin-bottom:16px!important}

/* El-label spacing */
.el-label{margin-bottom:8px!important;display:inline-block}

/* Section headings centered */
.elementor-section:not(:first-child) .elementor-widget-heading{text-align:center!important}
.elementor-section:not(:first-child) .elementor-heading-title{text-align:center!important}

/* Hero section — left aligned */
.elementor-section:first-child .elementor-widget-heading{text-align:left!important}
.elementor-section:first-child .elementor-heading-title{text-align:left!important}

/* Breadcrumb */
.ph-breadcrumb,p:has(> a[href="/"]):first-child{font-size:13px!important;opacity:.5!important;margin-bottom:12px!important}

/* Buttons — uniform */
.elementor-button{padding:14px 32px!important;border-radius:10px!important;font-weight:600!important;transition:all .25s ease!important}
.elementor-button:hover{transform:translateY(-1px)!important}

/* Card hover — uniform */
[style*="border-radius:16px"]{transition:all .25s ease!important}
[style*="border-radius:16px"]:hover{border-color:rgba(191,93,159,.3)!important;transform:translateY(-2px)!important}

/* Links — underline on hover */
.elementor-widget-text-editor a:hover{text-decoration:underline!important}

/* Footer — transparent for honeycomb, gold separator line (subtle) */
.elementor-location-footer{margin-top:0!important;background:transparent!important;border-top:1px solid rgba(212,168,67,.3)!important}
.elementor-location-footer .e-con{background:transparent!important}
footer.elementor-location-footer .elementor-section:first-child{padding:48px 0 32px!important;background:transparent!important}
/* Footer — reduce ALL spacing between sections */
.elementor-location-footer .e-con.e-parent>.e-con-inner{gap:12px!important}
.elementor-location-footer .e-con>.e-con-inner{gap:8px!important}
.elementor-location-footer .elementor-widget{margin-bottom:6px!important}
/* Copyright row — minimal spacing */
.elementor-location-footer .elementor-element-a50b97c{padding:0!important;margin:0!important}
.elementor-location-footer .elementor-element-a50b97c .elementor-widget{margin-bottom:2px!important}
/* Description text in first column — reduce bottom margin */
.elementor-location-footer .elementor-element-4a8fc13{margin-bottom:0!important}
/* Force footer bottom padding smaller */
.elementor-location-footer>.e-con-inner{padding-bottom:16px!important}

/* Smooth scroll */
html{scroll-behavior:smooth;scroll-padding-top:140px}

/* No empty space */
.elementor-section{min-height:0!important}

/* ═══════════════════════════════════════════════
   COMPREHENSIVE MOBILE & TABLET RESPONSIVE
   ═══════════════════════════════════════════════ */

/* === TABLET (max 1024px) === */
@media(max-width:1024px){
  /* Elementor sections reduce padding */
  .elementor-section{padding-left:16px!important;padding-right:16px!important}

  /* Inline grid overrides — 4col becomes 2col */
  [style*="grid-template-columns: repeat(4"],[style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr)!important}
  [style*="grid-template-columns: repeat(5"],[style*="grid-template-columns:repeat(5"]{grid-template-columns:repeat(2,1fr)!important}
  [style*="grid-template-columns: repeat(6"],[style*="grid-template-columns:repeat(6"]{grid-template-columns:repeat(2,1fr)!important}

  /* Stats grid */
  .hp-stat .n{font-size:28px!important}

  /* Hero heading smaller */
  .el-hero-section h1,.elementor-heading-title{font-size:36px!important}

  /* Download banner — stack vertically */
  [style*="display:flex"][style*="Poradca"],[style*="display:flex"][style*="Stiahnuť"]{flex-direction:column!important;text-align:center!important;gap:12px!important}

  /* Language switcher position */
  [style*="position:fixed"][style*="right:180px"]{right:16px!important;top:auto!important;bottom:16px!important;background:rgba(14,10,18,.9)!important;padding:8px 14px!important;border-radius:20px!important;border:1px solid rgba(191,93,159,.3)!important;backdrop-filter:blur(10px)!important}
}

/* === MOBILE (max 768px) === */
@media(max-width:768px){
  /* Base — prevent ANY horizontal overflow */
  html,body{overflow-x:hidden!important;max-width:100vw!important}
  html{scroll-padding-top:180px!important}
  .ctr{padding:0 16px}

  /* Elementor Header — compact single row: LOGO left, HAMBURGER center, FLAGS right */
  .elementor-location-header .e-con-inner{padding:8px 16px!important;flex-direction:row!important;flex-wrap:nowrap!important;align-items:center!important;justify-content:center!important;gap:0!important;min-height:0!important}
  .elementor-location-header .elementor-nav-menu--main{display:none!important}
  .elementor-location-header .elementor-widget-nav-menu{display:none!important;order:99!important}
  .elementor-location-header .elementor-widget-button{display:none!important}
  .elementor-location-header .elementor-widget-text-editor{display:none!important}
  /* Logo — left, takes available space */
  .elementor-location-header .elementor-widget-image{order:1!important;flex:1 1 0%!important;margin:0!important;padding:0!important;min-width:0!important}
  .elementor-location-header .elementor-widget-image img{height:28px!important;width:auto!important}
  /* Hamburger — center (injected into inner via JS with order:2) */
  .elementor-location-header .elementor-menu-toggle{display:none!important}
  .cyl-mobile-toggle{flex:0 0 auto!important;position:static!important;transform:none!important}
  /* Language flags — right, takes available space, aligned right */
  .elementor-location-header .lng{order:3!important;flex:1 1 0%!important;margin:0!important;display:flex!important;justify-content:flex-end!important}
  /* Elementor mobile dropdown overlay — target NAV only, not UL.sub-menu */
  nav.elementor-nav-menu--dropdown{display:none!important;position:fixed!important;top:56px!important;left:0!important;right:0!important;width:100%!important;height:calc(100vh - 56px)!important;background:rgb(14,10,18)!important;backdrop-filter:blur(20px)!important;-webkit-backdrop-filter:blur(20px)!important;padding:24px 20px!important;overflow-y:auto!important;z-index:99998!important;border:none!important;box-shadow:none!important}
  nav.elementor-nav-menu--dropdown .elementor-item{display:block!important;padding:14px 8px!important;font-size:18px!important;font-weight:500!important;color:rgba(255,255,255,.85)!important;border-bottom:1px solid rgba(255,255,255,.08)!important}
  nav.elementor-nav-menu--dropdown .elementor-item:hover{color:var(--tw)!important;background:var(--s2)!important}
  nav.elementor-nav-menu--dropdown .sub-menu{background:rgba(255,255,255,.08)!important;border-radius:8px!important;margin:4px 0 8px!important;padding:4px 0!important;display:none!important;position:static!important;opacity:1!important;visibility:visible!important;transform:none!important;box-shadow:none!important;min-width:0!important}
  nav.elementor-nav-menu--dropdown li.open>.sub-menu{display:block!important}
  nav.elementor-nav-menu--dropdown .sub-menu .elementor-item,
  nav.elementor-nav-menu--dropdown .sub-menu a,
  nav.elementor-nav-menu--dropdown .sub-menu li a{font-size:15px!important;padding:12px 20px!important;border-bottom:none!important;color:rgba(255,255,255,.75)!important}

  /* PDF badge — hide on mobile */
  #cyl-pdf-badge{display:none!important}

  /* PHP fallback header */
  .hd-wrap{height:56px!important}
  .hd .logo img{height:28px!important}
  .hd-r .btn{display:none!important}
  .hd-r .lng{display:none!important}
  .mbt{display:flex!important;align-items:center;justify-content:center}
  /* Mobile nav — fullscreen overlay, toggled via .mob-open */
  .nv{position:fixed!important;top:56px;left:0;right:0;bottom:0;background:rgba(14,10,18,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:24px 20px;overflow-y:auto;z-index:99998;flex-direction:column;display:none!important}
  .nv.mob-open{display:flex!important}
  .nv .menu{flex-direction:column;gap:0;width:100%}
  .nv .menu>li>a{display:block;padding:14px 8px;font-size:18px;font-weight:500;border-bottom:1px solid rgba(255,255,255,.06)}
  .nv .menu li.menu-item-has-children>a::after{float:right;margin-top:6px;transition:transform .25s ease}
  .nv .menu li.menu-item-has-children.open>a::after{transform:rotate(180deg)}
  .nv .menu .sub-menu{position:static;display:none;opacity:1;visibility:visible;transform:none;background:rgba(255,255,255,.03);border:none;border-radius:8px;box-shadow:none;margin:4px 0 8px;padding:4px 0;min-width:0}
  .nv .menu li.open>.sub-menu{display:block}
  .nv .menu .sub-menu li a{padding:12px 20px;font-size:15px;border-radius:0}
  .nv .menu li:hover>.sub-menu{opacity:1;visibility:visible;transform:none}

  /* Elementor containers */
  .e-con{padding-left:20px!important;padding-right:20px!important}
  .elementor-nav-menu--main{display:none!important}

  /* Hero */
  .el-hero-section{padding-top:80px!important;padding-bottom:32px!important}
  .el-hero-section h1,.elementor-heading-title[style*="font-size:56px"],.elementor-heading-title[style*="font-size: 56px"]{font-size:28px!important;line-height:1.2!important}
  .elementor-heading-title[style*="font-size:36px"],.elementor-heading-title[style*="font-size: 36px"]{font-size:24px!important}
  .elementor-heading-title[style*="font-size:42px"],.elementor-heading-title[style*="font-size: 42px"]{font-size:26px!important}

  /* All inline grids become single column on mobile */
  [style*="grid-template-columns: repeat(4"],[style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns: repeat(3"],[style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns: repeat(2"],[style*="grid-template-columns:repeat(2"],
  [style*="grid-template-columns: repeat(5"],[style*="grid-template-columns:repeat(5"],
  [style*="grid-template-columns: repeat(6"],[style*="grid-template-columns:repeat(6"],
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}

  /* Service pillar cards on homepage — single column */
  .svc-card,[style*="display:grid"] > a[style*="border-radius:16px"]{width:100%!important}

  /* Download banner — full stack */
  [style*="display:flex"][style*="gap:20px"][style*="border-radius:16px"]{flex-direction:column!important;text-align:center!important;padding:16px!important;gap:12px!important}
  [style*="display:flex"][style*="gap:20px"] > [style*="flex-shrink:0"]{display:none}
  [style*="display:flex"][style*="gap:24px"][style*="border:1px solid #d4a843"]{flex-direction:column!important;text-align:center!important;padding:20px 16px!important;gap:12px!important}

  /* Elementor section padding */
  .elementor-section .elementor-container{padding:0 16px!important}
  .elementor-section{padding-top:40px!important;padding-bottom:40px!important}
  .el-hero-section{padding-top:80px!important;padding-bottom:32px!important}

  /* Stats */
  .hp-stat .n{font-size:24px!important}
  .hp-stat .l{font-size:10px!important}

  /* Hierarchy diagram — 5 pillars become 1 column on mobile */
  [style*="grid-template-columns: repeat(5"],[style*="grid-template-columns:repeat(5"]{grid-template-columns:1fr!important}

  /* Process steps (01-05) — Elementor flex containers must stack */
  .e-con.e-con-boxed > .e-con-inner{flex-direction:column!important;gap:16px!important}
  /* Elementor columns inside sections — full width on mobile */
  .elementor-column{width:100%!important;flex:0 0 100%!important}
  .elementor-column-wrap,.elementor-widget-wrap{width:100%!important}

  /* Stat cards — uniform width, centered */
  .e-con-inner [style*="border-radius"][style*="text-align:center"],
  .e-con-inner [style*="border-radius"][style*="text-align: center"]{width:100%!important;max-width:320px!important;margin:0 auto!important}

  /* Contact page IČO — stack vertically */
  [style*="IDENTIFIKA"] ~ div, .company-id-row{flex-direction:column!important}

  /* All Elementor grids/flex — uniform gaps */
  .e-con-inner{gap:16px!important}

  /* Block spacing — consistent sections */
  .elementor-section + .elementor-section{margin-top:0!important}
  .e-con + .e-con{margin-top:0!important}

  /* Tier cards stack */
  .el-tier-card{padding:20px!important}

  /* Team 2x2 → 1 column */
  .tm-grid{grid-template-columns:1fr!important}
  img.tm-avatar,.tm-card img{width:100px!important;height:100px!important;aspect-ratio:1!important;object-fit:cover!important;border-radius:50%!important}

  /* Client cards — 2 columns on mobile */
  .cl-card{padding:14px 10px!important;min-height:60px!important}
  .cl-card span{font-size:12px!important}

  /* Blog grid */
  .blog-grid{grid-template-columns:1fr!important;gap:16px!important}
  .blog-card-inner{padding:16px!important}

  /* Homepage blog — show only 1 card on mobile, hide rest */
  .hp-blog-grid{grid-template-columns:1fr!important;gap:16px!important}
  .hp-blog-grid>.hp-blog-card:nth-child(n+2){display:none!important}
  .hp-blog-card h4{font-size:15px!important}
  .hp-blog-tag{font-size:9px!important}
  /* Elementor blog/posts grid — force 1 column on mobile */
  .elementor-posts-container,.elementor-posts,.elementor-grid{grid-template-columns:1fr!important}
  .elementor-posts-container .elementor-post,.elementor-grid .e-loop-item{width:100%!important}
  .e-loop-grid .e-con-inner{grid-template-columns:1fr!important}
  /* Process steps + any flex:1 items — force full width on mobile */
  [style*="flex: 1"][style*="min-width: 160px"],
  [style*="flex:1"][style*="min-width:160px"]{min-width:0!important;width:100%!important;flex:none!important}
  /* Blog cards: flex container → column, show only 1 card */
  [style*="display:flex"][style*="flex-wrap:wrap"][style*="gap:24px"]{flex-direction:column!important;gap:16px!important}
  [style*="flex: 1 1 0"][style*="min-width: 280px"],
  [style*="flex:1"][style*="min-width:280px"]{min-width:0!important;width:100%!important;flex:none!important}
  /* All inline flex containers with wrap — column on mobile */
  [style*="display: flex"][style*="flex-wrap: wrap"]{flex-direction:column!important;gap:16px!important}
  [style*="display:flex"][style*="flex-wrap:wrap"]{flex-direction:column!important;gap:16px!important}
  [style*="flex: 1 1 0"][style*="min-width: 280px"]:nth-child(n+2){display:none!important}
  [style*="min-width:280px"]{min-width:0!important;width:100%!important}

  /* Strategické riadenie / gold cards — prevent overflow */
  .el-hierarchy,.el-tier-card,[style*="border:1px solid #d4a843"],[style*="border: 1px solid #d4a843"]{max-width:100%!important;overflow:hidden!important;box-sizing:border-box!important}
  .el-hierarchy .h-top,.el-hierarchy .h-mid,.el-hierarchy .h-bot{max-width:100%!important;overflow:hidden!important}
  /* Scrolling text strips — clip and allow wrap on mobile */
  .strip,.strip-i{overflow:hidden!important;max-width:100%!important}
  .strip-l,.strip-nm,.strip *{white-space:normal!important}
  /* Elementor heading/text — force wrapping + Slovak hyphenation */
  .elementor-widget-heading .elementor-heading-title{white-space:normal!important;word-break:normal!important;overflow-wrap:break-word!important;hyphens:none!important;-webkit-hyphens:none!important;text-wrap:balance}
  .elementor-widget-text-editor{white-space:normal!important;word-break:normal!important;overflow-wrap:break-word!important;hyphens:none!important;-webkit-hyphens:none!important}
  /* All headings — Slovak hyphenation on mobile */
  h1,h2,h3,h4,.el-label,.elementor-heading-title{hyphens:none!important;-webkit-hyphens:none!important;overflow-wrap:break-word!important;word-break:normal!important;text-wrap:balance}
  /* Gold "Strategické riadenie spája" strip — force wrap on mobile */
  [style*="white-space:nowrap"],[style*="white-space: nowrap"]{white-space:normal!important}
  .elementor-widget-html [style*="nowrap"]{white-space:normal!important;position:static!important;transform:none!important;text-align:center!important;margin:8px auto!important;display:block!important}
  .elementor-widget-html [style*="nowrap"] span{white-space:normal!important}
  /* Hide DNA spiral on mobile — too compressed, services visible via pillar cards */
  .dna-hero-wrap{display:none!important}
  /* Hero section — back to single column on mobile */
  .elementor-section:first-child .elementor-column{width:100%!important;flex:0 0 100%!important}
  /* All overflow protection for Elementor content on mobile */
  .e-con,.e-con-inner,.elementor-widget-wrap,.elementor-widget,.elementor-element{max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box!important}

  /* Footer — PHP fallback */
  .ft-g{grid-template-columns:1fr!important;gap:24px!important}
  .ft .logo img{height:48px!important}
  .ft-bt{flex-direction:column!important;gap:8px!important;text-align:center!important;align-items:center!important;padding:16px 0!important}
  .ft-bt span{font-size:12px!important;line-height:1.5!important;display:block!important;text-align:center!important}
  .ft-bl{justify-content:center!important;flex-wrap:wrap!important;gap:12px!important}
  .ft-bl a{font-size:12px!important}
  /* Elementor footer copyright — center everything */
  .elementor-location-footer .e-con-inner{align-items:center!important}
  .ft h4{font-size:10px!important;margin-bottom:12px!important}
  .ft-a p{font-size:13px!important}
  .ft-ci{font-size:13px!important}
  .ft-ci span{font-size:13px!important}
  /* Footer — Elementor (ID 53): copyright text + all text sizing + centering */
  .elementor-location-footer .elementor-heading-title{font-size:13px!important;line-height:1.5!important;text-align:center!important}
  .elementor-element-e2f4cec .elementor-heading-title{font-size:12px!important;line-height:1.5!important;text-align:center!important}
  .elementor-location-footer .elementor-widget-text-editor{font-size:13px!important;text-align:center!important}
  .elementor-location-footer .elementor-widget-text-editor p{font-size:13px!important}
  .elementor-location-footer .e-con{text-align:center!important}
  .elementor-location-footer .elementor-widget-image{text-align:center!important}
  .elementor-location-footer .elementor-icon-list-items{justify-content:center!important}
  .elementor-location-footer .elementor-icon-list-text{font-size:13px!important}

  /* Testimonial / personal guarantee — stack photo + text on mobile */
  .elementor-section .elementor-row,.elementor-section .elementor-container{flex-direction:column!important}
  .elementor-section .elementor-column{width:100%!important;flex:0 0 100%!important}
  /* .cyl-testimonial — inline flex container with photo + quote */
  .cyl-testimonial{flex-direction:column!important;text-align:center!important;padding:24px 20px!important;gap:20px!important}
  .cyl-testimonial>[style*="flex-shrink"]{margin:0 auto!important}
  .cyl-testimonial img{margin:0 auto!important;display:block!important;aspect-ratio:1!important;object-fit:cover!important;border-radius:50%!important;width:120px!important;height:120px!important}
  /* ALL circular photos — force square aspect ratio on mobile to prevent oval stretching */
  img[style*="border-radius:50%"],img[style*="border-radius: 50%"],.elementor-widget-image img[style*="border-radius"]{aspect-ratio:1!important;object-fit:cover!important}
  .team-avatar,.team-avatar img{aspect-ratio:1!important;object-fit:cover!important}
  .team-card-full img,.team-card img{aspect-ratio:1!important;object-fit:cover!important;border-radius:50%!important;max-width:120px!important;max-height:120px!important;margin:0 auto!important}
  /* Testimonial quote text — readable on mobile */
  [style*="font-style:italic"],[style*="font-style: italic"]{font-size:16px!important;line-height:1.6!important}

  /* Buttons — full width on mobile */
  [style*="display:inline-flex"][style*="padding:14px 32px"],
  [style*="display:inline-flex"][style*="padding:12px 28px"],
  [style*="display:inline-flex"][style*="padding:12px 24px"],
  [style*="display:inline-flex"][style*="padding:10px 24px"]{width:100%!important;justify-content:center!important;box-sizing:border-box!important}

  /* CTA buttons row — stack */
  [style*="display:flex"][style*="gap:14px"][style*="flex-wrap:wrap"]{flex-direction:column!important;gap:10px!important}

  /* Reduce excessive padding on sections */
  [style*="padding:100px"],[style*="padding: 100px"]{padding:60px 0!important}
  [style*="padding:80px"],[style*="padding: 80px"]{padding:48px 0!important}
  [style*="padding:64px"],[style*="padding: 64px"]{padding:40px 0!important}
  [style*="padding:56px"],[style*="padding: 56px"]{padding:36px 0!important}

  /* Logo watermark — smaller on mobile */
  .el-hero-section::after{width:250px!important;height:250px!important;right:-15%!important;opacity:.02!important}
  .elementor-section:nth-child(6n+3)::before,.elementor-section:nth-child(6n+5)::before{display:none!important}

  /* Language switcher — bottom right floating */
  [style*="position:fixed"][style*="right:180px"]{right:16px!important;top:auto!important;bottom:16px!important;background:rgba(14,10,18,.95)!important;padding:8px 14px!important;border-radius:20px!important;border:1px solid rgba(191,93,159,.3)!important;backdrop-filter:blur(10px)!important;-webkit-backdrop-filter:blur(10px)!important}

  /* CSR cards, value cards etc */
  .csr-card,.os-stat{padding:16px!important}

  /* Single post */
  .single-content{padding:0 8px}
  .page-hero h1{font-size:26px!important}
  .post-meta{flex-wrap:wrap;gap:8px}

  /* Contact form */
  .wpcf7 input,.wpcf7 textarea{font-size:16px!important}

  /* Company strip — stack */
  [style*="SKUPINA SPOLOČNOSTÍ"]{flex-direction:column!important;gap:8px!important;text-align:center!important}

  /* Certifications badges — wrap */
  [style*="display:flex"][style*="flex-wrap:wrap"][style*="gap:12px"]{gap:8px!important}
  [style*="padding:8px 20px"][style*="border-radius:20px"]{padding:6px 12px!important;font-size:11px!important}

  /* Process/roadmap steps */
  [style*="display:flex"][style*="align-items:center"][style*="gap:16px"] > [style*="width:40px"]{width:32px!important;height:32px!important;min-width:32px!important;font-size:14px!important}

  /* Touch targets — minimum 44px for interactive elements */
  .cyl-cert-item{min-height:44px!important;min-width:44px!important}
  [style*="padding:4px 10px"],[style*="padding:5px 12px"],[style*="padding:4px 14px"]{min-height:44px!important;display:inline-flex!important;align-items:center!important}

  /* V médiách grid — 1 column on mobile */
  .media-grid{grid-template-columns:1fr;gap:12px}
  .media-tile h3{font-size:15px!important}

  /* Contact form inputs — ensure full width */
  .wpcf7 input,.wpcf7 textarea,.wpcf7 select{max-width:100%!important;box-sizing:border-box!important}

  /* Global text overflow — NO hyphens for Slovak, word-break:normal */
  body,p,span,li,td,th,a,div{overflow-wrap:break-word!important;word-break:normal!important}
  h1,h2,h3,h4,h5,h6,.el-label,.elementor-heading-title{hyphens:none!important;-webkit-hyphens:none!important;overflow-wrap:break-word!important;word-break:normal!important;text-wrap:balance}
  /* Force all Elementor content to respect max-width */
  .elementor-widget-wrap,.elementor-widget,.elementor-element,.e-con,.e-con-inner{max-width:100%!important;box-sizing:border-box!important}
  .elementor-widget-text-editor p,.elementor-widget-text-editor span,.elementor-widget-text-editor li{overflow-wrap:break-word!important;word-break:normal!important;hyphens:none!important}
  /* Inline elements with fixed widths — clamp */
  [style*="min-width"]{min-width:0!important}
  img{max-width:100%!important;height:auto!important}
}

/* === SMALL MOBILE (max 480px) === */
@media(max-width:480px){
  .el-hero-section h1,.elementor-heading-title[style*="font-size:56px"]{font-size:24px!important}
  .elementor-heading-title[style*="font-size:36px"]{font-size:20px!important}
  .ctr{padding:0 12px}

  /* Client grid — still 2 columns */
  [style*="grid-template-columns:repeat(4,1fr)"].cl-grid{grid-template-columns:repeat(2,1fr)!important}

  /* Stats grid — 2 columns on small screens */
  .hp-stats-grid{grid-template-columns:repeat(2,1fr)!important}

  /* Even smaller stats */
  .hp-stat{padding:16px 8px!important}
  .hp-stat .n{font-size:20px!important}

  /* Inline flex items with min-width — full width on small mobile */
  [style*="min-width:280px"]{min-width:0!important;width:100%!important}

  /* Hierarchy — single column */
  [style*="grid-template-columns: repeat(5"],[style*="grid-template-columns:repeat(5"]{grid-template-columns:1fr!important}

  /* Hide secondary decorative elements */
  .geo{opacity:.3!important}

  /* Service grid — 1 column on small mobile */
  .svc-grid{grid-template-columns:1fr!important}

  /* Word overflow — prevent long Slovak words from breaking layout */
  body{overflow-wrap:break-word;word-break:normal}
  h1,h2,h3,.el-label{hyphens:none;-webkit-hyphens:none;text-wrap:balance}
}

/* ═══ V MÉDIÁCH — MEDIA CARDS ═══ */
/* V médiách — kept for backwards compat */
.media-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:32px 28px;margin-bottom:16px;transition:all .25s ease;position:relative;overflow:hidden}
.media-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--p2),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s ease}
.media-card:hover{background:rgba(255,255,255,.06);border-color:rgba(191,93,159,.15);transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.media-card:hover::after{transform:scaleX(1)}
.media-card h2{font-size:20px;font-weight:700;margin-bottom:8px;line-height:1.3}
.media-card h2 a{color:var(--tw);text-decoration:none;transition:color .25s ease}
.media-card h2 a:hover{color:var(--p2)}
.media-card>p{font-size:14px;color:var(--t40);line-height:1.6;margin-bottom:16px}
.media-card-head{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.media-logo{height:24px;width:auto;opacity:.7}
.media-badge{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:100px;white-space:nowrap}
.media-badge-podcast{background:rgba(191,93,159,.15);color:var(--p2)}
.media-badge-rozhovor{background:rgba(59,130,246,.15);color:#60a5fa}
.media-badge-anketa{background:rgba(245,158,11,.12);color:#fbbf24}
.media-badge-konferencia{background:rgba(16,185,129,.12);color:#34d399}
.media-badge-ocenenie{background:rgba(212,168,67,.15);color:var(--gold)}
.media-badge-zmienka{background:rgba(255,255,255,.06);color:var(--t40)}
.media-card-foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--t40)}
.media-person{display:flex;align-items:center;gap:6px}
.media-source{opacity:.6}
.media-cta{display:inline-flex;align-items:center;gap:6px;color:var(--p2);font-weight:600;font-size:14px;text-decoration:none;margin-left:auto;transition:all .25s ease}
.media-cta:hover{color:var(--p3)}
.media-date{font-size:13px;color:var(--t25)}

/* ═══ COOKIEYES BANNER — DARK THEME ═══ */
.cky-consent-container .cky-consent-bar{background:#1a1424!important;border:1px solid rgba(191,93,159,.2)!important;border-radius:16px!important;box-shadow:0 20px 60px rgba(0,0,0,.6)!important}
.cky-consent-container .cky-title{color:#fff!important;font-family:var(--f)!important}
.cky-consent-container .cky-notice-des{color:rgba(255,255,255,.7)!important;font-family:var(--f)!important}
.cky-consent-container .cky-btn-accept{background:#bf5d9f!important;color:#fff!important;border:none!important;border-radius:10px!important;font-family:var(--f)!important;font-weight:600!important}
.cky-consent-container .cky-btn-reject{background:transparent!important;color:#bf5d9f!important;border:1px solid rgba(191,93,159,.4)!important;border-radius:10px!important;font-family:var(--f)!important;font-weight:600!important}
.cky-consent-container .cky-btn-customize{background:transparent!important;color:rgba(255,255,255,.7)!important;border:1px solid rgba(255,255,255,.15)!important;border-radius:10px!important;font-family:var(--f)!important}
.cky-consent-container .cky-preference-center{background:#0e0a12!important;border:1px solid rgba(191,93,159,.15)!important;border-radius:16px!important}
.cky-consent-container .cky-preference-title{color:#fff!important;font-family:var(--f)!important}
.cky-consent-container .cky-preference-content-wrapper{background:#0e0a12!important}
.cky-consent-container .cky-accordion-btn{color:#fff!important;background:rgba(255,255,255,.03)!important;font-family:var(--f)!important}
.cky-consent-container .cky-accordion-body{color:rgba(255,255,255,.6)!important;background:rgba(255,255,255,.02)!important}
.cky-consent-container .cky-audit-table{color:rgba(255,255,255,.5)!important;border-color:rgba(255,255,255,.08)!important}
.cky-consent-container .cky-audit-table td,.cky-consent-container .cky-audit-table th{border-color:rgba(255,255,255,.08)!important;color:rgba(255,255,255,.6)!important}
.cky-consent-container .cky-always-active{color:#bf5d9f!important}
.cky-consent-container .cky-preference-header{border-color:rgba(255,255,255,.08)!important}
.cky-consent-container .cky-footer-shadow{box-shadow:none!important}
.cky-consent-container .cky-prefrence-btn-wrapper .cky-btn{font-family:var(--f)!important}
.cky-revisit-bottom-left .cky-btn-revisit{background:#1a1424!important;border:1px solid rgba(191,93,159,.3)!important}
.cky-revisit-bottom-left{bottom:16px!important;left:16px!important;z-index:99990!important}
