/* ==========================================================================
   PRODUCT HEADER — 3 varijante (pill / sidebar / minimal)
   Boje preko CSS varijabli (--pc, --ink, --line) koje postavlja svaki product CSS.
   Header tema (svijetli/tamni) po body klasi proizvoda.
   ========================================================================== */

/* ---- Tema boja header-a po proizvodu ---- */
body.product-basic, body.product-dms {
  --hdr-bg: rgba(255,255,255,.82);
  --hdr-bg-solid: #ffffff;
  --hdr-text: var(--ink);
  --hdr-muted: var(--muted);
  --hdr-border: var(--line);
  --hdr-burger: var(--ink);
}
body.product-smart {
  --hdr-bg: rgba(10,20,36,.78);
  --hdr-bg-solid: #0b1929;
  --hdr-text: #ffffff;
  --hdr-muted: rgba(255,255,255,.78);
  --hdr-border: rgba(255,255,255,.12);
  --hdr-burger: #ffffff;
}

/* Reset zajedničkih elemenata */
.pp-overlay { display: none; }

/* .pp-btn fallback za DMS/Smart (samo BASIC ga ima u svom CSS-u) */
body.product-dms .pp-btn, body.product-smart .pp-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--pc); color: #fff; text-decoration: none;
  font-weight: 600; font-size: 15px; padding: 14px 26px;
  border-radius: 999px; border: 0; cursor: pointer;
  transition: background .2s, transform .2s, box-shadow .2s;
}
body.product-dms .pp-btn:hover, body.product-smart .pp-btn:hover {
  background: var(--pc-hover, var(--pc)); transform: translateY(-2px);
}
body.product-dms .pp-btn--sm, body.product-smart .pp-btn--sm { padding: 10px 20px; font-size: 14px; }
body.product-smart .pp-btn { box-shadow: 0 8px 24px rgba(14,165,233,.35); }

/* ==========================================================================
   1) FLOATING PILL
   ========================================================================== */
.pp-header--pill {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: transparent; backdrop-filter: none; border: 0; box-shadow: none;
  padding-top: 18px;
}
.pp-header--pill.pp-header--scrolled { box-shadow: none; }
.pp-header--pill .pp-header__inner {
  height: auto; padding: 0;
  width: min(1180px, 94%); margin-inline: auto;
}
.pp-header--pill .pp-header__inner > * { position: relative; z-index: 1; }
.pp-header--pill .pp-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--hdr-bg);
  border: 1px solid var(--hdr-border);
  border-radius: 999px;
  padding: 10px 12px 10px 24px;
  box-shadow: 0 10px 40px rgba(15,27,51,.10);
  backdrop-filter: saturate(180%) blur(14px);
  transition: box-shadow .25s, transform .25s;
}
.pp-header--pill.pp-header--scrolled .pp-header__inner {
  box-shadow: 0 14px 50px rgba(15,27,51,.16);
}
body.product-smart .pp-header--pill .pp-header__inner { box-shadow: 0 10px 40px rgba(0,0,0,.4); }
.pp-header--pill .pp-nav { gap: 26px; }
.pp-header--pill .pp-nav a { color: var(--hdr-text); }
.pp-header--pill .pp-nav a:hover { color: var(--pc); }
body.product-smart .pp-header--pill .pp-nav a:hover { color: var(--pc-bright, var(--pc)); }
.pp-header--pill .pp-logo { display: inline-flex; align-items: center; flex-shrink: 0; }
.pp-header--pill .pp-logo__img { width: auto !important; height: 44px !important; max-width: 150px !important; object-fit: contain; }

/* ==========================================================================
   2) SIDEBAR (vertikalan, lebdi lijevo)
   ========================================================================== */
.pp-header--sidebar {
  position: fixed; top: 0; left: 0; bottom: 0; right: auto; z-index: 100;
  width: 92px; height: 100vh;
  background: var(--hdr-bg-solid);
  border-right: 1px solid var(--hdr-border);
  box-shadow: 4px 0 30px rgba(15,27,51,.05);
  transition: width .3s cubic-bezier(.22,1,.36,1);
  overflow: hidden;
}
.pp-header--sidebar:hover { width: 230px; }
.pp-header--sidebar .pp-header__inner {
  width: 100%; height: 100%; padding: 28px 0;
  flex-direction: column; align-items: stretch; justify-content: flex-start;
}
.pp-header--sidebar .pp-logo {
  padding: 0 26px; margin-bottom: 44px; height: 44px;
  display: flex; align-items: center; overflow: hidden;
}
.pp-header--sidebar .pp-logo__img {
  width: 130px !important; max-width: none !important;
}
.pp-header--sidebar .pp-nav {
  flex-direction: column; align-items: stretch; gap: 4px; flex: 1;
}
.pp-header--sidebar .pp-nav a {
  display: flex; align-items: center; gap: 14px;
  color: var(--hdr-muted); font-weight: 600; font-size: 15px;
  padding: 14px 28px; white-space: nowrap; position: relative;
}
.pp-header--sidebar .pp-nav a::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--hdr-border); flex-shrink: 0; transition: background .2s, transform .2s;
}
.pp-header--sidebar .pp-nav a:hover { color: var(--pc); }
.pp-header--sidebar .pp-nav a:hover::before { background: var(--pc); transform: scale(1.3); }
.pp-header--sidebar .pp-nav .pp-btn {
  margin: 12px 18px 0; justify-content: center; white-space: nowrap;
  border-radius: 12px;
}
.pp-header--sidebar .pp-nav .pp-btn::before { display: none; }
/* Sadržaj se pomjera udesno za širinu collapsed sidebar-a */
body.hstyle-sidebar { padding-left: 92px; }
body.hstyle-sidebar .pp-hero--dark,
body.hstyle-sidebar .dms-hero,
body.hstyle-sidebar .sp-hero { margin-left: 0; }

/* ==========================================================================
   3) MINIMAL (logo + hamburger → fullscreen overlay)
   ========================================================================== */
.pp-header--minimal {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: transparent; border: 0; box-shadow: none;
  transition: background .25s, backdrop-filter .25s;
}
.pp-header--minimal.pp-header--scrolled {
  background: var(--hdr-bg); backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--hdr-border);
}
.pp-header--minimal .pp-header__inner { height: 92px; }
.pp-header--minimal .pp-nav { display: none; }
.pp-header--minimal .pp-burger {
  display: flex; order: 2; gap: 6px; padding: 10px;
}
.pp-header--minimal .pp-burger span {
  width: 28px; height: 2px; background: var(--hdr-burger); border-radius: 2px;
}

/* Fullscreen overlay — strukturiran: head / nav / foot */
.pp-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: var(--hdr-bg-solid);
  display: flex; flex-direction: column;
  padding: 22px 7% 36px;
  opacity: 0; visibility: hidden; transform: translateY(-12px);
  transition: opacity .35s, visibility .35s, transform .35s;
  overflow-y: auto;
}
.pp-overlay::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; z-index: -1;
  background: radial-gradient(circle at 100% 0%, rgba(45,91,214,.10), transparent 55%);
}
body.product-dms .pp-overlay::before { background: radial-gradient(circle at 100% 0%, rgba(22,160,133,.12), transparent 55%); }
body.product-smart .pp-overlay { background: linear-gradient(165deg, #08101f, #050a14); }
body.product-smart .pp-overlay::before { background: radial-gradient(circle at 100% 0%, rgba(14,165,233,.18), transparent 55%); }
.pp-overlay.pp-overlay--open { opacity: 1; visibility: visible; transform: translateY(0); }

/* Head: logo + close */
.pp-overlay__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: auto; }
.pp-overlay__logo { display: inline-flex; align-items: center; }
.pp-overlay__logo img { height: 42px; width: auto; }
body.product-smart .pp-overlay__logo img { filter: brightness(0) invert(1); }
.pp-overlay__logo .pp-logo__text { font-size: 22px; font-weight: 800; color: var(--pc); }
.pp-overlay__close {
  width: 46px; height: 46px; border-radius: 50%;
  background: var(--hdr-bg); border: 1px solid var(--hdr-border); cursor: pointer;
  display: grid; place-items: center; font-size: 22px; color: var(--hdr-text);
  transition: background .2s, transform .2s;
}
.pp-overlay__close:hover { background: var(--pc); color: #fff; transform: rotate(90deg); }

/* Nav: lijevo poravnati, numerisani, sa strelicom */
.pp-overlay__nav { display: flex; flex-direction: column; padding: 40px 0; }
.pp-overlay__nav a {
  display: flex; align-items: center; gap: 18px;
  text-decoration: none; color: var(--hdr-text);
  padding: 18px 0; border-bottom: 1px solid var(--hdr-border);
  transition: padding-left .25s, color .2s;
}
.pp-overlay__nav a:first-child { border-top: 1px solid var(--hdr-border); }
.pp-overlay__nav a:hover { padding-left: 14px; color: var(--pc); }
body.product-smart .pp-overlay__nav a:hover { color: var(--pc-bright, var(--pc)); }
.pp-overlay__n {
  font-family: 'JetBrains Mono', monospace; font-size: 13px; font-weight: 700;
  color: var(--pc); letter-spacing: 1px; opacity: .7;
}
.pp-overlay__t {
  flex: 1; font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(26px, 7vw, 40px); font-weight: 700; letter-spacing: -1px; line-height: 1.1;
}
.pp-overlay__nav a > i { font-size: 22px; color: var(--hdr-muted); transition: transform .25s, color .2s; }
.pp-overlay__nav a:hover > i { color: var(--pc); transform: translate(3px, -3px); }

/* Foot: CTA + kontakt */
.pp-overlay__foot { margin-top: auto; }
.pp-overlay__cta {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: var(--pc); color: #fff !important; text-decoration: none;
  font-size: 17px; font-weight: 700;
  padding: 17px 32px; border-radius: 14px; margin-bottom: 24px;
  transition: transform .2s, box-shadow .2s;
}
.pp-overlay__cta:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(0,0,0,.25); }
.pp-overlay__contact { display: flex; flex-direction: column; gap: 12px; }
.pp-overlay__contact a {
  display: inline-flex; align-items: center; gap: 10px;
  color: var(--hdr-muted); text-decoration: none; font-size: 15px; font-weight: 500;
  transition: color .2s;
}
.pp-overlay__contact a:hover { color: var(--pc); }
.pp-overlay__contact i { font-size: 18px; color: var(--pc); }

/* ==========================================================================
   MOBILE — sve varijante padaju na hamburger + overlay
   ========================================================================== */
@media (max-width: 860px) {
  /* Pill: hamburger umjesto nav-a */
  .pp-header--pill .pp-nav { display: none; }
  .pp-header--pill .pp-burger { display: flex; order: 2; }
  .pp-header--pill .pp-burger span { background: var(--hdr-burger); }
  /* Pill na mobilnom — simetričan padding lijevo/desno, logo fino unutar okvira */
  .pp-header--pill { padding-top: 12px; }
  .pp-header--pill .pp-header__inner { width: 92%; padding: 8px 16px !important; }
  .pp-header--pill .pp-logo__img { height: 38px !important; max-width: 130px !important; }
  .pp-header--pill .pp-burger { padding: 8px; }
}
@media (max-width: 400px) {
  .pp-header--pill .pp-header__inner { padding: 7px 14px !important; }
  .pp-header--pill .pp-logo__img { height: 34px !important; max-width: 118px !important; }

  /* Sidebar: kolaps u top-bar sa hamburgerom */
  .pp-header--sidebar {
    width: 100%; height: 76px; bottom: auto; right: 0;
    border-right: 0; border-bottom: 1px solid var(--hdr-border);
  }
  .pp-header--sidebar:hover { width: 100%; }
  .pp-header--sidebar .pp-header__inner {
    flex-direction: row; align-items: center; justify-content: space-between;
    padding: 0 5%;
  }
  .pp-header--sidebar .pp-logo { margin: 0; padding: 0; }
  .pp-header--sidebar .pp-nav { display: none; }
  .pp-header--sidebar .pp-burger { display: flex; order: 2; }
  body.hstyle-sidebar { padding-left: 0; }

  /* Minimal već radi na hamburger */
}
