/*
Theme Name: Nexim Global
Theme URI: https://nexim.it.com
Author: Nexim Global
Description: Tema su misura per Nexim Global - media services provider per broadcast e grandi eventi: contribuzione, distribuzione e servizi dedicati. Design chiaro, corporate e responsive.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: nexim-global
*/

/* ============================================================
   1. DESIGN TOKENS - tema chiaro corporate
   ============================================================ */
:root{
  --ng-bg:#ffffff;
  --ng-bg-soft:#f4f6fc;
  --ng-bg-mute:#eef1f8;
  --ng-dark:#0d1228;
  --ng-dark-2:#141a36;
  --ng-ink:#10162b;
  --ng-text:#525c75;
  --ng-text-soft:#727c93;
  --ng-text-dim:#9aa3b6;
  --ng-border:#e6e9f2;
  --ng-border-dark:rgba(255,255,255,.1);
  --ng-primary:#2542f5;
  --ng-primary-d:#1a31c7;
  --ng-violet:#7b3ff2;
  --ng-soft:#eef1ff;
  --ng-soft-2:#f3edff;
  --ng-grad:linear-gradient(115deg,#2542f5 0%,#7b3ff2 100%);
  --ng-white:#ffffff;
  --ng-radius:18px;
  --ng-radius-sm:12px;
  --ng-shadow-sm:0 4px 18px -8px rgba(20,30,80,.18);
  --ng-shadow:0 26px 60px -28px rgba(20,30,80,.32);
  --ng-shadow-card:0 18px 44px -24px rgba(20,30,80,.28);
  --ng-maxw:1200px;
  --ng-font-head:"Sora","Segoe UI",system-ui,sans-serif;
  --ng-font-body:"Inter","Segoe UI",system-ui,sans-serif;
  --ng-ease:cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   2. RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ng-font-body);
  background:var(--ng-bg);
  color:var(--ng-text);
  line-height:1.7;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .2s var(--ng-ease)}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--ng-font-head);font-weight:700;line-height:1.18;color:var(--ng-ink)}
h1{font-size:clamp(2.4rem,5vw,3.9rem);letter-spacing:-.025em;font-weight:800}
h2{font-size:clamp(1.85rem,3.4vw,2.7rem);letter-spacing:-.02em}
h3{font-size:1.25rem}
p{color:var(--ng-text)}
::selection{background:var(--ng-primary);color:#fff}

/* ============================================================
   3. LAYOUT
   ============================================================ */
.ng-container{max-width:var(--ng-maxw);margin:0 auto;padding:0 24px;width:100%}
.ng-section{padding:104px 0;position:relative}
.ng-section--tight{padding:64px 0}
.ng-section--alt{background:var(--ng-bg-soft)}
.ng-section--dark{background:var(--ng-dark);color:#c9cfe2}
.ng-section--dark h1,.ng-section--dark h2,.ng-section--dark h3{color:#fff}
.ng-section--dark p{color:#a8b0c8}
/* compat: alcune sezioni dei template usano questa classe */
.ng-section--light{background:var(--ng-bg)}

.ng-eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--ng-font-head);font-size:.78rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--ng-primary);margin-bottom:18px;
}
.ng-eyebrow::before{content:"";width:24px;height:2px;background:var(--ng-grad);border-radius:2px}
.ng-section--dark .ng-eyebrow{color:#9fb0ff}

.ng-head{max-width:680px;margin-bottom:54px}
.ng-head--center{margin-left:auto;margin-right:auto;text-align:center}
.ng-head p{margin-top:16px;font-size:1.07rem;color:var(--ng-text-soft)}

/* ============================================================
   4. BUTTONS
   ============================================================ */
.ng-btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--ng-font-head);font-weight:600;font-size:.95rem;
  padding:14px 28px;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s var(--ng-ease),box-shadow .25s var(--ng-ease),background .2s,color .2s,border-color .2s;
}
.ng-btn--primary{background:var(--ng-grad);color:#fff;box-shadow:0 14px 28px -12px rgba(37,66,245,.6)}
.ng-btn--primary:hover{transform:translateY(-3px);box-shadow:0 22px 40px -14px rgba(37,66,245,.65)}
.ng-btn--ghost{background:transparent;color:var(--ng-ink);border-color:var(--ng-border)}
.ng-btn--ghost:hover{border-color:var(--ng-primary);color:var(--ng-primary)}
.ng-btn--light{background:#fff;color:var(--ng-ink)}
.ng-btn--light:hover{transform:translateY(-3px);box-shadow:var(--ng-shadow-sm)}
.ng-btn--ondark{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.18)}
.ng-btn--ondark:hover{background:rgba(255,255,255,.14)}
.ng-btn svg{width:18px;height:18px}

/* ============================================================
   5. HEADER / NAV
   ============================================================ */
.ng-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s;
}
.ng-header.is-stuck{border-bottom-color:var(--ng-border);box-shadow:0 8px 30px -20px rgba(20,30,80,.4)}
.ng-header__inner{display:flex;align-items:center;justify-content:space-between;height:78px}
.ng-logo{display:flex;align-items:center;gap:11px;font-family:var(--ng-font-head);font-weight:800;font-size:1.22rem;color:var(--ng-ink)}
.ng-logo__mark{
  width:38px;height:38px;border-radius:11px;background:var(--ng-grad);
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:1.1rem;
  box-shadow:0 8px 18px -6px rgba(37,66,245,.55);
}
.ng-logo span b{background:var(--ng-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.ng-nav{display:flex;align-items:center;gap:34px}
.ng-nav ul{display:flex;gap:30px}
.ng-nav a{font-size:.95rem;font-weight:500;color:var(--ng-text);position:relative}
.ng-nav a:hover,.ng-nav .current-menu-item>a{color:var(--ng-ink)}
.ng-nav .current-menu-item>a::after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:2px;background:var(--ng-grad);border-radius:2px}
.ng-header__cta{display:flex;align-items:center;gap:14px}
.ng-burger{display:none;background:none;border:0;width:44px;height:44px;cursor:pointer;flex-direction:column;gap:5px;justify-content:center;align-items:center}
.ng-burger span{width:24px;height:2px;background:var(--ng-ink);border-radius:2px;transition:.3s var(--ng-ease)}
.ng-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ng-burger.is-open span:nth-child(2){opacity:0}
.ng-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   6. HERO
   ============================================================ */
.ng-hero{
  position:relative;padding:158px 0 96px;overflow:hidden;
  background:
    radial-gradient(680px 420px at 86% 4%,rgba(123,63,242,.12),transparent 62%),
    radial-gradient(620px 420px at 4% 88%,rgba(37,66,245,.1),transparent 60%),
    var(--ng-bg);
}
.ng-hero__grid{
  position:absolute;inset:0;opacity:.55;
  background-image:linear-gradient(var(--ng-border) 1px,transparent 1px),
                   linear-gradient(90deg,var(--ng-border) 1px,transparent 1px);
  background-size:62px 62px;
  -webkit-mask-image:radial-gradient(circle at 60% 35%,#000,transparent 72%);
          mask-image:radial-gradient(circle at 60% 35%,#000,transparent 72%);
}
.ng-hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.ng-hero__badge{
  display:inline-flex;align-items:center;gap:9px;padding:7px 15px;
  border:1px solid var(--ng-border);border-radius:999px;background:#fff;
  font-size:.82rem;font-weight:500;color:var(--ng-text-soft);margin-bottom:24px;
  box-shadow:var(--ng-shadow-sm);
}
.ng-hero__badge i{width:8px;height:8px;border-radius:50%;background:var(--ng-primary);box-shadow:0 0 0 4px rgba(37,66,245,.16)}
.ng-hero h1{margin-bottom:20px}
.ng-hero h1 em{font-style:normal;background:var(--ng-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.ng-hero__lead{font-size:1.12rem;max-width:520px;margin-bottom:32px;color:var(--ng-text-soft)}
.ng-hero__actions{display:flex;gap:13px;flex-wrap:wrap}
.ng-hero__stats{display:flex;gap:36px;margin-top:46px;flex-wrap:wrap}
.ng-hero__stat strong{display:block;font-family:var(--ng-font-head);font-size:2rem;font-weight:800;color:var(--ng-ink)}
.ng-hero__stat span{font-size:.84rem;color:var(--ng-text-dim)}

.ng-hero__visual{position:relative}
.ng-hero__panel{
  background:#fff;border:1px solid var(--ng-border);border-radius:22px;padding:22px;
  box-shadow:var(--ng-shadow);
}
.ng-hero__screen{
  border-radius:14px;overflow:hidden;background:#0c1024;
  aspect-ratio:16/10;position:relative;display:grid;place-items:center;
}
.ng-hero__screen::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(360px 200px at 50% 28%,rgba(123,63,242,.34),transparent 70%);
}
.ng-hero__feed{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:80%;position:relative}
.ng-hero__feed div{aspect-ratio:1;border-radius:7px;background:#1b2147;border:1px solid rgba(255,255,255,.06)}
.ng-hero__feed div:nth-child(2){background:var(--ng-grad)}
.ng-hero__feed div:nth-child(5){background:linear-gradient(135deg,#7b3ff2,#b07bff)}
.ng-hero__rec{
  position:absolute;top:13px;left:13px;display:flex;align-items:center;gap:7px;
  font-size:.68rem;font-weight:700;color:#fff;font-family:var(--ng-font-head);letter-spacing:.12em;
}
.ng-hero__rec i{width:8px;height:8px;border-radius:50%;background:#ff4d6a;animation:ngpulse 1.6s infinite}
@keyframes ngpulse{0%,100%{opacity:1}50%{opacity:.25}}
.ng-hero__chips{display:flex;gap:9px;margin-top:16px}
.ng-hero__chip{
  flex:1;background:var(--ng-bg-soft);border:1px solid var(--ng-border);
  border-radius:11px;padding:12px;text-align:center;
}
.ng-hero__chip strong{display:block;font-family:var(--ng-font-head);color:var(--ng-ink);font-size:1.05rem}
.ng-hero__chip span{font-size:.72rem;color:var(--ng-text-dim)}
.ng-hero__float{
  position:absolute;background:#fff;border:1px solid var(--ng-border);
  border-radius:13px;padding:13px 17px;box-shadow:var(--ng-shadow-card);
  display:flex;align-items:center;gap:12px;
}
.ng-hero__float--1{top:-22px;right:-16px}
.ng-hero__float--2{bottom:-22px;left:-20px}
.ng-hero__float .ic{width:36px;height:36px;border-radius:9px;background:var(--ng-soft);display:grid;place-items:center;color:var(--ng-primary)}
.ng-hero__float .ic svg{width:18px;height:18px}
.ng-hero__float small{display:block;font-size:.7rem;color:var(--ng-text-dim)}
.ng-hero__float b{font-family:var(--ng-font-head);color:var(--ng-ink);font-size:.88rem}

/* ============================================================
   7. LOGO / TRUST STRIP
   ============================================================ */
.ng-strip{border-top:1px solid var(--ng-border);background:var(--ng-bg)}
.ng-strip__inner{display:flex;align-items:center;gap:40px;padding:30px 0;flex-wrap:wrap;justify-content:center}
.ng-strip p{font-size:.78rem;text-transform:uppercase;letter-spacing:.13em;color:var(--ng-text-dim);font-weight:600}
.ng-strip ul{display:flex;gap:36px;flex-wrap:wrap;justify-content:center}
.ng-strip li{font-family:var(--ng-font-head);font-weight:700;font-size:1.02rem;color:#b3bacb}

/* ============================================================
   8. CARDS / SERVICE GRID
   ============================================================ */
.ng-grid{display:grid;gap:24px}
.ng-grid--3{grid-template-columns:repeat(3,1fr)}
.ng-grid--2{grid-template-columns:repeat(2,1fr)}
.ng-grid--4{grid-template-columns:repeat(4,1fr)}

.ng-card{
  background:#fff;border:1px solid var(--ng-border);border-radius:var(--ng-radius);
  padding:32px 30px;transition:transform .3s var(--ng-ease),border-color .3s,box-shadow .3s;
  position:relative;overflow:hidden;
}
.ng-card::after{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--ng-grad);transition:width .35s var(--ng-ease)}
.ng-card:hover{transform:translateY(-7px);border-color:transparent;box-shadow:var(--ng-shadow-card)}
.ng-card:hover::after{width:100%}
.ng-card__num{font-family:var(--ng-font-head);font-weight:800;font-size:.82rem;color:var(--ng-primary);letter-spacing:.08em;margin-bottom:14px;display:block}
.ng-card__ic{
  width:56px;height:56px;border-radius:14px;background:var(--ng-soft);
  display:grid;place-items:center;color:var(--ng-primary);margin-bottom:20px;
}
.ng-card__ic svg{width:28px;height:28px}
.ng-card h3{margin-bottom:11px;color:var(--ng-ink)}
.ng-card p{font-size:.95rem;margin-bottom:16px;color:var(--ng-text-soft)}
.ng-card__link{font-family:var(--ng-font-head);font-weight:600;font-size:.88rem;color:var(--ng-primary);display:inline-flex;align-items:center;gap:7px}
.ng-card__link svg{width:15px;height:15px;transition:transform .25s}
.ng-card:hover .ng-card__link svg{transform:translateX(4px)}
/* compat */
.ng-card--light{background:#fff}
.ng-section--alt .ng-card{background:#fff}

/* ============================================================
   9. FEATURE SPLIT
   ============================================================ */
.ng-split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.ng-split--rev .ng-split__media{order:2}
.ng-split__media{
  border-radius:20px;border:1px solid var(--ng-border);background:#fff;
  padding:28px;box-shadow:var(--ng-shadow-card);
}
.ng-section--dark .ng-split__media{background:var(--ng-dark-2);border-color:var(--ng-border-dark)}
.ng-checklist{margin-top:24px;display:grid;gap:13px}
.ng-checklist li{display:flex;gap:13px;align-items:flex-start;color:var(--ng-text-soft)}
.ng-checklist .ck{
  width:24px;height:24px;border-radius:7px;background:var(--ng-soft);
  color:var(--ng-primary);display:grid;place-items:center;flex:none;margin-top:3px;
}
.ng-checklist .ck svg{width:14px;height:14px}
.ng-checklist b{color:var(--ng-ink);font-family:var(--ng-font-head);font-weight:600}
.ng-section--dark .ng-checklist b{color:#fff}
.ng-section--dark .ng-checklist li{color:#a8b0c8}
.ng-section--dark .ng-checklist .ck{background:rgba(255,255,255,.08);color:#9fb0ff}

.ng-gear{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.ng-gear__item{background:var(--ng-bg-soft);border:1px solid var(--ng-border);border-radius:13px;padding:18px}
.ng-section--dark .ng-gear__item{background:var(--ng-dark);border-color:var(--ng-border-dark)}
.ng-gear__item .ic{width:42px;height:42px;border-radius:11px;background:var(--ng-grad);display:grid;place-items:center;color:#fff;margin-bottom:12px}
.ng-gear__item .ic svg{width:20px;height:20px}
.ng-gear__item b{font-family:var(--ng-font-head);color:var(--ng-ink);font-size:.95rem;display:block;margin-bottom:3px}
.ng-gear__item span{font-size:.82rem;color:var(--ng-text-dim)}
.ng-section--dark .ng-gear__item b{color:#fff}

/* ============================================================
   10. STATS BAND
   ============================================================ */
.ng-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.ng-stat{text-align:center;padding:32px 18px;border:1px solid var(--ng-border);border-radius:var(--ng-radius);background:#fff}
.ng-section--alt .ng-stat{background:#fff}
.ng-section--dark .ng-stat{background:var(--ng-dark-2);border-color:var(--ng-border-dark)}
.ng-stat strong{display:block;font-family:var(--ng-font-head);font-size:2.7rem;font-weight:800;background:var(--ng-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.ng-stat span{font-size:.92rem;color:var(--ng-text-soft)}
.ng-section--dark .ng-stat span{color:#a8b0c8}

/* ============================================================
   11. PROCESS STEPS
   ============================================================ */
.ng-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.ng-step{position:relative;padding-top:16px}
.ng-step::before{
  counter-increment:step;content:"0" counter(step);
  font-family:var(--ng-font-head);font-weight:800;font-size:2.6rem;
  color:transparent;-webkit-text-stroke:1.5px rgba(37,66,245,.32);display:block;margin-bottom:12px;
}
.ng-step h3{font-size:1.1rem;margin-bottom:8px;color:var(--ng-ink)}
.ng-step p{font-size:.92rem;color:var(--ng-text-soft)}
.ng-section--dark .ng-step::before{-webkit-text-stroke-color:rgba(159,176,255,.5)}

/* ============================================================
   12. PORTFOLIO / EVENTS
   ============================================================ */
.ng-folio{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.ng-folio__item{
  position:relative;border-radius:var(--ng-radius);overflow:hidden;
  min-height:316px;display:flex;flex-direction:column;justify-content:flex-end;
  padding:32px;color:#fff;isolation:isolate;
  transition:transform .35s var(--ng-ease),box-shadow .35s;
  box-shadow:var(--ng-shadow-card);
}
.ng-folio__item::before{content:"";position:absolute;inset:0;z-index:-2;background:linear-gradient(135deg,#1c2350,#0c1024)}
.ng-folio__item::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 28%,rgba(8,10,24,.92))}
.ng-folio__item:nth-child(1)::before{background:linear-gradient(135deg,#2a3170,#10142e)}
.ng-folio__item:nth-child(2)::before{background:linear-gradient(135deg,#3a2670,#160f2e)}
.ng-folio__item:nth-child(3)::before{background:linear-gradient(135deg,#1d3a6e,#0c1730)}
.ng-folio__item:nth-child(4)::before{background:linear-gradient(135deg,#4a2a64,#1a0f24)}
.ng-folio__item:nth-child(5)::before{background:linear-gradient(135deg,#243a66,#0d1426)}
.ng-folio__item:nth-child(6)::before{background:linear-gradient(135deg,#33276c,#13102c)}
.ng-folio__item:hover{transform:translateY(-6px);box-shadow:var(--ng-shadow)}
.ng-folio__tag{
  align-self:flex-start;font-size:.71rem;font-family:var(--ng-font-head);font-weight:700;
  letter-spacing:.09em;text-transform:uppercase;padding:6px 13px;border-radius:999px;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);margin-bottom:14px;
}
.ng-folio__item h3{font-size:1.38rem;margin-bottom:8px;color:#fff}
.ng-folio__item p{color:rgba(255,255,255,.74);font-size:.92rem}
.ng-folio__meta{display:flex;gap:18px;margin-top:16px;font-size:.8rem;color:rgba(255,255,255,.62)}
.ng-folio__meta span{display:flex;align-items:center;gap:6px}
.ng-folio__meta svg{width:15px;height:15px}

/* ============================================================
   13. TESTIMONIALS
   ============================================================ */
.ng-quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ng-quote{background:#fff;border:1px solid var(--ng-border);border-radius:var(--ng-radius);padding:32px;box-shadow:var(--ng-shadow-sm)}
.ng-quote__stars{color:#f6a609;letter-spacing:3px;margin-bottom:14px;font-size:.95rem}
.ng-quote p{color:var(--ng-ink);font-size:.98rem;margin-bottom:22px}
.ng-quote__who{display:flex;align-items:center;gap:13px}
.ng-quote__av{width:46px;height:46px;border-radius:50%;background:var(--ng-grad);display:grid;place-items:center;color:#fff;font-family:var(--ng-font-head);font-weight:700}
.ng-quote__who b{display:block;font-family:var(--ng-font-head);color:var(--ng-ink);font-size:.92rem}
.ng-quote__who span{font-size:.8rem;color:var(--ng-text-dim)}

/* ============================================================
   14. CTA
   ============================================================ */
.ng-cta{
  position:relative;border-radius:26px;overflow:hidden;padding:68px 56px;
  background:radial-gradient(560px 300px at 84% 16%,rgba(123,63,242,.55),transparent 62%),
             linear-gradient(125deg,#2542f5,#1a31c7);
  text-align:center;color:#fff;
}
.ng-cta .ng-eyebrow{color:#cdd6ff}
.ng-cta h2{margin-bottom:14px;color:#fff}
.ng-cta p{font-size:1.06rem;max-width:560px;margin:0 auto 28px;color:rgba(255,255,255,.88)}
.ng-cta__actions{display:flex;gap:13px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   15. PAGE HERO (inner pages)
   ============================================================ */
.ng-phero{
  padding:148px 0 64px;position:relative;overflow:hidden;
  background:radial-gradient(620px 320px at 78% 0%,rgba(123,63,242,.12),transparent 64%),var(--ng-bg-soft);
  border-bottom:1px solid var(--ng-border);
}
.ng-phero__crumb{font-size:.84rem;color:var(--ng-text-dim);margin-bottom:14px}
.ng-phero__crumb a:hover{color:var(--ng-primary)}
.ng-phero h1{margin-bottom:14px}
.ng-phero p{max-width:620px;font-size:1.06rem;color:var(--ng-text-soft)}

/* ============================================================
   16. CONTACT
   ============================================================ */
.ng-contact{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.ng-contact__info{display:grid;gap:20px}
.ng-contact__row{display:flex;gap:15px;align-items:flex-start}
.ng-contact__row .ic{width:48px;height:48px;border-radius:12px;background:var(--ng-soft);color:var(--ng-primary);display:grid;place-items:center;flex:none}
.ng-contact__row .ic svg{width:22px;height:22px}
.ng-contact__row b{font-family:var(--ng-font-head);color:var(--ng-ink);display:block;margin-bottom:3px}
.ng-contact__row span{font-size:.92rem;color:var(--ng-text-soft)}
.ng-contact__row a:hover{color:var(--ng-primary)}
.ng-formwrap{background:#fff;border:1px solid var(--ng-border);border-radius:var(--ng-radius);padding:38px;box-shadow:var(--ng-shadow-card)}
.ng-formwrap h3{margin-bottom:6px;color:var(--ng-ink)}
.ng-formwrap>p{font-size:.92rem;margin-bottom:22px;color:var(--ng-text-soft)}
.ng-form{display:grid;gap:15px}
.ng-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.ng-form p{margin:0}
.ng-form label{font-size:.84rem;font-family:var(--ng-font-head);font-weight:600;color:var(--ng-ink);display:block}
.ng-form input,.ng-form select,.ng-form textarea{
  width:100%;background:var(--ng-bg-soft);border:1px solid var(--ng-border);
  border-radius:10px;padding:13px 15px;color:var(--ng-ink);font-family:var(--ng-font-body);font-size:.94rem;
  margin-top:7px;transition:border-color .2s,background .2s;
}
.ng-form input:focus,.ng-form select:focus,.ng-form textarea:focus{outline:0;border-color:var(--ng-primary);background:#fff}
.ng-form textarea{min-height:128px;resize:vertical}
.ng-form .wpcf7-form-control-wrap{display:block}
.ng-form input[type=submit],.ng-form .wpcf7-submit{
  background:var(--ng-grad);color:#fff;border:0;border-radius:999px;width:auto;
  padding:14px 30px;font-family:var(--ng-font-head);font-weight:600;cursor:pointer;margin-top:4px;
  transition:transform .25s var(--ng-ease);
}
.ng-form input[type=submit]:hover,.ng-form .wpcf7-submit:hover{transform:translateY(-3px)}
.ng-form .wpcf7-spinner{margin:14px auto 0}
.wpcf7 .wpcf7-response-output{border-radius:10px;margin:18px 0 0;font-size:.9rem}
.ng-map{border-radius:var(--ng-radius);overflow:hidden;border:1px solid var(--ng-border);margin-top:4px}
.ng-map iframe{width:100%;height:290px;border:0;display:block}

/* ============================================================
   17. BLOG
   ============================================================ */
.ng-posts{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.ng-post{
  background:#fff;border:1px solid var(--ng-border);border-radius:var(--ng-radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .3s var(--ng-ease),box-shadow .3s;
}
.ng-post:hover{transform:translateY(-6px);box-shadow:var(--ng-shadow-card)}
.ng-post__thumb{aspect-ratio:16/10;background:linear-gradient(135deg,#2a3170,#10142e);position:relative;overflow:hidden;display:block}
.ng-post__thumb img{width:100%;height:100%;object-fit:cover}
.ng-post__cat{position:absolute;top:13px;left:13px;font-size:.71rem;font-family:var(--ng-font-head);font-weight:700;padding:5px 12px;border-radius:999px;background:#fff;color:var(--ng-primary)}
.ng-post__body{padding:24px;display:flex;flex-direction:column;flex:1}
.ng-post__date{font-size:.78rem;color:var(--ng-text-dim);margin-bottom:9px}
.ng-post__body h3{font-size:1.1rem;margin-bottom:10px;color:var(--ng-ink)}
.ng-post__body h3 a:hover{color:var(--ng-primary)}
.ng-post__body p{font-size:.91rem;margin-bottom:16px;flex:1;color:var(--ng-text-soft)}
.ng-post__more{font-family:var(--ng-font-head);font-weight:600;font-size:.85rem;color:var(--ng-primary);display:inline-flex;align-items:center;gap:6px}
.ng-post__more svg{width:15px;height:15px}

.ng-single{max-width:780px;margin:0 auto}
.ng-single__content{margin-top:26px}
.ng-single__content p{margin-bottom:18px;color:var(--ng-text)}
.ng-single__content h2,.ng-single__content h3{margin:30px 0 14px;color:var(--ng-ink)}
.ng-single__content img{border-radius:12px;margin:22px 0}
.ng-single__content a{color:var(--ng-primary);text-decoration:underline}
.ng-single__content ul,.ng-single__content ol{margin:0 0 18px 22px;color:var(--ng-text)}
.ng-single__content blockquote{border-left:3px solid var(--ng-primary);padding-left:20px;margin:22px 0;font-style:italic;color:var(--ng-ink)}

.ng-pagination{display:flex;gap:8px;justify-content:center;margin-top:48px}
.ng-pagination a,.ng-pagination span{
  display:grid;place-items:center;min-width:44px;height:44px;padding:0 12px;
  border:1px solid var(--ng-border);border-radius:10px;background:#fff;
  font-family:var(--ng-font-head);font-weight:600;font-size:.9rem;color:var(--ng-ink);
}
.ng-pagination .current{background:var(--ng-grad);color:#fff;border-color:transparent}
.ng-pagination a:hover{border-color:var(--ng-primary);color:var(--ng-primary)}

/* ============================================================
   18. FAQ
   ============================================================ */
.ng-faq{display:grid;gap:13px;max-width:820px;margin:0 auto}
.ng-faq__item{background:#fff;border:1px solid var(--ng-border);border-radius:13px;overflow:hidden}
.ng-faq__q{
  width:100%;text-align:left;background:none;border:0;cursor:pointer;
  padding:22px 24px;font-family:var(--ng-font-head);font-weight:600;color:var(--ng-ink);font-size:1rem;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.ng-faq__q span{flex:none;width:26px;height:26px;border-radius:7px;background:var(--ng-soft);color:var(--ng-primary);display:grid;place-items:center;transition:transform .3s}
.ng-faq__q span svg{width:14px;height:14px}
.ng-faq__item.is-open .ng-faq__q span{transform:rotate(45deg)}
.ng-faq__a{max-height:0;overflow:hidden;transition:max-height .35s var(--ng-ease)}
.ng-faq__a p{padding:0 24px 22px;font-size:.94rem;color:var(--ng-text-soft)}

/* ============================================================
   19. FOOTER (dark)
   ============================================================ */
.ng-footer{background:var(--ng-dark);color:#aab2c8;padding:70px 0 28px}
.ng-footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:44px;border-bottom:1px solid var(--ng-border-dark)}
.ng-footer .ng-logo{color:#fff}
.ng-footer .ng-logo span b{-webkit-text-fill-color:#9fb0ff}
.ng-footer__brand p{font-size:.92rem;margin:18px 0 22px;max-width:300px;color:#9aa3bd}
.ng-footer h4{font-family:var(--ng-font-head);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:#6d7691;margin-bottom:18px}
.ng-footer__col ul{display:grid;gap:11px}
.ng-footer__col a{font-size:.92rem;color:#aab2c8}
.ng-footer__col a:hover{color:#fff}
.ng-footer__news input{width:100%;background:var(--ng-dark-2);border:1px solid var(--ng-border-dark);border-radius:10px;padding:12px 14px;color:#fff;margin-bottom:10px}
.ng-socials{display:flex;gap:10px;margin-top:18px}
.ng-socials a{width:38px;height:38px;border-radius:9px;border:1px solid var(--ng-border-dark);display:grid;place-items:center;color:#aab2c8}
.ng-socials a:hover{border-color:transparent;background:var(--ng-grad);color:#fff}
.ng-socials svg{width:17px;height:17px}
.ng-footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;gap:20px;flex-wrap:wrap}
.ng-footer__bottom p{font-size:.85rem;color:#6d7691}
.ng-footer__bottom ul{display:flex;gap:22px}
.ng-footer__bottom a{font-size:.85rem;color:#6d7691}
.ng-footer__bottom a:hover{color:#fff}

/* ============================================================
   20. REVEAL ANIMATION
   ============================================================ */
.ng-reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ng-ease),transform .7s var(--ng-ease)}
.ng-reveal.is-in{opacity:1;transform:none}
.ng-reveal[data-d="1"]{transition-delay:.08s}
.ng-reveal[data-d="2"]{transition-delay:.16s}
.ng-reveal[data-d="3"]{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){.ng-reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   21. RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .ng-hero__inner,.ng-split,.ng-contact{grid-template-columns:1fr}
  .ng-split--rev .ng-split__media{order:0}
  .ng-grid--4,.ng-stats,.ng-steps{grid-template-columns:repeat(2,1fr)}
  .ng-grid--3,.ng-quotes,.ng-posts{grid-template-columns:repeat(2,1fr)}
  .ng-footer__top{grid-template-columns:1fr 1fr}
  .ng-hero__visual{max-width:470px;margin:0 auto}
}
@media(max-width:768px){
  .ng-section{padding:70px 0}
  .ng-hero{padding:128px 0 70px}
  .ng-nav{
    position:fixed;top:78px;left:0;right:0;background:#fff;
    flex-direction:column;align-items:flex-start;gap:0;padding:16px 24px 26px;
    border-bottom:1px solid var(--ng-border);box-shadow:var(--ng-shadow-sm);
    transform:translateY(-135%);transition:transform .35s var(--ng-ease);
    max-height:calc(100vh - 78px);overflow-y:auto;
  }
  .ng-nav.is-open{transform:translateY(0)}
  .ng-nav ul{flex-direction:column;gap:0;width:100%}
  .ng-nav li{width:100%;border-bottom:1px solid var(--ng-border)}
  .ng-nav a{display:block;padding:14px 0;width:100%}
  .ng-burger{display:flex}
  .ng-header__cta .ng-btn{display:none}
  .ng-grid--3,.ng-grid--2,.ng-grid--4,.ng-stats,.ng-steps,.ng-quotes,.ng-folio,.ng-posts,.ng-footer__top{grid-template-columns:1fr}
  .ng-cta{padding:48px 26px}
  .ng-hero__float{display:none}
  .ng-form .row2{grid-template-columns:1fr}
  .ng-footer__bottom{flex-direction:column;text-align:center}
}
