/* ===================================================================
   WEBZARDIO — Main stylesheet
   Dark, electric violet pulled from logo. Type: Inter + JetBrains Mono.
   =================================================================== */

/* ---------- TOKENS ---------- */
:root{
  --bg:#080610;
  --bg-2:#0E0A1A;
  --surface:#11091D;
  --surface-2:#160D26;
  --border:rgba(168,85,247,0.10);
  --border-strong:rgba(168,85,247,0.22);
  --text:#F5F0FF;
  --text-dim:#9088A8;
  --text-mute:#615877;
  --primary:#A855F7;
  --primary-hi:#C084FC;
  --primary-deep:#6D28D9;
  --accent:#7B5EA7;
  --danger:#ef4444;
  --maxw:1280px;
  --pad-y:120px;
  --r-sm:10px;
  --r:16px;
  --r-lg:22px;
  --easing:cubic-bezier(.22,1,.36,1);
  --display:'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
  --body:'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  /* glow system */
  --glow-xs: 0 0 12px rgba(168,85,247,0.25);
  --glow-sm: 0 0 24px rgba(168,85,247,0.35);
  --glow-md: 0 0 48px rgba(168,85,247,0.4);
  --glow-card: 0 8px 40px -12px rgba(168,85,247,0.45), 0 0 0 1px rgba(168,85,247,0.3);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
button{cursor:pointer}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:6px}
::selection{background:rgba(168,85,247,0.35);color:#fff}

/* ---------- SKIP ---------- */
.skip{position:absolute;left:-9999px;top:0;background:var(--primary);color:#0a0014;padding:10px 14px;border-radius:8px;font-weight:600;z-index:9999}
.skip:focus{left:12px;top:12px}

/* ---------- BG TEXTURE ---------- */
.bg-noise{
  position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.4;
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(168,85,247,0.18), transparent 60%),
    radial-gradient(ellipse 60% 50% at 100% 80%, rgba(109,40,217,0.15), transparent 60%),
    radial-gradient(ellipse 40% 30% at 0% 60%, rgba(123,94,167,0.08), transparent 70%);
}
.bg-grid{
  position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.35;
  background-image:
    linear-gradient(rgba(168,85,247,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(168,85,247,0.04) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 20%, #000 30%, transparent 80%);
}

/* ---------- LAYOUT ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}
section{padding:var(--pad-y) 0;position:relative;z-index:1}
@media (max-width:768px){:root{--pad-y:72px}.container{padding:0 20px}}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--primary-hi);
  padding:6px 14px;border:1px solid var(--border-strong);
  border-radius:999px;background:rgba(168,85,247,0.06);
  margin-bottom:24px;
}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--primary);box-shadow:0 0 10px var(--primary);animation:dotPulse 2.4s ease-in-out infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 6px var(--primary)}50%{box-shadow:0 0 16px var(--primary),0 0 24px rgba(168,85,247,0.5)}}

h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:-0.02em;line-height:1.05;margin:0;text-wrap:balance}
h2{font-size:clamp(32px,4.2vw,58px);text-wrap:balance}
h3{font-size:clamp(20px,2.2vw,26px);letter-spacing:-0.015em}
.italic-accent{font-style:italic;color:var(--primary-hi);font-weight:600}
.section-head{max-width:760px;margin-bottom:64px}
.section-head p{color:var(--text-dim);font-size:18px;margin:18px 0 0}

/* ---------- HEADER ---------- */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;transition:all .35s var(--easing);
}
.header.scrolled{
  background:rgba(8,6,16,0.72);backdrop-filter:blur(18px) saturate(1.2);
  -webkit-backdrop-filter:blur(18px) saturate(1.2);
  border-bottom:1px solid var(--border);
  padding:12px 0;
}
.nav{display:flex;align-items:center;gap:32px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand-logo{height:54px;width:auto;display:block;object-fit:contain}
.brand-mark{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-deep) 100%);
  display:grid;place-items:center;
  font-family:var(--display);font-weight:800;color:#fff;font-size:20px;
  box-shadow:0 8px 24px -8px rgba(168,85,247,0.6), inset 0 1px 0 rgba(255,255,255,0.2);
  position:relative;
}
.brand-mark::after{
  content:"";position:absolute;inset:-2px;border-radius:12px;
  background:linear-gradient(135deg,var(--primary-hi),transparent 50%);
  opacity:.4;z-index:-1;filter:blur(6px);
}
.brand-name{font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:-0.02em}
.brand-name span{color:var(--primary)}

.nav-links{display:flex;gap:6px;margin-left:auto;list-style:none;padding:0;margin-block:0}
.nav-links a{
  display:inline-block;padding:10px 16px;font-size:14px;font-weight:500;
  color:var(--text-dim);border-radius:8px;transition:color .25s, background .25s;
  position:relative;
}
.nav-links a::after{
  content:"";position:absolute;bottom:5px;left:16px;right:16px;height:1px;
  background:linear-gradient(90deg,transparent,var(--primary-hi),transparent);
  transform:scaleX(0);transform-origin:center;transition:transform .3s var(--easing);opacity:0.8;
}
.nav-links a:hover{color:var(--text);background:rgba(168,85,247,0.06)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-links a.active{color:var(--primary-hi)}
.nav-links a.active::after{
  content:"";position:absolute;bottom:4px;
  left:0;right:0;width:18px;height:2px;
  margin:0 auto;transform:none;
  background:var(--primary);border-radius:2px;
  box-shadow:0 0 8px var(--primary);
}

/* ---------- BUTTONS ---------- */
.cta-btn{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;font-weight:600;font-size:14px;
  background:linear-gradient(135deg,var(--primary-hi) 0%,var(--primary) 50%,var(--primary-deep) 100%);
  background-size:200% 200%;background-position:0% 0%;
  color:#0a0014;border:none;border-radius:999px;overflow:hidden;
  transition:transform .3s var(--easing), box-shadow .3s, background-position .5s var(--easing);
  box-shadow:0 0 0 1px rgba(255,255,255,0.1) inset, 0 8px 30px -8px rgba(168,85,247,0.7);
  white-space:nowrap;
}
.cta-btn::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.18) 50%,transparent 100%);
  transform:translateX(-100%);transition:transform 0s;
}
.cta-btn:hover{
  box-shadow:0 0 0 1px rgba(255,255,255,0.15) inset, 0 12px 40px -6px rgba(168,85,247,0.85);
  background-position:100% 100%;transform:translateY(-2px);
}
.cta-btn:hover::before{transform:translateX(100%);transition:transform .55s ease}
.cta-btn .arr{transition:transform .3s var(--easing)}
.cta-btn:hover .arr{transform:translateX(5px)}

.btn-outline{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;font-weight:600;font-size:14px;
  background:transparent;color:var(--text);
  border:1px solid var(--border-strong);border-radius:999px;
  transition:all .25s var(--easing);
}
.btn-outline:hover{border-color:var(--primary);background:rgba(168,85,247,0.08);color:var(--primary-hi);box-shadow:var(--glow-xs);transform:translateY(-2px)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;
  color:var(--primary-hi);font-family:var(--mono);letter-spacing:.04em;
}
.btn-ghost .arr{transition:transform .2s}
.btn-ghost:hover .arr{transform:translateX(4px)}

/* hamburger */
.burger{display:none;width:42px;height:42px;border-radius:10px;background:transparent;border:1px solid var(--border-strong);position:relative}
.burger span{position:absolute;left:11px;width:20px;height:1.5px;background:var(--text);transition:all .3s var(--easing)}
.burger span:nth-child(1){top:15px}
.burger span:nth-child(2){top:20px}
.burger span:nth-child(3){top:25px}
.burger.is-open span:nth-child(1){top:20px;transform:rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){top:20px;transform:rotate(-45deg)}

@media (max-width:1024px){
  .nav-links, .header .cta-btn{display:none}
  .burger{display:flex}
  .nav-actions{margin-left:auto;gap:8px}
  .nav{gap:0}
  .header{padding:12px 0}
  .header.scrolled{padding:8px 0;background:rgba(8,6,16,0.88);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4)}
  .brand-logo{height:44px}
}

/* ---------- NAV ACTIONS + MINI-CART ---------- */
.nav-actions{display:flex;align-items:center;gap:14px}

.header-cart{position:relative;display:flex;align-items:center}
.header-cart-btn{
  position:relative;display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:10px;
  background:transparent;border:1px solid var(--border-strong);
  color:var(--text);transition:all .25s var(--easing);
}
.header-cart-btn:hover{
  border-color:var(--primary);background:rgba(168,85,247,0.08);
  color:var(--primary-hi);box-shadow:var(--glow-xs);
}
.header-cart-count{
  position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--primary-hi),var(--primary));
  color:#0a0014;font-size:11px;font-weight:700;font-family:var(--display);
  border-radius:999px;line-height:1;
  box-shadow:0 2px 10px -2px rgba(168,85,247,0.8);
  border:2px solid var(--bg);
}
.header-cart-count[hidden]{display:none}

.header-cart-dropdown{
  position:absolute;top:calc(100% + 14px);right:0;width:340px;max-width:calc(100vw - 32px);
  background:rgba(14,10,26,0.97);backdrop-filter:blur(24px) saturate(1.4);
  -webkit-backdrop-filter:blur(24px) saturate(1.4);
  border:1px solid var(--border-strong);border-radius:var(--r-lg);
  box-shadow:0 24px 60px -12px rgba(0,0,0,0.6),0 0 0 1px rgba(168,85,247,0.08);
  padding:20px;opacity:0;visibility:hidden;transform:translateY(-8px) scale(.98);
  transform-origin:top right;transition:all .28s var(--easing);z-index:200;
}
.header-cart.open .header-cart-dropdown{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.header-cart-dropdown::before{
  content:"";position:absolute;top:-6px;right:16px;width:12px;height:12px;
  background:rgba(14,10,26,0.97);border-left:1px solid var(--border-strong);
  border-top:1px solid var(--border-strong);transform:rotate(45deg);
}

/* ── conținut mini-cart WooCommerce ── */
.header-cart-dropdown .woocommerce-mini-cart__empty-message{
  color:var(--text-dim);font-size:14px;text-align:center;padding:24px 0;margin:0;
}
.header-cart-dropdown ul.cart_list,
.header-cart-dropdown ul.woocommerce-mini-cart{
  list-style:none;margin:0 0 8px;padding:0;max-height:300px;overflow-y:auto;
}
.header-cart-dropdown ul.cart_list li,
.header-cart-dropdown ul.woocommerce-mini-cart li{
  display:flex;align-items:flex-start;gap:12px;position:relative;
  padding:14px 0;border-bottom:1px solid var(--border);
}
.header-cart-dropdown ul.cart_list li a:not(.remove){
  color:var(--text);font-size:13px;font-weight:500;line-height:1.4;
  display:block;padding-right:18px;
}
.header-cart-dropdown ul.cart_list li a:not(.remove):hover{color:var(--primary-hi)}
.header-cart-dropdown ul.cart_list li img{
  width:48px;height:48px;object-fit:cover;border-radius:var(--r-sm);
  border:1px solid var(--border);order:-1;float:none;margin:0;
}
.header-cart-dropdown ul.cart_list li .quantity{
  display:block;color:var(--text-dim);font-size:12px;margin-top:4px;
}
.header-cart-dropdown ul.cart_list li .quantity .amount{color:var(--primary-hi);font-weight:600}
.header-cart-dropdown ul.cart_list li a.remove{
  position:absolute;top:14px;right:0;width:20px;height:20px;
  display:flex;align-items:center;justify-content:center;border-radius:5px;
  font-size:16px;color:var(--text-mute) !important;line-height:1;transition:all .2s;
}
.header-cart-dropdown ul.cart_list li a.remove:hover{
  background:rgba(239,68,68,0.12);color:#ef4444 !important;
}
.header-cart-dropdown .woocommerce-mini-cart__total{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 0;margin:0;font-size:14px;color:var(--text);
  border-top:1px solid var(--border-strong);
}
.header-cart-dropdown .woocommerce-mini-cart__total strong{font-weight:500;color:var(--text-dim)}
.header-cart-dropdown .woocommerce-mini-cart__total .amount{
  color:var(--primary-hi);font-size:18px;font-weight:700;font-family:var(--display);
}
.header-cart-dropdown .woocommerce-mini-cart__buttons{
  display:flex;gap:10px;margin:8px 0 0;padding:0;
}
.header-cart-dropdown .woocommerce-mini-cart__buttons a{
  flex:1;display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:999px;font-size:13px;font-weight:500;
  text-align:center;transition:all .25s var(--easing);
}
.header-cart-dropdown .woocommerce-mini-cart__buttons a:not(.checkout){
  background:transparent;border:1px solid var(--border-strong);color:var(--text);
}
.header-cart-dropdown .woocommerce-mini-cart__buttons a:not(.checkout):hover{
  border-color:var(--primary);background:rgba(168,85,247,0.08);color:var(--primary-hi);
}
.header-cart-dropdown .woocommerce-mini-cart__buttons a.checkout{
  background:linear-gradient(135deg,var(--primary-hi),var(--primary),var(--primary-deep));
  color:#0a0014;font-weight:600;border:none;
  box-shadow:0 4px 20px -4px rgba(168,85,247,0.6);
}
.header-cart-dropdown .woocommerce-mini-cart__buttons a.checkout:hover{
  transform:translateY(-1px);box-shadow:0 6px 28px -4px rgba(168,85,247,0.8);
}
@media (max-width:480px){
  .header-cart-dropdown{position:fixed;top:auto;right:16px;left:16px;width:auto}
  .header-cart-dropdown::before{display:none}
}

.mobile-drawer{
  position:fixed;inset:0;background:rgba(8,6,16,0.96);backdrop-filter:blur(20px);
  z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:18px;opacity:0;pointer-events:none;transition:opacity .3s var(--easing);
}
.mobile-drawer.is-open{opacity:1;pointer-events:auto}
.mobile-drawer a{font-family:var(--display);font-size:28px;font-weight:600;color:var(--text);padding:8px 0}
.mobile-drawer a:hover, .mobile-drawer a.active{color:var(--primary-hi)}
.mobile-drawer .cta-btn{margin-top:14px;font-size:14px}

/* ---------- PAGE HERO (sub-pages) ---------- */
.page-hero{
  position:relative;padding:200px 0 80px;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 40% at 50% 0%, rgba(168,85,247,0.18), transparent 70%);
  pointer-events:none;
}
.page-hero h1{
  font-size:clamp(48px,7vw,96px);line-height:1.05;letter-spacing:-0.03em;
  font-family:var(--display);font-weight:700;text-wrap:balance;
  padding-bottom:0.04em;
}
.page-hero .lead{
  color:var(--text-dim);font-size:clamp(17px,1.5vw,20px);max-width:640px;
  margin:28px 0 0;line-height:1.55;
}
.crumbs{
  display:flex;align-items:center;gap:10px;margin-bottom:28px;
  font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-mute);
}
.crumbs a{color:var(--text-dim)}
.crumbs a:hover{color:var(--primary-hi)}
.crumbs span.sep{color:var(--text-mute)}
.crumbs span.cur{color:var(--primary-hi)}

/* ---------- STATS ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.stats-grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:768px){.stats-grid,.stats-grid.cols-4{grid-template-columns:1fr 1fr}}
.stat{
  position:relative;padding:32px 28px;border:1px solid var(--border);border-radius:var(--r-lg);
  background:linear-gradient(180deg,rgba(168,85,247,0.04),transparent 80%), var(--surface);
  transition:transform .4s var(--easing), border-color .3s;
}
.stat:hover{border-color:rgba(168,85,247,0.45);transform:translateY(-5px);box-shadow:var(--glow-card)}
.stat::before{
  content:"";position:absolute;top:0;left:0;width:32px;height:32px;
  border-top:1px solid var(--primary);border-left:1px solid var(--primary);
  border-top-left-radius:var(--r-lg);
}
.stat-icon{width:34px;height:34px;color:var(--primary-hi);margin-bottom:18px;opacity:.8}
.stat-num{
  font-family:var(--display);font-size:clamp(40px,5vw,56px);font-weight:700;
  letter-spacing:-0.03em;line-height:1;color:var(--text);
  display:flex;align-items:baseline;gap:4px;
  text-shadow:0 0 40px rgba(168,85,247,0.2);
}
.stat-num small{font-size:.5em;color:var(--primary);font-weight:600}
.stat-label{margin-top:10px;font-size:14px;color:var(--text-dim)}

/* ---------- PILLARS ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:768px){.pillars{grid-template-columns:1fr}}
.pillar{
  padding:24px;border:1px solid var(--border);border-radius:var(--r);
  background:var(--surface);display:flex;gap:14px;align-items:flex-start;
}
.pillar .ic{
  width:38px;height:38px;flex-shrink:0;display:grid;place-items:center;
  background:rgba(168,85,247,0.1);border-radius:10px;color:var(--primary-hi);
}
.pillar h4{font-family:var(--display);font-size:16px;font-weight:600;margin:0 0 4px}
.pillar p{margin:0;font-size:13px;color:var(--text-dim);line-height:1.55}

/* ---------- SERVICES ---------- */
.tabs{display:flex;gap:8px;margin-bottom:32px;flex-wrap:wrap;padding:6px;border:1px solid var(--border);border-radius:999px;width:fit-content;background:var(--surface)}
.tab{
  padding:11px 22px;font-size:14px;font-weight:500;color:var(--text-dim);
  background:transparent;border:none;border-radius:999px;
  transition:all .25s var(--easing);
  display:inline-flex;align-items:center;gap:8px;
}
.tab .c{font-family:var(--mono);font-size:10px;color:var(--text-mute);opacity:.7}
.tab.active{background:var(--primary);color:#0a0014;font-weight:600}
.tab.active .c{color:rgba(10,0,20,0.6);opacity:1}
.tab:not(.active):hover{color:var(--text)}

.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:1024px){.service-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.service-grid{grid-template-columns:1fr}}

.service{
  position:relative;padding:28px;border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);overflow:hidden;transition:all .35s var(--easing);
  will-change:transform;transform-style:preserve-3d;
}
.service::after{
  content:"";position:absolute;inset:0;border-radius:var(--r-lg);
  background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%),rgba(168,85,247,0.12),transparent 40%);
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.service:hover::after{opacity:1}
.service:hover{border-color:rgba(168,85,247,0.4);transform:translateY(-5px);box-shadow:var(--glow-card)}
.service-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.service-ic{
  width:48px;height:48px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(180deg,rgba(168,85,247,0.12),rgba(168,85,247,0.04));
  border:1px solid var(--border);color:var(--primary-hi);
}
.service-num{font-family:var(--mono);font-size:11px;color:var(--text-mute);letter-spacing:.1em}
.service h3{font-family:var(--display);font-size:20px;font-weight:600;margin-bottom:10px;text-wrap:balance}
.service p{font-size:14px;color:var(--text-dim);line-height:1.6;margin:0}
.service-tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:6px}
.service-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  padding:4px 10px;border-radius:999px;
  background:rgba(168,85,247,0.08);color:var(--primary-hi);
  border:1px solid var(--border);
}

.cat-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:32px;
  padding-bottom:20px;margin:64px 0 32px;border-bottom:1px solid var(--border);
  flex-wrap:wrap;
}
.cat-head h3{font-size:clamp(28px,3.4vw,40px);font-family:var(--display);font-weight:700;letter-spacing:-0.02em}
.cat-head .num{font-family:var(--mono);font-size:12px;color:var(--text-mute);letter-spacing:.18em;text-transform:uppercase}
.cat-head p{color:var(--text-dim);max-width:420px;font-size:15px;margin:0}

/* ---------- PROJECTS ---------- */
.proj-filter{display:flex;gap:8px;margin-bottom:36px;flex-wrap:wrap}
.filter-btn{
  padding:10px 18px;font-size:13px;font-weight:500;color:var(--text-dim);
  background:transparent;border:1px solid var(--border);border-radius:999px;
  transition:all .25s var(--easing);display:inline-flex;align-items:center;gap:8px;
}
.filter-btn:hover{color:var(--text);border-color:var(--border-strong)}
.filter-btn.active{background:var(--primary);color:#0a0014;border-color:var(--primary);font-weight:600}
.filter-btn .ct{font-family:var(--mono);font-size:10px;opacity:.7}

.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:1024px){.proj-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.proj-grid{grid-template-columns:1fr}}

.proj{
  position:relative;border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);overflow:hidden;transition:all .5s var(--easing);
}
.proj.hidden{display:none}
.proj:hover{border-color:rgba(168,85,247,0.4);transform:translateY(-5px);box-shadow:var(--glow-card)}
.proj-thumb{aspect-ratio:16/9;position:relative;overflow:hidden;background:var(--bg-2)}
.proj-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s var(--easing)}
.proj:hover .proj-thumb img{transform:scale(1.06)}
.proj-thumb .art{position:absolute;inset:0;transition:transform .8s var(--easing)}
.proj:hover .proj-thumb .art{transform:scale(1.08)}
.proj-thumb::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%, rgba(8,6,16,0.85) 100%);
}
.proj-badge{
  position:absolute;top:14px;left:14px;z-index:3;
  font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 14px;border-radius:999px;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hi) 100%);
  color:#fff;
  box-shadow:0 4px 18px rgba(168,85,247,0.55), 0 1px 0 rgba(255,255,255,0.15) inset;
  border:none;
}
.proj-tag-art{
  position:absolute;top:14px;right:14px;z-index:3;
  font-family:var(--mono);font-size:42px;font-weight:700;color:rgba(255,255,255,0.06);
  letter-spacing:-0.04em;
}
.proj-info{padding:22px 24px 24px}
.proj-info h3{font-family:var(--display);font-size:19px;font-weight:600;margin-bottom:6px}
.proj-info p{font-size:13px;color:var(--text-dim);margin:0 0 14px;line-height:1.55}
.proj-link{
  display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;
  color:var(--primary-hi);font-family:var(--mono);letter-spacing:.04em;
}
.proj-link .arr{transition:transform .2s var(--easing)}
.proj:hover .proj-link .arr{transform:translateX(4px)}

/* project art variations */
.art-grid{background:radial-gradient(circle at 30% 40%, rgba(168,85,247,0.35), transparent 50%),linear-gradient(135deg,#11091D 0%, #1a0a2e 100%)}
.art-grid::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(168,85,247,0.15) 1px,transparent 1px),linear-gradient(90deg,rgba(168,85,247,0.15) 1px,transparent 1px);background-size:24px 24px}
.art-mesh{background:radial-gradient(circle at 70% 30%, rgba(192,132,252,0.5), transparent 45%),radial-gradient(circle at 20% 80%, rgba(109,40,217,0.5), transparent 50%),linear-gradient(135deg,#0E0A1A 0%, #11091D 100%)}
.art-lines{background:linear-gradient(135deg,#0E0A1A,#160D26);position:relative}
.art-lines::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg, rgba(168,85,247,0.18) 0 1px, transparent 1px 14px)}
.art-dots{background:radial-gradient(circle at 50% 50%, rgba(168,85,247,0.25), transparent 55%),#0E0A1A}
.art-dots::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle, rgba(192,132,252,0.4) 1.5px, transparent 1.5px);background-size:18px 18px;mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%)}
.art-wave{background:linear-gradient(135deg,#11091D,#1a0a2e);position:relative}
.art-wave::before{content:"";position:absolute;inset:0;background-image:radial-gradient(ellipse 100% 50% at 50% 100%, rgba(168,85,247,0.3), transparent 60%),radial-gradient(ellipse 80% 40% at 50% 80%, rgba(192,132,252,0.2), transparent 60%)}
.art-circuit{background:#0E0A1A;position:relative}
.art-circuit::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(168,85,247,0.12) 2px, transparent 2px),linear-gradient(90deg, rgba(168,85,247,0.12) 2px, transparent 2px),radial-gradient(circle, rgba(192,132,252,0.5) 3px, transparent 3px);background-size:48px 48px, 48px 48px, 48px 48px}
.art-orbit{background:radial-gradient(circle at center, rgba(168,85,247,0.2), transparent 70%),#0E0A1A;position:relative}
.art-orbit::before{content:"";position:absolute;inset:18%;border:1px solid rgba(168,85,247,0.25);border-radius:50%}
.art-orbit::after{content:"";position:absolute;inset:32%;border:1px solid rgba(192,132,252,0.4);border-radius:50%}
.art-blocks{background:linear-gradient(135deg,#0E0A1A,#160D26);position:relative;overflow:hidden}
.art-blocks::before{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg, rgba(168,85,247,0.18) 50%, transparent 50%);background-size:32px 100%;mask-image:linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent)}
.art-diag{background:linear-gradient(45deg, rgba(168,85,247,0.18) 0 25%, transparent 0 50%, rgba(109,40,217,0.18) 0 75%, transparent 0);background-size:60px 60px;background-color:#0E0A1A}
.art-glow{background:radial-gradient(circle at 50% 60%, rgba(192,132,252,0.55), transparent 50%),radial-gradient(circle at 30% 30%, rgba(168,85,247,0.3), transparent 50%),#0E0A1A}
.art-spec{background:linear-gradient(135deg, rgba(168,85,247,0.4), rgba(109,40,217,0.2) 50%, transparent),#0E0A1A;position:relative}
.art-spec::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg, transparent 0 2px, rgba(192,132,252,0.08) 2px 3px)}

/* ---------- BLOG ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:1024px){.blog-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.blog-grid{grid-template-columns:1fr}}
.post{
  position:relative;border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);padding:32px 28px 28px;
  transition:all .3s var(--easing);display:flex;flex-direction:column;
}
.post:hover{border-color:rgba(168,85,247,0.4);transform:translateY(-5px);box-shadow:var(--glow-card)}
.post::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--primary-hi));
}
.post-meta{display:flex;gap:14px;align-items:center;margin-bottom:18px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--text-mute);text-transform:uppercase}
.post-cat{color:var(--primary-hi);padding:4px 10px;border:1px solid var(--border-strong);border-radius:999px;background:rgba(168,85,247,0.06)}
.post h3{font-family:var(--display);font-size:21px;line-height:1.2;font-weight:600;margin-bottom:14px;text-wrap:balance}
.post p{font-size:14px;color:var(--text-dim);margin:0 0 22px;line-height:1.6;flex-grow:1}
.post-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--primary-hi);font-weight:500;align-self:flex-start}

/* ---------- CONTACT FORM ---------- */
.form{display:grid;gap:20px}
.field{position:relative}
.field input, .field textarea, .field select{
  width:100%;padding:22px 18px 10px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  color:var(--text);font-size:15px;font-family:var(--body);
  transition:border-color .25s, background .25s;
  resize:vertical;
}
.field textarea{min-height:120px}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none;border-color:var(--primary);background:rgba(168,85,247,0.05);
  box-shadow:0 0 0 4px rgba(168,85,247,0.12), 0 0 20px rgba(168,85,247,0.1);
}
.field label{
  position:absolute;top:18px;left:18px;
  font-size:14px;color:var(--text-dim);pointer-events:none;
  transition:all .2s var(--easing);font-family:var(--body);
  background:transparent;padding:0;
}
.field input:focus + label,
.field input:not(:placeholder-shown) + label,
.field textarea:focus + label,
.field textarea:not(:placeholder-shown) + label,
.field.has-val label{
  top:7px;font-size:11px;color:var(--primary-hi);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;
}
.field.error input, .field.error textarea, .field.error select{border-color:var(--danger)}
.field-err{font-size:12px;color:var(--danger);margin-top:6px;display:none;font-family:var(--mono)}
.field.error .field-err{display:block}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239088a8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center;background-size:12px;padding-right:42px}
.field select option{background:var(--surface);color:var(--text)}

.row-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:640px){.row-2{grid-template-columns:1fr}}

.send-btn{
  margin-top:6px;padding:16px 28px;font-size:15px;font-weight:600;
  background:var(--primary);color:#0a0014;border:none;border-radius:var(--r);
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:all .25s var(--easing);
  box-shadow:0 8px 24px -8px rgba(168,85,247,0.55);
}
.send-btn:hover{box-shadow:0 12px 32px -6px rgba(168,85,247,0.7)}
.send-btn:disabled{opacity:.7;cursor:not-allowed}
.send-btn .spinner{
  width:16px;height:16px;border:2px solid rgba(10,0,20,0.2);
  border-top-color:#0a0014;border-radius:50%;display:none;animation:spin .8s linear infinite;
}
.send-btn.loading .spinner{display:inline-block}
.send-btn.loading .label{opacity:.6}
@keyframes spin{to{transform:rotate(360deg)}}
.form-success{
  padding:18px;border-radius:var(--r);background:rgba(168,85,247,0.08);
  border:1px solid var(--border-strong);color:var(--primary-hi);
  display:none;font-size:14px;
}
.form-success.show{display:block}

.contact-info{
  position:relative;padding:36px;border:1px solid var(--border);border-radius:var(--r-lg);
  background:linear-gradient(180deg,rgba(168,85,247,0.05),transparent 60%),var(--surface);
  overflow:hidden;
}
.contact-info::before{content:"";position:absolute;top:-100px;right:-100px;width:280px;height:280px;border-radius:50%;border:1px solid var(--border-strong)}
.contact-info::after{content:"";position:absolute;top:-150px;right:-150px;width:380px;height:380px;border-radius:50%;border:1px solid var(--border);animation:spinSlow 30s linear infinite}
@keyframes spinSlow{to{transform:rotate(360deg)}}
.contact-row{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--border)}
.contact-row:last-child{border-bottom:none}
.contact-row .ic{flex-shrink:0;width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:rgba(168,85,247,0.1);color:var(--primary-hi);border:1px solid var(--border)}
.contact-row .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--text-mute);text-transform:uppercase;margin-bottom:4px}
.contact-row .val{font-size:15px;color:var(--text);font-weight:500}
.contact-row a:hover{color:var(--primary-hi)}

/* ---------- TIMELINE ---------- */
.timeline{position:relative;display:grid;gap:0;padding-left:38px}
.timeline::before{
  content:"";position:absolute;left:14px;top:8px;bottom:8px;width:1px;
  background:linear-gradient(180deg,var(--primary),transparent 95%);
}
.tl-item{position:relative;padding:0 0 40px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{
  content:"";position:absolute;left:-32px;top:6px;width:13px;height:13px;border-radius:50%;
  background:var(--bg);border:2px solid var(--primary);
  box-shadow:0 0 0 4px rgba(168,85,247,0.12);
}
.tl-year{font-family:var(--mono);font-size:12px;color:var(--primary-hi);letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px;display:inline-block}
.tl-item h4{font-family:var(--display);font-size:22px;font-weight:600;margin-bottom:8px}
.tl-item p{color:var(--text-dim);margin:0;font-size:15px;line-height:1.65;max-width:540px}

/* ---------- ACCORDION ---------- */
.acc{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);overflow:hidden;margin-bottom:10px;transition:border-color .25s}
.acc[open]{border-color:var(--border-strong)}
.acc summary{
  list-style:none;cursor:pointer;padding:22px 28px;display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:var(--display);font-size:17px;font-weight:600;color:var(--text);
}
.acc summary::-webkit-details-marker{display:none}
.acc summary .plus{
  flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1px solid var(--border-strong);
  display:grid;place-items:center;color:var(--primary-hi);transition:transform .3s var(--easing), background .25s;
}
.acc[open] summary .plus{transform:rotate(45deg);background:var(--primary);color:#0a0014;border-color:var(--primary)}
.acc-body{padding:0 28px 22px;color:var(--text-dim);font-size:15px;line-height:1.7;max-width:780px}

/* ---------- TECH BADGES ---------- */
.stack-grid{display:flex;flex-wrap:wrap;gap:10px}
.stack-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border:1px solid var(--border);border-radius:999px;
  background:var(--surface);font-family:var(--mono);font-size:12px;letter-spacing:.04em;
  color:var(--text-dim);transition:all .25s;
}
.stack-badge:hover{border-color:var(--border-strong);color:var(--primary-hi);background:rgba(168,85,247,0.06)}
.stack-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--primary);box-shadow:0 0 6px var(--primary)}

/* ---------- PROCESS STEPS ---------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step}
@media (max-width:1024px){.process{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.process{grid-template-columns:1fr}}
.step{
  position:relative;padding:32px 26px;border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);counter-increment:step;
}
.step::before{
  content:counter(step, decimal-leading-zero);
  position:absolute;top:22px;right:22px;
  font-family:var(--mono);font-size:12px;color:var(--text-mute);letter-spacing:.1em;
}
.step .ic{
  width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(180deg,rgba(168,85,247,0.12),rgba(168,85,247,0.04));
  border:1px solid var(--border);color:var(--primary-hi);margin-bottom:20px;
}
.step h4{font-family:var(--display);font-size:18px;font-weight:600;margin-bottom:10px}
.step p{margin:0;font-size:14px;color:var(--text-dim);line-height:1.6}

/* ---------- TESTIMONIALS ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:1024px){.testi-grid{grid-template-columns:1fr}}
.testi{
  padding:32px 28px;border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);position:relative;display:flex;flex-direction:column;gap:22px;
}
.testi::before{
  content:"\201C";position:absolute;top:14px;right:24px;
  font-family:var(--display);font-size:80px;line-height:1;color:rgba(168,85,247,0.15);
}
.testi p{margin:0;font-size:16px;line-height:1.65;color:var(--text);font-style:italic;text-wrap:pretty}
.testi-author{display:flex;align-items:center;gap:14px;margin-top:auto}
.testi-avatar{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--primary),var(--primary-deep));
  display:grid;place-items:center;font-family:var(--display);font-weight:700;color:#fff;
}
.testi-name{font-weight:600;font-size:14px}
.testi-role{font-size:12px;color:var(--text-dim);font-family:var(--mono);letter-spacing:.04em}

/* ---------- CTA BANNER ---------- */
.cta-banner{
  position:relative;padding:80px 60px;border-radius:var(--r-lg);
  background:linear-gradient(135deg, rgba(168,85,247,0.18), rgba(109,40,217,0.08) 60%, transparent),var(--surface);
  border:1px solid var(--border-strong);overflow:hidden;
  display:flex;justify-content:space-between;align-items:center;gap:48px;flex-wrap:wrap;
}
.cta-banner::before{
  content:"";position:absolute;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(168,85,247,0.3),transparent 60%);
  right:-100px;top:-100px;filter:blur(20px);
}
.cta-banner h2{font-size:clamp(32px,4vw,52px);max-width:620px;text-wrap:balance}
.cta-banner p{color:var(--text-dim);font-size:17px;margin:14px 0 0;max-width:580px}
.cta-banner-actions{display:flex;gap:12px;flex-wrap:wrap;position:relative;z-index:2}
@media (max-width:768px){.cta-banner{padding:48px 28px}}

/* ---------- FOOTER ---------- */
.footer{
  position:relative;padding:80px 0 32px;border-top:1px solid var(--border);
  background:linear-gradient(180deg,transparent,rgba(168,85,247,0.04));
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:56px}
@media (max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:640px){.footer-grid{grid-template-columns:1fr}}
.footer-col h4{font-family:var(--display);font-size:14px;font-weight:600;color:var(--text);margin:0 0 18px;letter-spacing:.02em}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.footer-col a{font-size:14px;color:var(--text-dim);transition:color .2s}
.footer-col a:hover{color:var(--primary-hi)}
.footer-brand p{margin:14px 0 24px;color:var(--text-dim);font-size:14px;max-width:300px;line-height:1.6}
.socials{display:flex;gap:10px;margin-top:8px}
.socials a{
  width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--border);color:var(--text-dim);
  transition:all .25s var(--easing);
}
.socials a:hover{color:var(--primary-hi);border-color:var(--border-strong);background:rgba(168,85,247,0.06)}
.socials svg{width:16px;height:16px}
.footer-bottom{
  padding-top:28px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  font-size:13px;color:var(--text-mute);
}
.footer-bottom a{color:var(--text-dim)}
.footer-bottom a:hover{color:var(--primary-hi)}
.footer-bottom .legal{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.footer-bottom .legal .wzd-cc-link-btn{font-size:13px;color:var(--text-dim);text-decoration:none;transition:color .2s;padding:0;font-family:inherit}
.footer-bottom .legal .wzd-cc-link-btn:hover{color:var(--primary-hi);text-decoration:none}
.footer-bottom .craft{font-family:var(--mono);font-size:12px;letter-spacing:.04em}

/* ---------- ANIMATIONS ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--easing), transform .9s var(--easing)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .8s var(--easing), transform .8s var(--easing)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.26s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.33s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.4s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.47s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.54s}
.reveal-stagger.in > *:nth-child(9){transition-delay:.61s}

.fade-up-1{animation:fadeUp 1s var(--easing) .1s both}
.fade-up-2{animation:fadeUp 1s var(--easing) .25s both}
.fade-up-3{animation:fadeUp 1s var(--easing) .4s both}
.fade-up-4{animation:fadeUp 1s var(--easing) .55s both}
.fade-up-5{animation:fadeUp 1s var(--easing) .7s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal,.reveal-stagger > *,
  .fade-up-1,.fade-up-2,.fade-up-3,.fade-up-4,.fade-up-5{opacity:1;transform:none}
}

.diag{position:relative}
.diag::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--border-strong),transparent);
}

.two-col{display:grid;grid-template-columns:1.05fr 1fr;gap:80px;align-items:start}
.two-col.flip{grid-template-columns:1fr 1.05fr}
@media (max-width:1024px){.two-col,.two-col.flip{grid-template-columns:1fr;gap:48px}}

/* ===================================================================
   HOME PAGE
   =================================================================== */
.hero{min-height:100vh;display:flex;align-items:center;padding-top:140px;padding-bottom:80px;position:relative;overflow:visible}
.hero-canvas{position:absolute;inset:0;z-index:0;opacity:.7}
.hero-orb{position:absolute;width:540px;height:540px;border-radius:50%;background:radial-gradient(circle,rgba(168,85,247,0.28) 0%,transparent 60%);filter:blur(40px);top:8%;right:-12%;z-index:0;pointer-events:none;animation:floatA 14s ease-in-out infinite}
.hero-orb-2{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(109,40,217,0.25) 0%,transparent 60%);filter:blur(40px);bottom:5%;left:-8%;z-index:0;pointer-events:none;animation:floatB 18s ease-in-out infinite}
@keyframes floatA{0%,100%{transform:translate(0,0)}50%{transform:translate(-40px,30px)}}
@keyframes floatB{0%,100%{transform:translate(0,0)}50%{transform:translate(50px,-40px)}}
.hero-inner{position:relative;z-index:2;max-width:1080px}
.hero-meta{display:inline-flex;align-items:center;gap:14px;margin-bottom:32px;padding:8px 14px 8px 8px;border:1px solid var(--border-strong);border-radius:999px;background:rgba(255,255,255,0.02);font-family:var(--mono);font-size:12px;color:var(--text-dim);letter-spacing:.05em}
.hero-meta b{background:var(--primary);color:#0a0014;padding:4px 10px;border-radius:999px;font-family:var(--body);font-size:11px;font-weight:600;letter-spacing:.04em}
.hero h1{font-family:var(--display);font-weight:700;letter-spacing:-0.03em;font-size:clamp(48px,8.5vw,124px);line-height:1;text-wrap:balance;padding-bottom:0.04em}
.hero h1 .em{background:linear-gradient(110deg,var(--primary-hi) 10%,var(--primary) 40%,#fff 60%, var(--primary-hi) 90%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic;font-weight:600;animation:shimmer 8s linear infinite}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}
.hero p.lead{color:var(--text-dim);font-size:clamp(17px,1.6vw,21px);max-width:620px;margin:32px 0 44px;line-height:1.55}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.scroll-ind{position:absolute;left:50%;bottom:32px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--text-mute);font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.scroll-ind .mouse{width:24px;height:38px;border:1.5px solid var(--text-mute);border-radius:14px;position:relative}
.scroll-ind .mouse::after{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);width:3px;height:7px;background:var(--primary);border-radius:2px;animation:wheel 1.8s ease-in-out infinite}
@keyframes wheel{0%{opacity:0;transform:translate(-50%,0)}50%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}
.tech-strip{margin-top:80px;padding:20px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;gap:48px;flex-wrap:wrap;align-items:center;font-family:var(--mono);font-size:12px;color:var(--text-mute);letter-spacing:.12em}
.tech-strip span{display:inline-flex;align-items:center;gap:8px}
.tech-strip span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--primary);box-shadow:0 0 6px var(--primary)}

.cat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:1024px){.cat-cards{grid-template-columns:1fr}}
.cat-card{
  position:relative;padding:40px 36px;border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);display:flex;flex-direction:column;gap:20px;
  transition:all .35s var(--easing);min-height:360px;
}
.cat-card:hover{border-color:rgba(168,85,247,0.4);transform:translateY(-5px);box-shadow:var(--glow-card)}
.cat-card::before{
  content:"";position:absolute;inset:auto auto -60px -60px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(168,85,247,0.2),transparent 60%);
  filter:blur(20px);opacity:0;transition:opacity .4s;
}
.cat-card:hover::before{opacity:1}
.cat-card .num{font-family:var(--mono);font-size:11px;color:var(--text-mute);letter-spacing:.16em}
.cat-card .ic{
  width:56px;height:56px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(180deg,rgba(168,85,247,0.18),rgba(168,85,247,0.04));
  border:1px solid var(--border-strong);color:var(--primary-hi);
}
.cat-card h3{font-family:var(--display);font-size:clamp(24px,2.6vw,30px);font-weight:700;line-height:1.1}
.cat-card .blurb{color:var(--text-dim);font-size:15px;line-height:1.6;flex-grow:1;margin:0}
.cat-card .items{margin:0;padding-left:18px;color:var(--text-dim);font-size:13px;line-height:1.7}
.cat-card .items li::marker{color:var(--primary)}
.cat-card .more{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--primary-hi);display:inline-flex;align-items:center;gap:8px;margin-top:6px}
.cat-card .more .arr{transition:transform .25s}
.cat-card:hover .more .arr{transform:translateX(4px)}

/* ===================================================================
   DESPRE PAGE
   =================================================================== */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:768px){.mv-grid{grid-template-columns:1fr}}
.mv-card{
  position:relative;padding:40px 36px;border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);min-height:240px;
}
.mv-card .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--primary-hi);text-transform:uppercase}
.mv-card h3{font-family:var(--display);font-size:clamp(24px,2.6vw,32px);font-weight:700;margin:18px 0;text-wrap:balance}
.mv-card p{color:var(--text-dim);font-size:16px;line-height:1.65;margin:0}
.mv-card.deco::before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;border:1px solid var(--border-strong);right:-150px;bottom:-150px;opacity:.5}
.mv-card.deco::after{content:"";position:absolute;width:200px;height:200px;border-radius:50%;border:1px solid var(--border);right:-100px;bottom:-100px;opacity:.5;animation:spinSlow 30s linear infinite}

.story-art{
  position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(135deg,#160D26,#0E0A1A);border:1px solid var(--border-strong);
}
.story-art::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 30%, rgba(168,85,247,0.45), transparent 40%),
    radial-gradient(circle at 75% 75%, rgba(109,40,217,0.45), transparent 40%);
}
.story-art .ring{position:absolute;border-radius:50%;border:1px solid rgba(168,85,247,0.3)}
.story-art .ring.r1{inset:8%}
.story-art .ring.r2{inset:18%}
.story-art .ring.r3{inset:28%}
.story-art .ring.r4{inset:38%;border-color:rgba(192,132,252,0.5);box-shadow:0 0 30px rgba(168,85,247,0.4) inset}
.story-art .core{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:80px;height:80px;border-radius:18px;
  background:linear-gradient(135deg,var(--primary),var(--primary-deep));
  display:grid;place-items:center;
  font-family:var(--display);font-weight:800;font-size:36px;color:#fff;
  box-shadow:0 20px 60px -10px rgba(168,85,247,0.7);
}
.story-art .badge{
  position:absolute;padding:6px 12px;border-radius:999px;
  background:rgba(8,6,16,0.7);backdrop-filter:blur(8px);border:1px solid var(--border-strong);
  font-family:var(--mono);font-size:10px;color:var(--primary-hi);letter-spacing:.1em;text-transform:uppercase;
}
.story-art .badge.b1{top:12%;left:12%}
.story-art .badge.b2{top:18%;right:10%}
.story-art .badge.b3{bottom:18%;left:14%}
.story-art .badge.b4{bottom:14%;right:12%}
.story-art .dot{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--primary-hi);box-shadow:0 0 10px var(--primary)}
.story-art .dot.d1{top:30%;left:25%}
.story-art .dot.d2{top:40%;right:20%}
.story-art .dot.d3{bottom:32%;left:22%}
.story-art .dot.d4{bottom:24%;right:28%}
.section-tag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--text-mute);text-transform:uppercase;margin-bottom:16px;display:block}
.lead-big{font-size:clamp(20px,2vw,26px);line-height:1.45;color:var(--text);text-wrap:pretty;font-weight:500}
@keyframes skill-grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.skill-bar-wrap{height:5px;border-radius:999px;background:rgba(168,85,247,0.12);overflow:hidden}
.skill-bar{height:100%;border-radius:999px;transform-origin:left;transform:scaleX(0);animation:skill-grow .9s cubic-bezier(.4,0,.2,1) forwards}

/* ===================================================================
   SERVICII PAGE
   =================================================================== */
.cat-nav{display:flex;gap:8px;flex-wrap:wrap;margin-top:36px}
.cat-nav a{
  display:inline-flex;align-items:center;gap:10px;padding:10px 18px;
  border:1px solid var(--border);border-radius:999px;background:var(--surface);
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--text-dim);
  transition:all .25s var(--easing);
}
.cat-nav a:hover{border-color:var(--primary);color:var(--primary-hi);background:rgba(168,85,247,0.06)}
.cat-nav a .n{font-weight:700;color:var(--primary-hi)}

.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:1024px){.approach-grid{grid-template-columns:1fr}}
.approach{
  position:relative;padding:32px 28px;border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);overflow:hidden;
}
.approach.feat{border-color:var(--primary-deep);background:linear-gradient(180deg,rgba(168,85,247,0.1),transparent 80%),var(--surface)}
.approach.feat::before{
  content:"Recomandat";position:absolute;top:18px;right:18px;
  padding:4px 10px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  background:var(--primary);color:#0a0014;border-radius:999px;font-weight:600;
}
.approach .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--text-mute);text-transform:uppercase}
.approach h3{font-family:var(--display);font-size:22px;font-weight:700;margin:14px 0}
.approach .price-note{font-family:var(--mono);font-size:13px;color:var(--primary-hi);margin-bottom:20px;letter-spacing:.04em}
.approach ul{list-style:none;padding:0;margin:0 0 24px;display:grid;gap:10px}
.approach ul li{font-size:14px;color:var(--text-dim);padding-left:24px;position:relative}
.approach ul li::before{
  content:"";position:absolute;left:0;top:8px;width:14px;height:6px;
  border-left:2px solid var(--primary);border-bottom:2px solid var(--primary);transform:rotate(-45deg);
}
.approach .foot{font-size:13px;color:var(--text-mute);padding-top:18px;border-top:1px solid var(--border)}
:target{scroll-margin-top:100px}

/* ===================================================================
   PROIECTE PAGE
   =================================================================== */
.featured{
  display:grid;grid-template-columns:1.2fr 1fr;gap:0;
  border:1px solid var(--border-strong);border-radius:var(--r-lg);
  background:var(--surface);overflow:hidden;margin-bottom:64px;position:relative;
}
@media (max-width:1024px){.featured{grid-template-columns:1fr}.featured .art{aspect-ratio:16/9}}
.featured .art{position:relative;overflow:hidden}
.featured .art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.featured .body{padding:56px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.featured .body .meta{display:flex;gap:14px;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--text-mute);text-transform:uppercase}
.featured .body .meta b{color:var(--primary-hi);font-weight:500;padding:4px 10px;border:1px solid var(--border-strong);border-radius:999px;background:rgba(168,85,247,0.06)}
.featured .body h2{font-size:clamp(28px,3.2vw,44px);text-wrap:balance}
.featured .body p{color:var(--text-dim);font-size:16px;line-height:1.65;margin:0}
.featured .body .metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px;padding-top:24px;border-top:1px solid var(--border)}
.featured .body .metrics .m-num{font-family:var(--display);font-size:28px;font-weight:700;color:var(--text);line-height:1}
.featured .body .metrics .m-lbl{font-family:var(--mono);font-size:10px;color:var(--text-mute);letter-spacing:.1em;text-transform:uppercase;margin-top:6px}
.featured .body .stack-grid{margin-top:8px}
@media (max-width:768px){.featured .body{padding:36px 28px}.featured .body .metrics{grid-template-columns:1fr 1fr}}

.industries{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;align-items:center;padding:28px 0}
.industry{
  display:inline-flex;align-items:center;gap:10px;padding:10px 18px;
  border:1px solid var(--border);border-radius:999px;background:var(--surface);
}
.industry .ic{width:18px;height:18px;color:var(--primary-hi)}
.industry span{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--text-dim)}

/* ===================================================================
   CONTACT PAGE
   =================================================================== */
.contact-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:36px}
@media (max-width:1024px){.contact-cards{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.contact-cards{grid-template-columns:1fr}}
.cc{
  padding:24px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);
  display:flex;flex-direction:column;gap:14px;transition:all .25s;
}
.cc:hover{border-color:var(--border-strong);transform:translateY(-3px)}
.cc .ic{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:rgba(168,85,247,0.1);color:var(--primary-hi);border:1px solid var(--border)}
.cc .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:var(--text-mute);text-transform:uppercase}
.cc .val{font-size:15px;color:var(--text);font-weight:500;line-height:1.4}
.cc a:hover{color:var(--primary-hi)}

.map{
  position:relative;aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(135deg,#0E0A1A,#160D26);border:1px solid var(--border-strong);
}
.map::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(168,85,247,0.1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(168,85,247,0.1) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at 50% 55%, #000 30%, transparent 80%);
}
.map .road{position:absolute;height:2px;background:rgba(168,85,247,0.2);transform-origin:left center}
.map .road.r1{top:38%;left:-5%;width:60%;transform:rotate(8deg)}
.map .road.r2{top:62%;left:30%;width:70%;transform:rotate(-12deg)}
.map .road.r3{top:50%;left:10%;width:80%;transform:rotate(2deg)}
.map .road.r4{top:30%;left:25%;width:50%;transform:rotate(-22deg)}
.map .pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;gap:0;z-index:3}
.map .pin-dot{width:24px;height:24px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:linear-gradient(135deg,var(--primary),var(--primary-deep));box-shadow:0 8px 24px -4px rgba(168,85,247,0.7);position:relative}
.map .pin-dot::after{content:"";position:absolute;inset:6px;border-radius:50%;background:#fff}
.map .pin-pulse{position:absolute;top:0;left:0;width:24px;height:24px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:rgba(168,85,247,0.4);animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{transform:rotate(-45deg) scale(1);opacity:.6}100%{transform:rotate(-45deg) scale(3);opacity:0}}
.map .label{margin-top:14px;padding:8px 14px;border-radius:8px;background:rgba(8,6,16,0.9);backdrop-filter:blur(10px);border:1px solid var(--border-strong);font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--text);white-space:nowrap}
.map-link{position:absolute;bottom:18px;right:18px;z-index:4;padding:10px 16px;border-radius:999px;background:rgba(8,6,16,0.85);backdrop-filter:blur(10px);border:1px solid var(--border-strong);display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;color:var(--text);letter-spacing:.06em}
.map-link:hover{color:var(--primary-hi);border-color:var(--primary)}

.hours-card{padding:36px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface)}
.hours-card h3{font-family:var(--display);font-size:22px;font-weight:700;margin-bottom:22px}
.hours-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border);font-size:14px}
.hours-row:last-child{border-bottom:none}
.hours-row .d{color:var(--text-dim);font-family:var(--mono);letter-spacing:.04em;font-size:13px}
.hours-row .t{color:var(--text);font-weight:500}
.hours-row.cls .t{color:var(--text-mute);font-style:italic}
.hours-card .note{margin-top:20px;padding-top:20px;border-top:1px solid var(--border);font-size:13px;color:var(--text-dim);display:flex;align-items:center;gap:10px}
.hours-card .note::before{content:"";width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e}

/* ===================================================================
   BLOG PAGE
   =================================================================== */
.cat-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.cat-pill{
  padding:9px 16px;font-size:13px;font-weight:500;color:var(--text-dim);
  background:transparent;border:1px solid var(--border);border-radius:999px;
  transition:all .25s var(--easing);display:inline-flex;align-items:center;gap:8px;
}
.cat-pill:hover{color:var(--text);border-color:var(--border-strong)}
.cat-pill.active{background:var(--primary);color:#0a0014;border-color:var(--primary);font-weight:600}
.cat-pill .ct{font-family:var(--mono);font-size:10px;opacity:.7}

.newsletter{
  position:relative;padding:60px;border-radius:var(--r-lg);
  background:linear-gradient(135deg, rgba(168,85,247,0.14), rgba(109,40,217,0.05) 60%, transparent),var(--surface);
  border:1px solid var(--border-strong);overflow:hidden;
}
.newsletter::before{content:"";position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(168,85,247,0.3),transparent 60%);right:-80px;top:-80px;filter:blur(20px)}
.newsletter h2{font-size:clamp(26px,3vw,38px);max-width:540px;text-wrap:balance}
.newsletter p{color:var(--text-dim);font-size:16px;margin:14px 0 28px;max-width:540px}
.newsletter form{display:flex;gap:10px;max-width:480px;position:relative;z-index:2}
.newsletter input{flex:1;padding:16px 18px;border-radius:999px;border:1px solid var(--border);background:rgba(8,6,16,0.5);color:var(--text);font-size:14px}
.newsletter input:focus{outline:none;border-color:var(--primary)}
.newsletter button{padding:0 24px;border-radius:999px;border:none;background:var(--primary);color:#0a0014;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px;box-shadow:0 8px 24px -8px rgba(168,85,247,0.55)}
.newsletter .tiny{margin-top:14px;font-size:12px;color:var(--text-mute);font-family:var(--mono);letter-spacing:.04em}
@media (max-width:768px){.newsletter{padding:36px 28px}.newsletter form{flex-direction:column}.newsletter button{padding:14px}}

.feat-post{
  display:grid;grid-template-columns:1.05fr 1fr;gap:0;
  border:1px solid var(--border-strong);border-radius:var(--r-lg);
  background:var(--surface);overflow:hidden;margin-bottom:64px;
}
@media (max-width:1024px){.feat-post{grid-template-columns:1fr}}
.feat-post .art{aspect-ratio:5/4;position:relative}
.feat-post .body{padding:56px;display:flex;flex-direction:column;justify-content:center;gap:14px}
.feat-post .meta{display:flex;gap:14px;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--text-mute);text-transform:uppercase}
.feat-post .meta b{color:var(--primary-hi);font-weight:500;padding:4px 10px;border:1px solid var(--border-strong);border-radius:999px;background:rgba(168,85,247,0.06)}
.feat-post h2{font-size:clamp(28px,3.4vw,44px);text-wrap:balance;font-weight:700}
.feat-post p{color:var(--text-dim);font-size:17px;line-height:1.65;margin:0}
.feat-post .author{display:flex;align-items:center;gap:14px;margin-top:18px;padding-top:18px;border-top:1px solid var(--border)}
.feat-post .author .avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-deep));display:grid;place-items:center;font-family:var(--display);font-weight:700;color:#fff;font-size:14px}
.feat-post .author .nm{font-weight:600;font-size:14px}
.feat-post .author .rl{font-size:12px;color:var(--text-dim);font-family:var(--mono);letter-spacing:.04em}
@media (max-width:768px){.feat-post .body{padding:36px 28px}}

/* ===================================================================
   SINGLE POST
   =================================================================== */
.single-post-content{max-width:760px;margin:0 auto;padding:48px 0 80px}
.single-post-content h2,.single-post-content h3,.single-post-content h4{margin:40px 0 16px;color:var(--text)}
.single-post-content p{color:var(--text-dim);font-size:17px;line-height:1.75;margin:0 0 24px}
.single-post-content a{color:var(--primary-hi);text-decoration:underline;text-underline-offset:3px}
.single-post-content ul,.single-post-content ol{color:var(--text-dim);padding-left:24px;margin:0 0 24px;line-height:1.75}
.single-post-content img{border-radius:var(--r);margin:32px 0}
.single-post-content blockquote{border-left:3px solid var(--primary);padding:16px 24px;margin:32px 0;background:rgba(168,85,247,0.06);border-radius:0 var(--r) var(--r) 0}
.single-post-content code{font-family:var(--mono);font-size:13px;background:rgba(168,85,247,0.1);padding:2px 6px;border-radius:4px;color:var(--primary-hi)}
.single-post-content pre{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:24px;overflow-x:auto;margin:24px 0}
.single-post-content pre code{background:none;padding:0}

/* ===================================================================
   404 PAGE
   =================================================================== */
.page-404{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:140px 0 80px}
.page-404 .err-code{font-family:var(--display);font-size:clamp(120px,20vw,200px);font-weight:800;line-height:1.1;letter-spacing:-0.04em;background:linear-gradient(135deg,var(--primary-hi),var(--primary),var(--primary-deep));-webkit-background-clip:text;background-clip:text;color:transparent;display:block;padding-bottom:0.05em}
.page-404 h1{font-size:clamp(28px,4vw,48px);margin:16px 0}
.page-404 p{color:var(--text-dim);font-size:18px;margin:16px 0 36px;max-width:480px}

/* ===================================================================
   WORDPRESS OVERRIDES
   =================================================================== */
.wp-block-image img{border-radius:var(--r)}
.wp-caption-text,.figcaption{font-size:13px;color:var(--text-mute);font-family:var(--mono);letter-spacing:.04em;margin-top:8px;text-align:center}
.aligncenter{margin-left:auto;margin-right:auto;display:block}
.alignleft{float:left;margin-right:24px;margin-bottom:16px}
.alignright{float:right;margin-left:24px;margin-bottom:16px}
.screen-reader-text{position:absolute;left:-9999px}

/* ===================================================================
   VISUAL REDESIGN v2 — WEBZARDIO
   Dramatic, always-visible improvements
   =================================================================== */

/* ---- SCROLLBAR ---- */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--primary),var(--primary-deep));border-radius:999px}
::-webkit-scrollbar-thumb:hover{background:var(--primary-hi)}

/* ---- SELECTION ---- */
::selection{background:rgba(168,85,247,0.35);color:#fff}

/* ---- FONT RENDERING ---- */
html{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{
  font-feature-settings:"kern","liga","calt","ss01";
  -webkit-font-smoothing:antialiased;
}

/* ---- FOCUS ---- */
:focus-visible{outline:2px solid var(--primary);outline-offset:4px;border-radius:8px;box-shadow:0 0 0 4px rgba(168,85,247,0.15)}

/* ---- RICHER BODY BACKGROUND ---- */
body{
  background:
    radial-gradient(ellipse 140% 70% at 50% -10%, rgba(109,40,217,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 80% 60% at 100% 40%, rgba(168,85,247,0.06) 0%, transparent 50%),
    radial-gradient(ellipse 60% 50% at 0% 90%, rgba(109,40,217,0.05) 0%, transparent 50%),
    #080610;
  background-attachment:fixed;
}

/* ---- ITALIC ACCENT — glow + shimmer ---- */
.italic-accent{
  font-style:italic;font-weight:600;
  display:inline-block;
  background:linear-gradient(110deg,var(--primary-hi) 20%,#e9d5ff 50%,var(--primary-hi) 80%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
  animation:accentShimmer 5s linear infinite;
  /* strat de compunere stabil — fără filter:drop-shadow (cauza dispariției intermitente a textului decupat) */
  will-change:background-position;
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
  transform:translateZ(0);
}
@keyframes accentShimmer{
  0%{background-position:0% 50%}
  100%{background-position:200% 50%}
}

/* ---- EYEBROW — redesigned ---- */
.eyebrow{
  background:linear-gradient(135deg,rgba(168,85,247,0.18),rgba(109,40,217,0.08));
  border:1px solid rgba(168,85,247,0.42);
  box-shadow:0 0 28px rgba(168,85,247,0.18), inset 0 1px 0 rgba(255,255,255,0.07);
  letter-spacing:.2em;
}
.eyebrow::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--primary);box-shadow:0 0 10px var(--primary);
  animation:dotPulse 2.4s ease-in-out infinite;
}
@keyframes dotPulse{
  0%,100%{box-shadow:0 0 6px var(--primary)}
  50%{box-shadow:0 0 18px var(--primary),0 0 28px rgba(168,85,247,0.5)}
}

/* ---- SECTION-HEAD H2 — gradient ---- */
.section-head h2{
  background:linear-gradient(140deg,#f5f0ff 30%,var(--primary-hi) 65%,var(--primary));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---- STAT NUMBERS — gradient ---- */
.stat-num{
  background:linear-gradient(135deg,#ffffff 25%,var(--primary-hi) 85%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:none;
}
.stat-num small{
  background:none;-webkit-background-clip:unset;background-clip:unset;
  color:var(--primary);text-shadow:0 0 14px rgba(168,85,247,0.6);
}

/* ---- CARDS — glass surface ---- */
.service,.stat,.post,.proj,.cat-card,.testi,.mv-card,.step,.pillar,
.approach,.hours-card,.feat-post,.featured,.cc{
  background:linear-gradient(160deg,rgba(168,85,247,0.07) 0%,rgba(17,9,29,0.75) 35%),
    rgba(17,9,29,0.6);
  backdrop-filter:blur(18px) saturate(1.3);
  -webkit-backdrop-filter:blur(18px) saturate(1.3);
  border:1px solid rgba(168,85,247,0.16);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.06),
    inset 0 -1px 0 rgba(0,0,0,0.25),
    0 4px 32px rgba(0,0,0,0.35);
}

/* ---- CARD HOVER — unified glow system ---- */
.service:hover,.stat:hover,.post:hover,.proj:hover,
.cat-card:hover,.testi:hover,.step:hover,.pillar:hover,
.approach:hover,.cc:hover{
  border-color:rgba(168,85,247,0.42);
  transform:translateY(-5px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.09),
    0 8px 48px -12px rgba(168,85,247,0.55),
    0 0 0 1px rgba(168,85,247,0.18);
}

/* ---- LOGO — glow ---- */
.brand-logo{
  filter:drop-shadow(0 0 16px rgba(168,85,247,0.55)) brightness(1.05);
  transition:filter .3s;
}
.brand:hover .brand-logo{filter:drop-shadow(0 0 22px rgba(168,85,247,0.75)) brightness(1.1)}

/* ---- HEADER SCROLLED ---- */
.header.scrolled{
  background:rgba(8,6,16,0.55);
  backdrop-filter:blur(28px) saturate(1.6) brightness(1.08);
  -webkit-backdrop-filter:blur(28px) saturate(1.6) brightness(1.08);
  border-bottom:1px solid rgba(168,85,247,0.14);
}

/* ---- NAV LINKS — underline slide ---- */
.nav-links a::after{
  content:"";position:absolute;bottom:5px;left:16px;right:16px;height:1px;
  background:linear-gradient(90deg,transparent,var(--primary-hi),transparent);
  transform:scaleX(0);transform-origin:center;
  transition:transform .3s var(--easing);
}
.nav-links a:hover::after,.nav-links a.active::after{
  transform:scaleX(1);
  box-shadow:0 0 8px var(--primary);
}

/* ---- MOBILE DRAWER ---- */
.mobile-drawer{
  background:rgba(8,6,16,0.94);
  backdrop-filter:blur(32px) saturate(1.5);
  -webkit-backdrop-filter:blur(32px) saturate(1.5);
}

/* ---- CTA BUTTON — redesigned ---- */
.cta-btn{
  background:linear-gradient(135deg,var(--primary-hi) 0%,var(--primary) 50%,var(--primary-deep) 100%);
  background-size:200% 200%;background-position:0% 0%;
  padding:15px 28px;font-size:15px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.14),
    0 8px 32px -8px rgba(168,85,247,0.85),
    0 0 60px -15px rgba(168,85,247,0.4);
  transition:all .35s var(--easing);
  overflow:hidden;
}
.cta-btn::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.22) 50%,transparent 100%);
  transform:translateX(-120%);
}
.cta-btn:hover{
  background-position:100% 100%;transform:translateY(-3px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    0 14px 44px -8px rgba(168,85,247,0.95),
    0 0 80px -12px rgba(168,85,247,0.5);
}
.cta-btn:hover::before{transform:translateX(120%);transition:transform .55s ease}
.cta-btn .arr{transition:transform .3s var(--easing)}
.cta-btn:hover .arr{transform:translateX(5px)}

/* ---- BTN OUTLINE ---- */
.btn-outline{
  border:1px solid rgba(168,85,247,0.35);
  transition:all .3s var(--easing);
}
.btn-outline:hover{
  border-color:var(--primary);background:rgba(168,85,247,0.1);
  color:var(--primary-hi);box-shadow:0 0 24px rgba(168,85,247,0.25);
  transform:translateY(-2px);
}

/* ---- PAGE HERO ---- */
.page-hero{
  background:
    radial-gradient(ellipse 80% 60% at 50% -5%, rgba(168,85,247,0.14) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 85% 60%, rgba(109,40,217,0.08) 0%, transparent 50%);
}
.page-hero::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:200px;
  background:linear-gradient(0deg,var(--bg) 0%,transparent 100%);
  pointer-events:none;z-index:1;
}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{text-shadow:0 0 80px rgba(168,85,247,0.12)}

/* ---- HERO SECTION ---- */
.hero{
  background:
    radial-gradient(ellipse 70% 55% at 15% 55%, rgba(109,40,217,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 55% 45% at 88% 30%, rgba(168,85,247,0.1) 0%, transparent 50%);
}
.hero h1{text-shadow:0 0 120px rgba(168,85,247,0.14)}
.hero h1 .em{
  background:linear-gradient(110deg,#fff 5%,var(--primary-hi) 28%,var(--primary) 48%,#e9d5ff 58%,var(--primary-hi) 78%,#fff 92%);
  background-size:260% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-style:italic;font-weight:600;
  animation:heroShimmer 6s linear infinite;
  filter:drop-shadow(0 0 30px rgba(192,132,252,0.3));
}
@keyframes heroShimmer{0%{background-position:0% 50%}100%{background-position:260% 50%}}
.hero-meta{backdrop-filter:blur(14px);background:rgba(255,255,255,0.03);border:1px solid rgba(168,85,247,0.2)}

/* ---- SECTION SEPARATORS ---- */
.diag::before{
  height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(168,85,247,0.12) 15%,
    rgba(192,132,252,0.45) 50%,
    rgba(168,85,247,0.12) 85%,
    transparent 100%
  );
  box-shadow:0 0 12px rgba(168,85,247,0.2);
}

/* ---- STAT ICON GLOW ---- */
.stat-icon{filter:drop-shadow(0 0 6px rgba(168,85,247,0.4))}

/* ---- SERVICE ICON ---- */
.service-ic{
  background:linear-gradient(160deg,rgba(168,85,247,0.18),rgba(109,40,217,0.06));
  border:1px solid rgba(168,85,247,0.25);
  box-shadow:0 0 20px rgba(168,85,247,0.1) inset;
}

/* ---- PROCESS STEP ---- */
.step{transition:all .3s var(--easing)}
.step .ic{transition:all .3s var(--easing)}
.step:hover{border-color:rgba(168,85,247,0.38);box-shadow:0 6px 30px -10px rgba(168,85,247,0.35)}
.step:hover .ic{border-color:var(--primary);box-shadow:0 0 20px rgba(168,85,247,0.35);color:var(--text)}

/* ---- PROCESS STEP COUNTER ---- */
.step::before{
  font-size:11px;color:var(--primary-hi);
  text-shadow:0 0 10px rgba(168,85,247,0.5);
  letter-spacing:.12em;
}

/* ---- TIMELINE ---- */
.timeline::before{
  background:linear-gradient(180deg,var(--primary),var(--primary-deep) 70%,transparent);
  width:2px;box-shadow:0 0 14px rgba(168,85,247,0.45);
}
.tl-item::before{animation:tlPulse 3s ease-in-out infinite}
@keyframes tlPulse{
  0%,100%{box-shadow:0 0 0 4px rgba(168,85,247,0.12)}
  50%{box-shadow:0 0 0 6px rgba(168,85,247,0.25),0 0 20px rgba(168,85,247,0.35)}
}
.tl-year{
  display:inline-block;
  background:linear-gradient(90deg,var(--primary-hi),var(--primary));
  -webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
  transform:translateZ(0);
}

/* ---- PILLARS ---- */
.pillar{transition:all .3s var(--easing)}
.pillar:hover{border-color:rgba(168,85,247,0.38);transform:translateY(-4px)}
.pillar .ic{
  background:linear-gradient(160deg,rgba(168,85,247,0.16),rgba(109,40,217,0.06));
  border:1px solid rgba(168,85,247,0.22);
}
.pillar:hover .ic{border-color:var(--primary);box-shadow:0 0 20px rgba(168,85,247,0.3)}

/* ---- TESTIMONIALS ---- */
.testi::before{
  color:rgba(168,85,247,0.22);
  text-shadow:0 0 50px rgba(168,85,247,0.6);
}
.testi-avatar{box-shadow:0 0 20px rgba(168,85,247,0.5)}

/* ---- CTA BANNER ---- */
.cta-banner{
  background:linear-gradient(135deg,rgba(168,85,247,0.2),rgba(109,40,217,0.1) 50%,rgba(168,85,247,0.05)),
    rgba(17,9,29,0.7);
  backdrop-filter:blur(24px);
  border:1px solid rgba(168,85,247,0.32);
  box-shadow:
    0 0 100px -20px rgba(168,85,247,0.38),
    inset 0 1px 0 rgba(255,255,255,0.07),
    inset 0 -1px 0 rgba(0,0,0,0.2);
}

/* ---- NEWSLETTER ---- */
.newsletter{
  backdrop-filter:blur(20px);
  border:1px solid rgba(168,85,247,0.28);
  box-shadow:0 0 80px -20px rgba(168,85,247,0.28),inset 0 1px 0 rgba(255,255,255,0.05);
}
.newsletter input{border:1px solid rgba(168,85,247,0.2);background:rgba(8,6,16,0.6)}
.newsletter input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(168,85,247,0.15)}
.newsletter button{transition:all .3s var(--easing)}
.newsletter button:hover{box-shadow:0 12px 36px -6px rgba(168,85,247,0.75);transform:translateY(-2px)}

/* ---- FEATURED + FEAT-POST ---- */
.featured,.feat-post{
  border:1px solid rgba(168,85,247,0.22);
  box-shadow:0 0 80px -20px rgba(168,85,247,0.28),inset 0 1px 0 rgba(255,255,255,0.04);
  backdrop-filter:blur(20px);
  transition:box-shadow .4s var(--easing),border-color .4s;
}
.featured:hover,.feat-post:hover{
  border-color:rgba(168,85,247,0.38);
  box-shadow:0 0 120px -16px rgba(168,85,247,0.42),inset 0 1px 0 rgba(255,255,255,0.06);
}

/* ---- PROJ BADGE ---- */
.proj-badge{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hi) 100%) !important;
  border:none !important;
  box-shadow:0 4px 18px rgba(168,85,247,0.55), 0 1px 0 rgba(255,255,255,0.15) inset !important;
  backdrop-filter:none !important;
}

/* ---- PROJECT FILTER ---- */
.filter-btn.active{box-shadow:0 4px 20px -4px rgba(168,85,247,0.65)}
.filter-btn{transition:all .25s var(--easing)}
.filter-btn:hover:not(.active){border-color:rgba(168,85,247,0.35);box-shadow:0 0 16px rgba(168,85,247,0.2)}

/* ---- INDUSTRIES ---- */
.industry{transition:all .28s var(--easing)}
.industry:hover{
  border-color:var(--primary);
  background:rgba(168,85,247,0.08);
  box-shadow:0 4px 20px rgba(168,85,247,0.25);
  transform:translateY(-3px);
}
.industry:hover span{color:var(--primary-hi)}

/* ---- CONTACT CARDS ---- */
.cc .lbl{color:rgba(168,85,247,0.7)}

/* ---- FORM FIELDS ---- */
.field input,.field textarea,.field select{
  background:rgba(17,9,29,0.7);
  border:1px solid rgba(168,85,247,0.15);
  transition:border-color .25s,box-shadow .25s,background .25s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--primary);
  background:rgba(168,85,247,0.05);
  box-shadow:0 0 0 4px rgba(168,85,247,0.13),0 0 20px rgba(168,85,247,0.08);
}

/* ---- SEND BUTTON ---- */
.send-btn{
  background:linear-gradient(135deg,var(--primary-hi),var(--primary),var(--primary-deep));
  background-size:200% 200%;
  transition:all .3s var(--easing);
}
.send-btn:hover{
  background-position:100% 100%;transform:translateY(-2px);
  box-shadow:0 12px 36px -6px rgba(168,85,247,0.75),inset 0 1px 0 rgba(255,255,255,0.1);
}

/* ---- HOURS CARD ---- */
.hours-card{transition:border-color .25s,box-shadow .25s}
.hours-card:hover{border-color:rgba(168,85,247,0.3);box-shadow:0 0 24px rgba(168,85,247,0.15)}

/* ---- MAP ---- */
.map .label{animation:labelFloat 3.2s ease-in-out infinite}
@keyframes labelFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.map .pin-dot{box-shadow:0 8px 28px -4px rgba(168,85,247,0.9),0 0 20px rgba(168,85,247,0.5)}

/* ---- ACCORDION ---- */
.acc{
  background:rgba(17,9,29,0.6);backdrop-filter:blur(16px);
  border:1px solid rgba(168,85,247,0.13);
  transition:border-color .25s,box-shadow .25s;
}
.acc[open]{
  border-color:rgba(168,85,247,0.32);
  box-shadow:0 4px 30px -8px rgba(168,85,247,0.25);
}

/* ---- STACK BADGES ---- */
.stack-badge{transition:all .25s var(--easing)}
.stack-badge:hover{
  border-color:var(--primary);color:var(--primary-hi);
  background:rgba(168,85,247,0.1);
  box-shadow:0 0 16px rgba(168,85,247,0.25);
  transform:translateY(-2px);
}

/* ---- CAT PILLS ---- */
.cat-pill{transition:all .25s var(--easing)}
.cat-pill.active{box-shadow:0 4px 22px -4px rgba(168,85,247,0.6)}
.cat-pill:hover:not(.active){border-color:rgba(168,85,247,0.35);box-shadow:0 0 16px rgba(168,85,247,0.2)}

/* ---- CAT NAV ---- */
.cat-nav a:hover{box-shadow:0 0 20px rgba(168,85,247,0.2)}

/* ---- STORY ART ---- */
.story-art .ring.r4{box-shadow:0 0 40px rgba(168,85,247,0.55) inset,0 0 40px rgba(168,85,247,0.3)}
.story-art .core{box-shadow:0 20px 60px -10px rgba(168,85,247,0.85),0 0 50px rgba(168,85,247,0.45)}
.story-art .badge{
  background:rgba(8,6,16,0.75);backdrop-filter:blur(10px);
  border:1px solid rgba(168,85,247,0.38);
  box-shadow:0 2px 16px rgba(168,85,247,0.2);
}

/* ---- FOOTER ---- */
.footer{
  background:
    linear-gradient(180deg,transparent,rgba(168,85,247,0.06) 40%,rgba(109,40,217,0.04) 100%),
    radial-gradient(ellipse 70% 50% at 50% 100%,rgba(168,85,247,0.07),transparent 70%);
  border-top:1px solid rgba(168,85,247,0.18);
}
.footer-col a{display:inline-block;transition:color .2s,transform .2s}
.footer-col a:hover{color:var(--primary-hi);transform:translateX(4px)}

/* ---- SCROLL INDICATOR ---- */
.scroll-ind{animation:scrollFadeIn .9s var(--easing) 1.6s both}
@keyframes scrollFadeIn{from{opacity:0;transform:translate(-50%,14px)}to{opacity:1;transform:translate(-50%,0)}}

/* ---- POST CARD TOP BAR ---- */
.post::before{
  background:linear-gradient(90deg,var(--primary-deep),var(--primary),var(--primary-hi));
  box-shadow:0 0 16px rgba(168,85,247,0.4);
}

/* ---- 404 ---- */
.page-404 .err-code{-webkit-text-fill-color:transparent;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}

/* ---- SINGLE POST ---- */
.single-post-content h2,.single-post-content h3{
  background:linear-gradient(135deg,var(--text) 55%,var(--primary-hi));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.single-post-content p{text-rendering:optimizeLegibility}

/* ---- CRUMBS ---- */
.crumbs a{transition:color .2s}
.crumbs a:hover{color:var(--primary-hi);text-shadow:0 0 14px rgba(168,85,247,0.45)}

/* ---- APPROACH CARDS ---- */
.approach{transition:all .3s var(--easing)}
.approach:hover{border-color:rgba(168,85,247,0.38);transform:translateY(-4px);box-shadow:0 8px 36px -10px rgba(168,85,247,0.35)}
.approach.feat{
  border-color:rgba(168,85,247,0.3);
  background:linear-gradient(160deg,rgba(168,85,247,0.12),rgba(109,40,217,0.06) 60%,transparent),rgba(17,9,29,0.65);
  box-shadow:0 0 40px -12px rgba(168,85,247,0.25);
}

/* ---- CONTACT INFO ---- */
.contact-info .contact-row .ic{transition:all .25s var(--easing)}
.contact-info .contact-row:hover .ic{background:rgba(168,85,247,0.2);border-color:var(--primary);box-shadow:0 0 16px rgba(168,85,247,0.3)}

/* ---- HERO ORB UPGRADE ---- */
.hero-orb{background:radial-gradient(circle,rgba(168,85,247,0.38) 0%,transparent 60%);filter:blur(50px)}
.hero-orb-2{background:radial-gradient(circle,rgba(109,40,217,0.34) 0%,transparent 60%);filter:blur(50px)}

/* ---- HERO H1 — bigger max, stronger presence ---- */
.hero h1{
  font-size:clamp(52px,9.5vw,136px);
  letter-spacing:-0.04em;
}

/* ---- SECTION HEAD H2 — glow shadow ---- */
.section-head h2{
  text-shadow:0 0 80px rgba(168,85,247,0.12);
  font-size:clamp(34px,4vw,56px);
}

/* ---- CTA BANNER — pulsing glow ---- */
@keyframes ctaGlowPulse{
  0%,100%{
    box-shadow:0 0 60px -12px rgba(168,85,247,0.55),0 0 100px -20px rgba(168,85,247,0.3),
      inset 0 1px 0 rgba(255,255,255,0.07),inset 0 -1px 0 rgba(0,0,0,0.2);
    border-color:rgba(168,85,247,0.32);
  }
  50%{
    box-shadow:0 0 100px -8px rgba(168,85,247,0.75),0 0 160px -20px rgba(192,132,252,0.4),
      inset 0 1px 0 rgba(255,255,255,0.11),inset 0 -1px 0 rgba(0,0,0,0.2);
    border-color:rgba(192,132,252,0.55);
  }
}
.cta-banner{animation:ctaGlowPulse 4s ease-in-out infinite}

/* ---- CURSOR GLOW (desktop only) ---- */
#cursor-glow{
  pointer-events:none;
  position:fixed;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(168,85,247,0.07) 0%,transparent 60%);
  transform:translate(-50%,-50%);
  z-index:9999;
  transition:opacity .3s;
  will-change:transform;
}

/* ---- SOCIAL ICONS — hover glow ---- */
.socials a:hover{
  color:var(--primary-hi);
  border-color:var(--primary);
  background:rgba(168,85,247,0.12);
  box-shadow:0 0 18px rgba(168,85,247,0.35);
}

/* ---- TECH STRIP — dots pulse ---- */
.tech-strip span::before{
  animation:dotPulse 2.4s ease-in-out infinite;
  animation-delay:calc(var(--i,0) * 0.4s);
}

/* ---- REDUCED MOTION ---- */
@media(prefers-reduced-motion:reduce){
  .italic-accent,.cta-btn::before,.tl-item::before,.map .label,
  .eyebrow::before,.hero h1 .em,.scroll-ind,.cta-banner{animation:none !important}
  .italic-accent{background:none;color:var(--primary-hi);-webkit-text-fill-color:var(--primary-hi);filter:none;transform:none}
  .hero h1 .em{background:none;color:var(--primary-hi);-webkit-text-fill-color:var(--primary-hi);filter:none;transform:none}
  #cursor-glow{display:none}
}

/* ===================================================================
   APPLE STYLE — Precision · Space · Typography
   =================================================================== */

/* ── Token overrides ── */
:root{
  --bg:#000;
  --bg-2:#0a0a0a;
  --surface:#1c1c1e;
  --border:rgba(255,255,255,0.07);
  --border-strong:rgba(255,255,255,0.11);
  --text:#f5f5f7;
  --text-dim:#a1a1a6;
  --text-mute:#6e6e73;
  --easing:cubic-bezier(0.25,0.46,0.45,0.94);
  --r:16px;
  --r-lg:20px;
}

/* ── Body ── */
body{
  background:#000 !important;
  background-attachment:initial !important;
}

/* ── bg-noise / bg-grid — softer ── */
.bg-noise{opacity:.025}
.bg-grid{opacity:.018}

/* ── Header — Apple nav ── */
.header{
  padding:20px 0;
  background:rgba(0,0,0,0.78);
  backdrop-filter:saturate(180%) blur(24px);
  -webkit-backdrop-filter:saturate(180%) blur(24px);
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.header.scrolled{
  padding:14px 0;
  background:rgba(0,0,0,0.88) !important;
  backdrop-filter:saturate(180%) blur(28px) !important;
  -webkit-backdrop-filter:saturate(180%) blur(28px) !important;
  border-bottom:1px solid rgba(255,255,255,0.1) !important;
}
.nav-links a{
  font-size:15px;color:#f5f5f7;opacity:.75;
  letter-spacing:-.015em;padding:10px 14px;border-radius:8px;
  background:transparent;
}
.nav-links a:hover{opacity:1;color:#f5f5f7;background:rgba(255,255,255,0.06)}
.nav-links a.active{opacity:1;color:#f5f5f7}
.nav-links a::after{bottom:4px;left:14px;right:14px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.55),transparent);box-shadow:none}

/* ── Hero — Apple centered ── */
.hero{padding-top:160px;padding-bottom:100px}
.hero-inner{
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
}
.hero-meta{margin:0 auto 28px}
.hero h1{
  font-size:clamp(60px,11vw,152px);
  letter-spacing:-.05em;line-height:1.02;font-weight:700;
  max-width:1100px;
  padding-bottom:0.06em;
}
.hero h1 .em{
  background:linear-gradient(120deg,#fff 10%,var(--primary-hi) 35%,#e9d5ff 55%,var(--primary-hi) 75%,#fff 90%);
  background-size:280% 100%;
  -webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
  animation:heroShimmer 7s linear infinite;
  filter:none;
  /* strat de compunere stabil pentru textul decupat animat */
  will-change:background-position;
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
  transform:translateZ(0);
  padding-right:0.1em;
  margin-right:-0.1em;
}
.hero p.lead{
  font-size:clamp(19px,2vw,26px);
  color:#86868b;letter-spacing:-.015em;line-height:1.42;
  max-width:600px;margin:24px 0 40px;text-align:center;
}
.hero-ctas{justify-content:center}
.tech-strip{
  justify-content:center;
  border-color:rgba(255,255,255,0.07);
  color:#6e6e73;gap:32px;
}
.scroll-ind{color:#48484a}

/* ── Apple pill buttons ── */
.cta-btn{
  border-radius:980px !important;
  padding:15px 32px !important;
  font-size:17px !important;
  font-weight:600 !important;
  letter-spacing:-.022em !important;
}
.btn-outline{
  border-radius:980px;
  padding:14px 28px;
  font-size:17px;font-weight:600;
  letter-spacing:-.022em;
}
.btn-ghost{font-size:17px;letter-spacing:-.015em}

/* ── Section spacing ── */
.diag{padding-top:128px;padding-bottom:128px}

/* ── Eyebrow labels ── */
.eyebrow{
  background:rgba(255,255,255,0.05) !important;
  border:1px solid rgba(255,255,255,0.1) !important;
  box-shadow:none !important;
  color:#6e6e73;font-size:11px;letter-spacing:.1em;
}
.eyebrow::before{background:#6e6e73;box-shadow:none !important}

/* ── Section head ── */
.section-head{
  text-align:center;max-width:820px;
  margin-left:auto;margin-right:auto;
}
.section-head h2{
  font-size:clamp(44px,6vw,80px) !important;
  letter-spacing:-.04em;line-height:1.05;font-weight:700;
  background:linear-gradient(160deg,#f5f5f7 40%,#a1a1a6 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:none !important;
  padding-bottom:0.05em;
}
.section-head h2 .italic-accent{
  background:linear-gradient(110deg,var(--primary-hi) 20%,#e9d5ff 50%,var(--primary-hi) 80%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-head p{
  font-size:19px;color:#86868b;
  letter-spacing:-.01em;margin-top:14px;
}

/* ── Cards — Apple dark surface ── */
.service,.stat,.post,.proj,.cat-card,.testi,
.mv-card,.step,.pillar,.approach,.hours-card,.cc,
.feat-post,.featured,.newsletter{
  background:#1c1c1e !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  border:1px solid rgba(255,255,255,0.07) !important;
  border-radius:20px;
  box-shadow:none !important;
}
.service:hover,.stat:hover,.post:hover,.proj:hover,
.cat-card:hover,.testi:hover,.step:hover,.pillar:hover,
.approach:hover,.cc:hover{
  border-color:rgba(255,255,255,0.14) !important;
  background:#242426 !important;
  box-shadow:none !important;
  transform:translateY(-4px);
}

/* ── Stat numbers — Apple large callout ── */
.stat-num{
  font-size:clamp(56px,6.5vw,88px);
  letter-spacing:-.05em;line-height:1;
  background:linear-gradient(135deg,#f5f5f7 30%,var(--primary-hi) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat-label{
  font-size:13px;color:#6e6e73;
  letter-spacing:-.01em;margin-top:6px;
}

/* ── CTA banner — Apple glass ── */
.cta-banner{
  background:#1c1c1e !important;
  border:1px solid rgba(255,255,255,0.1) !important;
  animation:none !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
}
.cta-banner h2{
  background:linear-gradient(150deg,#f5f5f7 40%,#a1a1a6 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ── Timeline ── */
.tl-year{
  background:linear-gradient(90deg,#f5f5f7,#a1a1a6);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:none;
}
.timeline::before{
  background:linear-gradient(180deg,rgba(255,255,255,0.12),rgba(255,255,255,0.03) 70%,transparent);
  box-shadow:none;
}
.tl-item::before{
  background:#f5f5f7;box-shadow:0 0 0 4px rgba(255,255,255,0.08);
  animation:none;
}

/* ── Nav links underline ── */
.nav-links a::after{
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.6),transparent);
  box-shadow:none;
}

/* ── Logo ── */
.brand-logo{height:54px;width:auto;filter:brightness(1.05)}
.brand:hover .brand-logo{filter:brightness(1.15)}

/* ── Socials ── */
.socials a{
  background:rgba(255,255,255,0.05);
  border-color:rgba(255,255,255,0.07);
}
.socials a:hover{
  background:rgba(255,255,255,0.1);
  border-color:rgba(255,255,255,0.14);
  color:#f5f5f7;
  box-shadow:none !important;
}

/* ── Footer ── */
.footer{
  background:#000 !important;
  border-top:1px solid rgba(255,255,255,0.08) !important;
}
.footer-col h4{font-size:13px;color:#f5f5f7;letter-spacing:-.01em}
.footer-col a{font-size:13px;color:#6e6e73}
.footer-col a:hover{color:#f5f5f7;transform:none}
.footer-bottom{color:#6e6e73;border-color:rgba(255,255,255,0.07)}
.footer-bottom a{color:#6e6e73}
.footer-bottom a:hover{color:#f5f5f7}

/* ── Form fields ── */
.field input,.field textarea,.field select{
  background:rgba(255,255,255,0.05) !important;
  border:1px solid rgba(255,255,255,0.1) !important;
  border-radius:12px;color:#f5f5f7;
}
.field input:focus,.field textarea:focus,.field select:focus{
  background:rgba(255,255,255,0.07) !important;
  border-color:rgba(255,255,255,0.22) !important;
  box-shadow:none !important;
}
.send-btn{border-radius:980px !important}

/* ── Scroll reveal — cinematic ── */
.reveal{
  transition:opacity 1.1s cubic-bezier(0.25,0.46,0.45,0.94),
             transform 1.1s cubic-bezier(0.25,0.46,0.45,0.94) !important;
}
.reveal-stagger > *{
  transition:opacity .95s cubic-bezier(0.25,0.46,0.45,0.94),
             transform .95s cubic-bezier(0.25,0.46,0.45,0.94) !important;
}

/* ── Cursor glow — subtler ── */
#cursor-glow{
  background:radial-gradient(circle,rgba(255,255,255,0.03) 0%,transparent 60%);
}

/* ── Scrollbar ── */
::-webkit-scrollbar-thumb{
  background:rgba(255,255,255,0.14);
}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.22)}

/* ── Selection ── */
::selection{background:rgba(255,255,255,0.15);color:#fff}

/* ── Mobile drawer ── */
.mobile-drawer{
  background:rgba(0,0,0,0.94) !important;
  backdrop-filter:saturate(180%) blur(28px) !important;
}

/* ── Post top bar ── */
.post::before{
  background:linear-gradient(90deg,rgba(255,255,255,0.08),rgba(255,255,255,0.18),rgba(255,255,255,0.08));
  box-shadow:none;
}

/* ── Proj thumb gradient ── */
.proj-thumb::after{
  background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,0.88) 100%);
}
.proj-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s var(--easing)}
.proj:hover .proj-thumb img{transform:scale(1.06)}

/* ── Apple intro section ── */
.apple-intro-inner{
  text-align:center;max-width:860px;
  margin:0 auto 80px;
  display:flex;flex-direction:column;align-items:center;gap:20px;
}
.apple-big-text{
  font-size:clamp(44px,6vw,80px);
  letter-spacing:-.04em;line-height:1.0;font-weight:700;
  background:linear-gradient(160deg,#f5f5f7 40%,#a1a1a6 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin:8px 0 0;text-wrap:balance;
}
.apple-big-text .italic-accent{
  background:linear-gradient(110deg,var(--primary-hi) 20%,#e9d5ff 50%,var(--primary-hi) 80%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:accentShimmer 5s linear infinite;
}
.apple-sub{
  font-size:clamp(17px,1.8vw,21px);color:#86868b;
  letter-spacing:-.01em;line-height:1.5;max-width:620px;margin:0;
}
.apple-links{display:flex;gap:28px;align-items:center;flex-wrap:wrap;justify-content:center;margin-top:4px}
.apple-link{
  font-size:17px;font-weight:500;color:var(--primary-hi);
  letter-spacing:-.015em;display:inline-flex;align-items:center;gap:4px;
  transition:gap .2s var(--easing),color .2s;
}
.apple-link:hover{color:#fff}
.apple-link:hover .arr{transform:translateX(3px)}
.apple-link .arr{display:inline-block;transition:transform .2s var(--easing);font-style:normal}

/* ── Apple stats strip ── */
.apple-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:20px;background:#1c1c1e;
  overflow:hidden;
}
@media(max-width:768px){.apple-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.apple-stats{grid-template-columns:1fr}}
.apple-stat{
  padding:40px 32px;text-align:center;
  border-right:1px solid rgba(255,255,255,0.07);
}
.apple-stat:last-child{border-right:none}
@media(max-width:768px){
  .apple-stat:nth-child(2){border-right:none}
  .apple-stat:nth-child(3){border-top:1px solid rgba(255,255,255,0.07)}
  .apple-stat:nth-child(4){border-top:1px solid rgba(255,255,255,0.07);border-right:none}
}
.apple-stat .stat-num{
  font-size:clamp(48px,6vw,80px);
  letter-spacing:-.05em;line-height:1;
  background:linear-gradient(135deg,#f5f5f7 25%,var(--primary-hi) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-family:var(--display);font-weight:700;
}
.apple-stat .stat-num small{
  background:none;-webkit-background-clip:unset;background-clip:unset;
  color:var(--primary-hi);font-size:.45em;
}
.apple-stat .stat-label{
  font-size:13px;color:#6e6e73;letter-spacing:.01em;margin-top:8px;
}

/* ── Apple reduced motion ── */
@media(prefers-reduced-motion:reduce){
  .cta-banner,.italic-accent,.hero h1 .em,.apple-big-text .italic-accent{animation:none !important}
  .section-head h2 .italic-accent{background:none;color:var(--primary-hi);-webkit-text-fill-color:var(--primary-hi)}
}

/* ===================================================================
   DESCENDER FIX — litera "g" și alte litere cu coadă (y p q j)
   Syne Bold are descender adânc (~20% din em). Cu overflow:hidden
   pe carduri și line-height strâns, coada se taie.
   Fix: padding-bottom pe headings + overflow:visible explicit.
   =================================================================== */

/* Spaţiu universal sub orice heading pentru descender */
h1, h2, h3, h4 {
  padding-bottom: 0.18em;
}

/* Headings specifice unde descender-ul e cel mai vizibil */
.hero h1,
.page-hero h1,
.apple-big-text {
  padding-bottom: 0.22em !important;
}

/* h3 și h4 în interiorul cardurilor cu overflow:hidden —
   padding-bottom ţine coada în interiorul elementului */
.service h3,
.cat-card h3,
.mv-card h3,
.step h4,
.pillar h4,
.approach h3,
.proj-info h3,
.post h3,
.testi-name,
.featured .body h2,
.feat-post h2,
.cta-banner h2,
.newsletter h2,
.hours-card h3,
.cc .val {
  padding-bottom: 0.18em;
}

/* ===================================================================
   ITALIC CLIP FIX — universal
   Cauzele clipping-ului:
   1. Italic depășește bounding-box spre dreapta → padding-right
   2. line-height prea mic → text iese din line-box, overflow:clip taie
   3. diacritice (ă â î) depășesc line-box spre sus → padding-top
   =================================================================== */

/* Heading-uri nu trebuie să clipeze niciodată */
h1, h2, h3, h4 {
  overflow: visible;
}

/* Italic span — spaţiu suplimentar pe toate laturile unde iese */
.italic-accent,
.hero h1 .em,
h1 .em, h2 .em, h3 .em {
  padding-right: 0.18em;
  padding-left: 0.04em;
  padding-top: 0.06em;
  padding-bottom: 0.06em;
  margin-right: -0.18em;
  margin-left: -0.04em;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

/* Page-hero h1 — mai mult spaţiu vertical pentru diacritice */
.page-hero h1 {
  line-height: 1.08;
  padding-bottom: 0.08em;
  overflow: visible;
}

/* Apple big text */
.apple-big-text {
  line-height: 1.05;
  padding-bottom: 0.06em;
}

/* ── Topbar ── */
.topbar {
  position: relative;
  z-index: 101;
  background: rgba(255,255,255,0.04);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.topbar-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 7px 24px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11.5px;
  color: #6e6e73;
  letter-spacing: 0.02em;
}
.topbar-tag {
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 600;
  color: #000;
  background: #f5f5f7;
  border-radius: 5px;
  padding: 2px 7px;
  line-height: 1.5;
  letter-spacing: 0.04em;
}
.topbar-sep { color: rgba(255,255,255,0.18); }
.topbar-highlight { color: #a1a1a6; font-weight: 500; }
@media(max-width:600px) {
  .topbar-inner { gap:7px; font-size:10.5px; padding:6px 16px; flex-wrap:wrap; }
}

/* ── Social icons fix ── */
.footer-brand .socials { display:flex; gap:10px; margin-top:16px; }
.footer-brand .socials a {
  width:40px; height:40px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);
  color:#a1a1a6 !important;
  transition:all .25s ease;
  flex-shrink:0;
  font-size:0;
}
.footer-brand .socials a:hover {
  background:rgba(255,255,255,0.12);
  border-color:rgba(255,255,255,0.2);
  color:#f5f5f7 !important;
  transform:translateY(-2px);
}
.footer-brand .socials a svg { width:18px; height:18px; display:block; }

/* ── Hero inline stats strip ── */
.hero-stats {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
  margin-top: 32px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 18px 28px;
  width: fit-content;
}
.hstat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 24px;
}
.hstat strong {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #f5f5f7;
  line-height: 1.1;
}
.hstat span {
  font-size: 11.5px;
  color: #6e6e73;
  margin-top: 3px;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.hstat-sep {
  width: 1px;
  height: 32px;
  background: rgba(255,255,255,0.1);
  flex-shrink: 0;
}
@media(max-width:640px) {
  .hero-stats { gap: 12px; padding: 14px 18px; }
  .hstat { padding: 0 14px; }
  .hstat-sep { display: none; }
}

/* ── Gradient text flicker fix ──
   background-clip:text pe element inline în interiorul unui părinte cu
   opacity transition (reveal) cauzează flickering în Chrome/Safari.
   Soluție: display:inline-block + GPU layer forțat + -webkit-text-fill-color ── */
.italic-accent,
.hero h1 .em,
h1 .em, h2 .em, h3 .em,
.section-head h2 .italic-accent,
.apple-big-text .italic-accent,
.page-hero h1 .italic-accent {
  display: inline-block;
  -webkit-text-fill-color: transparent;
  transform: translateZ(0);
  will-change: background-position;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
