/* Auto-aggregated stylesheet: base + components + pages */

/* ===== assets/css/bootstrap-overrides.css ===== */

/* bootstrap-overrides.css
   - place Bootstrap-friendly overrides here (variables, button radii, etc.)
*/
:root{
  --bg:#F7F8FB;
  --surface:#FFFFFF;
  --text:#0F172A;
  --muted:#64748B;
  --border:#E5E7EB;
  --primary:#2563EB;
  --primary-600:#1D4ED8;
  --success:#16A34A;
  --warning:#F59E0B;
  --danger:#EF4444;

  --r:14px;
  --r-lg:16px;
  --shadow:0 10px 28px rgba(15, 23, 42, .10);
}

body{ background:var(--bg); color:var(--text); }
.container-xl{ max-width:1280px; }

.btn-primary{ background:var(--primary); border-color:var(--primary); }
.btn-primary:hover{ background:var(--primary-600); border-color:var(--primary-600); }

.btn-outline-primary{
  border-color:var(--border);
  color:var(--text);
  background:#fff;
}
.btn-outline-primary:hover{
  border-color:var(--primary);
  color:var(--primary);
  background:rgba(37,99,235,.06);
}

.nl-brand__mark{
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: rgba(37,99,235,.10);
  border: 1px solid rgba(37,99,235,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  color: var(--primary);
}


/* ===== Strict B2B look tweaks ===== */
:root{
  --r:10px;
  --r-lg:12px;
}

/* buttons slightly squarer */
.btn{ border-radius: 10px; }
.btn-primary{ box-shadow: none !important; }
.btn-outline-primary{ box-shadow: none !important; }

/* topbar */
.nl-topbar{ font-size: 13px; color: var(--muted); }
.nl-topbar__iconlink{
  width: 28px; height: 28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  text-decoration:none;
  background:#fff;
}
.nl-topbar__iconlink:hover{ border-color: rgba(37,99,235,.35); color: var(--primary); background: rgba(37,99,235,.04); }

/* header utility links */
.nl-header__utils{
  margin-top: 8px;
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  font-size: 13px;
}
.nl-util-link{
  color: var(--muted);
  text-decoration:none;
}
.nl-util-link:hover{ color: var(--primary); }

/* Make header main area lighter (no heavy shadow) */
.nl-header-main-wrap{
  box-shadow: none !important;
}


/* ===== assets/css/styles.css ===== */


:root{
  --bg:#f4f7ff; --surface:#ffffff; --text:#0b1220; --muted:#556277;
  --border:rgba(15,23,42,.10); --primary:#2563eb; --primary-600:#1d4ed8;
  --shadow-sm:0 10px 28px rgba(15,23,42,.10); --shadow-md:0 18px 46px rgba(15,23,42,.14);
  --r:16px; --r2:20px;
}
body{background:var(--bg); color:var(--text);}
.container-xl{max-width:1320px;}
.nl-link{color:var(--muted); text-decoration:none;}
.nl-link:hover{color:var(--text);}
.nl-pill{display:inline-flex;align-items:center;gap:.45rem;height:30px;padding:0 12px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:13px;white-space:nowrap;}
.nl-pill--ok{background:rgba(34,197,94,.10);border-color:rgba(34,197,94,.25);}
.nl-pill--soft{background:rgba(2,132,199,.08);border-color:rgba(2,132,199,.18);}
.nl-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-sm);}
.nl-topline{background:#f8fbff;border-bottom:1px solid var(--border);}
.nl-header{background:#fff;border-bottom:1px solid var(--border);}
.nl-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;}
.nl-logo__mark{width:44px;height:44px;border-radius:14px;background:rgba(37,99,235,.10);border:1px solid rgba(37,99,235,.18);display:flex;align-items:center;justify-content:center;color:var(--primary);}
.nl-logo__title{font-weight:900;font-size:20px;line-height:1;}
.nl-logo__sub{font-size:12px;color:var(--muted);margin-top:2px;}
.nl-search{border-radius:14px;overflow:hidden;box-shadow:0 10px 26px rgba(15,23,42,.08);}
.nl-search .form-control{height:44px;border-left:0;}
.nl-search .input-group-text{border-right:0;}
.nl-search .btn{height:44px;font-weight:800;}
.nl-suggest{position:absolute;left:0;right:0;top:52px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-md);overflow:hidden;z-index:100;}
.nl-suggest__item{padding:10px 12px;display:flex;justify-content:space-between;gap:12px;cursor:pointer;}
.nl-suggest__item:hover{background:rgba(37,99,235,.06);}
.nl-suggest__muted{color:var(--muted);font-size:12px;}
.nl-toolbar{background:#fff;border-bottom:1px solid var(--border);}
.nl-toolbar__row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.nl-toolbar__btn{height:40px;border-radius:14px;font-weight:800;}
.nl-toolbar__chipbtn{height:34px;border-radius:12px;border:1px solid var(--border);background:#fff;padding:0 12px;display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--text);text-decoration:none;}
.nl-toolbar__chipbtn:hover{border-color:rgba(37,99,235,.22);background:rgba(37,99,235,.04);color:var(--primary);}
.nl-toolbar__spacer{flex:1 1 auto;}
.nl-toolbar--sticky{position:sticky;top:0;z-index:1030;box-shadow:0 12px 24px rgba(15,23,42,.08);}
.nl-hero{position:relative;min-height:520px;border-radius:0;overflow:hidden;background:url('../img/hero-bg.svg') center/cover no-repeat;}
.nl-hero__inner{padding:42px 0 86px;}
.nl-hero h1{font-weight:900;font-size:56px;line-height:1.05;}
@media(max-width:992px){.nl-hero h1{font-size:40px;}}
.nl-hero__subtitle{font-size:18px;color:var(--muted);}
.nl-hero__badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;}
.nl-hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px;}
.nl-hero__cta .btn{height:46px;border-radius:14px;font-weight:900;padding:8px 16px;}
.nl-hero__visual{position:relative;height:420px;}
.nl-hero__visual img{position:absolute;right:0;bottom:-24px;width:min(520px,100%);filter:drop-shadow(0 20px 50px rgba(15,23,42,.20));border-radius:24px;}
.nl-hero__dept{position:absolute;right:0;top:20px;width:min(520px,100%);}
.nl-hero__dept h3{font-weight:900;font-size:18px;margin:0;}
.nl-hero__dept .btn{height:40px;border-radius:12px;font-weight:800;}
.nl-overlap{margin-top:-46px;position:relative;z-index:20;}
.nl-quick{border-radius:18px;}
.nl-quick__head{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.nl-quick__title{font-weight:900;font-size:20px;}
.nl-quick .btn{height:38px;border-radius:12px;font-weight:800;}
.nl-quick__input{height:44px;border-radius:14px;border:1px solid var(--border);}
.nl-quick__meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:13px;}
.nl-quick__meta b{color:var(--text);}
.nl-section-title{font-weight:900;font-size:28px;margin:0;}
.nl-tabs{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);}
.nl-tabs a{color:var(--muted);text-decoration:none;font-weight:700;}
.nl-tabs a.active{color:var(--text);}
.nl-cat-card{border-radius:18px;overflow:hidden;height:100%;}
.nl-cat-card__img{height:160px;background:#fff url('../img/prod-ph.svg') center/cover no-repeat;border-bottom:1px solid var(--border);}
.nl-cat-card__body{padding:14px;}
.nl-cat-card__title{font-weight:900;font-size:18px;margin-bottom:6px;}
.nl-cat-card__desc{color:var(--muted);font-size:13px;min-height:34px;}
.nl-cat-card__bottom{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px;}
.nl-cat-card__price{font-weight:900;}
.nl-cat-card .btn{height:36px;border-radius:12px;font-weight:900;}
.nl-prod{border-radius:18px;overflow:hidden;height:100%;}
.nl-prod__img{height:140px;background:#fff url('../img/prod-ph.svg') center/cover no-repeat;border-bottom:1px solid var(--border);}
.nl-prod__body{padding:14px;}
.nl-prod__badge{height:20px;padding:0 8px;border-radius:999px;font-size:11px;font-weight:900;display:inline-flex;align-items:center;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.25);color:#15803d;}
.nl-prod__title{font-weight:900;margin-top:10px;}
.nl-prod__meta{color:var(--muted);font-size:12px;}
.nl-prod__actions{display:flex;gap:10px;align-items:center;margin-top:12px;}
.nl-qty{width:120px;height:36px;border-radius:12px;border:1px solid var(--border);display:flex;overflow:hidden;}
.nl-qty button{width:36px;border:0;background:#fff;font-weight:900;}
.nl-qty input{width:48px;border:0;text-align:center;outline:none;font-weight:900;}
.nl-prod__actions .btn{height:36px;border-radius:12px;font-weight:900;}
.nl-footer{background:#fff;border-top:1px solid var(--border);margin-top:48px;}

.nl-topline .dropdown .nl-pill{cursor:pointer;}
.nl-topline .dropdown .nl-pill:focus{outline:0; box-shadow:0 0 0 .2rem rgba(37,99,235,.18);}


/* --- Topline / Toolbar layering + alignment fixes --- */
.nl-topline{
  position: relative;
  z-index: 1200; /* above sticky toolbar */
}
.nl-topline .dropdown-menu{
  z-index: 1300;
}
.nl-topline .nl-pill{
  height: 32px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.nl-topline .btn.btn-sm{
  height: 32px;
  padding-top: 0;
  padding-bottom: 0;
  display: inline-flex;
  align-items: center;
}
.nl-toolbar--sticky{
  position: sticky;
  top: 0;
  z-index: 1050;
}
.nl-toolbar{
  background:#fff;
  
  border-bottom: 1px solid rgba(229,231,235,.9);
}
.nl-toolbar .btn,
.nl-toolbar .form-control{
  height: 40px;
}
.nl-toolbar .btn{
  display: inline-flex;
  align-items: center;
}


/* --- Hero slider --- */
.nl-hero--slider{background:transparent;}
.nl-hero--slider .carousel,
.nl-hero--slider .carousel-inner,
.nl-hero--slider .carousel-item{min-height:520px;}
.nl-hero__slide{
  min-height:520px;
  background-color:#EEF5FF;
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
  position:relative;
}
.nl-hero__slide::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(255,255,255,.88) 0%, rgba(255,255,255,.78) 6%, rgb(255 255 255 / 0%) 40%)
}
.nl-hero__inner{position:relative; padding:72px 0 92px;}
@media (max-width: 991.98px){
  .nl-hero__inner{padding:42px 0 72px;}
  .nl-hero__slide::before{
    background:linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(255,255,255,.55) 30%);
  }
}

.nl-hero__control{
  width:44px;height:44px;border-radius:14px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(226,232,240,.95);
  display:flex;align-items:center;justify-content:center;
  color:#0F172A;
  box-shadow:0 10px 22px rgba(15,23,42,.10);
}
.nl-hero--slider .carousel-control-prev,
.nl-hero--slider .carousel-control-next{width:64px; opacity:1;}
.nl-hero--slider .carousel-control-prev:hover .nl-hero__control,
.nl-hero--slider .carousel-control-next:hover .nl-hero__control{
  transform:translateY(-1px);
}
.nl-hero--slider .carousel-indicators{margin-bottom:18px;}
.nl-hero--slider .carousel-indicators [data-bs-target]{
  width:8px;height:8px;border-radius:999px;
  background:rgba(15,23,42,.25);
  border:0;
}
.nl-hero--slider .carousel-indicators .active{
  background:rgba(37,99,235,.95);
}
.nl-hero__h2{
  font-weight:800;
  font-size:46px;
  line-height:1.08;
  margin:0;
}
@media (max-width: 575.98px){
  .nl-hero__h2{font-size:34px;}
}

/* --- Home: recommendations improvements --- */
.nl-badge-soft{
  height:20px;
  padding:0 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  background:rgba(37,99,235,.10);
  border:1px solid rgba(37,99,235,.24);
  color:#1d4ed8;
}

.nl-prod__price{
  margin-top:10px;
  font-weight:900;
  font-size:20px;
  line-height:1.2;
}

.nl-prod__price span{
  margin-left:6px;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
}

/* --- Home: certificates gallery --- */
.nl-cert-card{
  width:100%;
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  overflow:hidden;
  text-align:left;
  padding:0;
  box-shadow:var(--shadow-sm);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}

.nl-cert-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:rgba(37,99,235,.28);
}

.nl-cert-card__img{
  display:block;
  width:100%;
  height:170px;
  object-fit:cover;
  border-bottom:1px solid var(--border);
}

.nl-cert-card__body{
  display:block;
  padding:12px;
}

.nl-cert-card__body strong{
  display:block;
  font-size:14px;
  line-height:1.35;
}

.nl-cert-card__body small{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
}

.nl-cert-modal .modal-header{
  border-bottom:1px solid var(--border);
}

.nl-cert-modal__img{
  display:block;
  width:100%;
  max-height:78vh;
  object-fit:contain;
  border-radius:10px;
}

/* --- Footer: responsive + cross-browser friendly --- */
.nl-footer{
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border-top:1px solid var(--border);
  margin-top:48px;
}

.nl-footer__top{ align-items:flex-start; }

.nl-footer__links li + li{ margin-top:8px; }
.nl-footer__links a{
  display:inline-block;
  line-height:1.35;
  overflow-wrap:anywhere;
}

.nl-footer__subscribe .input-group .form-control,
.nl-footer__subscribe .input-group .btn{
  min-height:42px;
}

.nl-footer__bottom{
  border-top:1px solid rgba(148,163,184,.25);
}

/* keyboard accessibility */
.nl-footer a:focus-visible,
.nl-footer button:focus-visible,
.nl-footer input:focus-visible{
  outline:2px solid rgba(37,99,235,.45);
  outline-offset:2px;
}

/* Safari/iOS input rendering */
.nl-footer input[type="email"]{
  -webkit-appearance:none;
  appearance:none;
}

/* smoother rendering in old/mobile browsers */
@media (max-width: 991.98px){
  .nl-footer{ margin-top:40px; }
  .nl-footer .nl-pill{ font-size:12px; }
}

@media (max-width: 575.98px){
  .nl-footer .container-xl{ padding-left:16px; padding-right:16px; }
  .nl-footer__subscribe .input-group{ flex-direction:column; }
  .nl-footer__subscribe .input-group .btn,
  .nl-footer__subscribe .input-group .form-control{
    width:100%;
    border-radius:12px !important;
  }
}

@media (prefers-reduced-motion: reduce){
  .nl-footer *,
  .nl-footer *::before,
  .nl-footer *::after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}

/* --- Global site adaptive + cross-browser baseline --- */
*, *::before, *::after { box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, svg, video, canvas {
  display: block;
  max-width: 100%;
  height: auto;
}

a, button, input, select, textarea {
  font: inherit;
}

button, input, select, textarea {
  -webkit-appearance: none;
  appearance: none;
}

input[type="checkbox"],
input[type="radio"] {
  -webkit-appearance: auto;
  appearance: auto;
}

.container, .container-sm, .container-md, .container-lg, .container-xl, .container-xxl {
  width: 100%;
}

[class*="col-"] {
  min-width: 0;
}

.nl-logo, .nl-link, .btn, .badge {
  overflow-wrap: anywhere;
}

.table {
  word-break: normal;
}

.table-responsive {
  -webkit-overflow-scrolling: touch;
}

.ratio > * {
  object-fit: cover;
}

@supports not (gap: 1rem) {
  .d-flex > * + * {
    margin-left: .5rem;
  }
}

@media (max-width: 1199.98px) {
  .container-xl { max-width: 100%; }
}

@media (max-width: 991.98px) {
  .nl-section-title {
    font-size: clamp(24px, 4.6vw, 28px);
  }

  .nl-prod__actions {
    flex-wrap: wrap;
  }

  .nl-prod__actions .btn,
  .nl-qty {
    width: 100%;
  }

  .nl-header .btn,
  .nl-nav .btn,
  .nl-nav__link {
    min-height: 40px;
  }
}

@media (max-width: 767.98px) {
  .nl-hero__h2,
  .nl-hero h1 {
    font-size: clamp(30px, 8vw, 38px);
    line-height: 1.12;
  }

  .nl-search .btn,
  .nl-header__actions .btn {
    width: 100%;
  }

  .nl-surface,
  .nl-card {
    border-radius: 14px;
  }
}

@media (max-width: 575.98px) {
  .nl-topbar__left,
  .nl-topbar__right {
    width: 100%;
    justify-content: flex-start;
  }

  .nl-tabs {
    gap: 10px;
  }

  .nl-tabs a {
    font-size: 14px;
  }

  .nl-prod__title,
  .nl-cat-card__title {
    font-size: 16px;
  }
}

/* --- Hero slider custom illustrated backgrounds --- */
.nl-hero__slide--sport{
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.62) 0%, rgba(255,255,255,.36) 48%, rgba(255,255,255,.08) 100%),
    url('../img/ted.png');
}

.nl-hero__slide--b2b{
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.64) 0%, rgba(255,255,255,.34) 48%, rgba(255,255,255,.08) 100%),
    url('../img/slider-bg-2.svg');
}

.nl-hero__slide--logistics{
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.64) 0%, rgba(255,255,255,.34) 48%, rgba(255,255,255,.08) 100%),
    url('../img/slider-bg-3.svg');
}

.nl-hero__slide--sport,
.nl-hero__slide--b2b,
.nl-hero__slide--logistics{
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

@media (max-width: 767.98px){
  .nl-hero__slide--sport,
  .nl-hero__slide--b2b,
  .nl-hero__slide--logistics{
    background-position: 72% center;
  }
}


/* ===== assets/css/components.css ===== */

/* components.css
   - reusable UI pieces: chips, header card, search, mega, product cards, etc.
*/
.nl-link{ color:var(--muted); text-decoration:none; }
.nl-link:hover{ color:var(--text); }

.nl-surface{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  box-shadow:var(--shadow);
}

.nl-input{
  height:44px;
  border-radius:12px;
  border:1px solid var(--border);
}
.nl-input:focus{
  box-shadow:0 0 0 .2rem rgba(37,99,235,.20);
  border-color:rgba(37,99,235,.45);
}

.nl-chip{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:6px 10px;
  border-radius:999px;
  background:#F1F5F9;
  color:var(--text);
  font-size:12px;
  line-height:16px;
  border:1px solid var(--border);
  white-space:nowrap;
}
.nl-chip--ok{ background:rgba(22,163,74,.10); border-color:rgba(22,163,74,.25); }

/* Brand */
.nl-brand{
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:44px;
}
.nl-brand__title{
  font-weight:800;
  font-size:22px;
  line-height:1.1;
  letter-spacing:.2px;
  color: var(--primary);
}
.nl-brand__sub{
  margin-top:2px;
  font-size:12px;
  line-height:1.2;
  color: var(--muted);
}

/* Sticky wrap */
.nl-sticky-wrap{ position: sticky; top: 0; z-index:1030; }

/* Card sticky header (closer to mock) */
.nl-sticky-wrap--card{
  position: sticky;
  top: 14px;
  z-index: 1030;
  padding-top: 14px;
  padding-bottom: 6px;
}
.nl-header-card{
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(229,231,235,.92);
  border-radius: 18px;
  box-shadow: 0 18px 46px rgba(15,23,42,.14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  overflow: hidden;
}
.nl-header-divider{
  height:1px;
  background: rgba(229,231,235,.85);
}

/* Topbar thin (opt) */
.nl-topbar-thin{
  background:#fff;
  border-bottom:1px solid var(--border);
  font-size:13px;
}
.nl-topbar-thin__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.nl-topbar-thin__left{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.nl-topbar-thin__right{
  display:flex;
  align-items:center;
  gap:14px;
  flex: 0 0 auto;
}
.nl-topbar-thin__sep{ color: rgba(100,116,139,.6); }
.nl-topbar-thin__item{ color: var(--muted); white-space:nowrap; }
.nl-topbar-thin__link{
  color: var(--text);
  text-decoration:none;
  white-space:nowrap;
}
.nl-topbar-thin__link:hover{ color: var(--primary); }
.nl-topbar-thin__messengers{ display:flex; gap:8px; margin-left:4px; }
.nl-topbar-thin__pill{
  height:26px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 10px;
  border:1px solid var(--border);
  border-radius:999px;
  background:#fff;
  color: var(--text);
  text-decoration:none;
  font-weight:600;
  font-size:12px;
}
.nl-topbar-thin__pill:hover{ border-color: rgba(37,99,235,.35); color: var(--primary); }

.nl-topbar-thin--card{ border:0; background: transparent; }
.nl-topbar-thin--card .nl-topbar-thin__row{ padding: 10px 14px; }

/* Header row inside card */
.nl-header-main__row{
  display:flex;
  align-items:center;
  gap:14px;
  padding: 12px 14px;
}
.nl-header-main__search{ flex: 1 1 auto; min-width: 280px; }
.nl-header-main__actions{
  flex: 0 0 auto;
  display:flex;
  gap:10px;
  align-items:center;
}
.nl-header-main__actions .btn{
  height:44px;
  padding:0 14px;
  border-radius:12px;
}

/* Under-nav row */
.nl-nav-under__row{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 10px 14px 12px;
  flex-wrap:wrap;
}
.nl-catalog-btn{ height:44px; border-radius:12px; }
.nl-pillbtn{
  height:44px;
  display:inline-flex;
  align-items:center;
  padding:0 14px;
  border:1px solid rgba(229,231,235,.95);
  border-radius:12px;
  background:#fff;
  color: var(--text);
  text-decoration:none;
  white-space:nowrap;
}
.nl-pillbtn:hover{ border-color: rgba(37,99,235,.35); color: var(--primary); background: rgba(37,99,235,.04); }
.nl-pillbtn--ghost{ background: rgba(255,255,255,.65); }

/* Mega menu */
.dropdown-menu.mega{
  width:100%;
  margin-top:12px;
  padding:0;
  background:transparent;
  border:0;
}
@media (min-width: 992px){
  .dropdown-menu.mega{ left:0 !important; right:0 !important; }
}
.list-group-item{ border:0; padding:.5rem 0; }
.list-group-item-action:hover{ background:transparent; color:var(--primary); }

/* Search */
.nl-search{ align-items:stretch; }
.nl-search__icon{
  width:44px;
  justify-content:center;
  padding:0;
}
.nl-search__input{ height:44px; padding-top:0; padding-bottom:0; }
.nl-search__btn{ min-width:120px; }

/* Search suggestions */
.nl-suggest{
  position:absolute;
  top: calc(44px + 10px);
  left:0;
  right:0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: var(--shadow);
  overflow:hidden;
  z-index: 1050;
}
.nl-suggest__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  background: #fff;
}
.nl-suggest__title{ font-weight:600; font-size:13px; color: var(--muted); }
.nl-suggest__close{
  width:28px; height:28px;
  border-radius:10px;
  border:1px solid var(--border);
  background:#fff;
  line-height:1;
}
.nl-suggest__close:hover{ border-color: rgba(37,99,235,.35); }

.nl-suggest__list{ max-height: 320px; overflow:auto; }
.nl-suggest__item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 12px;
  cursor:pointer;
  border-bottom:1px solid rgba(229,231,235,.6);
}
.nl-suggest__item:last-child{ border-bottom:0; }
.nl-suggest__item:hover{ background: rgba(37,99,235,.06); }
.nl-suggest__item[aria-selected="true"]{ background: rgba(37,99,235,.10); }
.nl-suggest__badge{
  flex:0 0 auto;
  font-size:11px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid var(--border);
  background:#F1F5F9;
  color: var(--text);
  white-space:nowrap;
}
.nl-suggest__meta{ font-size:12px; color: var(--muted); margin-top:2px; }
.nl-suggest__name{ font-weight:600; line-height:1.2; }
.nl-suggest__hl{ color: var(--primary); font-weight:700; }
.nl-suggest__foot{
  padding:8px 12px;
  border-top:1px solid var(--border);
  background:#fff;
}

/* Product card (used in recommended tabs later) */
.nl-card-product{
  border:1px solid var(--border);
  border-radius:var(--r);
  background:var(--surface);
  overflow:hidden;
  transition:transform .12s ease, box-shadow .12s ease;
  height:100%;
}
.nl-card-product:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
.nl-imgph{ background:linear-gradient(180deg, #F1F5F9, #FFFFFF); border-bottom:1px solid var(--border); }

/* Qty */
.nl-qty{
  height:36px;
  border-radius:10px;
  border:1px solid var(--border);
  width:60px;
  text-align:center;
}

/* Responsive */
@media (max-width: 991.98px){
  .nl-topbar-thin__row{ flex-wrap:wrap; }
  .nl-topbar-thin__right{ flex-wrap:wrap; gap:10px; justify-content:flex-start; }
  .nl-header-main__row{ flex-wrap:wrap; }
  .nl-header-main__search{ min-width:0; width: 100%; }
  .nl-header-main__actions{ width:100%; justify-content:flex-start; }
}


/* ===== New header (v2): full-width, clean, closer to mock ===== */
.nl-header-wrap{
  position: relative;
  z-index: 1030;
}
.nl-topbar-wrap{
  background: #fff;
  border-bottom: 1px solid var(--border);
}

.nl-topbar{
  padding: 8px 0;
  font-size: 13px;
  color: var(--muted);
}
.nl-topbar__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.nl-topbar__left{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 0;
}
.nl-topbar__right{
  display:flex;
  align-items:center;
  gap: 14px;
  flex-wrap: nowrap;
}
.nl-topbar__sep{ color: rgba(100,116,139,.55); }
.nl-topbar__item{ white-space:nowrap; }
.nl-topbar__link{
  color: var(--text);
  text-decoration:none;
  white-space:nowrap;
}
.nl-topbar__link:hover{ color: var(--primary); }

.nl-topbar__messengers{
  display:flex;
  gap: 8px;
  margin-left: 4px;
}
.nl-topbar__pill{
  height: 28px;
  display:inline-flex;
  align-items:center;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  color: var(--text);
  text-decoration:none;
  font-weight: 600;
  font-size: 12px;
}
.nl-topbar__pill:hover{ border-color: rgba(37,99,235,.35); color: var(--primary); background: rgba(37,99,235,.04); }

.nl-header-main-wrap{
  background: #fff;
  border-bottom: 1px solid var(--border);
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
}

.nl-header{
  padding: 14px 0 12px;
}
.nl-header__row{
  display:flex;
  align-items:center;
  gap: 16px;
}
.nl-header__search{
  flex: 1 1 auto;
  min-width: 320px;
}
.nl-header__actions{
  flex: 0 0 auto;
  display:flex;
  align-items:center;
  gap: 10px;
}
.nl-header__actions .btn{
  height: 44px;
  padding: 0 14px;
  border-radius: 12px;
}
.nl-header__quicklinks{
  margin-top: 10px;
  gap: 8px;
  flex-wrap: wrap;
}

.nl-nav{
  padding: 10px 0 14px;
}
.nl-nav__row{
  display:flex;
  align-items:center;
  gap: 10px;
  flex-wrap: wrap;
}
.nl-nav__link{
  height: 44px;
  display:inline-flex;
  align-items:center;
  padding: 0 14px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background:#fff;
  color: var(--text);
  text-decoration:none;
  white-space:nowrap;
}
.nl-nav__link:hover{
  border-color: rgba(37,99,235,.35);
  color: var(--primary);
  background: rgba(37,99,235,.04);
}

/* Responsive */
@media (max-width: 991.98px){
  .nl-topbar__row{ flex-wrap: wrap; }
  .nl-topbar__right{ flex-wrap: wrap; justify-content:flex-start; gap: 10px; }
  .nl-header__row{ flex-wrap: wrap; }
  .nl-header__search{ width: 100%; min-width: 0; }
  .nl-header__actions{ width: 100%; justify-content:flex-start; }
}


/* Sticky only the navigation row (catalog + key links) */
.nl-nav--sticky{
  position: sticky;
  top: 0;
  z-index: 1035;
  background: #fff;
  border-bottom: 1px solid var(--border);
  box-shadow: 0 6px 16px rgba(15,23,42,.06);
}

.nl-nav--sticky .nl-nav{
  padding: 10px 0;
}
@media (min-width: 992px){
  .nl-nav--sticky{ top: 0; }
}


/* strict nav */
.nl-nav__link{
  border-radius: 10px;
  height: 40px;
  padding: 0 12px;
  font-weight: 600;
  font-size: 14px;
}
.nl-catalog-btn{
  height: 40px;
  padding: 0 12px;
  border-radius: 10px;
  font-weight: 700;
}

/* keep action buttons compact */
.nl-nav__action{
  height: 40px;
  padding: 0 12px;
  border-radius: 10px;
  font-weight: 700;
}

/* header sizing compact */
.nl-header{ padding: 12px 0 10px; }
.nl-header__actions .btn{ height: 40px; padding: 0 12px; border-radius: 10px; }
.nl-input{ height: 40px; border-radius: 10px; }


/* ===== B2B compact header/nav (v6) ===== */
.nl-topbar-wrap{ background:#fff; border-bottom:1px solid var(--border); }
.nl-topbar{ padding:6px 0; font-size:13px; color:var(--muted); }
.nl-topbar__row{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.nl-topbar__left, .nl-topbar__right{ display:flex; align-items:center; gap:12px; }
.nl-topbar__sep{ color:rgba(15,23,42,.25); }
.nl-topbar__link{ color:var(--muted); text-decoration:none; font-weight:600; white-space:nowrap; }
.nl-topbar__link:hover{ color:var(--text); }
.nl-topbar__item{ white-space:nowrap; }
.nl-topbar__pill{
  height:28px; padding:0 10px; border-radius:999px;
  border:1px solid var(--border); background:#fff;
  color:var(--muted); text-decoration:none; font-weight:700;
  display:inline-flex; align-items:center; gap:6px;
}
.nl-topbar__pill:hover{ color:var(--primary); border-color:rgba(37,99,235,.25); background:rgba(37,99,235,.04); }

.nl-header-main-wrap{ background:#fff; border-bottom:1px solid var(--border); }
.nl-header{ padding:12px 0; }
.nl-header__row{ display:flex; align-items:center; gap:16px; }
.nl-brand__mark{
  width:40px; height:40px; border-radius:12px;
  background:rgba(37,99,235,.08);
  border:1px solid rgba(37,99,235,.18);
  color:var(--primary);
  display:flex; align-items:center; justify-content:center;
}
.nl-brand__title{ font-weight:900; letter-spacing:.2px; }
.nl-brand__sub{ font-size:12px; color:var(--muted); margin-top:-2px; }
.nl-header__search{ flex:1 1 auto; min-width:320px; }
.nl-search{ border-radius:12px; overflow:hidden; }
.nl-input{ height:42px; border-radius:12px; border:1px solid var(--border); }
.nl-search__btn{ font-weight:800; }
.nl-header__actions{ display:flex; gap:10px; align-items:center; }
.nl-header__actions .btn{ height:42px; border-radius:12px; padding:0 12px; font-weight:800; }

.nl-nav--sticky{
  position: sticky; top:0; z-index:1035;
  background:#fff;
  border-bottom:1px solid var(--border);
  box-shadow:0 6px 16px rgba(15,23,42,.06);
}
.nl-nav{ padding:10px 0; }
.nl-nav__row{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:nowrap;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
}
.nl-nav__row::-webkit-scrollbar{ height:6px; }
.nl-nav__row::-webkit-scrollbar-thumb{ background:rgba(15,23,42,.12); border-radius:999px; }

.nl-catalog-btn{ height:40px; border-radius:12px; font-weight:900; padding:0 12px; white-space:nowrap; }
.nl-nav__link{
  height:40px; border-radius:12px;
  border:1px solid var(--border); background:#fff;
  color:var(--text); text-decoration:none;
  display:inline-flex; align-items:center; gap:8px;
  padding:0 12px; font-weight:800; white-space:nowrap;
}
.nl-nav__link:hover{ color:var(--primary); border-color:rgba(37,99,235,.22); background:rgba(37,99,235,.04); }
.nl-nav__action{ height:40px; border-radius:12px; padding:0 12px; font-weight:900; white-space:nowrap; }
.nl-nav__spacer{ flex:1 1 auto; }

@media (max-width: 991.98px){
  .nl-topbar__row{ flex-wrap:wrap; justify-content:flex-start; }
  .nl-topbar__right{ flex-wrap:wrap; }
  .nl-header__row{ flex-wrap:wrap; }
  .nl-header__actions{ width:100%; justify-content:flex-start; }
  .nl-header__search{ width:100%; min-width:0; }
}

/* --- Footer: responsive + cross-browser friendly --- */
.nl-footer{
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border-top:1px solid var(--border);
  margin-top:48px;
}

.nl-footer__top{ align-items:flex-start; }

.nl-footer__links li + li{ margin-top:8px; }
.nl-footer__links a{
  display:inline-block;
  line-height:1.35;
  overflow-wrap:anywhere;
}

.nl-footer__subscribe .input-group .form-control,
.nl-footer__subscribe .input-group .btn{
  min-height:42px;
}

.nl-footer__bottom{
  border-top:1px solid rgba(148,163,184,.25);
}

.nl-footer a:focus-visible,
.nl-footer button:focus-visible,
.nl-footer input:focus-visible{
  outline:2px solid rgba(37,99,235,.45);
  outline-offset:2px;
}

.nl-footer input[type="email"]{
  -webkit-appearance:none;
  appearance:none;
}

@media (max-width: 991.98px){
  .nl-footer{ margin-top:40px; }
  .nl-footer .nl-pill{ font-size:12px; }
}

@media (max-width: 575.98px){
  .nl-footer .container-xl{ padding-left:16px; padding-right:16px; }
  .nl-footer__subscribe .input-group{ flex-direction:column; }
  .nl-footer__subscribe .input-group .btn,
  .nl-footer__subscribe .input-group .form-control{
    width:100%;
    border-radius:12px !important;
  }
}

@media (prefers-reduced-motion: reduce){
  .nl-footer *,
  .nl-footer *::before,
  .nl-footer *::after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}

/* --- Global site adaptive + cross-browser baseline --- */
*, *::before, *::after { box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, svg, video, canvas {
  display: block;
  max-width: 100%;
  height: auto;
}

a, button, input, select, textarea {
  font: inherit;
}

button, input, select, textarea {
  -webkit-appearance: none;
  appearance: none;
}

input[type="checkbox"],
input[type="radio"] {
  -webkit-appearance: auto;
  appearance: auto;
}

.container, .container-sm, .container-md, .container-lg, .container-xl, .container-xxl {
  width: 100%;
}

[class*="col-"] {
  min-width: 0;
}

.nl-logo, .nl-link, .btn, .badge {
  overflow-wrap: anywhere;
}

.table-responsive {
  -webkit-overflow-scrolling: touch;
}

.ratio > * {
  object-fit: cover;
}

@supports not (gap: 1rem) {
  .d-flex > * + * {
    margin-left: .5rem;
  }
}

@media (max-width: 1199.98px) {
  .container-xl { max-width: 100%; }
}

@media (max-width: 991.98px) {
  .nl-section-title {
    font-size: clamp(24px, 4.6vw, 28px);
  }

  .nl-prod__actions {
    flex-wrap: wrap;
  }

  .nl-prod__actions .btn,
  .nl-qty {
    width: 100%;
  }

  .nl-header .btn,
  .nl-nav .btn,
  .nl-nav__link {
    min-height: 40px;
  }
}

@media (max-width: 767.98px) {
  .nl-search .btn,
  .nl-header__actions .btn {
    width: 100%;
  }

  .nl-surface,
  .nl-card {
    border-radius: 14px;
  }
}

@media (max-width: 575.98px) {
  .nl-topbar__left,
  .nl-topbar__right {
    width: 100%;
    justify-content: flex-start;
  }

  .nl-tabs {
    gap: 10px;
  }

  .nl-tabs a {
    font-size: 14px;
  }

  .nl-prod__title,
  .nl-cat-card__title {
    font-size: 16px;
  }
}


/* ===== assets/css/pages/home.css ===== */

/* pages/home.css
   - hero, quick-order overlap, home section spacing
*/

/* Full-width hero (background edge-to-edge) */
.nl-hero-full{
  position:relative;
  background:
    linear-gradient(90deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.78) 52%, rgba(255,255,255,.10) 100%),
    url("../img/hero-bg.jpg") center/cover no-repeat;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.nl-hero-full__inner{
  position:relative;
  border-radius: var(--r-lg);
  overflow:hidden;
  min-height: 420px;
  background: transparent;
}
.nl-hero-content{ position:relative; z-index:2; }

/* People image */
.nl-hero-full__inner .nl-hero-people{
  position:absolute;
  right:40px;
  bottom:-4px;
  width:min(460px, 42vw);
  height:auto;
  z-index:1;
  filter: drop-shadow(0 18px 40px rgba(15,23,42,.18));
}

/* Quick order overlap (over hero) */
.nl-quickbar{
  margin-top:-34px;
  position:relative;
  z-index: 5;
}
@media (max-width: 991.98px){
  .nl-hero-full__inner{ min-height: 380px; }
  .nl-quickbar{ margin-top:-18px; }
}


/* ===== assets/css/pages/brands.css ===== */

.brand-chip {
  display: block;
  padding: 12px 14px;
  border: 1px solid #d7e3f4;
  border-radius: 12px;
  color: #0d3b82;
  text-decoration: none;
  font-weight: 600;
  text-align: center;
  background: #f4f8ff;
}

.brand-chip:hover {
  background: #eaf2ff;
}

.brand-card {
  height: 100%;
  border: 1px solid #e9ecef;
  border-radius: 14px;
  padding: 16px;
  background: #fff;
}


/* ===== assets/css/pages/cart.css ===== */

.cart-item {
  display: grid;
  grid-template-columns: 110px 1fr auto;
  gap: 16px;
  align-items: center;
  border: 1px solid #e9ecef;
  border-radius: 14px;
  padding: 14px;
  background: #fff;
}

.cart-page-root,
[data-cart-page-root] {
  position: relative;
  transition: opacity .18s ease;
}

[data-cart-page-root].is-loading {
  opacity: .72;
  pointer-events: none;
}

.cart-item__img {
  width: 100%;
  height: 90px;
  object-fit: contain;
  background: #f8fafc;
  border-radius: 10px;
  padding: 8px;
}

.cart-item__qty-form {
  margin: 0;
}

.cart-item__qty-input {
  width: 96px;
}

.qty-pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  background: #f1f5f9;
  font-size: 14px;
}

.order-summary {
  border: 1px solid #e9ecef;
}

.order-total {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.1;
}

@media (max-width: 768px) {
  .cart-item {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .cart-item__img {
    width: 100%;
    max-width: 180px;
    height: 120px;
  }

  .cart-item__qty-input {
    width: 100%;
    max-width: 140px;
  }
}


/* ===== assets/css/pages/category.css ===== */

.sort-select {
  min-width: 230px;
}

.sticky-filters {
  position: sticky;
  top: 96px;
}

.catalog-card {
  height: 100%;
  border: 1px solid #e9ecef;
  border-radius: 14px;
  padding: 14px;
  background: #fff;
}

.catalog-card__img {
  width: 100%;
  height: 180px;
  object-fit: contain;
  background: #f8fafc;
  border-radius: 10px;
  padding: 12px;
}


/* ===== assets/css/pages/checkout.css ===== */

.checkout-card {
  border: 1px solid #e9ecef;
  border-radius: 14px;
  padding: 18px;
  background: #fff;
}

.delivery-option {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  border: 1px solid #e9ecef;
  border-radius: 12px;
  padding: 10px 12px;
  background: #fff;
}

.order-summary {
  border: 1px solid #e9ecef;
}

.order-total {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.1;
}


/* ===== assets/css/pages/info.css ===== */

.info-hero {
  background: linear-gradient(120deg, #f4f8ff, #edf2ff);
}

.contact-box {
  border: 1px solid #d7e3f4;
  background: #f8fbff;
}


/* ===== assets/css/pages/lk.css ===== */

.account-form {
  border: 1px solid #e9ecef;
  border-radius: 14px;
  padding: 18px;
  background: #fff;
}

.hint-box {
  border-radius: 14px;
  padding: 16px;
  background: #f4f8ff;
  color: #344054;
}

.lk-stat {
  border: 1px solid #e9ecef;
  border-radius: 14px;
  padding: 16px;
  background: #fff;
}

.lk-shell {
  overflow: hidden;
}

.lk-eyebrow {
  margin-bottom: 8px;
  color: #2563eb;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.lk-company-banner {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  padding: 18px 20px;
  border: 1px solid #d7e3f4;
  border-radius: 16px;
  background: linear-gradient(135deg, #f8fbff, #eef4ff);
}

.lk-chip-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.lk-chip {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(37, 99, 235, .08);
  border: 1px solid rgba(37, 99, 235, .18);
  color: #1d4ed8;
  font-size: 13px;
  font-weight: 700;
}

.lk-nav {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.lk-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid #d7e3f4;
  border-radius: 12px;
  background: #fff;
  color: #0f172a;
  text-decoration: none;
  font-weight: 700;
}

.lk-nav__link:hover {
  color: #2563eb;
  border-color: rgba(37, 99, 235, .24);
  background: rgba(37, 99, 235, .04);
}

.lk-nav__link.is-active {
  border-color: #2563eb;
  background: #2563eb;
  color: #fff;
}

.lk-nav__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 7px;
  border-radius: 999px;
  background: rgba(15, 23, 42, .08);
  color: inherit;
  font-size: 12px;
  font-weight: 800;
}

.lk-nav__link.is-active .lk-nav__count {
  background: rgba(255, 255, 255, .18);
}

.lk-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.lk-table-note {
  margin-top: 4px;
  color: #64748b;
  font-size: 12px;
}

.lk-empty {
  padding: 8px 0;
  color: #0f172a;
}

.lk-meta-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
  font-size: 14px;
}

.lk-meta-list li {
  color: #344054;
}

.lk-side-card {
  border: 1px solid #e9ecef;
  border-radius: 12px;
  padding: 12px;
  background: #fff;
}

.lk-action-card {
  display: block;
  height: 100%;
  padding: 16px;
  border: 1px solid #d7e3f4;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  color: #0f172a;
  text-decoration: none;
}

.lk-action-card:hover {
  border-color: rgba(37, 99, 235, .28);
  color: #0f172a;
  box-shadow: 0 12px 28px rgba(37, 99, 235, .08);
}

.lk-approval-steps {
  display: grid;
  gap: 10px;
}

.lk-approval-step {
  padding: 12px;
  border: 1px solid #e9ecef;
  border-radius: 12px;
  background: #f8fafc;
}

.lk-back-link {
  color: #2563eb;
  text-decoration: none;
  font-weight: 700;
}

.lk-back-link:hover {
  color: #1d4ed8;
}

.lk-entity-link {
  color: #0f172a;
  text-decoration: none;
}

.lk-entity-link:hover {
  color: #2563eb;
}

.lk-inline-note {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: #f1f5f9;
  color: #334155;
  font-size: 13px;
  font-weight: 600;
}

.lk-detail-card {
  height: 100%;
  padding: 14px;
  border: 1px solid #e9ecef;
  border-radius: 14px;
  background: #fff;
}

.lk-timeline {
  display: grid;
  gap: 16px;
}

.lk-timeline__item {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 12px;
}

.lk-timeline__dot {
  width: 12px;
  height: 12px;
  margin-top: 5px;
  border-radius: 999px;
  background: #2563eb;
  box-shadow: 0 0 0 4px rgba(37, 99, 235, .12);
}

.lk-timeline__content {
  padding-bottom: 14px;
  border-bottom: 1px solid #e9ecef;
}

.lk-timeline__item:last-child .lk-timeline__content {
  padding-bottom: 0;
  border-bottom: 0;
}

@media (max-width: 991.98px) {
  .lk-company-banner {
    flex-direction: column;
  }

  .lk-chip-row {
    justify-content: flex-start;
  }
}

@media (max-width: 767.98px) {
  .lk-nav {
    gap: 8px;
  }

  .lk-nav__link {
    width: 100%;
    justify-content: space-between;
  }

  .lk-section-head {
    flex-direction: column;
  }
}


/* ===== assets/css/pages/product.css ===== */

.product-gallery {
  border: 1px solid #e9ecef;
  border-radius: 16px;
  padding: 18px;
  background: #f8fafc;
}

.product-main-image {
  width: 100%;
  max-height: 420px;
  object-fit: contain;
}

.price-block {
  padding: 14px 16px;
  border-radius: 12px;
  background: #f4f8ff;
}

.price-main {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.1;
}

.feature-box {
  border: 1px solid #e9ecef;
  border-radius: 12px;
  padding: 16px;
  background: #fff;
}



/* ===== UX polish: stable rendering + no click highlight ===== */
:root{
  --nl-ease: cubic-bezier(.2,.8,.2,1);
}

*{
  -webkit-tap-highlight-color: transparent;
}

a, button, .btn, .nl-card, .nl-pill, .nl-toolbar__chipbtn, .nl-nav__link{
  transition: box-shadow .2s var(--nl-ease), background-color .2s var(--nl-ease), color .2s var(--nl-ease), border-color .2s var(--nl-ease);
}

a:focus,
a:active,
button:focus,
button:active,
.btn:focus,
.btn:active{
  outline: none !important;
  box-shadow: none !important;
}

.nl-prod:hover,
.nl-card:hover{
  box-shadow: 0 14px 28px rgba(15, 23, 42, .10);
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}


/* ===== Mobile readability cleanup ===== */
@media (max-width: 767.98px){
  /* Top line: keep only key contact */
  .nl-topline .container-xl{ gap:8px !important; }
  .nl-topline .container-xl > .d-flex:first-child > .nl-pill:first-child,
  .nl-topline .container-xl > .d-flex:first-child .dropdown,
  .nl-topline .container-xl > .d-flex:last-child{
    display:none !important;
  }

  /* Header: less visual noise */
  .nl-logo__sub{ display:none !important; }
  .nl-header .col-12.col-lg-3.d-flex{ flex-wrap:wrap; }
  .nl-header .col-12.col-lg-3.d-flex .btn{ flex:1 1 auto; }
  .nl-header .col-12.col-lg-3.d-flex .btn.btn-primary{ display:none !important; } /* hide duplicate registration CTA */
  .nl-header .badge{ font-size:10px; padding:.25em .45em; }

  /* Search block compact */
  .nl-search .form-control{ font-size:14px; }
  .nl-suggest .border-top.small.text-secondary{ display:none; }

  /* Toolbar: keep only primary actions */
  .nl-toolbar__row{ gap:6px; }
  .nl-toolbar__chipbtn:nth-of-type(n+4){ display:none !important; }
  .nl-toolbar__btn{ height:36px; border-radius:12px; }

  /* Hero: keep headline + core CTA */
  .nl-hero__badges,
  .nl-hero .small.text-secondary.mt-3,
  .nl-hero .nl-hero__dept{
    display:none !important;
  }
  .nl-hero__cta .btn + .btn{ display:none !important; }
  .nl-hero__h2,
  .nl-hero h1{ font-size:28px !important; line-height:1.15; }
  .nl-hero__subtitle{ font-size:15px; }

  /* Cards and dense meta text */
  .nl-prod__meta{ font-size:12px; }
}


/* Toolbar sticky fallback (follows page on scroll) */
.nl-toolbar--sticky.is-fixed{
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 1100;
  box-shadow: 0 10px 24px rgba(15,23,42,.12);
}
.nl-toolbar-spacer{ width:100%; }
.lk-approval-route {
  display: grid;
  gap: 12px;
}

.lk-approval-step.is-current {
  border-color: rgba(37, 99, 235, .36);
  background: linear-gradient(180deg, #ffffff, #f3f8ff);
  box-shadow: 0 12px 24px rgba(37, 99, 235, .08);
}

.lk-decision-log {
  padding: 14px;
  border: 1px solid #e9ecef;
  border-radius: 14px;
  background: #f8fafc;
  color: #334155;
}

.btn-outline-danger {
  border-color: rgba(239, 68, 68, .25);
  color: #b91c1c;
  background: #fff;
}

.btn-outline-danger:hover {
  border-color: #dc2626;
  color: #fff;
  background: #dc2626;
}


/* ===== Home page 2026 refresh ===== */
.home-page {
  background:
    radial-gradient(circle at top left, rgba(37, 99, 235, .08), transparent 28%),
    linear-gradient(180deg, #f4f7ff 0%, #f8fbff 28%, #ffffff 100%);
}

.home-hero__slider {
  position: relative;
}

.home-hero__slide {
  min-height: 560px;
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 28px;
  padding: 38px;
  background-size: cover;
  background-position: center;
  box-shadow: 0 24px 60px rgba(15, 23, 42, .12);
}

.home-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .88);
  border: 1px solid rgba(37, 99, 235, .14);
  color: #1d4ed8;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.home-hero__title {
  margin: 20px 0 16px;
  font-size: clamp(34px, 5vw, 62px);
  line-height: 1.02;
  font-weight: 900;
  max-width: 11ch;
}

.home-hero__subtitle {
  max-width: 620px;
  font-size: 18px;
  line-height: 1.55;
  color: #475569;
}

.home-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.home-hero__actions .btn {
  min-width: 190px;
  font-weight: 800;
}

.home-hero__aside {
  display: grid;
  gap: 16px;
}

.home-hero__illustration {
  min-height: 240px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255, 255, 255, .78);
  border: 1px solid rgba(255, 255, 255, .72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .65);
}

.home-hero__illustration img {
  width: 100%;
  height: 100%;
  max-height: 280px;
  object-fit: contain;
}

.home-hero__metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.home-metric {
  padding: 16px;
  border-radius: 20px;
  background: rgba(255, 255, 255, .9);
  border: 1px solid rgba(148, 163, 184, .18);
}

.home-metric__value {
  font-size: 28px;
  line-height: 1;
  font-weight: 900;
  color: #0f172a;
}

.home-metric__label {
  margin-top: 6px;
  font-size: 13px;
  color: #475569;
}

.home-hero__indicators {
  position: absolute;
  right: 24px;
  bottom: 20px;
  left: auto;
  margin: 0;
  gap: 8px;
}

.home-hero__indicators button {
  width: 12px !important;
  height: 12px !important;
  border-radius: 999px;
  border: 0;
  background: rgba(15, 23, 42, .18);
}

.home-hero__indicators .active {
  background: #2563eb;
}

.home-hero__control {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: rgba(255, 255, 255, .92);
  color: #0f172a;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .16);
}

.home-quick__card,
.home-panel {
  border: 1px solid rgba(148, 163, 184, .14);
  border-radius: 28px;
  background: rgba(255, 255, 255, .94);
  box-shadow: 0 22px 54px rgba(15, 23, 42, .08);
  padding: 28px;
}

.home-quick__title,
.home-section__title {
  margin: 8px 0 10px;
  font-size: clamp(26px, 4vw, 40px);
  font-weight: 900;
  line-height: 1.08;
}

.home-section__eyebrow {
  color: #2563eb;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.home-quick__hint,
.home-section__subtitle {
  max-width: 760px;
  color: #64748b;
  font-size: 15px;
  line-height: 1.6;
}

.home-quick__input-group {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 12px;
  margin-top: 20px;
}

.home-quick__input {
  min-height: 52px;
  border-radius: 16px;
}

.home-quick__input-group .btn {
  min-height: 52px;
  font-weight: 800;
}

.home-quick__stats {
  display: grid;
  gap: 12px;
}

.home-quick__stat {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  border: 1px solid rgba(148, 163, 184, .14);
}

.home-quick__stat span {
  color: #64748b;
  font-size: 14px;
}

.home-quick__stat strong {
  font-size: 18px;
  font-weight: 900;
}

.home-section__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 20px;
}

.home-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.home-tabs a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, .16);
  background: rgba(255, 255, 255, .92);
  color: #334155;
  text-decoration: none;
  font-weight: 700;
}

.home-tabs a.active,
.home-tabs a:hover {
  color: #2563eb;
  border-color: rgba(37, 99, 235, .24);
  background: rgba(37, 99, 235, .08);
}

.home-product-card,
.home-category-card,
.home-cert-card,
.home-step-card,
.home-contact-card {
  height: 100%;
  border: 1px solid rgba(148, 163, 184, .14);
  border-radius: 24px;
  background: rgba(255, 255, 255, .96);
  box-shadow: 0 18px 44px rgba(15, 23, 42, .06);
  overflow: hidden;
}

.home-product-card__media,
.home-category-card__media {
  height: 200px;
  background: linear-gradient(180deg, #f8fbff, #eef4ff);
}

.home-product-card__media img,
.home-category-card__media img,
.home-cert-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home-product-card__body,
.home-category-card__body {
  padding: 20px;
}

.home-product-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.home-tag {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(37, 99, 235, .12);
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 800;
}

.home-tag--soft {
  background: rgba(15, 23, 42, .06);
  color: #334155;
}

.home-product-card__title,
.home-category-card__title,
.home-info-card__title,
.home-step-card__title,
.home-contact-card__title {
  font-size: 20px;
  line-height: 1.2;
  font-weight: 900;
}

.home-product-card__meta,
.home-product-card__stock,
.home-category-card__text,
.home-info-card__text,
.home-step-card__text,
.home-contact-card__text {
  margin-top: 8px;
  color: #64748b;
  line-height: 1.6;
}

.home-product-card__price,
.home-category-card__price {
  margin-top: 16px;
  font-size: 26px;
  line-height: 1;
  font-weight: 900;
}

.home-product-card__actions {
  margin-top: 18px;
}

.home-category-card__placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #2563eb;
  font-size: 42px;
}

.home-category-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 18px;
}

.home-category-card__footer .btn {
  font-weight: 800;
}

.home-info-card {
  display: flex;
  gap: 14px;
  min-height: 100%;
  padding: 18px;
  border: 1px solid rgba(148, 163, 184, .12);
  border-radius: 20px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
}

.home-info-card--light {
  background: #fff;
}

.home-info-card__icon,
.home-step-card__icon {
  width: 46px;
  height: 46px;
  flex: 0 0 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: rgba(37, 99, 235, .10);
  color: #2563eb;
  font-size: 20px;
}

.home-info-card__meta {
  margin-top: 10px;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.home-certs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.home-cert-card {
  padding: 0;
  text-align: left;
  cursor: pointer;
}

.home-cert-card__media {
  height: 152px;
  background: linear-gradient(180deg, #f8fbff, #eef4ff);
}

.home-cert-card__body {
  display: grid;
  gap: 6px;
  padding: 16px;
}

.home-cert-card__body small {
  color: #64748b;
}

.home-step-card,
.home-contact-card {
  display: flex;
  gap: 14px;
  padding: 18px;
}

.home-step-card__body,
.home-contact-card__meta {
  display: grid;
  gap: 6px;
}

.home-panel--cta {
  background:
    radial-gradient(circle at top right, rgba(37, 99, 235, .12), transparent 30%),
    linear-gradient(180deg, #ffffff, #f8fbff);
}

.home-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
}

.home-cta__actions .btn {
  min-width: 180px;
  font-weight: 800;
}

.home-contact-list {
  display: grid;
  gap: 12px;
}

.home-contact-card__meta a {
  display: inline-flex;
  margin-right: 14px;
}

@media (max-width: 991.98px) {
  .home-hero__slide {
    min-height: 0;
    padding: 24px;
  }

  .home-hero__metrics {
    grid-template-columns: 1fr;
  }

  .home-section__head {
    flex-direction: column;
    align-items: flex-start;
  }

  .home-certs {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767.98px) {
  .home-quick__input-group {
    grid-template-columns: 1fr;
  }

  .home-category-card__footer,
  .home-cta__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .home-panel,
  .home-quick__card,
  .home-hero__slide {
    border-radius: 22px;
    padding: 20px;
  }

  .home-product-card__title,
  .home-category-card__title,
  .home-info-card__title,
  .home-step-card__title,
  .home-contact-card__title {
    font-size: 18px;
  }
}

/* Legacy home polish */
.nl-home-hero-dept {
  width: min(360px, 92%);
  padding: 22px 22px 18px;
  background: rgba(255, 255, 255, .86);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(148, 163, 184, .26);
  box-shadow: 0 20px 48px rgba(15, 23, 42, .18);
  border-radius: 24px;
}

.nl-home-quick-summary {
  background: linear-gradient(180deg, rgba(255, 255, 255, .92), rgba(243, 247, 255, .92));
}

.nl-home-hero-links {
  display: grid;
  gap: 10px;
}

.nl-home-hero-links a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 16px;
  text-decoration: none;
  font-weight: 700;
  color: var(--text);
  background: rgba(255, 255, 255, .78);
  border: 1px solid rgba(148, 163, 184, .20);
}

.nl-home-hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.nl-home-hero-stat {
  display: grid;
  gap: 4px;
  padding: 12px 10px;
  border-radius: 16px;
  background: rgba(244, 247, 255, .88);
  border: 1px solid rgba(148, 163, 184, .16);
}

.nl-home-hero-stat strong {
  font-size: 18px;
  line-height: 1;
}

.nl-home-hero-stat span {
  color: var(--muted);
  font-size: 11px;
}

.nl-home-preview-table .table {
  margin-bottom: 0;
}

.nl-home-preview-table tbody tr:last-child td {
  border-bottom: 0;
}

.nl-home-doc-card,
.nl-home-contact-card {
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(247, 250, 255, .96));
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.nl-home-doc-card {
  height: 100%;
  display: flex;
  flex-direction: column;
}

.nl-home-doc-card__row {
  width: 100%;
  height: 100%;
}

.nl-home-doc-card__body {
  display: flex;
  flex: 1 1 auto;
  min-height: 100%;
  flex-direction: column;
}

.nl-home-doc-card__meta {
  margin-top: auto !important;
}

.nl-home-doc-card__head {
  display: flex;
  align-items: center;
  gap: 14px;
}

.nl-home-doc-card__head .nl-home-info-icon {
  margin-bottom: 0;
}

.nl-home-doc-card:hover,
.nl-home-contact-card:hover {
  transform: translateY(-2px);
  border-color: rgba(37, 99, 235, .22);
  box-shadow: 0 16px 34px rgba(15, 23, 42, .08);
}

.nl-home-info-icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(37, 99, 235, .10);
  border: 1px solid rgba(37, 99, 235, .16);
  color: #1d4ed8;
  font-size: 18px;
  flex: 0 0 auto;
}

.nl-home-cta {
  background:
    radial-gradient(circle at top right, rgba(37, 99, 235, .12), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(244, 248, 255, .98));
}

@media (max-width: 991.98px) {
  .nl-home-hero-dept {
    position: relative;
    width: 100%;
    top: auto;
    right: auto;
    margin-top: 16px;
  }

  .nl-home-hero-stats {
    grid-template-columns: 1fr;
  }
}

/* Header/topline alignment overrides */
.nl-topline__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: nowrap;
}

.nl-topline__group {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  min-width: max-content;
}

.nl-topline__group--meta {
  margin-left: auto;
}

.nl-topline__group .nl-pill {
  white-space: nowrap;
}

.nl-header__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: nowrap;
}

.nl-header__brand {
  flex: 0 0 300px;
  min-width: 0;
}

.nl-header__search {
  flex: 1 1 520px;
  min-width: 280px;
}

.nl-header__actions > * {
  flex: 0 0 auto;
}

.nl-header__actions .btn,
.nl-header__actions form .btn {
  white-space: nowrap;
}

.nl-header-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  line-height: 1;
}

.nl-header-action-btn i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-size: 15px;
  flex: 0 0 auto;
}

.nl-cart-btn {
  padding-right: 18px;
}

.nl-cart-badge {
  top: -9px;
  right: -6px;
  left: auto;
  transform: none;
  min-width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 11px;
  padding: 0 6px;
}

.nl-cart-btn .nl-cart-badge {
  position: absolute;
  top: -9px;
  right: -6px;
}

@media (max-width: 1199.98px) {
  .nl-topline__row {
    flex-wrap: wrap;
  }

  .nl-topline__group {
    flex-wrap: wrap;
    min-width: 0;
  }

  .nl-topline__group--meta {
    margin-left: 0;
  }
}

@media (max-width: 991.98px) {
  .nl-header__row {
    flex-wrap: wrap;
  }

  .nl-header__brand,
  .nl-header__search,
  .nl-header__actions {
    width: 100%;
    flex: 1 1 100%;
  }

  .nl-header__actions {
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .nl-header__actions > * {
    flex: initial;
  }
}

.nl-home-quick-form {
  display: block;
}

.nl-quickbar {
  position: relative;
  transition: opacity .18s ease;
}

.nl-quickbar.is-loading {
  opacity: .72;
  pointer-events: none;
}

.nl-home-quick-messages .alert:last-child {
  margin-bottom: 0;
}

.nl-home-quick-input .btn {
  min-width: 148px;
}

.nl-home-quick-live-table {
  margin-bottom: 0;
  min-width: 1080px;
}

.nl-home-quick-live-table th,
.nl-home-quick-live-table td {
  vertical-align: middle;
}

.nl-home-quick-row-form {
  margin: 0;
}

.nl-home-quick-qty {
  display: flex;
  align-items: center;
  gap: 10px;
}

.nl-home-quick-qty input {
  max-width: 112px;
}

.nl-home-quick-money,
.nl-home-quick-discount {
  white-space: nowrap;
}

.nl-home-quick-discount {
  color: var(--muted);
}

.nl-home-quick-actions {
  display: inline-flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.nl-home-quick-actions form {
  margin: 0;
}

.nl-home-quick-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.nl-home-quick-empty {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 22px;
  border: 1px dashed rgba(148, 163, 184, .42);
  border-radius: 18px;
  background: rgba(248, 250, 252, .82);
}

@media (max-width: 767.98px) {
  .nl-home-quick-qty,
  .nl-home-quick-actions,
  .nl-home-quick-footer,
  .nl-home-quick-empty {
    width: 100%;
    justify-content: flex-start;
  }

  .nl-home-quick-input {
    flex-direction: column;
  }

  .nl-home-quick-input .btn,
  .nl-home-quick-qty input {
    width: 100%;
    max-width: none;
  }

  .nl-home-quick-live-table {
    min-width: 920px;
  }
}

/* Search suggestions must overlay the sticky toolbar */
.nl-header {
  position: relative;
  z-index: 1110;
}

.nl-header__search {
  position: relative;
  z-index: 1120;
}

.nl-header__search > form {
  position: relative;
  z-index: 1120;
}

.nl-header__search .nl-suggest,
#searchSuggest {
  z-index: 1400;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

/* Search suggest refresh */
.nl-header__search .nl-suggest,
#searchSuggest {
  top: calc(100% + 10px);
  padding: 0;
  border: 1px solid rgba(148, 163, 184, .22);
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(246, 249, 255, .98));
  box-shadow: 0 24px 54px rgba(15, 23, 42, .18);
  overflow: hidden;
}

.nl-suggest__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px 12px;
  background: linear-gradient(180deg, rgba(244, 247, 255, .92), rgba(255, 255, 255, .95));
  border-bottom: 1px solid rgba(148, 163, 184, .18);
}

.nl-suggest__eyebrow {
  font-size: 11px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #2563eb;
}

.nl-suggest__title {
  margin-top: 6px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 15px;
  line-height: 1.2;
  font-weight: 900;
  color: #0f172a;
}

.nl-suggest__close {
  width: 34px;
  height: 34px;
  min-width: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1px solid rgba(148, 163, 184, .24);
  background: rgba(255, 255, 255, .9);
  color: #64748b;
}

.nl-suggest__close:hover {
  border-color: rgba(37, 99, 235, .28);
  background: rgba(37, 99, 235, .06);
  color: #2563eb;
}

.nl-suggest__list {
  max-height: 360px;
  overflow: auto;
  padding: 8px;
}

.nl-suggest__item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 12px;
  border: 0;
  border-radius: 16px;
  cursor: pointer;
  transition: transform .14s ease, background-color .14s ease, box-shadow .14s ease;
}

.nl-suggest__item + .nl-suggest__item {
  margin-top: 4px;
}

.nl-suggest__item:hover,
.nl-suggest__item[aria-selected="true"] {
  background: linear-gradient(180deg, rgba(37, 99, 235, .08), rgba(37, 99, 235, .04));
  box-shadow: inset 0 0 0 1px rgba(37, 99, 235, .12);
  transform: translateY(-1px);
}

.nl-suggest__badge {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(241, 245, 249, .95);
  border: 1px solid rgba(148, 163, 184, .18);
  color: #334155;
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}

.nl-suggest__content {
  min-width: 0;
}

.nl-suggest__topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.nl-suggest__name {
  font-size: 15px;
  line-height: 1.3;
  font-weight: 800;
  color: #0f172a;
}

.nl-suggest__go {
  width: 26px;
  height: 26px;
  flex: 0 0 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(255, 255, 255, .88);
  border: 1px solid rgba(148, 163, 184, .18);
  color: #64748b;
}

.nl-suggest__item:hover .nl-suggest__go,
.nl-suggest__item[aria-selected="true"] .nl-suggest__go {
  color: #2563eb;
  border-color: rgba(37, 99, 235, .24);
}

.nl-suggest__meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}

.nl-suggest__meta-chip {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(248, 250, 252, .96);
  border: 1px solid rgba(226, 232, 240, .95);
  color: #64748b;
  font-size: 12px;
  line-height: 1;
}

.nl-suggest__hl {
  color: #2563eb;
  font-weight: 900;
}

.nl-suggest__state {
  min-height: 116px;
  display: grid;
  place-items: center;
  gap: 10px;
  padding: 20px 16px;
  text-align: center;
}

.nl-suggest__state-icon {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: rgba(37, 99, 235, .08);
  border: 1px solid rgba(37, 99, 235, .16);
  color: #2563eb;
  font-size: 18px;
}

.nl-suggest__state-text {
  color: #64748b;
  font-size: 13px;
  line-height: 1.5;
}

.nl-suggest__foot {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 12px 16px 14px;
  border-top: 1px solid rgba(148, 163, 184, .18);
  background: rgba(255, 255, 255, .92);
}

.nl-suggest__hint {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(241, 245, 249, .96);
  border: 1px solid rgba(226, 232, 240, .9);
  color: #64748b;
  font-size: 12px;
  line-height: 1;
}

@media (max-width: 767.98px) {
  .nl-suggest__head {
    padding: 12px 14px 10px;
  }

  .nl-suggest__list {
    padding: 6px;
  }

  .nl-suggest__item {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .nl-suggest__topline {
    gap: 10px;
  }

  .nl-suggest__foot {
    display: none;
  }
}

/* Auth modal */
.nl-auth-modal .modal-content {
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(37, 99, 235, .10), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(246, 249, 255, .98));
  box-shadow: 0 28px 70px rgba(15, 23, 42, .18);
}

.nl-auth-modal .modal-header,
.nl-auth-modal .modal-body {
  padding-left: 24px;
  padding-right: 24px;
}

.nl-auth-modal__eyebrow {
  font-size: 11px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #2563eb;
}

.nl-auth-modal__modes {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.nl-auth-modal__mode {
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid rgba(148, 163, 184, .22);
  border-radius: 999px;
  background: rgba(255, 255, 255, .92);
  color: #334155;
  font-size: 13px;
  font-weight: 700;
}

.nl-auth-modal__mode.is-active {
  border-color: rgba(37, 99, 235, .26);
  background: rgba(37, 99, 235, .08);
  color: #1d4ed8;
}

.nl-auth-modal .form-control {
  min-height: 48px;
  border-radius: 14px;
}

.nl-auth-modal .btn-lg {
  min-height: 50px;
  border-radius: 14px;
}

@media (max-width: 575.98px) {
  .nl-auth-modal .modal-header,
  .nl-auth-modal .modal-body {
    padding-left: 18px;
    padding-right: 18px;
  }

  .nl-auth-modal__modes {
    display: grid;
    grid-template-columns: 1fr;
  }
}

/* Registration lookup */
.nl-company-lookup {
  padding: 20px;
  border: 1px solid rgba(148, 163, 184, .22);
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(37, 99, 235, .08), transparent 34%),
    linear-gradient(180deg, rgba(248, 250, 252, .98), rgba(255, 255, 255, .98));
}

.nl-company-lookup__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.nl-company-lookup__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.nl-company-lookup__chip {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .9);
  border: 1px solid rgba(148, 163, 184, .18);
  color: #475569;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.nl-company-lookup__alert {
  border-radius: 16px;
}

.nl-registration-section .btn {
  min-height: 48px;
  border-radius: 14px;
}

.nl-registration-form > [class*="col-"],
.nl-company-lookup .row > [class*="col-"] {
  display: flex;
  flex-direction: column;
}

.nl-registration-form .form-control,
.nl-registration-form .form-select {
  min-height: 48px;
  border-radius: 14px;
}

.nl-registration-form textarea.form-control,
.nl-company-lookup textarea.form-control {
  min-height: 108px;
}

.nl-registration-form .form-label,
.nl-company-lookup .form-label {
  margin-bottom: 8px;
  font-weight: 700;
}

.nl-registration-form .text-danger.small,
.nl-company-lookup .text-danger.small,
.nl-form-feedback {
  display: block;
  margin-top: 6px !important;
  font-size: 12px;
  line-height: 1.35;
}

.nl-form-feedback {
  color: #dc3545;
}

.nl-registration-form__check {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 4px;
  padding-top: 2px;
}

.nl-registration-form__check .form-check-input {
  flex: 0 0 auto;
  margin: 4px 0 0;
  float: none;
}

.nl-registration-form__check-body {
  flex: 1 1 auto;
  min-width: 0;
}

.nl-registration-form__check .form-check-label {
  margin: 0;
  line-height: 1.5;
}

.nl-registration-form__actions {
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.nl-registration-form__actions .btn {
  min-height: 48px;
  border-radius: 14px;
}

.nl-registration-form__actions .small {
  max-width: 560px;
}

.nl-company-lookup .form-control[readonly],
.nl-company-lookup .form-control[readonly]:focus {
  background: #f8fafc;
  color: #0f172a;
}

[data-company-lookup-trigger].is-loading,
[data-bank-lookup-trigger].is-loading {
  opacity: .75;
  pointer-events: none;
}

@media (max-width: 767.98px) {
  .nl-company-lookup {
    padding: 16px;
  }

  .nl-registration-form__actions {
    align-items: stretch;
  }
}
