/* laseri.hr promo landing - static */
:root{
  --bg: #0f1115;
  --surface: rgba(255,255,255,.06);
  --surface2: rgba(255,255,255,.08);
  --border: rgba(255,255,255,.14);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.74);
  --muted2: rgba(255,255,255,.58);
  /* LGC-like: clean + purple accent */
  /* closer to LGC: deep purple */
  --brand: #6f1a56;
  --brand2: #8a256d;
  --accentSoft: rgba(111,26,86,.14);
  --ok: #16a34a;
  --danger: #e11d48;
  --shadow: 0 18px 50px rgba(15,23,42,.10);
  --radius: 18px;
  --max: 1120px;
  --fontBody: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  --fontHeading: "Montserrat", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  color:var(--text);
  background: #0f1115;
  font-family: var(--fontBody);
  line-height: 1.62;
}

a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:underline; text-underline-offset: 3px; }

.container{ max-width:var(--max); margin:0 auto; padding: 0 18px; }
.stack{ display:flex; flex-direction:column; gap:14px; }
.row{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.spacer{ height: 14px; }

/* Floating left tagline (index) */
.sideTagline{
  position: fixed;
  left: 18px;
  top: 150px;
  z-index: 2;
  pointer-events: none;
  max-width: 520px;
}
.sideTaglineInner{
  font-family: var(--fontHeading);
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
  line-height: .96;
  font-size: clamp(26px, 2.4vw, 46px);
  color: rgba(255,255,255,.26);
}
.sideTaglineLine{
  display: block;
}
.sideTaglineLine.isDarkText{
  color: rgba(15,23,42,.78);
}
@media (max-width: 1180px){
  .sideTagline{ display:none; }
}

.siteHeader{
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(12px);
  background: rgba(15,17,21,.75);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.siteHeader::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height: 3px;
  background: linear-gradient(90deg, rgba(111,26,86,1), rgba(138,37,109,1));
  opacity: .95;
}
.siteHeaderInner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-family: var(--fontHeading);
  font-weight: 800;
  letter-spacing: .2px;
}
.brandDot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  box-shadow: 0 0 0 4px rgba(138,37,109,.22);
}
.nav{
  display:flex;
  align-items:center;
  gap: 18px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.nav a{
  color: rgba(255,255,255,.82);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 8px 10px;
  border-radius: 10px;
}
.nav a[aria-current="page"]{
  background: transparent;
  color: rgba(255,255,255,.92);
  box-shadow: inset 0 -2px 0 rgba(138,37,109,.80);
}

.pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.86);
  font-size: 13px;
}
.pill strong{ color: var(--text); }

.pillMultiline{
  display:flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.1;
  min-width: 160px;
}
.pillSep{
  opacity: .85;
  font-weight: 900;
  letter-spacing: .02em;
}

.hero{
  padding: 34px 0 10px;
  position: relative;
}
.hero::before{
  content:"";
  position:absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(1200px 520px at 20% 0%, rgba(111,26,86,.18), transparent 62%),
    radial-gradient(900px 420px at 85% 15%, rgba(255,255,255,.06), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}
.heroVideo{
  aspect-ratio: 16 / 9;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.45);
  margin-bottom: 18px;
}
.heroVideoEl{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  background: rgba(0,0,0,.55);
}
.heroPanel{
  background: linear-gradient(180deg, rgba(111,26,86,1), rgba(103,22,80,1));
  border-radius: 34px;
  padding: 26px;
  box-shadow: 0 26px 70px rgba(15,23,42,.18);
  position: relative;
  overflow: hidden;
}
.heroPanel::before{
  content:"";
  position:absolute;
  inset: -120px -80px auto auto;
  width: 360px;
  height: 360px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.22), transparent 62%);
  transform: rotate(12deg);
}
.heroPanel::after{
  content:"";
  position:absolute;
  inset: auto auto -180px -120px;
  width: 420px;
  height: 420px;
  border-radius: 999px;
  background: radial-gradient(circle at 40% 40%, rgba(255,255,255,.18), transparent 64%);
}
.heroPanel *{ position: relative; }
.heroHeading{ margin: 0 0 12px; }
.heroHeadingTitle{ margin: 0; }
.heroPanel .h1,
.heroPanel .sectionTitle{ color: rgba(255,255,255,.96); }
.heroPanel .lead{ color: rgba(255,255,255,.82); }
.heroPanel .oldPrice{ color: rgba(255,255,255,.62); text-decoration-color: rgba(255,255,255,.50); }
.heroPanel .newPrice{ color: rgba(255,255,255,.96); }
.heroPanel .pill{
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.14);
  color: #1E1E1E;
}
.heroPanel .pill strong{ color: #1E1E1E; }
.heroPanel .notice{
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.82);
}
.heroPanel .btn{
  border-color: rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  color: rgba(255,255,255,.92);
}
.heroPanel .btnPrimary{
  background: rgba(255,255,255,.94);
  color: rgba(111,26,86,1);
  border-color: rgba(255,255,255,.34);
}
.heroPanel .carouselImg{
  background: rgba(255,255,255,.98);
}
.heroPanel .card{
  background: transparent;
  border-color: rgba(255,255,255,.18);
  box-shadow: none;
}
.heroPanel .heroBundleImg{
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.98);
}
.heroPanel a{
  color: rgba(255,255,255,.94);
}
.heroPanel a.btnPrimary{
  color: rgba(111,26,86,1);
}
.heroCover{
  border-radius: var(--radius);
  overflow:hidden;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 50px rgba(15,23,42,.10);
  margin-bottom: 18px;
}
.heroCover img{
  width: 100%;
  height: auto;
  display:block;
}
.heroCoverBar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 10px 14px;
  border-top: 1px solid rgba(15,23,42,.08);
  color: var(--muted);
  font-size: 13px;
}
.heroCoverBar b{ color: var(--text); }
.heroGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  align-items: stretch;
}
.promoCard .pill{
  background: rgba(255,255,255,.88);
}
.promoCard .h1{ margin-bottom: 8px; }
.promoCard.cardPad{ padding: 26px; }
.promoCard{
  display:flex;
  flex-direction:column;
  gap: 16px;
  height: 100%;
}
.promoCard .lead{ margin-top: 0; margin-bottom: 0; }
.promoCard .promoTopRow{
  justify-content: space-between;
  width: 100%;
  margin-top: 0;
}
.promoCard .priceBlock{
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  margin-top: 0;
}
.promoCard .oldPrice{
  font-size: 18px;
  line-height: 1.1;
}
.promoCard .newPrice{
  font-size: clamp(32px, 3.4vw, 42px);
  line-height: 1.05;
}
.promoCard .notice{ margin-top: 0 !important; }
.promoCard .ctaRow{ margin-top: 0 !important; }

.leafletInline{
  display:flex;
  flex-direction: column;
  align-items:flex-start;
  gap: 10px;
  padding-top: 2px;
}
.leafletInlineLink{
  display:block;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
}
.leafletInlineThumb{
  width: 400px;
  max-width: 100%;
  aspect-ratio: 210 / 297; /* A4 */
  height: auto;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.92);
}

.heroBundleImg{
  width: 100%;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  display:block;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.96);
  box-shadow: 0 18px 44px rgba(0,0,0,.25);
}
.card{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  border-radius: var(--radius);
  box-shadow: 0 16px 44px rgba(0,0,0,.22);
}
.cardPad{ padding: 20px; }

.h1{
  font-family: var(--fontHeading);
  font-size: clamp(28px, 3.8vw, 44px);
  line-height: 1.10;
  margin: 0;
  letter-spacing: -0.6px;
}
.lead{
  margin: 10px 0 0;
  color: var(--muted);
  max-width: 58ch;
  font-size: 15px;
}

.priceBlock{
  display:flex;
  align-items: baseline;
  gap: 14px;
  flex-wrap:wrap;
  margin-top: 18px;
}
.oldPrice{
  color: rgba(255,255,255,.62);
  text-decoration: line-through;
  text-decoration-thickness: 2px;
  text-decoration-color: rgba(255,255,255,.50);
  font-size: 20px;
  font-variant-numeric: tabular-nums;
}
.newPrice{
  font-size: clamp(34px, 4vw, 44px);
  font-weight: 900;
  letter-spacing: -0.4px;
  font-variant-numeric: tabular-nums;
}
.currency{
  font-weight: 800;
  font-size: .92em;
  opacity: .92;
}

.ctaRow{ margin-top: 16px; display:flex; gap: 12px; flex-wrap:wrap; }
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 11px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  font-weight: 800;
  cursor:pointer;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.92);
  font-size: 14px;
}
.btn:hover{ filter: brightness(1.06); text-decoration:none; }
.btnPrimary{
  border-color: rgba(255,255,255,.22);
  background: rgba(255,255,255,.92);
  color: rgba(111,26,86,1);
}

.btnSmall{
  padding: 9px 12px;
  font-size: 13px;
}

.navCta{
  background: rgba(111,26,86,1) !important;
  color: rgba(255,255,255,.96) !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(111,26,86,.35) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-size: 14px !important;
}
.btnGhost{
  background: transparent;
}
.btn:disabled{
  opacity: .65;
  cursor: not-allowed;
}

.heroMedia{
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.heroMedia img{
  width: 100%;
  height: 100%;
  max-height: 340px;
  object-fit: contain;
  display:block;
  padding: 18px 18px 0;
}
.leafletThumb{
  width: 100%;
  display:block;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 12px 30px rgba(15,23,42,.10);
}

.carousel{
  position: relative;
  overflow: hidden;
}
.carousel.card{
  border: 0;
  box-shadow: none;
  background: transparent;
}
.carousel.cardPad{
  padding: 0;
}
.carouselViewport{
  overflow: hidden;
  border-radius: calc(var(--radius) - 2px);
  width: 100%;
  max-width: 100%;
}
.carouselTrack{
  display:flex;
  gap: 0;
  transform: translateX(0);
  transition: transform 320ms ease;
  will-change: transform;
  width: 100%;
}
.carouselSlide{
  flex: 0 0 100%;
  width: 100%;
  max-width: 100%;
  padding: 0;
  box-sizing: border-box;
}
.carouselImg{
  width: 100%;
  max-width: 100%;
  height: min(420px, 55vw);
  object-fit: contain;
  display:block;
  border-radius: 0;
  background: transparent;
  border: 0;
}
.carouselControls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding-top: 10px;
}
.iconBtn{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.90);
  cursor:pointer;
  font-weight: 900;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.iconBtn:hover{ filter: brightness(1.03); }
.dots{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  flex: 1;
}
.dot{
  width: 9px;
  height: 9px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.40);
  background: rgba(255,255,255,.22);
  cursor:pointer;
}
.dot[aria-current="true"]{
  background: linear-gradient(90deg, rgba(255,59,141,.75), rgba(0,162,255,.65));
  border-color: rgba(15,23,42,.08);
  width: 22px;
}

/* Dots inside the purple hero area need extra contrast */
.heroPanel .dot{
  border-color: rgba(255,255,255,.58);
  background: rgba(255,255,255,.32);
}

.worksGrid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.workItem{
  padding: 0;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.90);
  border-radius: 16px;
  overflow:hidden;
  cursor:pointer;
  box-shadow: 0 10px 26px rgba(15,23,42,.08);
}
.workItem:hover{ transform: translateY(-1px); transition: transform 160ms ease; }
.workItem img{
  width: 100%;
  height: 190px;
  object-fit: cover;
  display:block;
}

.lightbox{
  position: fixed;
  inset: 0;
  z-index: 999;
  display:none;
  align-items:center;
  justify-content:center;
  padding: 22px;
  background: rgba(2,6,23,.72);
}
.lightbox[aria-hidden="false"]{ display:flex; }
.lightboxInner{
  width: min(1100px, 96vw);
  max-height: 88vh;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
}
.lightboxBar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 10px 12px;
  color: rgba(255,255,255,.92);
  border-bottom: 1px solid rgba(255,255,255,.12);
}
.lightboxImg{
  width: 100%;
  height: 100%;
  max-height: calc(88vh - 54px);
  object-fit: contain;
  display:block;
  background: rgba(0,0,0,.35);
}
.lightboxBtn{
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.92);
}

.tableWrap{
  overflow:auto;
  -webkit-overflow-scrolling: touch;
}
.specTable{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 720px;
  font-size: 14px;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  overflow:hidden;
  background: rgba(255,255,255,.88);
}
.specTable th,
.specTable td{
  padding: 10px 12px;
  border-bottom: 1px solid rgba(15,23,42,.08);
  vertical-align: top;
}
.specTable tr:last-child td{ border-bottom: 0; }
.specTable th{
  text-align:left;
  font-weight: 900;
  color: rgba(15,23,42,.86);
  background: rgba(15,23,42,.03);
  position: sticky;
  top: 0;
}
.specGroup{
  font-weight: 900;
  color: rgba(15,23,42,.82);
  background: linear-gradient(90deg, rgba(255,59,141,.08), rgba(0,162,255,.06));
}
.specKey{ color: rgba(15,23,42,.78); font-weight: 800; width: 32%; }
.specVal{ color: rgba(15,23,42,.90); }

@media (max-width: 920px){
  .worksGrid{ grid-template-columns: repeat(2, 1fr); }
  .workItem img{ height: 160px; }
}
.heroMediaFooter{
  padding: 14px 18px 18px;
  border-top: 1px solid rgba(15,23,42,.08);
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  color: var(--muted);
  font-size: 13px;
}
.kv{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.70);
}
.kv b{ color: var(--text); }

.section{ padding: 22px 0; }

/* Full-width "bands" (used on index like LGC) */
.band{
  padding: 54px 0;
}
.bandDark{
  background: #1E1E1E;
  color: rgba(255,255,255,.92);
}
.bandPurple{
  background: linear-gradient(180deg, rgba(111,26,86,1), rgba(103,22,80,1));
  color: rgba(255,255,255,.92);
}
.bandLight{
  background: #f3eef2;
  color: rgba(15,23,42,.92);
}
.bandMid{
  background: #f6f7f8;
  color: rgba(15,23,42,.92);
}
.bandRoundBottom{
  border-bottom-left-radius: 52px;
  border-bottom-right-radius: 52px;
}
.bandDark .sectionTitle,
.bandPurple .sectionTitle{ color: rgba(255,255,255,.94); }
.bandLight .sectionTitle,
.bandMid .sectionTitle{ color: rgba(15,23,42,.92); }
.bandDark .lead,
.bandDark p,
.bandDark li{ color: rgba(255,255,255,.78); }
.bandPurple .lead,
.bandPurple p,
.bandPurple li{ color: rgba(255,255,255,.84); }
.bandLight .lead,
.bandLight p,
.bandLight li,
.bandMid .lead,
.bandMid p,
.bandMid li{ color: rgba(15,23,42,.74); }

@media (max-width: 920px){
  .band{ padding: 22px 0; }
}
.sectionTitle{
  font-size: 20px;
  margin: 0 0 10px;
  letter-spacing: -0.2px;
}
.segment{
  border-radius: 34px;
  padding: 22px;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 52px rgba(0,0,0,.28);
}
.segment + .segment{ margin-top: 18px; }
.segmentGray{
  background: #1E1E1E;
  border-color: rgba(255,255,255,.10);
}
.segmentLight{
  background: rgba(255,255,255,.88);
  border-color: rgba(15,23,42,.10);
  box-shadow: 0 18px 52px rgba(15,23,42,.10);
}
.segmentLight .sectionTitle,
.segmentLight .h1{ color: rgba(15,23,42,.92); }
.segmentLight .lead,
.segmentLight p,
.segmentLight li{ color: rgba(15,23,42,.74); }

.segmentPurple{
  background: linear-gradient(180deg, rgba(111,26,86,1), rgba(103,22,80,1));
  border-color: rgba(255,255,255,.14);
  box-shadow: 0 26px 70px rgba(15,23,42,.18);
}
.segmentPurple .sectionTitle,
.segmentPurple .h1{ color: rgba(255,255,255,.96); }
.segmentPurple .lead,
.segmentPurple p,
.segmentPurple li{ color: rgba(255,255,255,.84); }
.segmentPurple .feature{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.14);
}
.segmentPurple .feature h3{ color: rgba(255,255,255,.96); }
.segmentPurple .feature p,
.segmentPurple .feature li{ color: rgba(255,255,255,.82); }
.segmentPurple .specTable{
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
}
.segmentPurple .specTable th{
  background: rgba(255,255,255,.10);
  color: rgba(255,255,255,.92);
  border-bottom-color: rgba(255,255,255,.14);
}
.segmentPurple .specTable td{
  border-bottom-color: rgba(255,255,255,.10);
  color: rgba(255,255,255,.88);
}
.segmentPurple .specKey{ color: rgba(255,255,255,.78); }
.segmentPurple .specGroup{
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.92);
}

.segmentGray .sectionTitle,
.segmentGray .h1{ color: rgba(255,255,255,.94); }
.segmentGray .lead,
.segmentGray p,
.segmentGray li{ color: rgba(255,255,255,.78); }
.segmentGray .feature{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
}
.segmentGray .feature h3{ color: rgba(255,255,255,.92); }
.segmentGray .feature p,
.segmentGray .feature li{ color: rgba(255,255,255,.76); }
.segmentGray .notice{
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.76);
}
.segmentGray .notice strong{ color: rgba(255,255,255,.92); }
.segmentGray .notice a{
  color: rgba(255,255,255,.92);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.segmentGray .leafletThumb{ border-color: rgba(255,255,255,.14); }
.segmentGray .workItem{ border-color: rgba(255,255,255,.12); background: rgba(255,255,255,.04); }

.faqXtPanel{
  margin-top: 22px;
  padding: 0;
  border-radius: calc(var(--radius) + 2px);
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(160deg, rgba(111,26,86,.20) 0%, rgba(0,0,0,.22) 45%, rgba(0,0,0,.20) 100%);
  box-shadow: 0 20px 48px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.05);
  overflow: hidden;
}
.faqXtHead{
  margin: 0;
  padding: 22px 22px 18px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04) 0%, transparent 100%);
}
.faqXtTitle{
  margin: 0;
  font-family: var(--fontHeading);
  font-size: clamp(20px, 2.1vw, 24px);
  font-weight: 800;
  letter-spacing: -0.4px;
  color: rgba(255,255,255,.96);
  line-height: 1.2;
  padding-left: 14px;
  border-left: 4px solid var(--brand2);
}
.faqList{
  padding: 20px 22px 26px;
  border-radius: 0 0 14px 14px;
  background: linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.04) 100%);
  border-top: 1px solid rgba(255,255,255,.05);
}
.faqList .faqItem{ margin-bottom: 11px; }

.faqItem{
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px;
  margin-bottom: 8px;
  background: rgba(0,0,0,.20);
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s, background .2s;
}
.faqItem:hover{
  border-color: rgba(255,255,255,.16);
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
}
.faqItem--accent{
  background: linear-gradient(135deg, rgba(111,26,86,.12) 0%, rgba(0,0,0,.18) 100%);
  border-color: rgba(138,37,109,.32);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}
.faqItem--accent[open]{
  border-color: rgba(138,37,109,.45);
}
.faqItem summary{
  cursor: pointer;
  position: relative;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.4;
  padding: 14px 42px 14px 16px;
  list-style: none;
  color: rgba(255,255,255,.90);
  font-family: var(--fontHeading);
}
.faqItem summary::after{
  content: "";
  position: absolute;
  right: 16px;
  top: 50%;
  width: 9px;
  height: 9px;
  margin-top: -1px;
  border-right: 2px solid rgba(255,255,255,.45);
  border-bottom: 2px solid rgba(255,255,255,.45);
  transform: translateY(-50%) rotate(45deg);
  transition: transform .22s ease, border-color .2s;
  pointer-events: none;
}
.faqItem[open] summary::after{
  margin-top: 2px;
  border-color: rgba(255,255,255,.65);
  transform: translateY(-50%) rotate(225deg);
}
.faqItem summary::-webkit-details-marker{ display: none; }
.faqItem[open] summary{
  border-bottom: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.98);
  background: rgba(0,0,0,.12);
}
.faqA{
  padding: 0 16px 16px;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255,255,255,.78);
}
.faqA p{ margin: 0 0 10px; }
.faqA p:last-child{ margin-bottom: 0; }
.faqA strong{ color: rgba(255,255,255,.92); }
.faqA a{
  color: rgba(255,255,255,.90);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.faqA ul{ margin: 8px 0 0; padding-left: 1.2em; }
.faqA li{ margin: 4px 0; }

.faqList .faqItem:last-child{ margin-bottom: 0; }

.segmentGray .faqA,
.segmentGray .faqA li{ color: rgba(255,255,255,.78); }

.eyebrow{
  text-transform: uppercase;
  letter-spacing: .18em;
  font-weight: 900;
  font-size: 12px;
  color: rgba(15,23,42,.55);
}
.prose{
  max-width: 70ch;
}
.prose h2{
  margin: 14px 0 8px;
  font-size: 22px;
  letter-spacing: -0.2px;
}
.prose h3{
  margin: 16px 0 8px;
  font-size: 18px;
  letter-spacing: -0.2px;
}
.prose p{
  margin: 0 0 14px;
  color: var(--muted);
  font-size: 16px;
}
.grid3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.feature{
  padding: 16px;
  border-radius: var(--radius);
  border: 1px solid rgba(15,23,42,.08);
  background: rgba(255,255,255,.76);
}
.feature h3{
  margin:0 0 6px;
  font-size: 16px;
}
.feature p{
  margin:0;
  color: var(--muted);
  font-size: 14px;
}
.feature ul{
  margin: 10px 0 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 14px;
}
.feature li{ margin: 6px 0; }

.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.field{
  display:flex;
  flex-direction:column;
  gap: 6px;
}
.field label{
  font-size: 13px;
  color: var(--muted);
  font-weight: 700;
}
.field input,.field textarea{
  appearance:none;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.92);
  color: rgba(15,23,42,.92);
  border-radius: 14px;
  padding: 12px 12px;
  outline: none;
  font-size: 15px;
}
.field input:focus,.field textarea:focus{
  border-color: rgba(0,162,255,.55);
  box-shadow: 0 0 0 4px rgba(0,162,255,.14);
}
.field textarea{ min-height: 140px; resize: vertical; }
.span2{ grid-column: 1 / -1; }

.notice{
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.76);
  padding: 12px 14px;
  color: rgba(15,23,42,.78);
  font-size: 14px;
}
.notice a{ color: rgba(15,23,42,.92); text-decoration: underline; text-underline-offset: 3px; }
.noticeOk{ border-color: rgba(52,211,153,.35); }
.noticeErr{ border-color: rgba(251,113,133,.40); }

/* Kontakt: status iskaznica skrivena dok nema poruke (nema „sive trake“) */
.formStatus[hidden]{
  display: none;
}
.formStatus.notice{
  margin: 0 0 12px;
}
.formStatus--info{
  border-color: rgba(0,162,255,.30);
  background: rgba(255,255,255,.88);
}

.siteFooter{
  border-top: 1px solid rgba(255,255,255,.10);
  margin-top: 26px;
  padding: 22px 0 30px;
  color: var(--muted2);
  font-size: 13px;
  background: #1E1E1E;
}
.footerTagline{
  margin-top: 8px;
  max-width: 52ch;
  color: rgba(255,255,255,.70);
  font-size: 13px;
  line-height: 1.55;
}
.footerTagline a{
  color: rgba(255,255,255,.88);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.footerTagline a:hover{
  color: #fff;
}

/* LGC-like "O nama" bands */
.aboutBand{
  padding: 54px 0;
}
.aboutBandLight{
  background: #f3eef2;
  color: rgba(15,23,42,.92);
  border-bottom-left-radius: 52px;
  border-bottom-right-radius: 52px;
}
.aboutBandMid{
  background: #f6f7f8;
  color: rgba(15,23,42,.92);
}
.aboutBandDark{
  background: #1E1E1E;
  color: rgba(255,255,255,.92);
}
.aboutBand .eyebrow{
  color: rgba(111,26,86,.90);
}
.aboutTitle{
  font-family: var(--fontHeading);
  font-weight: 900;
  letter-spacing: -0.6px;
  line-height: 1.05;
  margin: 8px 0 10px;
  font-size: clamp(28px, 3.4vw, 46px);
  text-transform: uppercase;
  color: rgba(111,26,86,.95);
}
.aboutLead{
  margin: 10px 0 0;
  max-width: 56ch;
  color: rgba(15,23,42,.74);
  font-size: 14px;
  line-height: 1.7;
}
.aboutGrid{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 34px;
  align-items: center;
}
.aboutGridReverse{
  grid-template-columns: .95fr 1.05fr;
}
.aboutText{ max-width: 68ch; }
.aboutH2{
  font-family: var(--fontHeading);
  font-size: 22px;
  letter-spacing: -0.2px;
  margin: 0 0 10px;
}
.aboutP{
  margin: 0 0 14px;
  color: rgba(255,255,255,.72);
  line-height: 1.75;
  font-size: 14px;
}
.aboutBandLight .aboutP,
.aboutBandMid .aboutP{
  color: rgba(15,23,42,.74);
}
.aboutBandLight .aboutH2,
.aboutBandMid .aboutH2{
  color: rgba(15,23,42,.92);
}
.aboutBandDark .aboutH2{
  color: rgba(255,255,255,.92);
}
.aboutMedia{
  display: flex;
  justify-content: center;
}
.aboutHeroImg{
  width: min(520px, 100%);
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 34px 34px 90px 34px;
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
  background: #fff;
}
.aboutHeroImgAlt{
  border-radius: 34px 90px 34px 34px;
}
.aboutCircleImg{
  width: min(380px, 84%);
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 999px;
  border: 4px solid rgba(111,26,86,.75);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  background: #000;
}
.aboutBandDark .notice{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.14);
  color: rgba(255,255,255,.76);
}
.aboutBandDark .notice a{ color: rgba(255,255,255,.92); }

/* Ensure contact boxes remain high-contrast on the mid (light) band */
.aboutBandMid .notice{
  background: rgba(255,255,255,.86);
  border-color: rgba(15,23,42,.12);
  color: rgba(15,23,42,.78);
}
.aboutBandMid .notice strong{ color: rgba(15,23,42,.92); }
.aboutBandMid .notice a{ color: rgba(15,23,42,.92); }

@media (max-width: 920px){
  .aboutBand{ padding: 34px 0; }
  .aboutGrid,
  .aboutGridReverse{ grid-template-columns: 1fr; gap: 18px; }
  .aboutMedia{ justify-content: flex-start; }
  .aboutHeroImg{ border-radius: 26px; }
}
.footerGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
  align-items: start;
}
.footerGrid a{ color: var(--muted); }
.small{ font-size: 12px; color: var(--muted2); }

@media (max-width: 920px){
  .container{ padding: 0 10px; }
  .heroPanel{ padding: 14px; border-radius: 22px; }
  .segment{ padding: 16px; border-radius: 26px; }
  .heroGrid{ grid-template-columns: 1fr; align-items: stretch; min-width: 0; }
  .heroGrid > *{ min-width: 0; }
  .promoCard{ height: auto; }
  .heroHeadingTitle{
    font-size: clamp(22px, 6.2vw, 34px);
    letter-spacing: -0.4px;
  }
  .promoCard .promoTopRow{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .promoCard .pill{ width: 100%; justify-content: center; }
  .promoCard .ctaRow{ flex-direction: column; align-items: stretch; }
  .promoCard .ctaRow .btn{ width: 100%; justify-content: center; }
  .leafletInline{ width: 100%; }
  .leafletInlineLink{ width: 100%; padding: 10px; }
  .leafletInlineThumb{ width: 100%; max-width: 400px; }
  .heroBundleImg{
    max-height: min(420px, 62vh);
    width: 100%;
  }
  .carousel,
  .carouselViewport,
  .carouselTrack,
  .carouselSlide{
    min-width: 0;
  }
  .carouselImg{
    width: 100%;
    height: auto;
    max-height: min(58vh, 520px);
    object-fit: contain;
  }
  .carouselViewport{
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .carouselControls{
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding-top: 10px;
  }
  .carouselControls .iconBtn{
    width: 44px;
    height: 44px;
    flex: 0 0 auto;
  }
  .dots{
    flex: 1 1 auto;
    min-width: 0;
    justify-content: center;
    flex-wrap: wrap;
    row-gap: 6px;
    column-gap: 6px;
  }
  .dot{
    width: 8px;
    height: 8px;
  }
  .dot[aria-current="true"]{
    width: 18px;
  }
  .cardPad{ padding: 14px; }
  .promoCard.cardPad{ padding: 16px; }
  .grid3{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .form{ grid-template-columns: 1fr; }
  .footerGrid{ grid-template-columns: 1fr; }
  .siteHeaderInner{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    padding: 12px 0;
  }
  .brand{
    width: 100%;
    justify-content: center;
  }
  .nav{
    width: 100%;
    justify-content: flex-end;
    gap: 10px 14px;
    flex-wrap: wrap;
  }
  .nav a{
    padding: 8px 6px;
    font-size: 12px;
    letter-spacing: .04em;
  }
  .navCta{ padding: 9px 12px !important; font-size: 13px !important; }
  .faqXtHead{ padding: 18px 16px 16px; }
  .faqXtTitle{ font-size: clamp(18px, 4.5vw, 22px); padding-left: 12px; border-left-width: 3px; }
  .faqList{ padding: 16px 16px 22px; }
}
