/*
Theme Name: Nissi Group SA
Theme URI: https://www.nissigroupsa.co.za
Author: Nissi Group of Companies
Author URI: https://www.nissigroupsa.co.za
Description: Premium custom theme for Nissi Staffing Solutions (Pty) Ltd — a modern South African staffing, logistics, warehousing and workforce solutions company. Includes Tools / Staff Portal login gate, Calibri-uniform typography, animated sections, and full enterprise page set.
Version: 4.1.7
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: nissi
Tags: business, corporate, custom-logo, custom-menu, featured-images, full-width-template, theme-options, threaded-comments, translation-ready
*/

/* =========================================================
   NISSI GROUP — DESIGN SYSTEM
   Calibri uniform typography. Carlito = free metric-compatible
   fallback so visitors without Calibri see identical metrics.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Carlito:ital,wght@0,400;0,700;1,400;1,700&display=swap');

:root{
  --nissi-orange:#F26B1F;
  --nissi-orange-soft:#ff8a3d;
  --nissi-blue:#1E63B0;
  --nissi-blue-deep:#0E2A4A;
  --nissi-blue-light:#3A8DD8;
  --nissi-silver:#C9CFD6;
  --nissi-ink:#0B1422;
  --nissi-ink-soft:#1a2638;
  --nissi-muted:#5a6675;
  --nissi-bg:#ffffff;
  --nissi-bg-alt:#f6f8fb;
  --nissi-border:#e4e8ee;
  --nissi-radius:14px;
  --nissi-shadow-sm:0 4px 14px -6px rgba(14,42,74,.18);
  --nissi-shadow:0 18px 48px -22px rgba(14,42,74,.35);
  --nissi-shadow-lg:0 30px 80px -30px rgba(14,42,74,.45);
  --nissi-grad:linear-gradient(135deg,var(--nissi-blue) 0%, var(--nissi-blue-light) 50%, var(--nissi-orange) 110%);
  --nissi-grad-dark:linear-gradient(135deg,#0a1d36 0%, #133b6e 60%, #1E63B0 100%);
  --nissi-max:1240px;
  --nissi-font:'Calibri','Carlito','Segoe UI',Tahoma,Geneva,Verdana,sans-serif;
  --nissi-ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body.nissi-body{
  margin:0;
  font-family:var(--nissi-font);
  font-size:17px;
  line-height:1.6;
  color:var(--nissi-ink);
  background:var(--nissi-bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body, button, input, select, textarea, h1, h2, h3, h4, h5, h6, p, li, a, span, div{
  font-family:var(--nissi-font) !important;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--nissi-blue);text-decoration:none;transition:color .25s var(--nissi-ease)}
a:hover{color:var(--nissi-orange)}

h1,h2,h3,h4,h5,h6{
  font-family:var(--nissi-font);
  color:var(--nissi-ink);
  line-height:1.15;
  letter-spacing:-.01em;
  margin:0 0 .6em;
  font-weight:700;
}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.7rem,3.2vw,2.6rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin:0 0 1em}

.nissi-container{max-width:var(--nissi-max);margin:0 auto;padding:0 22px}
.nissi-section{padding:96px 0;position:relative}
.nissi-section--alt{background:var(--nissi-bg-alt)}
.nissi-section--dark{background:var(--nissi-grad-dark);color:#fff}
.nissi-section--dark h1,.nissi-section--dark h2,.nissi-section--dark h3{color:#fff}
.nissi-section--dark p{color:#cbd6e6}

.nissi-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--nissi-orange);margin-bottom:14px;
}
.nissi-eyebrow::before{content:"";width:28px;height:2px;background:var(--nissi-orange);display:inline-block}
.nissi-section--dark .nissi-eyebrow{color:var(--nissi-orange-soft)}

.nissi-lead{font-size:1.15rem;color:var(--nissi-muted);max-width:680px}
.nissi-section--dark .nissi-lead{color:#b9c5d8}

/* ------- Buttons ------- */
.nissi-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 26px;border-radius:999px;font-weight:700;font-size:15px;
  letter-spacing:.02em;cursor:pointer;border:0;
  transition:transform .25s var(--nissi-ease),box-shadow .25s var(--nissi-ease),background .25s var(--nissi-ease);
}
.nissi-btn--primary{background:var(--nissi-orange);color:#fff;box-shadow:0 12px 30px -10px rgba(242,107,31,.55)}
.nissi-btn--primary:hover{background:#e35d12;transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(242,107,31,.7);color:#fff}
.nissi-btn--ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45)}
.nissi-btn--ghost:hover{background:rgba(255,255,255,.1);color:#fff;transform:translateY(-2px)}
.nissi-btn--dark{background:var(--nissi-blue-deep);color:#fff}
.nissi-btn--dark:hover{background:#0a1d36;color:#fff;transform:translateY(-2px)}

/* ============== HEADER ============== */
.nissi-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(228,232,238,.7);
  transition:box-shadow .3s var(--nissi-ease);
}
.nissi-header.is-scrolled{box-shadow:0 6px 24px -10px rgba(14,42,74,.18)}
.nissi-header__inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;max-width:var(--nissi-max);margin:0 auto;gap:24px;
}
.nissi-logo{display:flex;align-items:center;gap:12px;flex-shrink:0;max-width:38vw}
.nissi-logo img{display:block;height:clamp(40px,6vw,58px);width:auto;max-width:100%;object-fit:contain;image-rendering:auto}
.nissi-nav{display:flex;align-items:center;gap:6px}
.nissi-nav a{
  position:relative;padding:10px 14px;border-radius:8px;
  font-weight:600;font-size:15px;color:var(--nissi-ink);
}
.nissi-nav a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:6px;height:2px;
  background:var(--nissi-orange);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--nissi-ease);
}
.nissi-nav a:hover{color:var(--nissi-blue)}
.nissi-nav a:hover::after,.nissi-nav a.is-active::after{transform:scaleX(1)}
.nissi-nav a.is-active{color:var(--nissi-blue)}
.nissi-header__cta{display:flex;align-items:center;gap:8px}
.nissi-header__portal{
  font-size:13px;font-weight:700;color:#fff;background:var(--nissi-blue-deep);
  border:1.5px solid var(--nissi-blue-deep);padding:9px 18px;border-radius:999px;
  letter-spacing:.01em;transition:background .2s var(--nissi-ease),transform .2s var(--nissi-ease);
}
.nissi-header__portal:hover{background:var(--nissi-blue);border-color:var(--nissi-blue);color:#fff;transform:translateY(-1px)}

.nissi-burger{display:none;background:none;border:0;width:42px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.nissi-burger span{display:block;width:22px;height:2px;background:var(--nissi-ink);position:relative}
.nissi-burger span::before,.nissi-burger span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--nissi-ink);transition:transform .3s var(--nissi-ease)}
.nissi-burger span::before{top:-7px}
.nissi-burger span::after{top:7px}

/* ============== HERO ============== */
.nissi-hero{
  position:relative;min-height:88vh;display:flex;align-items:center;
  color:#fff;overflow:hidden;isolation:isolate;
}
.nissi-hero__bg{position:absolute;inset:0;z-index:-2}
.nissi-hero__bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);animation:nissiKenBurns 18s ease-in-out infinite alternate}
.nissi-hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,29,54,.92) 0%, rgba(14,42,74,.78) 45%, rgba(14,42,74,.35) 100%)}
@keyframes nissiKenBurns{from{transform:scale(1.05) translateX(0)}to{transform:scale(1.12) translateX(-2%)}}

.nissi-hero__inner{padding:140px 0 120px;max-width:880px}
.nissi-hero h1{color:#fff;font-size:clamp(2.4rem,5.4vw,4.2rem);margin-bottom:.4em}
.nissi-hero h1 span{color:var(--nissi-orange-soft);display:inline-block}
.nissi-hero p{font-size:1.15rem;color:#d6deeb;max-width:620px;margin-bottom:2em}
.nissi-hero__actions{display:flex;flex-wrap:wrap;gap:14px}
.nissi-hero__badges{
  display:flex;flex-wrap:wrap;gap:18px;margin-top:54px;
  padding-top:30px;border-top:1px solid rgba(255,255,255,.15);
}
.nissi-hero__badge{display:flex;align-items:center;gap:10px;color:#cbd6e6;font-size:14px;font-weight:600}
.nissi-hero__badge strong{color:#fff;font-size:20px;line-height:1}
.nissi-hero__badge .dot{width:8px;height:8px;border-radius:50%;background:var(--nissi-orange);box-shadow:0 0 0 4px rgba(242,107,31,.25)}

.nissi-scroll-cue{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);color:#fff;opacity:.6;font-size:12px;letter-spacing:.2em}
.nissi-scroll-cue::after{content:"";display:block;width:1px;height:36px;background:#fff;margin:8px auto 0;animation:nissiCue 2s ease-in-out infinite}
@keyframes nissiCue{0%,100%{transform:scaleY(.4);opacity:.2}50%{transform:scaleY(1);opacity:.8}}

/* ============== TRUST BAR ============== */
.nissi-trustbar{
  background:#fff;border-bottom:1px solid var(--nissi-border);
}
.nissi-trustbar__inner{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  max-width:var(--nissi-max);margin:0 auto;
}
.nissi-trustbar__item{padding:28px 22px;text-align:center;border-right:1px solid var(--nissi-border)}
.nissi-trustbar__item:last-child{border-right:0}
.nissi-trustbar__item strong{display:block;font-size:1.8rem;color:var(--nissi-blue-deep);font-weight:700}
.nissi-trustbar__item span{display:block;font-size:13px;color:var(--nissi-muted);text-transform:uppercase;letter-spacing:.12em;margin-top:4px}

/* ============== SECTION HEADERS ============== */
.nissi-section__head{max-width:760px;margin:0 auto 60px;text-align:center}
.nissi-section__head .nissi-eyebrow{justify-content:center}

/* ============== SERVICES GRID ============== */
.nissi-services{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.nissi-service{
  position:relative;padding:32px 28px;background:#fff;
  border:1px solid var(--nissi-border);border-radius:var(--nissi-radius);
  transition:transform .35s var(--nissi-ease),box-shadow .35s var(--nissi-ease),border-color .35s var(--nissi-ease);
  overflow:hidden;
}
.nissi-service::before{
  content:"";position:absolute;inset:0;border-radius:var(--nissi-radius);
  background:var(--nissi-grad);opacity:0;transition:opacity .35s var(--nissi-ease);z-index:0;
}
.nissi-service > *{position:relative;z-index:1}
.nissi-service:hover{transform:translateY(-6px);box-shadow:var(--nissi-shadow);border-color:transparent;color:#fff}
.nissi-service:hover::before{opacity:1}
.nissi-service:hover h3,.nissi-service:hover p,.nissi-service:hover .nissi-service__more{color:#fff}
.nissi-service__icon{
  width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#eaf2fc,#f6f8fb);color:var(--nissi-blue);
  font-size:24px;font-weight:700;margin-bottom:18px;
  transition:background .35s var(--nissi-ease),color .35s var(--nissi-ease);
}
.nissi-service:hover .nissi-service__icon{background:rgba(255,255,255,.18);color:#fff}
.nissi-service h3{font-size:1.2rem;margin-bottom:10px}
.nissi-service p{color:var(--nissi-muted);font-size:15px;margin-bottom:0}
.nissi-service__more{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-weight:700;font-size:14px;color:var(--nissi-blue)}

/* ============== TWO COLUMN ============== */
.nissi-two{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.nissi-two__media{position:relative;border-radius:var(--nissi-radius);overflow:hidden;box-shadow:var(--nissi-shadow-lg)}
.nissi-two__media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--nissi-ease)}
.nissi-two__media:hover img{transform:scale(1.04)}
/* removed orange blush over media */

/* ============== INDUSTRIES ============== */
.nissi-industries{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.nissi-industry{
  padding:28px 22px;border-radius:var(--nissi-radius);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  text-align:left;transition:background .3s var(--nissi-ease),transform .3s var(--nissi-ease);
}
.nissi-industry:hover{background:rgba(255,255,255,.12);transform:translateY(-4px)}
.nissi-industry strong{display:block;color:#fff;font-size:1.05rem;margin-bottom:6px}
.nissi-industry span{color:#a8b6cd;font-size:14px}

/* ============== COMPLIANCE ============== */
.nissi-compliance{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.nissi-comp{
  padding:28px;background:#fff;border-radius:var(--nissi-radius);
  border:1px solid var(--nissi-border);text-align:center;
  transition:transform .3s var(--nissi-ease),box-shadow .3s var(--nissi-ease);
}
.nissi-comp:hover{transform:translateY(-4px);box-shadow:var(--nissi-shadow)}
.nissi-comp__badge{
  width:64px;height:64px;border-radius:50%;margin:0 auto 14px;
  display:flex;align-items:center;justify-content:center;
  background:var(--nissi-grad);color:#fff;font-weight:800;font-size:18px;letter-spacing:.05em;
  box-shadow:0 12px 30px -12px rgba(30,99,176,.5);
}
.nissi-comp h3{font-size:1.05rem;margin-bottom:6px}
.nissi-comp p{font-size:14px;color:var(--nissi-muted);margin-bottom:0}

/* ============== LEADERSHIP ============== */
.nissi-leaders{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.nissi-leader{
  padding:20px;border-radius:var(--nissi-radius);background:#fff;
  border:1px solid var(--nissi-border);transition:transform .3s var(--nissi-ease),box-shadow .3s var(--nissi-ease);
  display:flex;flex-direction:column;gap:14px;
}
.nissi-leader:hover{transform:translateY(-4px);box-shadow:var(--nissi-shadow)}
.nissi-leader__head{display:flex;gap:14px;align-items:center}
.nissi-leader__avatar{
  width:52px;height:52px;border-radius:50%;flex-shrink:0;
  background:var(--nissi-grad);color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:18px;letter-spacing:.05em;
}
.nissi-leader__meta{min-width:0;flex:1}
.nissi-leader h3{font-size:1.05rem;margin-bottom:2px;line-height:1.2}
.nissi-leader__role{font-size:12px;color:var(--nissi-orange);text-transform:uppercase;letter-spacing:.1em;font-weight:700;display:block;line-height:1.3}
.nissi-leader__email{
  display:flex;align-items:center;gap:8px;width:100%;
  padding:10px 14px;border-radius:999px;
  background:rgba(15,76,140,.06);border:1px solid var(--nissi-border);
  color:var(--nissi-blue);font-size:13px;font-weight:600;
  text-decoration:none;word-break:break-all;
  transition:background .2s var(--nissi-ease),color .2s var(--nissi-ease),border-color .2s var(--nissi-ease),transform .2s var(--nissi-ease);
}
.nissi-leader__email:hover,.nissi-leader__email:focus-visible{
  background:var(--nissi-grad);color:#fff;border-color:transparent;transform:translateY(-1px);
}
.nissi-leader__email-icon{flex-shrink:0;font-size:14px;line-height:1}
.nissi-leader__email-text{min-width:0;overflow-wrap:anywhere}

/* ============== CTA ============== */
.nissi-cta{
  background:var(--nissi-grad-dark);color:#fff;border-radius:24px;
  padding:60px 50px;display:flex;align-items:center;justify-content:space-between;gap:40px;
  position:relative;overflow:hidden;
}
.nissi-cta::before{
  content:"";position:absolute;right:-100px;top:-100px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(58,141,216,.28),transparent 70%);
}
.nissi-cta h2{color:#fff;margin-bottom:8px;font-size:2rem}
.nissi-cta p{color:#cbd6e6;margin:0}
.nissi-cta__actions{display:flex;gap:12px;flex-shrink:0;position:relative}

/* ============== FOOTER ============== */
.nissi-footer{
  background:#070d18;color:#a8b6cd;padding:70px 0 24px;font-size:15px;
}
.nissi-footer h4{color:#fff;font-size:1rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:18px}
.nissi-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:50px}
.nissi-footer a{color:#a8b6cd}
.nissi-footer a:hover{color:#fff}
.nissi-footer__brand img{height:60px;margin-bottom:18px;filter:brightness(1.1)}
.nissi-footer__brand p{color:#7e8da3;font-size:14px}
.nissi-footer ul{list-style:none;margin:0;padding:0}
.nissi-footer li{margin-bottom:10px}
.nissi-footer__bottom{
  border-top:1px solid #1a2638;padding-top:22px;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:12px;color:#5a6675;font-size:13px;
}

/* ============== TOOLS PORTAL (login gate) ============== */
.nissi-portal{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--nissi-grad-dark);padding:60px 22px;
  position:relative;overflow:hidden;
}
.nissi-portal::before,.nissi-portal::after{
  content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.45;
}
.nissi-portal::before{background:var(--nissi-blue-light);width:380px;height:380px;top:-120px;right:-120px;opacity:.5}
.nissi-portal::after{background:var(--nissi-blue-light);width:420px;height:420px;bottom:-160px;left:-160px}
.nissi-portal__card{
  position:relative;z-index:2;width:100%;max-width:440px;
  background:rgba(255,255,255,.04);backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.12);border-radius:20px;
  padding:42px 36px;color:#fff;box-shadow:var(--nissi-shadow-lg);
}
.nissi-portal__logo{display:flex;justify-content:center;margin-bottom:20px}
.nissi-portal__logo img{height:60px;filter:brightness(1.05)}
.nissi-portal__card h1{color:#fff;font-size:1.6rem;text-align:center;margin-bottom:6px}
.nissi-portal__sub{color:#b9c5d8;text-align:center;font-size:14px;margin-bottom:30px}
.nissi-field{margin-bottom:16px}
.nissi-field label,.nissi-field > span{display:block;font-size:13px;color:#cbd6e6;font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.1em}
.nissi-field input{
  width:100%;padding:13px 16px;border-radius:10px;font-size:15px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:#fff;
  font-family:var(--nissi-font);transition:border-color .25s var(--nissi-ease),background .25s var(--nissi-ease);
}
.nissi-field input::placeholder{color:#7e8da3}
.nissi-field input:focus{outline:0;border-color:var(--nissi-orange);background:rgba(255,255,255,.12)}
.nissi-portal__submit{
  width:100%;padding:14px;border-radius:10px;background:var(--nissi-orange);color:#fff;
  font-weight:700;border:0;font-size:15px;cursor:pointer;letter-spacing:.02em;
  transition:background .25s var(--nissi-ease),transform .25s var(--nissi-ease);
  margin-top:8px;
}
.nissi-portal__submit:hover{background:#e35d12;transform:translateY(-2px)}
.nissi-portal__hint{margin-top:18px;text-align:center;font-size:13px;color:#7e8da3}
.nissi-portal__hint a{color:#cbd6e6;text-decoration:underline}
.nissi-portal__tools{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:24px;
  padding-top:22px;border-top:1px solid rgba(255,255,255,.1);
}
.nissi-portal__tool{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:12px;font-size:13px;color:#cbd6e6;text-align:center;
}
.nissi-portal__tool strong{display:block;color:#fff;margin-bottom:2px;font-size:13px}

/* ============== GENERIC PAGES ============== */
.nissi-page-hero{
  background:var(--nissi-grad-dark);color:#fff;padding:120px 0 80px;text-align:center;
  position:relative;overflow:hidden;
}
.nissi-page-hero::before{
  content:"";position:absolute;inset:0;background:
    radial-gradient(circle at 80% 70%,rgba(58,141,216,.22),transparent 45%);
}
.nissi-page-hero__inner{position:relative;max-width:760px;margin:0 auto;padding:0 22px}
.nissi-page-hero h1{color:#fff;margin-bottom:14px}
.nissi-page-hero p{color:#cbd6e6;font-size:1.1rem;margin:0}
.nissi-breadcrumb{font-size:13px;color:#a8b6cd;margin-bottom:14px;letter-spacing:.1em;text-transform:uppercase}
.nissi-breadcrumb a{color:#a8b6cd}

.nissi-rich{max-width:820px;margin:0 auto;font-size:1.05rem;color:#3b4859}
.nissi-rich h2{margin-top:1.4em}
.nissi-rich ul{padding-left:1.2em}
.nissi-rich li{margin-bottom:8px}

/* ============== CONTACT ============== */
.nissi-contact{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.nissi-contact__info{background:var(--nissi-bg-alt);border-radius:var(--nissi-radius);padding:36px}
.nissi-contact__info h3{margin-top:1.4em}
.nissi-contact__info h3:first-child{margin-top:0}
.nissi-contact__row{display:flex;gap:14px;margin-bottom:14px;color:var(--nissi-muted)}
.nissi-contact__row strong{color:var(--nissi-ink);min-width:110px;display:inline-block}
.nissi-contact__form{background:#fff;border:1px solid var(--nissi-border);border-radius:var(--nissi-radius);padding:36px}
.nissi-contact__form input,.nissi-contact__form select,.nissi-contact__form textarea{
  width:100%;padding:13px 16px;border-radius:10px;font-size:15px;
  border:1px solid var(--nissi-border);background:#fff;font-family:var(--nissi-font);
  margin-bottom:14px;transition:border-color .25s var(--nissi-ease);
  appearance:none;-webkit-appearance:none;
}
.nissi-contact__form input:focus,.nissi-contact__form select:focus,.nissi-contact__form textarea:focus{outline:0;border-color:var(--nissi-blue)}
.nissi-contact__form select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235a6675' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}
.nissi-contact__form textarea{min-height:140px;resize:vertical}
.nissi-contact__form .nissi-field > span{color:var(--nissi-muted);letter-spacing:.05em;text-transform:none;font-size:14px;font-weight:600}
.nissi-contact__notice{padding:16px 22px;border-radius:12px;margin-bottom:28px;font-size:15px;font-weight:500}
.nissi-contact__notice--success{background:#e8f5ed;border:1px solid #86efac;color:#166534}
.nissi-contact__notice--success strong{color:#14532d}
.nissi-contact__notice--error{background:#fde8eb;border:1px solid #fca5a5;color:#7f1d1d}
.nissi-contact__notice--error strong{color:#7f1d1d}
.nissi-contact__notice--error a{color:#1E63B0}

/* ============== ANIMATIONS ============== */
.nissi-reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--nissi-ease),transform .8s var(--nissi-ease)}
.nissi-reveal.is-visible{opacity:1;transform:translateY(0)}
.nissi-reveal-delay-1{transition-delay:.08s}
.nissi-reveal-delay-2{transition-delay:.16s}
.nissi-reveal-delay-3{transition-delay:.24s}
.nissi-reveal-delay-4{transition-delay:.32s}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
  .nissi-reveal{opacity:1;transform:none}
}

/* ============== RESPONSIVE ============== */
@media (max-width: 1080px){
  .nissi-services,.nissi-leaders{grid-template-columns:repeat(2,1fr)}
  .nissi-industries,.nissi-compliance{grid-template-columns:repeat(2,1fr)}
  .nissi-trustbar__inner{grid-template-columns:repeat(2,1fr)}
  .nissi-trustbar__item:nth-child(2){border-right:0}
  .nissi-trustbar__item:nth-child(-n+2){border-bottom:1px solid var(--nissi-border)}
}
@media (max-width: 820px){
  .nissi-burger{display:inline-flex}
  .nissi-nav{
    position:fixed;top:80px;left:0;right:0;background:#fff;
    flex-direction:column;align-items:stretch;padding:14px;gap:0;
    border-top:1px solid var(--nissi-border);box-shadow:var(--nissi-shadow);
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform .3s var(--nissi-ease),opacity .3s var(--nissi-ease);
  }
  .nissi-nav.is-open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nissi-nav a{padding:14px 16px}
  .nissi-header__cta .nissi-header__portal{display:none}
  .nissi-section{padding:64px 0}
  .nissi-two{grid-template-columns:1fr;gap:36px}
  .nissi-services,.nissi-leaders{grid-template-columns:1fr}
  .nissi-cta{flex-direction:column;text-align:center;padding:40px 28px}
  .nissi-contact{grid-template-columns:1fr}
  .nissi-hero__inner{padding:90px 0 70px}
}
@media (max-width: 520px){
  .nissi-industries,.nissi-compliance{grid-template-columns:1fr}
  .nissi-trustbar__inner{grid-template-columns:1fr}
  .nissi-trustbar__item{border-right:0;border-bottom:1px solid var(--nissi-border)}
  .nissi-trustbar__item:last-child{border-bottom:0}
}

/* === Extended sections (v1.1) === */
.nissi-timeline{list-style:none;margin:0;padding:0;display:grid;gap:24px;counter-reset:tl;}
.nissi-timeline li{position:relative;background:#fff;border:1px solid var(--nissi-border,#e6ebf2);border-radius:14px;padding:28px 28px 28px 120px;box-shadow:0 8px 24px -16px rgba(14,42,74,.18);}
.nissi-timeline__year{position:absolute;left:24px;top:24px;font-weight:700;font-size:18px;color:#0E2A4A;background:linear-gradient(135deg,#0E2A4A,#1a4a82);color:#fff;padding:10px 14px;border-radius:10px;letter-spacing:.5px;}
.nissi-timeline h3{margin:0 0 6px;font-size:20px;color:#0E2A4A;}
.nissi-timeline p{margin:0;color:#4b5563;}
@media(max-width:640px){.nissi-timeline li{padding:84px 20px 20px}.nissi-timeline__year{top:18px;left:18px}}

.nissi-process{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;counter-reset:pr;}
.nissi-process li{background:#fff;border:1px solid var(--nissi-border,#e6ebf2);border-radius:14px;padding:24px;text-align:center;position:relative;}
.nissi-step{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,#0E2A4A,#1a4a82);color:#fff;font-weight:700;font-size:18px;margin-bottom:14px;}
.nissi-process h3{margin:0 0 6px;font-size:18px;color:#0E2A4A;}
.nissi-process p{margin:0;color:#4b5563;font-size:14px;}

.nissi-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;}
.nissi-value{background:#fff;border-left:4px solid #F26B1F;border-radius:10px;padding:20px 22px;box-shadow:0 6px 18px -14px rgba(14,42,74,.2);}
.nissi-value strong{display:block;color:#0E2A4A;font-size:18px;margin-bottom:6px;}
.nissi-value p{margin:0;color:#4b5563;font-size:14px;}

.nissi-why{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;}
.nissi-why>div{background:#fff;border:1px solid var(--nissi-border,#e6ebf2);border-radius:14px;padding:24px;}
.nissi-why strong{color:#0E2A4A;font-size:18px;display:block;margin-bottom:8px;}
.nissi-why p{margin:0;color:#4b5563;}

.nissi-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;text-align:center;}
.nissi-stat{background:#fff;border:1px solid var(--nissi-border,#e6ebf2);border-radius:14px;padding:30px 18px;}
.nissi-stat strong{display:block;font-size:42px;font-weight:700;color:#0E2A4A;line-height:1;margin-bottom:8px;}
.nissi-stat span{color:#4b5563;font-size:14px;}

.nissi-ticks,.nissi-checklist{list-style:none;margin:0;padding:0;display:grid;gap:10px;}
.nissi-checklist{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
.nissi-ticks li,.nissi-checklist li{position:relative;padding:14px 14px 14px 44px;background:#fff;border:1px solid var(--nissi-border,#e6ebf2);border-radius:10px;color:#0E2A4A;font-weight:500;}
.nissi-ticks li:before,.nissi-checklist li:before{content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:50%;background:#16a34a;background-image:linear-gradient(135deg,#16a34a,#0E2A4A);}
.nissi-ticks li:after,.nissi-checklist li:after{content:"";position:absolute;left:19px;top:calc(50% - 4px);width:8px;height:4px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg);}

.nissi-faq{display:grid;gap:12px;}
.nissi-faq details{background:#fff;border:1px solid var(--nissi-border,#e6ebf2);border-radius:12px;padding:18px 22px;}
.nissi-faq summary{cursor:pointer;font-weight:600;color:#0E2A4A;font-size:17px;list-style:none;display:flex;justify-content:space-between;align-items:center;}
.nissi-faq summary::-webkit-details-marker{display:none;}
.nissi-faq summary:after{content:"+";font-size:24px;color:#F26B1F;font-weight:400;line-height:1;}
.nissi-faq details[open] summary:after{content:"–";}
.nissi-faq p{margin:14px 0 0;color:#4b5563;}

/* Portal extensions */
.nissi-portal__form{display:grid;gap:14px;margin:18px 0 22px;}
.nissi-portal__row{display:flex;justify-content:space-between;align-items:center;font-size:14px;}
.nissi-portal__remember{display:flex;align-items:center;gap:8px;color:#4b5563;}
.nissi-portal__forgot{color:#F26B1F;text-decoration:none;}
.nissi-portal__forgot:hover{text-decoration:underline;}

/* Two-column helper if not already present */
.nissi-two{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.nissi-two__media img{width:100%;border-radius:18px;display:block;box-shadow:0 24px 60px -30px rgba(14,42,74,.45);}
@media(max-width:880px){.nissi-two{grid-template-columns:1fr;}}

/* Portal: error + linkified tool tiles (v1.2.0) */
.nissi-portal__error{background:rgba(220,38,38,.15);border:1px solid rgba(220,38,38,.45);color:#fecaca;padding:10px 14px;border-radius:8px;margin:0 0 16px;font-size:13px}
a.nissi-portal__tool{text-decoration:none;color:inherit;display:block;transition:transform .15s ease,background .15s ease}
a.nissi-portal__tool:hover{transform:translateY(-2px);background:rgba(255,255,255,.08)}

/* v1.5.0 — disabled portal tool tile */
.nissi-portal__tool--soon{opacity:.5;pointer-events:none;cursor:not-allowed}
.nissi-portal__tool--soon span{color:#9aa0ad}

/* Portal tool icon */
.nissi-portal__tool-icon{display:block;font-size:22px;margin-bottom:6px;line-height:1}

/* ============== LEAVE REQUEST PAGE ============== */
.nissi-portal--leave{align-items:flex-start;padding:48px 22px 80px;min-height:100vh}
.nissi-leave__wrap{display:grid;grid-template-columns:260px 1fr;gap:28px;max-width:1100px;margin:0 auto;width:100%}
.nissi-leave__sidebar{
  background:rgba(255,255,255,.04);backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.1);border-radius:18px;
  padding:28px 22px;color:#fff;height:fit-content;position:sticky;top:100px;
}
.nissi-leave__logo{margin-bottom:28px}
.nissi-leave__logo img{height:44px;filter:brightness(1.1)}
.nissi-leave__nav{display:flex;flex-direction:column;gap:6px;margin-bottom:28px}
.nissi-leave__nav-link{
  display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;
  color:#a8b6cd;font-size:14px;font-weight:600;transition:background .2s,color .2s;text-decoration:none;
}
.nissi-leave__nav-link:hover{background:rgba(255,255,255,.08);color:#fff}
.nissi-leave__user{
  border-top:1px solid rgba(255,255,255,.1);padding-top:18px;
  display:flex;align-items:flex-start;gap:12px;
}
.nissi-leave__avatar{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:var(--nissi-grad);color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:15px;
}
.nissi-leave__user>div{display:flex;flex-direction:column;gap:3px;min-width:0}
.nissi-leave__user strong{color:#fff;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nissi-leave__user span{color:#7e8da3;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nissi-leave__user a{color:#F26B1F;font-size:11px;text-decoration:none;font-weight:700}
.nissi-leave__user a:hover{text-decoration:underline}

.nissi-leave__card{
  background:#fff;border-radius:18px;overflow:hidden;
  box-shadow:0 30px 80px -30px rgba(14,42,74,.4);
}
.nissi-leave__card-hdr{
  background:var(--nissi-grad-dark);color:#fff;padding:32px 36px;
  display:flex;align-items:flex-start;justify-content:space-between;gap:20px;
}
.nissi-leave__card-hdr h1{color:#fff;font-size:1.8rem;margin-bottom:6px}
.nissi-leave__card-hdr p{color:#b9c5d8;margin:0;font-size:14px}
.nissi-leave__badge{
  flex-shrink:0;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#F26B1F;border:1px solid rgba(242,107,31,.4);padding:5px 12px;border-radius:20px;
  background:rgba(242,107,31,.08);white-space:nowrap;margin-top:4px;
}
.nissi-leave__notice{
  margin:24px 36px 0;padding:14px 18px;border-radius:10px;font-size:14px;font-weight:500;
}
.nissi-leave__notice--ok{background:#e8f5ed;border:1px solid #86efac;color:#166534}
.nissi-leave__notice--ok strong{color:#14532d}
.nissi-leave__notice--err{background:#fde8eb;border:1px solid #fca5a5;color:#7f1d1d}
.nissi-leave__notice--err a{color:#1E63B0}

.nissi-leave__form{padding:30px 36px}
.nissi-leave__fieldset{
  border:1px solid var(--nissi-border);border-radius:12px;padding:24px 24px 18px;margin-bottom:22px;
}
.nissi-leave__fieldset legend{
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  color:var(--nissi-muted);padding:0 8px;
}
.nissi-leave__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.nissi-leave__field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.nissi-leave__field label{font-size:13px;font-weight:600;color:var(--nissi-ink)}
.nissi-leave__field input[type="text"],
.nissi-leave__field input[type="email"],
.nissi-leave__field input[type="date"],
.nissi-leave__field select,
.nissi-leave__field textarea{
  padding:11px 14px;border-radius:9px;font-size:14px;
  border:1px solid var(--nissi-border);background:#fff;font-family:var(--nissi-font);
  color:var(--nissi-ink);transition:border-color .22s;appearance:none;-webkit-appearance:none;
}
.nissi-leave__field input:focus,
.nissi-leave__field select:focus,
.nissi-leave__field textarea:focus{outline:0;border-color:var(--nissi-blue)}
.nissi-leave__field input[readonly]{background:var(--nissi-bg-alt);color:var(--nissi-muted);cursor:default}
.nissi-leave__field select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235a6675' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:34px;cursor:pointer;
}
.nissi-leave__field textarea{resize:vertical;min-height:110px}
.nissi-leave__req{color:var(--nissi-orange);margin-left:2px}
.nissi-leave__field--days label{color:var(--nissi-muted)}
.nissi-leave__days-count{
  padding:11px 14px;border-radius:9px;border:1px dashed var(--nissi-border);
  background:var(--nissi-bg-alt);font-size:1.05rem;font-weight:700;color:var(--nissi-blue-deep);
  text-align:center;letter-spacing:.03em;
}

/* Leave type cards */
.nissi-leave__types{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:4px}
.nissi-leave__type-card{
  position:relative;padding:14px 16px;border-radius:10px;cursor:pointer;
  border:1.5px solid var(--nissi-border);background:#fff;
  transition:border-color .2s,background .2s;display:flex;flex-direction:column;gap:4px;
}
.nissi-leave__type-card input[type="radio"]{
  position:absolute;opacity:0;width:0;height:0;pointer-events:none;
}
.nissi-leave__type-card strong{font-size:13px;color:var(--nissi-ink)}
.nissi-leave__type-card span{font-size:11px;color:var(--nissi-muted);line-height:1.3}
.nissi-leave__type-card:hover{border-color:var(--nissi-blue);background:#f0f7ff}
.nissi-leave__type-card.is-selected{
  border-color:var(--nissi-blue);background:linear-gradient(135deg,#eaf2fc,#f6faff);
}
.nissi-leave__type-card.is-selected strong{color:var(--nissi-blue-deep)}
.nissi-leave__type-card.is-selected::after{
  content:"✓";position:absolute;top:8px;right:10px;
  font-size:12px;font-weight:700;color:var(--nissi-blue);
}

/* Confirmation checkbox */
.nissi-leave__checkbox{
  display:flex;align-items:flex-start;gap:10px;font-size:13px;
  color:var(--nissi-muted);cursor:pointer;line-height:1.5;
}
.nissi-leave__checkbox input[type="checkbox"]{
  flex-shrink:0;width:16px;height:16px;margin-top:2px;accent-color:var(--nissi-blue);cursor:pointer;
}

/* Actions */
.nissi-leave__actions{
  display:flex;align-items:center;gap:18px;padding-top:8px;
}
.nissi-leave__submit{
  padding:14px 30px;border-radius:999px;background:var(--nissi-orange);color:#fff;
  font-weight:700;font-size:15px;border:0;cursor:pointer;letter-spacing:.02em;
  transition:background .25s,transform .25s;box-shadow:0 12px 28px -10px rgba(242,107,31,.5);
}
.nissi-leave__submit:hover{background:#e35d12;transform:translateY(-2px)}
.nissi-leave__submit:disabled{opacity:.6;transform:none;cursor:wait}
.nissi-leave__cancel{font-size:14px;color:var(--nissi-muted);font-weight:600;text-decoration:none}
.nissi-leave__cancel:hover{color:var(--nissi-ink)}

/* Responsive leave form */
@media(max-width:900px){
  .nissi-leave__wrap{grid-template-columns:1fr}
  .nissi-leave__sidebar{position:static;display:flex;flex-wrap:wrap;gap:16px;align-items:center;padding:18px 20px}
  .nissi-leave__logo{margin:0}
  .nissi-leave__logo img{height:36px}
  .nissi-leave__nav{flex-direction:row;margin:0}
  .nissi-leave__user{border-top:none;border-left:1px solid rgba(255,255,255,.1);padding:0 0 0 16px;margin-left:auto}
}
@media(max-width:680px){
  .nissi-leave__card-hdr{flex-direction:column;padding:24px 22px}
  .nissi-leave__form{padding:22px}
  .nissi-leave__fieldset{padding:18px 16px 12px}
  .nissi-leave__row{grid-template-columns:1fr}
  .nissi-leave__types{grid-template-columns:1fr 1fr}
  .nissi-leave__notice{margin:18px 22px 0}
  .nissi-leave__actions{flex-direction:column;align-items:stretch}
  .nissi-leave__submit{text-align:center}
}
@media(max-width:440px){
  .nissi-leave__types{grid-template-columns:1fr}
}

/* ============== STAFF DOCUMENT LIBRARY ============== */
.nissi-docs__bar{
  display:flex;align-items:center;gap:12px;padding:22px 36px 0;
}
.nissi-docs__search-wrap{
  position:relative;flex:1;max-width:380px;
  display:flex;align-items:center;
}
.nissi-docs__search-wrap svg{
  position:absolute;left:12px;color:var(--nissi-muted);pointer-events:none;flex-shrink:0;
}
.nissi-docs__search{
  width:100%;padding:10px 14px 10px 36px;border-radius:9px;
  border:1px solid var(--nissi-border);font-size:14px;font-family:var(--nissi-font);
  background:#fff;color:var(--nissi-ink);transition:border-color .22s;
}
.nissi-docs__search:focus{outline:0;border-color:var(--nissi-blue)}

.nissi-docs__tabs{
  display:flex;flex-wrap:wrap;gap:6px;padding:16px 36px 0;border-bottom:1px solid var(--nissi-border);
  padding-bottom:0;margin-bottom:0;
}
.nissi-docs__tab{
  padding:8px 16px;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;
  font-family:var(--nissi-font);font-size:13px;font-weight:600;color:var(--nissi-muted);
  transition:color .2s,border-color .2s;margin-bottom:-1px;border-radius:0;
}
.nissi-docs__tab:hover{color:var(--nissi-blue)}
.nissi-docs__tab.is-active{color:var(--nissi-blue-deep);border-bottom-color:var(--nissi-blue)}

.nissi-docs__grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:16px;padding:24px 36px 32px;
}
.nissi-docs__card{
  border:1px solid var(--nissi-border);border-radius:12px;padding:18px 18px 14px;
  background:#fff;transition:box-shadow .22s,border-color .22s;display:flex;flex-direction:column;gap:8px;
}
.nissi-docs__card:hover{box-shadow:0 8px 24px -10px rgba(14,42,74,.2);border-color:#c0cfe4}
.nissi-docs__card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.nissi-docs__icon{
  width:44px;height:44px;border-radius:10px;flex-shrink:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
}
.nissi-docs__icon span{font-size:18px;line-height:1}
.nissi-docs__icon em{font-style:normal;font-size:9px;font-weight:800;letter-spacing:.06em;line-height:1}
.nissi-docs__meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex:1;min-width:0}
.nissi-docs__cat{
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--nissi-blue);background:#eef5fd;padding:3px 8px;border-radius:20px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
}
.nissi-docs__version{font-size:11px;color:var(--nissi-muted);font-weight:600}
.nissi-docs__title{
  font-size:14px;font-weight:700;color:var(--nissi-ink);margin:0;line-height:1.35;
}
.nissi-docs__desc{font-size:12px;color:var(--nissi-muted);margin:0;line-height:1.5;flex:1}
.nissi-docs__card-foot{
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--nissi-border);padding-top:10px;margin-top:4px;
}
.nissi-docs__size{font-size:11px;color:var(--nissi-muted);font-weight:600}
.nissi-docs__dl{
  display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;
  font-size:12px;font-weight:700;background:var(--nissi-orange);color:#fff !important;
  text-decoration:none;transition:background .2s,transform .2s;
}
.nissi-docs__dl:hover{background:#e35d12;transform:translateY(-1px)}
.nissi-docs__no-file{font-size:11px;color:#b0b8c4;font-style:italic}
.nissi-docs__no-results{padding:32px 36px;text-align:center;color:var(--nissi-muted)}
.nissi-docs__empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:64px 36px;gap:12px;
}
.nissi-docs__empty-icon{font-size:52px;line-height:1;color:var(--nissi-border)}
.nissi-docs__empty h3{color:var(--nissi-ink);margin:0}
.nissi-docs__empty p{color:var(--nissi-muted);font-size:14px;max-width:360px;margin:0}

@media(max-width:680px){
  .nissi-docs__bar{padding:18px 22px 0}
  .nissi-docs__tabs{padding:14px 22px 0}
  .nissi-docs__grid{padding:18px 22px 24px;grid-template-columns:1fr}
}


/* =========================================================
   v4 ADDITIONS — Apply form, Jobs listing, Page hero
   Using Nissi v3 design tokens.
   ========================================================= */
.nissi-page-hero{
  position:relative;
  padding:120px 0 60px;
  background:var(--nissi-grad-dark);
  color:#fff;
  overflow:hidden;
}
.nissi-page-hero::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(60% 80% at 80% 20%, rgba(58,141,216,.18), transparent 60%);
  pointer-events:none;
}
.nissi-page-hero .nissi-container{position:relative;z-index:1;max-width:var(--nissi-max);margin:0 auto;padding:0 24px}
.nissi-page-hero h1{font-size:clamp(34px,5vw,56px);margin:8px 0 14px;line-height:1.05;font-weight:700}
.nissi-page-hero .nissi-eyebrow{color:var(--nissi-orange-soft)}
.nissi-page-hero .nissi-lead{color:rgba(255,255,255,.85);max-width:720px}

.nissi-stepbar{
  list-style:none;display:flex;gap:8px;padding:0;margin:0 0 24px;
  counter-reset:step;
}
.nissi-stepbar li{
  flex:1;display:flex;align-items:center;gap:10px;
  padding:12px 16px;background:var(--nissi-bg-alt);
  border:1px solid var(--nissi-border);border-radius:10px;
  font-weight:600;color:var(--nissi-muted);font-size:14px;
  transition:all .25s var(--nissi-ease);
}
.nissi-stepbar li span{
  width:28px;height:28px;border-radius:50%;
  background:#fff;border:1px solid var(--nissi-border);
  display:grid;place-items:center;font-weight:700;font-size:13px;
}
.nissi-stepbar li.is-active{
  background:linear-gradient(135deg,var(--nissi-blue),var(--nissi-blue-light));
  color:#fff;border-color:transparent;
  box-shadow:var(--nissi-shadow-sm);
}
.nissi-stepbar li.is-active span{background:var(--nissi-orange);color:#fff;border-color:transparent}

.nissi-card{
  background:#fff;border:1px solid var(--nissi-border);
  border-radius:var(--nissi-radius);box-shadow:var(--nissi-shadow-sm);
  padding:32px;
}
.nissi-form h3{margin:0 0 18px;font-size:22px;color:var(--nissi-ink)}
.nissi-form-grid{
  display:grid;gap:16px;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.nissi-form-grid .full,
.nissi-form > label.full,
.nissi-form-step > label.full{grid-column:1 / -1}
.nissi-form label,
.nissi-form-step > label{
  display:flex;flex-direction:column;gap:6px;
  font-weight:600;font-size:13px;color:var(--nissi-ink-soft);
}
.nissi-form input,
.nissi-form select,
.nissi-form textarea{
  width:100%;padding:11px 14px;font-family:inherit;font-size:15px;
  border:1px solid var(--nissi-border);border-radius:10px;
  background:#fff;color:var(--nissi-ink);
  transition:border-color .2s,box-shadow .2s;
}
.nissi-form input:focus,
.nissi-form select:focus,
.nissi-form textarea:focus{
  outline:none;border-color:var(--nissi-blue);
  box-shadow:0 0 0 3px rgba(30,99,176,.18);
}
.nissi-form .req{color:var(--nissi-orange);font-weight:700}
.nissi-form-actions{
  display:flex;gap:12px;justify-content:flex-end;
  margin-top:28px;padding-top:24px;border-top:1px solid var(--nissi-border);
}
.nissi-fineprint{font-size:13px;color:var(--nissi-muted);margin-top:14px}
.nissi-form-notice{
  padding:14px 18px;border-radius:10px;margin-bottom:18px;font-weight:600;
  border:1px solid transparent;
}
.nissi-form-notice.is-ok{background:#e7f7ec;border-color:#bfe6cc;color:#1a6b3a}
.nissi-form-notice.is-err{background:#fdeceb;border-color:#f4c8c4;color:#a8241b}

.nissi-cards{
  display:grid;gap:20px;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
}
.nissi-card--job h3{margin:0 0 8px;font-size:20px;color:var(--nissi-ink)}
.nissi-card--job .nissi-card__meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.nissi-card--job .nissi-card__meta span{
  background:var(--nissi-bg-alt);border:1px solid var(--nissi-border);
  padding:4px 10px;border-radius:999px;font-size:12px;color:var(--nissi-muted);font-weight:600;
}
.nissi-card--job .nissi-card__excerpt{color:var(--nissi-muted);margin-bottom:16px;font-size:15px}

.nissi-header__portal--apply{
  background:var(--nissi-orange) !important;
  color:#fff !important;
  border:1.5px solid var(--nissi-orange) !important;
}
.nissi-header__portal--apply:hover{background:#e35d12 !important;border-color:#e35d12 !important;color:#fff !important;transform:translateY(-1px)}

@media (max-width:720px){
  .nissi-form-grid{grid-template-columns:1fr}
  .nissi-stepbar{flex-direction:column}
  .nissi-page-hero{padding:90px 0 40px}
  .nissi-card{padding:22px}
}

/* ════════════════════════════════════════════════
   v4.1 MOBILE FIXES — CTA glow, footer, hero
═══════════════════════════════════════════════ */
@media (max-width: 720px){
  .nissi-footer__grid{
    grid-template-columns: 1fr 1fr;
    gap: 28px 24px;
  }
  .nissi-footer__brand{ grid-column: 1 / -1; }
  .nissi-footer__bottom{
    flex-direction: column;
    gap: 8px;
    text-align: center;
  }
}
@media (max-width: 520px){
  .nissi-footer__grid{ grid-template-columns: 1fr; gap: 24px; }

  .nissi-cta{
    padding: 32px 22px;
    border-radius: 18px;
  }
  .nissi-cta::before{
    width: 220px; height: 220px;
    right: -60px; top: -60px;
    background: radial-gradient(circle, rgba(58,141,216,.22), transparent 70%);
  }
  .nissi-cta h2{ font-size: 1.5rem; line-height: 1.2; }
  .nissi-cta p{ font-size: .95rem; }
  .nissi-cta__actions{
    flex-direction: column; width: 100%;
  }
  .nissi-cta__actions .nissi-btn{ width: 100%; text-align: center; }

  .nissi-hero__inner{ padding: 72px 0 56px; }
  .nissi-hero h1{ font-size: clamp(2rem, 8vw, 2.6rem); }
  .nissi-hero p{ font-size: 1rem; }
  .nissi-hero__badges{ gap: 14px; }
}


/* ════════════════════════════════════════════════
   v4.1.4 — Comprehensive Mobile Polish
═══════════════════════════════════════════════ */
@media (max-width: 820px){
  .nissi-container{padding:0 18px}
  .nissi-section{padding:56px 0}
  .nissi-header__inner{padding:10px 16px;gap:12px}
  .nissi-logo img{height:42px}
  .nissi-page-hero{padding:80px 0 50px}
  .nissi-page-hero h1{font-size:clamp(26px,7vw,38px)}
  .nissi-cta{padding:36px 22px;border-radius:18px;text-align:center}
  .nissi-cta h2{font-size:1.5rem}
  .nissi-cta__actions{flex-direction:column;width:100%}
  .nissi-cta__actions .nissi-btn{width:100%}
  .nissi-hero{min-height:auto}
  .nissi-hero__inner{padding:80px 0 60px}
  .nissi-hero h1{font-size:clamp(1.9rem,7.5vw,2.6rem)}
  .nissi-hero p{font-size:1rem}
  .nissi-hero__actions{width:100%}
  .nissi-hero__actions .nissi-btn{flex:1 1 auto;min-width:0}
  .nissi-hero__badges{margin-top:34px;padding-top:22px;gap:14px}
}
@media (max-width: 520px){
  body.nissi-body{font-size:16px}
  h1{font-size:clamp(1.8rem,8vw,2.4rem)}
  h2{font-size:clamp(1.4rem,6vw,1.9rem)}
  .nissi-container{padding:0 14px}
  .nissi-section{padding:44px 0}
  .nissi-header__inner{padding:8px 12px;gap:8px}
  .nissi-logo img{height:36px}
  .nissi-logo{max-width:55vw}
  .nissi-page-hero{padding:60px 0 36px}
  .nissi-hero__inner{padding:64px 0 48px}
  .nissi-hero__actions{flex-direction:column}
  .nissi-hero__actions .nissi-btn{width:100%}
  .nissi-btn{padding:12px 20px;font-size:14px}
  .nissi-services,.nissi-leaders,.nissi-industries,.nissi-compliance,.nissi-two,.nissi-contact,.nissi-form-grid{grid-template-columns:1fr !important}
  .nissi-card,.nissi-service,.nissi-leader{padding:20px}
  .nissi-footer{padding:48px 0 20px;font-size:14px}
  .nissi-footer h4{margin-bottom:12px}
  .nissi-stepbar{flex-direction:column;gap:6px}
  table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  img,iframe,video{max-width:100%;height:auto}
}
@media (max-width: 380px){
  .nissi-header__portal{padding:7px 12px;font-size:12px}
  .nissi-logo img{height:32px}
}

/* ═══════════════════════════════════════════════════════
   v4.2 — WORLD-CLASS ADDITIONS
   Open Graph, POPIA, WhatsApp, Floating CTA, Services
   Dropdown, Hero BG Images, Social Links, Cookie Banner
══════════════════════════════════════════════════════ */

/* ── Page hero: background image support via CSS variable ──────────────── */
.nissi-page-hero{
  position:relative;
}
.nissi-page-hero[style*="--hero-img"]::after{
  content:"";
  position:absolute;inset:0;
  background-image:var(--hero-img);
  background-size:cover;background-position:center;
  opacity:.13;
  z-index:0;
  pointer-events:none;
}
.nissi-page-hero__inner,
.nissi-page-hero .nissi-container{
  position:relative;z-index:1;
}

/* ── Services nav dropdown ─────────────────────────────────────────────── */
.nissi-nav__dropdown{
  position:relative;
}
.nissi-nav__dropdown-toggle{
  display:flex;align-items:center;gap:4px;cursor:pointer;
}
.nissi-nav__caret{
  font-size:9px;transition:transform .25s var(--nissi-ease);display:inline-block;
}
.nissi-nav__dropdown.is-open .nissi-nav__caret{
  transform:rotate(180deg);
}
.nissi-nav__submenu{
  position:absolute;top:calc(100% + 6px);left:0;
  min-width:230px;
  background:#fff;border:1px solid var(--nissi-border);
  border-radius:12px;box-shadow:var(--nissi-shadow);
  list-style:none;margin:0;padding:8px;
  opacity:0;transform:translateY(-6px);pointer-events:none;
  transition:opacity .22s var(--nissi-ease),transform .22s var(--nissi-ease);
  z-index:200;
}
.nissi-nav__dropdown.is-open .nissi-nav__submenu{
  opacity:1;transform:translateY(0);pointer-events:auto;
}
.nissi-nav__submenu li{margin:0;padding:0}
.nissi-nav__submenu a{
  display:block;padding:9px 14px;border-radius:8px;
  font-size:14px;font-weight:600;color:var(--nissi-ink);
  transition:background .18s,color .18s;
}
.nissi-nav__submenu a:first-child{
  font-weight:700;color:var(--nissi-blue-deep);border-bottom:1px solid var(--nissi-border);
  border-radius:0;margin-bottom:4px;padding-bottom:12px;
}
.nissi-nav__submenu a:hover{
  background:var(--nissi-bg-alt);color:var(--nissi-blue);
}

/* Mobile: dropdown opens inline */
@media (max-width:820px){
  .nissi-nav__submenu{
    position:static;box-shadow:none;border:1px solid var(--nissi-border);
    border-radius:8px;margin:4px 8px 4px 14px;
    opacity:1;transform:none;pointer-events:none;max-height:0;overflow:hidden;
    transition:max-height .3s var(--nissi-ease),opacity .2s;
    padding:0;
  }
  .nissi-nav__dropdown.is-open .nissi-nav__submenu{
    max-height:400px;pointer-events:auto;padding:8px;
  }
}

/* ── Footer social links ───────────────────────────────────────────────── */
.nissi-footer__social{
  display:flex;gap:8px;flex-wrap:wrap;margin-top:18px;
}
.nissi-footer__social-link{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  color:#a8b6cd;
  transition:background .22s,color .22s,transform .22s;
}
.nissi-footer__social-link:hover{
  background:var(--nissi-orange);border-color:transparent;color:#fff;
  transform:translateY(-2px);
}
.nissi-footer__legal{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.nissi-footer__legal a{color:#5a6675}
.nissi-footer__legal a:hover{color:#fff}

/* Clickable footer contact items */
.nissi-footer li a{color:#a8b6cd;transition:color .2s}
.nissi-footer li a:hover{color:#fff}

/* ── WhatsApp floating button ──────────────────────────────────────────── */
.nissi-whatsapp-btn{
  position:fixed;bottom:28px;right:28px;z-index:999;
  display:flex;align-items:center;gap:10px;
  background:#25D366;color:#fff;
  padding:14px 20px 14px 16px;border-radius:999px;
  box-shadow:0 8px 28px -8px rgba(37,211,102,.65);
  font-size:14px;font-weight:700;text-decoration:none;
  opacity:0;transform:translateY(16px);pointer-events:none;
  transition:opacity .35s var(--nissi-ease),transform .35s var(--nissi-ease),
             box-shadow .25s var(--nissi-ease),background .2s;
  white-space:nowrap;
}
.nissi-whatsapp-btn.is-visible{
  opacity:1;transform:translateY(0);pointer-events:auto;
}
.nissi-whatsapp-btn:hover{
  background:#1da851;color:#fff;
  box-shadow:0 14px 38px -8px rgba(37,211,102,.8);
  transform:translateY(-3px);
}
.nissi-whatsapp-btn__label{line-height:1}

@media (max-width:520px){
  .nissi-whatsapp-btn{ bottom:18px;right:16px;padding:12px 16px 12px 14px }
  .nissi-whatsapp-btn__label{ display:none }
}

/* ── Cookie Consent Banner ─────────────────────────────────────────────── */
.nissi-cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:#0B1422;border-top:1px solid rgba(255,255,255,.12);
  padding:18px 24px;
  transform:translateY(100%);opacity:0;
  transition:transform .4s var(--nissi-ease),opacity .4s var(--nissi-ease);
}
.nissi-cookie-banner.is-visible{
  transform:translateY(0);opacity:1;
}
.nissi-cookie-banner__inner{
  max-width:var(--nissi-max);margin:0 auto;
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
}
.nissi-cookie-banner p{
  margin:0;flex:1;font-size:13px;color:#a8b6cd;min-width:200px;
}
.nissi-cookie-banner a{color:var(--nissi-orange)}
.nissi-cookie-banner a:hover{color:var(--nissi-orange-soft)}
.nissi-cookie-banner__actions{
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.nissi-cookie-banner__decline{
  background:none;border:none;cursor:pointer;
  color:#7e8da3;font-size:13px;font-weight:600;
  font-family:var(--nissi-font);padding:8px;
  transition:color .2s;
}
.nissi-cookie-banner__decline:hover{color:#a8b6cd}
.nissi-btn--sm{padding:10px 18px;font-size:13px}

/* ── POPIA consent checkbox on apply form ─────────────────────────────── */
.nissi-popia-consent{
  background:var(--nissi-bg-alt);border:1px solid var(--nissi-border);
  border-radius:12px;padding:18px 20px;
}
.nissi-popia-label{
  display:flex;align-items:flex-start;gap:12px;cursor:pointer;
  font-size:13px;color:var(--nissi-ink-soft);line-height:1.55;font-weight:400;
}
.nissi-popia-label input[type="checkbox"]{
  flex-shrink:0;width:18px;height:18px;margin-top:2px;
  accent-color:var(--nissi-blue);cursor:pointer;
}
.nissi-popia-error{
  margin-top:10px;padding:10px 14px;border-radius:8px;
  background:#fde8eb;border:1px solid #fca5a5;color:#7f1d1d;
  font-size:13px;font-weight:600;
}

/* ── File upload fields ──────────────────────────────────────────────── */
.nissi-upload-area{
  position:relative;border:2px dashed var(--nissi-border);border-radius:12px;
  background:var(--nissi-bg-alt);cursor:pointer;
  transition:border-color .22s,background .22s;
  overflow:hidden;
}
.nissi-upload-area:hover,.nissi-upload-area.is-drag{
  border-color:var(--nissi-blue);background:#eef5fd;
}
.nissi-upload-area.is-selected{
  border-color:#16a34a;border-style:solid;background:#f0fdf4;
}
.nissi-upload-input{
  position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;z-index:2;
}
.nissi-upload-ui{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:28px 20px;gap:6px;text-align:center;
}
.nissi-upload-icon{font-size:28px;line-height:1}
.nissi-upload-label{font-weight:600;font-size:14px;color:var(--nissi-ink-soft)}
.nissi-upload-hint{font-size:12px;color:var(--nissi-muted)}
.nissi-upload-area.is-selected .nissi-upload-icon::before{content:"✓ ";color:#16a34a}
.nissi-upload-area.is-selected .nissi-upload-label{color:#166534;font-weight:700}

/* ── Contact page social pills ───────────────────────────────────────── */
.nissi-social-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:999px;font-size:12px;font-weight:700;
  background:var(--nissi-bg-alt);border:1px solid var(--nissi-border);
  color:var(--nissi-ink-soft);text-decoration:none;
  transition:background .2s,border-color .2s,color .2s,transform .2s;
}
.nissi-social-pill:hover{
  background:var(--nissi-blue-deep);border-color:var(--nissi-blue-deep);
  color:#fff;transform:translateY(-1px);
}

/* ── Apply form: 4-step bar update ──────────────────────────────────── */
.nissi-stepbar li:nth-child(3) span,.nissi-stepbar li:nth-child(4) span{
  background:#fff;
}


/* ── v4.2.1.1 mobile fix: prevent horizontal scroll on phones ────────── */
html, body, body.nissi-body { overflow-x: hidden; max-width: 100%; }
.nissi-hero { overflow: hidden; }
.nissi-hero__bg { overflow: hidden; }
.nissi-hero__bg img { will-change: transform; }
img, video, iframe, table { max-width: 100%; }
.nissi-container { width: 100%; }
@media (max-width: 820px){
  .nissi-hero__inner,
  .nissi-page-hero__inner,
  .nissi-rich,
  .nissi-section__head { max-width: 100%; }
}
